index 718ff68a3ae6427474ac3faa0f3214cfe5453e15..d6d65d32cf2a9c0ba220880097d42a020a0c3700 100644 (file)
--- a/src/game/g_monsters.pas
+++ b/src/game/g_monsters.pas
}
type
- ADirectedAnim = Array of Array [TDirection.D_LEFT..TDirection.D_RIGHT] of TAnimationState;
+ ADirectedAnim = Array of Array [TDirection.D_LEFT..TDirection.D_RIGHT] of TAnimState;
PMonster = ^TMonster;
TMonster = class{$IFDEF USE_MEMPOOL}(TPoolObject){$ENDIF}
{$ENDIF}
FFirePainTime: Integer;
FFireAttacker: Word;
- vilefire: TAnimationState;
+ vilefire: TAnimState;
mProxyId: Integer; // node in dyntree or -1
mArrIdx: Integer; // in gMonsters
property StartID: Integer read FStartID;
- property VileFireAnim: TAnimationState read vilefire;
+ property VileFireAnim: TAnimState read vilefire;
property DirAnim: ADirectedAnim read FAnim;
published
ANIM_ATTACK = 4;
ANIM_ATTACK2 = 5;
ANIM_PAIN = 6;
+ ANIM_LAST = ANIM_PAIN;
// Таблица характеристик монстров:
MONSTERTABLE: Array [MONSTER_DEMON..MONSTER_MAN] of
SetLength(FAnim, Length(ANIMTABLE));
for a := ANIM_SLEEP to ANIM_PAIN do
begin
- FAnim[a, TDirection.D_RIGHT] := TAnimationState.Create(ANIMTABLE[a].loop, MONSTER_ANIMTABLE[MonsterType].AnimSpeed[a], MONSTER_ANIMTABLE[MonsterType].AnimCount[a]);
- FAnim[a, TDirection.D_LEFT] := TAnimationState.Create(ANIMTABLE[a].loop, MONSTER_ANIMTABLE[MonsterType].AnimSpeed[a], MONSTER_ANIMTABLE[MonsterType].AnimCount[a]);
+ FAnim[a, TDirection.D_RIGHT] := TAnimState.Create(ANIMTABLE[a].loop, MONSTER_ANIMTABLE[MonsterType].AnimSpeed[a], MONSTER_ANIMTABLE[MonsterType].AnimCount[a]);
+ FAnim[a, TDirection.D_LEFT] := TAnimState.Create(ANIMTABLE[a].loop, MONSTER_ANIMTABLE[MonsterType].AnimSpeed[a], MONSTER_ANIMTABLE[MonsterType].AnimCount[a]);
end;
if MonsterType = MONSTER_VILE then
- vilefire := TAnimationState.Create(True, 2, 8);
+ vilefire := TAnimState.Create(True, 2, 8);
end;
function TMonster.Damage(aDamage: Word; VelX, VelY: Integer; SpawnerUID: Word; t: Byte): Boolean;
begin
for a := 0 to High(FAnim) do
begin
- FAnim[a, TDirection.D_LEFT].Free();
- FAnim[a, TDirection.D_RIGHT].Free();
+ FAnim[a, TDirection.D_LEFT].Invalidate;
+ FAnim[a, TDirection.D_RIGHT].Invalidate;
end;
- vilefire.Free();
+ vilefire.Invalidate;
if (mProxyId <> -1) then
begin
// Если анимация новая - перезапускаем её:
if FCurAnim <> Anim then
- if FAnim[Anim, FDirection] <> nil then
+ if FAnim[Anim, FDirection].IsValid() then
begin
FAnim[Anim, FDirection].Reset();
FCurAnim := Anim;
end;
// Если есть анимация огня колдуна - пусть она идет:
- if vilefire <> nil then
+ if vilefire.IsValid() then
vilefire.Update();
// Состояние - Умирает и текущая анимация проиграна:
if (FState = MONSTATE_DIE) and
- (FAnim[FCurAnim, FDirection] <> nil) and
+ (FAnim[FCurAnim, FDirection].IsValid()) and
(FAnim[FCurAnim, FDirection].Played) then
begin
// Умер:
// Совершение атаки и стрельбы:
if (FState = MONSTATE_ATTACK) or (FState = MONSTATE_SHOOT) then
- if (FAnim[FCurAnim, FDirection] <> nil) then
+ if (FAnim[FCurAnim, FDirection].IsValid()) then
// Анимация атаки есть - можно атаковать
if (FAnim[FCurAnim, FDirection].Played) then
begin // Анимация атаки закончилась => переходим на шаг
FObj.Vel.X := oldvelx;
// Если есть анимация, то пусть она идет:
- if FAnim[FCurAnim, FDirection] <> nil then
+ if FAnim[FCurAnim, FDirection].IsValid() then
FAnim[FCurAnim, FDirection].Update();
end;
end;
// Если есть анимация огня колдуна - пусть она идет:
- if vilefire <> nil then
+ if vilefire.IsValid() then
vilefire.Update();
// Состояние - Умирает и текущая анимация проиграна:
if (FState = MONSTATE_DIE) and
- (FAnim[FCurAnim, FDirection] <> nil) and
+ (FAnim[FCurAnim, FDirection].IsValid()) and
(FAnim[FCurAnim, FDirection].Played) then
begin
// Умер:
// Совершение атаки и стрельбы:
if (FState = MONSTATE_ATTACK) or (FState = MONSTATE_SHOOT) then
- if (FAnim[FCurAnim, FDirection] <> nil) then
+ if (FAnim[FCurAnim, FDirection].IsValid()) then
// Анимация атаки есть - можно атаковать
if (FAnim[FCurAnim, FDirection].Played) then
begin // Анимация атаки закончилась => переходим на шаг
FObj.Vel.X := oldvelx;
// Если есть анимация, то пусть она идет:
- if FAnim[FCurAnim, FDirection] <> nil then
+ if FAnim[FCurAnim, FDirection].IsValid() then
FAnim[FCurAnim, FDirection].Update();
end;
// Объект монстра
Obj_SaveState(st, @FObj);
// Есть ли анимация огня колдуна
- anim := (vilefire <> nil);
+ anim := (vilefire.IsValid());
utils.writeBool(st, anim);
// Если есть - сохраняем:
if anim then vilefire.SaveState(st, 0, False);
for i := ANIM_SLEEP to ANIM_PAIN do
begin
// Есть ли левая анимация
- anim := (FAnim[i, TDirection.D_LEFT] <> nil);
+ anim := (FAnim[i, TDirection.D_LEFT].IsValid());
utils.writeBool(st, anim);
// Если есть - сохраняем
if anim then FAnim[i, TDirection.D_LEFT].SaveState(st, 0, False);
// Есть ли правая анимация
- anim := (FAnim[i, TDirection.D_RIGHT] <> nil);
+ anim := (FAnim[i, TDirection.D_RIGHT].IsValid());
utils.writeBool(st, anim);
// Если есть - сохраняем
if anim then FAnim[i, TDirection.D_RIGHT].SaveState(st, 0, False);
// Если есть - загружаем:
if anim then
begin
- Assert(vilefire <> nil, 'TMonster.LoadState: no vilefire anim');
+ Assert(vilefire.IsValid(), 'TMonster.LoadState: no vilefire anim');
vilefire.LoadState(st, alpha, blending);
end;
// Анимации
// Если есть - загружаем
if anim then
begin
- Assert(FAnim[i, TDirection.D_LEFT] <> nil, 'TMonster.LoadState: no '+IntToStr(i)+'_left anim');
+ Assert(FAnim[i, TDirection.D_LEFT].IsValid(), 'TMonster.LoadState: no '+IntToStr(i)+'_left anim');
FAnim[i, TDirection.D_LEFT].LoadState(st, alpha, blending);
end;
// Есть ли правая анимация
// Если есть - загружаем
if anim then
begin
- Assert(FAnim[i, TDirection.D_RIGHT] <> nil, 'TMonster.LoadState: no '+IntToStr(i)+'_right anim');
+ Assert(FAnim[i, TDirection.D_RIGHT].IsValid(), 'TMonster.LoadState: no '+IntToStr(i)+'_right anim');
FAnim[i, TDirection.D_RIGHT].LoadState(st, alpha, blending);
end;
end;