author | alfadur |
Thu, 20 Jun 2019 16:05:03 +0300 | |
changeset 15190 | 9231247b1f83 |
parent 15186 | d13a38548112 |
child 15200 | 7d41e7889123 |
permissions | -rw-r--r-- |
6581 | 1 |
(* |
2 |
* Hedgewars, a free turn based strategy game |
|
11046 | 3 |
* Copyright (c) 2004-2015 Andrey Korotaev <unC0Rr@gmail.com> |
6581 | 4 |
* |
5 |
* This program is free software; you can redistribute it and/or modify |
|
6 |
* it under the terms of the GNU General Public License as published by |
|
7 |
* the Free Software Foundation; version 2 of the License |
|
8 |
* |
|
9 |
* This program is distributed in the hope that it will be useful, |
|
10 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
11 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
12 |
* GNU General Public License for more details. |
|
13 |
* |
|
14 |
* You should have received a copy of the GNU General Public License |
|
15 |
* along with this program; if not, write to the Free Software |
|
10108
c68cf030eded
update FSF address. note: two sdl include files (by Sam Lantinga) still have the old FSF address in their copyright - but I ain't gonna touch their copyright headers
sheepluva
parents:
10105
diff
changeset
|
16 |
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA |
6581 | 17 |
*) |
18 |
||
19 |
{$INCLUDE "options.inc"} |
|
20 |
||
21 |
unit uGearsUtils; |
|
22 |
interface |
|
9285 | 23 |
uses uTypes, uFloat; |
6581 | 24 |
|
6986
409dd3851309
add support for default pascal mode by removing default arguments value (maybe this also helps the parser)
koda
parents:
6888
diff
changeset
|
25 |
procedure doMakeExplosion(X, Y, Radius: LongInt; AttackingHog: PHedgehog; Mask: Longword); inline; |
8330 | 26 |
procedure doMakeExplosion(X, Y, Radius: LongInt; AttackingHog: PHedgehog; Mask: Longword; const Tint: LongWord); |
10363 | 27 |
procedure AddSplashForGear(Gear: PGear; justSkipping: boolean); |
13614
13f68f3e7153
Add bounce effect to cake when it touches bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
28 |
procedure AddBounceEffectForGear(Gear: PGear; imageScale: Single); |
10508 | 29 |
procedure AddBounceEffectForGear(Gear: PGear); |
6986
409dd3851309
add support for default pascal mode by removing default arguments value (maybe this also helps the parser)
koda
parents:
6888
diff
changeset
|
30 |
|
6581 | 31 |
function ModifyDamage(dmg: Longword; Gear: PGear): Longword; |
32 |
procedure ApplyDamage(Gear: PGear; AttackerHog: PHedgehog; Damage: Longword; Source: TDamageSource); |
|
33 |
procedure spawnHealthTagForHH(HHGear: PGear; dmg: Longword); |
|
14046
44f20c9e6861
Add Ouch taunt for particulary damaging hits (fall, bullet, shove, hammer)
Wuzzy <Wuzzy2@mail.ru>
parents:
14045
diff
changeset
|
34 |
procedure HHHurt(Hedgehog: PHedgehog; Source: TDamageSource; Damage: Longword); |
13622
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
35 |
procedure HHHeal(Hedgehog: PHedgehog; healthBoost: LongInt; showMessage: boolean; vgTint: Longword); |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
36 |
procedure HHHeal(Hedgehog: PHedgehog; healthBoost: LongInt; showMessage: boolean); |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
37 |
function IncHogHealth(Hedgehog: PHedgehog; healthBoost: LongInt): LongInt; |
6581 | 38 |
procedure CheckHHDamage(Gear: PGear); |
39 |
procedure CalcRotationDirAngle(Gear: PGear); |
|
8947
e906ebd59612
CheckGearDrowning could delete hedgehogs gear! (CheckGearDrowning -> ResurrectHedgehog -> FindPlace). Fixes bug 620.
unc0rr
parents:
8763
diff
changeset
|
40 |
procedure ResurrectHedgehog(var gear: PGear); |
6986
409dd3851309
add support for default pascal mode by removing default arguments value (maybe this also helps the parser)
koda
parents:
6888
diff
changeset
|
41 |
|
409dd3851309
add support for default pascal mode by removing default arguments value (maybe this also helps the parser)
koda
parents:
6888
diff
changeset
|
42 |
procedure FindPlace(var Gear: PGear; withFall: boolean; Left, Right: LongInt); inline; |
409dd3851309
add support for default pascal mode by removing default arguments value (maybe this also helps the parser)
koda
parents:
6888
diff
changeset
|
43 |
procedure FindPlace(var Gear: PGear; withFall: boolean; Left, Right: LongInt; skipProximity: boolean); |
409dd3851309
add support for default pascal mode by removing default arguments value (maybe this also helps the parser)
koda
parents:
6888
diff
changeset
|
44 |
|
13404 | 45 |
function CheckGearNear(Kind: TGearType; X, Y: hwFloat; rX, rY: LongInt): PGear; |
6581 | 46 |
function CheckGearNear(Gear: PGear; Kind: TGearType; rX, rY: LongInt): PGear; |
8947
e906ebd59612
CheckGearDrowning could delete hedgehogs gear! (CheckGearDrowning -> ResurrectHedgehog -> FindPlace). Fixes bug 620.
unc0rr
parents:
8763
diff
changeset
|
47 |
function CheckGearDrowning(var Gear: PGear): boolean; |
7592 | 48 |
procedure CheckCollision(Gear: PGear); inline; |
49 |
procedure CheckCollisionWithLand(Gear: PGear); inline; |
|
6581 | 50 |
|
9285 | 51 |
procedure AmmoShove(Ammo: PGear; Damage, Power: LongInt); |
14011
105793e575d6
make firepunch hit moving gears (airmines are not amused)
alfadur
parents:
14010
diff
changeset
|
52 |
procedure AmmoShoveCache(Ammo: PGear; Damage, Power: LongInt); |
12903 | 53 |
procedure AmmoShoveLine(Ammo: PGear; Damage, Power: LongInt; oX, oY, tX, tY: hwFloat); |
9285 | 54 |
function GearsNear(X, Y: hwFloat; Kind: TGearType; r: LongInt): PGearArrayS; |
14773
185f07ec4d12
New callback: onCaseDrop (called when engine MIGHT drop a crate)
Wuzzy <Wuzzy2@mail.ru>
parents:
14754
diff
changeset
|
55 |
function SpawnBoxOfSmth: PGear; |
185f07ec4d12
New callback: onCaseDrop (called when engine MIGHT drop a crate)
Wuzzy <Wuzzy2@mail.ru>
parents:
14754
diff
changeset
|
56 |
procedure PlayBoxSpawnTaunt(Gear: PGear); |
9285 | 57 |
procedure ShotgunShot(Gear: PGear); |
12717
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
58 |
function CanUseTardis(HHGear: PGear): boolean; |
9285 | 59 |
|
60 |
procedure SetAllToActive; |
|
61 |
procedure SetAllHHToActive(Ice: boolean); |
|
9954 | 62 |
procedure SetAllHHToActive(); inline; |
9285 | 63 |
|
64 |
function GetAmmo(Hedgehog: PHedgehog): TAmmoType; |
|
65 |
function GetUtility(Hedgehog: PHedgehog): TAmmoType; |
|
66 |
||
9473
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
67 |
function WorldWrap(var Gear: PGear): boolean; |
14519
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
68 |
function HomingWrap(var Gear: PGear): boolean; |
9473
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
69 |
|
14999
d9de740e194c
Add utility function to get hog left/right looking dir
Wuzzy <Wuzzy2@mail.ru>
parents:
14931
diff
changeset
|
70 |
function IsHogFacingLeft(Gear: PGear): boolean; |
11852 | 71 |
function IsHogLocal(HH: PHedgehog): boolean; |
9285 | 72 |
|
73 |
||
7719
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
74 |
function MakeHedgehogsStep(Gear: PGear) : boolean; |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
75 |
|
6581 | 76 |
var doStepHandlers: array[TGearType] of TGearStepProcedure; |
77 |
||
78 |
implementation |
|
9285 | 79 |
uses uSound, uCollisions, uUtils, uConsts, uVisualGears, uAIMisc, |
6581 | 80 |
uVariables, uLandGraphics, uScript, uStats, uCaptions, uTeams, uStore, |
10015 | 81 |
uLocale, uTextures, uRenderUtils, uRandom, SDLh, uDebug, |
9285 | 82 |
uGearsList, Math, uVisualGearsList, uGearsHandlersMess, |
83 |
uGearsHedgehog; |
|
6581 | 84 |
|
6986
409dd3851309
add support for default pascal mode by removing default arguments value (maybe this also helps the parser)
koda
parents:
6888
diff
changeset
|
85 |
procedure doMakeExplosion(X, Y, Radius: LongInt; AttackingHog: PHedgehog; Mask: Longword); inline; |
409dd3851309
add support for default pascal mode by removing default arguments value (maybe this also helps the parser)
koda
parents:
6888
diff
changeset
|
86 |
begin |
409dd3851309
add support for default pascal mode by removing default arguments value (maybe this also helps the parser)
koda
parents:
6888
diff
changeset
|
87 |
doMakeExplosion(X, Y, Radius, AttackingHog, Mask, $FFFFFFFF); |
409dd3851309
add support for default pascal mode by removing default arguments value (maybe this also helps the parser)
koda
parents:
6888
diff
changeset
|
88 |
end; |
409dd3851309
add support for default pascal mode by removing default arguments value (maybe this also helps the parser)
koda
parents:
6888
diff
changeset
|
89 |
|
6581 | 90 |
procedure doMakeExplosion(X, Y, Radius: LongInt; AttackingHog: PHedgehog; Mask: Longword; const Tint: LongWord); |
91 |
var Gear: PGear; |
|
6769
44ad49a3a126
Add drowning to grenade too, try some little optimisations
nemo
parents:
6765
diff
changeset
|
92 |
dmg, dmgBase: LongInt; |
6765 | 93 |
fX, fY, tdX, tdY: hwFloat; |
6581 | 94 |
vg: PVisualGear; |
95 |
i, cnt: LongInt; |
|
10653 | 96 |
wrap: boolean; |
10827 | 97 |
bubble: PVisualGear; |
12174
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12155
diff
changeset
|
98 |
s: ansistring; |
6581 | 99 |
begin |
100 |
if Radius > 4 then AddFileLog('Explosion: at (' + inttostr(x) + ',' + inttostr(y) + ')'); |
|
101 |
if Radius > 25 then KickFlakes(Radius, X, Y); |
|
102 |
||
103 |
if ((Mask and EXPLNoGfx) = 0) then |
|
104 |
begin |
|
105 |
vg:= nil; |
|
10827 | 106 |
if CheckCoordInWater(X, Y - Radius) then |
107 |
begin |
|
108 |
cnt:= 2 * Radius; |
|
109 |
for i:= (Radius * Radius) div 4 downto 0 do |
|
110 |
begin |
|
111 |
bubble := AddVisualGear(X - Radius + random(cnt), Y - Radius + random(cnt), vgtBubble); |
|
112 |
if bubble <> nil then |
|
113 |
bubble^.dY:= 0.1 + random(20)/10; |
|
114 |
end |
|
115 |
end |
|
116 |
else if Radius > 50 then vg:= AddVisualGear(X, Y, vgtBigExplosion) |
|
6581 | 117 |
else if Radius > 10 then vg:= AddVisualGear(X, Y, vgtExplosion); |
118 |
if vg <> nil then |
|
119 |
vg^.Tint:= Tint; |
|
120 |
end; |
|
121 |
if (Mask and EXPLAutoSound) <> 0 then PlaySound(sndExplosion); |
|
122 |
||
6765 | 123 |
dmgBase:= Radius shl 1 + cHHRadius div 2; |
10653 | 124 |
|
125 |
// we might have to run twice if weWrap is enabled |
|
126 |
wrap:= false; |
|
10659 | 127 |
repeat |
10653 | 128 |
|
10654 | 129 |
fX:= int2hwFloat(X); |
130 |
fY:= int2hwFloat(Y); |
|
131 |
Gear:= GearsList; |
|
132 |
||
6581 | 133 |
while Gear <> nil do |
134 |
begin |
|
135 |
dmg:= 0; |
|
136 |
if (Gear^.State and gstNoDamage) = 0 then |
|
137 |
begin |
|
138 |
case Gear^.Kind of |
|
139 |
gtHedgehog, |
|
140 |
gtMine, |
|
141 |
gtBall, |
|
142 |
gtMelonPiece, |
|
143 |
gtGrenade, |
|
144 |
gtClusterBomb, |
|
145 |
gtSMine, |
|
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10668
diff
changeset
|
146 |
gtAirMine, |
6581 | 147 |
gtCase, |
148 |
gtTarget, |
|
149 |
gtFlame, |
|
7754 | 150 |
gtKnife, |
14201
ab5e710d353d
Remove all traces of dead code related to amStructure/gtStructure
Wuzzy <Wuzzy2@mail.ru>
parents:
14046
diff
changeset
|
151 |
gtExplosives: begin |
6581 | 152 |
// Run the calcs only once we know we have a type that will need damage |
6765 | 153 |
tdX:= Gear^.X-fX; |
154 |
tdY:= Gear^.Y-fY; |
|
7721 | 155 |
if LongInt(tdX.Round + tdY.Round + 2) < dmgBase then |
7272
71df899c4163
Second part of the change. Make collision check use the new mask bit.
nemo
parents:
7190
diff
changeset
|
156 |
dmg:= dmgBase - hwRound(Distance(tdX, tdY)); |
6581 | 157 |
if dmg > 1 then |
158 |
begin |
|
159 |
dmg:= ModifyDamage(min(dmg div 2, Radius), Gear); |
|
160 |
//AddFileLog('Damage: ' + inttostr(dmg)); |
|
161 |
if (Mask and EXPLNoDamage) = 0 then |
|
162 |
begin |
|
10011
ead5e4b21671
Add check for gear kind of hedgehog on invulnerability effect. This probably fixes bug #766, is similar to change in previous r2a1483d91977 and was introduced by r7d925e82e572
nemo
parents:
10010
diff
changeset
|
163 |
if (Gear^.Kind <> gtHedgehog) or (Gear^.Hedgehog^.Effects[heInvulnerable] = 0) then |
6581 | 164 |
ApplyDamage(Gear, AttackingHog, dmg, dsExplosion) |
165 |
else |
|
166 |
Gear^.State:= Gear^.State or gstWinner; |
|
167 |
end; |
|
168 |
if ((Mask and EXPLDoNotTouchAny) = 0) and (((Mask and EXPLDoNotTouchHH) = 0) or (Gear^.Kind <> gtHedgehog)) then |
|
169 |
begin |
|
170 |
DeleteCI(Gear); |
|
6765 | 171 |
Gear^.dX:= Gear^.dX + SignAs(_0_005 * dmg + cHHKick, tdX)/(Gear^.Density/_3); |
172 |
Gear^.dY:= Gear^.dY + SignAs(_0_005 * dmg + cHHKick, tdY)/(Gear^.Density/_3); |
|
6581 | 173 |
|
174 |
Gear^.State:= (Gear^.State or gstMoving) and (not gstLoser); |
|
7767 | 175 |
if Gear^.Kind = gtKnife then Gear^.State:= Gear^.State and (not gstCollision); |
10011
ead5e4b21671
Add check for gear kind of hedgehog on invulnerability effect. This probably fixes bug #766, is similar to change in previous r2a1483d91977 and was introduced by r7d925e82e572
nemo
parents:
10010
diff
changeset
|
176 |
if (Gear^.Kind = gtHedgehog) and (Gear^.Hedgehog^.Effects[heInvulnerable] = 0) then |
14931
60340c8a6fae
Don't remove gstWinner after GameOver
Wuzzy <Wuzzy2@mail.ru>
parents:
14773
diff
changeset
|
177 |
begin |
60340c8a6fae
Don't remove gstWinner after GameOver
Wuzzy <Wuzzy2@mail.ru>
parents:
14773
diff
changeset
|
178 |
Gear^.State:= (Gear^.State or gstMoving) and (not (gstHHJumping or gstHHHJump)); |
60340c8a6fae
Don't remove gstWinner after GameOver
Wuzzy <Wuzzy2@mail.ru>
parents:
14773
diff
changeset
|
179 |
if (not GameOver) then |
60340c8a6fae
Don't remove gstWinner after GameOver
Wuzzy <Wuzzy2@mail.ru>
parents:
14773
diff
changeset
|
180 |
Gear^.State:= (Gear^.State and (not gstWinner)); |
60340c8a6fae
Don't remove gstWinner after GameOver
Wuzzy <Wuzzy2@mail.ru>
parents:
14773
diff
changeset
|
181 |
end; |
6581 | 182 |
Gear^.Active:= true; |
14208 | 183 |
if Gear^.Kind <> gtFlame then FollowGear:= Gear; |
184 |
if Gear^.Kind = gtAirMine then |
|
185 |
begin |
|
186 |
Gear^.Tag:= 1; |
|
187 |
Gear^.FlightTime:= 5000; |
|
188 |
end |
|
6581 | 189 |
end; |
11872 | 190 |
if ((Mask and EXPLPoisoned) <> 0) and (Gear^.Kind = gtHedgehog) and |
191 |
(Gear^.Hedgehog^.Effects[heInvulnerable] = 0) and (Gear^.Hedgehog^.Effects[heFrozen] = 0) and |
|
192 |
(Gear^.State and gstHHDeath = 0) then |
|
12174
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12155
diff
changeset
|
193 |
begin |
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12155
diff
changeset
|
194 |
if Gear^.Hedgehog^.Effects[hePoisoned] = 0 then |
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12155
diff
changeset
|
195 |
begin |
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12155
diff
changeset
|
196 |
s:= ansistring(Gear^.Hedgehog^.Name); |
13647
3d14950641a4
Refactor text color variable names, export 2 color values to Lua
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
197 |
AddCaption(FormatA(GetEventString(eidPoisoned), s), capcolDefault, capgrpMessage); |
12181
29f1ea94488b
Fix enemy saying “Missed” when poisoned w/o damage
Wuzzy <almikes@aol.com>
parents:
12174
diff
changeset
|
198 |
uStats.HedgehogPoisoned(Gear, AttackingHog) |
12174
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12155
diff
changeset
|
199 |
end; |
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12155
diff
changeset
|
200 |
Gear^.Hedgehog^.Effects[hePoisoned] := 5; |
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12155
diff
changeset
|
201 |
end |
6581 | 202 |
end; |
203 |
||
204 |
end; |
|
9814 | 205 |
gtGrave: if Mask and EXPLDoNotTouchAny = 0 then |
6581 | 206 |
// Run the calcs only once we know we have a type that will need damage |
207 |
begin |
|
9814 | 208 |
tdX:= Gear^.X-fX; |
209 |
tdY:= Gear^.Y-fY; |
|
210 |
if LongInt(tdX.Round + tdY.Round + 2) < dmgBase then |
|
211 |
dmg:= dmgBase - hwRound(Distance(tdX, tdY)); |
|
212 |
if dmg > 1 then |
|
213 |
begin |
|
214 |
dmg:= ModifyDamage(min(dmg div 2, Radius), Gear); |
|
215 |
Gear^.dY:= - _0_004 * dmg; |
|
216 |
Gear^.Active:= true |
|
217 |
end |
|
218 |
end; |
|
6581 | 219 |
end; |
220 |
end; |
|
221 |
Gear:= Gear^.NextGear |
|
222 |
end; |
|
223 |
||
224 |
if (Mask and EXPLDontDraw) = 0 then |
|
13609
73b096e1d895
Fix hammer/pickhammer not digging land with gfSolidLand on
Wuzzy <Wuzzy2@mail.ru>
parents:
13602
diff
changeset
|
225 |
if ((GameFlags and gfSolidLand) = 0) or ((Mask and EXPLForceDraw) <> 0) then |
6581 | 226 |
begin |
227 |
cnt:= DrawExplosion(X, Y, Radius) div 1608; // approx 2 16x16 circles to erase per chunk |
|
228 |
if (cnt > 0) and (SpritesData[sprChunk].Texture <> nil) then |
|
229 |
for i:= 0 to cnt do |
|
230 |
AddVisualGear(X, Y, vgtChunk) |
|
231 |
end; |
|
232 |
||
10653 | 233 |
if (WorldEdge = weWrap) then |
234 |
begin |
|
235 |
// already wrapped? let's not wrap again! |
|
236 |
if wrap then |
|
237 |
break; |
|
238 |
||
239 |
// Radius + 5 because that's the actual radius the explosion changes graphically |
|
14287
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14208
diff
changeset
|
240 |
if X + (Radius + 5) > rightX then |
10653 | 241 |
begin |
242 |
dec(X, playWidth); |
|
243 |
wrap:= true; |
|
244 |
end |
|
14287
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14208
diff
changeset
|
245 |
else if X - (Radius + 5) < leftX then |
10653 | 246 |
begin |
247 |
inc(X, playWidth); |
|
248 |
wrap:= true; |
|
249 |
end; |
|
250 |
end; |
|
251 |
||
252 |
until (not wrap); |
|
253 |
||
6581 | 254 |
uAIMisc.AwareOfExplosion(0, 0, 0) |
255 |
end; |
|
256 |
||
257 |
function ModifyDamage(dmg: Longword; Gear: PGear): Longword; |
|
258 |
var i: hwFloat; |
|
259 |
begin |
|
260 |
(* Invulnerability cannot be placed in here due to still needing kicks |
|
261 |
Not without a new damage machine. |
|
262 |
King check should be in here instead of ApplyDamage since Tiy wants them kicked less |
|
263 |
*) |
|
264 |
i:= _1; |
|
265 |
if (CurrentHedgehog <> nil) and CurrentHedgehog^.King then |
|
266 |
i:= _1_5; |
|
10015 | 267 |
if (Gear^.Kind = gtHedgehog) and (Gear^.Hedgehog <> nil) and |
10010
2a1483d91977
well. let's fix this at least - only apply to gears that are actually hedgehogs, not just ones associated with a hedgehog (which can be pretty much any gear since damage tracking was added)
nemo
parents:
9998
diff
changeset
|
268 |
(Gear^.Hedgehog^.King or (Gear^.Hedgehog^.Effects[heFrozen] > 0)) then |
9148
78c699d8fdfd
move 0.01 to the end to avoid increase damage fail on small values like fire. thanks to hedgewars wiki for noting this for fire damage.
nemo
parents:
9080
diff
changeset
|
269 |
ModifyDamage:= hwRound(cDamageModifier * dmg * i * cDamagePercent * _0_5 * _0_01) |
9149 | 270 |
else |
10526
b43d175d1577
Avoid promoting violence to hedgehogs. At least once a year.
nemo
parents:
10512
diff
changeset
|
271 |
ModifyDamage:= hwRound(cDamageModifier * dmg * i * cDamagePercent * _0_01); |
6581 | 272 |
end; |
273 |
||
274 |
procedure ApplyDamage(Gear: PGear; AttackerHog: PHedgehog; Damage: Longword; Source: TDamageSource); |
|
12942
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
275 |
var vampDmg, tmpDmg, i: Longword; |
6581 | 276 |
vg: PVisualGear; |
277 |
begin |
|
278 |
if Damage = 0 then |
|
279 |
exit; // nothing to apply |
|
280 |
||
281 |
if (Gear^.Kind = gtHedgehog) then |
|
282 |
begin |
|
283 |
Gear^.LastDamage := AttackerHog; |
|
284 |
||
285 |
Gear^.Hedgehog^.Team^.Clan^.Flawless:= false; |
|
14046
44f20c9e6861
Add Ouch taunt for particulary damaging hits (fall, bullet, shove, hammer)
Wuzzy <Wuzzy2@mail.ru>
parents:
14045
diff
changeset
|
286 |
HHHurt(Gear^.Hedgehog, Source, Damage); |
6581 | 287 |
AddDamageTag(hwRound(Gear^.X), hwRound(Gear^.Y), Damage, Gear^.Hedgehog^.Team^.Clan^.Color); |
288 |
tmpDmg:= min(Damage, max(0,Gear^.Health-Gear^.Damage)); |
|
289 |
if (Gear <> CurrentHedgehog^.Gear) and (CurrentHedgehog^.Gear <> nil) and (tmpDmg >= 1) then |
|
290 |
begin |
|
291 |
if cVampiric then |
|
292 |
begin |
|
293 |
vampDmg:= hwRound(int2hwFloat(tmpDmg)*_0_8); |
|
294 |
if vampDmg >= 1 then |
|
295 |
begin |
|
296 |
// was considering pulsing on attack, Tiy thinks it should be permanent while in play |
|
297 |
//CurrentHedgehog^.Gear^.State:= CurrentHedgehog^.Gear^.State or gstVampiric; |
|
13622
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
298 |
vampDmg:= IncHogHealth(CurrentHedgehog, vampDmg); |
6581 | 299 |
RenderHealth(CurrentHedgehog^); |
300 |
RecountTeamHealth(CurrentHedgehog^.Team); |
|
12942
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
301 |
HHHeal(CurrentHedgehog, vampDmg, true, $FF0000FF); |
6581 | 302 |
end |
303 |
end; |
|
12294
c20fbf96b853
Fix hedgehog self-damage not counted, and there were never Stupid taunts/announces
Wuzzy <almikes@aol.com>
parents:
12214
diff
changeset
|
304 |
if (GameFlags and gfKarma <> 0) and (GameFlags and gfInvulnerable = 0) and |
c20fbf96b853
Fix hedgehog self-damage not counted, and there were never Stupid taunts/announces
Wuzzy <almikes@aol.com>
parents:
12214
diff
changeset
|
305 |
(CurrentHedgehog^.Effects[heInvulnerable] = 0) then |
c20fbf96b853
Fix hedgehog self-damage not counted, and there were never Stupid taunts/announces
Wuzzy <almikes@aol.com>
parents:
12214
diff
changeset
|
306 |
begin // this cannot just use Damage or it interrupts shotgun and gets you called stupid |
c20fbf96b853
Fix hedgehog self-damage not counted, and there were never Stupid taunts/announces
Wuzzy <almikes@aol.com>
parents:
12214
diff
changeset
|
307 |
inc(CurrentHedgehog^.Gear^.Karma, tmpDmg); |
c20fbf96b853
Fix hedgehog self-damage not counted, and there were never Stupid taunts/announces
Wuzzy <almikes@aol.com>
parents:
12214
diff
changeset
|
308 |
CurrentHedgehog^.Gear^.LastDamage := CurrentHedgehog; |
c20fbf96b853
Fix hedgehog self-damage not counted, and there were never Stupid taunts/announces
Wuzzy <almikes@aol.com>
parents:
12214
diff
changeset
|
309 |
spawnHealthTagForHH(CurrentHedgehog^.Gear, tmpDmg); |
c20fbf96b853
Fix hedgehog self-damage not counted, and there were never Stupid taunts/announces
Wuzzy <almikes@aol.com>
parents:
12214
diff
changeset
|
310 |
end; |
6581 | 311 |
end; |
12294
c20fbf96b853
Fix hedgehog self-damage not counted, and there were never Stupid taunts/announces
Wuzzy <almikes@aol.com>
parents:
12214
diff
changeset
|
312 |
|
8330 | 313 |
uStats.HedgehogDamaged(Gear, AttackerHog, Damage, false); |
10526
b43d175d1577
Avoid promoting violence to hedgehogs. At least once a year.
nemo
parents:
10512
diff
changeset
|
314 |
|
15186 | 315 |
if AprilOne and (Gear^.Hedgehog^.Hat = 'fr_tomato') and (Damage > 2) then |
316 |
for i := 0 to random(min(Damage,20))+5 do |
|
317 |
begin |
|
318 |
vg:= AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtStraightShot); |
|
319 |
if vg <> nil then |
|
320 |
with vg^ do |
|
321 |
begin |
|
322 |
dx:= 0.001 * (random(100)+10); |
|
323 |
dy:= 0.001 * (random(100)+10); |
|
324 |
tdy:= -cGravityf; |
|
325 |
if random(2) = 0 then |
|
326 |
dx := -dx; |
|
327 |
FrameTicks:= random(500) + 1000; |
|
328 |
State:= ord(sprBubbles); |
|
329 |
Tint:= $ff0000ff |
|
330 |
end |
|
331 |
end |
|
8199
886ed135665b
Fix crashes and wtf behaviour introduced in r0b8beacff8a5
unc0rr
parents:
8161
diff
changeset
|
332 |
end else |
6581 | 333 |
Gear^.Hedgehog:= AttackerHog; |
334 |
inc(Gear^.Damage, Damage); |
|
8330 | 335 |
|
6581 | 336 |
ScriptCall('onGearDamage', Gear^.UID, Damage); |
337 |
end; |
|
338 |
||
339 |
procedure spawnHealthTagForHH(HHGear: PGear; dmg: Longword); |
|
340 |
var tag: PVisualGear; |
|
341 |
begin |
|
342 |
tag:= AddVisualGear(hwRound(HHGear^.X), hwRound(HHGear^.Y), vgtHealthTag, dmg); |
|
343 |
if (tag <> nil) then |
|
344 |
tag^.Hedgehog:= HHGear^.Hedgehog; // the tag needs the tag to determine the text color |
|
345 |
AllInactive:= false; |
|
346 |
HHGear^.Active:= true; |
|
347 |
end; |
|
8330 | 348 |
|
12942
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
349 |
// Play effects for hurt hedgehog |
14046
44f20c9e6861
Add Ouch taunt for particulary damaging hits (fall, bullet, shove, hammer)
Wuzzy <Wuzzy2@mail.ru>
parents:
14045
diff
changeset
|
350 |
procedure HHHurt(Hedgehog: PHedgehog; Source: TDamageSource; Damage: Longword); |
6581 | 351 |
begin |
9071 | 352 |
if Hedgehog^.Effects[heFrozen] <> 0 then exit; |
10526
b43d175d1577
Avoid promoting violence to hedgehogs. At least once a year.
nemo
parents:
10512
diff
changeset
|
353 |
|
14046
44f20c9e6861
Add Ouch taunt for particulary damaging hits (fall, bullet, shove, hammer)
Wuzzy <Wuzzy2@mail.ru>
parents:
14045
diff
changeset
|
354 |
if (Damage >= ouchDmg) and (OuchTauntTimer = 0) and ((Source = dsFall) or (Source = dsBullet) or (Source = dsShove) or (Source = dsHammer)) then |
44f20c9e6861
Add Ouch taunt for particulary damaging hits (fall, bullet, shove, hammer)
Wuzzy <Wuzzy2@mail.ru>
parents:
14045
diff
changeset
|
355 |
begin |
44f20c9e6861
Add Ouch taunt for particulary damaging hits (fall, bullet, shove, hammer)
Wuzzy <Wuzzy2@mail.ru>
parents:
14045
diff
changeset
|
356 |
PlaySoundV(sndOuch, Hedgehog^.Team^.voicepack); |
44f20c9e6861
Add Ouch taunt for particulary damaging hits (fall, bullet, shove, hammer)
Wuzzy <Wuzzy2@mail.ru>
parents:
14045
diff
changeset
|
357 |
// Prevent sndOuch from being played too often in short time |
44f20c9e6861
Add Ouch taunt for particulary damaging hits (fall, bullet, shove, hammer)
Wuzzy <Wuzzy2@mail.ru>
parents:
14045
diff
changeset
|
358 |
OuchTauntTimer:= 1250; |
44f20c9e6861
Add Ouch taunt for particulary damaging hits (fall, bullet, shove, hammer)
Wuzzy <Wuzzy2@mail.ru>
parents:
14045
diff
changeset
|
359 |
end |
44f20c9e6861
Add Ouch taunt for particulary damaging hits (fall, bullet, shove, hammer)
Wuzzy <Wuzzy2@mail.ru>
parents:
14045
diff
changeset
|
360 |
else if (Source = dsFall) or (Source = dsExplosion) then |
6581 | 361 |
case random(3) of |
7053 | 362 |
0: PlaySoundV(sndOoff1, Hedgehog^.Team^.voicepack); |
363 |
1: PlaySoundV(sndOoff2, Hedgehog^.Team^.voicepack); |
|
364 |
2: PlaySoundV(sndOoff3, Hedgehog^.Team^.voicepack); |
|
6581 | 365 |
end |
366 |
else if (Source = dsPoison) then |
|
367 |
case random(2) of |
|
7053 | 368 |
0: PlaySoundV(sndPoisonCough, Hedgehog^.Team^.voicepack); |
369 |
1: PlaySoundV(sndPoisonMoan, Hedgehog^.Team^.voicepack); |
|
6581 | 370 |
end |
371 |
else |
|
372 |
case random(4) of |
|
7053 | 373 |
0: PlaySoundV(sndOw1, Hedgehog^.Team^.voicepack); |
374 |
1: PlaySoundV(sndOw2, Hedgehog^.Team^.voicepack); |
|
375 |
2: PlaySoundV(sndOw3, Hedgehog^.Team^.voicepack); |
|
376 |
3: PlaySoundV(sndOw4, Hedgehog^.Team^.voicepack); |
|
6581 | 377 |
end |
378 |
end; |
|
379 |
||
12942
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
380 |
{- |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
381 |
Show heal particles and message at hog gear. |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
382 |
Hedgehog: Hedgehog which gets the health boost |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
383 |
healthBoost: Amount of added health added |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
384 |
showMessage: Whether to show announcer message |
13622
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
385 |
vgTint: Tint of heal particle (if 0, don't render particles) |
12942
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
386 |
-} |
13622
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
387 |
procedure HHHeal(Hedgehog: PHedgehog; healthBoost: LongInt; showMessage: boolean; vgTint: Longword); |
12942
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
388 |
var i: LongInt; |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
389 |
vg: PVisualGear; |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
390 |
s: ansistring; |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
391 |
begin |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
392 |
if healthBoost < 1 then |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
393 |
exit; |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
394 |
|
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
395 |
if showMessage then |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
396 |
begin |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
397 |
s:= IntToStr(healthBoost); |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
398 |
AddCaption(FormatA(trmsg[sidHealthGain], s), Hedgehog^.Team^.Clan^.Color, capgrpAmmoinfo) |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
399 |
end; |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
400 |
|
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
401 |
i:= 0; |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
402 |
// One particle for every 5 HP. Max. 200 particles |
13622
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
403 |
if (vgTint <> 0) then |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
404 |
while (i < healthBoost) and (i < 1000) do |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
405 |
begin |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
406 |
vg:= AddVisualGear(hwRound(Hedgehog^.Gear^.X), hwRound(Hedgehog^.Gear^.Y), vgtStraightShot); |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
407 |
if vg <> nil then |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
408 |
with vg^ do |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
409 |
begin |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
410 |
Tint:= vgTint; |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
411 |
State:= ord(sprHealth) |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
412 |
end; |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
413 |
inc(i, 5) |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
414 |
end; |
12942
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
415 |
end; |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
416 |
|
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
417 |
// Shorthand for the same above, but with tint implied |
13622
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
418 |
procedure HHHeal(Hedgehog: PHedgehog; healthBoost: LongInt; showMessage: boolean); |
12942
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
419 |
begin |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
420 |
HHHeal(Hedgehog, healthBoost, showMessage, $00FF00FF); |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
421 |
end; |
a84a05719454
Refactor health gain effects and message into util fuction HHHeal
Wuzzy <Wuzzy2@mail.ru>
parents:
12925
diff
changeset
|
422 |
|
13622
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
423 |
// Increase hog health by healthBoost (at least 1). |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
424 |
// Resulting health is capped at cMaxHogHealth. |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
425 |
// Returns actual amount healed. |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
426 |
function IncHogHealth(Hedgehog: PHedgehog; healthBoost: LongInt): LongInt; |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
427 |
var oldHealth: LongInt; |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
428 |
begin |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
429 |
if healthBoost < 1 then |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
430 |
begin |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
431 |
IncHogHealth:= 0; |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
432 |
exit; |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
433 |
end; |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
434 |
oldHealth:= Hedgehog^.Gear^.Health; |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
435 |
inc(Hedgehog^.Gear^.Health, healthBoost); |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
436 |
// Prevent overflow |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
437 |
if (Hedgehog^.Gear^.Health < 1) or (Hedgehog^.Gear^.Health > cMaxHogHealth) then |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
438 |
Hedgehog^.Gear^.Health:= cMaxHogHealth; |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
439 |
IncHogHealth:= Hedgehog^.Gear^.Health - oldHealth; |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
440 |
end; |
a6abc2c1fc1a
Show correct health increase when hog health cap is reached
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
441 |
|
6581 | 442 |
procedure CheckHHDamage(Gear: PGear); |
10015 | 443 |
var |
9809 | 444 |
dmg: LongInt; |
8003 | 445 |
i: LongWord; |
6581 | 446 |
particle: PVisualGear; |
447 |
begin |
|
9071 | 448 |
if _0_4 < Gear^.dY then |
449 |
begin |
|
450 |
dmg := ModifyDamage(1 + hwRound((Gear^.dY - _0_4) * 70), Gear); |
|
451 |
if Gear^.Hedgehog^.Effects[heFrozen] = 0 then |
|
452 |
PlaySound(sndBump) |
|
453 |
else PlaySound(sndFrozenHogImpact); |
|
454 |
if dmg < 1 then |
|
455 |
exit; |
|
6581 | 456 |
|
9809 | 457 |
for i:= min(12, 3 + dmg div 10) downto 0 do |
9071 | 458 |
begin |
459 |
particle := AddVisualGear(hwRound(Gear^.X) - 5 + Random(10), hwRound(Gear^.Y) + 12, vgtDust); |
|
460 |
if particle <> nil then |
|
461 |
particle^.dX := particle^.dX + (Gear^.dX.QWordValue / 21474836480); |
|
462 |
end; |
|
6581 | 463 |
|
9685
7d925e82e572
Tweak trophyrace to work better w/ skip (probably, needs testing), drop Invulnerable in favour of effects - heInvulnerable is already in effects,
nemo
parents:
9561
diff
changeset
|
464 |
if ((Gear^.Hedgehog^.Effects[heInvulnerable] <> 0)) then |
9071 | 465 |
exit; |
6581 | 466 |
|
9071 | 467 |
if Gear^.LastDamage <> nil then |
468 |
ApplyDamage(Gear, Gear^.LastDamage, dmg, dsFall) |
|
469 |
else |
|
470 |
ApplyDamage(Gear, CurrentHedgehog, dmg, dsFall); |
|
6581 | 471 |
end |
472 |
end; |
|
473 |
||
474 |
||
475 |
procedure CalcRotationDirAngle(Gear: PGear); |
|
8330 | 476 |
var |
6581 | 477 |
dAngle: real; |
478 |
begin |
|
7825 | 479 |
// Frac/Round to be kind to JS as of 2012-08-27 where there is yet no int64/uint64 |
480 |
dAngle := (Gear^.dX.Round + Gear^.dY.Round) / 2 + (Gear^.dX.Frac/$100000000+Gear^.dY.Frac/$100000000); |
|
6581 | 481 |
if not Gear^.dX.isNegative then |
482 |
Gear^.DirAngle := Gear^.DirAngle + dAngle |
|
483 |
else |
|
484 |
Gear^.DirAngle := Gear^.DirAngle - dAngle; |
|
485 |
||
486 |
if Gear^.DirAngle < 0 then |
|
487 |
Gear^.DirAngle := Gear^.DirAngle + 360 |
|
488 |
else if 360 < Gear^.DirAngle then |
|
489 |
Gear^.DirAngle := Gear^.DirAngle - 360 |
|
490 |
end; |
|
491 |
||
10363 | 492 |
procedure AddSplashForGear(Gear: PGear; justSkipping: boolean); |
493 |
var x, y, i, distL, distR, distB, minDist, maxDrops: LongInt; |
|
494 |
splash, particle: PVisualGear; |
|
495 |
speed, hwTmp: hwFloat; |
|
496 |
vi, vs, tmp: real; // impact speed and sideways speed |
|
497 |
isImpactH, isImpactRight: boolean; |
|
10419 | 498 |
const dist2surf = 4; |
10363 | 499 |
begin |
500 |
x:= hwRound(Gear^.X); |
|
501 |
y:= hwRound(Gear^.Y); |
|
502 |
||
10419 | 503 |
// find position for splash and impact speed |
10363 | 504 |
|
505 |
distB:= cWaterline - y; |
|
506 |
||
507 |
if WorldEdge <> weSea then |
|
508 |
minDist:= distB |
|
509 |
else |
|
510 |
begin |
|
511 |
distL:= x - leftX; |
|
512 |
distR:= rightX - x; |
|
513 |
minDist:= min(distB, min(distL, distR)); |
|
514 |
end; |
|
515 |
||
516 |
isImpactH:= (minDist <> distB); |
|
517 |
||
518 |
if not isImpactH then |
|
519 |
begin |
|
10417 | 520 |
y:= cWaterline - dist2surf; |
10363 | 521 |
speed:= hwAbs(Gear^.dY); |
522 |
end |
|
523 |
else |
|
524 |
begin |
|
525 |
isImpactRight := minDist = distR; |
|
526 |
if isImpactRight then |
|
10419 | 527 |
x:= rightX - dist2surf |
10363 | 528 |
else |
10419 | 529 |
x:= leftX + dist2surf; |
10363 | 530 |
speed:= hwAbs(Gear^.dX); |
531 |
end; |
|
532 |
||
533 |
// splash sound |
|
534 |
||
535 |
if justSkipping then |
|
536 |
PlaySound(sndSkip) |
|
537 |
else |
|
538 |
begin |
|
539 |
// adjust water impact sound based on gear speed and density |
|
540 |
hwTmp:= hwAbs(Gear^.Density * speed); |
|
541 |
||
542 |
if hwTmp > _1 then |
|
543 |
PlaySound(sndSplash) |
|
544 |
else if hwTmp > _0_5 then |
|
545 |
PlaySound(sndSkip) |
|
12155 | 546 |
else if hwTmp > _0_0002 then // arbitrary sanity cutoff. mostly for airmines |
10363 | 547 |
PlaySound(sndDroplet2); |
548 |
end; |
|
549 |
||
10419 | 550 |
|
551 |
// splash visuals |
|
552 |
||
553 |
if ((cReducedQuality and rqPlainSplash) <> 0) then |
|
554 |
exit; |
|
555 |
||
556 |
splash:= AddVisualGear(x, y, vgtSplash); |
|
557 |
if splash = nil then |
|
558 |
exit; |
|
559 |
||
560 |
if not isImpactH then |
|
561 |
vs:= abs(hwFloat2Float(Gear^.dX)) |
|
562 |
else |
|
563 |
begin |
|
564 |
if isImpactRight then |
|
565 |
splash^.Angle:= -90 |
|
566 |
else |
|
567 |
splash^.Angle:= 90; |
|
568 |
vs:= abs(hwFloat2Float(Gear^.dY)); |
|
569 |
end; |
|
570 |
||
571 |
||
572 |
vi:= hwFloat2Float(speed); |
|
573 |
||
10363 | 574 |
with splash^ do |
575 |
begin |
|
576 |
Scale:= abs(hwFloat2Float(Gear^.Density / _3 * speed)); |
|
577 |
if Scale > 1 then Scale:= power(Scale,0.3333) |
|
578 |
else Scale:= Scale + ((1-Scale) / 2); |
|
579 |
if Scale > 1 then Timer:= round(min(Scale*0.0005/cGravityf,4)) |
|
580 |
else Timer:= 1; |
|
15155
c383ebdd61b9
Move piano splash a few pixels lower
Wuzzy <Wuzzy2@mail.ru>
parents:
15152
diff
changeset
|
581 |
if Scale > 1 then Y:= Y + 10; |
10363 | 582 |
// Low Gravity |
583 |
FrameTicks:= FrameTicks*Timer; |
|
584 |
end; |
|
585 |
||
586 |
||
587 |
// eject water drops |
|
588 |
||
589 |
maxDrops := (hwRound(Gear^.Density) * 3) div 2 + round((vi + vs) * hwRound(Gear^.Density) * 6); |
|
590 |
for i:= max(maxDrops div 3, min(32, Random(maxDrops))) downto 0 do |
|
591 |
begin |
|
592 |
if isImpactH then |
|
593 |
particle := AddVisualGear(x, y - 3 + Random(7), vgtDroplet) |
|
594 |
else |
|
595 |
particle := AddVisualGear(x - 3 + Random(7), y, vgtDroplet); |
|
596 |
||
597 |
if particle <> nil then |
|
598 |
with particle^ do |
|
599 |
begin |
|
600 |
// dX and dY were initialized to have a random value on creation (see uVisualGearsList) |
|
601 |
if isImpactH then |
|
602 |
begin |
|
603 |
tmp:= dX; |
|
604 |
if isImpactRight then |
|
605 |
dX:= dY - vi / 5 |
|
606 |
else |
|
607 |
dX:= -dy + vi / 5; |
|
608 |
dY:= tmp * (1 + vs / 10); |
|
609 |
end |
|
610 |
else |
|
611 |
begin |
|
612 |
dX:= dX * (1 + vs / 10); |
|
613 |
dY:= dY - vi / 5; |
|
614 |
end; |
|
615 |
||
616 |
if splash <> nil then |
|
617 |
begin |
|
618 |
if splash^.Scale > 1 then |
|
619 |
begin |
|
620 |
dX:= dX * power(splash^.Scale, 0.3333); // tone down the droplet height further |
|
621 |
dY:= dY * power(splash^.Scale, 0.3333); |
|
622 |
end |
|
623 |
else |
|
624 |
begin |
|
625 |
dX:= dX * splash^.Scale; |
|
626 |
dY:= dY * splash^.Scale; |
|
627 |
end; |
|
628 |
end; |
|
629 |
end |
|
630 |
end; |
|
631 |
||
632 |
end; |
|
633 |
||
10354 | 634 |
procedure DrownGear(Gear: PGear); |
635 |
begin |
|
636 |
Gear^.doStep := @doStepDrowningGear; |
|
637 |
||
638 |
Gear^.Timer := 5000; // how long game should wait |
|
639 |
end; |
|
640 |
||
8947
e906ebd59612
CheckGearDrowning could delete hedgehogs gear! (CheckGearDrowning -> ResurrectHedgehog -> FindPlace). Fixes bug 620.
unc0rr
parents:
8763
diff
changeset
|
641 |
function CheckGearDrowning(var Gear: PGear): boolean; |
10015 | 642 |
var |
10363 | 643 |
skipSpeed, skipAngle, skipDecay: hwFloat; |
644 |
tmp, X, Y, dist2Water: LongInt; |
|
645 |
isSubmersible, isDirH, isImpact, isSkip: boolean; |
|
10124
aabd1b75d5a3
Even more explicit type conversions and other stuff to help pas2c use ansistrings
unc0rr
parents:
10116
diff
changeset
|
646 |
s: ansistring; |
6581 | 647 |
begin |
648 |
// probably needs tweaking. might need to be in a case statement based upon gear type |
|
10354 | 649 |
X:= hwRound(Gear^.X); |
6581 | 650 |
Y:= hwRound(Gear^.Y); |
10354 | 651 |
|
652 |
dist2Water:= cWaterLine - (Y + Gear^.Radius); |
|
10363 | 653 |
isDirH:= false; |
10354 | 654 |
|
655 |
if WorldEdge = weSea then |
|
6581 | 656 |
begin |
10363 | 657 |
tmp:= dist2Water; |
14287
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14208
diff
changeset
|
658 |
dist2Water:= min(dist2Water, min(X - Gear^.Radius - leftX, rightX - (X + Gear^.Radius))); |
10363 | 659 |
// if water on sides is closer than on bottom -> horizontal direction |
660 |
isDirH:= tmp <> dist2Water; |
|
10354 | 661 |
end; |
662 |
||
10363 | 663 |
isImpact:= false; |
664 |
||
10354 | 665 |
if dist2Water < 0 then |
666 |
begin |
|
667 |
// invisible gears will just be deleted |
|
668 |
// unless they are generic fallers, then they will be "respawned" |
|
7389
15c3fb4882df
Sorry about the slight delay in pickup. You can blame a few lame cheaters. This is to make their cheating a bit harder.
nemo
parents:
7372
diff
changeset
|
669 |
if Gear^.State and gstInvisible <> 0 then |
15c3fb4882df
Sorry about the slight delay in pickup. You can blame a few lame cheaters. This is to make their cheating a bit harder.
nemo
parents:
7372
diff
changeset
|
670 |
begin |
7406
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7389
diff
changeset
|
671 |
if Gear^.Kind = gtGenericFaller then |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7389
diff
changeset
|
672 |
begin |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7389
diff
changeset
|
673 |
Gear^.X:= int2hwFloat(GetRandom(rightX-leftX)+leftX); |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7389
diff
changeset
|
674 |
Gear^.Y:= int2hwFloat(GetRandom(LAND_HEIGHT-topY)+topY); |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7389
diff
changeset
|
675 |
Gear^.dX:= _90-(GetRandomf*_360); |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7389
diff
changeset
|
676 |
Gear^.dY:= _90-(GetRandomf*_360) |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7389
diff
changeset
|
677 |
end |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7389
diff
changeset
|
678 |
else DeleteGear(Gear); |
10245 | 679 |
exit(true) |
7389
15c3fb4882df
Sorry about the slight delay in pickup. You can blame a few lame cheaters. This is to make their cheating a bit harder.
nemo
parents:
7372
diff
changeset
|
680 |
end; |
8992
5b0be812dcdb
Rename submersible state, increase getaway time for attack underwater, slow down gear dx/dy underwater to simulate water resistance
nemo
parents:
8991
diff
changeset
|
681 |
isSubmersible:= ((Gear = CurrentHedgehog^.Gear) and (CurAmmoGear <> nil) and (CurAmmoGear^.State and gstSubmersible <> 0)) or (Gear^.State and gstSubmersible <> 0); |
10363 | 682 |
|
6581 | 683 |
skipSpeed := _0_25; |
684 |
skipAngle := _1_9; |
|
685 |
skipDecay := _0_87; |
|
10363 | 686 |
|
10354 | 687 |
|
688 |
// skipping |
|
689 |
||
10512
25021aac078e
fix underwater-skipping bug and make air-strike missiles submersible when fired from within weSea
sheepluva
parents:
10508
diff
changeset
|
690 |
if (not isSubmersible) and (hwSqr(Gear^.dX) + hwSqr(Gear^.dY) > skipSpeed) |
10363 | 691 |
and ( ((not isDirH) and (hwAbs(Gear^.dX) > skipAngle * hwAbs(Gear^.dY))) |
692 |
or (isDirH and (hwAbs(Gear^.dY) > skipAngle * hwAbs(Gear^.dX))) ) then |
|
6581 | 693 |
begin |
10363 | 694 |
isSkip:= true; |
10354 | 695 |
// if skipping we move the gear out of water |
10363 | 696 |
if isDirH then |
10354 | 697 |
begin |
698 |
Gear^.dX.isNegative := (not Gear^.dX.isNegative); |
|
699 |
Gear^.X:= Gear^.X + Gear^.dX; |
|
700 |
end |
|
701 |
else |
|
702 |
begin |
|
703 |
Gear^.dY.isNegative := (not Gear^.dY.isNegative); |
|
704 |
Gear^.Y:= Gear^.Y + Gear^.dY; |
|
705 |
end; |
|
6581 | 706 |
Gear^.dY := Gear^.dY * skipDecay; |
707 |
Gear^.dX := Gear^.dX * skipDecay; |
|
708 |
CheckGearDrowning := false; |
|
709 |
end |
|
10354 | 710 |
else // not skipping |
6581 | 711 |
begin |
10363 | 712 |
isImpact:= true; |
713 |
isSkip:= false; |
|
6581 | 714 |
if not isSubmersible then |
715 |
begin |
|
716 |
CheckGearDrowning := true; |
|
717 |
Gear^.State := gstDrowning; |
|
12182
bfeeb1c35e77
Set turn time to 0 when current hog drowns
Wuzzy <almikes@aol.com>
parents:
12181
diff
changeset
|
718 |
if Gear = CurrentHedgehog^.Gear then |
bfeeb1c35e77
Set turn time to 0 when current hog drowns
Wuzzy <almikes@aol.com>
parents:
12181
diff
changeset
|
719 |
TurnTimeLeft := 0; |
6581 | 720 |
Gear^.RenderTimer := false; |
721 |
if (Gear^.Kind <> gtSniperRifleShot) and (Gear^.Kind <> gtShotgunShot) |
|
12903 | 722 |
and (Gear^.Kind <> gtDEagleShot) and (Gear^.Kind <> gtSineGunShot) |
723 |
and (Gear^.Kind <> gtMinigunBullet) then |
|
6581 | 724 |
if Gear^.Kind = gtHedgehog then |
725 |
begin |
|
7010
10a0a31804f3
Switch effects to longint for convenience of tracking ice states. I could add a new Hedgehog value, but since we have this effects list being all useless as booleans anyway...
nemo
parents:
6990
diff
changeset
|
726 |
if Gear^.Hedgehog^.Effects[heResurrectable] <> 0 then |
8947
e906ebd59612
CheckGearDrowning could delete hedgehogs gear! (CheckGearDrowning -> ResurrectHedgehog -> FindPlace). Fixes bug 620.
unc0rr
parents:
8763
diff
changeset
|
727 |
begin |
e906ebd59612
CheckGearDrowning could delete hedgehogs gear! (CheckGearDrowning -> ResurrectHedgehog -> FindPlace). Fixes bug 620.
unc0rr
parents:
8763
diff
changeset
|
728 |
// Gear could become nil after this, just exit to skip splashes |
e906ebd59612
CheckGearDrowning could delete hedgehogs gear! (CheckGearDrowning -> ResurrectHedgehog -> FindPlace). Fixes bug 620.
unc0rr
parents:
8763
diff
changeset
|
729 |
ResurrectHedgehog(Gear); |
10245 | 730 |
exit(true) |
8947
e906ebd59612
CheckGearDrowning could delete hedgehogs gear! (CheckGearDrowning -> ResurrectHedgehog -> FindPlace). Fixes bug 620.
unc0rr
parents:
8763
diff
changeset
|
731 |
end |
6581 | 732 |
else |
733 |
begin |
|
10354 | 734 |
DrownGear(Gear); |
6581 | 735 |
Gear^.State := Gear^.State and (not gstHHDriven); |
10124
aabd1b75d5a3
Even more explicit type conversions and other stuff to help pas2c use ansistrings
unc0rr
parents:
10116
diff
changeset
|
736 |
s:= ansistring(Gear^.Hedgehog^.Name); |
12174
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12155
diff
changeset
|
737 |
if Gear^.Hedgehog^.King then |
13647
3d14950641a4
Refactor text color variable names, export 2 color values to Lua
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
738 |
AddCaption(FormatA(GetEventString(eidKingDied), s), capcolDefault, capgrpMessage) |
12174
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12155
diff
changeset
|
739 |
else |
13647
3d14950641a4
Refactor text color variable names, export 2 color values to Lua
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
740 |
AddCaption(FormatA(GetEventString(eidDrowned), s), capcolDefault, capgrpMessage); |
6581 | 741 |
end |
742 |
end |
|
743 |
else |
|
10354 | 744 |
DrownGear(Gear); |
10419 | 745 |
if Gear^.Kind = gtFlake then |
10354 | 746 |
exit(true); // skip splashes |
8990 | 747 |
end |
10363 | 748 |
else // submersible |
749 |
begin |
|
14539
c38dd843763f
Fix double water splash if flying saucer drowns (bug 681)
Wuzzy <Wuzzy2@mail.ru>
parents:
14519
diff
changeset
|
750 |
// drown submersible gears if far below map |
10363 | 751 |
if (Y > cWaterLine + cVisibleWater*4) then |
752 |
begin |
|
753 |
DrownGear(Gear); |
|
754 |
exit(true); // no splashes needed |
|
755 |
end; |
|
10354 | 756 |
|
10363 | 757 |
CheckGearDrowning := false; |
758 |
||
759 |
// check if surface was penetrated |
|
10354 | 760 |
|
10363 | 761 |
// no penetration if center's water distance not smaller than radius |
12451
48ee3777e42e
trying to eliminate that annoying impact sound for gears that are well under the water and not even exiting it. sheepluva might want to look this over since this is modifying his code and should perhaps be part of the addSplashForGear checks, but hadn't had much luck getting him to examine it past year or so
nemo
parents:
12450
diff
changeset
|
762 |
if ((dist2Water + Gear^.Radius div 2) < 0) or (abs(dist2Water + Gear^.Radius) >= Gear^.Radius) then |
10363 | 763 |
isImpact:= false |
6804 | 764 |
else |
10354 | 765 |
begin |
10363 | 766 |
// get distance to water of last tick |
767 |
if isDirH then |
|
768 |
begin |
|
769 |
tmp:= hwRound(Gear^.X - Gear^.dX); |
|
12605 | 770 |
if abs(tmp - real(leftX)) < abs(tmp - real(rightX)) then // left edge |
771 |
isImpact:= (abs(tmp-real(leftX)) >= Gear^.Radius) and (Gear^.dX.isNegative) |
|
12451
48ee3777e42e
trying to eliminate that annoying impact sound for gears that are well under the water and not even exiting it. sheepluva might want to look this over since this is modifying his code and should perhaps be part of the addSplashForGear checks, but hadn't had much luck getting him to examine it past year or so
nemo
parents:
12450
diff
changeset
|
772 |
else |
12605 | 773 |
isImpact:= (abs(tmp-real(rightX)) >= Gear^.Radius) and (not Gear^.dX.isNegative); |
10363 | 774 |
end |
10354 | 775 |
else |
6803
0e70f3ea3bf8
bit of an experiment in variable splash sizes based on object/speed. not sure if it looks good yet. need to drown more stuff.
nemo
parents:
6769
diff
changeset
|
776 |
begin |
10363 | 777 |
tmp:= hwRound(Gear^.Y - Gear^.dY); |
778 |
tmp:= abs(cWaterLine - tmp); |
|
12451
48ee3777e42e
trying to eliminate that annoying impact sound for gears that are well under the water and not even exiting it. sheepluva might want to look this over since this is modifying his code and should perhaps be part of the addSplashForGear checks, but hadn't had much luck getting him to examine it past year or so
nemo
parents:
12450
diff
changeset
|
779 |
// there was an impact if distance was >= radius |
48ee3777e42e
trying to eliminate that annoying impact sound for gears that are well under the water and not even exiting it. sheepluva might want to look this over since this is modifying his code and should perhaps be part of the addSplashForGear checks, but hadn't had much luck getting him to examine it past year or so
nemo
parents:
12450
diff
changeset
|
780 |
isImpact:= (tmp >= Gear^.Radius) and (not Gear^.dY.isNegative); |
10363 | 781 |
end; |
10354 | 782 |
|
10363 | 783 |
end; |
784 |
end; // end of submersible |
|
785 |
end; // end of not skipping |
|
786 |
||
787 |
// splash sound animation and droplets |
|
788 |
if isImpact or isSkip then |
|
14539
c38dd843763f
Fix double water splash if flying saucer drowns (bug 681)
Wuzzy <Wuzzy2@mail.ru>
parents:
14519
diff
changeset
|
789 |
if (not (((dist2Water + Gear^.Radius div 2) < 0) or (abs(dist2Water + Gear^.Radius) >= Gear^.Radius))) then |
c38dd843763f
Fix double water splash if flying saucer drowns (bug 681)
Wuzzy <Wuzzy2@mail.ru>
parents:
14519
diff
changeset
|
790 |
addSplashForGear(Gear, isSkip); |
10363 | 791 |
|
10668 | 792 |
if isSkip then |
793 |
ScriptCall('onGearWaterSkip', Gear^.uid); |
|
6581 | 794 |
end |
795 |
else |
|
9473
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
796 |
CheckGearDrowning := false |
6581 | 797 |
end; |
798 |
||
799 |
||
8947
e906ebd59612
CheckGearDrowning could delete hedgehogs gear! (CheckGearDrowning -> ResurrectHedgehog -> FindPlace). Fixes bug 620.
unc0rr
parents:
8763
diff
changeset
|
800 |
procedure ResurrectHedgehog(var gear: PGear); |
6581 | 801 |
var tempTeam : PTeam; |
13634
c9a49d06f1a2
Report spawning visual gear in onGearResurrect
Wuzzy <Wuzzy2@mail.ru>
parents:
13632
diff
changeset
|
802 |
sparkles, expl: PVisualGear; |
7092
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7066
diff
changeset
|
803 |
gX, gY: LongInt; |
6581 | 804 |
begin |
7357
06454899d0d2
Score AI resurrection as a kill. These values will not be the same as the in-game scoring, since in-game scoring doesn't count friendlies.
nemo
parents:
7272
diff
changeset
|
805 |
if (Gear^.LastDamage <> nil) then |
06454899d0d2
Score AI resurrection as a kill. These values will not be the same as the in-game scoring, since in-game scoring doesn't count friendlies.
nemo
parents:
7272
diff
changeset
|
806 |
uStats.HedgehogDamaged(Gear, Gear^.LastDamage, 0, true) |
06454899d0d2
Score AI resurrection as a kill. These values will not be the same as the in-game scoring, since in-game scoring doesn't count friendlies.
nemo
parents:
7272
diff
changeset
|
807 |
else |
06454899d0d2
Score AI resurrection as a kill. These values will not be the same as the in-game scoring, since in-game scoring doesn't count friendlies.
nemo
parents:
7272
diff
changeset
|
808 |
uStats.HedgehogDamaged(Gear, CurrentHedgehog, 0, true); |
13634
c9a49d06f1a2
Report spawning visual gear in onGearResurrect
Wuzzy <Wuzzy2@mail.ru>
parents:
13632
diff
changeset
|
809 |
// Reset gear state |
6581 | 810 |
AttackBar:= 0; |
811 |
gear^.dX := _0; |
|
812 |
gear^.dY := _0; |
|
813 |
gear^.Damage := 0; |
|
814 |
gear^.Health := gear^.Hedgehog^.InitialHealth; |
|
7010
10a0a31804f3
Switch effects to longint for convenience of tracking ice states. I could add a new Hedgehog value, but since we have this effects list being all useless as booleans anyway...
nemo
parents:
6990
diff
changeset
|
815 |
gear^.Hedgehog^.Effects[hePoisoned] := 0; |
7176
fb4b0c6dfdbd
Make watching AI v AI on ai survival a bit more entertaining
nemo
parents:
7168
diff
changeset
|
816 |
if (CurrentHedgehog^.Effects[heResurrectable] = 0) or ((CurrentHedgehog^.Effects[heResurrectable] <> 0) |
fb4b0c6dfdbd
Make watching AI v AI on ai survival a bit more entertaining
nemo
parents:
7168
diff
changeset
|
817 |
and (Gear^.Hedgehog^.Team^.Clan <> CurrentHedgehog^.Team^.Clan)) then |
8330 | 818 |
with CurrentHedgehog^ do |
6581 | 819 |
begin |
820 |
inc(Team^.stats.AIKills); |
|
10634
35d059bd0932
Use FreeAndNil across the board. Even if we are immediately assigning after, probably avoids accidental mistakes. Also free neglected owner tex on shutdown, and delete hog gears using the normal deletion procedure if for any reason they still exist (EndGame call?).
nemo
parents:
10558
diff
changeset
|
821 |
FreeAndNilTexture(Team^.AIKillsTex); |
10124
aabd1b75d5a3
Even more explicit type conversions and other stuff to help pas2c use ansistrings
unc0rr
parents:
10116
diff
changeset
|
822 |
Team^.AIKillsTex := RenderStringTex(ansistring(inttostr(Team^.stats.AIKills)), Team^.Clan^.Color, fnt16); |
6581 | 823 |
end; |
824 |
tempTeam := gear^.Hedgehog^.Team; |
|
825 |
DeleteCI(gear); |
|
7092
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7066
diff
changeset
|
826 |
gX := hwRound(gear^.X); |
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7066
diff
changeset
|
827 |
gY := hwRound(gear^.Y); |
13634
c9a49d06f1a2
Report spawning visual gear in onGearResurrect
Wuzzy <Wuzzy2@mail.ru>
parents:
13632
diff
changeset
|
828 |
// Spawn a few sparkles at death position. |
c9a49d06f1a2
Report spawning visual gear in onGearResurrect
Wuzzy <Wuzzy2@mail.ru>
parents:
13632
diff
changeset
|
829 |
// Might need more sparkles for a column. |
7092
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7066
diff
changeset
|
830 |
sparkles:= AddVisualGear(gX, gY, vgtDust, 1); |
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7066
diff
changeset
|
831 |
if sparkles <> nil then |
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7066
diff
changeset
|
832 |
begin |
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7066
diff
changeset
|
833 |
sparkles^.Tint:= tempTeam^.Clan^.Color shl 8 or $FF; |
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7066
diff
changeset
|
834 |
end; |
13634
c9a49d06f1a2
Report spawning visual gear in onGearResurrect
Wuzzy <Wuzzy2@mail.ru>
parents:
13632
diff
changeset
|
835 |
// Set new position of gear (might fail) |
8330 | 836 |
FindPlace(gear, false, 0, LAND_WIDTH, true); |
6581 | 837 |
if gear <> nil then |
838 |
begin |
|
13634
c9a49d06f1a2
Report spawning visual gear in onGearResurrect
Wuzzy <Wuzzy2@mail.ru>
parents:
13632
diff
changeset
|
839 |
// Visual effect at position of resurrection |
c9a49d06f1a2
Report spawning visual gear in onGearResurrect
Wuzzy <Wuzzy2@mail.ru>
parents:
13632
diff
changeset
|
840 |
expl:= AddVisualGear(hwRound(gear^.X), hwRound(gear^.Y), vgtExplosion); |
7168
8defaabce92e
warp sound when AI survival hog respawns. attempt at a bit of a crate spawn animation (moar sparkles and a quick fadein)
nemo
parents:
7092
diff
changeset
|
841 |
PlaySound(sndWarp); |
6581 | 842 |
RenderHealth(gear^.Hedgehog^); |
13634
c9a49d06f1a2
Report spawning visual gear in onGearResurrect
Wuzzy <Wuzzy2@mail.ru>
parents:
13632
diff
changeset
|
843 |
if expl <> nil then |
c9a49d06f1a2
Report spawning visual gear in onGearResurrect
Wuzzy <Wuzzy2@mail.ru>
parents:
13632
diff
changeset
|
844 |
ScriptCall('onGearResurrect', gear^.uid, expl^.uid) |
c9a49d06f1a2
Report spawning visual gear in onGearResurrect
Wuzzy <Wuzzy2@mail.ru>
parents:
13632
diff
changeset
|
845 |
else |
c9a49d06f1a2
Report spawning visual gear in onGearResurrect
Wuzzy <Wuzzy2@mail.ru>
parents:
13632
diff
changeset
|
846 |
ScriptCall('onGearResurrect', gear^.uid); |
6581 | 847 |
gear^.State := gstWait; |
8947
e906ebd59612
CheckGearDrowning could delete hedgehogs gear! (CheckGearDrowning -> ResurrectHedgehog -> FindPlace). Fixes bug 620.
unc0rr
parents:
8763
diff
changeset
|
848 |
end; |
6581 | 849 |
RecountTeamHealth(tempTeam); |
850 |
end; |
|
851 |
||
12453
8b89fe2115ad
So, was trying to allow spawning on level surfaces of ice but not girders, but seems to be failing. We'll call this WIP
nemo
parents:
12451
diff
changeset
|
852 |
function CountLand(x, y, r, c: LongInt; mask, antimask: LongWord): LongInt; |
6581 | 853 |
var i: LongInt; |
854 |
count: LongInt = 0; |
|
855 |
begin |
|
6990
40e5af28d026
change every return value into a more pascal-ish form, using the name of the fucntion (helps the parser and macpas compaitilibity)
koda
parents:
6986
diff
changeset
|
856 |
if (y and LAND_HEIGHT_MASK) = 0 then |
10272
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
857 |
for i:= max(x - r, 0) to min(x + r, LAND_WIDTH - 1) do |
12453
8b89fe2115ad
So, was trying to allow spawning on level surfaces of ice but not girders, but seems to be failing. We'll call this WIP
nemo
parents:
12451
diff
changeset
|
858 |
if (Land[y, i] and mask <> 0) and (Land[y, i] and antimask = 0) then |
8b89fe2115ad
So, was trying to allow spawning on level surfaces of ice but not girders, but seems to be failing. We'll call this WIP
nemo
parents:
12451
diff
changeset
|
859 |
begin |
6990
40e5af28d026
change every return value into a more pascal-ish form, using the name of the fucntion (helps the parser and macpas compaitilibity)
koda
parents:
6986
diff
changeset
|
860 |
inc(count); |
40e5af28d026
change every return value into a more pascal-ish form, using the name of the fucntion (helps the parser and macpas compaitilibity)
koda
parents:
6986
diff
changeset
|
861 |
if count = c then |
12453
8b89fe2115ad
So, was trying to allow spawning on level surfaces of ice but not girders, but seems to be failing. We'll call this WIP
nemo
parents:
12451
diff
changeset
|
862 |
begin |
8b89fe2115ad
So, was trying to allow spawning on level surfaces of ice but not girders, but seems to be failing. We'll call this WIP
nemo
parents:
12451
diff
changeset
|
863 |
CountLand:= count; |
6990
40e5af28d026
change every return value into a more pascal-ish form, using the name of the fucntion (helps the parser and macpas compaitilibity)
koda
parents:
6986
diff
changeset
|
864 |
exit |
12453
8b89fe2115ad
So, was trying to allow spawning on level surfaces of ice but not girders, but seems to be failing. We'll call this WIP
nemo
parents:
12451
diff
changeset
|
865 |
end; |
6990
40e5af28d026
change every return value into a more pascal-ish form, using the name of the fucntion (helps the parser and macpas compaitilibity)
koda
parents:
6986
diff
changeset
|
866 |
end; |
12453
8b89fe2115ad
So, was trying to allow spawning on level surfaces of ice but not girders, but seems to be failing. We'll call this WIP
nemo
parents:
12451
diff
changeset
|
867 |
CountLand:= count; |
6581 | 868 |
end; |
869 |
||
10272
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
870 |
function isSteadyPosition(x, y, r, c: LongInt; mask: Longword): boolean; |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
871 |
var cnt, i: LongInt; |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
872 |
begin |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
873 |
cnt:= 0; |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
874 |
isSteadyPosition:= false; |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
875 |
|
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
876 |
if ((y and LAND_HEIGHT_MASK) = 0) and (x - r >= 0) and (x + r < LAND_WIDTH) then |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
877 |
begin |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
878 |
for i:= r - c + 2 to r do |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
879 |
begin |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
880 |
if (Land[y, x - i] and mask <> 0) then inc(cnt); |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
881 |
if (Land[y, x + i] and mask <> 0) then inc(cnt); |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
882 |
|
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
883 |
if cnt >= c then |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
884 |
begin |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
885 |
isSteadyPosition:= true; |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
886 |
exit |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
887 |
end; |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
888 |
end; |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
889 |
end; |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
890 |
end; |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
891 |
|
6888 | 892 |
|
893 |
function NoGearsToAvoid(mX, mY: LongInt; rX, rY: LongInt): boolean; |
|
894 |
var t: PGear; |
|
895 |
begin |
|
6990
40e5af28d026
change every return value into a more pascal-ish form, using the name of the fucntion (helps the parser and macpas compaitilibity)
koda
parents:
6986
diff
changeset
|
896 |
NoGearsToAvoid:= false; |
6888 | 897 |
t:= GearsList; |
898 |
rX:= sqr(rX); |
|
899 |
rY:= sqr(rY); |
|
900 |
while t <> nil do |
|
901 |
begin |
|
902 |
if t^.Kind <= gtExplosives then |
|
903 |
if not (hwSqr(int2hwFloat(mX) - t^.X) / rX + hwSqr(int2hwFloat(mY) - t^.Y) / rY > _1) then |
|
6990
40e5af28d026
change every return value into a more pascal-ish form, using the name of the fucntion (helps the parser and macpas compaitilibity)
koda
parents:
6986
diff
changeset
|
904 |
exit; |
6888 | 905 |
t:= t^.NextGear |
906 |
end; |
|
907 |
NoGearsToAvoid:= true |
|
908 |
end; |
|
909 |
||
6986
409dd3851309
add support for default pascal mode by removing default arguments value (maybe this also helps the parser)
koda
parents:
6888
diff
changeset
|
910 |
procedure FindPlace(var Gear: PGear; withFall: boolean; Left, Right: LongInt); inline; |
409dd3851309
add support for default pascal mode by removing default arguments value (maybe this also helps the parser)
koda
parents:
6888
diff
changeset
|
911 |
begin |
409dd3851309
add support for default pascal mode by removing default arguments value (maybe this also helps the parser)
koda
parents:
6888
diff
changeset
|
912 |
FindPlace(Gear, withFall, Left, Right, false); |
409dd3851309
add support for default pascal mode by removing default arguments value (maybe this also helps the parser)
koda
parents:
6888
diff
changeset
|
913 |
end; |
6888 | 914 |
|
6581 | 915 |
procedure FindPlace(var Gear: PGear; withFall: boolean; Left, Right: LongInt; skipProximity: boolean); |
916 |
var x: LongInt; |
|
11197
283b6e6cf7ea
Scan from right too. Not sure this is actually helpful, so committing separately.
nemo
parents:
11196
diff
changeset
|
917 |
y, sy, dir: LongInt; |
8007 | 918 |
ar: array[0..1023] of TPoint; |
919 |
ar2: array[0..2047] of TPoint; |
|
8026
4a4f21070479
merge xymeng's gsoc engine with a few updates (and further checks on symbol definitions)
koda
parents:
8007
diff
changeset
|
920 |
temp: TPoint; |
6581 | 921 |
cnt, cnt2: Longword; |
922 |
delta: LongInt; |
|
7190
aa8d68817c32
Make it AI survival almost definitely impossible by adding a 3rd pass to FindGear. 1st pass normal, 2nd pass allow close to objects, 3rd pass, allow overlapping objects.
nemo
parents:
7176
diff
changeset
|
923 |
ignoreNearObjects, ignoreOverlap, tryAgain: boolean; |
6581 | 924 |
begin |
7190
aa8d68817c32
Make it AI survival almost definitely impossible by adding a 3rd pass to FindGear. 1st pass normal, 2nd pass allow close to objects, 3rd pass, allow overlapping objects.
nemo
parents:
7176
diff
changeset
|
925 |
ignoreNearObjects:= false; // try not skipping proximity at first |
aa8d68817c32
Make it AI survival almost definitely impossible by adding a 3rd pass to FindGear. 1st pass normal, 2nd pass allow close to objects, 3rd pass, allow overlapping objects.
nemo
parents:
7176
diff
changeset
|
926 |
ignoreOverlap:= false; // this not only skips proximity, but allows overlapping objects (barrels, mines, hogs, crates). Saving it for a 3rd pass. With this active, winning AI Survival goes back to virtual impossibility |
6581 | 927 |
tryAgain:= true; |
10015 | 928 |
if WorldEdge <> weNone then |
9477 | 929 |
begin |
14287
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14208
diff
changeset
|
930 |
Left:= max(Left, leftX + Gear^.Radius); |
9477 | 931 |
Right:= min(Right,rightX-Gear^.Radius) |
932 |
end; |
|
6581 | 933 |
while tryAgain do |
934 |
begin |
|
8007 | 935 |
delta:= LAND_WIDTH div 16; |
6581 | 936 |
cnt2:= 0; |
937 |
repeat |
|
11197
283b6e6cf7ea
Scan from right too. Not sure this is actually helpful, so committing separately.
nemo
parents:
11196
diff
changeset
|
938 |
if GetRandom(2) = 0 then dir:= -1 else dir:= 1; |
283b6e6cf7ea
Scan from right too. Not sure this is actually helpful, so committing separately.
nemo
parents:
11196
diff
changeset
|
939 |
x:= max(LAND_WIDTH div 2048, LongInt(GetRandom(Delta))); |
283b6e6cf7ea
Scan from right too. Not sure this is actually helpful, so committing separately.
nemo
parents:
11196
diff
changeset
|
940 |
if dir = 1 then x:= Left + x else x:= Right - x; |
6581 | 941 |
repeat |
942 |
cnt:= 0; |
|
9809 | 943 |
y:= min(1024, topY) - Gear^.Radius shl 1; |
6581 | 944 |
while y < cWaterLine do |
945 |
begin |
|
946 |
repeat |
|
947 |
inc(y, 2); |
|
7190
aa8d68817c32
Make it AI survival almost definitely impossible by adding a 3rd pass to FindGear. 1st pass normal, 2nd pass allow close to objects, 3rd pass, allow overlapping objects.
nemo
parents:
7176
diff
changeset
|
948 |
until (y >= cWaterLine) or |
12453
8b89fe2115ad
So, was trying to allow spawning on level surfaces of ice but not girders, but seems to be failing. We'll call this WIP
nemo
parents:
12451
diff
changeset
|
949 |
(ignoreOverLap and (CountLand(x, y, Gear^.Radius - 1, 1, $FF00, 0) = 0)) or |
8b89fe2115ad
So, was trying to allow spawning on level surfaces of ice but not girders, but seems to be failing. We'll call this WIP
nemo
parents:
12451
diff
changeset
|
950 |
(not ignoreOverLap and (CountLand(x, y, Gear^.Radius - 1, 1, $FFFF, 0) = 0)); |
8b89fe2115ad
So, was trying to allow spawning on level surfaces of ice but not girders, but seems to be failing. We'll call this WIP
nemo
parents:
12451
diff
changeset
|
951 |
|
6581 | 952 |
|
953 |
sy:= y; |
|
954 |
||
955 |
repeat |
|
956 |
inc(y); |
|
7190
aa8d68817c32
Make it AI survival almost definitely impossible by adding a 3rd pass to FindGear. 1st pass normal, 2nd pass allow close to objects, 3rd pass, allow overlapping objects.
nemo
parents:
7176
diff
changeset
|
957 |
until (y >= cWaterLine) or |
12453
8b89fe2115ad
So, was trying to allow spawning on level surfaces of ice but not girders, but seems to be failing. We'll call this WIP
nemo
parents:
12451
diff
changeset
|
958 |
(ignoreOverlap and |
12454 | 959 |
(CountLand(x, y, Gear^.Radius - 1, 1, $FFFF, 0) <> 0)) or |
12453
8b89fe2115ad
So, was trying to allow spawning on level surfaces of ice but not girders, but seems to be failing. We'll call this WIP
nemo
parents:
12451
diff
changeset
|
960 |
(not ignoreOverlap and |
12454 | 961 |
(CountLand(x, y, Gear^.Radius - 1, 1, lfLandMask, 0) <> 0)); |
6581 | 962 |
|
10272
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
963 |
if (y - sy > Gear^.Radius * 2) and (y < cWaterLine) |
6581 | 964 |
and (((Gear^.Kind = gtExplosives) |
10272
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
965 |
and (ignoreNearObjects or NoGearsToAvoid(x, y - Gear^.Radius, 60, 60)) |
10274 | 966 |
and (isSteadyPosition(x, y+1, Gear^.Radius - 1, 3, $FFFF) |
12453
8b89fe2115ad
So, was trying to allow spawning on level surfaces of ice but not girders, but seems to be failing. We'll call this WIP
nemo
parents:
12451
diff
changeset
|
967 |
or (CountLand(x, y+1, Gear^.Radius - 1, Gear^.Radius+1, $FFFF, 0) > Gear^.Radius) |
10274 | 968 |
)) |
10272
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
969 |
or |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
970 |
((Gear^.Kind <> gtExplosives) |
31ee88c9b4d0
Allow barrels to spawn in U-shaped pits in stable position
unc0rr
parents:
10245
diff
changeset
|
971 |
and (ignoreNearObjects or NoGearsToAvoid(x, y - Gear^.Radius, 110, 110)) |
12454 | 972 |
and (isSteadyPosition(x, y+1, Gear^.Radius - 1, 3, lfIce) |
973 |
or (CountLand(x, y+1, Gear^.Radius - 1, Gear^.Radius+1, $FFFF, lfIce) <> 0) |
|
974 |
))) then |
|
6888 | 975 |
begin |
6581 | 976 |
ar[cnt].X:= x; |
977 |
if withFall then |
|
978 |
ar[cnt].Y:= sy + Gear^.Radius |
|
979 |
else |
|
980 |
ar[cnt].Y:= y - Gear^.Radius; |
|
981 |
inc(cnt) |
|
982 |
end; |
|
983 |
||
7603
e9c3c67b5dfd
reducing this value is sufficient to ensure crates drop just below top border or a girder
nemo
parents:
7599
diff
changeset
|
984 |
inc(y, 10) |
6581 | 985 |
end; |
986 |
||
987 |
if cnt > 0 then |
|
10015 | 988 |
begin |
989 |
temp := ar[GetRandom(cnt)]; |
|
990 |
with temp do |
|
6581 | 991 |
begin |
992 |
ar2[cnt2].x:= x; |
|
993 |
ar2[cnt2].y:= y; |
|
994 |
inc(cnt2) |
|
11197
283b6e6cf7ea
Scan from right too. Not sure this is actually helpful, so committing separately.
nemo
parents:
11196
diff
changeset
|
995 |
end; |
11196
0f6916065849
This should probably fix feedback that hogs weren't spawning on left side of map.
nemo
parents:
11046
diff
changeset
|
996 |
end; |
11197
283b6e6cf7ea
Scan from right too. Not sure this is actually helpful, so committing separately.
nemo
parents:
11196
diff
changeset
|
997 |
inc(x, Delta*dir) |
283b6e6cf7ea
Scan from right too. Not sure this is actually helpful, so committing separately.
nemo
parents:
11196
diff
changeset
|
998 |
until ((dir = 1) and (x > Right)) or ((dir = -1) and (x < Left)); |
6581 | 999 |
|
1000 |
dec(Delta, 60) |
|
1001 |
until (cnt2 > 0) or (Delta < 70); |
|
7190
aa8d68817c32
Make it AI survival almost definitely impossible by adding a 3rd pass to FindGear. 1st pass normal, 2nd pass allow close to objects, 3rd pass, allow overlapping objects.
nemo
parents:
7176
diff
changeset
|
1002 |
// if either of these has not been tried, do another pass |
aa8d68817c32
Make it AI survival almost definitely impossible by adding a 3rd pass to FindGear. 1st pass normal, 2nd pass allow close to objects, 3rd pass, allow overlapping objects.
nemo
parents:
7176
diff
changeset
|
1003 |
if (cnt2 = 0) and skipProximity and (not ignoreOverlap) then |
6581 | 1004 |
tryAgain:= true |
1005 |
else tryAgain:= false; |
|
7190
aa8d68817c32
Make it AI survival almost definitely impossible by adding a 3rd pass to FindGear. 1st pass normal, 2nd pass allow close to objects, 3rd pass, allow overlapping objects.
nemo
parents:
7176
diff
changeset
|
1006 |
if ignoreNearObjects then ignoreOverlap:= true; |
aa8d68817c32
Make it AI survival almost definitely impossible by adding a 3rd pass to FindGear. 1st pass normal, 2nd pass allow close to objects, 3rd pass, allow overlapping objects.
nemo
parents:
7176
diff
changeset
|
1007 |
ignoreNearObjects:= true; |
6581 | 1008 |
end; |
1009 |
||
1010 |
if cnt2 > 0 then |
|
8026
4a4f21070479
merge xymeng's gsoc engine with a few updates (and further checks on symbol definitions)
koda
parents:
8007
diff
changeset
|
1011 |
begin |
4a4f21070479
merge xymeng's gsoc engine with a few updates (and further checks on symbol definitions)
koda
parents:
8007
diff
changeset
|
1012 |
temp := ar2[GetRandom(cnt2)]; |
4a4f21070479
merge xymeng's gsoc engine with a few updates (and further checks on symbol definitions)
koda
parents:
8007
diff
changeset
|
1013 |
with temp do |
6581 | 1014 |
begin |
1015 |
Gear^.X:= int2hwFloat(x); |
|
1016 |
Gear^.Y:= int2hwFloat(y); |
|
1017 |
AddFileLog('Assigned Gear coordinates (' + inttostr(x) + ',' + inttostr(y) + ')'); |
|
1018 |
end |
|
8026
4a4f21070479
merge xymeng's gsoc engine with a few updates (and further checks on symbol definitions)
koda
parents:
8007
diff
changeset
|
1019 |
end |
11482
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1020 |
else |
6581 | 1021 |
begin |
1022 |
OutError('Can''t find place for Gear', false); |
|
1023 |
if Gear^.Kind = gtHedgehog then |
|
11482
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1024 |
begin |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1025 |
cnt:= 0; |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1026 |
if GameTicks = 0 then |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1027 |
begin |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1028 |
//AddFileLog('Trying to make a hole'); |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1029 |
while (cnt < 1000) do |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1030 |
begin |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1031 |
inc(cnt); |
11756
20e0a72e0e2c
make hog fallback (flower-in-hole) positioning respect limits (e.g. used by gfDivideTeams)
sheepluva
parents:
11556
diff
changeset
|
1032 |
x:= left+GetRandom(right-left-2*cHHRadius)+cHHRadius; |
11484 | 1033 |
y:= topY+GetRandom(LAND_HEIGHT-topY-64)+48; |
11483
8c95d5a4366c
Tweak the hole carving to become less agressive about spacing if random points keep failing.
nemo
parents:
11482
diff
changeset
|
1034 |
if NoGearsToAvoid(x, y, 100 div max(1,cnt div 100), 100 div max(1,cnt div 100)) then |
11482
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1035 |
begin |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1036 |
Gear^.State:= Gear^.State or gsttmpFlag; |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1037 |
Gear^.X:= int2hwFloat(x); |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1038 |
Gear^.Y:= int2hwFloat(y); |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1039 |
AddFileLog('Picked a spot for hog at coordinates (' + inttostr(hwRound(Gear^.X)) + ',' + inttostr(hwRound(Gear^.Y)) + ')'); |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1040 |
cnt:= 2000 |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1041 |
end |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1042 |
end; |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1043 |
end; |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1044 |
if cnt < 2000 then |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1045 |
begin |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1046 |
Gear^.Hedgehog^.Effects[heResurrectable] := 0; |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1047 |
DeleteGear(Gear); |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1048 |
Gear:= nil |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1049 |
end |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1050 |
end |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1051 |
else |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1052 |
begin |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1053 |
DeleteGear(Gear); |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1054 |
Gear:= nil |
e425a6eb9da3
Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents:
11477
diff
changeset
|
1055 |
end |
6581 | 1056 |
end |
1057 |
end; |
|
1058 |
||
13904 | 1059 |
function CheckGearNearImpl(Kind: TGearType; X, Y: hwFloat; rX, rY: LongInt; exclude: PGear): PGear; |
13905 | 1060 |
var t: PGear; |
13906 | 1061 |
width, bound, dX, dY: hwFloat; |
13897 | 1062 |
isHit: Boolean; |
15186 | 1063 |
i, j: LongWord; |
6581 | 1064 |
begin |
13899 | 1065 |
bound:= _1_5 * int2hwFloat(max(rX, rY)); |
13897 | 1066 |
rX:= sqr(rX); |
1067 |
rY:= sqr(rY); |
|
13898 | 1068 |
width:= int2hwFloat(RightX - LeftX); |
15186 | 1069 |
if (Kind = gtHedgehog) then |
13404 | 1070 |
begin |
15186 | 1071 |
for j:= 0 to Pred(TeamsCount) do |
1072 |
if TeamsArray[j]^.TeamHealth > 0 then // it's impossible for a team to have hogs in game and zero health right? |
|
1073 |
with TeamsArray[j]^ do |
|
1074 |
for i:= 0 to cMaxHHIndex do |
|
1075 |
with Hedgehogs[i] do |
|
1076 |
if (Gear <> nil) and (Gear <> exclude) then |
|
1077 |
begin |
|
1078 |
// code duplication - could throw into an inline function I guess |
|
1079 |
dX := X - Gear^.X; |
|
1080 |
dY := Y - Gear^.Y; |
|
1081 |
isHit := (hwAbs(dX) + hwAbs(dY) < bound) |
|
1082 |
and (not ((hwSqr(dX) / rX + hwSqr(dY) / rY) > _1)); |
|
13897 | 1083 |
|
15186 | 1084 |
if (not isHit) and (WorldEdge = weWrap) then |
1085 |
begin |
|
1086 |
if (hwAbs(dX - width) + hwAbs(dY) < bound) |
|
1087 |
and (not ((hwSqr(dX - width) / rX + hwSqr(dY) / rY) > _1)) then |
|
1088 |
isHit := true |
|
1089 |
else if (hwAbs(dX + width) + hwAbs(dY) < bound) |
|
1090 |
and (not ((hwSqr(dX + width) / rX + hwSqr(dY) / rY) > _1)) then |
|
1091 |
isHit := true |
|
1092 |
end; |
|
1093 |
||
1094 |
if isHit then |
|
1095 |
begin |
|
1096 |
CheckGearNearImpl:= Gear; |
|
1097 |
exit; |
|
1098 |
end |
|
1099 |
end; |
|
1100 |
end |
|
1101 |
else |
|
1102 |
begin |
|
1103 |
t:= GearsList; |
|
1104 |
||
1105 |
while t <> nil do |
|
13897 | 1106 |
begin |
15186 | 1107 |
if (t <> exclude) and (t^.Kind = Kind) then |
1108 |
begin |
|
1109 |
dX := X - t^.X; |
|
1110 |
dY := Y - t^.Y; |
|
1111 |
isHit := (hwAbs(dX) + hwAbs(dY) < bound) |
|
1112 |
and (not ((hwSqr(dX) / rX + hwSqr(dY) / rY) > _1)); |
|
13897 | 1113 |
|
15186 | 1114 |
if (not isHit) and (WorldEdge = weWrap) then |
1115 |
begin |
|
1116 |
if (hwAbs(dX - width) + hwAbs(dY) < bound) |
|
1117 |
and (not ((hwSqr(dX - width) / rX + hwSqr(dY) / rY) > _1)) then |
|
1118 |
isHit := true |
|
1119 |
else if (hwAbs(dX + width) + hwAbs(dY) < bound) |
|
1120 |
and (not ((hwSqr(dX + width) / rX + hwSqr(dY) / rY) > _1)) then |
|
1121 |
isHit := true |
|
1122 |
end; |
|
1123 |
||
1124 |
if isHit then |
|
1125 |
begin |
|
1126 |
CheckGearNearImpl:= t; |
|
1127 |
exit; |
|
1128 |
end; |
|
1129 |
end; |
|
1130 |
t:= t^.NextGear |
|
1131 |
end |
|
13404 | 1132 |
end; |
1133 |
||
13906 | 1134 |
CheckGearNearImpl:= nil |
13897 | 1135 |
end; |
1136 |
||
1137 |
function CheckGearNear(Kind: TGearType; X, Y: hwFloat; rX, rY: LongInt): PGear; |
|
1138 |
begin |
|
1139 |
CheckGearNear := CheckGearNearImpl(Kind, X, Y, rX, rY, nil); |
|
13404 | 1140 |
end; |
1141 |
||
1142 |
function CheckGearNear(Gear: PGear; Kind: TGearType; rX, rY: LongInt): PGear; |
|
1143 |
begin |
|
13897 | 1144 |
CheckGearNear := CheckGearNearImpl(Kind, Gear^.X, Gear^.Y, rX, rY, Gear); |
6581 | 1145 |
end; |
1146 |
||
7592 | 1147 |
procedure CheckCollision(Gear: PGear); inline; |
1148 |
begin |
|
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9685
diff
changeset
|
1149 |
if (TestCollisionXwithGear(Gear, hwSign(Gear^.dX)) <> 0) |
7592 | 1150 |
or (TestCollisionYwithGear(Gear, hwSign(Gear^.dY)) <> 0) then |
1151 |
Gear^.State := Gear^.State or gstCollision |
|
1152 |
else |
|
1153 |
Gear^.State := Gear^.State and (not gstCollision) |
|
1154 |
end; |
|
1155 |
||
1156 |
procedure CheckCollisionWithLand(Gear: PGear); inline; |
|
1157 |
begin |
|
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9685
diff
changeset
|
1158 |
if (TestCollisionX(Gear, hwSign(Gear^.dX)) <> 0) |
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9685
diff
changeset
|
1159 |
or (TestCollisionY(Gear, hwSign(Gear^.dY)) <> 0) then |
7592 | 1160 |
Gear^.State := Gear^.State or gstCollision |
8330 | 1161 |
else |
7592 | 1162 |
Gear^.State := Gear^.State and (not gstCollision) |
1163 |
end; |
|
1164 |
||
7719
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1165 |
function MakeHedgehogsStep(Gear: PGear) : boolean; |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1166 |
begin |
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9685
diff
changeset
|
1167 |
if TestCollisionXwithGear(Gear, hwSign(Gear^.dX)) <> 0 then if (TestCollisionYwithGear(Gear, -1) = 0) then |
7719
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1168 |
begin |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1169 |
Gear^.Y:= Gear^.Y - _1; |
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9685
diff
changeset
|
1170 |
if TestCollisionXwithGear(Gear, hwSign(Gear^.dX)) <> 0 then if (TestCollisionYwithGear(Gear, -1) = 0) then |
7719
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1171 |
begin |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1172 |
Gear^.Y:= Gear^.Y - _1; |
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9685
diff
changeset
|
1173 |
if TestCollisionXwithGear(Gear, hwSign(Gear^.dX)) <> 0 then if (TestCollisionYwithGear(Gear, -1) = 0) then |
7719
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1174 |
begin |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1175 |
Gear^.Y:= Gear^.Y - _1; |
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9685
diff
changeset
|
1176 |
if TestCollisionXwithGear(Gear, hwSign(Gear^.dX)) <> 0 then if (TestCollisionYwithGear(Gear, -1) = 0) then |
7719
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1177 |
begin |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1178 |
Gear^.Y:= Gear^.Y - _1; |
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9685
diff
changeset
|
1179 |
if TestCollisionXwithGear(Gear, hwSign(Gear^.dX)) <> 0 then if (TestCollisionYwithGear(Gear, -1) = 0) then |
7719
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1180 |
begin |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1181 |
Gear^.Y:= Gear^.Y - _1; |
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9685
diff
changeset
|
1182 |
if TestCollisionXwithGear(Gear, hwSign(Gear^.dX)) <> 0 then if (TestCollisionYwithGear(Gear, -1) = 0) then |
7719
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1183 |
begin |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1184 |
Gear^.Y:= Gear^.Y - _1; |
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9685
diff
changeset
|
1185 |
if TestCollisionXwithGear(Gear, hwSign(Gear^.dX)) <> 0 then |
7719
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1186 |
Gear^.Y:= Gear^.Y + _6 |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1187 |
end else Gear^.Y:= Gear^.Y + _5 else |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1188 |
end else Gear^.Y:= Gear^.Y + _4 else |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1189 |
end else Gear^.Y:= Gear^.Y + _3 else |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1190 |
end else Gear^.Y:= Gear^.Y + _2 else |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1191 |
end else Gear^.Y:= Gear^.Y + _1 |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1192 |
end; |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1193 |
|
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9685
diff
changeset
|
1194 |
if TestCollisionXwithGear(Gear, hwSign(Gear^.dX)) = 0 then |
7719
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1195 |
begin |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1196 |
Gear^.X:= Gear^.X + SignAs(_1, Gear^.dX); |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1197 |
MakeHedgehogsStep:= true |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1198 |
end else |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1199 |
MakeHedgehogsStep:= false; |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1200 |
|
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1201 |
if TestCollisionYwithGear(Gear, 1) = 0 then |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1202 |
begin |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1203 |
Gear^.Y:= Gear^.Y + _1; |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1204 |
if TestCollisionYwithGear(Gear, 1) = 0 then |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1205 |
begin |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1206 |
Gear^.Y:= Gear^.Y + _1; |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1207 |
if TestCollisionYwithGear(Gear, 1) = 0 then |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1208 |
begin |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1209 |
Gear^.Y:= Gear^.Y + _1; |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1210 |
if TestCollisionYwithGear(Gear, 1) = 0 then |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1211 |
begin |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1212 |
Gear^.Y:= Gear^.Y + _1; |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1213 |
if TestCollisionYwithGear(Gear, 1) = 0 then |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1214 |
begin |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1215 |
Gear^.Y:= Gear^.Y + _1; |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1216 |
if TestCollisionYwithGear(Gear, 1) = 0 then |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1217 |
begin |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1218 |
Gear^.Y:= Gear^.Y + _1; |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1219 |
if TestCollisionYwithGear(Gear, 1) = 0 then |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1220 |
begin |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1221 |
Gear^.Y:= Gear^.Y - _6; |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1222 |
Gear^.dY:= _0; |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1223 |
Gear^.State:= Gear^.State or gstMoving; |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1224 |
exit |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1225 |
end; |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1226 |
end |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1227 |
end |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1228 |
end |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1229 |
end |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1230 |
end |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1231 |
end; |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1232 |
end; |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7627
diff
changeset
|
1233 |
|
9285 | 1234 |
|
1235 |
procedure ShotgunShot(Gear: PGear); |
|
1236 |
var t: PGear; |
|
1237 |
dmg, r, dist: LongInt; |
|
1238 |
dx, dy: hwFloat; |
|
1239 |
begin |
|
1240 |
Gear^.Radius:= cShotgunRadius; |
|
1241 |
t:= GearsList; |
|
1242 |
while t <> nil do |
|
1243 |
begin |
|
1244 |
case t^.Kind of |
|
1245 |
gtHedgehog, |
|
1246 |
gtMine, |
|
1247 |
gtSMine, |
|
13412
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13408
diff
changeset
|
1248 |
gtAirMine, |
9285 | 1249 |
gtKnife, |
1250 |
gtCase, |
|
1251 |
gtTarget, |
|
14201
ab5e710d353d
Remove all traces of dead code related to amStructure/gtStructure
Wuzzy <Wuzzy2@mail.ru>
parents:
14046
diff
changeset
|
1252 |
gtExplosives: begin |
9285 | 1253 |
//addFileLog('ShotgunShot radius: ' + inttostr(Gear^.Radius) + ', t^.Radius = ' + inttostr(t^.Radius) + ', distance = ' + inttostr(dist) + ', dmg = ' + inttostr(dmg)); |
1254 |
dmg:= 0; |
|
1255 |
r:= Gear^.Radius + t^.Radius; |
|
1256 |
dx:= Gear^.X-t^.X; |
|
1257 |
dx.isNegative:= false; |
|
1258 |
dy:= Gear^.Y-t^.Y; |
|
1259 |
dy.isNegative:= false; |
|
1260 |
if r-hwRound(dx+dy) > 0 then |
|
1261 |
begin |
|
1262 |
dist:= hwRound(Distance(dx, dy)); |
|
11477 | 1263 |
dmg:= ModifyDamage(min(r - dist, Gear^.Boom), t); |
9285 | 1264 |
end; |
1265 |
if dmg > 0 then |
|
1266 |
begin |
|
10558 | 1267 |
if (t^.Kind <> gtHedgehog) or (t^.Hedgehog^.Effects[heInvulnerable] = 0) then |
9285 | 1268 |
ApplyDamage(t, Gear^.Hedgehog, dmg, dsBullet) |
1269 |
else |
|
1270 |
Gear^.State:= Gear^.State or gstWinner; |
|
1271 |
||
1272 |
DeleteCI(t); |
|
1273 |
t^.dX:= t^.dX + Gear^.dX * dmg * _0_01 + SignAs(cHHKick, Gear^.dX); |
|
1274 |
t^.dY:= t^.dY + Gear^.dY * dmg * _0_01; |
|
1275 |
t^.State:= t^.State or gstMoving; |
|
1276 |
if t^.Kind = gtKnife then t^.State:= t^.State and (not gstCollision); |
|
1277 |
t^.Active:= true; |
|
14205 | 1278 |
FollowGear:= t; |
1279 |
||
1280 |
if t^.Kind = gtAirmine then |
|
1281 |
begin |
|
1282 |
t^.Tag:= 1; |
|
1283 |
t^.FlightTime:= 5000; |
|
1284 |
end |
|
9285 | 1285 |
end |
1286 |
end; |
|
1287 |
gtGrave: begin |
|
1288 |
dmg:= 0; |
|
1289 |
r:= Gear^.Radius + t^.Radius; |
|
1290 |
dx:= Gear^.X-t^.X; |
|
1291 |
dx.isNegative:= false; |
|
1292 |
dy:= Gear^.Y-t^.Y; |
|
1293 |
dy.isNegative:= false; |
|
1294 |
if r-hwRound(dx+dy) > 0 then |
|
1295 |
begin |
|
1296 |
dist:= hwRound(Distance(dx, dy)); |
|
11477 | 1297 |
dmg:= ModifyDamage(min(r - dist, Gear^.Boom), t); |
9285 | 1298 |
end; |
1299 |
if dmg > 0 then |
|
1300 |
begin |
|
1301 |
t^.dY:= - _0_1; |
|
1302 |
t^.Active:= true |
|
1303 |
end |
|
1304 |
end; |
|
1305 |
end; |
|
1306 |
t:= t^.NextGear |
|
1307 |
end; |
|
1308 |
if (GameFlags and gfSolidLand) = 0 then |
|
1309 |
DrawExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), cShotgunRadius) |
|
1310 |
end; |
|
1311 |
||
12717
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1312 |
// Returns true if the given hog gear can use the tardis |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1313 |
function CanUseTardis(HHGear: PGear): boolean; |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1314 |
var usable: boolean; |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1315 |
i, j, cnt: LongInt; |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1316 |
HH: PHedgehog; |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1317 |
begin |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1318 |
(* |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1319 |
Conditions for not activating. |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1320 |
1. Hog is last of his clan |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1321 |
2. Sudden Death is in play |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1322 |
3. Hog is a king |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1323 |
*) |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1324 |
usable:= true; |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1325 |
HH:= HHGear^.Hedgehog; |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1326 |
if HHGear <> nil then |
12925
21827fc9ca98
Fix timebox being usable in SD w/ damage=0
Wuzzy <Wuzzy2@mail.ru>
parents:
12903
diff
changeset
|
1327 |
if (HHGear = nil) or (HH^.King) or (SuddenDeathActive) then |
12717
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1328 |
usable:= false; |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1329 |
cnt:= 0; |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1330 |
for j:= 0 to Pred(HH^.Team^.Clan^.TeamsNumber) do |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1331 |
for i:= 0 to Pred(HH^.Team^.Clan^.Teams[j]^.HedgehogsNumber) do |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1332 |
if (HH^.Team^.Clan^.Teams[j]^.Hedgehogs[i].Gear <> nil) |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1333 |
and ((HH^.Team^.Clan^.Teams[j]^.Hedgehogs[i].Gear^.State and gstDrowning) = 0) |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1334 |
and (HH^.Team^.Clan^.Teams[j]^.Hedgehogs[i].Gear^.Health > HH^.Team^.Clan^.Teams[j]^.Hedgehogs[i].Gear^.Damage) then |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1335 |
inc(cnt); |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1336 |
if (cnt < 2) then |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1337 |
usable:= false; |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1338 |
CanUseTardis:= usable; |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1339 |
end; |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12661
diff
changeset
|
1340 |
|
12903 | 1341 |
procedure AmmoShoveImpl(Ammo: PGear; Damage, Power: LongInt; collisions: PGearArray); |
9285 | 1342 |
var t: PGearArray; |
1343 |
Gear: PGear; |
|
1344 |
i, j, tmpDmg: LongInt; |
|
1345 |
VGear: PVisualGear; |
|
1346 |
begin |
|
12903 | 1347 |
t:= collisions; |
1348 |
||
9285 | 1349 |
// Just to avoid hogs on rope dodging fire. |
1350 |
if (CurAmmoGear <> nil) and ((CurAmmoGear^.Kind = gtRope) or (CurAmmoGear^.Kind = gtJetpack) or (CurAmmoGear^.Kind = gtBirdy)) |
|
1351 |
and (CurrentHedgehog^.Gear <> nil) and (CurrentHedgehog^.Gear^.CollisionIndex = -1) |
|
1352 |
and (sqr(hwRound(Ammo^.X) - hwRound(CurrentHedgehog^.Gear^.X)) + sqr(hwRound(Ammo^.Y) - hwRound(CurrentHedgehog^.Gear^.Y)) <= sqr(cHHRadius + Ammo^.Radius)) then |
|
1353 |
begin |
|
1354 |
t^.ar[t^.Count]:= CurrentHedgehog^.Gear; |
|
1355 |
inc(t^.Count) |
|
1356 |
end; |
|
1357 |
||
1358 |
i:= t^.Count; |
|
1359 |
||
1360 |
if (Ammo^.Kind = gtFlame) and (i > 0) then |
|
1361 |
Ammo^.Health:= 0; |
|
1362 |
while i > 0 do |
|
1363 |
begin |
|
1364 |
dec(i); |
|
1365 |
Gear:= t^.ar[i]; |
|
14012 | 1366 |
if (Ammo^.Kind in [gtDEagleShot, gtSniperRifleShot, gtMinigunBullet, |
14342 | 1367 |
gtFirePunch, gtKamikaze, gtWhip, gtShover]) |
13408
9c9d29be9e00
make all bullets function similar to machinegun bullets (can hit/shove objects without checkin)
nemo
parents:
13404
diff
changeset
|
1368 |
and (((Ammo^.Data <> nil) and (PGear(Ammo^.Data) = Gear)) |
9c9d29be9e00
make all bullets function similar to machinegun bullets (can hit/shove objects without checkin)
nemo
parents:
13404
diff
changeset
|
1369 |
or (not UpdateHitOrder(Gear, Ammo^.WDTimer))) then |
11555
881231c1ba46
disallow bullets to hit the hedgehog that fired them (unless bounced/wrapped/portal'd)
sheepluva
parents:
11484
diff
changeset
|
1370 |
continue; |
12903 | 1371 |
|
10015 | 1372 |
if ((Ammo^.Kind = gtFlame) or (Ammo^.Kind = gtBlowTorch)) and |
12903 | 1373 |
(Gear^.Kind = gtHedgehog) and (Gear^.Hedgehog^.Effects[heFrozen] > 255) then |
9285 | 1374 |
Gear^.Hedgehog^.Effects[heFrozen]:= max(255,Gear^.Hedgehog^.Effects[heFrozen]-10000); |
1375 |
tmpDmg:= ModifyDamage(Damage, Gear); |
|
1376 |
if (Gear^.State and gstNoDamage) = 0 then |
|
1377 |
begin |
|
1378 |
||
1379 |
if (Gear^.Kind = gtHedgehog) and (Ammo^.State and gsttmpFlag <> 0) and (Ammo^.Kind = gtShover) then |
|
1380 |
Gear^.FlightTime:= 1; |
|
1381 |
||
1382 |
case Gear^.Kind of |
|
1383 |
gtHedgehog, |
|
1384 |
gtMine, |
|
13404 | 1385 |
gtAirMine, |
9285 | 1386 |
gtSMine, |
1387 |
gtKnife, |
|
1388 |
gtTarget, |
|
1389 |
gtCase, |
|
14201
ab5e710d353d
Remove all traces of dead code related to amStructure/gtStructure
Wuzzy <Wuzzy2@mail.ru>
parents:
14046
diff
changeset
|
1390 |
gtExplosives: |
9285 | 1391 |
begin |
14012 | 1392 |
if (Ammo^.Kind in [gtFirePunch, gtKamikaze]) and (Gear^.Kind <> gtSMine) then |
14004 | 1393 |
PlaySound(sndFirePunchHit); |
1394 |
||
13780 | 1395 |
if Ammo^.Kind in [gtDEagleShot, gtSniperRifleShot, gtMinigunBullet] then |
1396 |
begin |
|
1397 |
VGear := AddVisualGear(t^.cX[i], t^.cY[i], vgtBulletHit); |
|
1398 |
if VGear <> nil then |
|
1399 |
VGear^.Angle := DxDy2Angle(-Ammo^.dX, Ammo^.dY); |
|
1400 |
end; |
|
9285 | 1401 |
if (Ammo^.Kind = gtDrill) then |
1402 |
begin |
|
1403 |
Ammo^.Timer:= 0; |
|
1404 |
exit; |
|
1405 |
end; |
|
10011
ead5e4b21671
Add check for gear kind of hedgehog on invulnerability effect. This probably fixes bug #766, is similar to change in previous r2a1483d91977 and was introduced by r7d925e82e572
nemo
parents:
10010
diff
changeset
|
1406 |
if (Gear^.Kind <> gtHedgehog) or (Gear^.Hedgehog^.Effects[heInvulnerable] = 0) then |
9285 | 1407 |
begin |
1408 |
if (Ammo^.Kind = gtKnife) and (tmpDmg > 0) then |
|
1409 |
for j:= 1 to max(1,min(3,tmpDmg div 5)) do |
|
1410 |
begin |
|
12903 | 1411 |
VGear:= AddVisualGear( |
1412 |
t^.cX[i] - ((t^.cX[i] - hwround(Gear^.X)) div 2), |
|
1413 |
t^.cY[i] - ((t^.cY[i] - hwround(Gear^.Y)) div 2), |
|
1414 |
vgtStraightShot); |
|
9285 | 1415 |
if VGear <> nil then |
1416 |
with VGear^ do |
|
1417 |
begin |
|
1418 |
Tint:= $FFCC00FF; |
|
1419 |
Angle:= random(360); |
|
1420 |
dx:= 0.0005 * (random(100)); |
|
1421 |
dy:= 0.0005 * (random(100)); |
|
1422 |
if random(2) = 0 then |
|
1423 |
dx := -dx; |
|
1424 |
if random(2) = 0 then |
|
1425 |
dy := -dy; |
|
1426 |
FrameTicks:= 600+random(200); |
|
1427 |
State:= ord(sprStar) |
|
1428 |
end |
|
1429 |
end; |
|
14205 | 1430 |
ApplyDamage(Gear, Ammo^.Hedgehog, tmpDmg, dsShove); |
1431 |
||
1432 |
if Gear^.Kind = gtAirmine then |
|
1433 |
begin |
|
1434 |
Gear^.Tag:= 1; |
|
1435 |
Gear^.FlightTime:= 5000; |
|
1436 |
end |
|
9285 | 1437 |
end |
1438 |
else |
|
1439 |
Gear^.State:= Gear^.State or gstWinner; |
|
10015 | 1440 |
if (Gear^.Kind = gtExplosives) and (Ammo^.Kind = gtBlowtorch) then |
9285 | 1441 |
begin |
1442 |
if (Ammo^.Hedgehog^.Gear <> nil) then |
|
1443 |
Ammo^.Hedgehog^.Gear^.State:= Ammo^.Hedgehog^.Gear^.State and (not gstNotKickable); |
|
14045
128fbd36eee4
Stop using dsUnknown, replace with concrete damage sources
Wuzzy <Wuzzy2@mail.ru>
parents:
14027
diff
changeset
|
1444 |
ApplyDamage(Gear, Ammo^.Hedgehog, tmpDmg * 100, dsExplosion); // crank up damage for explosives + blowtorch |
9285 | 1445 |
end; |
1446 |
||
1447 |
if (Gear^.Kind = gtHedgehog) and (Gear^.Hedgehog^.King or (Gear^.Hedgehog^.Effects[heFrozen] > 0)) then |
|
1448 |
begin |
|
13778 | 1449 |
Gear^.dX:= Ammo^.dX * Power * _0_005; |
1450 |
Gear^.dY:= Ammo^.dY * Power * _0_005 |
|
9285 | 1451 |
end |
1452 |
else if ((Ammo^.Kind <> gtFlame) or (Gear^.Kind = gtHedgehog)) and (Power <> 0) then |
|
1453 |
begin |
|
13778 | 1454 |
Gear^.dX:= Ammo^.dX * Power * _0_01; |
1455 |
Gear^.dY:= Ammo^.dY * Power * _0_01 |
|
9285 | 1456 |
end; |
1457 |
||
1458 |
if (not isZero(Gear^.dX)) or (not isZero(Gear^.dY)) then |
|
1459 |
begin |
|
1460 |
Gear^.Active:= true; |
|
1461 |
DeleteCI(Gear); |
|
1462 |
Gear^.State:= Gear^.State or gstMoving; |
|
1463 |
if Gear^.Kind = gtKnife then Gear^.State:= Gear^.State and (not gstCollision); |
|
1464 |
// move the gear upwards a bit to throw it over tiny obstacles at start |
|
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9685
diff
changeset
|
1465 |
if TestCollisionXwithGear(Gear, hwSign(Gear^.dX)) <> 0 then |
9285 | 1466 |
begin |
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9685
diff
changeset
|
1467 |
if (TestCollisionXwithXYShift(Gear, _0, -3, hwSign(Gear^.dX)) = 0) and |
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9685
diff
changeset
|
1468 |
(TestCollisionYwithGear(Gear, -1) = 0) then |
9285 | 1469 |
Gear^.Y:= Gear^.Y - _1; |
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9685
diff
changeset
|
1470 |
if (TestCollisionXwithXYShift(Gear, _0, -2, hwSign(Gear^.dX)) = 0) and |
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9685
diff
changeset
|
1471 |
(TestCollisionYwithGear(Gear, -1) = 0) then |
9285 | 1472 |
Gear^.Y:= Gear^.Y - _1; |
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9685
diff
changeset
|
1473 |
if (TestCollisionXwithXYShift(Gear, _0, -1, hwSign(Gear^.dX)) = 0) and |
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9685
diff
changeset
|
1474 |
(TestCollisionYwithGear(Gear, -1) = 0) then |
9285 | 1475 |
Gear^.Y:= Gear^.Y - _1; |
1476 |
end |
|
1477 |
end; |
|
1478 |
||
1479 |
||
1480 |
if (Ammo^.Kind <> gtFlame) or ((Ammo^.State and gsttmpFlag) = 0) then |
|
1481 |
FollowGear:= Gear |
|
1482 |
end; |
|
1483 |
end |
|
1484 |
end; |
|
1485 |
end; |
|
1486 |
if i <> 0 then |
|
1487 |
SetAllToActive |
|
1488 |
end; |
|
1489 |
||
12903 | 1490 |
procedure AmmoShoveLine(Ammo: PGear; Damage, Power: LongInt; oX, oY, tX, tY: hwFloat); |
1491 |
var t: PGearArray; |
|
1492 |
begin |
|
13408
9c9d29be9e00
make all bullets function similar to machinegun bullets (can hit/shove objects without checkin)
nemo
parents:
13404
diff
changeset
|
1493 |
t:= CheckAllGearsLineCollision(Ammo, oX, oY, tX, tY); |
12903 | 1494 |
AmmoShoveImpl(Ammo, Damage, Power, t); |
1495 |
end; |
|
1496 |
||
1497 |
procedure AmmoShove(Ammo: PGear; Damage, Power: LongInt); |
|
1498 |
begin |
|
1499 |
AmmoShoveImpl(Ammo, Damage, Power, |
|
1500 |
CheckGearsCollision(Ammo)); |
|
1501 |
end; |
|
1502 |
||
14011
105793e575d6
make firepunch hit moving gears (airmines are not amused)
alfadur
parents:
14010
diff
changeset
|
1503 |
procedure AmmoShoveCache(Ammo: PGear; Damage, Power: LongInt); |
105793e575d6
make firepunch hit moving gears (airmines are not amused)
alfadur
parents:
14010
diff
changeset
|
1504 |
begin |
105793e575d6
make firepunch hit moving gears (airmines are not amused)
alfadur
parents:
14010
diff
changeset
|
1505 |
AmmoShoveImpl(Ammo, Damage, Power, |
105793e575d6
make firepunch hit moving gears (airmines are not amused)
alfadur
parents:
14010
diff
changeset
|
1506 |
CheckCacheCollision(Ammo)); |
105793e575d6
make firepunch hit moving gears (airmines are not amused)
alfadur
parents:
14010
diff
changeset
|
1507 |
end; |
9285 | 1508 |
|
1509 |
function CountGears(Kind: TGearType): Longword; |
|
1510 |
var t: PGear; |
|
1511 |
count: Longword = 0; |
|
1512 |
begin |
|
1513 |
||
1514 |
t:= GearsList; |
|
1515 |
while t <> nil do |
|
1516 |
begin |
|
1517 |
if t^.Kind = Kind then |
|
1518 |
inc(count); |
|
1519 |
t:= t^.NextGear |
|
1520 |
end; |
|
1521 |
CountGears:= count; |
|
1522 |
end; |
|
1523 |
||
1524 |
procedure SetAllToActive; |
|
1525 |
var t: PGear; |
|
1526 |
begin |
|
1527 |
AllInactive:= false; |
|
1528 |
t:= GearsList; |
|
1529 |
while t <> nil do |
|
1530 |
begin |
|
1531 |
t^.Active:= true; |
|
1532 |
t:= t^.NextGear |
|
1533 |
end |
|
1534 |
end; |
|
1535 |
||
1536 |
procedure SetAllHHToActive; inline; |
|
1537 |
begin |
|
1538 |
SetAllHHToActive(true) |
|
1539 |
end; |
|
1540 |
||
1541 |
||
1542 |
procedure SetAllHHToActive(Ice: boolean); |
|
1543 |
var t: PGear; |
|
1544 |
begin |
|
1545 |
AllInactive:= false; |
|
1546 |
t:= GearsList; |
|
1547 |
while t <> nil do |
|
1548 |
begin |
|
1549 |
if (t^.Kind = gtHedgehog) or (t^.Kind = gtExplosives) then |
|
1550 |
begin |
|
1551 |
if (t^.Kind = gtHedgehog) and Ice then CheckIce(t); |
|
1552 |
t^.Active:= true |
|
1553 |
end; |
|
1554 |
t:= t^.NextGear |
|
1555 |
end |
|
1556 |
end; |
|
1557 |
||
1558 |
||
1559 |
var GearsNearArray : TPGearArray; |
|
1560 |
function GearsNear(X, Y: hwFloat; Kind: TGearType; r: LongInt): PGearArrayS; |
|
1561 |
var |
|
1562 |
t: PGear; |
|
1563 |
s: Longword; |
|
12748
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12742
diff
changeset
|
1564 |
xc, xc_left, xc_right, yc: hwFloat; |
9285 | 1565 |
begin |
1566 |
r:= r*r; |
|
1567 |
s:= 0; |
|
1568 |
SetLength(GearsNearArray, s); |
|
1569 |
t := GearsList; |
|
10015 | 1570 |
while t <> nil do |
9285 | 1571 |
begin |
12748
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12742
diff
changeset
|
1572 |
xc:= (X - t^.X)*(X - t^.X); |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12742
diff
changeset
|
1573 |
xc_left:= ((X - int2hwFloat(RightX-LeftX)) - t^.X)*((X - int2hwFloat(RightX-LeftX)) - t^.X); |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12742
diff
changeset
|
1574 |
xc_right := ((X + int2hwFloat(RightX-LeftX)) - t^.X)*((X + int2hwFloat(RightX-LeftX)) - t^.X); |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12742
diff
changeset
|
1575 |
yc:= (Y - t^.Y)*(Y - t^.Y); |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12742
diff
changeset
|
1576 |
if (t^.Kind = Kind) |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12742
diff
changeset
|
1577 |
and ((xc + yc < int2hwFloat(r)) |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12742
diff
changeset
|
1578 |
or ((WorldEdge = weWrap) and |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12742
diff
changeset
|
1579 |
((xc_left + yc < int2hwFloat(r)) or |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12742
diff
changeset
|
1580 |
(xc_right + yc < int2hwFloat(r))))) then |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12742
diff
changeset
|
1581 |
begin |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12742
diff
changeset
|
1582 |
inc(s); |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12742
diff
changeset
|
1583 |
SetLength(GearsNearArray, s); |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12742
diff
changeset
|
1584 |
GearsNearArray[s - 1] := t; |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12742
diff
changeset
|
1585 |
end; |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12742
diff
changeset
|
1586 |
t := t^.NextGear; |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12742
diff
changeset
|
1587 |
end; |
9285 | 1588 |
|
1589 |
GearsNear.size:= s; |
|
1590 |
GearsNear.ar:= @GearsNearArray |
|
1591 |
end; |
|
1592 |
||
14773
185f07ec4d12
New callback: onCaseDrop (called when engine MIGHT drop a crate)
Wuzzy <Wuzzy2@mail.ru>
parents:
14754
diff
changeset
|
1593 |
function SpawnBoxOfSmth: PGear; |
185f07ec4d12
New callback: onCaseDrop (called when engine MIGHT drop a crate)
Wuzzy <Wuzzy2@mail.ru>
parents:
14754
diff
changeset
|
1594 |
var t, aTot, uTot, a, h: LongInt; |
9285 | 1595 |
i: TAmmoType; |
1596 |
begin |
|
14773
185f07ec4d12
New callback: onCaseDrop (called when engine MIGHT drop a crate)
Wuzzy <Wuzzy2@mail.ru>
parents:
14754
diff
changeset
|
1597 |
SpawnBoxOfSmth:= nil; |
9285 | 1598 |
if (PlacingHogs) or |
1599 |
(cCaseFactor = 0) |
|
13632
605767bbd022
Move max. number of crate spawns into variable
Wuzzy <Wuzzy2@mail.ru>
parents:
13622
diff
changeset
|
1600 |
or (CountGears(gtCase) >= cMaxCaseDrops) |
9285 | 1601 |
or (GetRandom(cCaseFactor) <> 0) then |
1602 |
exit; |
|
1603 |
||
1604 |
FollowGear:= nil; |
|
1605 |
aTot:= 0; |
|
1606 |
uTot:= 0; |
|
1607 |
for i:= Low(TAmmoType) to High(TAmmoType) do |
|
1608 |
if (Ammoz[i].Ammo.Propz and ammoprop_Utility) = 0 then |
|
1609 |
inc(aTot, Ammoz[i].Probability) |
|
1610 |
else |
|
1611 |
inc(uTot, Ammoz[i].Probability); |
|
1612 |
||
1613 |
t:=0; |
|
1614 |
a:=aTot; |
|
1615 |
h:= 1; |
|
1616 |
||
1617 |
if (aTot+uTot) <> 0 then |
|
1618 |
if ((GameFlags and gfInvulnerable) = 0) then |
|
1619 |
begin |
|
1620 |
h:= cHealthCaseProb * 100; |
|
1621 |
t:= GetRandom(10000); |
|
1622 |
a:= (10000-h)*aTot div (aTot+uTot) |
|
1623 |
end |
|
1624 |
else |
|
1625 |
begin |
|
1626 |
t:= GetRandom(aTot+uTot); |
|
1627 |
h:= 0 |
|
1628 |
end; |
|
1629 |
||
1630 |
||
1631 |
if t<h then |
|
1632 |
begin |
|
1633 |
FollowGear:= AddGear(0, 0, gtCase, 0, _0, _0, 0); |
|
14754
533ac9774279
Add key to display extra gear info tags
Wuzzy <Wuzzy2@mail.ru>
parents:
14579
diff
changeset
|
1634 |
FollowGear^.RenderHealth:= true; |
9285 | 1635 |
FollowGear^.Health:= cHealthCaseAmount; |
1636 |
FollowGear^.Pos:= posCaseHealth; |
|
10506 | 1637 |
// health crate is smaller than the other crates |
1638 |
FollowGear^.Radius := cCaseHealthRadius; |
|
13647
3d14950641a4
Refactor text color variable names, export 2 color values to Lua
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
1639 |
AddCaption(GetEventString(eidNewHealthPack), capcolDefault, capgrpAmmoInfo); |
9285 | 1640 |
end |
1641 |
else if (t<a+h) then |
|
1642 |
begin |
|
1643 |
t:= aTot; |
|
1644 |
if (t > 0) then |
|
1645 |
begin |
|
1646 |
FollowGear:= AddGear(0, 0, gtCase, 0, _0, _0, 0); |
|
1647 |
t:= GetRandom(t); |
|
1648 |
i:= Low(TAmmoType); |
|
1649 |
FollowGear^.Pos:= posCaseAmmo; |
|
1650 |
FollowGear^.AmmoType:= i; |
|
13647
3d14950641a4
Refactor text color variable names, export 2 color values to Lua
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
1651 |
AddCaption(GetEventString(eidNewAmmoPack), capcolDefault, capgrpAmmoInfo); |
9285 | 1652 |
end |
1653 |
end |
|
1654 |
else |
|
1655 |
begin |
|
1656 |
t:= uTot; |
|
1657 |
if (t > 0) then |
|
1658 |
begin |
|
1659 |
FollowGear:= AddGear(0, 0, gtCase, 0, _0, _0, 0); |
|
1660 |
t:= GetRandom(t); |
|
1661 |
i:= Low(TAmmoType); |
|
1662 |
FollowGear^.Pos:= posCaseUtility; |
|
1663 |
FollowGear^.AmmoType:= i; |
|
13647
3d14950641a4
Refactor text color variable names, export 2 color values to Lua
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
1664 |
AddCaption(GetEventString(eidNewUtilityPack), capcolDefault, capgrpAmmoInfo); |
9285 | 1665 |
end |
1666 |
end; |
|
1667 |
||
1668 |
// handles case of no ammo or utility crates - considered also placing booleans in uAmmos and altering probabilities |
|
1669 |
if (FollowGear <> nil) then |
|
1670 |
begin |
|
1671 |
FindPlace(FollowGear, true, 0, LAND_WIDTH); |
|
14773
185f07ec4d12
New callback: onCaseDrop (called when engine MIGHT drop a crate)
Wuzzy <Wuzzy2@mail.ru>
parents:
14754
diff
changeset
|
1672 |
PlayBoxSpawnTaunt(FollowGear); |
185f07ec4d12
New callback: onCaseDrop (called when engine MIGHT drop a crate)
Wuzzy <Wuzzy2@mail.ru>
parents:
14754
diff
changeset
|
1673 |
SpawnBoxOfSmth:= FollowGear; |
185f07ec4d12
New callback: onCaseDrop (called when engine MIGHT drop a crate)
Wuzzy <Wuzzy2@mail.ru>
parents:
14754
diff
changeset
|
1674 |
end |
185f07ec4d12
New callback: onCaseDrop (called when engine MIGHT drop a crate)
Wuzzy <Wuzzy2@mail.ru>
parents:
14754
diff
changeset
|
1675 |
end; |
9285 | 1676 |
|
14773
185f07ec4d12
New callback: onCaseDrop (called when engine MIGHT drop a crate)
Wuzzy <Wuzzy2@mail.ru>
parents:
14754
diff
changeset
|
1677 |
procedure PlayBoxSpawnTaunt(Gear: PGear); |
185f07ec4d12
New callback: onCaseDrop (called when engine MIGHT drop a crate)
Wuzzy <Wuzzy2@mail.ru>
parents:
14754
diff
changeset
|
1678 |
const |
185f07ec4d12
New callback: onCaseDrop (called when engine MIGHT drop a crate)
Wuzzy <Wuzzy2@mail.ru>
parents:
14754
diff
changeset
|
1679 |
// Max. distance between hog and crate for sndThisOneIsMine taunt |
185f07ec4d12
New callback: onCaseDrop (called when engine MIGHT drop a crate)
Wuzzy <Wuzzy2@mail.ru>
parents:
14754
diff
changeset
|
1680 |
ThisOneIsMineDistance : LongInt = 130; |
185f07ec4d12
New callback: onCaseDrop (called when engine MIGHT drop a crate)
Wuzzy <Wuzzy2@mail.ru>
parents:
14754
diff
changeset
|
1681 |
var d, minD: LongInt; |
185f07ec4d12
New callback: onCaseDrop (called when engine MIGHT drop a crate)
Wuzzy <Wuzzy2@mail.ru>
parents:
14754
diff
changeset
|
1682 |
gi, closestHog: PGear; |
185f07ec4d12
New callback: onCaseDrop (called when engine MIGHT drop a crate)
Wuzzy <Wuzzy2@mail.ru>
parents:
14754
diff
changeset
|
1683 |
begin |
14027
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1684 |
// Taunt |
14773
185f07ec4d12
New callback: onCaseDrop (called when engine MIGHT drop a crate)
Wuzzy <Wuzzy2@mail.ru>
parents:
14754
diff
changeset
|
1685 |
if (Gear <> nil) then |
14027
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1686 |
begin |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1687 |
// Look for hog closest to the crate (on the X axis) |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1688 |
gi := GearsList; |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1689 |
minD := LAND_WIDTH + ThisOneIsMineDistance + 1; |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1690 |
closestHog:= nil; |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1691 |
while gi <> nil do |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1692 |
begin |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1693 |
if (gi^.Kind = gtHedgehog) then |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1694 |
begin |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1695 |
// Y axis is ignored to simplify calculations |
14773
185f07ec4d12
New callback: onCaseDrop (called when engine MIGHT drop a crate)
Wuzzy <Wuzzy2@mail.ru>
parents:
14754
diff
changeset
|
1696 |
d := hwRound(hwAbs(gi^.X - Gear^.X)); |
14027
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1697 |
if d < minD then |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1698 |
begin |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1699 |
minD := d; |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1700 |
closestHog:= gi; |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1701 |
end; |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1702 |
end; |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1703 |
gi := gi^.NextGear; |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1704 |
end; |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1705 |
|
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1706 |
// Is closest hog close enough to the crate (on the X axis)? |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1707 |
if (closestHog <> nil) and (closestHog^.Hedgehog <> nil) and (minD <= ThisOneIsMineDistance) then |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1708 |
// If so, there's a chance for a special taunt |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1709 |
if random(3) > 0 then |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1710 |
AddVoice(sndThisOneIsMine, closestHog^.Hedgehog^.Team^.voicepack) |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1711 |
else |
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1712 |
AddVoice(sndReinforce, CurrentTeam^.voicepack) |
14019 | 1713 |
else |
14027
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1714 |
// Default crate drop taunt |
14019 | 1715 |
AddVoice(sndReinforce, CurrentTeam^.voicepack); |
14027
e155b300d49f
Only play sndThisOneIsMine if crate drops close to hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14019
diff
changeset
|
1716 |
end; |
9285 | 1717 |
end; |
1718 |
||
1719 |
||
1720 |
function GetAmmo(Hedgehog: PHedgehog): TAmmoType; |
|
1721 |
var t, aTot: LongInt; |
|
1722 |
i: TAmmoType; |
|
1723 |
begin |
|
1724 |
Hedgehog:= Hedgehog; // avoid hint |
|
1725 |
||
1726 |
aTot:= 0; |
|
1727 |
for i:= Low(TAmmoType) to High(TAmmoType) do |
|
1728 |
if (Ammoz[i].Ammo.Propz and ammoprop_Utility) = 0 then |
|
1729 |
inc(aTot, Ammoz[i].Probability); |
|
1730 |
||
1731 |
t:= aTot; |
|
1732 |
i:= Low(TAmmoType); |
|
1733 |
if (t > 0) then |
|
1734 |
begin |
|
1735 |
t:= GetRandom(t); |
|
1736 |
while t >= 0 do |
|
1737 |
begin |
|
1738 |
inc(i); |
|
1739 |
if (Ammoz[i].Ammo.Propz and ammoprop_Utility) = 0 then |
|
1740 |
dec(t, Ammoz[i].Probability) |
|
1741 |
end |
|
1742 |
end; |
|
1743 |
GetAmmo:= i |
|
1744 |
end; |
|
1745 |
||
1746 |
function GetUtility(Hedgehog: PHedgehog): TAmmoType; |
|
1747 |
var t, uTot: LongInt; |
|
1748 |
i: TAmmoType; |
|
1749 |
begin |
|
1750 |
||
1751 |
uTot:= 0; |
|
1752 |
for i:= Low(TAmmoType) to High(TAmmoType) do |
|
1753 |
if ((Ammoz[i].Ammo.Propz and ammoprop_Utility) <> 0) |
|
1754 |
and ((Hedgehog^.Team^.HedgehogsNumber > 1) or (Ammoz[i].Ammo.AmmoType <> amSwitch)) then |
|
1755 |
inc(uTot, Ammoz[i].Probability); |
|
1756 |
||
1757 |
t:= uTot; |
|
1758 |
i:= Low(TAmmoType); |
|
1759 |
if (t > 0) then |
|
1760 |
begin |
|
1761 |
t:= GetRandom(t); |
|
1762 |
while t >= 0 do |
|
1763 |
begin |
|
1764 |
inc(i); |
|
1765 |
if ((Ammoz[i].Ammo.Propz and ammoprop_Utility) <> 0) and ((Hedgehog^.Team^.HedgehogsNumber > 1) |
|
1766 |
or (Ammoz[i].Ammo.AmmoType <> amSwitch)) then |
|
1767 |
dec(t, Ammoz[i].Probability) |
|
1768 |
end |
|
1769 |
end; |
|
1770 |
GetUtility:= i |
|
1771 |
end; |
|
1772 |
||
9473
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1773 |
(* |
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1774 |
Intended to check Gear X/Y against the map left/right edges and apply one of the world modes |
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1775 |
* Normal - infinite world, do nothing |
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1776 |
* Wrap (entering left edge exits at same height on right edge) |
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1777 |
* Bounce (striking edge is treated as a 100% elasticity bounce) |
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1778 |
* From the depths (same as from sky, but from sea, with submersible flag set) |
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1779 |
|
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1780 |
Trying to make the checks a little broader than on first pass to catch things that don't move normally. |
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1781 |
*) |
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1782 |
function WorldWrap(var Gear: PGear): boolean; |
14568
ca9c632db2cf
Bounce off gears at bouncy world edge only if they move towards it
Wuzzy <Wuzzy2@mail.ru>
parents:
14539
diff
changeset
|
1783 |
var bounced: boolean; |
9473
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1784 |
begin |
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1785 |
WorldWrap:= false; |
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1786 |
if WorldEdge = weNone then exit(false); |
14287
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14208
diff
changeset
|
1787 |
if (hwRound(Gear^.X) < leftX) or |
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14208
diff
changeset
|
1788 |
(hwRound(Gear^.X) > rightX) then |
9473
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1789 |
begin |
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1790 |
if WorldEdge = weWrap then |
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1791 |
begin |
14287
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14208
diff
changeset
|
1792 |
if (hwRound(Gear^.X) < leftX) then |
10160 | 1793 |
Gear^.X:= Gear^.X + int2hwfloat(rightX - leftX) |
1794 |
else Gear^.X:= Gear^.X - int2hwfloat(rightX - leftX); |
|
9557 | 1795 |
LeftImpactTimer:= 150; |
14576
1d3dc553829c
Fix WorldWrap returning sometimes true unjustifiably
Wuzzy <Wuzzy2@mail.ru>
parents:
14568
diff
changeset
|
1796 |
RightImpactTimer:= 150; |
1d3dc553829c
Fix WorldWrap returning sometimes true unjustifiably
Wuzzy <Wuzzy2@mail.ru>
parents:
14568
diff
changeset
|
1797 |
WorldWrap:= true; |
9473
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1798 |
end |
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1799 |
else if WorldEdge = weBounce then |
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1800 |
begin |
14568
ca9c632db2cf
Bounce off gears at bouncy world edge only if they move towards it
Wuzzy <Wuzzy2@mail.ru>
parents:
14539
diff
changeset
|
1801 |
bounced:= false; |
15183
d3998dcc076f
weBounce: Fix some weird bouncing behaviour
Wuzzy <Wuzzy2@mail.ru>
parents:
15155
diff
changeset
|
1802 |
if (hwRound(Gear^.X) - Gear^.Radius < leftX) and (((hwSign(Gear^.dX) = -1) and (not isZero(Gear^.dX))) or (Gear^.Kind = gtHedgehog)) then |
9473
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1803 |
begin |
9557 | 1804 |
LeftImpactTimer:= 333; |
9473
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1805 |
Gear^.dX.isNegative:= false; |
14568
ca9c632db2cf
Bounce off gears at bouncy world edge only if they move towards it
Wuzzy <Wuzzy2@mail.ru>
parents:
14539
diff
changeset
|
1806 |
Gear^.X:= int2hwfloat(leftX + Gear^.Radius); |
ca9c632db2cf
Bounce off gears at bouncy world edge only if they move towards it
Wuzzy <Wuzzy2@mail.ru>
parents:
14539
diff
changeset
|
1807 |
bounced:= true; |
9473
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1808 |
end |
15183
d3998dcc076f
weBounce: Fix some weird bouncing behaviour
Wuzzy <Wuzzy2@mail.ru>
parents:
15155
diff
changeset
|
1809 |
else if (hwRound(Gear^.X) + Gear^.Radius > rightX) and (((hwSign(Gear^.dX) = 1) and (not isZero(Gear^.dX))) or (Gear^.Kind = gtHedgehog)) then |
9473
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1810 |
begin |
9557 | 1811 |
RightImpactTimer:= 333; |
9473
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1812 |
Gear^.dX.isNegative:= true; |
14568
ca9c632db2cf
Bounce off gears at bouncy world edge only if they move towards it
Wuzzy <Wuzzy2@mail.ru>
parents:
14539
diff
changeset
|
1813 |
Gear^.X:= int2hwfloat(rightX-Gear^.Radius); |
ca9c632db2cf
Bounce off gears at bouncy world edge only if they move towards it
Wuzzy <Wuzzy2@mail.ru>
parents:
14539
diff
changeset
|
1814 |
bounced:= true; |
9557 | 1815 |
end; |
14576
1d3dc553829c
Fix WorldWrap returning sometimes true unjustifiably
Wuzzy <Wuzzy2@mail.ru>
parents:
14568
diff
changeset
|
1816 |
if (bounced) then |
1d3dc553829c
Fix WorldWrap returning sometimes true unjustifiably
Wuzzy <Wuzzy2@mail.ru>
parents:
14568
diff
changeset
|
1817 |
begin |
1d3dc553829c
Fix WorldWrap returning sometimes true unjustifiably
Wuzzy <Wuzzy2@mail.ru>
parents:
14568
diff
changeset
|
1818 |
WorldWrap:= true; |
14579
6e5cda26f676
Tweak bounce effects of some gears
Wuzzy <Wuzzy2@mail.ru>
parents:
14577
diff
changeset
|
1819 |
if (Gear^.dX.QWordValue > _0_001.QWordValue) then |
14576
1d3dc553829c
Fix WorldWrap returning sometimes true unjustifiably
Wuzzy <Wuzzy2@mail.ru>
parents:
14568
diff
changeset
|
1820 |
AddBounceEffectForGear(Gear); |
1d3dc553829c
Fix WorldWrap returning sometimes true unjustifiably
Wuzzy <Wuzzy2@mail.ru>
parents:
14568
diff
changeset
|
1821 |
end; |
1d3dc553829c
Fix WorldWrap returning sometimes true unjustifiably
Wuzzy <Wuzzy2@mail.ru>
parents:
14568
diff
changeset
|
1822 |
end |
1d3dc553829c
Fix WorldWrap returning sometimes true unjustifiably
Wuzzy <Wuzzy2@mail.ru>
parents:
14568
diff
changeset
|
1823 |
else |
1d3dc553829c
Fix WorldWrap returning sometimes true unjustifiably
Wuzzy <Wuzzy2@mail.ru>
parents:
14568
diff
changeset
|
1824 |
WorldWrap:= true; |
9473
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1825 |
end; |
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9285
diff
changeset
|
1826 |
end; |
9285 | 1827 |
|
14519
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1828 |
(* |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1829 |
Applies wrap-around logic for the target of homing gears. |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1830 |
|
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1831 |
In wrap-around world edge, the shortest way may to the target might |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1832 |
be across the border, so the X value of the target would lead the |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1833 |
gear to the wrong direction across the whole map. This procedure |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1834 |
changes the target X in this case. |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1835 |
This function must be called after the gear passed through |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1836 |
the wrap-around world edge (WorldWrap returned true). |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1837 |
|
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1838 |
No-op for other world edges. |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1839 |
|
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1840 |
Returns true if target has been changed. |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1841 |
*) |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1842 |
function HomingWrap(var Gear: PGear): boolean; |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1843 |
var dist_center, dist_right, dist_left: hwFloat; |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1844 |
begin |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1845 |
if WorldEdge = weWrap then |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1846 |
begin |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1847 |
HomingWrap:= false; |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1848 |
// We just check the same target 3 times: |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1849 |
// 1) in current section (no change) |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1850 |
// 2) clone in the right section |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1851 |
// 3) clone in the left section |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1852 |
// The gear will go for the target with the shortest distance to the gear. |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1853 |
// For simplicity, we only check distance on the X axis. |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1854 |
dist_center:= hwAbs(Gear^.X - int2hwFloat(Gear^.Target.X)); |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1855 |
dist_right:= hwAbs(Gear^.X - int2hwFloat(Gear^.Target.X + (RightX-LeftX))); |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1856 |
dist_left:= hwAbs(Gear^.X - int2hwFloat(Gear^.Target.X - (RightX-LeftX))); |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1857 |
if (dist_left < dist_right) and (dist_left < dist_center) then |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1858 |
begin |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1859 |
dec(Gear^.Target.X, RightX-LeftX); |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1860 |
HomingWrap:= true; |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1861 |
end |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1862 |
else if (dist_right < dist_left) and (dist_right < dist_center) then |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1863 |
begin |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1864 |
inc(Gear^.Target.X, RightX-LeftX); |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1865 |
HomingWrap:= true; |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1866 |
end; |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1867 |
end; |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14342
diff
changeset
|
1868 |
end; |
13614
13f68f3e7153
Add bounce effect to cake when it touches bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
1869 |
|
13f68f3e7153
Add bounce effect to cake when it touches bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
1870 |
// Add an audiovisual bounce effect for gear after it bounced from bouncy material. |
13f68f3e7153
Add bounce effect to cake when it touches bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
1871 |
// Graphical effect is based on speed. |
10508 | 1872 |
procedure AddBounceEffectForGear(Gear: PGear); |
13614
13f68f3e7153
Add bounce effect to cake when it touches bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
1873 |
begin |
13f68f3e7153
Add bounce effect to cake when it touches bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
1874 |
AddBounceEffectForGear(Gear, hwFloat2Float(Gear^.Density * hwAbs(Gear^.dY) + hwAbs(Gear^.dX)) / 1.5); |
13f68f3e7153
Add bounce effect to cake when it touches bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
1875 |
end; |
13f68f3e7153
Add bounce effect to cake when it touches bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
1876 |
|
13f68f3e7153
Add bounce effect to cake when it touches bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
1877 |
// Same as above, but can specify the size of bounce image with imageScale manually. |
13f68f3e7153
Add bounce effect to cake when it touches bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
1878 |
procedure AddBounceEffectForGear(Gear: PGear; imageScale: Single); |
10508 | 1879 |
var boing: PVisualGear; |
1880 |
begin |
|
14579
6e5cda26f676
Tweak bounce effects of some gears
Wuzzy <Wuzzy2@mail.ru>
parents:
14577
diff
changeset
|
1881 |
if (Gear^.Density < _0_01) or (Gear^.Radius < 2) then |
13577
a71e6856ffab
Fix freeze ray not working through wrap world edge; add DrawLineWrapped
Wuzzy <Wuzzy2@mail.ru>
parents:
13573
diff
changeset
|
1882 |
exit; |
10508 | 1883 |
boing:= AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtStraightShot, 0, false, 1); |
1884 |
if boing <> nil then |
|
1885 |
with boing^ do |
|
1886 |
begin |
|
1887 |
Angle:= random(360); |
|
1888 |
dx:= 0; |
|
1889 |
dy:= 0; |
|
1890 |
FrameTicks:= 200; |
|
13614
13f68f3e7153
Add bounce effect to cake when it touches bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
1891 |
Scale:= imageScale; |
10508 | 1892 |
State:= ord(sprBoing) |
1893 |
end; |
|
13856
f01798038c2e
Rename amDuck and related symbols to amCreeper, gtCreeper, etc.
Wuzzy <Wuzzy2@mail.ru>
parents:
13780
diff
changeset
|
1894 |
PlaySound(sndMelonImpact, true) |
10508 | 1895 |
end; |
1896 |
||
14999
d9de740e194c
Add utility function to get hog left/right looking dir
Wuzzy <Wuzzy2@mail.ru>
parents:
14931
diff
changeset
|
1897 |
function IsHogFacingLeft(Gear: PGear): boolean; |
d9de740e194c
Add utility function to get hog left/right looking dir
Wuzzy <Wuzzy2@mail.ru>
parents:
14931
diff
changeset
|
1898 |
var sign: LongInt; |
d9de740e194c
Add utility function to get hog left/right looking dir
Wuzzy <Wuzzy2@mail.ru>
parents:
14931
diff
changeset
|
1899 |
begin |
d9de740e194c
Add utility function to get hog left/right looking dir
Wuzzy <Wuzzy2@mail.ru>
parents:
14931
diff
changeset
|
1900 |
sign:= hwSign(Gear^.dX); |
15151
6b7d92fa4912
Keep hog facing direction while on parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15057
diff
changeset
|
1901 |
if (CurAmmoGear <> nil) and (CurAmmoGear^.Kind = gtParachute) then |
6b7d92fa4912
Keep hog facing direction while on parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15057
diff
changeset
|
1902 |
IsHogFacingLeft:= CurAmmoGear^.Tag = -1 |
6b7d92fa4912
Keep hog facing direction while on parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15057
diff
changeset
|
1903 |
else if ((Gear^.State and gstHHHJump) <> 0) and (Gear^.Hedgehog^.Effects[heArtillery] = 0) then |
14999
d9de740e194c
Add utility function to get hog left/right looking dir
Wuzzy <Wuzzy2@mail.ru>
parents:
14931
diff
changeset
|
1904 |
IsHogFacingLeft:= sign > 0 |
d9de740e194c
Add utility function to get hog left/right looking dir
Wuzzy <Wuzzy2@mail.ru>
parents:
14931
diff
changeset
|
1905 |
else |
d9de740e194c
Add utility function to get hog left/right looking dir
Wuzzy <Wuzzy2@mail.ru>
parents:
14931
diff
changeset
|
1906 |
IsHogFacingLeft:= sign < 0; |
d9de740e194c
Add utility function to get hog left/right looking dir
Wuzzy <Wuzzy2@mail.ru>
parents:
14931
diff
changeset
|
1907 |
end; |
d9de740e194c
Add utility function to get hog left/right looking dir
Wuzzy <Wuzzy2@mail.ru>
parents:
14931
diff
changeset
|
1908 |
|
11852 | 1909 |
function IsHogLocal(HH: PHedgehog): boolean; |
1910 |
begin |
|
15057
1a754860b0e5
Refactor definition of "local" clans
Wuzzy <Wuzzy2@mail.ru>
parents:
14999
diff
changeset
|
1911 |
IsHogLocal:= (not (HH^.Team^.ExtDriven or (HH^.BotLevel > 0))) or (HH^.Team^.Clan^.LocalOrAlly) or (GameType = gmtDemo); |
11852 | 1912 |
end; |
1913 |
||
6581 | 1914 |
end. |