author | nemo |
Thu, 04 Apr 2013 11:27:23 -0400 | |
changeset 8854 | 31133afaa025 |
parent 8818 | 8f317ba10675 |
child 8833 | c13ebed437cb |
child 8947 | e906ebd59612 |
permissions | -rw-r--r-- |
6581 | 1 |
(* |
2 |
* Hedgewars, a free turn based strategy game |
|
6700 | 3 |
* Copyright (c) 2004-2012 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 |
|
16 |
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA |
|
17 |
*) |
|
18 |
||
19 |
{$INCLUDE "options.inc"} |
|
20 |
||
21 |
unit uGearsHedgehog; |
|
22 |
interface |
|
23 |
uses uTypes; |
|
24 |
||
25 |
procedure doStepHedgehog(Gear: PGear); |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
26 |
procedure AfterAttack; |
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
27 |
procedure HedgehogStep(Gear: PGear); |
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
28 |
procedure doStepHedgehogMoving(Gear: PGear); |
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
29 |
procedure HedgehogChAngle(HHGear: PGear); |
6581 | 30 |
procedure PickUp(HH, Gear: PGear); |
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:
7375
diff
changeset
|
31 |
procedure AddPickup(HH: THedgehog; ammo: TAmmoType; cnt, X, Y: LongWord); |
8574 | 32 |
procedure CheckIce(Gear: PGear); inline; |
6581 | 33 |
|
34 |
implementation |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
35 |
uses uConsts, uVariables, uFloat, uAmmos, uSound, uCaptions, |
6581 | 36 |
uCommands, uLocale, uUtils, uVisualGears, uStats, uIO, uScript, |
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
37 |
uGearsList, uGears, uCollisions, uRandom, uStore, uTeams, |
6581 | 38 |
uGearsUtils; |
39 |
||
7028 | 40 |
var GHStepTicks: LongWord = 0; |
41 |
||
6581 | 42 |
// Shouldn't more of this ammo switching stuff be moved to uAmmos ? |
43 |
function ChangeAmmo(HHGear: PGear): boolean; |
|
44 |
var slot, i: Longword; |
|
45 |
ammoidx: LongInt; |
|
7754 | 46 |
prevAmmo: TAmmoType; |
6581 | 47 |
begin |
48 |
ChangeAmmo:= false; |
|
49 |
slot:= HHGear^.MsgParam; |
|
50 |
||
51 |
with HHGear^.Hedgehog^ do |
|
52 |
begin |
|
53 |
HHGear^.Message:= HHGear^.Message and (not gmSlot); |
|
7754 | 54 |
prevAmmo:= CurAmmoType; |
6581 | 55 |
ammoidx:= 0; |
56 |
if ((HHGear^.State and (gstAttacking or gstAttacked)) <> 0) |
|
57 |
or ((HHGear^.State and gstHHDriven) = 0) then |
|
58 |
exit; |
|
59 |
ChangeAmmo:= true; |
|
60 |
||
61 |
while (ammoidx < cMaxSlotAmmoIndex) and (Ammo^[slot, ammoidx].AmmoType <> CurAmmoType) do |
|
62 |
inc(ammoidx); |
|
63 |
||
8553
a8e1cff496d8
Allow switching away from any weapon when during multishoot.
nemo
parents:
8494
diff
changeset
|
64 |
if (MultiShootAttacks > 0) then |
a8e1cff496d8
Allow switching away from any weapon when during multishoot.
nemo
parents:
8494
diff
changeset
|
65 |
begin |
a8e1cff496d8
Allow switching away from any weapon when during multishoot.
nemo
parents:
8494
diff
changeset
|
66 |
if (CurAmmoType = amSniperRifle) and ((GameFlags and gfArtillery) = 0) then |
a8e1cff496d8
Allow switching away from any weapon when during multishoot.
nemo
parents:
8494
diff
changeset
|
67 |
cArtillery := false; |
8631
796ed875aa95
Call act as if attack ended on last shot if switching while in mid multi-shoot. Thanks to AI for discovering this.
nemo
parents:
8616
diff
changeset
|
68 |
if (Ammoz[CurAmmoType].Ammo.Propz and ammoprop_NoRoundEnd) = 0 then |
796ed875aa95
Call act as if attack ended on last shot if switching while in mid multi-shoot. Thanks to AI for discovering this.
nemo
parents:
8616
diff
changeset
|
69 |
begin |
796ed875aa95
Call act as if attack ended on last shot if switching while in mid multi-shoot. Thanks to AI for discovering this.
nemo
parents:
8616
diff
changeset
|
70 |
MultiShootAttacks:= Ammoz[CurAmmoType].Ammo.NumPerTurn; |
796ed875aa95
Call act as if attack ended on last shot if switching while in mid multi-shoot. Thanks to AI for discovering this.
nemo
parents:
8616
diff
changeset
|
71 |
AfterAttack |
796ed875aa95
Call act as if attack ended on last shot if switching while in mid multi-shoot. Thanks to AI for discovering this.
nemo
parents:
8616
diff
changeset
|
72 |
end |
796ed875aa95
Call act as if attack ended on last shot if switching while in mid multi-shoot. Thanks to AI for discovering this.
nemo
parents:
8616
diff
changeset
|
73 |
else OnUsedAmmo(HHGear^.Hedgehog^) |
8553
a8e1cff496d8
Allow switching away from any weapon when during multishoot.
nemo
parents:
8494
diff
changeset
|
74 |
end; |
6581 | 75 |
|
76 |
MultiShootAttacks:= 0; |
|
77 |
HHGear^.Message:= HHGear^.Message and (not (gmLJump or gmHJump)); |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
78 |
|
6581 | 79 |
if Ammoz[CurAmmoType].Slot = slot then |
80 |
begin |
|
81 |
i:= 0; |
|
82 |
repeat |
|
83 |
inc(ammoidx); |
|
84 |
if (ammoidx > cMaxSlotAmmoIndex) then |
|
85 |
begin |
|
86 |
inc(i); |
|
87 |
CurAmmoType:= amNothing; |
|
88 |
ammoidx:= -1; |
|
89 |
//TryDo(i < 2, 'Engine bug: no ammo in current slot', true) |
|
90 |
end; |
|
91 |
until (i = 1) or ((Ammo^[slot, ammoidx].Count > 0) |
|
92 |
and (Team^.Clan^.TurnNumber > Ammoz[Ammo^[slot, ammoidx].AmmoType].SkipTurns)) |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
93 |
|
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
94 |
end |
6581 | 95 |
else |
96 |
begin |
|
97 |
i:= 0; |
|
98 |
// check whether there is ammo in slot |
|
99 |
while (i <= cMaxSlotAmmoIndex) and ((Ammo^[slot, i].Count = 0) |
|
100 |
or (Team^.Clan^.TurnNumber <= Ammoz[Ammo^[slot, i].AmmoType].SkipTurns)) |
|
101 |
do inc(i); |
|
102 |
||
103 |
if i <= cMaxSlotAmmoIndex then |
|
104 |
ammoidx:= i |
|
105 |
else ammoidx:= -1 |
|
106 |
end; |
|
107 |
if ammoidx >= 0 then |
|
108 |
CurAmmoType:= Ammo^[slot, ammoidx].AmmoType; |
|
7754 | 109 |
if (prevAmmo <> CurAmmoType) then |
110 |
begin |
|
111 |
if CurAmmoType = amKnife then |
|
112 |
LoadHedgehogHat(HHGear^.Hedgehog^, 'Reserved/chef') |
|
113 |
else if prevAmmo = amKnife then |
|
114 |
LoadHedgehogHat(HHGear^.Hedgehog^, Hat); |
|
8051
f26422ef0333
oft-requested, should make the shoppa guys happy, probably, but, knowing them, I'm sure someone will complain
nemo
parents:
8030
diff
changeset
|
115 |
end; |
f26422ef0333
oft-requested, should make the shoppa guys happy, probably, but, knowing them, I'm sure someone will complain
nemo
parents:
8030
diff
changeset
|
116 |
// Try again in the next slot |
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
117 |
if CurAmmoType = prevAmmo then |
8051
f26422ef0333
oft-requested, should make the shoppa guys happy, probably, but, knowing them, I'm sure someone will complain
nemo
parents:
8030
diff
changeset
|
118 |
begin |
f26422ef0333
oft-requested, should make the shoppa guys happy, probably, but, knowing them, I'm sure someone will complain
nemo
parents:
8030
diff
changeset
|
119 |
if slot >= cMaxSlotIndex then slot:= 0 else inc(slot); |
f26422ef0333
oft-requested, should make the shoppa guys happy, probably, but, knowing them, I'm sure someone will complain
nemo
parents:
8030
diff
changeset
|
120 |
HHGear^.MsgParam:= slot; |
f26422ef0333
oft-requested, should make the shoppa guys happy, probably, but, knowing them, I'm sure someone will complain
nemo
parents:
8030
diff
changeset
|
121 |
ChangeAmmo(HHGear) |
7754 | 122 |
end |
6581 | 123 |
end |
124 |
end; |
|
125 |
||
126 |
procedure HHSetWeapon(HHGear: PGear); |
|
127 |
var t: LongInt; |
|
128 |
weap: TAmmoType; |
|
129 |
Hedgehog: PHedgehog; |
|
130 |
s: boolean; |
|
131 |
begin |
|
132 |
s:= false; |
|
133 |
||
134 |
weap:= TAmmoType(HHGear^.MsgParam); |
|
135 |
Hedgehog:= HHGear^.Hedgehog; |
|
136 |
||
137 |
if Hedgehog^.Team^.Clan^.TurnNumber <= Ammoz[weap].SkipTurns then |
|
138 |
exit; // weapon is not activated yet |
|
139 |
||
140 |
HHGear^.MsgParam:= Ammoz[weap].Slot; |
|
141 |
||
142 |
t:= cMaxSlotAmmoIndex; |
|
143 |
||
144 |
HHGear^.Message:= HHGear^.Message and (not gmWeapon); |
|
145 |
||
146 |
with Hedgehog^ do |
|
147 |
while (CurAmmoType <> weap) and (t >= 0) do |
|
148 |
begin |
|
149 |
s:= ChangeAmmo(HHGear); |
|
150 |
dec(t) |
|
151 |
end; |
|
152 |
||
153 |
if s then |
|
154 |
ApplyAmmoChanges(HHGear^.Hedgehog^) |
|
155 |
end; |
|
156 |
||
157 |
procedure HHSetTimer(Gear: PGear); |
|
158 |
var CurWeapon: PAmmo; |
|
159 |
color: LongWord; |
|
160 |
begin |
|
161 |
Gear^.Message:= Gear^.Message and (not gmTimer); |
|
6924 | 162 |
CurWeapon:= GetCurAmmoEntry(Gear^.Hedgehog^); |
6581 | 163 |
with Gear^.Hedgehog^ do |
164 |
if ((Gear^.Message and gmPrecise) <> 0) and ((CurWeapon^.Propz and ammoprop_SetBounce) <> 0) then |
|
165 |
begin |
|
166 |
color:= Gear^.Hedgehog^.Team^.Clan^.Color; |
|
167 |
case Gear^.MsgParam of |
|
168 |
1: begin |
|
7069 | 169 |
AddCaption(FormatA(trmsg[sidBounce], trmsg[sidBounce1]), color, capgrpAmmostate); |
6581 | 170 |
CurWeapon^.Bounciness:= 350; |
171 |
end; |
|
172 |
2: begin |
|
7069 | 173 |
AddCaption(FormatA(trmsg[sidBounce], trmsg[sidBounce2]), color, capgrpAmmostate); |
6581 | 174 |
CurWeapon^.Bounciness:= 700; |
175 |
end; |
|
176 |
3: begin |
|
7069 | 177 |
AddCaption(FormatA(trmsg[sidBounce], trmsg[sidBounce3]), color, capgrpAmmostate); |
6581 | 178 |
CurWeapon^.Bounciness:= 1000; |
179 |
end; |
|
180 |
4: begin |
|
7069 | 181 |
AddCaption(FormatA(trmsg[sidBounce], trmsg[sidBounce4]), color, capgrpAmmostate); |
6581 | 182 |
CurWeapon^.Bounciness:= 2000; |
183 |
end; |
|
184 |
5: begin |
|
7069 | 185 |
AddCaption(FormatA(trmsg[sidBounce], trmsg[sidBounce5]), color, capgrpAmmostate); |
6581 | 186 |
CurWeapon^.Bounciness:= 4000; |
187 |
end |
|
188 |
end |
|
189 |
end |
|
190 |
else if (CurWeapon^.Propz and ammoprop_Timerable) <> 0 then |
|
191 |
begin |
|
192 |
CurWeapon^.Timer:= 1000 * Gear^.MsgParam; |
|
193 |
with CurrentTeam^ do |
|
194 |
ApplyAmmoChanges(Hedgehogs[CurrHedgehog]); |
|
195 |
end; |
|
196 |
end; |
|
197 |
||
198 |
||
199 |
procedure Attack(Gear: PGear); |
|
200 |
var xx, yy, newDx, newDy, lx, ly: hwFloat; |
|
201 |
speech: PVisualGear; |
|
202 |
newGear: PGear; |
|
203 |
CurWeapon: PAmmo; |
|
204 |
altUse: boolean; |
|
205 |
elastic: hwFloat; |
|
206 |
begin |
|
207 |
newGear:= nil; |
|
208 |
bShowFinger:= false; |
|
6924 | 209 |
CurWeapon:= GetCurAmmoEntry(Gear^.Hedgehog^); |
6581 | 210 |
with Gear^, |
211 |
Gear^.Hedgehog^ do |
|
212 |
begin |
|
213 |
if ((State and gstHHDriven) <> 0) and ((State and (gstAttacked or gstHHChooseTarget)) = 0) and (((State and gstMoving) = 0) |
|
214 |
or (Power > 0) |
|
215 |
or (CurAmmoType = amTeleport) |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
216 |
or |
6581 | 217 |
// Allow attacks while moving on ammo with AltAttack |
218 |
((CurAmmoGear <> nil) and ((Ammoz[CurAmmoGear^.AmmoType].Ammo.Propz and ammoprop_AltAttack) <> 0)) |
|
219 |
or ((Ammoz[CurAmmoType].Ammo.Propz and ammoprop_AttackInMove) <> 0)) |
|
220 |
and ((TargetPoint.X <> NoPointX) or ((Ammoz[CurAmmoType].Ammo.Propz and ammoprop_NeedTarget) = 0)) then |
|
221 |
begin |
|
222 |
State:= State or gstAttacking; |
|
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
223 |
if (Power = cMaxPower) or ((Ammoz[CurAmmoType].Ammo.Propz and ammoprop_Power) = 0) then |
6581 | 224 |
Message:= Message and (not gmAttack) |
225 |
else |
|
226 |
begin |
|
227 |
if Power = 0 then |
|
228 |
begin |
|
229 |
AttackBar:= CurrentTeam^.AttackBar; |
|
230 |
PlaySound(sndThrowPowerUp) |
|
231 |
end; |
|
232 |
inc(Power) |
|
233 |
end; |
|
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
234 |
if ((Message and gmAttack) <> 0) then |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
235 |
exit; |
6581 | 236 |
|
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
237 |
if (Ammoz[CurAmmoType].Ammo.Propz and ammoprop_Power) <> 0 then |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
238 |
begin |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
239 |
StopSound(sndThrowPowerUp); |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
240 |
PlaySound(sndThrowRelease); |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
241 |
end; |
6581 | 242 |
|
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
243 |
xx:= SignAs(AngleSin(Angle), dX); |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
244 |
yy:= -AngleCos(Angle); |
6581 | 245 |
|
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
246 |
lx:= X + int2hwfloat(round(GetLaunchX(CurAmmoType, hwSign(dX), Angle))); |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
247 |
ly:= Y + int2hwfloat(round(GetLaunchY(CurAmmoType, Angle))); |
6581 | 248 |
|
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
249 |
if ((Gear^.State and gstHHHJump) <> 0) and (not cArtillery) then |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
250 |
xx:= - xx; |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
251 |
if Ammoz[CurAmmoType].Ammo.AttackVoice <> sndNone then |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
252 |
AddVoice(Ammoz[CurAmmoType].Ammo.AttackVoice, CurrentTeam^.voicepack); |
6581 | 253 |
|
254 |
// Initiating alt attack |
|
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
255 |
if (CurAmmoGear <> nil) |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
256 |
and ((Ammoz[CurAmmoGear^.AmmoType].Ammo.Propz and ammoprop_AltAttack) <> 0) |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
257 |
and ((Gear^.Message and gmLJump) <> 0) |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
258 |
and ((Ammoz[CurAmmoType].Ammo.Propz and ammoprop_AltUse) <> 0) then |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
259 |
begin |
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
260 |
newDx:= dX; |
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
261 |
newDy:= dY; |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
262 |
altUse:= true |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
263 |
end |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
264 |
else |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
265 |
begin |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
266 |
newDx:= xx*Power/cPowerDivisor; |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
267 |
newDy:= yy*Power/cPowerDivisor; |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
268 |
altUse:= false |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
269 |
end; |
6581 | 270 |
|
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
271 |
case CurAmmoType of |
6581 | 272 |
amGrenade: newGear:= AddGear(hwRound(lx), hwRound(ly), gtGrenade, 0, newDx, newDy, CurWeapon^.Timer); |
273 |
amMolotov: newGear:= AddGear(hwRound(lx), hwRound(ly), gtMolotov, 0, newDx, newDy, 0); |
|
274 |
amClusterBomb: newGear:= AddGear(hwRound(lx), hwRound(ly), gtClusterBomb, 0, newDx, newDy, CurWeapon^.Timer); |
|
275 |
amGasBomb: newGear:= AddGear(hwRound(lx), hwRound(ly), gtGasBomb, 0, newDx, newDy, CurWeapon^.Timer); |
|
276 |
amBazooka: newGear:= AddGear(hwRound(lx), hwRound(ly), gtShell, 0, newDx, newDy, 0); |
|
277 |
amSnowball: newGear:= AddGear(hwRound(lx), hwRound(ly), gtSnowball, 0, newDx, newDy, 0); |
|
278 |
amBee: newGear:= AddGear(hwRound(lx), hwRound(ly), gtBee, 0, newDx, newDy, 0); |
|
279 |
amShotgun: begin |
|
280 |
PlaySound(sndShotgunReload); |
|
281 |
newGear:= AddGear(hwRound(lx), hwRound(ly), gtShotgunShot, 0, xx * _0_5, yy * _0_5, 0); |
|
282 |
end; |
|
283 |
amPickHammer: newGear:= AddGear(hwRound(lx), hwRound(ly) + cHHRadius, gtPickHammer, 0, _0, _0, 0); |
|
284 |
amSkip: ParseCommand('/skip', true); |
|
285 |
amRope: newGear:= AddGear(hwRound(lx), hwRound(ly), gtRope, 0, xx, yy, 0); |
|
7602
a620319d377e
Fix throwing things off rope, also make throwing things a bit more generic and gear density dependent (so you can throw mines further, and also throw dynamite a little).
nemo
parents:
7598
diff
changeset
|
286 |
amMine: newGear:= AddGear(hwRound(lx) + hwSign(dX) * 7, hwRound(ly), gtMine, gstWait, SignAs(_0_02, dX), _0, 3000); |
6581 | 287 |
amSMine: newGear:= AddGear(hwRound(lx), hwRound(ly), gtSMine, 0, xx*Power/cPowerDivisor, yy*Power/cPowerDivisor, 0); |
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
288 |
amKnife: begin |
7754 | 289 |
newGear:= AddGear(hwRound(lx), hwRound(ly), gtKnife, 0, xx*Power/cPowerDivisor, yy*Power/cPowerDivisor, 0); |
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
290 |
newGear^.State:= newGear^.State or gstMoving; |
8494
53b91a602955
Cleaver tweaks based on feedback. Nerf damage, shrink radius. This means cleaver will embed into ground quite a bit further.
nemo
parents:
8493
diff
changeset
|
291 |
newGear^.Radius:= 4 // temporarily shrink so it doesn't instantly embed in the ground |
7754 | 292 |
end; |
6581 | 293 |
amDEagle: newGear:= AddGear(hwRound(lx + xx * cHHRadius), hwRound(ly + yy * cHHRadius), gtDEagleShot, 0, xx * _0_5, yy * _0_5, 0); |
294 |
amSineGun: newGear:= AddGear(hwRound(lx + xx * cHHRadius), hwRound(ly + yy * cHHRadius), gtSineGunShot, 0, xx * _0_5, yy * _0_5, 0); |
|
295 |
amPortalGun: begin |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
296 |
newGear:= AddGear(hwRound(lx + xx * cHHRadius), hwRound(ly + yy * cHHRadius), gtPortal, 0, xx * _0_6, yy * _0_6, |
6581 | 297 |
// set selected color |
298 |
CurWeapon^.Pos); |
|
299 |
end; |
|
300 |
amSniperRifle: begin |
|
301 |
PlaySound(sndSniperReload); |
|
302 |
newGear:= AddGear(hwRound(lx + xx * cHHRadius), hwRound(ly + yy * cHHRadius), gtSniperRifleShot, 0, xx * _0_5, yy * _0_5, 0); |
|
303 |
end; |
|
304 |
amDynamite: newGear:= AddGear(hwRound(lx) + hwSign(dX) * 7, hwRound(ly), gtDynamite, 0, SignAs(_0_03, dX), _0, 5000); |
|
305 |
amFirePunch: newGear:= AddGear(hwRound(lx) + hwSign(dX) * 10, hwRound(ly), gtFirePunch, 0, xx, _0, 0); |
|
306 |
amWhip: begin |
|
307 |
newGear:= AddGear(hwRound(lx) + hwSign(dX) * 10, hwRound(ly), gtWhip, 0, SignAs(_1, dX), - _0_8, 0); |
|
308 |
PlaySound(sndWhipCrack) |
|
309 |
end; |
|
310 |
amHammer: begin |
|
311 |
newGear:= AddGear(hwRound(lx) + hwSign(dX) * 10, hwRound(ly), gtHammer, 0, SignAs(_1, dX), - _0_8, 0); |
|
312 |
PlaySound(sndWhack) |
|
313 |
end; |
|
314 |
amBaseballBat: begin |
|
315 |
newGear:= AddGear(hwRound(lx) + hwSign(dX) * 10, hwRound(ly), gtShover, gsttmpFlag, xx * _0_5, yy * _0_5, 0); |
|
316 |
PlaySound(sndBaseballBat) // TODO: Only play if something is hit? |
|
317 |
end; |
|
318 |
amParachute: begin |
|
319 |
newGear:= AddGear(hwRound(lx), hwRound(ly), gtParachute, 0, _0, _0, 0); |
|
320 |
PlaySound(sndParachute) |
|
321 |
end; |
|
322 |
// we save CurWeapon^.Pos (in this case: cursor direction) by using it as (otherwise irrelevant) X value of the new gear. |
|
323 |
amAirAttack: newGear:= AddGear(CurWeapon^.Pos, 0, gtAirAttack, 0, _0, _0, 0); |
|
324 |
amMineStrike: newGear:= AddGear(CurWeapon^.Pos, 0, gtAirAttack, 1, _0, _0, 0); |
|
325 |
amDrillStrike: newGear:= AddGear(CurWeapon^.Pos, 0, gtAirAttack, 3, _0, _0, CurWeapon^.Timer); |
|
326 |
amNapalm: newGear:= AddGear(CurWeapon^.Pos, 0, gtAirAttack, 2, _0, _0, 0); |
|
327 |
amBlowTorch: newGear:= AddGear(hwRound(lx), hwRound(ly), gtBlowTorch, 0, SignAs(_0_5, dX), _0, 0); |
|
328 |
amGirder: newGear:= AddGear(0, 0, gtGirder, CurWeapon^.Pos, _0, _0, 0); |
|
329 |
amTeleport: newGear:= AddGear(CurWeapon^.Pos, 0, gtTeleport, 0, _0, _0, 0); |
|
330 |
amSwitch: newGear:= AddGear(hwRound(lx), hwRound(ly), gtSwitcher, 0, _0, _0, 0); |
|
331 |
amMortar: begin |
|
332 |
playSound(sndMortar); |
|
333 |
newGear:= AddGear(hwRound(lx), hwRound(ly), gtMortar, 0, xx*cMaxPower/cPowerDivisor, yy*cMaxPower/cPowerDivisor, 0); |
|
334 |
end; |
|
335 |
amRCPlane: begin |
|
336 |
newGear:= AddGear(hwRound(lx), hwRound(ly), gtRCPlane, 0, xx * cMaxPower / cPowerDivisor / 4, yy * cMaxPower / cPowerDivisor / 4, 0); |
|
7053 | 337 |
newGear^.SoundChannel:= LoopSound(sndRCPlane) |
6581 | 338 |
end; |
339 |
amKamikaze: newGear:= AddGear(hwRound(lx), hwRound(ly), gtKamikaze, 0, xx * _0_5, yy * _0_5, 0); |
|
7832 | 340 |
amCake: newGear:= AddGear(hwRound(lx) + hwSign(dX) * 3, hwRound(ly), gtCake, 0, SignAs(cLittle, xx), _0, 0); |
6581 | 341 |
amSeduction: newGear:= AddGear(hwRound(lx), hwRound(ly), gtSeduction, 0, _0, _0, 0); |
342 |
amWatermelon: newGear:= AddGear(hwRound(lx), hwRound(ly), gtWatermelon, 0, newDx, newDy, CurWeapon^.Timer); |
|
343 |
amHellishBomb: newGear:= AddGear(hwRound(lx), hwRound(ly), gtHellishBomb, 0, newDx, newDy, 0); |
|
344 |
amDrill: newGear:= AddGear(hwRound(lx), hwRound(ly), gtDrill, 0, newDx, newDy, 0); |
|
345 |
amBallgun: newGear:= AddGear(hwRound(X), hwRound(Y), gtBallgun, 0, xx * _0_5, yy * _0_5, 0); |
|
346 |
amJetpack: newGear:= AddGear(hwRound(lx), hwRound(ly), gtJetpack, 0, _0, _0, 0); |
|
347 |
amBirdy: begin |
|
348 |
PlaySound(sndWhistle); |
|
349 |
newGear:= AddGear(hwRound(lx), hwRound(ly) - 32, gtBirdy, 0, _0, _0, 0); |
|
350 |
end; |
|
351 |
amLowGravity: begin |
|
352 |
PlaySound(sndLowGravity); |
|
353 |
cGravity:= cMaxWindSpeed; |
|
354 |
cGravityf:= 0.00025 |
|
355 |
end; |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
356 |
amExtraDamage: begin |
6581 | 357 |
PlaySound(sndHellishImpact4); |
358 |
cDamageModifier:= _1_5 |
|
359 |
end; |
|
360 |
amInvulnerable: Invulnerable:= true; |
|
361 |
amExtraTime: begin |
|
362 |
PlaySound(sndSwitchHog); |
|
363 |
TurnTimeLeft:= TurnTimeLeft + 30000 |
|
364 |
end; |
|
365 |
amLaserSight: cLaserSighting:= true; |
|
366 |
amVampiric: begin |
|
7053 | 367 |
PlaySoundV(sndOw1, Team^.voicepack); |
6581 | 368 |
cVampiric:= true; |
369 |
end; |
|
370 |
amPiano: begin |
|
371 |
// Tuck the hedgehog away until the piano attack is completed |
|
372 |
Unplaced:= true; |
|
373 |
X:= _0; |
|
374 |
Y:= _0; |
|
8414
c1ac0b64315e
Start piano higher (piano on maps that matched land_height was really weird before). Experiment w/ trying to make birdy shrink into distance to avoid odd birdy vanishes if tracking it.
nemo
parents:
8161
diff
changeset
|
375 |
newGear:= AddGear(TargetPoint.X, -1024, gtPiano, 0, _0, _0, 0); |
6581 | 376 |
PauseMusic |
377 |
end; |
|
378 |
amFlamethrower: newGear:= AddGear(hwRound(X), hwRound(Y), gtFlamethrower, 0, xx * _0_5, yy * _0_5, 0); |
|
379 |
amLandGun: newGear:= AddGear(hwRound(X), hwRound(Y), gtLandGun, 0, xx * _0_5, yy * _0_5, 0); |
|
380 |
amResurrector: begin |
|
381 |
newGear:= AddGear(hwRound(lx), hwRound(ly), gtResurrector, 0, _0, _0, 0); |
|
382 |
newGear^.SoundChannel := LoopSound(sndResurrector); |
|
383 |
end; |
|
8161 | 384 |
//amStructure: newGear:= AddGear(hwRound(lx) + hwSign(dX) * 7, hwRound(ly), gtStructure, gstWait, SignAs(_0_02, dX), _0, 3000); |
6581 | 385 |
amTardis: newGear:= AddGear(hwRound(X), hwRound(Y), gtTardis, 0, _0, _0, 5000); |
8774
39754516eee6
Try to document TGear a bit, so people know what is commonly overridden, and what stuff is used for. Remove gtIceGun-specific values from TGear and abuse a couple of commonly abused members instead.
nemo
parents:
8753
diff
changeset
|
386 |
amIceGun: newGear:= AddGear(hwRound(X), hwRound(Y), gtIceGun, 0, _0, _0, 0); |
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
387 |
end; |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
388 |
if altUse and (newGear <> nil) then |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
389 |
begin |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
390 |
newGear^.dX:= newDx / newGear^.Density; |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
391 |
newGear^.dY:= newDY / newGear^.Density |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
392 |
end; |
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
393 |
|
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
394 |
case CurAmmoType of |
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
395 |
amGrenade, amMolotov, |
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
396 |
amClusterBomb, amGasBomb, |
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
397 |
amBazooka, amSnowball, |
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
398 |
amBee, amSMine, |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
399 |
amMortar, amWatermelon, |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
400 |
amHellishBomb, amDrill: FollowGear:= newGear; |
6581 | 401 |
|
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
402 |
amShotgun, amPickHammer, |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
403 |
amRope, amDEagle, |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
404 |
amSineGun, amSniperRifle, |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
405 |
amFirePunch, amWhip, |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
406 |
amHammer, amBaseballBat, |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
407 |
amParachute, amBlowTorch, |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
408 |
amGirder, amTeleport, |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
409 |
amSwitch, amRCPlane, |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
410 |
amKamikaze, amCake, |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
411 |
amSeduction, amBallgun, |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
412 |
amJetpack, amBirdy, |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
413 |
amFlamethrower, amLandGun, |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
414 |
amResurrector, //amStructure, |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
415 |
amTardis, amPiano, |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
416 |
amIceGun: CurAmmoGear:= newGear; |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
417 |
end; |
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
418 |
|
6581 | 419 |
if ((CurAmmoType = amMine) or (CurAmmoType = amSMine)) and (GameFlags and gfInfAttack <> 0) then |
420 |
newGear^.FlightTime:= GameTicks + 1000 |
|
421 |
else if CurAmmoType = amDrill then |
|
422 |
newGear^.FlightTime:= GameTicks + 250; |
|
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
423 |
if Ammoz[CurAmmoType].Ammo.Propz and ammoprop_NeedTarget <> 0 then |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
424 |
begin |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
425 |
newGear^.Target.X:= TargetPoint.X; |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
426 |
newGear^.Target.Y:= TargetPoint.Y |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
427 |
end; |
8744 | 428 |
if (newGear <> nil) and (newGear^.CollisionMask and lfCurrentHog <> 0) then newGear^.CollisionMask:= newGear^.CollisionMask and (not lfCurrentHog); |
6581 | 429 |
|
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
430 |
// Clear FollowGear if using on a rope/parachute/saucer etc so focus stays with the hog's movement |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
431 |
if altUse then |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
432 |
FollowGear:= nil; |
6581 | 433 |
|
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
434 |
if (newGear <> nil) and ((Ammoz[newGear^.AmmoType].Ammo.Propz and ammoprop_SetBounce) <> 0) then |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
435 |
begin |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
436 |
elastic:= int2hwfloat(CurWeapon^.Bounciness) / _1000; |
6581 | 437 |
|
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
438 |
if elastic < _1 then |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
439 |
newGear^.Elasticity:= newGear^.Elasticity * elastic |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
440 |
else if elastic > _1 then |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
441 |
newGear^.Elasticity:= _1 - ((_1-newGear^.Elasticity) / elastic); |
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
442 |
(* Experimented with friction modifier. Didn't seem helpful |
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
443 |
fric:= int2hwfloat(CurWeapon^.Bounciness) / _250; |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
444 |
if fric < _1 then newGear^.Friction:= newGear^.Friction * fric |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
445 |
else if fric > _1 then newGear^.Friction:= _1 - ((_1-newGear^.Friction) / fric)*) |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
446 |
end; |
6581 | 447 |
|
448 |
||
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
449 |
uStats.AmmoUsed(CurAmmoType); |
6581 | 450 |
|
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
451 |
if not (SpeechText = '') then |
6581 | 452 |
begin |
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
453 |
speech:= AddVisualGear(0, 0, vgtSpeechBubble); |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
454 |
if speech <> nil then |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
455 |
begin |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
456 |
speech^.Text:= SpeechText; |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
457 |
speech^.Hedgehog:= Gear^.Hedgehog; |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
458 |
speech^.FrameTicks:= SpeechType; |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
459 |
end; |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
460 |
SpeechText:= '' |
6581 | 461 |
end; |
462 |
||
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
463 |
Power:= 0; |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
464 |
if (CurAmmoGear <> nil) |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
465 |
and ((Ammoz[CurAmmoType].Ammo.Propz and ammoprop_AltUse) = 0){check for dropping ammo from rope} then |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
466 |
begin |
8566
d9627d65edf7
This and the "retain freezing" stuff could probably use a flag.
nemo
parents:
8562
diff
changeset
|
467 |
if CurAmmoType in [amRope,amResurrector] then Message:= Message or gmAttack; |
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
468 |
CurAmmoGear^.Message:= Message |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
469 |
end |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
470 |
else |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
471 |
begin |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
472 |
if not CurrentTeam^.ExtDriven |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
473 |
and ((Ammoz[CurAmmoType].Ammo.Propz and ammoprop_Power) <> 0) then |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
474 |
SendIPC(_S'a'); |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
475 |
AfterAttack; |
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
476 |
end |
6581 | 477 |
end |
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
478 |
else |
8492
67d2ad3b3ce9
Allow moving after firing cleaver. This changes multishoot behaviour quite a bit. Needs a lot of testing.
nemo
parents:
8414
diff
changeset
|
479 |
Message:= Message and (not gmAttack); |
6581 | 480 |
end; |
481 |
TargetPoint.X := NoPointX; |
|
482 |
ScriptCall('onHogAttack'); |
|
483 |
end; |
|
484 |
||
485 |
procedure AfterAttack; |
|
486 |
var s: shortstring; |
|
487 |
a: TAmmoType; |
|
7459
8511a3f899d3
Allow AfterAttack to proceed even if the Hedgehog is dead. They could be resurrected after all.
nemo
parents:
7426
diff
changeset
|
488 |
HHGear: PGear; |
6581 | 489 |
begin |
7459
8511a3f899d3
Allow AfterAttack to proceed even if the Hedgehog is dead. They could be resurrected after all.
nemo
parents:
7426
diff
changeset
|
490 |
with CurrentHedgehog^ do |
6581 | 491 |
begin |
7459
8511a3f899d3
Allow AfterAttack to proceed even if the Hedgehog is dead. They could be resurrected after all.
nemo
parents:
7426
diff
changeset
|
492 |
HHGear:= Gear; |
6581 | 493 |
a:= CurAmmoType; |
7459
8511a3f899d3
Allow AfterAttack to proceed even if the Hedgehog is dead. They could be resurrected after all.
nemo
parents:
7426
diff
changeset
|
494 |
if HHGear <> nil then HHGear^.State:= HHGear^.State and (not gstAttacking); |
6581 | 495 |
if (Ammoz[a].Ammo.Propz and ammoprop_Effect) = 0 then |
496 |
begin |
|
497 |
Inc(MultiShootAttacks); |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
498 |
|
6581 | 499 |
if (Ammoz[a].Ammo.NumPerTurn >= MultiShootAttacks) then |
500 |
begin |
|
501 |
s:= inttostr(Ammoz[a].Ammo.NumPerTurn - MultiShootAttacks + 1); |
|
502 |
AddCaption(format(trmsg[sidRemaining], s), cWhiteColor, capgrpAmmostate); |
|
503 |
end; |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
504 |
|
6581 | 505 |
if (Ammoz[a].Ammo.NumPerTurn >= MultiShootAttacks) |
506 |
or ((GameFlags and gfMultiWeapon) <> 0) then |
|
507 |
begin |
|
508 |
isInMultiShoot:= true |
|
509 |
end |
|
510 |
else |
|
511 |
begin |
|
512 |
OnUsedAmmo(CurrentHedgehog^); |
|
513 |
if ((Ammoz[a].Ammo.Propz and ammoprop_NoRoundEnd) = 0) and (((GameFlags and gfInfAttack) = 0) or PlacingHogs) then |
|
514 |
begin |
|
515 |
if TagTurnTimeLeft = 0 then |
|
516 |
TagTurnTimeLeft:= TurnTimeLeft; |
|
517 |
TurnTimeLeft:=(Ammoz[a].TimeAfterTurn * cGetAwayTime) div 100; |
|
518 |
end; |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
519 |
if ((Ammoz[a].Ammo.Propz and ammoprop_NoRoundEnd) = 0) and (HHGear <> nil) then |
7462 | 520 |
HHGear^.State:= HHGear^.State or gstAttacked; |
6581 | 521 |
if (Ammoz[a].Ammo.Propz and ammoprop_NoRoundEnd) <> 0 then |
522 |
ApplyAmmoChanges(CurrentHedgehog^) |
|
523 |
end; |
|
524 |
end |
|
525 |
else |
|
526 |
begin |
|
527 |
OnUsedAmmo(CurrentHedgehog^); |
|
528 |
ApplyAmmoChanges(CurrentHedgehog^); |
|
529 |
end; |
|
530 |
AttackBar:= 0 |
|
531 |
end |
|
532 |
end; |
|
533 |
||
534 |
//////////////////////////////////////////////////////////////////////////////// |
|
535 |
procedure doStepHedgehogDead(Gear: PGear); |
|
536 |
const frametime = 200; |
|
537 |
timertime = frametime * 6; |
|
538 |
begin |
|
539 |
if Gear^.Hedgehog^.Unplaced then |
|
540 |
exit; |
|
541 |
if Gear^.Timer > 1 then |
|
542 |
begin |
|
543 |
AllInactive:= false; |
|
544 |
dec(Gear^.Timer); |
|
545 |
if (Gear^.Timer mod frametime) = 0 then |
|
546 |
inc(Gear^.Pos) |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
547 |
end |
6581 | 548 |
else if Gear^.Timer = 1 then |
549 |
begin |
|
550 |
Gear^.State:= Gear^.State or gstNoDamage; |
|
551 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), 30, CurrentHedgehog, EXPLAutoSound); |
|
552 |
AddGear(hwRound(Gear^.X), hwRound(Gear^.Y), gtGrave, 0, _0, _0, 0)^.Hedgehog:= Gear^.Hedgehog; |
|
553 |
DeleteGear(Gear); |
|
554 |
SetAllToActive |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
555 |
end |
6581 | 556 |
else // Gear^.Timer = 0 |
557 |
begin |
|
558 |
AllInactive:= false; |
|
559 |
Gear^.Z:= cCurrHHZ; |
|
560 |
RemoveGearFromList(Gear); |
|
561 |
InsertGearToList(Gear); |
|
7053 | 562 |
PlaySoundV(sndByeBye, Gear^.Hedgehog^.Team^.voicepack); |
6581 | 563 |
Gear^.Pos:= 0; |
564 |
Gear^.Timer:= timertime |
|
565 |
end |
|
566 |
end; |
|
567 |
||
568 |
//////////////////////////////////////////////////////////////////////////////// |
|
569 |
procedure doStepHedgehogGone(Gear: PGear); |
|
570 |
const frametime = 65; |
|
571 |
timertime = frametime * 11; |
|
572 |
begin |
|
573 |
if Gear^.Hedgehog^.Unplaced then |
|
574 |
exit; |
|
575 |
if Gear^.Timer > 1 then |
|
576 |
begin |
|
577 |
AllInactive:= false; |
|
578 |
dec(Gear^.Timer); |
|
579 |
if (Gear^.Timer mod frametime) = 0 then |
|
580 |
inc(Gear^.Pos) |
|
581 |
end |
|
582 |
else |
|
583 |
if Gear^.Timer = 1 then |
|
584 |
begin |
|
585 |
DeleteGear(Gear); |
|
586 |
SetAllToActive |
|
587 |
end |
|
588 |
else // Gear^.Timer = 0 |
|
589 |
begin |
|
590 |
AllInactive:= false; |
|
591 |
Gear^.Z:= cCurrHHZ; |
|
592 |
RemoveGearFromList(Gear); |
|
593 |
InsertGearToList(Gear); |
|
7053 | 594 |
PlaySoundV(sndByeBye, Gear^.Hedgehog^.Team^.voicepack); |
6581 | 595 |
PlaySound(sndWarp); |
596 |
Gear^.Pos:= 0; |
|
597 |
Gear^.Timer:= timertime |
|
598 |
end |
|
599 |
end; |
|
600 |
||
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:
7375
diff
changeset
|
601 |
procedure AddPickup(HH: THedgehog; ammo: TAmmoType; cnt, X, Y: LongWord); |
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:
7375
diff
changeset
|
602 |
var s: shortstring; |
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:
7375
diff
changeset
|
603 |
vga: PVisualGear; |
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:
7375
diff
changeset
|
604 |
begin |
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:
7375
diff
changeset
|
605 |
if cnt <> 0 then AddAmmo(HH, ammo, cnt) |
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:
7375
diff
changeset
|
606 |
else AddAmmo(HH, ammo); |
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:
7375
diff
changeset
|
607 |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
608 |
if (not (HH.Team^.ExtDriven |
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:
7375
diff
changeset
|
609 |
or (HH.BotLevel > 0))) |
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:
7375
diff
changeset
|
610 |
or (HH.Team^.Clan^.ClanIndex = LocalClan) |
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:
7375
diff
changeset
|
611 |
or (GameType = gmtDemo) 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:
7375
diff
changeset
|
612 |
begin |
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:
7375
diff
changeset
|
613 |
if cnt <> 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:
7375
diff
changeset
|
614 |
s:= trammo[Ammoz[ammo].NameId] + ' (+' + IntToStr(cnt) + ')' |
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:
7375
diff
changeset
|
615 |
else |
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:
7375
diff
changeset
|
616 |
s:= trammo[Ammoz[ammo].NameId] + ' (+' + IntToStr(Ammoz[ammo].NumberInCase) + ')'; |
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:
7375
diff
changeset
|
617 |
AddCaption(s, HH.Team^.Clan^.Color, capgrpAmmoinfo); |
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:
7375
diff
changeset
|
618 |
|
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:
7375
diff
changeset
|
619 |
// show ammo icon |
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:
7375
diff
changeset
|
620 |
vga:= AddVisualGear(X, Y, vgtAmmo); |
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:
7375
diff
changeset
|
621 |
if vga <> nil 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:
7375
diff
changeset
|
622 |
vga^.Frame:= Longword(ammo); |
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:
7375
diff
changeset
|
623 |
end; |
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:
7375
diff
changeset
|
624 |
end; |
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:
7375
diff
changeset
|
625 |
|
6581 | 626 |
//////////////////////////////////////////////////////////////////////////////// |
627 |
procedure PickUp(HH, Gear: PGear); |
|
628 |
var s: shortstring; |
|
7406
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7391
diff
changeset
|
629 |
i: LongInt; |
6581 | 630 |
vga: PVisualGear; |
7406
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7391
diff
changeset
|
631 |
ag, gi: PGear; |
6581 | 632 |
begin |
633 |
Gear^.Message:= gmDestroy; |
|
634 |
if (Gear^.Pos and posCaseExplode) <> 0 then |
|
635 |
if (Gear^.Pos and posCasePoison) <> 0 then |
|
636 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), 25, HH^.Hedgehog, EXPLAutoSound + EXPLPoisoned) |
|
637 |
else |
|
638 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), 25, HH^.Hedgehog, EXPLAutoSound) |
|
639 |
else if (Gear^.Pos and posCasePoison) <> 0 then |
|
640 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), 25, HH^.Hedgehog, EXPLAutoSound + EXPLPoisoned + EXPLNoDamage) |
|
641 |
else |
|
642 |
case Gear^.Pos of |
|
643 |
posCaseUtility, |
|
644 |
posCaseAmmo: begin |
|
7597
1ef520fea21c
make cheating a bit easier (mikade insisted). Also, try flipping dust for a bit more variety.
nemo
parents:
7462
diff
changeset
|
645 |
PlaySound(sndShotgunReload); |
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
646 |
if Gear^.AmmoType <> amNothing then |
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:
7375
diff
changeset
|
647 |
begin |
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:
7375
diff
changeset
|
648 |
AddPickup(HH^.Hedgehog^, Gear^.AmmoType, Gear^.Power, hwRound(Gear^.X), hwRound(Gear^.Y)); |
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:
7375
diff
changeset
|
649 |
end |
6581 | 650 |
else |
651 |
begin |
|
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:
7375
diff
changeset
|
652 |
// Add spawning here... |
7409 | 653 |
AddRandomness(GameTicks); |
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
654 |
|
7406
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7391
diff
changeset
|
655 |
gi := GearsList; |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7391
diff
changeset
|
656 |
while gi <> nil do |
7391
588eabb4b384
Apparently order of multiple getrandom in params is undefined. Also remove broken and pointless getrandom call.
nemo
parents:
7389
diff
changeset
|
657 |
begin |
8030
165aeaaaf445
Call fallers less often. Should hopefully still be about as effective at the intended purpose. Should help loads quite a bit.
nemo
parents:
8003
diff
changeset
|
658 |
if (gi^.Kind = gtGenericFaller) and (gi^.State and gstInvisible <> 0) then |
7406
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7391
diff
changeset
|
659 |
begin |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7391
diff
changeset
|
660 |
gi^.Active:= true; |
8030
165aeaaaf445
Call fallers less often. Should hopefully still be about as effective at the intended purpose. Should help loads quite a bit.
nemo
parents:
8003
diff
changeset
|
661 |
gi^.State:= gi^.State or gstTmpFlag; |
7406
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7391
diff
changeset
|
662 |
gi^.X:= int2hwFloat(GetRandom(rightX-leftX)+leftX); |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7391
diff
changeset
|
663 |
gi^.Y:= int2hwFloat(GetRandom(LAND_HEIGHT-topY)+topY); |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7391
diff
changeset
|
664 |
gi^.dX:= _90-(GetRandomf*_360); |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7391
diff
changeset
|
665 |
gi^.dY:= _90-(GetRandomf*_360) |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7391
diff
changeset
|
666 |
end; |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7391
diff
changeset
|
667 |
gi := gi^.NextGear |
7391
588eabb4b384
Apparently order of multiple getrandom in params is undefined. Also remove broken and pointless getrandom call.
nemo
parents:
7389
diff
changeset
|
668 |
end; |
7598 | 669 |
ag:= AddGear(hwRound(Gear^.X), hwRound(Gear^.Y), gtAddAmmo, gstInvisible, _0, _0, GetRandom(125)+25); |
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:
7375
diff
changeset
|
670 |
ag^.Pos:= Gear^.Pos; |
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:
7375
diff
changeset
|
671 |
ag^.Power:= Gear^.Power |
6581 | 672 |
end; |
673 |
end; |
|
674 |
posCaseHealth: begin |
|
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:
7375
diff
changeset
|
675 |
PlaySound(sndShotgunReload); |
6581 | 676 |
inc(HH^.Health, Gear^.Health); |
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:
6992
diff
changeset
|
677 |
HH^.Hedgehog^.Effects[hePoisoned] := 0; |
6581 | 678 |
str(Gear^.Health, s); |
679 |
s:= '+' + s; |
|
680 |
AddCaption(s, HH^.Hedgehog^.Team^.Clan^.Color, capgrpAmmoinfo); |
|
681 |
RenderHealth(HH^.Hedgehog^); |
|
682 |
RecountTeamHealth(HH^.Hedgehog^.Team); |
|
683 |
||
684 |
i:= 0; |
|
685 |
while i < Gear^.Health do |
|
686 |
begin |
|
687 |
vga:= AddVisualGear(hwRound(HH^.X), hwRound(HH^.Y), vgtStraightShot); |
|
688 |
if vga <> nil then |
|
689 |
with vga^ do |
|
690 |
begin |
|
691 |
Tint:= $00FF00FF; |
|
692 |
State:= ord(sprHealth) |
|
693 |
end; |
|
694 |
inc(i, 5); |
|
695 |
end; |
|
696 |
end; |
|
697 |
end |
|
698 |
end; |
|
699 |
||
700 |
procedure HedgehogStep(Gear: PGear); |
|
701 |
var PrevdX: LongInt; |
|
702 |
CurWeapon: PAmmo; |
|
703 |
begin |
|
6924 | 704 |
CurWeapon:= GetCurAmmoEntry(Gear^.Hedgehog^); |
6581 | 705 |
if ((Gear^.State and (gstAttacking or gstMoving)) = 0) then |
706 |
begin |
|
707 |
if isCursorVisible then |
|
708 |
with Gear^.Hedgehog^ do |
|
709 |
with CurWeapon^ do |
|
710 |
begin |
|
711 |
if (Gear^.Message and gmLeft ) <> 0 then |
|
712 |
Pos:= (Pos - 1 + Ammoz[AmmoType].PosCount) mod Ammoz[AmmoType].PosCount |
|
713 |
else |
|
714 |
if (Gear^.Message and gmRight ) <> 0 then |
|
715 |
Pos:= (Pos + 1) mod Ammoz[AmmoType].PosCount |
|
716 |
else |
|
717 |
exit; |
|
7028 | 718 |
GHStepTicks:= 200; |
6581 | 719 |
exit |
720 |
end; |
|
721 |
||
722 |
if ((Gear^.Message and gmAnimate) <> 0) then |
|
723 |
begin |
|
724 |
Gear^.Message:= 0; |
|
725 |
Gear^.State:= Gear^.State or gstAnimation; |
|
726 |
Gear^.Tag:= Gear^.MsgParam; |
|
727 |
Gear^.Timer:= 0; |
|
728 |
Gear^.Pos:= 0 |
|
729 |
end; |
|
730 |
||
731 |
if ((Gear^.Message and gmLJump ) <> 0) then |
|
732 |
begin |
|
733 |
Gear^.Message:= Gear^.Message and (not gmLJump); |
|
734 |
DeleteCI(Gear); |
|
735 |
if TestCollisionYwithGear(Gear, -1) = 0 then |
|
736 |
if not TestCollisionXwithXYShift(Gear, _0, -2, hwSign(Gear^.dX)) then |
|
737 |
Gear^.Y:= Gear^.Y - _2 |
|
738 |
else |
|
739 |
if not TestCollisionXwithXYShift(Gear, _0, -1, hwSign(Gear^.dX)) then |
|
740 |
Gear^.Y:= Gear^.Y - _1; |
|
741 |
if not (TestCollisionXwithGear(Gear, hwSign(Gear^.dX)) |
|
742 |
or (TestCollisionYwithGear(Gear, -1) <> 0)) then |
|
743 |
begin |
|
744 |
Gear^.dY:= -_0_15; |
|
745 |
if not cArtillery then |
|
746 |
Gear^.dX:= SignAs(_0_15, Gear^.dX); |
|
747 |
Gear^.State:= Gear^.State or gstMoving or gstHHJumping; |
|
7053 | 748 |
PlaySoundV(sndJump1, Gear^.Hedgehog^.Team^.voicepack); |
6581 | 749 |
exit |
750 |
end; |
|
751 |
end; |
|
752 |
||
753 |
if ((Gear^.Message and gmHJump ) <> 0) then |
|
754 |
begin |
|
755 |
DeleteCI(Gear); |
|
756 |
Gear^.Message:= Gear^.Message and (not gmHJump); |
|
757 |
||
758 |
Gear^.dY:= -_0_2; |
|
759 |
SetLittle(Gear^.dX); |
|
760 |
Gear^.State:= Gear^.State or gstMoving or gstHHJumping; |
|
7053 | 761 |
PlaySoundV(sndJump3, Gear^.Hedgehog^.Team^.voicepack); |
6581 | 762 |
exit |
763 |
end; |
|
764 |
||
765 |
PrevdX:= hwSign(Gear^.dX); |
|
766 |
if (Gear^.Message and gmLeft )<>0 then |
|
767 |
Gear^.dX:= -cLittle else |
|
768 |
if (Gear^.Message and gmRight )<>0 then |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
769 |
Gear^.dX:= cLittle |
7187
aff30d80bd7b
- Allow camera movement while current hedgehog is falling
unc0rr
parents:
7164
diff
changeset
|
770 |
else exit; |
6581 | 771 |
|
7187
aff30d80bd7b
- Allow camera movement while current hedgehog is falling
unc0rr
parents:
7164
diff
changeset
|
772 |
StepSoundTimer:= cHHStepTicks; |
7719
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7671
diff
changeset
|
773 |
|
7028 | 774 |
GHStepTicks:= cHHStepTicks; |
6581 | 775 |
if PrevdX <> hwSign(Gear^.dX) then |
776 |
begin |
|
777 |
FollowGear:= Gear; |
|
778 |
exit |
|
779 |
end; |
|
780 |
DeleteCI(Gear); // must be after exit!! (see previous line) |
|
781 |
||
782 |
Gear^.Hedgehog^.visStepPos:= (Gear^.Hedgehog^.visStepPos + 1) and 7; |
|
7164
fad64b97947e
Some brainfucking code which greatly reduces number of TestCollision* calls in hedgehog walk routine. Especially helpful to AI optimization. Also fixes some edge cases.
unc0rr
parents:
7069
diff
changeset
|
783 |
|
7719
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7671
diff
changeset
|
784 |
if (not cArtillery) and ((Gear^.Message and gmPrecise) = 0) then |
eeae1cb6b6bf
Move hedgehog's step routine into separate function, use it in both hedgehog and ai code
unc0rr
parents:
7671
diff
changeset
|
785 |
MakeHedgehogsStep(Gear); |
6581 | 786 |
|
8576
286ebfcb3d97
workaround for frequent AllHH active call in hedgehog step
nemo
parents:
8574
diff
changeset
|
787 |
SetAllHHToActive(false); |
6581 | 788 |
AddGearCI(Gear) |
789 |
end |
|
790 |
end; |
|
791 |
||
792 |
procedure HedgehogChAngle(HHGear: PGear); |
|
793 |
var da: LongWord; |
|
794 |
begin |
|
795 |
with HHGear^.Hedgehog^ do |
|
8818
8f317ba10675
This should ensure rope can still be aimed quickly when an alt weapon is active.
nemo
parents:
8795
diff
changeset
|
796 |
if ((CurAmmoGear <> nil) and (CurAmmoGear^.AmmoType = amRope) and ((HHGear^.State and (gstMoving or gstHHJumping)) = gstMoving)) |
6581 | 797 |
or ((CurAmmoType = amPortalGun) and ((HHGear^.State and gstMoving) <> 0)) then |
798 |
da:= 2 |
|
799 |
else da:= 1; |
|
800 |
||
801 |
if (((HHGear^.Message and gmPrecise) = 0) or ((GameTicks mod 5) = 1)) then |
|
802 |
if ((HHGear^.Message and gmUp) <> 0) and (HHGear^.Angle >= CurMinAngle + da) then |
|
803 |
dec(HHGear^.Angle, da) |
|
804 |
else |
|
805 |
if ((HHGear^.Message and gmDown) <> 0) and (HHGear^.Angle + da <= CurMaxAngle) then |
|
806 |
inc(HHGear^.Angle, da) |
|
807 |
end; |
|
808 |
||
809 |
||
810 |
//////////////////////////////////////////////////////////////////////////////// |
|
811 |
procedure doStepHedgehogMoving(Gear: PGear); |
|
812 |
var isFalling, isUnderwater: boolean; |
|
813 |
land: Word; |
|
814 |
begin |
|
815 |
land:= 0; |
|
816 |
isUnderwater:= cWaterLine < hwRound(Gear^.Y) + Gear^.Radius; |
|
817 |
if Gear^.dX.QWordValue > 8160437862 then |
|
818 |
Gear^.dX.QWordValue:= 8160437862; |
|
819 |
if Gear^.dY.QWordValue > 8160437862 then |
|
820 |
Gear^.dY.QWordValue:= 8160437862; |
|
821 |
||
822 |
if Gear^.Hedgehog^.Unplaced then |
|
823 |
begin |
|
824 |
Gear^.dY:= _0; |
|
825 |
Gear^.dX:= _0; |
|
826 |
Gear^.State:= Gear^.State and (not gstMoving); |
|
827 |
exit |
|
828 |
end; |
|
7426
55b49cc1f33a
Changes for the benefit of pas2c. Use downto in for loops to avoid repeated calls of Random/GetRandom. Wrap nots.
nemo
parents:
7409
diff
changeset
|
829 |
isFalling:= (Gear^.dY.isNegative) or (not TestCollisionYKick(Gear, 1)); |
6581 | 830 |
if isFalling then |
831 |
begin |
|
832 |
if (Gear^.dY.isNegative) and TestCollisionYKick(Gear, -1) then |
|
833 |
Gear^.dY:= _0; |
|
834 |
Gear^.State:= Gear^.State or gstMoving; |
|
835 |
if (CurrentHedgehog^.Gear = Gear) |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
836 |
and (hwSqr(Gear^.dX) + hwSqr(Gear^.dY) > _0_003) then |
6581 | 837 |
begin |
7187
aff30d80bd7b
- Allow camera movement while current hedgehog is falling
unc0rr
parents:
7164
diff
changeset
|
838 |
// TODO: why so aggressive at setting FollowGear when falling? |
6581 | 839 |
FollowGear:= Gear; |
840 |
end; |
|
841 |
if isUnderwater then |
|
842 |
Gear^.dY:= Gear^.dY + cGravity / _2 |
|
843 |
else |
|
844 |
begin |
|
845 |
Gear^.dY:= Gear^.dY + cGravity; |
|
846 |
// this set of circumstances could be less complex if jumping was more clearly identified |
|
847 |
if ((GameFlags and gfMoreWind) <> 0) and (((Gear^.Damage <> 0) |
|
848 |
or ((CurAmmoGear <> nil) and ((CurAmmoGear^.AmmoType = amJetpack) or (CurAmmoGear^.AmmoType = amBirdy))) |
|
849 |
or ((Gear^.dY.QWordValue + Gear^.dX.QWordValue) > _0_55.QWordValue))) then |
|
850 |
Gear^.dX := Gear^.dX + cWindSpeed / Gear^.Density |
|
851 |
end |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
852 |
end |
6581 | 853 |
else |
854 |
begin |
|
855 |
land:= TestCollisionYwithGear(Gear, 1); |
|
856 |
if ((Gear^.dX.QWordValue + Gear^.dY.QWordValue) < _0_55.QWordValue) and ((land and lfIce) = 0) |
|
857 |
and ((Gear^.State and gstHHJumping) <> 0) then |
|
858 |
SetLittle(Gear^.dX); |
|
859 |
||
860 |
if not Gear^.dY.isNegative then |
|
861 |
begin |
|
862 |
CheckHHDamage(Gear); |
|
863 |
||
864 |
if ((Gear^.State and gstHHHJump) <> 0) and (not cArtillery) |
|
865 |
and (Gear^.dX.QWordValue < _0_02.QWordValue) then |
|
866 |
Gear^.dX.isNegative:= not Gear^.dX.isNegative; // landing after high jump |
|
867 |
Gear^.State:= Gear^.State and (not (gstHHJumping or gstHHHJump)); |
|
868 |
Gear^.dY:= _0; |
|
869 |
end |
|
870 |
else |
|
871 |
Gear^.dY:= Gear^.dY + cGravity; |
|
872 |
||
873 |
if ((Gear^.State and gstMoving) <> 0) then |
|
874 |
begin |
|
875 |
if land and lfIce <> 0 then |
|
876 |
begin |
|
877 |
Gear^.dX:= Gear^.dX * (_1 - (_1 - Gear^.Friction) / _2) |
|
878 |
end |
|
879 |
else |
|
880 |
Gear^.dX:= Gear^.dX * Gear^.Friction; |
|
881 |
end |
|
882 |
end; |
|
883 |
||
884 |
if (Gear^.State <> 0) then |
|
885 |
DeleteCI(Gear); |
|
886 |
||
887 |
if isUnderwater then |
|
888 |
begin |
|
889 |
Gear^.dY:= Gear^.dY * _0_999; |
|
890 |
Gear^.dX:= Gear^.dX * _0_999; |
|
891 |
end; |
|
892 |
||
893 |
if (Gear^.State and gstMoving) <> 0 then |
|
894 |
if TestCollisionXKick(Gear, hwSign(Gear^.dX)) then |
|
895 |
if not isFalling then |
|
896 |
if hwAbs(Gear^.dX) > _0_01 then |
|
8753
1dfc456b7d50
fix ancient issue with hedgehogs sliding through/into think gaps; fixes issue 542; could and should be optimized (also to make sure that hogs can't slide through little pixel turds) - feel free to do so =P
sheepluva
parents:
8744
diff
changeset
|
897 |
if not (TestCollisionXwithXYShift(Gear, int2hwFloat(hwSign(Gear^.dX)) - Gear^.dX, -1, hwSign(Gear^.dX)) or |
1dfc456b7d50
fix ancient issue with hedgehogs sliding through/into think gaps; fixes issue 542; could and should be optimized (also to make sure that hogs can't slide through little pixel turds) - feel free to do so =P
sheepluva
parents:
8744
diff
changeset
|
898 |
(TestCollisionYwithXYShift(Gear, hwSign(Gear^.dX) - hwRound(Gear^.dX), -1, -1))) then |
6581 | 899 |
begin |
900 |
Gear^.X:= Gear^.X + Gear^.dX; |
|
901 |
Gear^.dX:= Gear^.dX * _0_96; |
|
902 |
Gear^.Y:= Gear^.Y - _1 |
|
903 |
end |
|
904 |
else |
|
8753
1dfc456b7d50
fix ancient issue with hedgehogs sliding through/into think gaps; fixes issue 542; could and should be optimized (also to make sure that hogs can't slide through little pixel turds) - feel free to do so =P
sheepluva
parents:
8744
diff
changeset
|
905 |
if not (TestCollisionXwithXYShift(Gear, int2hwFloat(hwSign(Gear^.dX)) - Gear^.dX, -2, hwSign(Gear^.dX)) or |
1dfc456b7d50
fix ancient issue with hedgehogs sliding through/into think gaps; fixes issue 542; could and should be optimized (also to make sure that hogs can't slide through little pixel turds) - feel free to do so =P
sheepluva
parents:
8744
diff
changeset
|
906 |
(TestCollisionYwithXYShift(Gear, hwSign(Gear^.dX) - hwRound(Gear^.dX), -1, -1))) then |
6581 | 907 |
begin |
908 |
Gear^.X:= Gear^.X + Gear^.dX; |
|
909 |
Gear^.dX:= Gear^.dX * _0_93; |
|
910 |
Gear^.Y:= Gear^.Y - _2 |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
911 |
end |
6581 | 912 |
else |
8753
1dfc456b7d50
fix ancient issue with hedgehogs sliding through/into think gaps; fixes issue 542; could and should be optimized (also to make sure that hogs can't slide through little pixel turds) - feel free to do so =P
sheepluva
parents:
8744
diff
changeset
|
913 |
if not (TestCollisionXwithXYShift(Gear, int2hwFloat(hwSign(Gear^.dX)) - Gear^.dX, -3, hwSign(Gear^.dX)) or |
1dfc456b7d50
fix ancient issue with hedgehogs sliding through/into think gaps; fixes issue 542; could and should be optimized (also to make sure that hogs can't slide through little pixel turds) - feel free to do so =P
sheepluva
parents:
8744
diff
changeset
|
914 |
(TestCollisionYwithXYShift(Gear, hwSign(Gear^.dX) - hwRound(Gear^.dX), -1, -1))) then |
6581 | 915 |
begin |
916 |
Gear^.X:= Gear^.X + Gear^.dX; |
|
917 |
Gear^.dX:= Gear^.dX * _0_9 ; |
|
918 |
Gear^.Y:= Gear^.Y - _3 |
|
919 |
end |
|
920 |
else |
|
8753
1dfc456b7d50
fix ancient issue with hedgehogs sliding through/into think gaps; fixes issue 542; could and should be optimized (also to make sure that hogs can't slide through little pixel turds) - feel free to do so =P
sheepluva
parents:
8744
diff
changeset
|
921 |
if not (TestCollisionXwithXYShift(Gear, int2hwFloat(hwSign(Gear^.dX)) - Gear^.dX, -4, hwSign(Gear^.dX)) or |
1dfc456b7d50
fix ancient issue with hedgehogs sliding through/into think gaps; fixes issue 542; could and should be optimized (also to make sure that hogs can't slide through little pixel turds) - feel free to do so =P
sheepluva
parents:
8744
diff
changeset
|
922 |
(TestCollisionYwithXYShift(Gear, hwSign(Gear^.dX) - hwRound(Gear^.dX), -1, -1))) then |
6581 | 923 |
begin |
924 |
Gear^.X:= Gear^.X + Gear^.dX; |
|
925 |
Gear^.dX:= Gear^.dX * _0_87; |
|
926 |
Gear^.Y:= Gear^.Y - _4 |
|
927 |
end |
|
928 |
else |
|
8753
1dfc456b7d50
fix ancient issue with hedgehogs sliding through/into think gaps; fixes issue 542; could and should be optimized (also to make sure that hogs can't slide through little pixel turds) - feel free to do so =P
sheepluva
parents:
8744
diff
changeset
|
929 |
if not (TestCollisionXwithXYShift(Gear, int2hwFloat(hwSign(Gear^.dX)) - Gear^.dX, -5, hwSign(Gear^.dX)) or |
1dfc456b7d50
fix ancient issue with hedgehogs sliding through/into think gaps; fixes issue 542; could and should be optimized (also to make sure that hogs can't slide through little pixel turds) - feel free to do so =P
sheepluva
parents:
8744
diff
changeset
|
930 |
(TestCollisionYwithXYShift(Gear, hwSign(Gear^.dX) - hwRound(Gear^.dX), -1, -1))) then |
6581 | 931 |
begin |
932 |
Gear^.X:= Gear^.X + Gear^.dX; |
|
933 |
Gear^.dX:= Gear^.dX * _0_84; |
|
934 |
Gear^.Y:= Gear^.Y - _5 |
|
935 |
end |
|
936 |
else |
|
937 |
if hwAbs(Gear^.dX) > _0_02 then |
|
938 |
Gear^.dX:= -Gear^.Elasticity * Gear^.dX |
|
939 |
else |
|
940 |
begin |
|
941 |
Gear^.State:= Gear^.State and (not gstMoving); |
|
942 |
while TestCollisionYWithGear(Gear,1) = 0 do |
|
943 |
Gear^.Y:= Gear^.Y+_1; |
|
944 |
SetLittle(Gear^.dX) |
|
945 |
end |
|
946 |
else |
|
947 |
begin |
|
948 |
Gear^.State:= Gear^.State and (not gstMoving); |
|
949 |
while TestCollisionYWithGear(Gear,1) = 0 do |
|
950 |
Gear^.Y:= Gear^.Y+_1; |
|
951 |
SetLittle(Gear^.dX) |
|
952 |
end |
|
953 |
else if (hwAbs(Gear^.dX) > cLittle) |
|
954 |
and ((Gear^.State and gstHHJumping) = 0) then |
|
955 |
Gear^.dX:= -Gear^.Elasticity * Gear^.dX |
|
956 |
else |
|
957 |
SetLittle(Gear^.dX); |
|
958 |
||
959 |
if (not isFalling) |
|
7362
53bcfc714cb3
Fix rare condition when hog's gear stucks in an infinite loop which adds 1 to its Y coordinate not checking for drowning
unc0rr
parents:
7339
diff
changeset
|
960 |
and (hwAbs(Gear^.dX) + hwAbs(Gear^.dY) < _0_03) then |
6581 | 961 |
begin |
962 |
Gear^.State:= Gear^.State and (not gstWinner); |
|
963 |
Gear^.State:= Gear^.State and (not gstMoving); |
|
7426
55b49cc1f33a
Changes for the benefit of pas2c. Use downto in for loops to avoid repeated calls of Random/GetRandom. Wrap nots.
nemo
parents:
7409
diff
changeset
|
964 |
while (TestCollisionYWithGear(Gear,1) = 0) and (not CheckGearDrowning(Gear)) do |
6581 | 965 |
Gear^.Y:= Gear^.Y+_1; |
966 |
SetLittle(Gear^.dX); |
|
967 |
Gear^.dY:= _0 |
|
968 |
end |
|
969 |
else |
|
970 |
Gear^.State:= Gear^.State or gstMoving; |
|
971 |
||
972 |
if (Gear^.State and gstMoving) <> 0 then |
|
973 |
begin |
|
974 |
Gear^.State:= Gear^.State and (not gstAnimation); |
|
975 |
// ARTILLERY but not being moved by explosions |
|
976 |
Gear^.X:= Gear^.X + Gear^.dX; |
|
977 |
Gear^.Y:= Gear^.Y + Gear^.dY; |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
978 |
if (not Gear^.dY.isNegative) and (not TestCollisionYKick(Gear, 1)) |
6581 | 979 |
and TestCollisionYwithXYShift(Gear, 0, 1, 1) then |
980 |
begin |
|
981 |
CheckHHDamage(Gear); |
|
982 |
Gear^.dY:= _0; |
|
983 |
Gear^.Y:= Gear^.Y + _1 |
|
984 |
end; |
|
985 |
CheckGearDrowning(Gear); |
|
986 |
// hide target cursor if current hog is drowning |
|
987 |
if (Gear^.State and gstDrowning) <> 0 then |
|
988 |
if (CurrentHedgehog^.Gear = Gear) then |
|
989 |
isCursorVisible:= false |
|
990 |
end; |
|
7623
addc5b262617
isZero appears to be never used. Use it in a few obvious cases and add web variant.
nemo
parents:
7615
diff
changeset
|
991 |
if (not isZero(Gear^.dY)) and (Gear^.FlightTime > 0) and ((GameFlags and gfLowGravity) = 0) then |
6581 | 992 |
begin |
993 |
inc(Gear^.FlightTime); |
|
8003 | 994 |
if (Gear^.FlightTime > 1500) and ((hwRound(Gear^.X) < LongInt(leftX)-250) or (hwRound(Gear^.X) > LongInt(rightX)+250)) then |
6581 | 995 |
begin |
7763 | 996 |
Gear^.FlightTime:= 0; |
6581 | 997 |
AddCaption(GetEventString(eidHomerun), cWhiteColor, capgrpMessage); |
998 |
PlaySound(sndHomerun) |
|
999 |
end; |
|
1000 |
end |
|
1001 |
else |
|
1002 |
begin |
|
1003 |
uStats.hedgehogFlight(Gear, Gear^.FlightTime); |
|
1004 |
Gear^.FlightTime:= 0; |
|
1005 |
end; |
|
1006 |
||
1007 |
end; |
|
1008 |
||
1009 |
procedure doStepHedgehogDriven(HHGear: PGear); |
|
1010 |
var t: PGear; |
|
1011 |
wasJumping: boolean; |
|
1012 |
Hedgehog: PHedgehog; |
|
1013 |
begin |
|
1014 |
Hedgehog:= HHGear^.Hedgehog; |
|
8658 | 1015 |
if not isInMultiShoot then |
1016 |
AllInactive:= false |
|
1017 |
else if Hedgehog^.CurAmmoType in [amShotgun, amDEagle, amSniperRifle] then |
|
1018 |
HHGear^.Message:= 0; |
|
6581 | 1019 |
|
1020 |
if (TurnTimeLeft = 0) or (HHGear^.Damage > 0) then |
|
1021 |
begin |
|
8494
53b91a602955
Cleaver tweaks based on feedback. Nerf damage, shrink radius. This means cleaver will embed into ground quite a bit further.
nemo
parents:
8493
diff
changeset
|
1022 |
if (Hedgehog^.CurAmmoType = amKnife) then |
53b91a602955
Cleaver tweaks based on feedback. Nerf damage, shrink radius. This means cleaver will embed into ground quite a bit further.
nemo
parents:
8493
diff
changeset
|
1023 |
LoadHedgehogHat(Hedgehog^, Hedgehog^.Hat); |
6581 | 1024 |
if TagTurnTimeLeft = 0 then |
1025 |
TagTurnTimeLeft:= TurnTimeLeft; |
|
1026 |
TurnTimeLeft:= 0; |
|
1027 |
isCursorVisible:= false; |
|
1028 |
HHGear^.State:= HHGear^.State and (not (gstHHDriven or gstAnimation or gstAttacking)); |
|
1029 |
AttackBar:= 0; |
|
1030 |
if HHGear^.Damage > 0 then |
|
1031 |
HHGear^.State:= HHGear^.State and (not (gstHHJumping or gstHHHJump)); |
|
1032 |
exit |
|
1033 |
end; |
|
1034 |
||
1035 |
if (HHGear^.State and gstAnimation) <> 0 then |
|
1036 |
begin |
|
1037 |
HHGear^.Message:= 0; |
|
1038 |
if (HHGear^.Pos = Wavez[TWave(HHGear^.Tag)].VoiceDelay) and (HHGear^.Timer = 0) then |
|
7053 | 1039 |
PlaySoundV(Wavez[TWave(HHGear^.Tag)].Voice, Hedgehog^.Team^.voicepack); |
6581 | 1040 |
inc(HHGear^.Timer); |
1041 |
if HHGear^.Timer = Wavez[TWave(HHGear^.Tag)].Interval then |
|
1042 |
begin |
|
1043 |
HHGear^.Timer:= 0; |
|
1044 |
inc(HHGear^.Pos); |
|
1045 |
if HHGear^.Pos = Wavez[TWave(HHGear^.Tag)].FramesCount then |
|
1046 |
HHGear^.State:= HHGear^.State and (not gstAnimation) |
|
1047 |
end; |
|
1048 |
exit |
|
1049 |
end; |
|
1050 |
||
1051 |
if ((HHGear^.State and gstMoving) <> 0) |
|
7028 | 1052 |
or (GHStepTicks = cHHStepTicks) |
6581 | 1053 |
or (CurAmmoGear <> nil) then // we are moving |
1054 |
begin |
|
1055 |
with Hedgehog^ do |
|
1056 |
if (CurAmmoGear = nil) |
|
1057 |
and (HHGear^.dY > _0_39) |
|
1058 |
and (CurAmmoType = amParachute) then |
|
1059 |
HHGear^.Message:= HHGear^.Message or gmAttack; |
|
1060 |
// check for case with ammo |
|
1061 |
t:= CheckGearNear(HHGear, gtCase, 36, 36); |
|
1062 |
if t <> nil then |
|
1063 |
PickUp(HHGear, t) |
|
1064 |
end; |
|
1065 |
||
1066 |
if (CurAmmoGear = nil) then |
|
1067 |
if (((HHGear^.Message and gmAttack) <> 0) |
|
1068 |
or ((HHGear^.State and gstAttacking) <> 0)) then |
|
1069 |
Attack(HHGear) // should be before others to avoid desync with '/put' msg and changing weapon msgs |
|
1070 |
else |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
1071 |
else |
6581 | 1072 |
with Hedgehog^ do |
1073 |
if ((Ammoz[CurAmmoGear^.AmmoType].Ammo.Propz and ammoprop_AltAttack) <> 0) |
|
1074 |
and ((HHGear^.Message and gmLJump) <> 0) |
|
1075 |
and ((Ammoz[CurAmmoType].Ammo.Propz and ammoprop_AltUse) <> 0) then |
|
1076 |
begin |
|
1077 |
Attack(HHGear); |
|
1078 |
HHGear^.Message:= HHGear^.Message and (not gmLJump) |
|
1079 |
end; |
|
1080 |
||
1081 |
if (CurAmmoGear = nil) |
|
7956
61da79e83330
Causes AI fail. Needs testing 'cause at some point, I thought this was needed for portal, I don't remember *why*
nemo
parents:
7832
diff
changeset
|
1082 |
or ((Ammoz[CurAmmoGear^.AmmoType].Ammo.Propz and ammoprop_AltAttack) <> 0) then |
6581 | 1083 |
begin |
1084 |
if ((HHGear^.Message and gmSlot) <> 0) then |
|
1085 |
if ChangeAmmo(HHGear) then ApplyAmmoChanges(Hedgehog^); |
|
1086 |
||
1087 |
if ((HHGear^.Message and gmWeapon) <> 0) then |
|
1088 |
HHSetWeapon(HHGear); |
|
1089 |
||
1090 |
if ((HHGear^.Message and gmTimer) <> 0) then |
|
1091 |
HHSetTimer(HHGear); |
|
1092 |
end; |
|
1093 |
||
1094 |
if CurAmmoGear <> nil then |
|
1095 |
begin |
|
1096 |
CurAmmoGear^.Message:= HHGear^.Message; |
|
1097 |
exit |
|
1098 |
end; |
|
1099 |
||
1100 |
HedgehogChAngle(HHGear); |
|
1101 |
||
1102 |
if (HHGear^.State and gstMoving) <> 0 then |
|
1103 |
begin |
|
1104 |
wasJumping:= ((HHGear^.State and gstHHJumping) <> 0); |
|
1105 |
||
1106 |
if ((HHGear^.Message and gmHJump) <> 0) and wasJumping and ((HHGear^.State and gstHHHJump) = 0) then |
|
1107 |
if (not (hwAbs(HHGear^.dX) > cLittle)) and (HHGear^.dY < -_0_02) then |
|
1108 |
begin |
|
1109 |
HHGear^.State:= HHGear^.State or gstHHHJump; |
|
1110 |
HHGear^.dY:= -_0_25; |
|
1111 |
if not cArtillery then |
|
1112 |
HHGear^.dX:= -SignAs(_0_02, HHGear^.dX); |
|
7053 | 1113 |
PlaySoundV(sndJump2, Hedgehog^.Team^.voicepack) |
6581 | 1114 |
end; |
1115 |
||
1116 |
HHGear^.Message:= HHGear^.Message and (not (gmLJump or gmHJump)); |
|
1117 |
||
1118 |
if (not cArtillery) and wasJumping and TestCollisionXwithGear(HHGear, hwSign(HHGear^.dX)) then |
|
1119 |
SetLittle(HHGear^.dX); |
|
1120 |
||
1121 |
if Hedgehog^.Gear <> nil then |
|
1122 |
doStepHedgehogMoving(HHGear); |
|
1123 |
||
1124 |
if ((HHGear^.State and (gstMoving or gstDrowning)) = 0) then |
|
1125 |
begin |
|
1126 |
AddGearCI(HHGear); |
|
1127 |
if wasJumping then |
|
7028 | 1128 |
GHStepTicks:= 410 |
6581 | 1129 |
else |
7028 | 1130 |
GHStepTicks:= 95 |
6581 | 1131 |
end; |
1132 |
exit |
|
1133 |
end; |
|
1134 |
||
8562
d9d1cb650ff8
Restore freezing hedgehog for shotgun, sniper rifle and deagle to make unc0rr happy. You'll still be able to get away after throwing cleaver and sticky bomb tho.
nemo
parents:
8553
diff
changeset
|
1135 |
if not(isInMultiShoot and (Hedgehog^.CurAmmoType in [amShotgun, amDEagle, amSniperRifle])) and (Hedgehog^.Gear <> nil) then |
6581 | 1136 |
begin |
7028 | 1137 |
if GHStepTicks > 0 then |
1138 |
dec(GHStepTicks); |
|
1139 |
if (GHStepTicks = 0) then |
|
6581 | 1140 |
HedgehogStep(HHGear) |
1141 |
end |
|
1142 |
end; |
|
1143 |
||
1144 |
//////////////////////////////////////////////////////////////////////////////// |
|
1145 |
procedure doStepHedgehogFree(Gear: PGear); |
|
1146 |
var prevState: Longword; |
|
1147 |
begin |
|
1148 |
prevState:= Gear^.State; |
|
1149 |
||
1150 |
doStepHedgehogMoving(Gear); |
|
1151 |
||
1152 |
if (Gear^.State and (gstMoving or gstDrowning)) <> 0 then |
|
1153 |
begin |
|
1154 |
if Gear^.Damage > 0 then |
|
1155 |
CalcRotationDirAngle(Gear); |
|
1156 |
AllInactive:= false; |
|
1157 |
exit |
|
1158 |
end; |
|
1159 |
||
1160 |
if (Gear^.Health = 0) then |
|
1161 |
begin |
|
1162 |
if PrvInactive or ((GameFlags and gfInfAttack) <> 0) then |
|
1163 |
begin |
|
1164 |
Gear^.Timer:= 0; |
|
1165 |
FollowGear:= Gear; |
|
1166 |
PrvInactive:= false; |
|
1167 |
AllInactive:= false; |
|
1168 |
||
1169 |
if (Gear^.State and gstHHGone) = 0 then |
|
1170 |
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:
6992
diff
changeset
|
1171 |
Gear^.Hedgehog^.Effects[hePoisoned] := 0; |
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:
6992
diff
changeset
|
1172 |
if Gear^.Hedgehog^.Effects[heResurrectable] <> 0 then |
6581 | 1173 |
begin |
1174 |
ResurrectHedgehog(Gear); |
|
1175 |
end |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
1176 |
else |
6581 | 1177 |
begin |
1178 |
Gear^.State:= (Gear^.State or gstHHDeath) and (not gstAnimation); |
|
1179 |
Gear^.doStep:= @doStepHedgehogDead; |
|
1180 |
// Death message |
|
1181 |
AddCaption(Format(GetEventString(eidDied), Gear^.Hedgehog^.Name), cWhiteColor, capgrpMessage); |
|
1182 |
end; |
|
1183 |
end |
|
1184 |
else |
|
1185 |
begin |
|
1186 |
Gear^.State:= Gear^.State and (not gstAnimation); |
|
1187 |
Gear^.doStep:= @doStepHedgehogGone; |
|
1188 |
||
1189 |
// Gone message |
|
1190 |
AddCaption(Format(GetEventString(eidGone), Gear^.Hedgehog^.Name), cWhiteColor, capgrpMessage); |
|
1191 |
end |
|
1192 |
end; |
|
1193 |
exit |
|
1194 |
end; |
|
1195 |
||
1196 |
if ((Gear^.State and gstWait) = 0) and |
|
1197 |
(prevState <> Gear^.State) then |
|
1198 |
begin |
|
1199 |
Gear^.State:= Gear^.State or gstWait; |
|
1200 |
Gear^.Timer:= 150 |
|
1201 |
end |
|
1202 |
else |
|
1203 |
begin |
|
1204 |
if Gear^.Timer = 0 then |
|
1205 |
begin |
|
1206 |
Gear^.State:= Gear^.State and (not (gstWait or gstLoser or gstWinner or gstAttacked or gstNotKickable or gstHHChooseTarget)); |
|
8563
4d9d8287e601
Trying to improve rendering, sliding and thawing. Messing around w/ making fire thaw faster.
nemo
parents:
8560
diff
changeset
|
1207 |
if Gear^.Hedgehog^.Effects[heFrozen] = 0 then Gear^.Active:= false; |
6581 | 1208 |
AddGearCI(Gear); |
1209 |
exit |
|
1210 |
end |
|
1211 |
else dec(Gear^.Timer) |
|
1212 |
end; |
|
1213 |
||
1214 |
AllInactive:= false |
|
1215 |
end; |
|
1216 |
||
8574 | 1217 |
procedure CheckIce(Gear: PGear); inline; |
6581 | 1218 |
(* |
1219 |
var x,y,tx,ty: LongInt; |
|
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
1220 |
tdX, tdY, slope: hwFloat; |
6581 | 1221 |
land: Word; *) |
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
1222 |
var slope: hwFloat; |
6581 | 1223 |
begin |
8574 | 1224 |
if (Gear^.Message and (gmAllStoppable or gmLJump or gmHJump) = 0) |
1225 |
and (Gear^.State and (gstHHJumping or gstHHHJump or gstAttacking) = 0) |
|
8633 | 1226 |
and ((Gear^.Hedgehog = nil) or ((Gear^.Hedgehog^.Effects[heFrozen] = 0) or (Gear^.Hedgehog^.Effects[heFrozen] > 255))) |
8616
c4536e98c712
Safety check. The main place this can be a problem is on a mild bowl w/ multiple hogs. Could possibly add a hog collision check in here.
nemo
parents:
8589
diff
changeset
|
1227 |
and (not Gear^.dY.isNegative) and (TurnTimeLeft > 0) and (TestCollisionYwithGear(Gear, 1) and lfIce <> 0) then |
8574 | 1228 |
begin |
1229 |
slope:= CalcSlopeBelowGear(Gear); |
|
1230 |
if slope.QWordValue > 730144440 then // ignore mild slopes |
|
1231 |
begin |
|
1232 |
Gear^.dX:=Gear^.dX+slope*cGravity*_256; |
|
1233 |
Gear^.State:= Gear^.State or gstMoving |
|
1234 |
end |
|
1235 |
end; |
|
1236 |
(* |
|
1237 |
x:= hwRound(Gear^.X); |
|
1238 |
y:= hwRound(Gear^.Y); |
|
1239 |
AddVisualGear(x, y, vgtSmokeTrace); |
|
1240 |
AddVisualGear(x - hwRound(_5*slope), y + hwRound(_5*slope), vgtSmokeTrace); |
|
1241 |
AddVisualGear(x + hwRound(_5*slope), y - hwRound(_5*slope), vgtSmokeTrace); |
|
1242 |
AddVisualGear(x - hwRound(_20 * slope), y + hwRound(_20 * slope), vgtSmokeTrace); |
|
1243 |
AddVisualGear(x + hwRound(_20 * slope), y - hwRound(_20 * slope), vgtSmokeTrace); |
|
1244 |
AddVisualGear(x - hwRound(_30 * slope), y + hwRound(_30 * slope), vgtSmokeTrace); |
|
1245 |
AddVisualGear(x + hwRound(_30 * slope), y - hwRound(_30 * slope), vgtSmokeTrace); |
|
1246 |
AddVisualGear(x - hwRound(_40 * slope), y + hwRound(_40 * slope), vgtSmokeTrace); |
|
1247 |
AddVisualGear(x + hwRound(_40 * slope), y - hwRound(_40 * slope), vgtSmokeTrace); |
|
1248 |
AddVisualGear(x - hwRound(_50 * slope), y + hwRound(_50 * slope), vgtSmokeTrace); |
|
1249 |
AddVisualGear(x + hwRound(_50 * slope), y - hwRound(_50 * slope), vgtSmokeTrace); *) |
|
1250 |
end; |
|
1251 |
||
1252 |
//////////////////////////////////////////////////////////////////////////////// |
|
1253 |
procedure doStepHedgehog(Gear: PGear); |
|
1254 |
begin |
|
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:
7375
diff
changeset
|
1255 |
CheckSum:= CheckSum xor Gear^.Hedgehog^.BotLevel; |
6581 | 1256 |
if (Gear^.Message and gmDestroy) <> 0 then |
1257 |
begin |
|
1258 |
DeleteGear(Gear); |
|
1259 |
exit |
|
1260 |
end; |
|
8576
286ebfcb3d97
workaround for frequent AllHH active call in hedgehog step
nemo
parents:
8574
diff
changeset
|
1261 |
if GameTicks mod 100 = 0 then CheckIce(Gear); |
8655
9fa380a18a65
At multiple requests, change ice to be turn based. This is a more modest adjustment of existing code, that can be fairly easily flagged or reverted if desired. It also allows scripts to extend freezing, and preserves fire melting.
nemo
parents:
8633
diff
changeset
|
1262 |
(* |
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
1263 |
if Gear^.Hedgehog^.Effects[heFrozen] > 0 then |
8563
4d9d8287e601
Trying to improve rendering, sliding and thawing. Messing around w/ making fire thaw faster.
nemo
parents:
8560
diff
changeset
|
1264 |
begin |
8632
b5ed76d2a1f9
Make hogs thaw only on enemy turns, make timebox counter decrement only on your turn, adjust knock for frozen hogs, increase damage on frozen hogs, make freezer fuel only reduce when not adjusting angle.
nemo
parents:
8631
diff
changeset
|
1265 |
if (Gear^.Hedgehog^.Effects[heFrozen] > 256) and (CurrentHedgehog^.Team^.Clan <> Gear^.Hedgehog^.Team^.Clan) then |
8563
4d9d8287e601
Trying to improve rendering, sliding and thawing. Messing around w/ making fire thaw faster.
nemo
parents:
8560
diff
changeset
|
1266 |
dec(Gear^.Hedgehog^.Effects[heFrozen]) |
4d9d8287e601
Trying to improve rendering, sliding and thawing. Messing around w/ making fire thaw faster.
nemo
parents:
8560
diff
changeset
|
1267 |
else if GameTicks mod 10 = 0 then |
4d9d8287e601
Trying to improve rendering, sliding and thawing. Messing around w/ making fire thaw faster.
nemo
parents:
8560
diff
changeset
|
1268 |
dec(Gear^.Hedgehog^.Effects[heFrozen]) |
4d9d8287e601
Trying to improve rendering, sliding and thawing. Messing around w/ making fire thaw faster.
nemo
parents:
8560
diff
changeset
|
1269 |
end; |
8655
9fa380a18a65
At multiple requests, change ice to be turn based. This is a more modest adjustment of existing code, that can be fairly easily flagged or reverted if desired. It also allows scripts to extend freezing, and preserves fire melting.
nemo
parents:
8633
diff
changeset
|
1270 |
*) |
8795
b5b79a8f9354
merge correction, also what's with all those trailing whitespaces?
koda
parents:
8774
diff
changeset
|
1271 |
if (GameTicks mod 10 = 0) and (Gear^.Hedgehog^.Effects[heFrozen] > 0) and (Gear^.Hedgehog^.Effects[heFrozen] < 256) then |
8655
9fa380a18a65
At multiple requests, change ice to be turn based. This is a more modest adjustment of existing code, that can be fairly easily flagged or reverted if desired. It also allows scripts to extend freezing, and preserves fire melting.
nemo
parents:
8633
diff
changeset
|
1272 |
dec(Gear^.Hedgehog^.Effects[heFrozen]); |
6581 | 1273 |
if (Gear^.State and gstHHDriven) = 0 then |
1274 |
doStepHedgehogFree(Gear) |
|
1275 |
else |
|
1276 |
begin |
|
1277 |
with Gear^.Hedgehog^ do |
|
1278 |
if Team^.hasGone then |
|
1279 |
TeamGoneEffect(Team^) |
|
1280 |
else |
|
1281 |
doStepHedgehogDriven(Gear) |
|
1282 |
end; |
|
1283 |
end; |
|
1284 |
||
1285 |
end. |