From c1fadc464add5e4a2de943234f229dc243b39db4 Mon Sep 17 00:00:00 2001 From: DeaDDooMER <deaddoomer@deadsoftware.ru> Date: Wed, 13 Apr 2022 21:09:33 +0300 Subject: [PATCH] weapons: use TAnimState --- src/game/g_weapons.pas | 83 +++++++++++++++-------------------- src/game/opengl/r_weapons.pas | 6 +-- 2 files changed, 38 insertions(+), 51 deletions(-) diff --git a/src/game/g_weapons.pas b/src/game/g_weapons.pas index 95137cd..cf80f59 100644 --- a/src/game/g_weapons.pas +++ b/src/game/g_weapons.pas @@ -30,7 +30,7 @@ type SpawnerUID: Word; Triggers: DWArray; Obj: TObj; - Animation: TAnimationState; + Animation: TAnimState; Timeout: DWORD; Stopped: Byte; @@ -598,9 +598,9 @@ begin Obj.Rect.Width := SHOT_ROCKETLAUNCHER_WIDTH; Obj.Rect.Height := SHOT_ROCKETLAUNCHER_HEIGHT; - Animation := nil; Triggers := nil; ShotType := WEAPON_ROCKETLAUNCHER; + Animation.Invalidate; end; end; @@ -615,7 +615,7 @@ begin Triggers := nil; ShotType := WEAPON_PLASMA; - Animation := TAnimationState.Create(True, 5, 2); // !!! put values into table + Animation := TAnimState.Create(True, 5, 2); // !!! put values into table end; end; @@ -630,7 +630,7 @@ begin Triggers := nil; ShotType := WEAPON_BFG; - Animation := TAnimationState.Create(True, 6, 2); // !!! put values into table + Animation := TAnimState.Create(True, 6, 2); // !!! put values into table end; end; @@ -645,7 +645,8 @@ begin Triggers := nil; ShotType := WEAPON_FLAMETHROWER; - // Animation := TAnimationState.Create(True, 6, 0); // drawed as gfx + Animation.Invalidate; + // Animation := TAnimState.Create(True, 6, 0); // drawed as gfx end; end; @@ -660,7 +661,7 @@ begin Triggers := nil; ShotType := WEAPON_IMP_FIRE; - Animation := TAnimationState.Create(True, 4, 2); // !!! put values into table + Animation := TAnimState.Create(True, 4, 2); // !!! put values into table end; end; @@ -675,7 +676,7 @@ begin Triggers := nil; ShotType := WEAPON_CACO_FIRE; - Animation := TAnimationState.Create(True, 4, 2); // !!! put values into table + Animation := TAnimState.Create(True, 4, 2); // !!! put values into table end; end; @@ -690,7 +691,7 @@ begin Triggers := nil; ShotType := WEAPON_MANCUB_FIRE; - Animation := TAnimationState.Create(True, 4, 2); // !!! put values into table + Animation := TAnimState.Create(True, 4, 2); // !!! put values into table end; end; @@ -705,7 +706,7 @@ begin Triggers := nil; ShotType := WEAPON_BARON_FIRE; - Animation := TAnimationState.Create(True, 4, 2); // !!! put values into table + Animation := TAnimState.Create(True, 4, 2); // !!! put values into table end; end; @@ -720,7 +721,7 @@ begin Triggers := nil; ShotType := WEAPON_BSP_FIRE; - Animation := TAnimationState.Create(True, 4, 2); // !!! put values into table + Animation := TAnimState.Create(True, 4, 2); // !!! put values into table end; end; @@ -736,7 +737,7 @@ begin Triggers := nil; ShotType := WEAPON_SKEL_FIRE; target := TargetUID; - Animation := TAnimationState.Create(True, 5, 2); // !!! put values into table + Animation := TAnimState.Create(True, 5, 2); // !!! put values into table end; end; end; @@ -1111,18 +1112,8 @@ begin end; procedure g_Weapon_Free(); -var - i: Integer; begin - if Shots <> nil then - begin - for i := 0 to High(Shots) do - if Shots[i].ShotType <> 0 then - Shots[i].Animation.Free(); - - Shots := nil; - end; - + Shots := nil; WaterMap := nil; end; @@ -1662,7 +1653,7 @@ begin ShotType := WEAPON_ROCKETLAUNCHER; throw(find_id, x+dx, y+dy, xd+dx, yd+dy, 12); - Animation := nil; + Animation.Invalidate; triggers := nil; end; @@ -1702,7 +1693,7 @@ begin triggers := nil; target := TargetUID; - Animation := TAnimationState.Create(True, 5, 2); // !!! put values into table + Animation := TAnimState.Create(True, 5, 2); // !!! put values into table end; Shots[find_id].SpawnerUID := SpawnerUID; @@ -1743,7 +1734,7 @@ begin throw(find_id, x+dx, y+dy, xd+dx, yd+dy, 16); triggers := nil; - Animation := TAnimationState.Create(True, 5, 2); // !!! put values into table + Animation := TAnimState.Create(True, 5, 2); // !!! put values into table end; Shots[find_id].SpawnerUID := SpawnerUID; @@ -1784,7 +1775,7 @@ begin throw(find_id, x+dx, y+dy, xd+dx, yd+dy, 16); triggers := nil; - Animation := nil; + Animation.Invalidate; end; Shots[find_id].SpawnerUID := SpawnerUID; @@ -1825,7 +1816,7 @@ begin throw(find_id, x+dx, y+dy, xd+dx, yd+dy, 16); triggers := nil; - Animation := TAnimationState.Create(True, 4, 2); // !!! put values into table + Animation := TAnimState.Create(True, 4, 2); // !!! put values into table end; Shots[find_id].SpawnerUID := SpawnerUID; @@ -1866,7 +1857,7 @@ begin throw(find_id, x+dx, y+dy, xd+dx, yd+dy, 16); triggers := nil; - Animation := TAnimationState.Create(True, 4, 2); // !!! put values into table + Animation := TAnimState.Create(True, 4, 2); // !!! put values into table end; Shots[find_id].SpawnerUID := SpawnerUID; @@ -1907,7 +1898,7 @@ begin throw(find_id, x+dx, y+dy, xd+dx, yd+dy, 16); triggers := nil; - Animation := TAnimationState.Create(True, 4, 2); // !!! put values into table + Animation := TAnimState.Create(True, 4, 2); // !!! put values into table end; Shots[find_id].SpawnerUID := SpawnerUID; @@ -1949,7 +1940,7 @@ begin triggers := nil; - Animation := TAnimationState.Create(True, 4, 2); // !!! put values into table + Animation := TAnimState.Create(True, 4, 2); // !!! put values into table end; Shots[find_id].SpawnerUID := SpawnerUID; @@ -1991,7 +1982,7 @@ begin triggers := nil; - Animation := TAnimationState.Create(True, 4, 2); // !!! put values into table + Animation := TAnimState.Create(True, 4, 2); // !!! put values into table end; Shots[find_id].SpawnerUID := SpawnerUID; @@ -2032,7 +2023,7 @@ begin throw(find_id, x+dx, y+dy, xd+dx, yd+dy, 16); triggers := nil; - Animation := TAnimationState.Create(True, 6, 2); // !!! put values into table + Animation := TAnimState.Create(True, 6, 2); // !!! put values into table end; Shots[find_id].SpawnerUID := SpawnerUID; @@ -2192,7 +2183,7 @@ begin end; // Àíèìàöèÿ ñíàðÿäà: - if Animation <> nil then + if Animation.IsValid() then Animation.Update(); // Äâèæåíèå: @@ -2216,7 +2207,7 @@ begin begin // Íà êëèåíòå ñêîðåå âñåãî è òàê óæå âûïàë. ShotType := 0; - Animation.Free(); + Animation.Invalidate(); Continue; end; @@ -2490,11 +2481,7 @@ begin begin if gGameSettings.GameType = GT_SERVER then MH_SEND_DeleteShot(i, Obj.X, Obj.Y, Loud); - if Animation <> nil then - begin - Animation.Free(); - Animation := nil; - end; + Animation.Invalidate; end else if (ShotType <> WEAPON_FLAMETHROWER) and ((oldvx <> Obj.Vel.X) or (oldvy <> Obj.Vel.Y)) then if gGameSettings.GameType = GT_SERVER then @@ -2601,7 +2588,7 @@ begin Shots[i].Stopped := utils.readByte(st); // Óñòàíîâêà òåêñòóðû èëè àíèìàöèè - Shots[i].Animation := nil; + Shots[i].Animation.Invalidate; case Shots[i].ShotType of WEAPON_ROCKETLAUNCHER, WEAPON_SKEL_FIRE: @@ -2609,31 +2596,31 @@ begin end; WEAPON_PLASMA: begin - Shots[i].Animation := TAnimationState.Create(True, 5, 2); // !!! put values into table + Shots[i].Animation := TAnimState.Create(True, 5, 2); // !!! put values into table end; WEAPON_BFG: begin - Shots[i].Animation := TAnimationState.Create(True, 6, 2); // !!! put values into table + Shots[i].Animation := TAnimState.Create(True, 6, 2); // !!! put values into table end; WEAPON_IMP_FIRE: begin - Shots[i].Animation := TAnimationState.Create(True, 4, 2); // !!! put values into table + Shots[i].Animation := TAnimState.Create(True, 4, 2); // !!! put values into table end; WEAPON_BSP_FIRE: begin - Shots[i].Animation := TAnimationState.Create(True, 4, 2); // !!! put values into table + Shots[i].Animation := TAnimState.Create(True, 4, 2); // !!! put values into table end; WEAPON_CACO_FIRE: begin - Shots[i].Animation := TAnimationState.Create(True, 4, 2); // !!! put values into table + Shots[i].Animation := TAnimState.Create(True, 4, 2); // !!! put values into table end; WEAPON_BARON_FIRE: begin - Shots[i].Animation := TAnimationState.Create(True, 4, 2); // !!! put values into table + Shots[i].Animation := TAnimState.Create(True, 4, 2); // !!! put values into table end; WEAPON_MANCUB_FIRE: begin - Shots[i].Animation := TAnimationState.Create(True, 4, 2); // !!! put values into table + Shots[i].Animation := TAnimState.Create(True, 4, 2); // !!! put values into table end; end; end; @@ -2720,7 +2707,7 @@ begin end; // case ShotType of... ShotType := 0; - Animation.Free(); + Animation.Invalidate; end; end; diff --git a/src/game/opengl/r_weapons.pas b/src/game/opengl/r_weapons.pas index fb5e612..e469cf6 100644 --- a/src/game/opengl/r_weapons.pas +++ b/src/game/opengl/r_weapons.pas @@ -144,12 +144,12 @@ implementation p.X := Obj.Rect.Width div 2; p.Y := Obj.Rect.Height div 2; - if Animation <> nil then + if Animation.IsValid() then begin if Shots[i].ShotType in [WEAPON_BARON_FIRE, WEAPON_MANCUB_FIRE, WEAPON_SKEL_FIRE] then - r_AnimationState_DrawEx(ShotFrames[Shots[i].ShotType], Animation, fX, fY, 0, TMirrorType.None, False, p, a) + r_AnimState_DrawEx(ShotFrames[Shots[i].ShotType], Animation, fX, fY, 0, TMirrorType.None, False, p, a) else - r_AnimationState_Draw(ShotFrames[Shots[i].ShotType], Animation, fX, fY, 0, TMirrorType.None, False); + r_AnimState_Draw(ShotFrames[Shots[i].ShotType], Animation, fX, fY, 0, TMirrorType.None, False); end else if ShotTexture[Shots[i].ShotType] <> 0 then begin -- 2.29.2