author | unC0Rr |
Fri, 03 Feb 2023 14:44:33 +0100 | |
branch | transitional_engine |
changeset 15946 | e82de0410da5 |
parent 15930 | f39f0f614dbf |
child 16004 | 2146cb7be36f |
permissions | -rw-r--r-- |
4 | 1 |
(* |
1066 | 2 |
* Hedgewars, a free turn based strategy game |
11046 | 3 |
* Copyright (c) 2004-2015 Andrey Korotaev <unC0Rr@gmail.com> |
4 | 4 |
* |
183 | 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 |
|
4 | 8 |
* |
183 | 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. |
|
4 | 13 |
* |
183 | 14 |
* You should have received a copy of the GNU General Public License |
15 |
* along with this program; if not, write to the Free Software |
|
10108
c68cf030eded
update FSF address. note: two sdl include files (by Sam Lantinga) still have the old FSF address in their copyright - but I ain't gonna touch their copyright headers
sheepluva
parents:
10040
diff
changeset
|
16 |
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA |
4 | 17 |
*) |
18 |
||
5121
2d34ec60992c
added some comments in order to confuse the GSoC students as much as possible ;D
sheepluva
parents:
5076
diff
changeset
|
19 |
(* |
2d34ec60992c
added some comments in order to confuse the GSoC students as much as possible ;D
sheepluva
parents:
5076
diff
changeset
|
20 |
* This file contains the step handlers for gears. |
2d34ec60992c
added some comments in order to confuse the GSoC students as much as possible ;D
sheepluva
parents:
5076
diff
changeset
|
21 |
* |
2d34ec60992c
added some comments in order to confuse the GSoC students as much as possible ;D
sheepluva
parents:
5076
diff
changeset
|
22 |
* Important: Since gears change the course of the game, calculations that |
2d34ec60992c
added some comments in order to confuse the GSoC students as much as possible ;D
sheepluva
parents:
5076
diff
changeset
|
23 |
* lead to different results for different clients/players/machines |
2d34ec60992c
added some comments in order to confuse the GSoC students as much as possible ;D
sheepluva
parents:
5076
diff
changeset
|
24 |
* should NOT occur! |
2d34ec60992c
added some comments in order to confuse the GSoC students as much as possible ;D
sheepluva
parents:
5076
diff
changeset
|
25 |
* Use safe functions and data types! (e.g. GetRandom() and hwFloat) |
2d34ec60992c
added some comments in order to confuse the GSoC students as much as possible ;D
sheepluva
parents:
5076
diff
changeset
|
26 |
*) |
10015 | 27 |
|
9285 | 28 |
{$INCLUDE "options.inc"} |
29 |
||
30 |
unit uGearsHandlersMess; |
|
31 |
interface |
|
32 |
uses uTypes, uFloat; |
|
33 |
||
34 |
procedure doStepPerPixel(Gear: PGear; step: TGearStepProcedure; onlyCheckIfChanged: boolean); |
|
14032
3c40754f6cfe
Add Grenade taunt when grenade close to hog is about to blow up
Wuzzy <Wuzzy2@mail.ru>
parents:
14030
diff
changeset
|
35 |
procedure makeHogsWorry(x, y: hwFloat; r: LongInt; gearType: TGearType); |
9285 | 36 |
procedure HideHog(HH: PHedgehog); |
37 |
procedure doStepDrowningGear(Gear: PGear); |
|
38 |
procedure doStepFallingGear(Gear: PGear); |
|
39 |
procedure doStepBomb(Gear: PGear); |
|
40 |
procedure doStepMolotov(Gear: PGear); |
|
41 |
procedure doStepCluster(Gear: PGear); |
|
42 |
procedure doStepShell(Gear: PGear); |
|
43 |
procedure doStepSnowball(Gear: PGear); |
|
44 |
procedure doStepSnowflake(Gear: PGear); |
|
45 |
procedure doStepGrave(Gear: PGear); |
|
46 |
procedure doStepBeeWork(Gear: PGear); |
|
47 |
procedure doStepBee(Gear: PGear); |
|
48 |
procedure doStepShotIdle(Gear: PGear); |
|
49 |
procedure doStepShotgunShot(Gear: PGear); |
|
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
50 |
procedure spawnBulletTrail(Bullet: PGear; bulletX, bulletY: hwFloat; fadeIn: Boolean); |
9285 | 51 |
procedure doStepBulletWork(Gear: PGear); |
52 |
procedure doStepDEagleShot(Gear: PGear); |
|
53 |
procedure doStepSniperRifleShot(Gear: PGear); |
|
54 |
procedure doStepActionTimer(Gear: PGear); |
|
55 |
procedure doStepPickHammerWork(Gear: PGear); |
|
56 |
procedure doStepPickHammer(Gear: PGear); |
|
57 |
procedure doStepBlowTorchWork(Gear: PGear); |
|
58 |
procedure doStepBlowTorch(Gear: PGear); |
|
59 |
procedure doStepMine(Gear: PGear); |
|
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
60 |
procedure doStepAirMine(Gear: PGear); |
9285 | 61 |
procedure doStepSMine(Gear: PGear); |
62 |
procedure doStepDynamite(Gear: PGear); |
|
63 |
procedure doStepRollingBarrel(Gear: PGear); |
|
64 |
procedure doStepCase(Gear: PGear); |
|
65 |
procedure doStepTarget(Gear: PGear); |
|
66 |
procedure doStepIdle(Gear: PGear); |
|
67 |
procedure doStepShover(Gear: PGear); |
|
68 |
procedure doStepWhip(Gear: PGear); |
|
69 |
procedure doStepFlame(Gear: PGear); |
|
70 |
procedure doStepFirePunchWork(Gear: PGear); |
|
71 |
procedure doStepFirePunch(Gear: PGear); |
|
72 |
procedure doStepParachuteWork(Gear: PGear); |
|
73 |
procedure doStepParachute(Gear: PGear); |
|
74 |
procedure doStepAirAttackWork(Gear: PGear); |
|
75 |
procedure doStepAirAttack(Gear: PGear); |
|
76 |
procedure doStepAirBomb(Gear: PGear); |
|
77 |
procedure doStepGirder(Gear: PGear); |
|
78 |
procedure doStepTeleportAfter(Gear: PGear); |
|
79 |
procedure doStepTeleportAnim(Gear: PGear); |
|
80 |
procedure doStepTeleport(Gear: PGear); |
|
81 |
procedure doStepSwitcherWork(Gear: PGear); |
|
82 |
procedure doStepSwitcher(Gear: PGear); |
|
83 |
procedure doStepMortar(Gear: PGear); |
|
84 |
procedure doStepKamikazeWork(Gear: PGear); |
|
85 |
procedure doStepKamikazeIdle(Gear: PGear); |
|
86 |
procedure doStepKamikaze(Gear: PGear); |
|
87 |
procedure doStepCakeExpl(Gear: PGear); |
|
88 |
procedure doStepCakeDown(Gear: PGear); |
|
11531 | 89 |
procedure doStepCakeWalk(Gear: PGear); |
9285 | 90 |
procedure doStepCakeUp(Gear: PGear); |
91 |
procedure doStepCakeFall(Gear: PGear); |
|
92 |
procedure doStepCake(Gear: PGear); |
|
93 |
procedure doStepSeductionWork(Gear: PGear); |
|
94 |
procedure doStepSeductionWear(Gear: PGear); |
|
95 |
procedure doStepSeduction(Gear: PGear); |
|
96 |
procedure doStepWaterUp(Gear: PGear); |
|
97 |
procedure doStepDrillDrilling(Gear: PGear); |
|
98 |
procedure doStepDrill(Gear: PGear); |
|
99 |
procedure doStepBallgunWork(Gear: PGear); |
|
100 |
procedure doStepBallgun(Gear: PGear); |
|
101 |
procedure doStepRCPlaneWork(Gear: PGear); |
|
102 |
procedure doStepRCPlane(Gear: PGear); |
|
103 |
procedure doStepJetpackWork(Gear: PGear); |
|
104 |
procedure doStepJetpack(Gear: PGear); |
|
105 |
procedure doStepBirdyDisappear(Gear: PGear); |
|
106 |
procedure doStepBirdyFly(Gear: PGear); |
|
107 |
procedure doStepBirdyDescend(Gear: PGear); |
|
108 |
procedure doStepBirdyAppear(Gear: PGear); |
|
109 |
procedure doStepBirdy(Gear: PGear); |
|
110 |
procedure doStepEggWork(Gear: PGear); |
|
111 |
procedure doPortalColorSwitch(); |
|
112 |
procedure doStepPortal(Gear: PGear); |
|
113 |
procedure loadNewPortalBall(oldPortal: PGear; destroyGear: Boolean); |
|
114 |
procedure doStepMovingPortal_real(Gear: PGear); |
|
115 |
procedure doStepMovingPortal(Gear: PGear); |
|
116 |
procedure doStepPortalShot(newPortal: PGear); |
|
117 |
procedure doStepPiano(Gear: PGear); |
|
14587
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
118 |
procedure doStepPianoWork(Gear: PGear); |
9285 | 119 |
procedure doStepSineGunShotWork(Gear: PGear); |
120 |
procedure doStepSineGunShot(Gear: PGear); |
|
121 |
procedure doStepFlamethrowerWork(Gear: PGear); |
|
122 |
procedure doStepFlamethrower(Gear: PGear); |
|
123 |
procedure doStepLandGunWork(Gear: PGear); |
|
124 |
procedure doStepLandGun(Gear: PGear); |
|
125 |
procedure doStepPoisonCloud(Gear: PGear); |
|
126 |
procedure doStepHammer(Gear: PGear); |
|
127 |
procedure doStepHammerHitWork(Gear: PGear); |
|
128 |
procedure doStepHammerHit(Gear: PGear); |
|
129 |
procedure doStepResurrectorWork(Gear: PGear); |
|
130 |
procedure doStepResurrector(Gear: PGear); |
|
131 |
procedure doStepNapalmBomb(Gear: PGear); |
|
132 |
procedure doStepTardisWarp(Gear: PGear); |
|
133 |
procedure doStepTardis(Gear: PGear); |
|
134 |
procedure updateFuel(Gear: PGear); |
|
135 |
procedure updateTarget(Gear:PGear; newX, newY:HWFloat); |
|
136 |
procedure doStepIceGun(Gear: PGear); |
|
137 |
procedure doStepAddAmmo(Gear: PGear); |
|
138 |
procedure doStepGenericFaller(Gear: PGear); |
|
13605
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
139 |
procedure doStepCreeper(Gear: PGear); |
9285 | 140 |
procedure doStepKnife(Gear: PGear); |
12898 | 141 |
procedure doStepMinigunWork(Gear: PGear); |
142 |
procedure doStepMinigun(Gear: PGear); |
|
143 |
procedure doStepMinigunBullet(Gear: PGear); |
|
15847 | 144 |
procedure ResetSentryState(Gear: PGear; state, timer: LongInt); |
15737 | 145 |
procedure doStepSentryDeploy(Gear: PGear); |
9285 | 146 |
|
147 |
var |
|
148 |
upd: Longword; |
|
149 |
snowLeft,snowRight: LongInt; |
|
150 |
||
151 |
implementation |
|
152 |
uses uConsts, uVariables, uVisualGearsList, uRandom, uCollisions, uGearsList, uUtils, uSound |
|
153 |
, SDLh, uScript, uGearsHedgehog, uGearsUtils, uIO, uCaptions, uLandGraphics |
|
15242
bf11546c1920
Remove excessive console output of gtAirAttack
Wuzzy <Wuzzy2@mail.ru>
parents:
15225
diff
changeset
|
154 |
, uGearsHandlers, uTextures, uRenderUtils, uAmmos, uTeams, uLandTexture |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
155 |
, uStore, uAI, uStats, uLocale, uLandUtils; |
5121
2d34ec60992c
added some comments in order to confuse the GSoC students as much as possible ;D
sheepluva
parents:
5076
diff
changeset
|
156 |
|
3569 | 157 |
procedure doStepPerPixel(Gear: PGear; step: TGearStepProcedure; onlyCheckIfChanged: boolean); |
158 |
var |
|
159 |
dX, dY, sX, sY: hwFloat; |
|
160 |
i, steps: LongWord; |
|
161 |
caller: TGearStepProcedure; |
|
162 |
begin |
|
163 |
dX:= Gear^.dX; |
|
164 |
dY:= Gear^.dY; |
|
165 |
steps:= max(abs(hwRound(Gear^.X+dX)-hwRound(Gear^.X)), abs(hwRound(Gear^.Y+dY)-hwRound(Gear^.Y))); |
|
166 |
||
167 |
// Gear is still on the same Pixel it was before |
|
168 |
if steps < 1 then |
|
4578 | 169 |
begin |
3569 | 170 |
if onlyCheckIfChanged then |
4578 | 171 |
begin |
3569 | 172 |
Gear^.X := Gear^.X + dX; |
173 |
Gear^.Y := Gear^.Y + dY; |
|
174 |
EXIT; |
|
4578 | 175 |
end |
3569 | 176 |
else |
177 |
steps := 1; |
|
4578 | 178 |
end; |
3569 | 179 |
|
180 |
if steps > 1 then |
|
4578 | 181 |
begin |
3569 | 182 |
sX:= dX / steps; |
183 |
sY:= dY / steps; |
|
4578 | 184 |
end |
8795 | 185 |
|
3569 | 186 |
else |
4578 | 187 |
begin |
3569 | 188 |
sX:= dX; |
189 |
sY:= dY; |
|
4578 | 190 |
end; |
3569 | 191 |
|
192 |
caller:= Gear^.doStep; |
|
193 |
||
194 |
for i:= 1 to steps do |
|
4578 | 195 |
begin |
3569 | 196 |
Gear^.X := Gear^.X + sX; |
197 |
Gear^.Y := Gear^.Y + sY; |
|
198 |
step(Gear); |
|
199 |
if (Gear^.doStep <> caller) |
|
200 |
or ((Gear^.State and gstCollision) <> 0) |
|
201 |
or ((Gear^.State and gstMoving) = 0) then |
|
202 |
break; |
|
4578 | 203 |
end; |
3569 | 204 |
end; |
205 |
||
14032
3c40754f6cfe
Add Grenade taunt when grenade close to hog is about to blow up
Wuzzy <Wuzzy2@mail.ru>
parents:
14030
diff
changeset
|
206 |
procedure makeHogsWorry(x, y: hwFloat; r: LongInt; gearType: TGearType); |
8795 | 207 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
208 |
gi: PGear; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
209 |
d: LongInt; |
14032
3c40754f6cfe
Add Grenade taunt when grenade close to hog is about to blow up
Wuzzy <Wuzzy2@mail.ru>
parents:
14030
diff
changeset
|
210 |
grenadeTaunt: boolean; |
2647 | 211 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
212 |
gi := GearsList; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
213 |
while gi <> nil do |
4578 | 214 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
215 |
if (gi^.Kind = gtHedgehog) then |
4578 | 216 |
begin |
12805 | 217 |
d := r - hwRound(Distance(gi^.X - x, gi^.Y - y)); |
10011
ead5e4b21671
Add check for gear kind of hedgehog on invulnerability effect. This probably fixes bug #766, is similar to change in previous r2a1483d91977 and was introduced by r7d925e82e572
nemo
parents:
9998
diff
changeset
|
218 |
if (d > 1) and (gi^.Hedgehog^.Effects[heInvulnerable] = 0) and (GetRandom(2) = 0) then |
4578 | 219 |
begin |
3143 | 220 |
if (CurrentHedgehog^.Gear = gi) then |
14040
1effb8b72b11
New taunt: Runaway, when something is about to blow up near current hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14035
diff
changeset
|
221 |
if (CurrentHedgehog^.Gear^.FlightTime = 0) then |
1effb8b72b11
New taunt: Runaway, when something is about to blow up near current hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14035
diff
changeset
|
222 |
case random(4) of |
1effb8b72b11
New taunt: Runaway, when something is about to blow up near current hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14035
diff
changeset
|
223 |
0: PlaySoundV(sndWhatThe, gi^.Hedgehog^.Team^.voicepack); |
1effb8b72b11
New taunt: Runaway, when something is about to blow up near current hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14035
diff
changeset
|
224 |
1: PlaySoundV(sndOops, gi^.Hedgehog^.Team^.voicepack); |
1effb8b72b11
New taunt: Runaway, when something is about to blow up near current hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14035
diff
changeset
|
225 |
2: PlaySoundV(sndRunAway, gi^.Hedgehog^.Team^.voicepack); |
1effb8b72b11
New taunt: Runaway, when something is about to blow up near current hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14035
diff
changeset
|
226 |
3: PlaySoundV(sndRunAway, gi^.Hedgehog^.Team^.voicepack); |
1effb8b72b11
New taunt: Runaway, when something is about to blow up near current hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14035
diff
changeset
|
227 |
end |
14035 | 228 |
else |
14040
1effb8b72b11
New taunt: Runaway, when something is about to blow up near current hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14035
diff
changeset
|
229 |
if random(4) = 0 then |
1effb8b72b11
New taunt: Runaway, when something is about to blow up near current hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14035
diff
changeset
|
230 |
PlaySoundV(sndWhatThe, gi^.Hedgehog^.Team^.voicepack) |
1effb8b72b11
New taunt: Runaway, when something is about to blow up near current hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14035
diff
changeset
|
231 |
else |
1effb8b72b11
New taunt: Runaway, when something is about to blow up near current hog
Wuzzy <Wuzzy2@mail.ru>
parents:
14035
diff
changeset
|
232 |
PlaySoundV(sndOops, gi^.Hedgehog^.Team^.voicepack) |
8795 | 233 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
234 |
else |
4578 | 235 |
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:
8628
diff
changeset
|
236 |
if ((gi^.State and gstMoving) = 0) and (gi^.Hedgehog^.Effects[heFrozen] = 0) then |
7829
c1dc7839d7b9
Set minimums on a few values to avoid camera zooming out past them. partly Issue #430. Might be worth defining a new constant for this.
nemo
parents:
7784
diff
changeset
|
237 |
begin |
c1dc7839d7b9
Set minimums on a few values to avoid camera zooming out past them. partly Issue #430. Might be worth defining a new constant for this.
nemo
parents:
7784
diff
changeset
|
238 |
gi^.dX.isNegative:= X<gi^.X; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
239 |
gi^.State := gi^.State or gstLoser; |
7829
c1dc7839d7b9
Set minimums on a few values to avoid camera zooming out past them. partly Issue #430. Might be worth defining a new constant for this.
nemo
parents:
7784
diff
changeset
|
240 |
end; |
8795 | 241 |
|
14032
3c40754f6cfe
Add Grenade taunt when grenade close to hog is about to blow up
Wuzzy <Wuzzy2@mail.ru>
parents:
14030
diff
changeset
|
242 |
grenadeTaunt:= false; |
3c40754f6cfe
Add Grenade taunt when grenade close to hog is about to blow up
Wuzzy <Wuzzy2@mail.ru>
parents:
14030
diff
changeset
|
243 |
if (gearType = gtGrenade) then |
3c40754f6cfe
Add Grenade taunt when grenade close to hog is about to blow up
Wuzzy <Wuzzy2@mail.ru>
parents:
14030
diff
changeset
|
244 |
grenadeTaunt:= random(2) = 0; |
3c40754f6cfe
Add Grenade taunt when grenade close to hog is about to blow up
Wuzzy <Wuzzy2@mail.ru>
parents:
14030
diff
changeset
|
245 |
|
3c40754f6cfe
Add Grenade taunt when grenade close to hog is about to blow up
Wuzzy <Wuzzy2@mail.ru>
parents:
14030
diff
changeset
|
246 |
if grenadeTaunt then |
3c40754f6cfe
Add Grenade taunt when grenade close to hog is about to blow up
Wuzzy <Wuzzy2@mail.ru>
parents:
14030
diff
changeset
|
247 |
PlaySoundV(sndGrenade, gi^.Hedgehog^.Team^.voicepack) |
3143 | 248 |
else |
14032
3c40754f6cfe
Add Grenade taunt when grenade close to hog is about to blow up
Wuzzy <Wuzzy2@mail.ru>
parents:
14030
diff
changeset
|
249 |
if d > r div 2 then |
14035 | 250 |
if random(3) = 0 then |
251 |
PlaySoundV(sndWhatThe, gi^.Hedgehog^.Team^.voicepack) |
|
252 |
else |
|
253 |
PlaySoundV(sndNooo, gi^.Hedgehog^.Team^.voicepack) |
|
14032
3c40754f6cfe
Add Grenade taunt when grenade close to hog is about to blow up
Wuzzy <Wuzzy2@mail.ru>
parents:
14030
diff
changeset
|
254 |
else |
3c40754f6cfe
Add Grenade taunt when grenade close to hog is about to blow up
Wuzzy <Wuzzy2@mail.ru>
parents:
14030
diff
changeset
|
255 |
PlaySoundV(sndUhOh, gi^.Hedgehog^.Team^.voicepack); |
3c40754f6cfe
Add Grenade taunt when grenade close to hog is about to blow up
Wuzzy <Wuzzy2@mail.ru>
parents:
14030
diff
changeset
|
256 |
|
4578 | 257 |
end; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
258 |
end; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
259 |
end; |
8795 | 260 |
|
4578 | 261 |
gi := gi^.NextGear |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
262 |
end; |
2647 | 263 |
end; |
5313
5e18eaef65d0
now scripts can create unique crates: dummy (empty) crates and booby traps. scripts can also set health crate values
Henek
parents:
5298
diff
changeset
|
264 |
|
5807
5c8fe58dead5
Define 2 script callbacks to notify of hog vanishment
nemo
parents:
5806
diff
changeset
|
265 |
procedure HideHog(HH: PHedgehog); |
5c8fe58dead5
Define 2 script callbacks to notify of hog vanishment
nemo
parents:
5806
diff
changeset
|
266 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
267 |
ScriptCall('onHogHide', HH^.Gear^.Uid); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
268 |
DeleteCI(HH^.Gear); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
269 |
if FollowGear = HH^.Gear then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
270 |
FollowGear:= nil; |
8795 | 271 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
272 |
if lastGearByUID = HH^.Gear then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
273 |
lastGearByUID := nil; |
8795 | 274 |
|
7400
09427dbec1d8
Fix TARDIS, make switcher work w/ the new more stringent check.
nemo
parents:
7399
diff
changeset
|
275 |
HH^.Gear^.Message:= HH^.Gear^.Message or gmRemoveFromList; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
276 |
with HH^.Gear^ do |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
277 |
begin |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
278 |
Z := cHHZ; |
7400
09427dbec1d8
Fix TARDIS, make switcher work w/ the new more stringent check.
nemo
parents:
7399
diff
changeset
|
279 |
HH^.Gear^.Active:= false; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
280 |
State:= State and (not (gstHHDriven or gstAttacking or gstAttacked)); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
281 |
Message := Message and (not gmAttack); |
5807
5c8fe58dead5
Define 2 script callbacks to notify of hog vanishment
nemo
parents:
5806
diff
changeset
|
282 |
end; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
283 |
HH^.GearHidden:= HH^.Gear; |
13140
e330feceb662
Hide team bar if all hedgehogs in it are hidden or dead
Wuzzy <Wuzzy2@mail.ru>
parents:
13096
diff
changeset
|
284 |
HH^.Gear:= nil; |
e330feceb662
Hide team bar if all hedgehogs in it are hidden or dead
Wuzzy <Wuzzy2@mail.ru>
parents:
13096
diff
changeset
|
285 |
AddVisualGear(0, 0, vgtTeamHealthSorter); |
5807
5c8fe58dead5
Define 2 script callbacks to notify of hog vanishment
nemo
parents:
5806
diff
changeset
|
286 |
end; |
5c8fe58dead5
Define 2 script callbacks to notify of hog vanishment
nemo
parents:
5806
diff
changeset
|
287 |
|
4 | 288 |
|
289 |
//////////////////////////////////////////////////////////////////////////////// |
|
290 |
procedure doStepDrowningGear(Gear: PGear); |
|
12714
5a57acce9cae
Fix bubbles drawn on the wrong side when hog drowns and faces right
Wuzzy <almikes@aol.com>
parents:
12712
diff
changeset
|
291 |
var i, d, bubbleX, bubbleY: LongInt; |
10364
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
292 |
bubble: PVisualGear; |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
293 |
begin |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
294 |
if Gear^.Timer = 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
295 |
begin |
10364
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
296 |
d:= 2 * Gear^.Radius; |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
297 |
for i:= (Gear^.Radius * Gear^.Radius) div 4 downto 0 do |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
298 |
begin |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
299 |
bubble := AddVisualGear(hwRound(Gear^.X) - Gear^.Radius + random(d), hwRound(Gear^.Y) - Gear^.Radius + random(d), vgtBubble); |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
300 |
if bubble <> nil then |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
301 |
bubble^.dY:= 0.1 + random(20)/10; |
10354 | 302 |
end; |
10364
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
303 |
DeleteGear(Gear); |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
304 |
exit; |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
305 |
end; |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
306 |
|
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
307 |
AllInactive := false; |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
308 |
dec(Gear^.Timer); |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
309 |
|
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
310 |
Gear^.Y := Gear^.Y + cDrownSpeed; |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
311 |
|
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
312 |
if cWaterLine > hwRound(Gear^.Y) + Gear^.Radius then |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
313 |
begin |
14303
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14225
diff
changeset
|
314 |
if leftX + Gear^.Radius > hwRound(Gear^.X) then |
10364
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
315 |
Gear^.X := Gear^.X - cDrownSpeed |
10354 | 316 |
else |
10364
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
317 |
Gear^.X := Gear^.X + cDrownSpeed; |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
318 |
end |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
319 |
else |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
320 |
Gear^.X := Gear^.X + Gear^.dX * cDrownSpeed; |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
321 |
|
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
322 |
// Create some bubbles (0.5% might be better but causes too few bubbles sometimes) |
12714
5a57acce9cae
Fix bubbles drawn on the wrong side when hog drowns and faces right
Wuzzy <almikes@aol.com>
parents:
12712
diff
changeset
|
323 |
if (Gear^.Kind = gtHedgehog) and (Gear^.dX.isNegative) then |
5a57acce9cae
Fix bubbles drawn on the wrong side when hog drowns and faces right
Wuzzy <almikes@aol.com>
parents:
12712
diff
changeset
|
324 |
bubbleX:= hwRound(Gear^.X) - Gear^.Radius |
5a57acce9cae
Fix bubbles drawn on the wrong side when hog drowns and faces right
Wuzzy <almikes@aol.com>
parents:
12712
diff
changeset
|
325 |
else |
5a57acce9cae
Fix bubbles drawn on the wrong side when hog drowns and faces right
Wuzzy <almikes@aol.com>
parents:
12712
diff
changeset
|
326 |
bubbleX:= hwRound(Gear^.X) + Gear^.Radius; |
5a57acce9cae
Fix bubbles drawn on the wrong side when hog drowns and faces right
Wuzzy <almikes@aol.com>
parents:
12712
diff
changeset
|
327 |
bubbleY:= hwRound(Gear^.Y) - Gear^.Radius; |
10364
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
328 |
if ((not SuddenDeathDmg and (WaterOpacity < $FF)) |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
329 |
or (SuddenDeathDmg and (SDWaterOpacity < $FF))) and ((GameTicks and $1F) = 0) then |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
330 |
if (Gear^.Kind = gtHedgehog) and (Random(4) = 0) then |
12714
5a57acce9cae
Fix bubbles drawn on the wrong side when hog drowns and faces right
Wuzzy <almikes@aol.com>
parents:
12712
diff
changeset
|
331 |
AddVisualGear(bubbleX, bubbleY, vgtBubble) |
10364
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
332 |
else if Random(12) = 0 then |
12714
5a57acce9cae
Fix bubbles drawn on the wrong side when hog drowns and faces right
Wuzzy <almikes@aol.com>
parents:
12712
diff
changeset
|
333 |
AddVisualGear(bubbleX, bubbleY, vgtBubble); |
13739
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
334 |
// Insta-delete gear and skip drowning animation if water is 100% opaque |
10364
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
335 |
if (not SuddenDeathDmg and (WaterOpacity > $FE)) |
13739
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
336 |
or (SuddenDeathDmg and (SDWaterOpacity > $FE)) then |
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
337 |
begin |
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
338 |
// Teleport gear to a suitable position for the damage tag in the water |
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
339 |
if (WorldEdge = weSea) and (hwRound(Gear^.X) - Gear^.Radius < leftX) then |
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
340 |
begin |
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
341 |
if (hwRound(Gear^.X) - Gear^.Radius > leftX - 90) then |
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
342 |
Gear^.X := Gear^.X - _90 |
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
343 |
end |
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
344 |
else if (WorldEdge = weSea) and (hwRound(Gear^.X) + Gear^.Radius > rightX) then |
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
345 |
begin |
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
346 |
if (hwRound(Gear^.X) - Gear^.Radius < rightX + 90) then |
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
347 |
Gear^.X := Gear^.X + _90 |
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
348 |
end |
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
349 |
else |
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
350 |
Gear^.Y := int2hwFloat(Gear^.Radius + cWaterLine + cVisibleWater); |
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
351 |
DeleteGear(Gear); |
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
352 |
exit; |
bbea77a8dff9
Fix damage not being displayed if hog drowns in water with 100% opacity (like in Compost theme)
Wuzzy <Wuzzy2@mail.ru>
parents:
13651
diff
changeset
|
353 |
end; |
15265
44533b2e4fb1
Drowning gears: Delete big gears when they're *completely* out of visible area
Wuzzy <Wuzzy2@mail.ru>
parents:
15264
diff
changeset
|
354 |
// Delete gear normally if it is outside of visible range. |
44533b2e4fb1
Drowning gears: Delete big gears when they're *completely* out of visible area
Wuzzy <Wuzzy2@mail.ru>
parents:
15264
diff
changeset
|
355 |
// But first determine size tolerance for big gears to make sure the gear is REALLY out of range. |
44533b2e4fb1
Drowning gears: Delete big gears when they're *completely* out of visible area
Wuzzy <Wuzzy2@mail.ru>
parents:
15264
diff
changeset
|
356 |
if Gear^.Kind = gtPiano then |
44533b2e4fb1
Drowning gears: Delete big gears when they're *completely* out of visible area
Wuzzy <Wuzzy2@mail.ru>
parents:
15264
diff
changeset
|
357 |
d:= SpritesData[sprPiano].height |
44533b2e4fb1
Drowning gears: Delete big gears when they're *completely* out of visible area
Wuzzy <Wuzzy2@mail.ru>
parents:
15264
diff
changeset
|
358 |
else if Gear^.Kind = gtRCPlane then |
44533b2e4fb1
Drowning gears: Delete big gears when they're *completely* out of visible area
Wuzzy <Wuzzy2@mail.ru>
parents:
15264
diff
changeset
|
359 |
d:= SpritesData[sprPlane].width |
44533b2e4fb1
Drowning gears: Delete big gears when they're *completely* out of visible area
Wuzzy <Wuzzy2@mail.ru>
parents:
15264
diff
changeset
|
360 |
else if Gear^.Kind = gtKnife then |
44533b2e4fb1
Drowning gears: Delete big gears when they're *completely* out of visible area
Wuzzy <Wuzzy2@mail.ru>
parents:
15264
diff
changeset
|
361 |
d:= SpritesData[sprKnife].height |
44533b2e4fb1
Drowning gears: Delete big gears when they're *completely* out of visible area
Wuzzy <Wuzzy2@mail.ru>
parents:
15264
diff
changeset
|
362 |
else if Gear^.Kind = gtDynamite then |
44533b2e4fb1
Drowning gears: Delete big gears when they're *completely* out of visible area
Wuzzy <Wuzzy2@mail.ru>
parents:
15264
diff
changeset
|
363 |
d:= SpritesData[sprDynamite].height |
44533b2e4fb1
Drowning gears: Delete big gears when they're *completely* out of visible area
Wuzzy <Wuzzy2@mail.ru>
parents:
15264
diff
changeset
|
364 |
else if Gear^.Kind = gtSnowball then |
44533b2e4fb1
Drowning gears: Delete big gears when they're *completely* out of visible area
Wuzzy <Wuzzy2@mail.ru>
parents:
15264
diff
changeset
|
365 |
d:= SpritesData[sprSnowball].height |
44533b2e4fb1
Drowning gears: Delete big gears when they're *completely* out of visible area
Wuzzy <Wuzzy2@mail.ru>
parents:
15264
diff
changeset
|
366 |
else |
44533b2e4fb1
Drowning gears: Delete big gears when they're *completely* out of visible area
Wuzzy <Wuzzy2@mail.ru>
parents:
15264
diff
changeset
|
367 |
d:= Gear^.Radius * 2; |
44533b2e4fb1
Drowning gears: Delete big gears when they're *completely* out of visible area
Wuzzy <Wuzzy2@mail.ru>
parents:
15264
diff
changeset
|
368 |
if (hwRound(Gear^.Y) > d + cWaterLine + cVisibleWater) then |
10364
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
369 |
DeleteGear(Gear); |
9f7be3da1245
burst drowning gears into bubbles after timeout
sheepluva
parents:
10363
diff
changeset
|
370 |
end; |
4 | 371 |
|
372 |
//////////////////////////////////////////////////////////////////////////////// |
|
373 |
procedure doStepFallingGear(Gear: PGear); |
|
8795 | 374 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
375 |
isFalling: boolean; |
9526 | 376 |
tX, tdX, tdY: hwFloat; |
9769
5814e0c47c99
Experiment in adding a "boing" graphic for bouncing. It has no text right now (was thinking l10n) and colour is fixed.
nemo
parents:
9768
diff
changeset
|
377 |
collV, collH, gX, gY: LongInt; |
9721
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
378 |
land, xland: word; |
4 | 379 |
begin |
9526 | 380 |
tX:= Gear^.X; |
9769
5814e0c47c99
Experiment in adding a "boing" graphic for bouncing. It has no text right now (was thinking l10n) and colour is fixed.
nemo
parents:
9768
diff
changeset
|
381 |
gX:= hwRound(Gear^.X); |
5814e0c47c99
Experiment in adding a "boing" graphic for bouncing. It has no text right now (was thinking l10n) and colour is fixed.
nemo
parents:
9768
diff
changeset
|
382 |
gY:= hwRound(Gear^.Y); |
13610
f1b6070a6e14
Fix projectiles reacing incorrectly with land just behind the wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
383 |
Gear^.State := Gear^.State and (not gstCollision); |
f1b6070a6e14
Fix projectiles reacing incorrectly with land just behind the wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
384 |
|
f1b6070a6e14
Fix projectiles reacing incorrectly with land just behind the wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
385 |
// World wrap |
f1b6070a6e14
Fix projectiles reacing incorrectly with land just behind the wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
386 |
if (Gear^.Kind <> gtGenericFaller) and WorldWrap(Gear) and (WorldEdge = weWrap) and |
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9698
diff
changeset
|
387 |
((TestCollisionXwithGear(Gear, 1) <> 0) or (TestCollisionXwithGear(Gear, -1) <> 0)) then |
9526 | 388 |
begin |
13610
f1b6070a6e14
Fix projectiles reacing incorrectly with land just behind the wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
389 |
// Collision with land that *just* behind the other side of the world wrap edge |
f1b6070a6e14
Fix projectiles reacing incorrectly with land just behind the wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
390 |
if (not Gear^.Sticky) then |
f1b6070a6e14
Fix projectiles reacing incorrectly with land just behind the wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
391 |
begin |
f1b6070a6e14
Fix projectiles reacing incorrectly with land just behind the wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
392 |
Gear^.X:= tX; |
14303
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14225
diff
changeset
|
393 |
Gear^.dX.isNegative:= (gX > leftX + Gear^.Radius*2); |
13610
f1b6070a6e14
Fix projectiles reacing incorrectly with land just behind the wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
394 |
Gear^.dX := Gear^.dX * Gear^.Friction; |
f1b6070a6e14
Fix projectiles reacing incorrectly with land just behind the wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
395 |
end; |
f1b6070a6e14
Fix projectiles reacing incorrectly with land just behind the wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13609
diff
changeset
|
396 |
Gear^.State := Gear^.State or gstCollision; |
9526 | 397 |
end; |
9473
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9470
diff
changeset
|
398 |
|
7627 | 399 |
// clip velocity at 2 - over 1 per pixel, but really shouldn't cause many actual problems. |
15825 | 400 |
if Gear^.dX.QWordValue > 8160437862 then |
401 |
Gear^.dX.QWordValue:= 8160437862; |
|
402 |
if Gear^.dY.QWordValue > 8160437862 then |
|
403 |
Gear^.dY.QWordValue:= 8160437862; |
|
8838
aa2ffd427f6a
strip PAS2C, old WEB symbols and outdated pas2c sources from default branch, all c-related development is done on the webgl branch
koda
parents:
8822
diff
changeset
|
404 |
|
10354 | 405 |
if (Gear^.State and gstSubmersible <> 0) and CheckCoordInWater(gX, gY) then |
8992
5b0be812dcdb
Rename submersible state, increase getaway time for attack underwater, slow down gear dx/dy underwater to simulate water resistance
nemo
parents:
8990
diff
changeset
|
406 |
begin |
5b0be812dcdb
Rename submersible state, increase getaway time for attack underwater, slow down gear dx/dy underwater to simulate water resistance
nemo
parents:
8990
diff
changeset
|
407 |
Gear^.dX:= Gear^.dX * _0_999; |
5b0be812dcdb
Rename submersible state, increase getaway time for attack underwater, slow down gear dx/dy underwater to simulate water resistance
nemo
parents:
8990
diff
changeset
|
408 |
Gear^.dY:= Gear^.dY * _0_999 |
5b0be812dcdb
Rename submersible state, increase getaway time for attack underwater, slow down gear dx/dy underwater to simulate water resistance
nemo
parents:
8990
diff
changeset
|
409 |
end; |
5b0be812dcdb
Rename submersible state, increase getaway time for attack underwater, slow down gear dx/dy underwater to simulate water resistance
nemo
parents:
8990
diff
changeset
|
410 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
411 |
collV := 0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
412 |
collH := 0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
413 |
tdX := Gear^.dX; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
414 |
tdY := Gear^.dY; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
415 |
|
3359 | 416 |
// might need some testing/adjustments - just to avoid projectiles to fly forever (accelerated by wind/skips) |
9769
5814e0c47c99
Experiment in adding a "boing" graphic for bouncing. It has no text right now (was thinking l10n) and colour is fixed.
nemo
parents:
9768
diff
changeset
|
417 |
if (gX < min(LAND_WIDTH div -2, -2048)) |
5814e0c47c99
Experiment in adding a "boing" graphic for bouncing. It has no text right now (was thinking l10n) and colour is fixed.
nemo
parents:
9768
diff
changeset
|
418 |
or (gX > max(LAND_WIDTH * 3 div 2, 6144)) then |
11389
c93f204a5a00
Set gears that go off map to gmDestroy instead of collision, disable morewind for no-gravity gears, restrict application of wind to gears that are already moving and not colliding.
nemo
parents:
11342
diff
changeset
|
419 |
Gear^.Message := Gear^.Message or gmDestroy; |
3359 | 420 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
421 |
if Gear^.dY.isNegative then |
4578 | 422 |
begin |
6081
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
423 |
land:= TestCollisionYwithGear(Gear, -1); |
9820 | 424 |
isFalling := land = 0; |
6081
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
425 |
if land <> 0 then |
4578 | 426 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
427 |
collV := -1; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
428 |
if land and lfIce <> 0 then |
9721
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
429 |
Gear^.dX := Gear^.dX * (_0_9 + Gear^.Friction * _0_1) |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
430 |
else Gear^.dX := Gear^.dX * Gear^.Friction; |
9731
953197ac43d8
Make sticky mine respect lfBouncy, make hogs do same, kinda... make uCollisions return land w/ mask, restrict bouncy to advbounce gears only, which means piano doesn't bounce anymore
nemo
parents:
9724
diff
changeset
|
431 |
if (Gear^.AdvBounce = 0) or (land and lfBouncy = 0) then |
9721
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
432 |
begin |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
433 |
Gear^.dY := - Gear^.dY * Gear^.Elasticity; |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
434 |
Gear^.State := Gear^.State or gstCollision |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
435 |
end |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
436 |
else Gear^.dY := - Gear^.dY * cElastic |
4578 | 437 |
end |
9721
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
438 |
else if Gear^.AdvBounce = 1 then |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
439 |
begin |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
440 |
land:= TestCollisionYwithGear(Gear, 1); |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
441 |
if land <> 0 then collV := 1 |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
442 |
end |
4578 | 443 |
end |
8795 | 444 |
else |
6498 | 445 |
begin // Gear^.dY.isNegative is false |
6081
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
446 |
land:= TestCollisionYwithGear(Gear, 1); |
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
447 |
if land <> 0 then |
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
448 |
begin |
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
449 |
collV := 1; |
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
450 |
isFalling := false; |
8795 | 451 |
if land and lfIce <> 0 then |
6498 | 452 |
Gear^.dX := Gear^.dX * (_0_9 + Gear^.Friction * _0_1) |
8795 | 453 |
else |
6498 | 454 |
Gear^.dX := Gear^.dX * Gear^.Friction; |
6081
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
455 |
|
9731
953197ac43d8
Make sticky mine respect lfBouncy, make hogs do same, kinda... make uCollisions return land w/ mask, restrict bouncy to advbounce gears only, which means piano doesn't bounce anymore
nemo
parents:
9724
diff
changeset
|
456 |
if (Gear^.AdvBounce = 0) or (land and lfBouncy = 0) then |
9721
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
457 |
begin |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
458 |
Gear^.dY := - Gear^.dY * Gear^.Elasticity; |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
459 |
Gear^.State := Gear^.State or gstCollision |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
460 |
end |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
461 |
else Gear^.dY := - Gear^.dY * cElastic |
6081
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
462 |
end |
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
463 |
else |
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
464 |
begin |
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
465 |
isFalling := true; |
9721
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
466 |
if Gear^.AdvBounce = 1 then |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
467 |
begin |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
468 |
land:= TestCollisionYwithGear(Gear, -1); |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
469 |
if land <> 0 then collV := -1 |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
470 |
end |
6081
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
471 |
end |
4578 | 472 |
end; |
503 | 473 |
|
2989
b49d87499398
Add back sheepluva's 45° patch for some weapons. Rescale Tiy's latest icons to his specifications.
nemo
parents:
2983
diff
changeset
|
474 |
|
9721
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
475 |
xland:= TestCollisionXwithGear(Gear, hwSign(Gear^.dX)); |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
476 |
if xland <> 0 then |
4578 | 477 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
478 |
collH := hwSign(Gear^.dX); |
9731
953197ac43d8
Make sticky mine respect lfBouncy, make hogs do same, kinda... make uCollisions return land w/ mask, restrict bouncy to advbounce gears only, which means piano doesn't bounce anymore
nemo
parents:
9724
diff
changeset
|
479 |
if (Gear^.AdvBounce = 0) or (xland and lfBouncy = 0) then |
9721
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
480 |
begin |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
481 |
Gear^.dX := - Gear^.dX * Gear^.Elasticity; |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
482 |
Gear^.dY := Gear^.dY * Gear^.Elasticity; |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
483 |
Gear^.State := Gear^.State or gstCollision |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
484 |
end |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
485 |
else |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
486 |
begin |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
487 |
Gear^.dX := - Gear^.dX * cElastic; |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
488 |
Gear^.dY := Gear^.dY * cElastic |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
489 |
end |
4578 | 490 |
end |
9721
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
491 |
else if Gear^.AdvBounce = 1 then |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
492 |
begin |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
493 |
xland:= TestCollisionXwithGear(Gear, -hwSign(Gear^.dX)); |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
494 |
if xland <> 0 then collH := -hwSign(Gear^.dX) |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
495 |
end; |
10015 | 496 |
if (collV <> 0) and (collH <> 0) and |
9731
953197ac43d8
Make sticky mine respect lfBouncy, make hogs do same, kinda... make uCollisions return land w/ mask, restrict bouncy to advbounce gears only, which means piano doesn't bounce anymore
nemo
parents:
9724
diff
changeset
|
497 |
(((Gear^.AdvBounce=1) and ((collV=-1) or ((tdX.QWordValue + tdY.QWordValue) > _0_2.QWordValue)))) then |
9721
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
498 |
begin |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
499 |
if (xland or land) and lfBouncy = 0 then |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
500 |
begin |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
501 |
Gear^.dX := tdY*Gear^.Elasticity*Gear^.Friction; |
9767 | 502 |
Gear^.dY := tdX*Gear^.Elasticity; |
503 |
Gear^.State := Gear^.State or gstCollision |
|
9721
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
504 |
end |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
505 |
else |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
506 |
begin |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
507 |
Gear^.dX := tdY*cElastic*Gear^.Friction; |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
508 |
Gear^.dY := tdX*cElastic |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
509 |
end; |
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
510 |
|
10895
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
511 |
Gear^.dX.isNegative:= tdX.isNegative; |
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
512 |
Gear^.dY.isNegative:= tdY.isNegative; |
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
513 |
if (collV > 0) and (collH > 0) and (not tdX.isNegative) and (not tdY.isNegative) then |
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
514 |
begin |
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
515 |
Gear^.dX.isNegative := true; |
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
516 |
Gear^.dY.isNegative := true |
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
517 |
end |
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
518 |
else if (collV > 0) and (collH < 0) and (tdX.isNegative or tdY.isNegative) then |
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
519 |
begin |
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
520 |
Gear^.dY.isNegative := not tdY.isNegative; |
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
521 |
if not tdY.isNegative then Gear^.dX.isNegative := false |
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
522 |
end |
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
523 |
else if (collV < 0) and (collH > 0) and (not tdX.isNegative) then |
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
524 |
begin |
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
525 |
Gear^.dX.isNegative := true; |
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
526 |
Gear^.dY.isNegative := false |
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
527 |
end |
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
528 |
else if (collV < 0) and (collH < 0) and tdX.isNegative and tdY.isNegative then |
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
529 |
Gear^.dX.isNegative := false; |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
530 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
531 |
isFalling := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
532 |
Gear^.AdvBounce := 10; |
4578 | 533 |
end; |
503 | 534 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
535 |
if Gear^.AdvBounce > 1 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
536 |
dec(Gear^.AdvBounce); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
537 |
|
11389
c93f204a5a00
Set gears that go off map to gmDestroy instead of collision, disable morewind for no-gravity gears, restrict application of wind to gears that are already moving and not colliding.
nemo
parents:
11342
diff
changeset
|
538 |
if isFalling and (Gear^.State and gstNoGravity = 0) then |
c93f204a5a00
Set gears that go off map to gmDestroy instead of collision, disable morewind for no-gravity gears, restrict application of wind to gears that are already moving and not colliding.
nemo
parents:
11342
diff
changeset
|
539 |
begin |
15619
3409433a236a
Fix many gears not being affected by gfMoreWind on turn end
Wuzzy <Wuzzy2@mail.ru>
parents:
15609
diff
changeset
|
540 |
// Apply gravity and wind |
11389
c93f204a5a00
Set gears that go off map to gmDestroy instead of collision, disable morewind for no-gravity gears, restrict application of wind to gears that are already moving and not colliding.
nemo
parents:
11342
diff
changeset
|
541 |
Gear^.dY := Gear^.dY + cGravity; |
15619
3409433a236a
Fix many gears not being affected by gfMoreWind on turn end
Wuzzy <Wuzzy2@mail.ru>
parents:
15609
diff
changeset
|
542 |
if ((GameFlags and gfMoreWind) <> 0) and |
3409433a236a
Fix many gears not being affected by gfMoreWind on turn end
Wuzzy <Wuzzy2@mail.ru>
parents:
15609
diff
changeset
|
543 |
// Disable gfMoreWind for land objects on turn end to prevent bouncing them forever |
15620
6e72bd61002e
Disable gfMoreWind for land objects on turn end only after a fixed-time delay
Wuzzy <Wuzzy2@mail.ru>
parents:
15619
diff
changeset
|
544 |
// This solution is rather ugly, in that it will occassionally suddenly wind physics |
6e72bd61002e
Disable gfMoreWind for land objects on turn end only after a fixed-time delay
Wuzzy <Wuzzy2@mail.ru>
parents:
15619
diff
changeset
|
545 |
// while a gear is moving, this can be rather confusing. |
6e72bd61002e
Disable gfMoreWind for land objects on turn end only after a fixed-time delay
Wuzzy <Wuzzy2@mail.ru>
parents:
15619
diff
changeset
|
546 |
// TODO: Find a way to make gfMoreWind-affected land objects settle more reliably |
6e72bd61002e
Disable gfMoreWind for land objects on turn end only after a fixed-time delay
Wuzzy <Wuzzy2@mail.ru>
parents:
15619
diff
changeset
|
547 |
// and quickler without touching wind itselvs |
15662 | 548 |
((not (Gear^.Kind in [gtMine, gtAirMine, gtSMine, gtKnife, gtExplosives, gtSentry])) or (TimeNotInTurn < MaxMoreWindTime)) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
549 |
Gear^.dX := Gear^.dX + cWindSpeed / Gear^.Density |
9820 | 550 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
551 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
552 |
Gear^.X := Gear^.X + Gear^.dX; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
553 |
Gear^.Y := Gear^.Y + Gear^.dY; |
9479
167dea42d7d7
move border back a bit from left/right bounds, bee tweak
nemo
parents:
9477
diff
changeset
|
554 |
CheckGearDrowning(Gear); |
6498 | 555 |
if (not isFalling) and ((Gear^.dX.QWordValue + Gear^.dY.QWordValue) < _0_02.QWordValue) then |
6450 | 556 |
Gear^.State := Gear^.State and (not gstMoving) |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
557 |
else |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
558 |
Gear^.State := Gear^.State or gstMoving; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
559 |
|
9731
953197ac43d8
Make sticky mine respect lfBouncy, make hogs do same, kinda... make uCollisions return land w/ mask, restrict bouncy to advbounce gears only, which means piano doesn't bounce anymore
nemo
parents:
9724
diff
changeset
|
560 |
if ((xland or land) and lfBouncy <> 0) and (Gear^.dX.QWordValue < _0_15.QWordValue) and (Gear^.dY.QWordValue < _0_15.QWordValue) then |
9721
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
561 |
Gear^.State := Gear^.State or gstCollision; |
10015 | 562 |
|
14595
6e5cda26f676
Tweak bounce effects of some gears
Wuzzy <Wuzzy2@mail.ru>
parents:
14593
diff
changeset
|
563 |
if ((xland or land) and lfBouncy <> 0) and |
9769
5814e0c47c99
Experiment in adding a "boing" graphic for bouncing. It has no text right now (was thinking l10n) and colour is fixed.
nemo
parents:
9768
diff
changeset
|
564 |
((Gear^.dX.QWordValue > _0_15.QWordValue) or (Gear^.dY.QWordValue > _0_15.QWordValue)) then |
5814e0c47c99
Experiment in adding a "boing" graphic for bouncing. It has no text right now (was thinking l10n) and colour is fixed.
nemo
parents:
9768
diff
changeset
|
565 |
begin |
10508 | 566 |
AddBounceEffectForGear(Gear); |
9769
5814e0c47c99
Experiment in adding a "boing" graphic for bouncing. It has no text right now (was thinking l10n) and colour is fixed.
nemo
parents:
9768
diff
changeset
|
567 |
end |
9721
1833dadcebf0
Initial pass at bounciness. To try it out, or lfBouncy on girder in uLandGraphics (search for the word graphically)
nemo
parents:
9706
diff
changeset
|
568 |
else if (Gear^.nImpactSounds > 0) and |
7777 | 569 |
(Gear^.State and gstCollision <> 0) and |
570 |
(((Gear^.Kind <> gtMine) and (Gear^.Damage <> 0)) or (Gear^.State and gstMoving <> 0)) and |
|
571 |
(((Gear^.Radius < 3) and (Gear^.dY < -_0_1)) or |
|
8795 | 572 |
((Gear^.Radius >= 3) and |
7777 | 573 |
((Gear^.dX.QWordValue > _0_1.QWordValue) or (Gear^.dY.QWordValue > _0_1.QWordValue)))) then |
15609 | 574 |
PlaySound(TSound(ord(Gear^.ImpactSound) + LongInt(GetRandom(Gear^.nImpactSounds))), Gear^.Kind <> gtDynamite); |
4 | 575 |
end; |
576 |
||
577 |
//////////////////////////////////////////////////////////////////////////////// |
|
578 |
procedure doStepBomb(Gear: PGear); |
|
8795 | 579 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
580 |
i, x, y: LongInt; |
8413
454191defee6
restore former cluster behaviour (makes the most diff for the bomb)
nemo
parents:
8370
diff
changeset
|
581 |
dX, dY, gdX: hwFloat; |
3475 | 582 |
vg: PVisualGear; |
4 | 583 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
584 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
585 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
586 |
doStepFallingGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
587 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
588 |
dec(Gear^.Timer); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
589 |
if Gear^.Timer = 1000 then // might need adjustments |
8795 | 590 |
case Gear^.Kind of |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
591 |
gtGrenade, |
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
592 |
gtClusterBomb, |
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
593 |
gtWatermelon, |
14032
3c40754f6cfe
Add Grenade taunt when grenade close to hog is about to blow up
Wuzzy <Wuzzy2@mail.ru>
parents:
14030
diff
changeset
|
594 |
gtHellishBomb: makeHogsWorry(Gear^.X, Gear^.Y, Gear^.Boom, Gear^.Kind); |
3c40754f6cfe
Add Grenade taunt when grenade close to hog is about to blow up
Wuzzy <Wuzzy2@mail.ru>
parents:
14030
diff
changeset
|
595 |
gtGasBomb: makeHogsWorry(Gear^.X, Gear^.Y, 50, Gear^.Kind); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
596 |
end; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
597 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
598 |
if (Gear^.Kind = gtBall) and ((Gear^.State and gstTmpFlag) <> 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
599 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
600 |
CheckCollision(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
601 |
if (Gear^.State and gstCollision) <> 0 then |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
602 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLDontDraw or EXPLNoGfx); |
7726
1137406bce12
Set default collision mask for gears at currenthedgehog X/Y to FF7F, expose mask to scripting as well. This should resolve the collision part of bug #420
nemo
parents:
7721
diff
changeset
|
603 |
end; |
3004 | 604 |
|
3475 | 605 |
if (Gear^.Kind = gtGasBomb) and ((GameTicks mod 200) = 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
606 |
begin |
3475 | 607 |
vg:= AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtSmokeWhite); |
608 |
if vg <> nil then |
|
609 |
vg^.Tint:= $FFC0C000; |
|
7726
1137406bce12
Set default collision mask for gears at currenthedgehog X/Y to FF7F, expose mask to scripting as well. This should resolve the collision part of bug #420
nemo
parents:
7721
diff
changeset
|
610 |
end; |
3475 | 611 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
612 |
if Gear^.Timer = 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
613 |
begin |
8795 | 614 |
case Gear^.Kind of |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
615 |
gtGrenade: doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
616 |
gtBall: doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
8795 | 617 |
gtClusterBomb: |
3476
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
618 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
619 |
x := hwRound(Gear^.X); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
620 |
y := hwRound(Gear^.Y); |
8413
454191defee6
restore former cluster behaviour (makes the most diff for the bomb)
nemo
parents:
8370
diff
changeset
|
621 |
gdX:= Gear^.dX; |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
622 |
doMakeExplosion(x, y, Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
623 |
for i:= 0 to 4 do |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
624 |
begin |
8413
454191defee6
restore former cluster behaviour (makes the most diff for the bomb)
nemo
parents:
8370
diff
changeset
|
625 |
dX := rndSign(GetRandomf * _0_1) + gdX / 5; |
7001 | 626 |
dY := (GetRandomf - _3) * _0_08; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
627 |
FollowGear := AddGear(x, y, gtCluster, 0, dX, dY, 25) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
628 |
end |
3476
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
629 |
end; |
8795 | 630 |
gtWatermelon: |
3476
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
631 |
begin |
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
632 |
x := hwRound(Gear^.X); |
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
633 |
y := hwRound(Gear^.Y); |
8413
454191defee6
restore former cluster behaviour (makes the most diff for the bomb)
nemo
parents:
8370
diff
changeset
|
634 |
gdX:= Gear^.dX; |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
635 |
doMakeExplosion(x, y, Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
3476
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
636 |
for i:= 0 to 5 do |
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
637 |
begin |
8413
454191defee6
restore former cluster behaviour (makes the most diff for the bomb)
nemo
parents:
8370
diff
changeset
|
638 |
dX := rndSign(GetRandomf * _0_1) + gdX / 5; |
7001 | 639 |
dY := (GetRandomf - _1_5) * _0_3; |
6120 | 640 |
FollowGear:= AddGear(x, y, gtMelonPiece, 0, dX, dY, 75); |
641 |
FollowGear^.DirAngle := i * 60 |
|
3476
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
642 |
end |
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
643 |
end; |
8795 | 644 |
gtHellishBomb: |
3476
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
645 |
begin |
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
646 |
x := hwRound(Gear^.X); |
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
647 |
y := hwRound(Gear^.Y); |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
648 |
doMakeExplosion(x, y, Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
3476
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
649 |
|
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
650 |
for i:= 0 to 127 do |
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
651 |
begin |
7001 | 652 |
dX := AngleCos(i * 16) * _0_5 * (GetRandomf + _1); |
653 |
dY := AngleSin(i * 16) * _0_5 * (GetRandomf + _1); |
|
6131 | 654 |
if i mod 2 = 0 then |
6126
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
655 |
begin |
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
656 |
AddGear(x, y, gtFlame, gstTmpFlag, dX, dY, 0); |
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
657 |
AddGear(x, y, gtFlame, 0, dX, -dY, 0) |
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
658 |
end |
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
659 |
else |
8795 | 660 |
begin |
6126
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
661 |
AddGear(x, y, gtFlame, 0, dX, dY, 0); |
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
662 |
AddGear(x, y, gtFlame, gstTmpFlag, dX, -dY, 0) |
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
663 |
end; |
3476
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
664 |
end |
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
665 |
end; |
3712 | 666 |
gtGasBomb: |
667 |
begin |
|
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
668 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
3712 | 669 |
for i:= 0 to 2 do |
4160
043c17a8b3ca
Don't call getrandom() from parameters to a function. The order of calls is undefined, so desyncs are probable.
unc0rr
parents:
4155
diff
changeset
|
670 |
begin |
043c17a8b3ca
Don't call getrandom() from parameters to a function. The order of calls is undefined, so desyncs are probable.
unc0rr
parents:
4155
diff
changeset
|
671 |
x:= GetRandom(60); |
043c17a8b3ca
Don't call getrandom() from parameters to a function. The order of calls is undefined, so desyncs are probable.
unc0rr
parents:
4155
diff
changeset
|
672 |
y:= GetRandom(40); |
6120 | 673 |
FollowGear:= AddGear(hwRound(Gear^.X) - 30 + x, hwRound(Gear^.Y) - 20 + y, gtPoisonCloud, 0, _0, _0, 0); |
4160
043c17a8b3ca
Don't call getrandom() from parameters to a function. The order of calls is undefined, so desyncs are probable.
unc0rr
parents:
4155
diff
changeset
|
674 |
end |
3712 | 675 |
end; |
7726
1137406bce12
Set default collision mask for gears at currenthedgehog X/Y to FF7F, expose mask to scripting as well. This should resolve the collision part of bug #420
nemo
parents:
7721
diff
changeset
|
676 |
end; |
1137406bce12
Set default collision mask for gears at currenthedgehog X/Y to FF7F, expose mask to scripting as well. This should resolve the collision part of bug #420
nemo
parents:
7721
diff
changeset
|
677 |
DeleteGear(Gear); |
1137406bce12
Set default collision mask for gears at currenthedgehog X/Y to FF7F, expose mask to scripting as well. This should resolve the collision part of bug #420
nemo
parents:
7721
diff
changeset
|
678 |
exit |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
679 |
end; |
6498 | 680 |
|
681 |
CalcRotationDirAngle(Gear); |
|
682 |
||
683 |
if Gear^.Kind = gtHellishBomb then |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
684 |
begin |
6498 | 685 |
|
686 |
if Gear^.Timer = 3000 then |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
687 |
begin |
6498 | 688 |
Gear^.nImpactSounds := 0; |
689 |
PlaySound(sndHellish); |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
690 |
end; |
6498 | 691 |
|
692 |
if (GameTicks and $3F) = 0 then |
|
693 |
if (Gear^.State and gstCollision) = 0 then |
|
694 |
AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtEvilTrace); |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
695 |
end; |
4 | 696 |
end; |
5313
5e18eaef65d0
now scripts can create unique crates: dummy (empty) crates and booby traps. scripts can also set health crate values
Henek
parents:
5298
diff
changeset
|
697 |
|
2457
ecf0c7e7995b
Initial molotov cocktail. Still needs graphics, tweaking of fire behaviour. Also changed probabilities for default weapon sets
nemo
parents:
2455
diff
changeset
|
698 |
//////////////////////////////////////////////////////////////////////////////// |
ecf0c7e7995b
Initial molotov cocktail. Still needs graphics, tweaking of fire behaviour. Also changed probabilities for default weapon sets
nemo
parents:
2455
diff
changeset
|
699 |
procedure doStepMolotov(Gear: PGear); |
8795 | 700 |
var |
6472 | 701 |
s: Longword; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
702 |
i, gX, gY: LongInt; |
2457
ecf0c7e7995b
Initial molotov cocktail. Still needs graphics, tweaking of fire behaviour. Also changed probabilities for default weapon sets
nemo
parents:
2455
diff
changeset
|
703 |
dX, dY: hwFloat; |
5874
5cd329cf2460
nemo's molotov burst effect; with a slight color modification added
sheepluva
parents:
5873
diff
changeset
|
704 |
smoke, glass: PVisualGear; |
2457
ecf0c7e7995b
Initial molotov cocktail. Still needs graphics, tweaking of fire behaviour. Also changed probabilities for default weapon sets
nemo
parents:
2455
diff
changeset
|
705 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
706 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
707 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
708 |
doStepFallingGear(Gear); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
709 |
CalcRotationDirAngle(Gear); |
2457
ecf0c7e7995b
Initial molotov cocktail. Still needs graphics, tweaking of fire behaviour. Also changed probabilities for default weapon sets
nemo
parents:
2455
diff
changeset
|
710 |
|
5870 | 711 |
// let's add some smoke depending on speed |
8906
82756a90a343
I see no reason why a visual effect needs Distance. IMO square should look just fine. Untested. Oh. Also reduced flake count at Randi's request.
nemo
parents:
8838
diff
changeset
|
712 |
s:= max(32,152 - round((abs(hwFloat2FLoat(Gear^.dX))+abs(hwFloat2Float(Gear^.dY)))*120))+random(10); |
6011
519f8a58c021
Fix a bunch of warnings (also improves speed a bit in 32 bit code)
unC0Rr
parents:
6002
diff
changeset
|
713 |
if (GameTicks mod s) = 0 then |
5871
09daa06191d7
Since we are tweaking molotov. make the flame flickery and add a drowning frame
nemo
parents:
5870
diff
changeset
|
714 |
begin |
5873 | 715 |
// adjust angle to match the texture |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
716 |
if Gear^.dX.isNegative then |
8906
82756a90a343
I see no reason why a visual effect needs Distance. IMO square should look just fine. Untested. Oh. Also reduced flake count at Randi's request.
nemo
parents:
8838
diff
changeset
|
717 |
i:= 130 |
82756a90a343
I see no reason why a visual effect needs Distance. IMO square should look just fine. Untested. Oh. Also reduced flake count at Randi's request.
nemo
parents:
8838
diff
changeset
|
718 |
else i:= 50; |
8795 | 719 |
|
5873 | 720 |
smoke:= AddVisualGear(hwRound(Gear^.X)-round(cos((Gear^.DirAngle+i) * pi / 180)*20), hwRound(Gear^.Y)-round(sin((Gear^.DirAngle+i) * pi / 180)*20), vgtSmoke); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
721 |
if smoke <> nil then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
722 |
smoke^.Scale:= 0.75; |
5871
09daa06191d7
Since we are tweaking molotov. make the flame flickery and add a drowning frame
nemo
parents:
5870
diff
changeset
|
723 |
end; |
5870 | 724 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
725 |
if (Gear^.State and gstCollision) <> 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
726 |
begin |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
727 |
PlaySound(sndMolotov); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
728 |
gX := hwRound(Gear^.X); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
729 |
gY := hwRound(Gear^.Y); |
5924
82fc26c53d2a
Tweak sparkles, glass. Left glass commented out in case he prefers old behaviour.
nemo
parents:
5922
diff
changeset
|
730 |
for i:= 0 to 4 do |
5874
5cd329cf2460
nemo's molotov burst effect; with a slight color modification added
sheepluva
parents:
5873
diff
changeset
|
731 |
begin |
15072 | 732 |
glass:= AddVisualGear(gx+random(7)-3, gy+random(7)-3, vgtEgg); |
6131 | 733 |
if glass <> nil then |
5924
82fc26c53d2a
Tweak sparkles, glass. Left glass commented out in case he prefers old behaviour.
nemo
parents:
5922
diff
changeset
|
734 |
with glass^ do |
82fc26c53d2a
Tweak sparkles, glass. Left glass commented out in case he prefers old behaviour.
nemo
parents:
5922
diff
changeset
|
735 |
begin |
82fc26c53d2a
Tweak sparkles, glass. Left glass commented out in case he prefers old behaviour.
nemo
parents:
5922
diff
changeset
|
736 |
Frame:= 2; |
82fc26c53d2a
Tweak sparkles, glass. Left glass commented out in case he prefers old behaviour.
nemo
parents:
5922
diff
changeset
|
737 |
Tint:= $41B83ED0 - i * $10081000; |
15072 | 738 |
dX:= dX + hwFloat2Float(Gear^.dX) / 2; |
7066
12cc2bd84b0b
Make pas2c even more happier with uGears.c, allow assigning arrays in some cases
unc0rr
parents:
7062
diff
changeset
|
739 |
Angle:= random(360); |
5924
82fc26c53d2a
Tweak sparkles, glass. Left glass commented out in case he prefers old behaviour.
nemo
parents:
5922
diff
changeset
|
740 |
FrameTicks:= 750; |
82fc26c53d2a
Tweak sparkles, glass. Left glass commented out in case he prefers old behaviour.
nemo
parents:
5922
diff
changeset
|
741 |
State:= ord(sprEgg) |
82fc26c53d2a
Tweak sparkles, glass. Left glass commented out in case he prefers old behaviour.
nemo
parents:
5922
diff
changeset
|
742 |
end; |
5874
5cd329cf2460
nemo's molotov burst effect; with a slight color modification added
sheepluva
parents:
5873
diff
changeset
|
743 |
end; |
5415
94e26612e2ec
Adjust "sticky" fire (molotov) so it makes better fire pits, by making the kicks more regular, yet of random left/right. Tweak napalm slightly along same lines. Probably needs more balancing.
nemo
parents:
5413
diff
changeset
|
744 |
for i:= 0 to 24 do |
6126
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
745 |
begin |
7001 | 746 |
dX := AngleCos(i * 2) * ((_0_15*(i div 5))) * (GetRandomf + _1); |
747 |
dY := AngleSin(i * 8) * _0_5 * (GetRandomf + _1); |
|
6126
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
748 |
AddGear(gX, gY, gtFlame, gstTmpFlag, dX, dY, 0); |
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
749 |
AddGear(gX, gY, gtFlame, gstTmpFlag, dX,-dY, 0); |
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
750 |
AddGear(gX, gY, gtFlame, gstTmpFlag,-dX, dY, 0); |
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
751 |
AddGear(gX, gY, gtFlame, gstTmpFlag,-dX,-dY, 0); |
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
752 |
end; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
753 |
DeleteGear(Gear); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
754 |
exit |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
755 |
end; |
2457
ecf0c7e7995b
Initial molotov cocktail. Still needs graphics, tweaking of fire behaviour. Also changed probabilities for default weapon sets
nemo
parents:
2455
diff
changeset
|
756 |
end; |
4 | 757 |
|
5313
5e18eaef65d0
now scripts can create unique crates: dummy (empty) crates and booby traps. scripts can also set health crate values
Henek
parents:
5298
diff
changeset
|
758 |
//////////////////////////////////////////////////////////////////////////////// |
1279 | 759 |
|
78 | 760 |
procedure doStepCluster(Gear: PGear); |
761 |
begin |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
762 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
763 |
doStepFallingGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
764 |
if (Gear^.State and gstCollision) <> 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
765 |
begin |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
766 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
767 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
768 |
exit |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
769 |
end; |
1262 | 770 |
|
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
771 |
if (Gear^.Kind = gtMelonPiece) then |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
772 |
CalcRotationDirAngle(Gear) |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
773 |
else if (GameTicks and $1F) = 0 then |
10352 | 774 |
AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtSmokeTrace); |
78 | 775 |
end; |
776 |
||
4 | 777 |
//////////////////////////////////////////////////////////////////////////////// |
4168 | 778 |
procedure doStepShell(Gear: PGear); |
4 | 779 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
780 |
AllInactive := false; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
781 |
if (GameFlags and gfMoreWind) = 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
782 |
Gear^.dX := Gear^.dX + cWindSpeed; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
783 |
doStepFallingGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
784 |
if (Gear^.State and gstCollision) <> 0 then |
4578 | 785 |
begin |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
786 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
787 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
788 |
exit |
4578 | 789 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
790 |
if (GameTicks and $3F) = 0 then |
10352 | 791 |
AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtSmokeTrace); |
95 | 792 |
end; |
793 |
||
4 | 794 |
//////////////////////////////////////////////////////////////////////////////// |
4578 | 795 |
procedure doStepSnowball(Gear: PGear); |
796 |
var kick, i: LongInt; |
|
797 |
particle: PVisualGear; |
|
8945
145bf64a9579
this should improve consistency of mortar cluster spread and snowball knocks
nemo
parents:
8934
diff
changeset
|
798 |
gdX, gdY: hwFloat; |
4578 | 799 |
begin |
800 |
AllInactive := false; |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
801 |
if (GameFlags and gfMoreWind) = 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
802 |
Gear^.dX := Gear^.dX + cWindSpeed; |
8945
145bf64a9579
this should improve consistency of mortar cluster spread and snowball knocks
nemo
parents:
8934
diff
changeset
|
803 |
gdX := Gear^.dX; |
145bf64a9579
this should improve consistency of mortar cluster spread and snowball knocks
nemo
parents:
8934
diff
changeset
|
804 |
gdY := Gear^.dY; |
4578 | 805 |
doStepFallingGear(Gear); |
806 |
CalcRotationDirAngle(Gear); |
|
807 |
if (Gear^.State and gstCollision) <> 0 then |
|
808 |
begin |
|
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
809 |
kick:= hwRound((hwAbs(gdX)+hwAbs(gdY)) * Gear^.Boom / 10000); |
8945
145bf64a9579
this should improve consistency of mortar cluster spread and snowball knocks
nemo
parents:
8934
diff
changeset
|
810 |
Gear^.dX:= gdX; |
145bf64a9579
this should improve consistency of mortar cluster spread and snowball knocks
nemo
parents:
8934
diff
changeset
|
811 |
Gear^.dY:= gdY; |
7621 | 812 |
AmmoShove(Gear, 0, kick); |
4578 | 813 |
for i:= 15 + kick div 10 downto 0 do |
814 |
begin |
|
815 |
particle := AddVisualGear(hwRound(Gear^.X) + Random(25), hwRound(Gear^.Y) + Random(25), vgtDust); |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
816 |
if particle <> nil then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
817 |
particle^.dX := particle^.dX + (Gear^.dX.QWordValue / 21474836480) |
4578 | 818 |
end; |
819 |
DeleteGear(Gear); |
|
820 |
exit |
|
821 |
end; |
|
822 |
if ((GameTicks and $1F) = 0) and (Random(3) = 0) then |
|
823 |
begin |
|
4582 | 824 |
particle:= AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtDust); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
825 |
if particle <> nil then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
826 |
particle^.dX := particle^.dX + (Gear^.dX.QWordValue / 21474836480) |
4578 | 827 |
end |
828 |
end; |
|
829 |
||
5313
5e18eaef65d0
now scripts can create unique crates: dummy (empty) crates and booby traps. scripts can also set health crate values
Henek
parents:
5298
diff
changeset
|
830 |
//////////////////////////////////////////////////////////////////////////////// |
4611 | 831 |
procedure doStepSnowflake(Gear: PGear); |
6419
6a464d0a5c13
Tidy up flake land generation, to avoid ragged holes in landbacktex. Remove of one odd Land[] change forces a PROTO bump. Well, had to happen eventually.
nemo
parents:
6389
diff
changeset
|
832 |
var xx, yy, px, py, rx, ry, lx, ly: LongInt; |
5025
ac1691d35cf2
Land sprayer tweaks, make land spray and mudball not end turn
nemo
parents:
5024
diff
changeset
|
833 |
move, draw, allpx, gun: Boolean; |
4611 | 834 |
s: PSDL_Surface; |
835 |
p: PLongwordArray; |
|
5693 | 836 |
lf: LongWord; |
15927
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
837 |
oldY: hwFloat; |
4611 | 838 |
begin |
5025
ac1691d35cf2
Land sprayer tweaks, make land spray and mudball not end turn
nemo
parents:
5024
diff
changeset
|
839 |
gun:= (Gear^.State and gstTmpFlag) <> 0; |
5024 | 840 |
move:= false; |
841 |
draw:= false; |
|
5025
ac1691d35cf2
Land sprayer tweaks, make land spray and mudball not end turn
nemo
parents:
5024
diff
changeset
|
842 |
if gun then |
5024 | 843 |
begin |
15927
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
844 |
inc(Gear^.Pos); |
6450 | 845 |
Gear^.State:= Gear^.State and (not gstInvisible); |
5024 | 846 |
doStepFallingGear(Gear); |
847 |
CheckCollision(Gear); |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
848 |
if ((Gear^.State and gstCollision) <> 0) or ((Gear^.State and gstMoving) = 0) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
849 |
draw:= true; |
5024 | 850 |
xx:= hwRound(Gear^.X); |
851 |
yy:= hwRound(Gear^.Y); |
|
14303
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14225
diff
changeset
|
852 |
if draw and (WorldEdge = weWrap) and ((xx < leftX + 3) or (xx > rightX - 3)) then |
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14225
diff
changeset
|
853 |
begin |
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14225
diff
changeset
|
854 |
if xx < leftX + 3 then |
9563 | 855 |
xx:= rightX-3 |
856 |
else xx:= leftX+3; |
|
857 |
Gear^.X:= int2hwFloat(xx) |
|
858 |
end |
|
5024 | 859 |
end |
860 |
else if GameTicks and $7 = 0 then |
|
4611 | 861 |
with Gear^ do |
862 |
begin |
|
15927
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
863 |
inc(Pos, 8); |
6450 | 864 |
State:= State and (not gstInvisible); |
15927
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
865 |
oldY:= Y; |
5355 | 866 |
X:= X + cWindSpeed * 3200 + dX; |
15927
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
867 |
Y:= Y + dY + cGravity * (vobFallSpeed * 8); // using same value as flakes to try and get similar results |
4611 | 868 |
xx:= hwRound(X); |
869 |
yy:= hwRound(Y); |
|
870 |
if vobVelocity <> 0 then |
|
871 |
begin |
|
7649 | 872 |
DirAngle := DirAngle + (Damage / 1000); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
873 |
if DirAngle < 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
874 |
DirAngle := DirAngle + 360 |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
875 |
else if 360 < DirAngle then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
876 |
DirAngle := DirAngle - 360; |
4611 | 877 |
end; |
878 |
// move back to cloud layer |
|
10354 | 879 |
if CheckCoordInWater(xx, yy) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
880 |
move:= true |
7477
26706bf32ecf
First pass at variable land size. For playing a small map (forced on rqLowRes), this should save 42MiB of RAM.
nemo
parents:
7468
diff
changeset
|
881 |
else if (xx > snowRight) or (xx < snowLeft) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
882 |
move:=true |
15927
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
883 |
else if (cGravity.isNegative) and (yy < LAND_HEIGHT-1200) then |
10736
5b7cf9fcb47e
Try to handle negative gravity w/ snow. Still needs to look nicer. Currently causes banding.
nemo
parents:
10679
diff
changeset
|
884 |
move:=true |
4791 | 885 |
// Solid pixel encountered |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
886 |
else if ((yy and LAND_HEIGHT_MASK) = 0) and ((xx and LAND_WIDTH_MASK) = 0) and (LandGet(yy, xx) <> 0) then |
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
887 |
begin |
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
888 |
lf:= LandGet(yy, xx) and (lfObject or lfBasic or lfIndestructible); |
8602 | 889 |
if lf = 0 then lf:= lfObject; |
4791 | 890 |
// If there's room below keep falling |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
891 |
if (((yy-1) and LAND_HEIGHT_MASK) = 0) and (LandGet(yy-1, xx) = 0) then |
4791 | 892 |
begin |
893 |
X:= X - cWindSpeed * 1600 - dX; |
|
894 |
end |
|
895 |
// If there's room below, on the sides, fill the gaps |
|
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
896 |
else if (((yy-1) and LAND_HEIGHT_MASK) = 0) then |
15927
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
897 |
begin |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
898 |
if (((xx - 1) and LAND_WIDTH_MASK) = 0) and (LandGet(yy - 1, (xx - 1)) = 0) then |
15927
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
899 |
begin |
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
900 |
X:= X - _0_8; |
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
901 |
Y:= oldY; |
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
902 |
end |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
903 |
else if (((xx - 2) and LAND_WIDTH_MASK) = 0) and (LandGet(yy - 1, (xx - 2)) = 0) then |
15927
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
904 |
begin |
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
905 |
X:= X - _1_6; |
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
906 |
Y:= oldY; |
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
907 |
end |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
908 |
else if (((xx + 1) and LAND_WIDTH_MASK) = 0) and (LandGet(yy - 1, (xx + 1)) = 0) then |
15927
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
909 |
begin |
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
910 |
X:= X + _0_8; |
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
911 |
Y:= oldY; |
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
912 |
end |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
913 |
else if (((xx + 2) and LAND_WIDTH_MASK) = 0) and (LandGet(yy - 1, (xx + 2)) = 0) then |
15927
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
914 |
begin |
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
915 |
X:= X + _1_6; |
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
916 |
Y:= oldY; |
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
917 |
end else |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
918 |
if ((((yy+1) and LAND_HEIGHT_MASK) = 0) and ((LandGet(yy + 1, xx) and $FF) <> 0)) then |
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
919 |
move:=true |
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
920 |
else |
15927
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
921 |
draw:= true |
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
922 |
end |
4805
01332828b568
Fancier detection of hogs/objects. Hogs wont get buried even by the worst of storms.
Palewolf
parents:
4803
diff
changeset
|
923 |
// if there's an hog/object below do nothing |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
924 |
else if ((((yy+1) and LAND_HEIGHT_MASK) = 0) and ((LandGet(yy+1, xx) and $FF) <> 0)) |
4805
01332828b568
Fancier detection of hogs/objects. Hogs wont get buried even by the worst of storms.
Palewolf
parents:
4803
diff
changeset
|
925 |
then move:=true |
5024 | 926 |
else draw:= true |
927 |
end |
|
15927
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
928 |
end; |
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
929 |
|
6131 | 930 |
if draw then |
5024 | 931 |
with Gear^ do |
932 |
begin |
|
933 |
// we've collided with land. draw some stuff and get back into the clouds |
|
934 |
move:= true; |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
935 |
if (Pos > 20) and ((CurAmmoGear = nil) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
936 |
or (CurAmmoGear^.Kind <> gtRope)) then |
5024 | 937 |
begin |
5025
ac1691d35cf2
Land sprayer tweaks, make land spray and mudball not end turn
nemo
parents:
5024
diff
changeset
|
938 |
if not gun then |
5024 | 939 |
begin |
940 |
dec(yy,3); |
|
941 |
dec(xx,1) |
|
942 |
end; |
|
943 |
s:= SpritesData[sprSnow].Surface; |
|
944 |
p:= s^.pixels; |
|
945 |
allpx:= true; |
|
946 |
for py:= 0 to Pred(s^.h) do |
|
947 |
begin |
|
948 |
for px:= 0 to Pred(s^.w) do |
|
6419
6a464d0a5c13
Tidy up flake land generation, to avoid ragged holes in landbacktex. Remove of one odd Land[] change forces a PROTO bump. Well, had to happen eventually.
nemo
parents:
6389
diff
changeset
|
949 |
begin |
6a464d0a5c13
Tidy up flake land generation, to avoid ragged holes in landbacktex. Remove of one odd Land[] change forces a PROTO bump. Well, had to happen eventually.
nemo
parents:
6389
diff
changeset
|
950 |
lx:=xx + px; ly:=yy + py; |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
951 |
if (ly and LAND_HEIGHT_MASK = 0) and (lx and LAND_WIDTH_MASK = 0) and (LandGet(ly, lx) and $FF = 0) then |
5024 | 952 |
begin |
6419
6a464d0a5c13
Tidy up flake land generation, to avoid ragged holes in landbacktex. Remove of one odd Land[] change forces a PROTO bump. Well, had to happen eventually.
nemo
parents:
6389
diff
changeset
|
953 |
rx:= lx; |
6a464d0a5c13
Tidy up flake land generation, to avoid ragged holes in landbacktex. Remove of one odd Land[] change forces a PROTO bump. Well, had to happen eventually.
nemo
parents:
6389
diff
changeset
|
954 |
ry:= ly; |
6a464d0a5c13
Tidy up flake land generation, to avoid ragged holes in landbacktex. Remove of one odd Land[] change forces a PROTO bump. Well, had to happen eventually.
nemo
parents:
6389
diff
changeset
|
955 |
if cReducedQuality and rqBlurryLand <> 0 then |
5025
ac1691d35cf2
Land sprayer tweaks, make land spray and mudball not end turn
nemo
parents:
5024
diff
changeset
|
956 |
begin |
6419
6a464d0a5c13
Tidy up flake land generation, to avoid ragged holes in landbacktex. Remove of one odd Land[] change forces a PROTO bump. Well, had to happen eventually.
nemo
parents:
6389
diff
changeset
|
957 |
rx:= rx div 2;ry:= ry div 2; |
6a464d0a5c13
Tidy up flake land generation, to avoid ragged holes in landbacktex. Remove of one odd Land[] change forces a PROTO bump. Well, had to happen eventually.
nemo
parents:
6389
diff
changeset
|
958 |
end; |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
959 |
if LandGet(yy + py, xx + px) <= lfAllObjMask then |
5025
ac1691d35cf2
Land sprayer tweaks, make land spray and mudball not end turn
nemo
parents:
5024
diff
changeset
|
960 |
if gun then |
6419
6a464d0a5c13
Tidy up flake land generation, to avoid ragged holes in landbacktex. Remove of one odd Land[] change forces a PROTO bump. Well, had to happen eventually.
nemo
parents:
6389
diff
changeset
|
961 |
begin |
6a464d0a5c13
Tidy up flake land generation, to avoid ragged holes in landbacktex. Remove of one odd Land[] change forces a PROTO bump. Well, had to happen eventually.
nemo
parents:
6389
diff
changeset
|
962 |
LandDirty[yy div 32, xx div 32]:= 1; |
15930
f39f0f614dbf
Use LandPixels array allocate in hwengine-future library
unC0Rr
parents:
15929
diff
changeset
|
963 |
if LandPixelGet(ry, rx) = 0 then |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
964 |
LandSet(ly, lx, lfDamaged or lfObject) |
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
965 |
else LandSet(ly, lx, lfDamaged or lfBasic) |
6419
6a464d0a5c13
Tidy up flake land generation, to avoid ragged holes in landbacktex. Remove of one odd Land[] change forces a PROTO bump. Well, had to happen eventually.
nemo
parents:
6389
diff
changeset
|
966 |
end |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
967 |
else LandSet(ly, lx, lf); |
6419
6a464d0a5c13
Tidy up flake land generation, to avoid ragged holes in landbacktex. Remove of one odd Land[] change forces a PROTO bump. Well, had to happen eventually.
nemo
parents:
6389
diff
changeset
|
968 |
if gun then |
15930
f39f0f614dbf
Use LandPixels array allocate in hwengine-future library
unC0Rr
parents:
15929
diff
changeset
|
969 |
LandPixelSet(ry, rx, (Gear^.Tint shr 24 shl RShift) or |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
970 |
(Gear^.Tint shr 16 and $FF shl GShift) or |
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
971 |
(Gear^.Tint shr 8 and $FF shl BShift) or |
15930
f39f0f614dbf
Use LandPixels array allocate in hwengine-future library
unC0Rr
parents:
15929
diff
changeset
|
972 |
(p^[px] and AMask)) |
f39f0f614dbf
Use LandPixels array allocate in hwengine-future library
unC0Rr
parents:
15929
diff
changeset
|
973 |
else LandPixelSet(ry, rx, addBgColor(LandPixelGet(ry, rx), p^[px])); |
5024 | 974 |
end |
6419
6a464d0a5c13
Tidy up flake land generation, to avoid ragged holes in landbacktex. Remove of one odd Land[] change forces a PROTO bump. Well, had to happen eventually.
nemo
parents:
6389
diff
changeset
|
975 |
else allpx:= false |
6a464d0a5c13
Tidy up flake land generation, to avoid ragged holes in landbacktex. Remove of one odd Land[] change forces a PROTO bump. Well, had to happen eventually.
nemo
parents:
6389
diff
changeset
|
976 |
end; |
10131
4b4a043111f4
- pas2c recognizes typecasts in initialization expressions
unc0rr
parents:
10125
diff
changeset
|
977 |
p:= PLongWordArray(@(p^[s^.pitch shr 2])) |
5024 | 978 |
end; |
8795 | 979 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
980 |
if allpx then |
7170
84ac6c6d2d8e
Only create textures for non-empty LandPixel chunks. This should save a fair amount of memory, especially on smaller maps, and eliminate a number of draws
nemo
parents:
7168
diff
changeset
|
981 |
UpdateLandTexture(xx, Pred(s^.h), yy, Pred(s^.w), true) |
4791 | 982 |
else |
4611 | 983 |
begin |
5024 | 984 |
UpdateLandTexture( |
985 |
max(0, min(LAND_WIDTH, xx)), |
|
986 |
min(LAND_WIDTH - xx, Pred(s^.w)), |
|
987 |
max(0, min(LAND_WIDTH, yy)), |
|
7170
84ac6c6d2d8e
Only create textures for non-empty LandPixel chunks. This should save a fair amount of memory, especially on smaller maps, and eliminate a number of draws
nemo
parents:
7168
diff
changeset
|
988 |
min(LAND_HEIGHT - yy, Pred(s^.h)), false // could this be true without unnecessarily creating blanks? |
5024 | 989 |
); |
4791 | 990 |
end; |
4611 | 991 |
end |
5024 | 992 |
end; |
993 |
||
994 |
if move then |
|
995 |
begin |
|
5025
ac1691d35cf2
Land sprayer tweaks, make land spray and mudball not end turn
nemo
parents:
5024
diff
changeset
|
996 |
if gun then |
5024 | 997 |
begin |
998 |
DeleteGear(Gear); |
|
999 |
exit |
|
1000 |
end; |
|
5695 | 1001 |
Gear^.Pos:= 0; |
7721 | 1002 |
Gear^.X:= int2hwFloat(LongInt(GetRandom(snowRight - snowLeft)) + snowLeft); |
15927
046182f1080b
Optimize doStepSnowflake a bit, losing backwards compatibility
unC0Rr
parents:
15873
diff
changeset
|
1003 |
if (cGravity.isNegative) and (yy < LAND_HEIGHT-1200) then |
10736
5b7cf9fcb47e
Try to handle negative gravity w/ snow. Still needs to look nicer. Currently causes banding.
nemo
parents:
10679
diff
changeset
|
1004 |
Gear^.Y:= int2hwFloat(LAND_HEIGHT - 50 - LongInt(GetRandom(50))) |
5b7cf9fcb47e
Try to handle negative gravity w/ snow. Still needs to look nicer. Currently causes banding.
nemo
parents:
10679
diff
changeset
|
1005 |
else Gear^.Y:= int2hwFloat(LAND_HEIGHT + LongInt(GetRandom(50)) - 1250); |
5413 | 1006 |
Gear^.State:= Gear^.State or gstInvisible; |
4611 | 1007 |
end |
1008 |
end; |
|
1009 |
||
4578 | 1010 |
//////////////////////////////////////////////////////////////////////////////// |
4 | 1011 |
procedure doStepGrave(Gear: PGear); |
1012 |
begin |
|
7394 | 1013 |
if (Gear^.Message and gmDestroy) <> 0 then |
7393
3f203c62353b
Fix bug in resurrector deleting graves (exists in stable too), remove some unnecessary assignments due to the fillchar 0
nemo
parents:
7391
diff
changeset
|
1014 |
begin |
3f203c62353b
Fix bug in resurrector deleting graves (exists in stable too), remove some unnecessary assignments due to the fillchar 0
nemo
parents:
7391
diff
changeset
|
1015 |
DeleteGear(Gear); |
3f203c62353b
Fix bug in resurrector deleting graves (exists in stable too), remove some unnecessary assignments due to the fillchar 0
nemo
parents:
7391
diff
changeset
|
1016 |
exit |
3f203c62353b
Fix bug in resurrector deleting graves (exists in stable too), remove some unnecessary assignments due to the fillchar 0
nemo
parents:
7391
diff
changeset
|
1017 |
end; |
7394 | 1018 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1019 |
AllInactive := false; |
7394 | 1020 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1021 |
if Gear^.dY.isNegative then |
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9698
diff
changeset
|
1022 |
if TestCollisionY(Gear, -1) <> 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1023 |
Gear^.dY := _0; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1024 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1025 |
if not Gear^.dY.isNegative then |
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9698
diff
changeset
|
1026 |
if TestCollisionY(Gear, 1) <> 0 then |
9820 | 1027 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1028 |
Gear^.dY := - Gear^.dY * Gear^.Elasticity; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1029 |
if Gear^.dY > - _1div1024 then |
9820 | 1030 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1031 |
Gear^.Active := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1032 |
exit |
9820 | 1033 |
end |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1034 |
else if Gear^.dY < - _0_03 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1035 |
PlaySound(Gear^.ImpactSound) |
9820 | 1036 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1037 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1038 |
Gear^.Y := Gear^.Y + Gear^.dY; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1039 |
CheckGearDrowning(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1040 |
Gear^.dY := Gear^.dY + cGravity |
4 | 1041 |
end; |
1042 |
||
1043 |
//////////////////////////////////////////////////////////////////////////////// |
|
3080 | 1044 |
procedure doStepBeeWork(Gear: PGear); |
8795 | 1045 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1046 |
t: hwFloat; |
5748
70d7f8e40f53
Just for fun. Flowers! Also, use a less blatant image in ammo menu.
nemo
parents:
5738
diff
changeset
|
1047 |
gX,gY,i: LongInt; |
14535
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14419
diff
changeset
|
1048 |
uw, nuw, wrapped: boolean; |
5748
70d7f8e40f53
Just for fun. Flowers! Also, use a less blatant image in ammo menu.
nemo
parents:
5738
diff
changeset
|
1049 |
flower: PVisualGear; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1050 |
|
4 | 1051 |
begin |
14535
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14419
diff
changeset
|
1052 |
wrapped:= WorldWrap(Gear); |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14419
diff
changeset
|
1053 |
if wrapped then |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14419
diff
changeset
|
1054 |
HomingWrap(Gear); |
5ac181cb2396
Fix bee targeting fail across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14419
diff
changeset
|
1055 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1056 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1057 |
gX := hwRound(Gear^.X); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1058 |
gY := hwRound(Gear^.Y); |
6251 | 1059 |
uw := (Gear^.Tag <> 0); // was bee underwater last tick? |
10354 | 1060 |
nuw := CheckCoordInWater(gx, gy + Gear^.Radius); // is bee underwater now? |
6251 | 1061 |
|
1062 |
// if water entered or left |
|
1063 |
if nuw <> uw then |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1064 |
begin |
10363 | 1065 |
if Gear^.Timer <> 5000 then |
1066 |
AddSplashForGear(Gear, false); |
|
7053 | 1067 |
StopSoundChan(Gear^.SoundChannel); |
6251 | 1068 |
if nuw then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1069 |
begin |
6251 | 1070 |
Gear^.SoundChannel := LoopSound(sndBeeWater); |
1071 |
Gear^.Tag := 1; |
|
1072 |
end |
|
1073 |
else |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1074 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1075 |
Gear^.SoundChannel := LoopSound(sndBee); |
6251 | 1076 |
Gear^.Tag := 0; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1077 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1078 |
end; |
6251 | 1079 |
|
1080 |
||
1081 |
if Gear^.Timer = 0 then |
|
9766
62c49992b049
fix Issue #724: Bee sound never stops (underwater when timer is 0)
sheepluva
parents:
9742
diff
changeset
|
1082 |
begin |
13593
083733ec7941
Add support for infinite fly time of jetpack and Birdy
Wuzzy <Wuzzy2@mail.ru>
parents:
13572
diff
changeset
|
1083 |
// no energy? just fall |
9766
62c49992b049
fix Issue #724: Bee sound never stops (underwater when timer is 0)
sheepluva
parents:
9742
diff
changeset
|
1084 |
doStepFallingGear(Gear); |
62c49992b049
fix Issue #724: Bee sound never stops (underwater when timer is 0)
sheepluva
parents:
9742
diff
changeset
|
1085 |
// if drowning, stop bee sound |
62c49992b049
fix Issue #724: Bee sound never stops (underwater when timer is 0)
sheepluva
parents:
9742
diff
changeset
|
1086 |
if (Gear^.State and gstDrowning) <> 0 then |
62c49992b049
fix Issue #724: Bee sound never stops (underwater when timer is 0)
sheepluva
parents:
9742
diff
changeset
|
1087 |
StopSoundChan(Gear^.SoundChannel); |
62c49992b049
fix Issue #724: Bee sound never stops (underwater when timer is 0)
sheepluva
parents:
9742
diff
changeset
|
1088 |
end |
6251 | 1089 |
else |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1090 |
begin |
11475 | 1091 |
if (Gear^.Timer and $F) = 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1092 |
begin |
11475 | 1093 |
if (Gear^.Timer and $3F) = 0 then |
10352 | 1094 |
AddVisualGear(gX, gY, vgtBeeTrace); |
1095 |
||
11475 | 1096 |
Gear^.dX := Gear^.dX + _0_000064 * (Gear^.Target.X - gX); |
1097 |
Gear^.dY := Gear^.dY + _0_000064 * (Gear^.Target.Y - gY); |
|
6251 | 1098 |
// make sure new speed isn't higher than original one (which we stored in Friction variable) |
1099 |
t := Gear^.Friction / Distance(Gear^.dX, Gear^.dY); |
|
1100 |
Gear^.dX := Gear^.dX * t; |
|
1101 |
Gear^.dY := Gear^.dY * t; |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1102 |
end; |
6251 | 1103 |
|
1104 |
Gear^.X := Gear^.X + Gear^.dX; |
|
1105 |
Gear^.Y := Gear^.Y + Gear^.dY; |
|
1106 |
||
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1107 |
end; |
3591 | 1108 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1109 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1110 |
CheckCollision(Gear); |
6251 | 1111 |
if ((Gear^.State and gstCollision) <> 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1112 |
begin |
7053 | 1113 |
StopSoundChan(Gear^.SoundChannel); |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
1114 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
5748
70d7f8e40f53
Just for fun. Flowers! Also, use a less blatant image in ammo menu.
nemo
parents:
5738
diff
changeset
|
1115 |
for i:= 0 to 31 do |
70d7f8e40f53
Just for fun. Flowers! Also, use a less blatant image in ammo menu.
nemo
parents:
5738
diff
changeset
|
1116 |
begin |
70d7f8e40f53
Just for fun. Flowers! Also, use a less blatant image in ammo menu.
nemo
parents:
5738
diff
changeset
|
1117 |
flower:= AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtStraightShot); |
6131 | 1118 |
if flower <> nil then |
5748
70d7f8e40f53
Just for fun. Flowers! Also, use a less blatant image in ammo menu.
nemo
parents:
5738
diff
changeset
|
1119 |
with flower^ do |
70d7f8e40f53
Just for fun. Flowers! Also, use a less blatant image in ammo menu.
nemo
parents:
5738
diff
changeset
|
1120 |
begin |
70d7f8e40f53
Just for fun. Flowers! Also, use a less blatant image in ammo menu.
nemo
parents:
5738
diff
changeset
|
1121 |
Scale:= 0.75; |
70d7f8e40f53
Just for fun. Flowers! Also, use a less blatant image in ammo menu.
nemo
parents:
5738
diff
changeset
|
1122 |
dx:= 0.001 * (random(200)); |
70d7f8e40f53
Just for fun. Flowers! Also, use a less blatant image in ammo menu.
nemo
parents:
5738
diff
changeset
|
1123 |
dy:= 0.001 * (random(200)); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1124 |
if random(2) = 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1125 |
dx := -dx; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1126 |
if random(2) = 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1127 |
dy := -dy; |
5748
70d7f8e40f53
Just for fun. Flowers! Also, use a less blatant image in ammo menu.
nemo
parents:
5738
diff
changeset
|
1128 |
FrameTicks:= random(250) + 250; |
70d7f8e40f53
Just for fun. Flowers! Also, use a less blatant image in ammo menu.
nemo
parents:
5738
diff
changeset
|
1129 |
State:= ord(sprTargetBee); |
70d7f8e40f53
Just for fun. Flowers! Also, use a less blatant image in ammo menu.
nemo
parents:
5738
diff
changeset
|
1130 |
end; |
70d7f8e40f53
Just for fun. Flowers! Also, use a less blatant image in ammo menu.
nemo
parents:
5738
diff
changeset
|
1131 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1132 |
DeleteGear(Gear); |
10135 | 1133 |
exit; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1134 |
end; |
6251 | 1135 |
|
1136 |
if (Gear^.Timer > 0) then |
|
9766
62c49992b049
fix Issue #724: Bee sound never stops (underwater when timer is 0)
sheepluva
parents:
9742
diff
changeset
|
1137 |
begin |
62c49992b049
fix Issue #724: Bee sound never stops (underwater when timer is 0)
sheepluva
parents:
9742
diff
changeset
|
1138 |
dec(Gear^.Timer); |
62c49992b049
fix Issue #724: Bee sound never stops (underwater when timer is 0)
sheepluva
parents:
9742
diff
changeset
|
1139 |
if Gear^.Timer = 0 then |
62c49992b049
fix Issue #724: Bee sound never stops (underwater when timer is 0)
sheepluva
parents:
9742
diff
changeset
|
1140 |
begin |
62c49992b049
fix Issue #724: Bee sound never stops (underwater when timer is 0)
sheepluva
parents:
9742
diff
changeset
|
1141 |
// no need to display remaining time anymore |
62c49992b049
fix Issue #724: Bee sound never stops (underwater when timer is 0)
sheepluva
parents:
9742
diff
changeset
|
1142 |
Gear^.RenderTimer:= false; |
62c49992b049
fix Issue #724: Bee sound never stops (underwater when timer is 0)
sheepluva
parents:
9742
diff
changeset
|
1143 |
// bee can drown when timer reached 0 |
9954 | 1144 |
Gear^.State:= Gear^.State and (not gstSubmersible); |
9766
62c49992b049
fix Issue #724: Bee sound never stops (underwater when timer is 0)
sheepluva
parents:
9742
diff
changeset
|
1145 |
end; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1146 |
end; |
4 | 1147 |
end; |
1148 |
||
3080 | 1149 |
procedure doStepBee(Gear: PGear); |
15225
f55c1c895797
Bee: Call HomingWrap in pre-homing phase, too
Wuzzy <Wuzzy2@mail.ru>
parents:
15217
diff
changeset
|
1150 |
var wrapped: boolean; |
4 | 1151 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1152 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1153 |
Gear^.X := Gear^.X + Gear^.dX; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1154 |
Gear^.Y := Gear^.Y + Gear^.dY; |
15225
f55c1c895797
Bee: Call HomingWrap in pre-homing phase, too
Wuzzy <Wuzzy2@mail.ru>
parents:
15217
diff
changeset
|
1155 |
wrapped:= WorldWrap(Gear); |
f55c1c895797
Bee: Call HomingWrap in pre-homing phase, too
Wuzzy <Wuzzy2@mail.ru>
parents:
15217
diff
changeset
|
1156 |
if wrapped then |
f55c1c895797
Bee: Call HomingWrap in pre-homing phase, too
Wuzzy <Wuzzy2@mail.ru>
parents:
15217
diff
changeset
|
1157 |
HomingWrap(Gear); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1158 |
Gear^.dY := Gear^.dY + cGravity; |
10363 | 1159 |
CheckGearDrowning(Gear); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1160 |
CheckCollision(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1161 |
if (Gear^.State and gstCollision) <> 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1162 |
begin |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
1163 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1164 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1165 |
exit |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1166 |
end; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1167 |
dec(Gear^.Timer); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1168 |
if Gear^.Timer = 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1169 |
begin |
6450 | 1170 |
Gear^.Hedgehog^.Gear^.Message:= Gear^.Hedgehog^.Gear^.Message and (not gmAttack); |
1171 |
Gear^.Hedgehog^.Gear^.State:= Gear^.Hedgehog^.Gear^.State and (not gstAttacking); |
|
4135
5be798ecafdc
This should make bee and other targetted things behave more reliably in infinite attack mode. Blocks switching of weps if a target point is active.
nemo
parents:
4104
diff
changeset
|
1172 |
AttackBar:= 0; |
8795 | 1173 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1174 |
Gear^.SoundChannel := LoopSound(sndBee); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1175 |
Gear^.Timer := 5000; |
3591 | 1176 |
// save initial speed in otherwise unused Friction variable |
1177 |
Gear^.Friction := Distance(Gear^.dX, Gear^.dY); |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1178 |
Gear^.doStep := @doStepBeeWork |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1179 |
end; |
4 | 1180 |
end; |
1181 |
||
1182 |
//////////////////////////////////////////////////////////////////////////////// |
|
876 | 1183 |
procedure doStepShotIdle(Gear: PGear); |
1184 |
begin |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1185 |
AllInactive := false; |
13152 | 1186 |
if (Gear^.Kind <> gtMinigunBullet) then |
1187 |
begin |
|
1188 |
inc(Gear^.Timer); |
|
1189 |
if Gear^.Timer > 75 then |
|
1190 |
begin |
|
1191 |
DeleteGear(Gear); |
|
1192 |
AfterAttack |
|
1193 |
end |
|
1194 |
end |
|
1195 |
else |
|
14577 | 1196 |
DeleteGear(Gear); |
876 | 1197 |
end; |
1198 |
||
13147
7040506c831f
Fix direction of dispensed bullet shells from shotgun/sniper/minigun
alfadur
parents:
13140
diff
changeset
|
1199 |
procedure CreateShellForGear(Gear: PGear; startFrame: Longword); |
7040506c831f
Fix direction of dispensed bullet shells from shotgun/sniper/minigun
alfadur
parents:
13140
diff
changeset
|
1200 |
var |
7040506c831f
Fix direction of dispensed bullet shells from shotgun/sniper/minigun
alfadur
parents:
13140
diff
changeset
|
1201 |
shell: PVisualGear; |
7040506c831f
Fix direction of dispensed bullet shells from shotgun/sniper/minigun
alfadur
parents:
13140
diff
changeset
|
1202 |
begin |
7040506c831f
Fix direction of dispensed bullet shells from shotgun/sniper/minigun
alfadur
parents:
13140
diff
changeset
|
1203 |
shell := AddVisualGear(hwRound(Gear^.x), hwRound(Gear^.y), vgtShell); |
7040506c831f
Fix direction of dispensed bullet shells from shotgun/sniper/minigun
alfadur
parents:
13140
diff
changeset
|
1204 |
if shell <> nil then |
7040506c831f
Fix direction of dispensed bullet shells from shotgun/sniper/minigun
alfadur
parents:
13140
diff
changeset
|
1205 |
begin |
7040506c831f
Fix direction of dispensed bullet shells from shotgun/sniper/minigun
alfadur
parents:
13140
diff
changeset
|
1206 |
shell^.dX := gear^.dX.QWordValue / -17179869184; |
7040506c831f
Fix direction of dispensed bullet shells from shotgun/sniper/minigun
alfadur
parents:
13140
diff
changeset
|
1207 |
if (gear^.dX.isNegative) then |
7040506c831f
Fix direction of dispensed bullet shells from shotgun/sniper/minigun
alfadur
parents:
13140
diff
changeset
|
1208 |
shell^.dX := -shell^.dX; |
7040506c831f
Fix direction of dispensed bullet shells from shotgun/sniper/minigun
alfadur
parents:
13140
diff
changeset
|
1209 |
shell^.dY := gear^.dY.QWordValue / -17179869184; |
7040506c831f
Fix direction of dispensed bullet shells from shotgun/sniper/minigun
alfadur
parents:
13140
diff
changeset
|
1210 |
shell^.Frame := startFrame; |
7040506c831f
Fix direction of dispensed bullet shells from shotgun/sniper/minigun
alfadur
parents:
13140
diff
changeset
|
1211 |
end; |
7040506c831f
Fix direction of dispensed bullet shells from shotgun/sniper/minigun
alfadur
parents:
13140
diff
changeset
|
1212 |
end; |
7040506c831f
Fix direction of dispensed bullet shells from shotgun/sniper/minigun
alfadur
parents:
13140
diff
changeset
|
1213 |
|
13407
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1214 |
function ShotgunLineHitHelp(Gear: PGear; oX, oY, tX, tY: hwFloat): Boolean; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1215 |
var i: LongInt; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1216 |
Collisions: PGearArray; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1217 |
begin |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1218 |
ShotgunLineHitHelp := false; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1219 |
Collisions := CheckAllGearsLineCollision(Gear, oX, oY, tX, tY); |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1220 |
i := Collisions^.Count; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1221 |
while i > 0 do |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1222 |
begin |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1223 |
dec(i); |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1224 |
if Collisions^.ar[i]^.Kind in |
15732 | 1225 |
[gtMine, gtSMine, gtAirMine, gtKnife, gtCase, gtTarget, gtExplosives, gtSentry] then |
13407
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1226 |
begin |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1227 |
Gear^.X := Collisions^.ar[i]^.X; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1228 |
Gear^.Y := Collisions^.ar[i]^.Y; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1229 |
ShotgunShot(Gear); |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1230 |
Gear^.doStep := @doStepShotIdle; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1231 |
ShotgunLineHitHelp := true; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1232 |
exit; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1233 |
end; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1234 |
end; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1235 |
end; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1236 |
|
4 | 1237 |
procedure doStepShotgunShot(Gear: PGear); |
8795 | 1238 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1239 |
i: LongWord; |
13407
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1240 |
oX, oY, tmpX, tmpY: hwFloat; |
4 | 1241 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1242 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1243 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1244 |
if ((Gear^.State and gstAnimation) = 0) then |
15745 | 1245 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1246 |
dec(Gear^.Timer); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1247 |
if Gear^.Timer = 0 then |
15745 | 1248 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1249 |
PlaySound(sndShotgunFire); |
13147
7040506c831f
Fix direction of dispensed bullet shells from shotgun/sniper/minigun
alfadur
parents:
13140
diff
changeset
|
1250 |
CreateShellForGear(Gear, 0); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1251 |
Gear^.State := Gear^.State or gstAnimation |
15745 | 1252 |
end |
1253 |
else if (Gear^.Hedgehog^.Gear = nil) |
|
1254 |
or ((Gear^.Hedgehog^.Gear^.State and (gstMoving or gstHHDriven)) = gstMoving) then |
|
1255 |
begin |
|
7564
651d56a6e568
Cancel shotgun shot if hedgehog is moved moved (by explosion)
unc0rr
parents:
7539
diff
changeset
|
1256 |
DeleteGear(Gear); |
651d56a6e568
Cancel shotgun shot if hedgehog is moved moved (by explosion)
unc0rr
parents:
7539
diff
changeset
|
1257 |
AfterAttack; |
15745 | 1258 |
end; |
1259 |
exit |
|
1260 |
end |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1261 |
else |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1262 |
inc(Gear^.Timer); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1263 |
|
13407
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1264 |
i := 100; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1265 |
oX := Gear^.X; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1266 |
oY := Gear^.Y; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1267 |
repeat |
13407
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1268 |
if Gear^.Tag = 0 then |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1269 |
begin |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1270 |
Gear^.X := Gear^.X + Gear^.dX; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1271 |
Gear^.Y := Gear^.Y + Gear^.dY; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1272 |
end; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1273 |
|
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1274 |
tmpX := Gear^.X; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1275 |
tmpY := Gear^.Y; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1276 |
if (Gear^.PortalCounter < 30) and WorldWrap(Gear) then |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1277 |
begin |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1278 |
inc(Gear^.PortalCounter); |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1279 |
if ShotgunLineHitHelp(Gear, oX, oY, tmpX, tmpY) then |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1280 |
exit; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1281 |
oX := Gear^.X; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1282 |
oY := Gear^.Y; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1283 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1284 |
CheckCollision(Gear); |
13407
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1285 |
|
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1286 |
if ((Gear^.State and gstCollision) <> 0) then |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1287 |
begin |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1288 |
if Gear^.Tag = 0 then |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1289 |
begin |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1290 |
//Try to align the shot with the land to give portals a chance to catch it |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1291 |
Gear^.X := Gear^.X + Gear^.dX * 2; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1292 |
Gear^.Y := Gear^.Y + Gear^.dY * 2; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1293 |
Gear^.Tag := 1 |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1294 |
end |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1295 |
else |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1296 |
begin |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1297 |
Gear^.X := Gear^.X + Gear^.dX * 6; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1298 |
Gear^.Y := Gear^.Y + Gear^.dY * 6; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1299 |
ShotgunShot(Gear); |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1300 |
Gear^.doStep := @doStepShotIdle; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1301 |
end; |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1302 |
exit |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1303 |
end |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1304 |
else |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1305 |
Gear^.Tag := 0; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1306 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1307 |
CheckGearDrowning(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1308 |
if (Gear^.State and gstDrowning) <> 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1309 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1310 |
Gear^.doStep := @doStepShotIdle; |
13407
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1311 |
break; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1312 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1313 |
dec(i) |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1314 |
until i = 0; |
13407
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1315 |
|
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1316 |
ShotgunLineHitHelp(Gear, oX, oY, Gear^.X, Gear^.Y); |
06792533ef91
ensure shotgun works with portals and make it hit airmines
alfadur
parents:
13406
diff
changeset
|
1317 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1318 |
if (hwRound(Gear^.X) and LAND_WIDTH_MASK <> 0) or (hwRound(Gear^.Y) and LAND_HEIGHT_MASK <> 0) then |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1319 |
Gear^.doStep := @doStepShotIdle |
4 | 1320 |
end; |
1321 |
||
1322 |
//////////////////////////////////////////////////////////////////////////////// |
|
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1323 |
procedure spawnBulletTrail(Bullet: PGear; bulletX, bulletY: hwFloat; fadeIn: Boolean); |
5841 | 1324 |
var oX, oY: hwFloat; |
13341
0c3f612edc19
Partial fix of Pas2C parsing problems (part 1: uGearsHandlersMess)
Wuzzy <Wuzzy2@mail.ru>
parents:
13323
diff
changeset
|
1325 |
fromX, fromY, toX, toY, dX, dY, bLength, stepLength: real; |
5841 | 1326 |
VGear: PVisualGear; |
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1327 |
i, steps: LongWord; |
5841 | 1328 |
begin |
15873
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
1329 |
if CurrentHedgehog^.Gear = nil then |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
1330 |
begin |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
1331 |
DeleteGear(Bullet); |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
1332 |
exit |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
1333 |
end; |
5841 | 1334 |
if Bullet^.PortalCounter = 0 then |
1335 |
begin |
|
1336 |
ox:= CurrentHedgehog^.Gear^.X + Int2hwFloat(GetLaunchX(CurrentHedgehog^.CurAmmoType, hwSign(CurrentHedgehog^.Gear^.dX), CurrentHedgehog^.Gear^.Angle)); |
|
1337 |
oy:= CurrentHedgehog^.Gear^.Y + Int2hwFloat(GetLaunchY(CurrentHedgehog^.CurAmmoType, CurrentHedgehog^.Gear^.Angle)); |
|
1338 |
end |
|
1339 |
else |
|
1340 |
begin |
|
1341 |
ox:= Bullet^.Elasticity; |
|
1342 |
oy:= Bullet^.Friction; |
|
1343 |
end; |
|
1344 |
||
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1345 |
fromX:= hwFloat2Float(ox); |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1346 |
fromY:= hwFloat2Float(oy); |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1347 |
toX:= hwFloat2Float(bulletX); |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1348 |
toY:= hwFloat2Float(bulletY); |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1349 |
|
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1350 |
dX:= toX - fromX; |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1351 |
dY:= toY - fromY; |
13341
0c3f612edc19
Partial fix of Pas2C parsing problems (part 1: uGearsHandlersMess)
Wuzzy <Wuzzy2@mail.ru>
parents:
13323
diff
changeset
|
1352 |
bLength:= sqrt(dX * dX + dY * dY); |
0c3f612edc19
Partial fix of Pas2C parsing problems (part 1: uGearsHandlersMess)
Wuzzy <Wuzzy2@mail.ru>
parents:
13323
diff
changeset
|
1353 |
dX:= dX / bLength; |
0c3f612edc19
Partial fix of Pas2C parsing problems (part 1: uGearsHandlersMess)
Wuzzy <Wuzzy2@mail.ru>
parents:
13323
diff
changeset
|
1354 |
dY:= dY / bLength; |
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1355 |
|
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1356 |
if fadeIn then |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1357 |
begin |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1358 |
steps:= 10; |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1359 |
stepLength:= 12; |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1360 |
fromX:= fromX + dX * 45; |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1361 |
fromY:= fromY + dY * 45; |
13341
0c3f612edc19
Partial fix of Pas2C parsing problems (part 1: uGearsHandlersMess)
Wuzzy <Wuzzy2@mail.ru>
parents:
13323
diff
changeset
|
1362 |
bLength:= bLength - 45; |
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1363 |
end |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1364 |
else steps:= 1; |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1365 |
|
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1366 |
for i:= 0 to steps - 1 do |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1367 |
begin |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1368 |
if i < steps - 1 then |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1369 |
begin |
13341
0c3f612edc19
Partial fix of Pas2C parsing problems (part 1: uGearsHandlersMess)
Wuzzy <Wuzzy2@mail.ru>
parents:
13323
diff
changeset
|
1370 |
toX:= fromX + dX * minD(stepLength, bLength); |
0c3f612edc19
Partial fix of Pas2C parsing problems (part 1: uGearsHandlersMess)
Wuzzy <Wuzzy2@mail.ru>
parents:
13323
diff
changeset
|
1371 |
toY:= fromY + dY * minD(stepLength, bLength); |
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1372 |
end |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1373 |
else if steps > 1 then |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1374 |
begin |
13341
0c3f612edc19
Partial fix of Pas2C parsing problems (part 1: uGearsHandlersMess)
Wuzzy <Wuzzy2@mail.ru>
parents:
13323
diff
changeset
|
1375 |
toX:= fromX + dX * bLength; |
0c3f612edc19
Partial fix of Pas2C parsing problems (part 1: uGearsHandlersMess)
Wuzzy <Wuzzy2@mail.ru>
parents:
13323
diff
changeset
|
1376 |
toY:= fromY + dY * bLength; |
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1377 |
end; |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1378 |
|
13341
0c3f612edc19
Partial fix of Pas2C parsing problems (part 1: uGearsHandlersMess)
Wuzzy <Wuzzy2@mail.ru>
parents:
13323
diff
changeset
|
1379 |
if bLength > 0 then |
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1380 |
begin |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1381 |
VGear := AddVisualGear(round(fromX), round(fromY), vgtLineTrail); |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1382 |
if VGear <> nil then |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1383 |
begin |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1384 |
VGear^.X:= fromX; |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1385 |
VGear^.Y:= fromY; |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1386 |
VGear^.dX:= toX; |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1387 |
VGear^.dY:= toY; |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1388 |
VGear^.Tint:= $FFFFFF00 or ($FF * (i + 1) div (steps)); |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1389 |
|
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1390 |
// reached edge of land. assume infinite beam. Extend it way out past camera |
13321
23ade5604f8d
Fix bullet trails overlapping when the pass through wrap or bounce world edge
alfadur
parents:
13318
diff
changeset
|
1391 |
if ((round(toX) and LAND_WIDTH_MASK <> 0) and (not (WorldEdge in [weBounce, weWrap]))) |
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1392 |
or (round(toY) and LAND_HEIGHT_MASK <> 0) then |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1393 |
// only extend if not under water |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1394 |
if not CheckCoordInWater(round(toX), round(toY)) then |
5841 | 1395 |
begin |
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1396 |
VGear^.dX := VGear^.dX + max(LAND_WIDTH,4096) * (VGear^.dX - VGear^.X); |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1397 |
VGear^.dY := VGear^.dY + max(LAND_WIDTH,4096) * (VGear^.dY - VGear^.Y); |
5841 | 1398 |
end; |
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1399 |
VGear^.Timer := 200; |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1400 |
end; |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1401 |
end; |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1402 |
|
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1403 |
if i < steps - 1 then |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1404 |
begin |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1405 |
fromX:= toX; |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1406 |
fromY:= toY; |
13341
0c3f612edc19
Partial fix of Pas2C parsing problems (part 1: uGearsHandlersMess)
Wuzzy <Wuzzy2@mail.ru>
parents:
13323
diff
changeset
|
1407 |
bLength:= bLength - stepLength; |
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1408 |
end |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1409 |
end; |
5841 | 1410 |
end; |
1411 |
||
12898 | 1412 |
procedure LineShoveHelp(Gear: PGear; oX, oY, tX, tY, dX, dY: hwFloat; count: LongWord); |
1413 |
var dmg,power: LongInt; |
|
1414 |
begin |
|
13403
9c9d29be9e00
make all bullets function similar to machinegun bullets (can hit/shove objects without checkin)
nemo
parents:
13402
diff
changeset
|
1415 |
if hwSqr(tX - oX) + hwSqr(tY - oY) > _0_25 then |
12898 | 1416 |
begin |
1417 |
if (Gear^.AmmoType = amDEagle) or (Gear^.AmmoType = amMinigun) then |
|
1418 |
dmg:= Gear^.Boom |
|
1419 |
else |
|
1420 |
dmg:= Gear^.Timer * Gear^.Boom div 100000; |
|
1421 |
if (Gear^.AmmoType = amMinigun) then |
|
1422 |
power:= 10 |
|
1423 |
else |
|
1424 |
power:= 20; |
|
1425 |
AmmoShoveLine(Gear, dmg, power, oX, oY, tX, tY); |
|
1426 |
end; |
|
1427 |
if Gear^.Damage > 0 then |
|
1428 |
begin |
|
1429 |
DrawTunnel(oX, oY, dX, dY, count, 1); |
|
1430 |
dec(Gear^.Health, Gear^.Damage); |
|
1431 |
Gear^.Damage := 0 |
|
1432 |
end; |
|
1433 |
end; |
|
1434 |
||
13381 | 1435 |
procedure CheckBulletDrowningHelp(Bullet: PGear); |
1436 |
var dX, dY: hwFloat; |
|
1437 |
begin |
|
1438 |
dX := Bullet^.dX; |
|
1439 |
dY := Bullet^.dY; |
|
1440 |
CheckGearDrowning(Bullet); |
|
1441 |
if (dX <> Bullet^.dX) or (dY <> Bullet^.dY) then |
|
1442 |
begin |
|
1443 |
SpawnBulletTrail(Bullet, Bullet^.X, Bullet^.Y, Bullet^.FlightTime = 0); |
|
1444 |
Bullet^.Elasticity := Bullet^.X; |
|
1445 |
Bullet^.Friction := Bullet^.Y; |
|
1446 |
Inc(Bullet^.PortalCounter); |
|
1447 |
Bullet^.FlightTime:= 1; |
|
1448 |
end; |
|
1449 |
end; |
|
1450 |
||
13408 | 1451 |
procedure CreateBubblesForBullet(Gear: PGear); |
1452 |
var i, iInit: LongWord; |
|
1453 |
begin |
|
14305 | 1454 |
iInit:= 0; |
13408 | 1455 |
if ((Gear^.State and gstDrowning) <> 0) and (Gear^.Health > 0) then |
1456 |
begin |
|
1457 |
// draw bubbles |
|
1458 |
if (not SuddenDeathDmg and (WaterOpacity < $FF)) or (SuddenDeathDmg and (SDWaterOpacity < $FF)) then |
|
1459 |
begin |
|
1460 |
case Gear^.Kind of |
|
1461 |
gtMinigunBullet: iInit:= Gear^.Health * 100; |
|
1462 |
gtDEagleShot, gtSniperRifleShot: iInit:= Gear^.Health * 4 |
|
1463 |
end; |
|
1464 |
for i:=iInit downto 0 do |
|
1465 |
begin |
|
1466 |
if Random(6) = 0 then |
|
1467 |
AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtBubble); |
|
1468 |
Gear^.X := Gear^.X + Gear^.dX; |
|
1469 |
Gear^.Y := Gear^.Y + Gear^.dY; |
|
1470 |
end; |
|
1471 |
end; |
|
1472 |
// bullet dies underwater |
|
1473 |
Gear^.Health:= 0; |
|
1474 |
end; |
|
1475 |
end; |
|
1476 |
||
2023
41d3afaa20c7
Artillery mode, sniper rifle, speech bubble tweaks, fix of rope bug introduced by enabling hats in jump
nemo
parents:
2017
diff
changeset
|
1477 |
procedure doStepBulletWork(Gear: PGear); |
8795 | 1478 |
var |
12377
efa13b925cd8
Fix bullets being reflected too early on bouncy world edge border while digging land
alfadur
parents:
12306
diff
changeset
|
1479 |
i, x, y, iInit: LongWord; |
efa13b925cd8
Fix bullets being reflected too early on bouncy world edge border while digging land
alfadur
parents:
12306
diff
changeset
|
1480 |
oX, oY, tX, tY, tDx, tDy: hwFloat; |
4327 | 1481 |
VGear: PVisualGear; |
12898 | 1482 |
LandFlags: Word; |
1483 |
isDigging: Boolean; |
|
1484 |
isDead: Boolean; |
|
38 | 1485 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1486 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1487 |
inc(Gear^.Timer); |
12898 | 1488 |
iInit := 100; |
12377
efa13b925cd8
Fix bullets being reflected too early on bouncy world edge border while digging land
alfadur
parents:
12306
diff
changeset
|
1489 |
i := iInit; |
12898 | 1490 |
isDigging := false; |
1491 |
isDead := false; |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1492 |
oX := Gear^.X; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1493 |
oY := Gear^.Y; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1494 |
repeat |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1495 |
Gear^.X := Gear^.X + Gear^.dX; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1496 |
Gear^.Y := Gear^.Y + Gear^.dY; |
9485
3dee8a3b0406
add shotgun wrap, revert 100px offset. Problematic w/ things that rely on Land.
nemo
parents:
9479
diff
changeset
|
1497 |
tX:= Gear^.X; |
3dee8a3b0406
add shotgun wrap, revert 100px offset. Problematic w/ things that rely on Land.
nemo
parents:
9479
diff
changeset
|
1498 |
tY:= Gear^.Y; |
12377
efa13b925cd8
Fix bullets being reflected too early on bouncy world edge border while digging land
alfadur
parents:
12306
diff
changeset
|
1499 |
tDx:= Gear^.dX; |
efa13b925cd8
Fix bullets being reflected too early on bouncy world edge border while digging land
alfadur
parents:
12306
diff
changeset
|
1500 |
tDy:= Gear^.dY; |
9565 | 1501 |
if (Gear^.PortalCounter < 30) and WorldWrap(Gear) then |
9485
3dee8a3b0406
add shotgun wrap, revert 100px offset. Problematic w/ things that rely on Land.
nemo
parents:
9479
diff
changeset
|
1502 |
begin |
12898 | 1503 |
LineShoveHelp(Gear, oX, oY, tX, tY, tDx, tDy, iInit + 2 - i); |
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1504 |
SpawnBulletTrail(Gear, tX, tY, Gear^.FlightTime = 0); |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1505 |
Gear^.FlightTime:= 1; |
12377
efa13b925cd8
Fix bullets being reflected too early on bouncy world edge border while digging land
alfadur
parents:
12306
diff
changeset
|
1506 |
iInit:= i; |
efa13b925cd8
Fix bullets being reflected too early on bouncy world edge border while digging land
alfadur
parents:
12306
diff
changeset
|
1507 |
oX:= Gear^.X; |
efa13b925cd8
Fix bullets being reflected too early on bouncy world edge border while digging land
alfadur
parents:
12306
diff
changeset
|
1508 |
oY:= Gear^.Y; |
9485
3dee8a3b0406
add shotgun wrap, revert 100px offset. Problematic w/ things that rely on Land.
nemo
parents:
9479
diff
changeset
|
1509 |
inc(Gear^.PortalCounter); |
3dee8a3b0406
add shotgun wrap, revert 100px offset. Problematic w/ things that rely on Land.
nemo
parents:
9479
diff
changeset
|
1510 |
Gear^.Elasticity:= Gear^.X; |
3dee8a3b0406
add shotgun wrap, revert 100px offset. Problematic w/ things that rely on Land.
nemo
parents:
9479
diff
changeset
|
1511 |
Gear^.Friction:= Gear^.Y; |
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1512 |
SpawnBulletTrail(Gear, Gear^.X, Gear^.Y, false); |
13318
9071600f7b22
Fix minigun bullets hitting shooter when it hits hog on other side of world wrap
alfadur
parents:
13285
diff
changeset
|
1513 |
|
9071600f7b22
Fix minigun bullets hitting shooter when it hits hog on other side of world wrap
alfadur
parents:
13285
diff
changeset
|
1514 |
// bullets can now hurt the hog that fired them |
9071600f7b22
Fix minigun bullets hitting shooter when it hits hog on other side of world wrap
alfadur
parents:
13285
diff
changeset
|
1515 |
if WorldEdge <> weSea then Gear^.Data:= nil; |
9485
3dee8a3b0406
add shotgun wrap, revert 100px offset. Problematic w/ things that rely on Land.
nemo
parents:
9479
diff
changeset
|
1516 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1517 |
x := hwRound(Gear^.X); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1518 |
y := hwRound(Gear^.Y); |
8795 | 1519 |
|
12898 | 1520 |
if ((y and LAND_HEIGHT_MASK) = 0) and ((x and LAND_WIDTH_MASK) = 0) then |
1521 |
begin |
|
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
1522 |
LandFlags:= LandGet(y, x); |
12898 | 1523 |
if LandFlags <> 0 then inc(Gear^.Damage); |
1524 |
isDigging:= (LandFlags and lfLandMask) <> 0; |
|
1525 |
end; |
|
1526 |
// let's interrupt before a collision with land to give portals a chance to catch the bullet |
|
1527 |
if isDigging and (Gear^.Tag = 0) then |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1528 |
begin |
5841 | 1529 |
Gear^.Tag := 1; |
12898 | 1530 |
dec(Gear^.Damage); |
5841 | 1531 |
Gear^.X := Gear^.X - Gear^.dX; |
1532 |
Gear^.Y := Gear^.Y - Gear^.dY; |
|
13381 | 1533 |
CheckBulletDrowningHelp(Gear); |
5841 | 1534 |
break; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1535 |
end |
12898 | 1536 |
else if (not isDigging) then |
5841 | 1537 |
Gear^.Tag := 0; |
1538 |
||
12898 | 1539 |
//Shove static gears to remove the mask and stop damaging the bullet |
1540 |
if (not isDigging) and (Gear^.Damage > 5) and (Gear^.Kind <> gtMinigunBullet) then |
|
1541 |
begin |
|
1542 |
LineShoveHelp(Gear, oX, oY, tX, tY, tDx, tDy, iInit + 2 - i); |
|
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1543 |
SpawnBulletTrail(Gear, tX, tY, Gear^.FlightTime = 0); |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1544 |
Gear^.FlightTime:= 1; |
12898 | 1545 |
iInit:= i; |
1546 |
oX:= Gear^.X; |
|
1547 |
oY:= Gear^.Y; |
|
10125 | 1548 |
end; |
12898 | 1549 |
|
13381 | 1550 |
CheckBulletDrowningHelp(Gear); |
12898 | 1551 |
case Gear^.Kind of |
13357
030b085b182f
real droplet fix - default density is fine - also add back in the underwater bullet trails
nemo
parents:
13341
diff
changeset
|
1552 |
gtMinigunBullet: isDead:= isDigging or ((Gear^.State and gstDrowning) <> 0); |
030b085b182f
real droplet fix - default density is fine - also add back in the underwater bullet trails
nemo
parents:
13341
diff
changeset
|
1553 |
gtDEagleShot, gtSniperRifleShot: isDead:= (Gear^.Damage >= Gear^.Health) or ((Gear^.State and gstDrowning) <> 0) |
12898 | 1554 |
end; |
8795 | 1555 |
dec(i) |
13357
030b085b182f
real droplet fix - default density is fine - also add back in the underwater bullet trails
nemo
parents:
13341
diff
changeset
|
1556 |
until (i = 0) or (isDead); |
12898 | 1557 |
|
1558 |
LineShoveHelp(Gear, oX, oY, Gear^.X, Gear^.Y, |
|
1559 |
Gear^.dX, Gear^.dY, iInit + 2 - i); |
|
10650
7f23971bd9db
fix some old code that assumes that a bullet under water is always outside land array - which is wrong (e.g. during sudden-death in previous releases, also weSea now)
sheepluva
parents:
10645
diff
changeset
|
1560 |
|
13408 | 1561 |
CreateBubblesForBullet(Gear); |
1562 |
||
1563 |
x := hwRound(Gear^.X); |
|
1564 |
y := hwRound(Gear^.Y); |
|
1565 |
if (isDead) or (x and LAND_WIDTH_MASK <> 0) or (y and LAND_HEIGHT_MASK <> 0) then |
|
1566 |
begin |
|
1567 |
if (Gear^.Kind = gtSniperRifleShot) then |
|
1568 |
cLaserSightingSniper := false; |
|
1569 |
if (Ammoz[Gear^.AmmoType].Ammo.NumPerTurn <= CurrentHedgehog^.MultiShootAttacks) and (CurrentHedgehog^.Effects[heArtillery] = 2) then |
|
1570 |
CurrentHedgehog^.Effects[heArtillery]:= 0; |
|
1571 |
||
1572 |
// Bullet Hit |
|
1573 |
if ((Gear^.State and gstDrowning) = 0) and (x and LAND_WIDTH_MASK = 0) and (y and LAND_HEIGHT_MASK = 0) then |
|
1574 |
begin |
|
1575 |
if Gear^.Kind = gtMinigunBullet then |
|
10650
7f23971bd9db
fix some old code that assumes that a bullet under water is always outside land array - which is wrong (e.g. during sudden-death in previous releases, also weSea now)
sheepluva
parents:
10645
diff
changeset
|
1576 |
begin |
15678 | 1577 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Karma, |
14076
82956b3ba2ab
prevent minigun bullet land impacts from pushing hedgehogs
alfadur
parents:
14061
diff
changeset
|
1578 |
Gear^.Hedgehog, (EXPLNoDamage or EXPLDoNotTouchHH){ or EXPLDontDraw or EXPLNoGfx}); |
13408 | 1579 |
VGear := AddVisualGear(hwRound(Gear^.X + Gear^.dX * 5), hwRound(Gear^.Y + Gear^.dY * 5), vgtBulletHit); |
1580 |
end |
|
1581 |
else |
|
1582 |
VGear := AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtBulletHit); |
|
1583 |
||
1584 |
if VGear <> nil then |
|
1585 |
begin |
|
1586 |
VGear^.Angle := DxDy2Angle(-Gear^.dX, Gear^.dY); |
|
10650
7f23971bd9db
fix some old code that assumes that a bullet under water is always outside land array - which is wrong (e.g. during sudden-death in previous releases, also weSea now)
sheepluva
parents:
10645
diff
changeset
|
1587 |
end; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1588 |
end; |
13408 | 1589 |
|
1590 |
spawnBulletTrail(Gear, Gear^.X, Gear^.Y, Gear^.FlightTime = 0); |
|
1591 |
Gear^.FlightTime:= 1; |
|
1592 |
if Gear^.Kind = gtMinigunBullet then |
|
1593 |
ClearHitOrderLeq(Gear^.Tag); |
|
1594 |
||
1595 |
if (worldEdge = weSea) and (Gear^.Kind = gtMinigunBullet) |
|
1596 |
and Gear^.Y.isNegative and Gear^.dY.isNegative |
|
1597 |
and (Gear^.Health > 0) and (not isZero(Gear^.dX)) then |
|
1598 |
begin |
|
1599 |
if Gear^.dX.isNegative then |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1600 |
begin |
13408 | 1601 |
|
1602 |
Gear^.X:= int2hwFloat(-1); |
|
1603 |
iInit:= x - leftX; |
|
1604 |
end |
|
1605 |
else |
|
1606 |
begin |
|
1607 |
Gear^.X:= int2hwFloat(LAND_WIDTH); |
|
1608 |
iInit:= rightX - x - 1; |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1609 |
end; |
13408 | 1610 |
Gear^.Y:= Gear^.Y + Gear^.dY * hwAbs(int2hwFloat(iInit) / Gear^.dX); |
1611 |
CheckGearDrowning(Gear); |
|
1612 |
CreateBubblesForBullet(Gear); |
|
1613 |
end; |
|
1614 |
Gear^.doStep := @doStepShotIdle |
|
1615 |
end; |
|
37 | 1616 |
end; |
1617 |
||
559 | 1618 |
procedure doStepDEagleShot(Gear: PGear); |
1619 |
begin |
|
15663 | 1620 |
if Gear^.Data = nil then |
1621 |
// remember who fired this |
|
1622 |
if (Gear^.Hedgehog <> nil) and (Gear^.Hedgehog^.Gear <> nil) then |
|
1623 |
Gear^.Data:= Pointer(Gear^.Hedgehog^.Gear); |
|
11550
881231c1ba46
disallow bullets to hit the hedgehog that fired them (unless bounced/wrapped/portal'd)
sheepluva
parents:
11540
diff
changeset
|
1624 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1625 |
PlaySound(sndGun); |
13403
9c9d29be9e00
make all bullets function similar to machinegun bullets (can hit/shove objects without checkin)
nemo
parents:
13402
diff
changeset
|
1626 |
ClearHitOrder(); |
11553 | 1627 |
// add 2 initial steps to avoid problem with ammoshove related to calculation of radius + 1 radius as gear widths, and also just plain old weird angles |
11552 | 1628 |
Gear^.X := Gear^.X + Gear^.dX * 2; |
1629 |
Gear^.Y := Gear^.Y + Gear^.dY * 2; |
|
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1630 |
Gear^.FlightTime := 0; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1631 |
Gear^.doStep := @doStepBulletWork |
2023
41d3afaa20c7
Artillery mode, sniper rifle, speech bubble tweaks, fix of rope bug introduced by enabling hats in jump
nemo
parents:
2017
diff
changeset
|
1632 |
end; |
41d3afaa20c7
Artillery mode, sniper rifle, speech bubble tweaks, fix of rope bug introduced by enabling hats in jump
nemo
parents:
2017
diff
changeset
|
1633 |
|
41d3afaa20c7
Artillery mode, sniper rifle, speech bubble tweaks, fix of rope bug introduced by enabling hats in jump
nemo
parents:
2017
diff
changeset
|
1634 |
procedure doStepSniperRifleShot(Gear: PGear); |
12898 | 1635 |
var HHGear: PGear; |
2023
41d3afaa20c7
Artillery mode, sniper rifle, speech bubble tweaks, fix of rope bug introduced by enabling hats in jump
nemo
parents:
2017
diff
changeset
|
1636 |
begin |
11550
881231c1ba46
disallow bullets to hit the hedgehog that fired them (unless bounced/wrapped/portal'd)
sheepluva
parents:
11540
diff
changeset
|
1637 |
|
4365 | 1638 |
HHGear := Gear^.Hedgehog^.Gear; |
13096
d78e65c66573
Add hedgehog effect heArtillery, allows to set per-hedgehog artillery mode
Wuzzy <Wuzzy2@mail.ru>
parents:
13058
diff
changeset
|
1639 |
if (Gear^.Hedgehog^.Effects[heArtillery] <> 1) then |
d78e65c66573
Add hedgehog effect heArtillery, allows to set per-hedgehog artillery mode
Wuzzy <Wuzzy2@mail.ru>
parents:
13058
diff
changeset
|
1640 |
Gear^.Hedgehog^.Effects[heArtillery]:= 2; |
10174 | 1641 |
|
1642 |
if HHGear = nil then |
|
1643 |
begin |
|
1644 |
DeleteGear(gear); |
|
1645 |
exit |
|
1646 |
end; |
|
1647 |
||
11550
881231c1ba46
disallow bullets to hit the hedgehog that fired them (unless bounced/wrapped/portal'd)
sheepluva
parents:
11540
diff
changeset
|
1648 |
// remember who fired this |
881231c1ba46
disallow bullets to hit the hedgehog that fired them (unless bounced/wrapped/portal'd)
sheepluva
parents:
11540
diff
changeset
|
1649 |
Gear^.Data:= Pointer(Gear^.Hedgehog^.Gear); |
881231c1ba46
disallow bullets to hit the hedgehog that fired them (unless bounced/wrapped/portal'd)
sheepluva
parents:
11540
diff
changeset
|
1650 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1651 |
HHGear^.State := HHGear^.State or gstNotKickable; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1652 |
HedgehogChAngle(HHGear); |
12306
cdd884397760
Fix sniper rifle disabling laser sight utility after shooting
Wuzzy <almikes@aol.com>
parents:
12300
diff
changeset
|
1653 |
if cLaserSightingSniper = false then |
cdd884397760
Fix sniper rifle disabling laser sight utility after shooting
Wuzzy <almikes@aol.com>
parents:
12300
diff
changeset
|
1654 |
// Turn sniper's laser sight on and give it a chance to aim |
cdd884397760
Fix sniper rifle disabling laser sight utility after shooting
Wuzzy <almikes@aol.com>
parents:
12300
diff
changeset
|
1655 |
begin |
cdd884397760
Fix sniper rifle disabling laser sight utility after shooting
Wuzzy <almikes@aol.com>
parents:
12300
diff
changeset
|
1656 |
cLaserSightingSniper := true; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1657 |
HHGear^.Message := 0; |
7066
12cc2bd84b0b
Make pas2c even more happier with uGears.c, allow assigning arrays in some cases
unc0rr
parents:
7062
diff
changeset
|
1658 |
if (HHGear^.Angle >= 32) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1659 |
dec(HHGear^.Angle,32) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1660 |
end; |
2031
b6f3e56fb100
david_ac's game scheme options for mine delay/quantity, tweaks to sniper rifle
nemo
parents:
2029
diff
changeset
|
1661 |
|
3894 | 1662 |
if (HHGear^.Message and gmAttack) <> 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1663 |
begin |
13147
7040506c831f
Fix direction of dispensed bullet shells from shotgun/sniper/minigun
alfadur
parents:
13140
diff
changeset
|
1664 |
CreateShellForGear(Gear, 1); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1665 |
Gear^.State := Gear^.State or gstAnimation; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1666 |
Gear^.dX := SignAs(AngleSin(HHGear^.Angle), HHGear^.dX) * _0_5; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1667 |
Gear^.dY := -AngleCos(HHGear^.Angle) * _0_5; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1668 |
PlaySound(sndGun); |
13403
9c9d29be9e00
make all bullets function similar to machinegun bullets (can hit/shove objects without checkin)
nemo
parents:
13402
diff
changeset
|
1669 |
ClearHitOrder(); |
11553 | 1670 |
// add 2 initial steps to avoid problem with ammoshove related to calculation of radius + 1 radius as gear widths, and also just weird angles |
1671 |
Gear^.X := Gear^.X + Gear^.dX * 2; |
|
1672 |
Gear^.Y := Gear^.Y + Gear^.dY * 2; |
|
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
1673 |
Gear^.FlightTime := 0; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1674 |
Gear^.doStep := @doStepBulletWork; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1675 |
end |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1676 |
else |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1677 |
if (GameTicks mod 32) = 0 then |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1678 |
if (GameTicks mod 4096) < 2048 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1679 |
begin |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1680 |
if (HHGear^.Angle + 1 <= cMaxAngle) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1681 |
inc(HHGear^.Angle) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1682 |
end |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1683 |
else |
7066
12cc2bd84b0b
Make pas2c even more happier with uGears.c, allow assigning arrays in some cases
unc0rr
parents:
7062
diff
changeset
|
1684 |
if (HHGear^.Angle >= 1) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1685 |
dec(HHGear^.Angle); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1686 |
|
11918
9da78300c5d0
Fix sniper rifle making timer gray all the time
Wuzzy <almikes@aol.com>
parents:
11915
diff
changeset
|
1687 |
if (TurnTimeLeft = 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1688 |
begin |
10831
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
1689 |
HHGear^.State := HHGear^.State and (not gstNotKickable); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1690 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1691 |
AfterAttack |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1692 |
end; |
559 | 1693 |
end; |
1694 |
||
37 | 1695 |
//////////////////////////////////////////////////////////////////////////////// |
4 | 1696 |
procedure doStepActionTimer(Gear: PGear); |
1697 |
begin |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1698 |
dec(Gear^.Timer); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1699 |
case Gear^.Kind of |
8795 | 1700 |
gtATStartGame: |
8679 | 1701 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1702 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1703 |
if Gear^.Timer = 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1704 |
begin |
13642
3d14950641a4
Refactor text color variable names, export 2 color values to Lua
Wuzzy <Wuzzy2@mail.ru>
parents:
13640
diff
changeset
|
1705 |
AddCaption(GetEventString(eidRoundStart), capcolDefault, capgrpGameState); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1706 |
end |
8679 | 1707 |
end; |
8795 | 1708 |
gtATFinishGame: |
8679 | 1709 |
begin |
5368
a66d5141a3ba
fix build. seems like a indentation-related merge-oopsy dragged deleted code back in.
sheepluva
parents:
5366
diff
changeset
|
1710 |
AllInactive := false; |
a66d5141a3ba
fix build. seems like a indentation-related merge-oopsy dragged deleted code back in.
sheepluva
parents:
5366
diff
changeset
|
1711 |
if Gear^.Timer = 1000 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1712 |
begin |
5368
a66d5141a3ba
fix build. seems like a indentation-related merge-oopsy dragged deleted code back in.
sheepluva
parents:
5366
diff
changeset
|
1713 |
ScreenFade := sfToBlack; |
a66d5141a3ba
fix build. seems like a indentation-related merge-oopsy dragged deleted code back in.
sheepluva
parents:
5366
diff
changeset
|
1714 |
ScreenFadeValue := 0; |
a66d5141a3ba
fix build. seems like a indentation-related merge-oopsy dragged deleted code back in.
sheepluva
parents:
5366
diff
changeset
|
1715 |
ScreenFadeSpeed := 1; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1716 |
end; |
5368
a66d5141a3ba
fix build. seems like a indentation-related merge-oopsy dragged deleted code back in.
sheepluva
parents:
5366
diff
changeset
|
1717 |
if Gear^.Timer = 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1718 |
begin |
7068 | 1719 |
SendIPC(_S'N'); |
15299
16f389fcd462
Prevent saving of demo after /lua command was used
Wuzzy <Wuzzy2@mail.ru>
parents:
15274
diff
changeset
|
1720 |
if (luaCmdUsed) then |
16f389fcd462
Prevent saving of demo after /lua command was used
Wuzzy <Wuzzy2@mail.ru>
parents:
15274
diff
changeset
|
1721 |
SendIPC(_S'm'); |
7068 | 1722 |
SendIPC(_S'q'); |
5368
a66d5141a3ba
fix build. seems like a indentation-related merge-oopsy dragged deleted code back in.
sheepluva
parents:
5366
diff
changeset
|
1723 |
GameState := gsExit |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1724 |
end |
8679 | 1725 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1726 |
end; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1727 |
if Gear^.Timer = 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1728 |
DeleteGear(Gear) |
4 | 1729 |
end; |
1730 |
||
1731 |
//////////////////////////////////////////////////////////////////////////////// |
|
1732 |
procedure doStepPickHammerWork(Gear: PGear); |
|
8795 | 1733 |
var |
4578 | 1734 |
i, ei, x, y: LongInt; |
4 | 1735 |
HHGear: PGear; |
1736 |
begin |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1737 |
AllInactive := false; |
9487
fbe203c1d11e
couple more wrap calls. freezer still doesn't propagate properly. mostly due to
nemo
parents:
9485
diff
changeset
|
1738 |
WorldWrap(Gear); |
4365 | 1739 |
HHGear := Gear^.Hedgehog^.Gear; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1740 |
dec(Gear^.Timer); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1741 |
if (TurnTimeLeft = 0) or (Gear^.Timer = 0) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1742 |
or((Gear^.Message and gmDestroy) <> 0) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1743 |
or((HHGear^.State and gstHHDriven) =0) then |
4578 | 1744 |
begin |
7053 | 1745 |
StopSoundChan(Gear^.SoundChannel); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1746 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1747 |
AfterAttack; |
3954
ae3583ad6ea9
Hopefully fix the last of the more obvious weapon bugs w/ infinite attack mode, add a depixeling sweep every 5s too.
nemo
parents:
3953
diff
changeset
|
1748 |
doStepHedgehogMoving(HHGear); // for gfInfAttack |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1749 |
exit |
4578 | 1750 |
end; |
1751 |
||
1752 |
x:= hwRound(Gear^.X); |
|
1753 |
y:= hwRound(Gear^.Y); |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1754 |
if (Gear^.Timer mod 33) = 0 then |
4578 | 1755 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1756 |
HHGear^.State := HHGear^.State or gstNoDamage; |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
1757 |
doMakeExplosion(x, y + 7, Gear^.Boom, Gear^.Hedgehog, EXPLDontDraw); |
6450 | 1758 |
HHGear^.State := HHGear^.State and (not gstNoDamage) |
4578 | 1759 |
end; |
422 | 1760 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1761 |
if (Gear^.Timer mod 47) = 0 then |
4578 | 1762 |
begin |
1763 |
// ok. this was an attempt to turn off dust if not actually drilling land. I have no idea why it isn't working as expected |
|
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
1764 |
if (( (y + 12) and LAND_HEIGHT_MASK) = 0) and ((x and LAND_WIDTH_MASK) = 0) and (LandGet(y + 12, x) > 255) then |
4578 | 1765 |
for i:= 0 to 1 do |
1766 |
AddVisualGear(x - 5 + Random(10), y + 12, vgtDust); |
|
1767 |
||
1768 |
i := x - Gear^.Radius - LongInt(GetRandom(2)); |
|
1769 |
ei := x + Gear^.Radius + LongInt(GetRandom(2)); |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1770 |
while i <= ei do |
4578 | 1771 |
begin |
13604
73b096e1d895
Fix hammer/pickhammer not digging land with gfSolidLand on
Wuzzy <Wuzzy2@mail.ru>
parents:
13603
diff
changeset
|
1772 |
doMakeExplosion(i, y + 3, 3, Gear^.Hedgehog, EXPLNoDamage or EXPLDoNotTouchAny or EXPLNoGfx or EXPLForceDraw); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1773 |
inc(i, 1) |
4578 | 1774 |
end; |
2331
e4941a7986d6
Another try at keeping blowtorch/firepunch/jackhammer from going through indestructible stuff. Shame these routines don't use hedgehog movement
nemo
parents:
2329
diff
changeset
|
1775 |
|
6314 | 1776 |
if CheckLandValue(hwRound(Gear^.X + Gear^.dX + SignAs(_6,Gear^.dX)), hwRound(Gear^.Y + _1_9), lfIndestructible) then |
4578 | 1777 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1778 |
Gear^.X := Gear^.X + Gear^.dX; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1779 |
Gear^.Y := Gear^.Y + _1_9; |
4578 | 1780 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1781 |
SetAllHHToActive; |
4578 | 1782 |
end; |
6081
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
1783 |
if TestCollisionYwithGear(Gear, 1) <> 0 then |
4578 | 1784 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1785 |
Gear^.dY := _0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1786 |
SetLittle(HHGear^.dX); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1787 |
HHGear^.dY := _0; |
4578 | 1788 |
end |
11020
2aa09da8f3ef
fix pickhammer collision when moving upwards, thanks to MK for reporting
sheepluva
parents:
10993
diff
changeset
|
1789 |
else if Gear^.dY.isNegative and (TestCollisionYwithGear(HHGear, -1) <> 0) then |
2aa09da8f3ef
fix pickhammer collision when moving upwards, thanks to MK for reporting
sheepluva
parents:
10993
diff
changeset
|
1790 |
begin |
2aa09da8f3ef
fix pickhammer collision when moving upwards, thanks to MK for reporting
sheepluva
parents:
10993
diff
changeset
|
1791 |
Gear^.dY := cGravity; |
2aa09da8f3ef
fix pickhammer collision when moving upwards, thanks to MK for reporting
sheepluva
parents:
10993
diff
changeset
|
1792 |
HHGear^.dY := cGravity; |
2aa09da8f3ef
fix pickhammer collision when moving upwards, thanks to MK for reporting
sheepluva
parents:
10993
diff
changeset
|
1793 |
end |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1794 |
else |
4578 | 1795 |
begin |
8751
4609823efc94
More flagging of Land values. Also use less than for tests of non-terrain, instead of "and $FF00 = 0". Saves a couple of ops, which actually matters a small amount in a few places.
nemo
parents:
8744
diff
changeset
|
1796 |
if CheckLandValue(hwRound(Gear^.X), hwRound(Gear^.Y + Gear^.dY + cGravity), lfLandMask) then |
6314 | 1797 |
begin |
1798 |
Gear^.dY := Gear^.dY + cGravity; |
|
1799 |
Gear^.Y := Gear^.Y + Gear^.dY |
|
1800 |
end; |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1801 |
if hwRound(Gear^.Y) > cWaterLine then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1802 |
Gear^.Timer := 1 |
4578 | 1803 |
end; |
4 | 1804 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1805 |
Gear^.X := Gear^.X + HHGear^.dX; |
8751
4609823efc94
More flagging of Land values. Also use less than for tests of non-terrain, instead of "and $FF00 = 0". Saves a couple of ops, which actually matters a small amount in a few places.
nemo
parents:
8744
diff
changeset
|
1806 |
if CheckLandValue(hwRound(Gear^.X), hwRound(Gear^.Y)-cHHRadius, lfLandMask) then |
6314 | 1807 |
begin |
1808 |
HHGear^.X := Gear^.X; |
|
1809 |
HHGear^.Y := Gear^.Y - int2hwFloat(cHHRadius) |
|
1810 |
end; |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1811 |
|
3894 | 1812 |
if (Gear^.Message and gmAttack) <> 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1813 |
if (Gear^.State and gsttmpFlag) <> 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1814 |
Gear^.Timer := 1 |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1815 |
else //there would be a mistake. |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1816 |
else |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1817 |
if (Gear^.State and gsttmpFlag) = 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1818 |
Gear^.State := Gear^.State or gsttmpFlag; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1819 |
if ((Gear^.Message and gmLeft) <> 0) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1820 |
Gear^.dX := - _0_3 |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1821 |
else |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1822 |
if ((Gear^.Message and gmRight) <> 0) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1823 |
Gear^.dX := _0_3 |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1824 |
else Gear^.dX := _0; |
4 | 1825 |
end; |
1826 |
||
1827 |
procedure doStepPickHammer(Gear: PGear); |
|
8795 | 1828 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1829 |
i, y: LongInt; |
4 | 1830 |
ar: TRangeArray; |
911
b709fe13ed69
Fix issue with hedgehog on top of the hedgehog with pickhammer
unc0rr
parents:
883
diff
changeset
|
1831 |
HHGear: PGear; |
4 | 1832 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1833 |
i := 0; |
4365 | 1834 |
HHGear := Gear^.Hedgehog^.Gear; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1835 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1836 |
y := hwRound(Gear^.Y) - cHHRadius * 2; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1837 |
while y < hwRound(Gear^.Y) do |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1838 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1839 |
ar[i].Left := hwRound(Gear^.X) - Gear^.Radius - LongInt(GetRandom(2)); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1840 |
ar[i].Right := hwRound(Gear^.X) + Gear^.Radius + LongInt(GetRandom(2)); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1841 |
inc(y, 2); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1842 |
inc(i) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1843 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1844 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1845 |
DrawHLinesExplosions(@ar, 3, hwRound(Gear^.Y) - cHHRadius * 2, 2, Pred(i)); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1846 |
Gear^.dY := HHGear^.dY; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1847 |
DeleteCI(HHGear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1848 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1849 |
Gear^.SoundChannel := LoopSound(sndPickhammer); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1850 |
doStepPickHammerWork(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1851 |
Gear^.doStep := @doStepPickHammerWork |
4 | 1852 |
end; |
1853 |
||
1854 |
//////////////////////////////////////////////////////////////////////////////// |
|
8795 | 1855 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1856 |
BTPrevAngle, BTSteps: LongInt; |
302 | 1857 |
|
303
1659c4aad5ab
Now blow torch angle can be changed during blowing :)
unc0rr
parents:
302
diff
changeset
|
1858 |
procedure doStepBlowTorchWork(Gear: PGear); |
8795 | 1859 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1860 |
HHGear: PGear; |
15618 | 1861 |
dig, hit: boolean; |
15841 | 1862 |
newX, newY: hwFloat; |
302 | 1863 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1864 |
AllInactive := false; |
14358 | 1865 |
WorldWrap(Gear); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1866 |
dec(Gear^.Timer); |
8795 | 1867 |
|
9385 | 1868 |
if Gear^.Hedgehog^.Gear = nil then |
1869 |
begin |
|
15618 | 1870 |
ClearProximityCache(); |
11911
6145efcff302
Add sounds for blowtorch, invuln., f. saucer, lasersight, portal gun
Wuzzy <almikes@aol.com>
parents:
11860
diff
changeset
|
1871 |
StopSoundChan(Gear^.SoundChannel); |
9385 | 1872 |
DeleteGear(Gear); |
1873 |
AfterAttack; |
|
1874 |
exit |
|
1875 |
end; |
|
1876 |
||
4365 | 1877 |
HHGear := Gear^.Hedgehog^.Gear; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1878 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1879 |
HedgehogChAngle(HHGear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1880 |
|
15617 | 1881 |
dig := false; |
15618 | 1882 |
hit := false; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1883 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1884 |
if abs(LongInt(HHGear^.Angle) - BTPrevAngle) > 7 then |
5706 | 1885 |
begin |
5722
3b7f2bfc8632
Keep blowtorch direction (doesn't actually fix the bug with hedgehog turning opposite direction)
unc0rr
parents:
5716
diff
changeset
|
1886 |
Gear^.dX := SignAs(AngleSin(HHGear^.Angle) * _0_5, Gear^.dX); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1887 |
Gear^.dY := AngleCos(HHGear^.Angle) * ( - _0_5); |
15643 | 1888 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1889 |
BTPrevAngle := HHGear^.Angle; |
15617 | 1890 |
dig := true |
5706 | 1891 |
end; |
1528 | 1892 |
|
15841 | 1893 |
if (HHGear^.State and gstMoving) <> 0 then |
5706 | 1894 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1895 |
doStepHedgehogMoving(HHGear); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1896 |
if (HHGear^.State and gstHHDriven) = 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1897 |
Gear^.Timer := 0 |
5706 | 1898 |
end; |
305 | 1899 |
|
15618 | 1900 |
if Gear^.Timer mod 1500 = 0 then |
1901 |
RefillProximityCache(Gear, 200); |
|
1902 |
||
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1903 |
if Gear^.Timer mod cHHStepTicks = 0 then |
5706 | 1904 |
begin |
15617 | 1905 |
dig := true; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1906 |
if Gear^.dX.isNegative then |
3894 | 1907 |
HHGear^.Message := (HHGear^.Message and (gmAttack or gmUp or gmDown)) or gmLeft |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1908 |
else |
3894 | 1909 |
HHGear^.Message := (HHGear^.Message and (gmAttack or gmUp or gmDown)) or gmRight; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1910 |
|
15841 | 1911 |
if (HHGear^.State and gstMoving) = 0 then |
5706 | 1912 |
begin |
6450 | 1913 |
HHGear^.State := HHGear^.State and (not gstAttacking); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1914 |
|
15841 | 1915 |
if CheckLandValue(hwRound(HHGear^.X + SignAs(_6, HHGear^.dX)), hwRound(HHGear^.Y), lfIndestructible) then |
15617 | 1916 |
HedgehogStep(HHGear); |
1917 |
||
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1918 |
HHGear^.State := HHGear^.State or gstAttacking |
5706 | 1919 |
end; |
305 | 1920 |
|
15841 | 1921 |
newX := HHGear^.X + Gear^.dX * (cHHRadius + cBlowTorchC); |
1922 |
newY := HHGear^.Y + Gear^.dY * (cHHRadius + cBlowTorchC); |
|
1923 |
if CheckLandValue(hwRound(newX + SignAs(_6, Gear^.dX)), hwRound(newY), lfIndestructible) then |
|
1924 |
begin |
|
1925 |
Gear^.X := newX; |
|
1926 |
Gear^.Y := newY; |
|
1927 |
end; |
|
1928 |
||
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1929 |
inc(BTSteps); |
15866 | 1930 |
if BTSteps = 11 then |
5706 | 1931 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1932 |
BTSteps := 0; |
15618 | 1933 |
hit := true |
5706 | 1934 |
end; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
1935 |
end; |
305 | 1936 |
|
15617 | 1937 |
if dig then |
9385 | 1938 |
begin |
6278
654eed7c6b97
tweak DrawTunnel call of blowtorch. should fix issues with blowtorch going horizontal when it shouldn't
sheepluva
parents:
6251
diff
changeset
|
1939 |
DrawTunnel(HHGear^.X + Gear^.dX * cHHRadius, |
15618 | 1940 |
HHGear^.Y + Gear^.dY * cHHRadius - _1 - |
1941 |
((hwAbs(Gear^.dX) / (hwAbs(Gear^.dX) + hwAbs(Gear^.dY))) * _0_5 * 7), |
|
1942 |
Gear^.dX, Gear^.dY, |
|
1943 |
cHHStepTicks, cHHRadius * 2 + 7); |
|
1944 |
||
1945 |
HHGear^.State := HHGear^.State or gstNoDamage; |
|
1946 |
if hit then |
|
1947 |
AmmoShoveCache(Gear, Gear^.Boom, 15) |
|
1948 |
else |
|
1949 |
AmmoShoveCache(Gear, 0, 15); |
|
1950 |
HHGear^.State := HHGear^.State and (not gstNoDamage); |
|
9385 | 1951 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1952 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1953 |
if (TurnTimeLeft = 0) or (Gear^.Timer = 0) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1954 |
or ((HHGear^.Message and gmAttack) <> 0) then |
5706 | 1955 |
begin |
15618 | 1956 |
ClearProximityCache(); |
11911
6145efcff302
Add sounds for blowtorch, invuln., f. saucer, lasersight, portal gun
Wuzzy <almikes@aol.com>
parents:
11860
diff
changeset
|
1957 |
StopSoundChan(Gear^.SoundChannel); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1958 |
HHGear^.Message := 0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1959 |
HHGear^.State := HHGear^.State and (not gstNotKickable); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1960 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1961 |
AfterAttack |
5706 | 1962 |
end |
302 | 1963 |
end; |
1964 |
||
303
1659c4aad5ab
Now blow torch angle can be changed during blowing :)
unc0rr
parents:
302
diff
changeset
|
1965 |
procedure doStepBlowTorch(Gear: PGear); |
8795 | 1966 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1967 |
HHGear: PGear; |
303
1659c4aad5ab
Now blow torch angle can be changed during blowing :)
unc0rr
parents:
302
diff
changeset
|
1968 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1969 |
BTPrevAngle := High(LongInt); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1970 |
BTSteps := 0; |
4365 | 1971 |
HHGear := Gear^.Hedgehog^.Gear; |
8617
e7bea88096d2
So. A while ago, while trying to prevent hogs blowtorching getting turned around, unc0rr altered the old range of blowtorch from 1/8th of 180° up or down, to a 4° gain in upwards and a -4° loss in downwards. He also made it so that starting tunnels could fail to erase sufficient terrain, trapping hogs. Here are a couple of workarounds to more closely approximate old behaviour (do some initial erasure, adjust min/max angles)
nemo
parents:
8612
diff
changeset
|
1972 |
HedgehogChAngle(HHGear); |
e7bea88096d2
So. A while ago, while trying to prevent hogs blowtorching getting turned around, unc0rr altered the old range of blowtorch from 1/8th of 180° up or down, to a 4° gain in upwards and a -4° loss in downwards. He also made it so that starting tunnels could fail to erase sufficient terrain, trapping hogs. Here are a couple of workarounds to more closely approximate old behaviour (do some initial erasure, adjust min/max angles)
nemo
parents:
8612
diff
changeset
|
1973 |
Gear^.dX := SignAs(AngleSin(HHGear^.Angle) * _0_5, Gear^.dX); |
e7bea88096d2
So. A while ago, while trying to prevent hogs blowtorching getting turned around, unc0rr altered the old range of blowtorch from 1/8th of 180° up or down, to a 4° gain in upwards and a -4° loss in downwards. He also made it so that starting tunnels could fail to erase sufficient terrain, trapping hogs. Here are a couple of workarounds to more closely approximate old behaviour (do some initial erasure, adjust min/max angles)
nemo
parents:
8612
diff
changeset
|
1974 |
Gear^.dY := AngleCos(HHGear^.Angle) * ( - _0_5); |
e7bea88096d2
So. A while ago, while trying to prevent hogs blowtorching getting turned around, unc0rr altered the old range of blowtorch from 1/8th of 180° up or down, to a 4° gain in upwards and a -4° loss in downwards. He also made it so that starting tunnels could fail to erase sufficient terrain, trapping hogs. Here are a couple of workarounds to more closely approximate old behaviour (do some initial erasure, adjust min/max angles)
nemo
parents:
8612
diff
changeset
|
1975 |
DrawTunnel(HHGear^.X, |
e7bea88096d2
So. A while ago, while trying to prevent hogs blowtorching getting turned around, unc0rr altered the old range of blowtorch from 1/8th of 180° up or down, to a 4° gain in upwards and a -4° loss in downwards. He also made it so that starting tunnels could fail to erase sufficient terrain, trapping hogs. Here are a couple of workarounds to more closely approximate old behaviour (do some initial erasure, adjust min/max angles)
nemo
parents:
8612
diff
changeset
|
1976 |
HHGear^.Y + Gear^.dY * cHHRadius - _1 - |
e7bea88096d2
So. A while ago, while trying to prevent hogs blowtorching getting turned around, unc0rr altered the old range of blowtorch from 1/8th of 180° up or down, to a 4° gain in upwards and a -4° loss in downwards. He also made it so that starting tunnels could fail to erase sufficient terrain, trapping hogs. Here are a couple of workarounds to more closely approximate old behaviour (do some initial erasure, adjust min/max angles)
nemo
parents:
8612
diff
changeset
|
1977 |
((hwAbs(Gear^.dX) / (hwAbs(Gear^.dX) + hwAbs(Gear^.dY))) * _0_5 * 7), |
e7bea88096d2
So. A while ago, while trying to prevent hogs blowtorching getting turned around, unc0rr altered the old range of blowtorch from 1/8th of 180° up or down, to a 4° gain in upwards and a -4° loss in downwards. He also made it so that starting tunnels could fail to erase sufficient terrain, trapping hogs. Here are a couple of workarounds to more closely approximate old behaviour (do some initial erasure, adjust min/max angles)
nemo
parents:
8612
diff
changeset
|
1978 |
Gear^.dX, Gear^.dY, |
e7bea88096d2
So. A while ago, while trying to prevent hogs blowtorching getting turned around, unc0rr altered the old range of blowtorch from 1/8th of 180° up or down, to a 4° gain in upwards and a -4° loss in downwards. He also made it so that starting tunnels could fail to erase sufficient terrain, trapping hogs. Here are a couple of workarounds to more closely approximate old behaviour (do some initial erasure, adjust min/max angles)
nemo
parents:
8612
diff
changeset
|
1979 |
cHHStepTicks, cHHRadius * 2 + 7); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1980 |
HHGear^.Message := 0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1981 |
HHGear^.State := HHGear^.State or gstNotKickable; |
15618 | 1982 |
RefillProximityCache(Gear, 200); |
15643 | 1983 |
|
11911
6145efcff302
Add sounds for blowtorch, invuln., f. saucer, lasersight, portal gun
Wuzzy <almikes@aol.com>
parents:
11860
diff
changeset
|
1984 |
Gear^.SoundChannel := LoopSound(sndBlowTorch); |
14358 | 1985 |
Gear^.doStep := @doStepBlowTorchWork |
303
1659c4aad5ab
Now blow torch angle can be changed during blowing :)
unc0rr
parents:
302
diff
changeset
|
1986 |
end; |
1659c4aad5ab
Now blow torch angle can be changed during blowing :)
unc0rr
parents:
302
diff
changeset
|
1987 |
|
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
1988 |
|
302 | 1989 |
//////////////////////////////////////////////////////////////////////////////// |
10 | 1990 |
procedure doStepMine(Gear: PGear); |
5690
f6e0c5bd8020
Allow vgtSmoke to scale. Scale it down 50% for mines, so smoke doesn't seem so oversized
nemo
parents:
5688
diff
changeset
|
1991 |
var vg: PVisualGear; |
8958
3818b38d72c0
simplify mine/explosive damage calc. clear dX in stable explosives. remove 0/4096 in trace routines.
nemo
parents:
8952
diff
changeset
|
1992 |
dxdy: hwFloat; |
10679
5989c293955a
add a couple of onGearDamage callbacks to mine/barrel fall damage
nemo
parents:
10676
diff
changeset
|
1993 |
dmg: LongWord; |
10 | 1994 |
begin |
9043 | 1995 |
if Gear^.Health = 0 then dxdy:= hwAbs(Gear^.dX)+hwAbs(Gear^.dY); |
14771
ab7bf5036314
Render mine timer if gear info is active
Wuzzy <Wuzzy2@mail.ru>
parents:
14770
diff
changeset
|
1996 |
Gear^.RenderTimer:= ((Gear^.State and gstFrozen) = 0) and ((Gear^.State and gstAttacking) = 0) and (Gear^.Health <> 0); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1997 |
if (Gear^.State and gstMoving) <> 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
1998 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
1999 |
DeleteCI(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2000 |
doStepFallingGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2001 |
if (Gear^.State and gstMoving) = 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2002 |
begin |
9291
15f7bb217b66
Make add/delete consistent (this has bugged me for so long)
nemo
parents:
9289
diff
changeset
|
2003 |
AddCI(Gear); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2004 |
Gear^.dX := _0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2005 |
Gear^.dY := _0 |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2006 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2007 |
CalcRotationDirAngle(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2008 |
AllInactive := false |
7754 | 2009 |
end |
2010 |
else if (GameTicks and $3F) = 25 then |
|
2011 |
doStepFallingGear(Gear); |
|
4966
fa612a614317
make defective mines explode if they take enough damage, add missing interface line for koda's new uSound fade
nemo
parents:
4956
diff
changeset
|
2012 |
if (Gear^.Health = 0) then |
fa612a614317
make defective mines explode if they take enough damage, add missing interface line for koda's new uSound fade
nemo
parents:
4956
diff
changeset
|
2013 |
begin |
8971
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2014 |
if (dxdy > _0_4) and (Gear^.State and gstCollision <> 0) then |
10679
5989c293955a
add a couple of onGearDamage callbacks to mine/barrel fall damage
nemo
parents:
10676
diff
changeset
|
2015 |
begin |
5989c293955a
add a couple of onGearDamage callbacks to mine/barrel fall damage
nemo
parents:
10676
diff
changeset
|
2016 |
dmg:= hwRound(dxdy * _50); |
5989c293955a
add a couple of onGearDamage callbacks to mine/barrel fall damage
nemo
parents:
10676
diff
changeset
|
2017 |
inc(Gear^.Damage, dmg); |
5989c293955a
add a couple of onGearDamage callbacks to mine/barrel fall damage
nemo
parents:
10676
diff
changeset
|
2018 |
ScriptCall('onGearDamage', Gear^.UID, dmg) |
5989c293955a
add a couple of onGearDamage callbacks to mine/barrel fall damage
nemo
parents:
10676
diff
changeset
|
2019 |
end; |
8795 | 2020 |
|
6498 | 2021 |
if ((GameTicks and $FF) = 0) and (Gear^.Damage > random(30)) then |
7754 | 2022 |
begin |
2023 |
vg:= AddVisualGear(hwRound(Gear^.X) - 4 + Random(8), hwRound(Gear^.Y) - 4 - Random(4), vgtSmoke); |
|
2024 |
if vg <> nil then |
|
2025 |
vg^.Scale:= 0.5 |
|
2026 |
end; |
|
4966
fa612a614317
make defective mines explode if they take enough damage, add missing interface line for koda's new uSound fade
nemo
parents:
4956
diff
changeset
|
2027 |
|
fa612a614317
make defective mines explode if they take enough damage, add missing interface line for koda's new uSound fade
nemo
parents:
4956
diff
changeset
|
2028 |
if (Gear^.Damage > 35) then |
fa612a614317
make defective mines explode if they take enough damage, add missing interface line for koda's new uSound fade
nemo
parents:
4956
diff
changeset
|
2029 |
begin |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
2030 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
4966
fa612a614317
make defective mines explode if they take enough damage, add missing interface line for koda's new uSound fade
nemo
parents:
4956
diff
changeset
|
2031 |
DeleteGear(Gear); |
fa612a614317
make defective mines explode if they take enough damage, add missing interface line for koda's new uSound fade
nemo
parents:
4956
diff
changeset
|
2032 |
exit |
fa612a614317
make defective mines explode if they take enough damage, add missing interface line for koda's new uSound fade
nemo
parents:
4956
diff
changeset
|
2033 |
end |
fa612a614317
make defective mines explode if they take enough damage, add missing interface line for koda's new uSound fade
nemo
parents:
4956
diff
changeset
|
2034 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2035 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2036 |
if ((Gear^.State and gsttmpFlag) <> 0) and (Gear^.Health <> 0) then |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2037 |
if ((Gear^.State and gstAttacking) = 0) then |
4224
99c6d87df131
No point in leaving hogs at 0, since shotgun triggers death anyway. Also, add some audio cues to extra damage / time
nemo
parents:
4187
diff
changeset
|
2038 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2039 |
if ((GameTicks and $1F) = 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2040 |
if CheckGearNear(Gear, gtHedgehog, 46, 32) <> nil then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2041 |
Gear^.State := Gear^.State or gstAttacking |
4224
99c6d87df131
No point in leaving hogs at 0, since shotgun triggers death anyway. Also, add some audio cues to extra damage / time
nemo
parents:
4187
diff
changeset
|
2042 |
end |
99c6d87df131
No point in leaving hogs at 0, since shotgun triggers death anyway. Also, add some audio cues to extra damage / time
nemo
parents:
4187
diff
changeset
|
2043 |
else // gstAttacking <> 0 |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2044 |
begin |
4224
99c6d87df131
No point in leaving hogs at 0, since shotgun triggers death anyway. Also, add some audio cues to extra damage / time
nemo
parents:
4187
diff
changeset
|
2045 |
AllInactive := false; |
12171
115867d77982
Add back accidental removal of random mines
Wuzzy <almikes@aol.com>
parents:
12169
diff
changeset
|
2046 |
// tag of 1 means this mine has a random timer |
115867d77982
Add back accidental removal of random mines
Wuzzy <almikes@aol.com>
parents:
12169
diff
changeset
|
2047 |
if (Gear^.Tag = 1) and (Gear^.Timer = 0) then |
115867d77982
Add back accidental removal of random mines
Wuzzy <almikes@aol.com>
parents:
12169
diff
changeset
|
2048 |
begin |
115867d77982
Add back accidental removal of random mines
Wuzzy <almikes@aol.com>
parents:
12169
diff
changeset
|
2049 |
if (GameTicks mod 2 = 0) then GetRandom(2); |
115867d77982
Add back accidental removal of random mines
Wuzzy <almikes@aol.com>
parents:
12169
diff
changeset
|
2050 |
if (GameTicks mod 3 = 0) then GetRandom(2); |
115867d77982
Add back accidental removal of random mines
Wuzzy <almikes@aol.com>
parents:
12169
diff
changeset
|
2051 |
Gear^.Timer:= GetRandom(51) * 100; |
115867d77982
Add back accidental removal of random mines
Wuzzy <almikes@aol.com>
parents:
12169
diff
changeset
|
2052 |
Gear^.Tag:= 0; |
115867d77982
Add back accidental removal of random mines
Wuzzy <almikes@aol.com>
parents:
12169
diff
changeset
|
2053 |
end; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2054 |
if (Gear^.Timer and $FF) = 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2055 |
PlaySound(sndMineTick); |
4224
99c6d87df131
No point in leaving hogs at 0, since shotgun triggers death anyway. Also, add some audio cues to extra damage / time
nemo
parents:
4187
diff
changeset
|
2056 |
if Gear^.Timer = 0 then |
99c6d87df131
No point in leaving hogs at 0, since shotgun triggers death anyway. Also, add some audio cues to extra damage / time
nemo
parents:
4187
diff
changeset
|
2057 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2058 |
if ((Gear^.State and gstWait) <> 0) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2059 |
or (cMineDudPercent = 0) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2060 |
or (getRandom(100) > cMineDudPercent) then |
4224
99c6d87df131
No point in leaving hogs at 0, since shotgun triggers death anyway. Also, add some audio cues to extra damage / time
nemo
parents:
4187
diff
changeset
|
2061 |
begin |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
2062 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
14575 | 2063 |
DeleteGear(Gear); |
14577 | 2064 |
exit // redundant but we've had too many delete gear bugs |
4224
99c6d87df131
No point in leaving hogs at 0, since shotgun triggers death anyway. Also, add some audio cues to extra damage / time
nemo
parents:
4187
diff
changeset
|
2065 |
end |
99c6d87df131
No point in leaving hogs at 0, since shotgun triggers death anyway. Also, add some audio cues to extra damage / time
nemo
parents:
4187
diff
changeset
|
2066 |
else |
99c6d87df131
No point in leaving hogs at 0, since shotgun triggers death anyway. Also, add some audio cues to extra damage / time
nemo
parents:
4187
diff
changeset
|
2067 |
begin |
5690
f6e0c5bd8020
Allow vgtSmoke to scale. Scale it down 50% for mines, so smoke doesn't seem so oversized
nemo
parents:
5688
diff
changeset
|
2068 |
vg:= AddVisualGear(hwRound(Gear^.X) - 4 + Random(8), hwRound(Gear^.Y) - 4 - Random(4), vgtSmoke); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2069 |
if vg <> nil then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2070 |
vg^.Scale:= 0.5; |
4224
99c6d87df131
No point in leaving hogs at 0, since shotgun triggers death anyway. Also, add some audio cues to extra damage / time
nemo
parents:
4187
diff
changeset
|
2071 |
PlaySound(sndVaporize); |
99c6d87df131
No point in leaving hogs at 0, since shotgun triggers death anyway. Also, add some audio cues to extra damage / time
nemo
parents:
4187
diff
changeset
|
2072 |
Gear^.Health := 0; |
4966
fa612a614317
make defective mines explode if they take enough damage, add missing interface line for koda's new uSound fade
nemo
parents:
4956
diff
changeset
|
2073 |
Gear^.Damage := 0; |
6450 | 2074 |
Gear^.State := Gear^.State and (not gstAttacking) |
4224
99c6d87df131
No point in leaving hogs at 0, since shotgun triggers death anyway. Also, add some audio cues to extra damage / time
nemo
parents:
4187
diff
changeset
|
2075 |
end; |
99c6d87df131
No point in leaving hogs at 0, since shotgun triggers death anyway. Also, add some audio cues to extra damage / time
nemo
parents:
4187
diff
changeset
|
2076 |
exit |
99c6d87df131
No point in leaving hogs at 0, since shotgun triggers death anyway. Also, add some audio cues to extra damage / time
nemo
parents:
4187
diff
changeset
|
2077 |
end; |
99c6d87df131
No point in leaving hogs at 0, since shotgun triggers death anyway. Also, add some audio cues to extra damage / time
nemo
parents:
4187
diff
changeset
|
2078 |
dec(Gear^.Timer); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2079 |
end |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2080 |
else // gsttmpFlag = 0 |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2081 |
if (TurnTimeLeft = 0) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2082 |
or ((GameFlags and gfInfAttack <> 0) and (GameTicks > Gear^.FlightTime)) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2083 |
or (Gear^.Hedgehog^.Gear = nil) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2084 |
Gear^.State := Gear^.State or gsttmpFlag; |
10 | 2085 |
end; |
57 | 2086 |
|
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2087 |
procedure doStepAirMine(Gear: PGear); |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2088 |
var i,t,targDist,tmpDist: LongWord; |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2089 |
targ, tmpG: PGear; |
12805 | 2090 |
trackSpeed, airFriction, tX, tY: hwFloat; |
10827 | 2091 |
isUnderwater: Boolean; |
14223 | 2092 |
sparkle: PVisualGear; |
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2093 |
begin |
14362
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
2094 |
targ:= nil; |
14771
ab7bf5036314
Render mine timer if gear info is active
Wuzzy <Wuzzy2@mail.ru>
parents:
14770
diff
changeset
|
2095 |
Gear^.RenderTimer:= ((Gear^.State and gstFrozen) = 0) and ((Gear^.State and gstAttacking) = 0); |
14362
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
2096 |
if (Gear^.State and gstFrozen) <> 0 then |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
2097 |
begin |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
2098 |
if Gear^.Damage > 0 then |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
2099 |
begin |
14364
2221c418026a
Pixel-perfect removal of exploding frozen air mines
Wuzzy <Wuzzy2@mail.ru>
parents:
14363
diff
changeset
|
2100 |
// Normal, damaging explosion |
2221c418026a
Pixel-perfect removal of exploding frozen air mines
Wuzzy <Wuzzy2@mail.ru>
parents:
14363
diff
changeset
|
2101 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
14365
e3e06b216e00
Frozen air mines: Don't erase land if gstNoGravity state is off
Wuzzy <Wuzzy2@mail.ru>
parents:
14364
diff
changeset
|
2102 |
if ((Gear^.State and gstNoGravity) <> 0) then |
e3e06b216e00
Frozen air mines: Don't erase land if gstNoGravity state is off
Wuzzy <Wuzzy2@mail.ru>
parents:
14364
diff
changeset
|
2103 |
// Remove land created by frozen air mine sprite pixel-perfectly |
e3e06b216e00
Frozen air mines: Don't erase land if gstNoGravity state is off
Wuzzy <Wuzzy2@mail.ru>
parents:
14364
diff
changeset
|
2104 |
EraseLand( |
e3e06b216e00
Frozen air mines: Don't erase land if gstNoGravity state is off
Wuzzy <Wuzzy2@mail.ru>
parents:
14364
diff
changeset
|
2105 |
hwRound(Gear^.X) - SpritesData[sprFrozenAirMine].Width div 2, |
e3e06b216e00
Frozen air mines: Don't erase land if gstNoGravity state is off
Wuzzy <Wuzzy2@mail.ru>
parents:
14364
diff
changeset
|
2106 |
hwRound(Gear^.Y) - SpritesData[sprFrozenAirMine].Height div 2, |
e3e06b216e00
Frozen air mines: Don't erase land if gstNoGravity state is off
Wuzzy <Wuzzy2@mail.ru>
parents:
14364
diff
changeset
|
2107 |
sprFrozenAirMine, 0, 0, false, false, false, false); |
14575 | 2108 |
DeleteGear(Gear); |
14577 | 2109 |
exit |
14362
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
2110 |
end; |
15202 | 2111 |
if ((Gear^.dX.QWordValue + Gear^.dY.QWordValue) > _0_02.QWordValue) or ((GameTicks and $3F) = 15) then |
2112 |
doStepFallingGear(Gear); |
|
14362
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
2113 |
exit |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
2114 |
end; |
10827 | 2115 |
isUnderwater:= CheckCoordInWater(hwRound(Gear^.X), hwRound(Gear^.Y) + Gear^.Radius); |
10800 | 2116 |
if Gear^.Pos > 0 then |
2117 |
begin |
|
2118 |
airFriction:= _1; |
|
10827 | 2119 |
if isUnderwater then |
2120 |
dec(airFriction.QWordValue,Gear^.Pos*2) |
|
2121 |
else |
|
2122 |
dec(airFriction.QWordValue,Gear^.Pos); |
|
10800 | 2123 |
Gear^.dX:= Gear^.dX*airFriction; |
2124 |
Gear^.dY:= Gear^.dY*airFriction |
|
2125 |
end; |
|
15202 | 2126 |
if ((Gear^.dX.QWordValue + Gear^.dY.QWordValue) > _0_02.QWordValue) or ((GameTicks and $3F) = 15) then |
2127 |
doStepFallingGear(Gear); |
|
10806 | 2128 |
if (TurnTimeLeft = 0) and ((Gear^.dX.QWordValue + Gear^.dY.QWordValue) > _0_02.QWordValue) then |
2129 |
AllInactive := false; |
|
2130 |
||
14769
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2131 |
// Disable targeting if airmine is not active yet |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2132 |
if ((Gear^.State and gsttmpFlag) = 0) then |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2133 |
begin |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2134 |
if (TurnTimeLeft = 0) |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2135 |
or ((GameFlags and gfInfAttack <> 0) and (GameTicks > Gear^.FlightTime)) |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2136 |
or (CurrentHedgehog^.Gear = nil) then |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2137 |
begin |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2138 |
Gear^.FlightTime:= GameTicks; |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2139 |
Gear^.State := Gear^.State or gsttmpFlag; |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2140 |
Gear^.Hedgehog := nil; |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2141 |
end; |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2142 |
exit; |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2143 |
end; |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2144 |
|
14221 | 2145 |
//Disable targeting while the airmine is stunned |
2146 |
if Gear^.Tag <> 0 then |
|
2147 |
begin |
|
14223 | 2148 |
if ((Gear^.FlightTime and $FF) = 0) then |
15247
eb61cf77b365
Spawn bubbles instead of sparkles when air mine is stunned underwater
Wuzzy <Wuzzy2@mail.ru>
parents:
15246
diff
changeset
|
2149 |
// spawn lots of particles when stunned (sparkles or bubbles) |
eb61cf77b365
Spawn bubbles instead of sparkles when air mine is stunned underwater
Wuzzy <Wuzzy2@mail.ru>
parents:
15246
diff
changeset
|
2150 |
if CheckCoordInWater(hwRound(Gear^.X), hwRound(Gear^.Y)) = false then |
14223 | 2151 |
begin |
15247
eb61cf77b365
Spawn bubbles instead of sparkles when air mine is stunned underwater
Wuzzy <Wuzzy2@mail.ru>
parents:
15246
diff
changeset
|
2152 |
sparkle:= AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtDust, 1); |
eb61cf77b365
Spawn bubbles instead of sparkles when air mine is stunned underwater
Wuzzy <Wuzzy2@mail.ru>
parents:
15246
diff
changeset
|
2153 |
if sparkle <> nil then |
eb61cf77b365
Spawn bubbles instead of sparkles when air mine is stunned underwater
Wuzzy <Wuzzy2@mail.ru>
parents:
15246
diff
changeset
|
2154 |
begin |
eb61cf77b365
Spawn bubbles instead of sparkles when air mine is stunned underwater
Wuzzy <Wuzzy2@mail.ru>
parents:
15246
diff
changeset
|
2155 |
sparkle^.dX:= 0.004 * (random(100) - 50); |
eb61cf77b365
Spawn bubbles instead of sparkles when air mine is stunned underwater
Wuzzy <Wuzzy2@mail.ru>
parents:
15246
diff
changeset
|
2156 |
sparkle^.dY:= -0.05 + 0.004 * (random(100) - 50); |
eb61cf77b365
Spawn bubbles instead of sparkles when air mine is stunned underwater
Wuzzy <Wuzzy2@mail.ru>
parents:
15246
diff
changeset
|
2157 |
sparkle^.Tint:= $D5CD8CFF; |
eb61cf77b365
Spawn bubbles instead of sparkles when air mine is stunned underwater
Wuzzy <Wuzzy2@mail.ru>
parents:
15246
diff
changeset
|
2158 |
sparkle^.Angle:= random(360); |
eb61cf77b365
Spawn bubbles instead of sparkles when air mine is stunned underwater
Wuzzy <Wuzzy2@mail.ru>
parents:
15246
diff
changeset
|
2159 |
end; |
eb61cf77b365
Spawn bubbles instead of sparkles when air mine is stunned underwater
Wuzzy <Wuzzy2@mail.ru>
parents:
15246
diff
changeset
|
2160 |
end |
eb61cf77b365
Spawn bubbles instead of sparkles when air mine is stunned underwater
Wuzzy <Wuzzy2@mail.ru>
parents:
15246
diff
changeset
|
2161 |
else |
eb61cf77b365
Spawn bubbles instead of sparkles when air mine is stunned underwater
Wuzzy <Wuzzy2@mail.ru>
parents:
15246
diff
changeset
|
2162 |
AddVisualGear(hwRound(Gear^.X) - 8 + random(16), hwRound(Gear^.Y) + 16 + random(8), vgtBubble); |
14223 | 2163 |
|
14221 | 2164 |
dec(Gear^.FlightTime); |
2165 |
if Gear^.FlightTime = 0 then |
|
14225 | 2166 |
begin |
14221 | 2167 |
Gear^.Tag:= 0; |
14225 | 2168 |
Gear^.Hedgehog:= nil; |
2169 |
Gear^.State:= Gear^.State and (not gstAttacking); |
|
2170 |
Gear^.Timer:= Gear^.WDTimer |
|
2171 |
end; |
|
14221 | 2172 |
exit |
2173 |
end; |
|
2174 |
||
10806 | 2175 |
if (TurnTimeLeft = 0) or (Gear^.Angle = 0) or (Gear^.Hedgehog = nil) or (Gear^.Hedgehog^.Gear = nil) then |
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2176 |
begin |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2177 |
Gear^.Hedgehog:= nil; |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2178 |
targ:= nil; |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2179 |
end |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2180 |
else if Gear^.Hedgehog <> nil then |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2181 |
targ:= Gear^.Hedgehog^.Gear; |
10800 | 2182 |
if targ <> nil then |
2183 |
begin |
|
12805 | 2184 |
tX:=Gear^.X-targ^.X; |
2185 |
tY:=Gear^.Y-targ^.Y; |
|
10800 | 2186 |
// allow escaping - should maybe flag this too |
14086 | 2187 |
if (GameTicks > Gear^.FlightTime + 10000) or |
14100 | 2188 |
(not ((tX.Round + tY.Round < Gear^.Angle * 9) and |
14086 | 2189 |
(hwRound(hwSqr(tX) + hwSqr(tY)) < sqr(Gear^.Angle * 6)))) |
2190 |
then |
|
10800 | 2191 |
targ:= nil |
2192 |
end; |
|
2193 |
||
10807
66cde98f8cbe
Make the various mine states a bit clearer (inactive, active but not in seek mode, seek mode, chasing target)
nemo
parents:
10806
diff
changeset
|
2194 |
// If in ready timer, or after turn, or in first 5 seconds of turn (really a window due to extra time utility) |
14769
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2195 |
// or hunting is disabled due to seek radius of 0 then we aren't hunting |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
2196 |
if (ReadyTimeLeft > 0) or (TurnTimeLeft = 0) or |
10807
66cde98f8cbe
Make the various mine states a bit clearer (inactive, active but not in seek mode, seek mode, chasing target)
nemo
parents:
10806
diff
changeset
|
2197 |
((TurnTimeLeft < cHedgehogTurnTime) and (cHedgehogTurnTime-TurnTimeLeft < 5000)) or |
66cde98f8cbe
Make the various mine states a bit clearer (inactive, active but not in seek mode, seek mode, chasing target)
nemo
parents:
10806
diff
changeset
|
2198 |
(Gear^.Angle = 0) then |
10818
f642a28cab0c
Add placement of airmines in engine outside of hog proximity. Has a bug, only protecting 1st team. Also fix a spelling error and rename gstHHChooseTarget to gstChooseTarget
nemo
parents:
10815
diff
changeset
|
2199 |
gear^.State:= gear^.State and (not gstChooseTarget) |
10807
66cde98f8cbe
Make the various mine states a bit clearer (inactive, active but not in seek mode, seek mode, chasing target)
nemo
parents:
10806
diff
changeset
|
2200 |
else if |
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2201 |
// todo, allow not finding new target, set timeout on target retention |
10807
66cde98f8cbe
Make the various mine states a bit clearer (inactive, active but not in seek mode, seek mode, chasing target)
nemo
parents:
10806
diff
changeset
|
2202 |
(Gear^.State and gstAttacking = 0) and |
66cde98f8cbe
Make the various mine states a bit clearer (inactive, active but not in seek mode, seek mode, chasing target)
nemo
parents:
10806
diff
changeset
|
2203 |
((GameTicks and $FF) = 17) and |
66cde98f8cbe
Make the various mine states a bit clearer (inactive, active but not in seek mode, seek mode, chasing target)
nemo
parents:
10806
diff
changeset
|
2204 |
(GameTicks > Gear^.FlightTime) then // recheck hunted hog |
66cde98f8cbe
Make the various mine states a bit clearer (inactive, active but not in seek mode, seek mode, chasing target)
nemo
parents:
10806
diff
changeset
|
2205 |
begin |
10818
f642a28cab0c
Add placement of airmines in engine outside of hog proximity. Has a bug, only protecting 1st team. Also fix a spelling error and rename gstHHChooseTarget to gstChooseTarget
nemo
parents:
10815
diff
changeset
|
2206 |
gear^.State:= gear^.State or gstChooseTarget; |
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2207 |
if targ <> nil then |
12805 | 2208 |
targDist:= Distance(Gear^.X-targ^.X,Gear^.Y-targ^.Y).Round |
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2209 |
else targDist:= 0; |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2210 |
for t:= 0 to Pred(TeamsCount) do |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2211 |
with TeamsArray[t]^ do |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2212 |
for i:= 0 to cMaxHHIndex do |
15863 | 2213 |
if (not Hedgehogs[i].Unplaced) and (Hedgehogs[i].Gear <> nil) and (Hedgehogs[i].Effects[heFrozen] = 0) and ((Hedgehogs[i].Gear^.State and gstInvisible) = 0) then |
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2214 |
begin |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2215 |
tmpG:= Hedgehogs[i].Gear; |
12805 | 2216 |
tX:=Gear^.X-tmpG^.X; |
2217 |
tY:=Gear^.Y-tmpG^.Y; |
|
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2218 |
if (Gear^.Angle = $FFFFFFFF) or |
12805 | 2219 |
((tX.Round+tY.Round < Gear^.Angle) and |
2220 |
(hwRound(hwSqr(tX) + hwSqr(tY)) < sqr(Gear^.Angle))) then |
|
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2221 |
begin |
12805 | 2222 |
if targ <> nil then tmpDist:= Distance(tX,tY).Round; |
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2223 |
if (targ = nil) or (tmpDist < targDist) then |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2224 |
begin |
12805 | 2225 |
if targ = nil then targDist:= Distance(tX,tY).Round |
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2226 |
else targDist:= tmpDist; |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2227 |
Gear^.Hedgehog:= @Hedgehogs[i]; |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2228 |
targ:= tmpG; |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2229 |
end |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2230 |
end |
10791
0311c9fa7498
tweak a few params. still something wtf going on when on rope
nemo
parents:
10789
diff
changeset
|
2231 |
end; |
10802
089e43d01f74
Use the larger scaled airmine sprite originally intended, add some antidickery measures.
nemo
parents:
10800
diff
changeset
|
2232 |
if targ <> nil then Gear^.FlightTime:= GameTicks + 5000 |
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2233 |
end; |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2234 |
if targ <> nil then |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2235 |
begin |
10799
658794118fd8
initialise trackSpeed, add nil check before resetting seek timer
nemo
parents:
10798
diff
changeset
|
2236 |
trackSpeed:= _0; |
10827 | 2237 |
if isUnderwater then |
2238 |
trackSpeed.QWordValue:= Gear^.Power div 2 |
|
2239 |
else |
|
2240 |
trackSpeed.QWordValue:= Gear^.Power; |
|
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2241 |
if (Gear^.X < targ^.X) and (Gear^.dX < _0_1) then |
12806 | 2242 |
if (WorldEdge = weWrap) and ((targ^.X - Gear^.X) > ((Gear^.X - int2hwFloat(LeftX)) + (int2hwFloat(RightX) - targ^.X))) then |
2243 |
Gear^.dX:= Gear^.dX-trackSpeed |
|
2244 |
else |
|
2245 |
Gear^.dX:= Gear^.dX+trackSpeed // please leave as an add. I like the effect |
|
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2246 |
else if (Gear^.X > targ^.X) and (Gear^.dX > -_0_1) then |
12806 | 2247 |
if (WorldEdge = weWrap) and ((Gear^.X - targ^.X) > ((targ^.X - int2hwFloat(LeftX)) + (int2hwFloat(RightX) - Gear^.X))) then |
2248 |
Gear^.dX:= Gear^.dX+trackSpeed |
|
2249 |
else |
|
2250 |
Gear^.dX:= Gear^.dX-trackSpeed; |
|
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2251 |
if (Gear^.Y < targ^.Y) and (Gear^.dY < _0_1) then |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2252 |
Gear^.dY:= Gear^.dY+trackSpeed |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2253 |
else if (Gear^.Y > targ^.Y) and (Gear^.dY > -_0_1) then |
10802
089e43d01f74
Use the larger scaled airmine sprite originally intended, add some antidickery measures.
nemo
parents:
10800
diff
changeset
|
2254 |
Gear^.dY:= Gear^.dY-trackSpeed |
10800 | 2255 |
end |
2256 |
else Gear^.Hedgehog:= nil; |
|
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2257 |
|
14769
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2258 |
if ((Gear^.State and gstAttacking) = 0) then |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2259 |
begin |
15202 | 2260 |
if (((GameTicks+Gear^.Uid) and $1F) = 0) then |
14769
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2261 |
begin |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2262 |
if targ <> nil then |
10794
ace862eda192
radius and sprite drawing tweaks to match the still temporary sprite. also a begin/end sheepluva suggested
nemo
parents:
10791
diff
changeset
|
2263 |
begin |
14769
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2264 |
tX:=Gear^.X-targ^.X; |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2265 |
tY:=Gear^.Y-targ^.Y; |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2266 |
if (tX.Round+tY.Round < Gear^.Boom) and |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2267 |
(hwRound(hwSqr(tX) + hwSqr(tY)) < sqr(Gear^.Boom)) then |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2268 |
Gear^.State := Gear^.State or gstAttacking |
10794
ace862eda192
radius and sprite drawing tweaks to match the still temporary sprite. also a begin/end sheepluva suggested
nemo
parents:
10791
diff
changeset
|
2269 |
end |
14769
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2270 |
else if (Gear^.Angle > 0) and (CheckGearNear(Gear, gtHedgehog, Gear^.Boom, Gear^.Boom) <> nil) then |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2271 |
Gear^.State := Gear^.State or gstAttacking |
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2272 |
end |
14769
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2273 |
end |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2274 |
else // gstAttacking <> 0 |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2275 |
begin |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2276 |
AllInactive := false; |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2277 |
if (Gear^.Timer and $FF) = 0 then |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2278 |
PlaySound(sndMineTick); |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2279 |
if Gear^.Timer = 0 then |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2280 |
begin |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2281 |
// recheck |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2282 |
if targ <> nil then |
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2283 |
begin |
14769
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2284 |
tX:=Gear^.X-targ^.X; |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2285 |
tY:=Gear^.Y-targ^.Y; |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2286 |
if (tX.Round+tY.Round < Gear^.Boom) and |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2287 |
(hwRound(hwSqr(tX) + hwSqr(tY)) < sqr(Gear^.Boom)) then |
10791
0311c9fa7498
tweak a few params. still something wtf going on when on rope
nemo
parents:
10789
diff
changeset
|
2288 |
begin |
0311c9fa7498
tweak a few params. still something wtf going on when on rope
nemo
parents:
10789
diff
changeset
|
2289 |
Gear^.Hedgehog:= CurrentHedgehog; |
14769
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2290 |
tmpG:= FollowGear; |
13399 | 2291 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
14769
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2292 |
FollowGear:= tmpG; |
10791
0311c9fa7498
tweak a few params. still something wtf going on when on rope
nemo
parents:
10789
diff
changeset
|
2293 |
DeleteGear(Gear); |
0311c9fa7498
tweak a few params. still something wtf going on when on rope
nemo
parents:
10789
diff
changeset
|
2294 |
exit |
14769
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2295 |
end |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2296 |
end |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2297 |
else if (Gear^.Angle > 0) and (CheckGearNear(Gear, gtHedgehog, Gear^.Boom, Gear^.Boom) <> nil) then |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2298 |
begin |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2299 |
Gear^.Hedgehog:= CurrentHedgehog; |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2300 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2301 |
DeleteGear(Gear); |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2302 |
exit |
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2303 |
end; |
14769
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2304 |
Gear^.State:= Gear^.State and (not gstAttacking); |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2305 |
Gear^.Timer:= Gear^.WDTimer |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2306 |
end; |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2307 |
if Gear^.Timer > 0 then |
2ad6f0555e61
Fix air mine not colliding with crates initially (bug 679)
Wuzzy <Wuzzy2@mail.ru>
parents:
14763
diff
changeset
|
2308 |
dec(Gear^.Timer); |
10791
0311c9fa7498
tweak a few params. still something wtf going on when on rope
nemo
parents:
10789
diff
changeset
|
2309 |
end |
10789
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2310 |
end; |
acbf69e2e5cf
experiment with air mines. thought they could make shoppa... interesting. ToDo: Allow mines to give up, tweak distances, real graphics, toggle for whether they can acquire a new target while they haven't given up.
nemo
parents:
10736
diff
changeset
|
2311 |
|
39 | 2312 |
//////////////////////////////////////////////////////////////////////////////// |
3714 | 2313 |
procedure doStepSMine(Gear: PGear); |
9731
953197ac43d8
Make sticky mine respect lfBouncy, make hogs do same, kinda... make uCollisions return land w/ mask, restrict bouncy to advbounce gears only, which means piano doesn't bounce anymore
nemo
parents:
9724
diff
changeset
|
2314 |
var land: Word; |
3710 | 2315 |
begin |
3714 | 2316 |
// TODO: do real calculation? |
9731
953197ac43d8
Make sticky mine respect lfBouncy, make hogs do same, kinda... make uCollisions return land w/ mask, restrict bouncy to advbounce gears only, which means piano doesn't bounce anymore
nemo
parents:
9724
diff
changeset
|
2317 |
land:= TestCollisionXwithGear(Gear, 2); |
953197ac43d8
Make sticky mine respect lfBouncy, make hogs do same, kinda... make uCollisions return land w/ mask, restrict bouncy to advbounce gears only, which means piano doesn't bounce anymore
nemo
parents:
9724
diff
changeset
|
2318 |
if land = 0 then land:= TestCollisionYwithGear(Gear,-2); |
953197ac43d8
Make sticky mine respect lfBouncy, make hogs do same, kinda... make uCollisions return land w/ mask, restrict bouncy to advbounce gears only, which means piano doesn't bounce anymore
nemo
parents:
9724
diff
changeset
|
2319 |
if land = 0 then land:= TestCollisionXwithGear(Gear,-2); |
953197ac43d8
Make sticky mine respect lfBouncy, make hogs do same, kinda... make uCollisions return land w/ mask, restrict bouncy to advbounce gears only, which means piano doesn't bounce anymore
nemo
parents:
9724
diff
changeset
|
2320 |
if land = 0 then land:= TestCollisionYwithGear(Gear, 2); |
11305
a20f416c91ec
fix bug reported by S.D.: throwing a sticking mine into a bouncy pit never ends turn. see also http://hedgewars.org/node/6350
sheepluva
parents:
11286
diff
changeset
|
2321 |
if (land <> 0) and ((land and lfBouncy = 0) or ((Gear^.State and gstMoving) = 0)) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2322 |
begin |
10964 | 2323 |
if ((Gear^.State and gstMoving) <> 0) or (not isZero(Gear^.dX)) or (not isZero(Gear^.dY)) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2324 |
begin |
3717 | 2325 |
PlaySound(sndRopeAttach); |
4880
07e9849c6a70
bugfix: fixing sticky mines calling AddGearCI when they shouldn't (allows jumping on them in midair)
sheepluva
parents:
4874
diff
changeset
|
2326 |
Gear^.dX:= _0; |
07e9849c6a70
bugfix: fixing sticky mines calling AddGearCI when they shouldn't (allows jumping on them in midair)
sheepluva
parents:
4874
diff
changeset
|
2327 |
Gear^.dY:= _0; |
10164
0570d4b22187
AI doesn't skip till action on the map stops (mostly dedicated to highlander) + various small tweaks
unc0rr
parents:
10145
diff
changeset
|
2328 |
Gear^.State:= Gear^.State and (not gstMoving); |
9291
15f7bb217b66
Make add/delete consistent (this has bugged me for so long)
nemo
parents:
9289
diff
changeset
|
2329 |
AddCI(Gear); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2330 |
end; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2331 |
end |
3714 | 2332 |
else |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2333 |
begin |
10164
0570d4b22187
AI doesn't skip till action on the map stops (mostly dedicated to highlander) + various small tweaks
unc0rr
parents:
10145
diff
changeset
|
2334 |
Gear^.State:= Gear^.State or gstMoving; |
4880
07e9849c6a70
bugfix: fixing sticky mines calling AddGearCI when they shouldn't (allows jumping on them in midair)
sheepluva
parents:
4874
diff
changeset
|
2335 |
DeleteCI(Gear); |
3714 | 2336 |
doStepFallingGear(Gear); |
2337 |
AllInactive := false; |
|
2338 |
CalcRotationDirAngle(Gear); |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2339 |
end; |
3714 | 2340 |
|
14779
bc0e86b0347b
Don't show SMine timer if drowning
Wuzzy <Wuzzy2@mail.ru>
parents:
14771
diff
changeset
|
2341 |
Gear^.RenderTimer:= (Gear^.State and (gstFrozen or gstAttacking or gstDrowning) = 0); |
3710 | 2342 |
if ((Gear^.State and gsttmpFlag) <> 0) and (Gear^.Health <> 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2343 |
begin |
12299
6b25d117a904
Freezer allows to freeze sticky mines (currently only disables them)
Wuzzy <almikes@aol.com>
parents:
12292
diff
changeset
|
2344 |
if ((Gear^.State and gstAttacking) = 0) and ((Gear^.State and gstFrozen) = 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2345 |
begin |
3710 | 2346 |
if ((GameTicks and $1F) = 0) then |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
2347 |
// FIXME - values taken from mine. use a gear val and set both to same |
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
2348 |
if CheckGearNear(Gear, gtHedgehog, 46, 32) <> nil then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2349 |
Gear^.State := Gear^.State or gstAttacking |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2350 |
end |
12299
6b25d117a904
Freezer allows to freeze sticky mines (currently only disables them)
Wuzzy <almikes@aol.com>
parents:
12292
diff
changeset
|
2351 |
else if (Gear^.State and gstFrozen) = 0 then // gstAttacking <> 0 |
9742
419e5c651870
Remove turntimeleft/hog gear check from smine if infinite attack is enabled. just use the flightime for that.
nemo
parents:
9731
diff
changeset
|
2352 |
begin |
4880
07e9849c6a70
bugfix: fixing sticky mines calling AddGearCI when they shouldn't (allows jumping on them in midair)
sheepluva
parents:
4874
diff
changeset
|
2353 |
AllInactive := false; |
07e9849c6a70
bugfix: fixing sticky mines calling AddGearCI when they shouldn't (allows jumping on them in midair)
sheepluva
parents:
4874
diff
changeset
|
2354 |
if Gear^.Timer = 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2355 |
begin |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
2356 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
4880
07e9849c6a70
bugfix: fixing sticky mines calling AddGearCI when they shouldn't (allows jumping on them in midair)
sheepluva
parents:
4874
diff
changeset
|
2357 |
DeleteGear(Gear); |
07e9849c6a70
bugfix: fixing sticky mines calling AddGearCI when they shouldn't (allows jumping on them in midair)
sheepluva
parents:
4874
diff
changeset
|
2358 |
exit |
9742
419e5c651870
Remove turntimeleft/hog gear check from smine if infinite attack is enabled. just use the flightime for that.
nemo
parents:
9731
diff
changeset
|
2359 |
end |
419e5c651870
Remove turntimeleft/hog gear check from smine if infinite attack is enabled. just use the flightime for that.
nemo
parents:
9731
diff
changeset
|
2360 |
else |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2361 |
if (Gear^.Timer and $FF) = 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2362 |
PlaySound(sndMineTick); |
9742
419e5c651870
Remove turntimeleft/hog gear check from smine if infinite attack is enabled. just use the flightime for that.
nemo
parents:
9731
diff
changeset
|
2363 |
dec(Gear^.Timer); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2364 |
end |
9742
419e5c651870
Remove turntimeleft/hog gear check from smine if infinite attack is enabled. just use the flightime for that.
nemo
parents:
9731
diff
changeset
|
2365 |
end |
3710 | 2366 |
else // gsttmpFlag = 0 |
10015 | 2367 |
if ((GameFlags and gfInfAttack = 0) and ((TurnTimeLeft = 0) or (Gear^.Hedgehog^.Gear = nil))) |
9742
419e5c651870
Remove turntimeleft/hog gear check from smine if infinite attack is enabled. just use the flightime for that.
nemo
parents:
9731
diff
changeset
|
2368 |
or ((GameFlags and gfInfAttack <> 0) and (GameTicks > Gear^.FlightTime)) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2369 |
Gear^.State := Gear^.State or gsttmpFlag; |
3710 | 2370 |
end; |
2371 |
||
2372 |
//////////////////////////////////////////////////////////////////////////////// |
|
39 | 2373 |
procedure doStepDynamite(Gear: PGear); |
2374 |
begin |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2375 |
doStepFallingGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2376 |
AllInactive := false; |
11527
44e646598e6a
sparkles for dynamite at sheepy's request. he can tweak values if he wishes
nemo
parents:
11523
diff
changeset
|
2377 |
|
15498 | 2378 |
if (Gear^.SoundChannel <> -1) and ((Gear^.State and gstDrowning) <> 0) then |
2379 |
begin |
|
2380 |
StopSoundChan(Gear^.SoundChannel); |
|
2381 |
Gear^.SoundChannel:= -1; |
|
2382 |
end |
|
2383 |
else if Gear^.SoundChannel = -1 then |
|
2384 |
Gear^.SoundChannel := LoopSound(sndDynamiteFuse); |
|
15494
1e3761ecfc13
Fix incorrect dynamite drown check
Wuzzy <Wuzzy2@mail.ru>
parents:
15493
diff
changeset
|
2385 |
if (Gear^.State and gstDrowning) <> 0 then |
15492
e1467bced64d
Dynamite handler: Exit early when drowning
Wuzzy <Wuzzy2@mail.ru>
parents:
15381
diff
changeset
|
2386 |
exit; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2387 |
if Gear^.Timer mod 166 = 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2388 |
inc(Gear^.Tag); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2389 |
if Gear^.Timer = 1000 then // might need better timing |
14032
3c40754f6cfe
Add Grenade taunt when grenade close to hog is about to blow up
Wuzzy <Wuzzy2@mail.ru>
parents:
14030
diff
changeset
|
2390 |
makeHogsWorry(Gear^.X, Gear^.Y, 75, Gear^.Kind); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2391 |
if Gear^.Timer = 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2392 |
begin |
15498 | 2393 |
StopSoundChan(Gear^.SoundChannel); |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
2394 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2395 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2396 |
exit |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2397 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2398 |
dec(Gear^.Timer); |
39 | 2399 |
end; |
14
81f125629b25
- Mine checks whether a hedgehog is near less frequently
unc0rr
parents:
13
diff
changeset
|
2400 |
|
351 | 2401 |
/////////////////////////////////////////////////////////////////////////////// |
2941
566f967ec22f
White/Black smoke, break out rolling barrel into its own routine, adjust rolling barrel impact damage. NEEDS TESTING
nemo
parents:
2939
diff
changeset
|
2402 |
|
566f967ec22f
White/Black smoke, break out rolling barrel into its own routine, adjust rolling barrel impact damage. NEEDS TESTING
nemo
parents:
2939
diff
changeset
|
2403 |
procedure doStepRollingBarrel(Gear: PGear); |
8795 | 2404 |
var |
10679
5989c293955a
add a couple of onGearDamage callbacks to mine/barrel fall damage
nemo
parents:
10676
diff
changeset
|
2405 |
i, dmg: LongInt; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
2406 |
particle: PVisualGear; |
8958
3818b38d72c0
simplify mine/explosive damage calc. clear dX in stable explosives. remove 0/4096 in trace routines.
nemo
parents:
8952
diff
changeset
|
2407 |
dxdy: hwFloat; |
2941
566f967ec22f
White/Black smoke, break out rolling barrel into its own routine, adjust rolling barrel impact damage. NEEDS TESTING
nemo
parents:
2939
diff
changeset
|
2408 |
begin |
10490 | 2409 |
if (Gear^.dX.QWordValue = 0) and (Gear^.dY.QWordValue = 0) and (TestCollisionYwithGear(Gear, 1) = 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2410 |
SetLittle(Gear^.dY); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2411 |
Gear^.State := Gear^.State or gstAnimation; |
9954 | 2412 |
if Gear^.Health < cBarrelHealth then Gear^.State:= Gear^.State and (not gstFrozen); |
8795 | 2413 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2414 |
if ((Gear^.dX.QWordValue <> 0) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2415 |
or (Gear^.dY.QWordValue <> 0)) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2416 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2417 |
DeleteCI(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2418 |
AllInactive := false; |
8958
3818b38d72c0
simplify mine/explosive damage calc. clear dX in stable explosives. remove 0/4096 in trace routines.
nemo
parents:
8952
diff
changeset
|
2419 |
dxdy:= hwAbs(Gear^.dX)+hwAbs(Gear^.dY); |
8971
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2420 |
doStepFallingGear(Gear); |
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2421 |
if (Gear^.State and gstCollision <> 0) and(dxdy > _0_4) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2422 |
begin |
8958
3818b38d72c0
simplify mine/explosive damage calc. clear dX in stable explosives. remove 0/4096 in trace routines.
nemo
parents:
8952
diff
changeset
|
2423 |
if (TestCollisionYwithGear(Gear, 1) <> 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2424 |
begin |
8958
3818b38d72c0
simplify mine/explosive damage calc. clear dX in stable explosives. remove 0/4096 in trace routines.
nemo
parents:
8952
diff
changeset
|
2425 |
Gear^.State := Gear^.State or gsttmpFlag; |
3818b38d72c0
simplify mine/explosive damage calc. clear dX in stable explosives. remove 0/4096 in trace routines.
nemo
parents:
8952
diff
changeset
|
2426 |
for i:= min(12, hwRound(dxdy*_10)) downto 0 do |
3818b38d72c0
simplify mine/explosive damage calc. clear dX in stable explosives. remove 0/4096 in trace routines.
nemo
parents:
8952
diff
changeset
|
2427 |
begin |
3818b38d72c0
simplify mine/explosive damage calc. clear dX in stable explosives. remove 0/4096 in trace routines.
nemo
parents:
8952
diff
changeset
|
2428 |
particle := AddVisualGear(hwRound(Gear^.X) - 5 + Random(10), hwRound(Gear^.Y) + 12,vgtDust); |
3818b38d72c0
simplify mine/explosive damage calc. clear dX in stable explosives. remove 0/4096 in trace routines.
nemo
parents:
8952
diff
changeset
|
2429 |
if particle <> nil then |
3818b38d72c0
simplify mine/explosive damage calc. clear dX in stable explosives. remove 0/4096 in trace routines.
nemo
parents:
8952
diff
changeset
|
2430 |
particle^.dX := particle^.dX + (Gear^.dX.QWordValue / 21474836480) |
3818b38d72c0
simplify mine/explosive damage calc. clear dX in stable explosives. remove 0/4096 in trace routines.
nemo
parents:
8952
diff
changeset
|
2431 |
end |
8971
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2432 |
end; |
10679
5989c293955a
add a couple of onGearDamage callbacks to mine/barrel fall damage
nemo
parents:
10676
diff
changeset
|
2433 |
dmg:= hwRound(dxdy * _50); |
5989c293955a
add a couple of onGearDamage callbacks to mine/barrel fall damage
nemo
parents:
10676
diff
changeset
|
2434 |
inc(Gear^.Damage, dmg); |
5989c293955a
add a couple of onGearDamage callbacks to mine/barrel fall damage
nemo
parents:
10676
diff
changeset
|
2435 |
ScriptCall('onGearDamage', Gear^.UID, dmg) |
8958
3818b38d72c0
simplify mine/explosive damage calc. clear dX in stable explosives. remove 0/4096 in trace routines.
nemo
parents:
8952
diff
changeset
|
2436 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2437 |
CalcRotationDirAngle(Gear); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2438 |
end |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2439 |
else |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2440 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2441 |
Gear^.State := Gear^.State or gsttmpFlag; |
9291
15f7bb217b66
Make add/delete consistent (this has bugged me for so long)
nemo
parents:
9289
diff
changeset
|
2442 |
AddCI(Gear) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2443 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2444 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2445 |
if not Gear^.dY.isNegative and (Gear^.dY < _0_001) and (TestCollisionYwithGear(Gear, 1) <> 0) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2446 |
Gear^.dY := _0; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2447 |
if hwAbs(Gear^.dX) < _0_001 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2448 |
Gear^.dX := _0; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2449 |
|
5128
3c65326bb713
Check for 0 health to avoid div by 0. spotted by mikade.
nemo
parents:
5121
diff
changeset
|
2450 |
if (Gear^.Health > 0) and ((Gear^.Health * 100 div cBarrelHealth) < random(90)) and ((GameTicks and $FF) = 0) then |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2451 |
if (cBarrelHealth div Gear^.Health) > 2 then |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2452 |
AddVisualGear(hwRound(Gear^.X) - 16 + Random(32), hwRound(Gear^.Y) - 2, vgtSmoke) |
2941
566f967ec22f
White/Black smoke, break out rolling barrel into its own routine, adjust rolling barrel impact damage. NEEDS TESTING
nemo
parents:
2939
diff
changeset
|
2453 |
else |
566f967ec22f
White/Black smoke, break out rolling barrel into its own routine, adjust rolling barrel impact damage. NEEDS TESTING
nemo
parents:
2939
diff
changeset
|
2454 |
AddVisualGear(hwRound(Gear^.X) - 16 + Random(32), hwRound(Gear^.Y) - 2, vgtSmokeWhite); |
14976
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2455 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2456 |
dec(Gear^.Health, Gear^.Damage); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2457 |
Gear^.Damage := 0; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2458 |
if Gear^.Health <= 0 then |
14976
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2459 |
doStepCase(Gear) |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2460 |
else |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2461 |
// health texture (FlightTime = health when the last texture was generated) |
15381
c117e17b90bc
flag some of the renderstringtex which are taking up a ton of processing time with --stats-only and pas2c
nemo
parents:
15354
diff
changeset
|
2462 |
if (not cOnlyStats) and ((Gear^.Health <> Gear^.FlightTime) or (Gear^.Tex = nil)) then |
14976
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2463 |
begin |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2464 |
Gear^.FlightTime:= Gear^.Health; |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2465 |
FreeAndNilTexture(Gear^.Tex); |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2466 |
Gear^.Tex := RenderStringTex(ansistring(inttostr(Gear^.Health)), $ff808080, fnt16); |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2467 |
end; |
2941
566f967ec22f
White/Black smoke, break out rolling barrel into its own routine, adjust rolling barrel impact damage. NEEDS TESTING
nemo
parents:
2939
diff
changeset
|
2468 |
end; |
566f967ec22f
White/Black smoke, break out rolling barrel into its own routine, adjust rolling barrel impact damage. NEEDS TESTING
nemo
parents:
2939
diff
changeset
|
2469 |
|
14
81f125629b25
- Mine checks whether a hedgehog is near less frequently
unc0rr
parents:
13
diff
changeset
|
2470 |
procedure doStepCase(Gear: PGear); |
8795 | 2471 |
var |
7406
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7400
diff
changeset
|
2472 |
i, x, y: LongInt; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
2473 |
k: TGearType; |
7406
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7400
diff
changeset
|
2474 |
dX, dY: HWFloat; |
4837
2ea0a152c319
Pass PHedgehog instead of PGear to stats. Fixes crash.
unc0rr
parents:
4824
diff
changeset
|
2475 |
hog: PHedgehog; |
7168
8defaabce92e
warp sound when AI survival hog respawns. attempt at a bit of a crate spawn animation (moar sparkles and a quick fadein)
nemo
parents:
7128
diff
changeset
|
2476 |
sparkles: PVisualGear; |
14
81f125629b25
- Mine checks whether a hedgehog is near less frequently
unc0rr
parents:
13
diff
changeset
|
2477 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2478 |
k := Gear^.Kind; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2479 |
|
3894 | 2480 |
if (Gear^.Message and gmDestroy) > 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2481 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2482 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2483 |
FreeActionsList; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2484 |
SetAllToActive; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2485 |
// something (hh, mine, etc...) could be on top of the case |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2486 |
with CurrentHedgehog^ do |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2487 |
if Gear <> nil then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2488 |
Gear^.Message := Gear^.Message and (not (gmLJump or gmHJump)); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2489 |
exit |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2490 |
end; |
9954 | 2491 |
if (k = gtExplosives) and (Gear^.Health < cBarrelHealth) then Gear^.State:= Gear^.State and (not gstFrozen); |
15 | 2492 |
|
8973 | 2493 |
if ((k <> gtExplosives) and (Gear^.Damage > 0)) or ((k = gtExplosives) and (Gear^.Health<=0)) then |
8971
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2494 |
begin |
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2495 |
x := hwRound(Gear^.X); |
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2496 |
y := hwRound(Gear^.Y); |
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2497 |
hog:= Gear^.Hedgehog; |
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2498 |
|
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2499 |
if k = gtCase then |
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2500 |
begin |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
2501 |
doMakeExplosion(x, y, Gear^.Boom, hog, EXPLAutoSound); |
8971
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2502 |
for i:= 0 to 63 do |
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2503 |
AddGear(x, y, gtFlame, 0, _0, _0, 0); |
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2504 |
end |
12568
494d3e1c4810
Don't play “missed” taunt if a target has been hit
Wuzzy <almikes@aol.com>
parents:
12377
diff
changeset
|
2505 |
else if k = gtTarget then |
494d3e1c4810
Don't play “missed” taunt if a target has been hit
Wuzzy <almikes@aol.com>
parents:
12377
diff
changeset
|
2506 |
uStats.TargetHit() |
8971
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2507 |
else if k = gtExplosives then |
14577 | 2508 |
begin |
2509 |
doMakeExplosion(x, y, Gear^.Boom, hog, EXPLAutoSound); |
|
2510 |
for i:= 0 to 31 do |
|
2511 |
begin |
|
2512 |
dX := AngleCos(i * 64) * _0_5 * (getrandomf + _1); |
|
2513 |
dY := AngleSin(i * 64) * _0_5 * (getrandomf + _1); |
|
2514 |
AddGear(x, y, gtFlame, 0, dX, dY, 0); |
|
2515 |
AddGear(x, y, gtFlame, gstTmpFlag, -dX, -dY, 0); |
|
2516 |
end |
|
2517 |
end; |
|
14575 | 2518 |
DeleteGear(Gear); |
14577 | 2519 |
exit |
8971
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2520 |
end; |
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2521 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2522 |
if k = gtExplosives then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2523 |
begin |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2524 |
if (hwAbs(Gear^.dX) > _0_15) or ((hwAbs(Gear^.dY) > _0_15) and (hwAbs(Gear^.dX) > _0_02)) then |
8962
9780e79619ed
So. This at least should make the math more accurate, even if it still doesn't appear to resolve prob w/ AI attacks
nemo
parents:
8958
diff
changeset
|
2525 |
begin |
9780e79619ed
So. This at least should make the math more accurate, even if it still doesn't appear to resolve prob w/ AI attacks
nemo
parents:
8958
diff
changeset
|
2526 |
Gear^.doStep := @doStepRollingBarrel; |
9780e79619ed
So. This at least should make the math more accurate, even if it still doesn't appear to resolve prob w/ AI attacks
nemo
parents:
8958
diff
changeset
|
2527 |
exit; |
9780e79619ed
So. This at least should make the math more accurate, even if it still doesn't appear to resolve prob w/ AI attacks
nemo
parents:
8958
diff
changeset
|
2528 |
end |
8958
3818b38d72c0
simplify mine/explosive damage calc. clear dX in stable explosives. remove 0/4096 in trace routines.
nemo
parents:
8952
diff
changeset
|
2529 |
else Gear^.dX:= _0; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2530 |
|
8971
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2531 |
if ((Gear^.Health * 100 div cBarrelHealth) < random(90)) and ((GameTicks and $FF) = 0) then |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2532 |
if (cBarrelHealth div Gear^.Health) > 2 then |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2533 |
AddVisualGear(hwRound(Gear^.X) - 16 + Random(32), hwRound(Gear^.Y) - 2, vgtSmoke) |
8971
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2534 |
else |
fcb29a13b1b1
Adjust barrel damage so AI can actually bat to explode them. Fix state flag check. Remove unneeded dmgMod var. Cancel dX for low dX barrel tracing.
nemo
parents:
8962
diff
changeset
|
2535 |
AddVisualGear(hwRound(Gear^.X) - 16 + Random(32), hwRound(Gear^.Y) - 2, vgtSmokeWhite); |
14976
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2536 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2537 |
dec(Gear^.Health, Gear^.Damage); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2538 |
Gear^.Damage := 0; |
14976
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2539 |
// health texture (FlightTime = health when the last texture was generated) |
15381
c117e17b90bc
flag some of the renderstringtex which are taking up a ton of processing time with --stats-only and pas2c
nemo
parents:
15354
diff
changeset
|
2540 |
if (not cOnlyStats) and ((Gear^.Health <> Gear^.FlightTime) or (Gear^.Tex = nil)) then |
14976
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2541 |
begin |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2542 |
Gear^.FlightTime:= Gear^.Health; |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2543 |
FreeAndNilTexture(Gear^.Tex); |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2544 |
Gear^.Tex := RenderStringTex(ansistring(inttostr(Gear^.Health)), $ff808080, fnt16); |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2545 |
end; |
7168
8defaabce92e
warp sound when AI survival hog respawns. attempt at a bit of a crate spawn animation (moar sparkles and a quick fadein)
nemo
parents:
7128
diff
changeset
|
2546 |
end |
8defaabce92e
warp sound when AI survival hog respawns. attempt at a bit of a crate spawn animation (moar sparkles and a quick fadein)
nemo
parents:
7128
diff
changeset
|
2547 |
else |
8795 | 2548 |
begin |
14770
533ac9774279
Add key to display extra gear info tags
Wuzzy <Wuzzy2@mail.ru>
parents:
14769
diff
changeset
|
2549 |
// health texture for health crate |
14976
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2550 |
if (k = gtCase) and ((Gear^.Pos and posCaseHealth) <> 0) then |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2551 |
begin |
14770
533ac9774279
Add key to display extra gear info tags
Wuzzy <Wuzzy2@mail.ru>
parents:
14769
diff
changeset
|
2552 |
if ((Gear^.State and gstFrozen) = 0) then |
14782
1b82538970ca
Fix health crate health display not respecting Karma value properly
Wuzzy <Wuzzy2@mail.ru>
parents:
14780
diff
changeset
|
2553 |
begin |
14780 | 2554 |
// Karma=2: Always hide health |
2555 |
if (Gear^.Karma = 2) then |
|
14782
1b82538970ca
Fix health crate health display not respecting Karma value properly
Wuzzy <Wuzzy2@mail.ru>
parents:
14780
diff
changeset
|
2556 |
i:= 0 |
14780 | 2557 |
// Karma=1: Hide health in game, but show in demo |
14782
1b82538970ca
Fix health crate health display not respecting Karma value properly
Wuzzy <Wuzzy2@mail.ru>
parents:
14780
diff
changeset
|
2558 |
else if (Gear^.Karma = 1) then |
1b82538970ca
Fix health crate health display not respecting Karma value properly
Wuzzy <Wuzzy2@mail.ru>
parents:
14780
diff
changeset
|
2559 |
if (GameType in [gmtDemo, gmtRecord]) then |
1b82538970ca
Fix health crate health display not respecting Karma value properly
Wuzzy <Wuzzy2@mail.ru>
parents:
14780
diff
changeset
|
2560 |
i:= 1 |
1b82538970ca
Fix health crate health display not respecting Karma value properly
Wuzzy <Wuzzy2@mail.ru>
parents:
14780
diff
changeset
|
2561 |
else |
1b82538970ca
Fix health crate health display not respecting Karma value properly
Wuzzy <Wuzzy2@mail.ru>
parents:
14780
diff
changeset
|
2562 |
i:= 0 |
15381
c117e17b90bc
flag some of the renderstringtex which are taking up a ton of processing time with --stats-only and pas2c
nemo
parents:
15354
diff
changeset
|
2563 |
else if cOnlyStats then |
c117e17b90bc
flag some of the renderstringtex which are taking up a ton of processing time with --stats-only and pas2c
nemo
parents:
15354
diff
changeset
|
2564 |
i:= 0 |
14780 | 2565 |
// Always show health (default) |
2566 |
else |
|
14782
1b82538970ca
Fix health crate health display not respecting Karma value properly
Wuzzy <Wuzzy2@mail.ru>
parents:
14780
diff
changeset
|
2567 |
i:= 1; |
1b82538970ca
Fix health crate health display not respecting Karma value properly
Wuzzy <Wuzzy2@mail.ru>
parents:
14780
diff
changeset
|
2568 |
if i = 1 then |
14976
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2569 |
begin |
15381
c117e17b90bc
flag some of the renderstringtex which are taking up a ton of processing time with --stats-only and pas2c
nemo
parents:
15354
diff
changeset
|
2570 |
if (not cOnlyStats) and ((Gear^.Health <> Gear^.FlightTime) or (Gear^.Tex = nil)) then |
14976
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2571 |
begin |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2572 |
Gear^.FlightTime:= Gear^.Health; |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2573 |
FreeAndNilTexture(Gear^.Tex); |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2574 |
Gear^.Tex := RenderStringTex(ansistring(inttostr(Gear^.Health)), $ff80ff80, fnt16) |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2575 |
end |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2576 |
end |
14782
1b82538970ca
Fix health crate health display not respecting Karma value properly
Wuzzy <Wuzzy2@mail.ru>
parents:
14780
diff
changeset
|
2577 |
else |
14976
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2578 |
begin |
15381
c117e17b90bc
flag some of the renderstringtex which are taking up a ton of processing time with --stats-only and pas2c
nemo
parents:
15354
diff
changeset
|
2579 |
if (not cOnlyStats) and ((Gear^.FlightTime <> $ffffffff) or (Gear^.Tex = nil)) then |
14976
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2580 |
begin |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2581 |
Gear^.FlightTime:= $ffffffff; |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2582 |
FreeAndNilTexture(Gear^.Tex); |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2583 |
Gear^.Tex := RenderStringTex(trmsg[sidUnknownGearValue], $ff80ff80, fnt16) |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2584 |
end |
088c1d319612
if at all possible, don't regenerate arbitrary number of health textures each tick
alfadur
parents:
14958
diff
changeset
|
2585 |
end |
14782
1b82538970ca
Fix health crate health display not respecting Karma value properly
Wuzzy <Wuzzy2@mail.ru>
parents:
14780
diff
changeset
|
2586 |
end; |
14770
533ac9774279
Add key to display extra gear info tags
Wuzzy <Wuzzy2@mail.ru>
parents:
14769
diff
changeset
|
2587 |
end; |
7276 | 2588 |
if Gear^.Timer = 500 then |
2589 |
begin |
|
7168
8defaabce92e
warp sound when AI survival hog respawns. attempt at a bit of a crate spawn animation (moar sparkles and a quick fadein)
nemo
parents:
7128
diff
changeset
|
2590 |
(* Can't make sparkles team coloured without working out what the next team is going to be. This should be solved, really, since it also screws up |
8defaabce92e
warp sound when AI survival hog respawns. attempt at a bit of a crate spawn animation (moar sparkles and a quick fadein)
nemo
parents:
7128
diff
changeset
|
2591 |
voices. Reinforcements voices is heard for active team, not team-to-be. Either that or change crate spawn from end of turn to start, although that |
8defaabce92e
warp sound when AI survival hog respawns. attempt at a bit of a crate spawn animation (moar sparkles and a quick fadein)
nemo
parents:
7128
diff
changeset
|
2592 |
has its own complexities. *) |
7276 | 2593 |
// Abuse a couple of gear values to track origin |
7339 | 2594 |
Gear^.Angle:= hwRound(Gear^.Y); |
7276 | 2595 |
Gear^.Tag:= random(2); |
2596 |
inc(Gear^.Timer) |
|
2597 |
end; |
|
2598 |
if Gear^.Timer < 1833 then inc(Gear^.Timer); |
|
2599 |
if Gear^.Timer = 1000 then |
|
7168
8defaabce92e
warp sound when AI survival hog respawns. attempt at a bit of a crate spawn animation (moar sparkles and a quick fadein)
nemo
parents:
7128
diff
changeset
|
2600 |
begin |
7339 | 2601 |
sparkles:= AddVisualGear(hwRound(Gear^.X), Gear^.Angle, vgtDust, 1); |
7276 | 2602 |
if sparkles <> nil then |
2603 |
begin |
|
2604 |
sparkles^.dX:= 0; |
|
2605 |
sparkles^.dY:= 0; |
|
2606 |
sparkles^.Angle:= 270; |
|
8795 | 2607 |
if Gear^.Tag = 1 then |
7276 | 2608 |
sparkles^.Tint:= $3744D7FF |
2609 |
else sparkles^.Tint:= $FAB22CFF |
|
2610 |
end; |
|
2611 |
end; |
|
8795 | 2612 |
if Gear^.Timer < 1000 then |
7283 | 2613 |
begin |
2614 |
AllInactive:= false; |
|
2615 |
exit |
|
2616 |
end |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2617 |
end; |
2911 | 2618 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2619 |
|
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2620 |
if (Gear^.dY.QWordValue <> 0) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2621 |
or (TestCollisionYwithGear(Gear, 1) = 0) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2622 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2623 |
AllInactive := false; |
7661
3046ad5b361e
fix for issue 376 (embedding barrels in ceiling)
sheepluva
parents:
7659
diff
changeset
|
2624 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2625 |
Gear^.dY := Gear^.dY + cGravity; |
7661
3046ad5b361e
fix for issue 376 (embedding barrels in ceiling)
sheepluva
parents:
7659
diff
changeset
|
2626 |
|
9820 | 2627 |
if ((not Gear^.dY.isNegative) and (TestCollisionYwithGear(Gear, 1) <> 0)) or |
2628 |
(Gear^.dY.isNegative and (TestCollisionYwithGear(Gear, -1) <> 0)) then |
|
2629 |
Gear^.dY := _0 |
|
2630 |
else Gear^.Y := Gear^.Y + Gear^.dY; |
|
7661
3046ad5b361e
fix for issue 376 (embedding barrels in ceiling)
sheepluva
parents:
7659
diff
changeset
|
2631 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2632 |
if (not Gear^.dY.isNegative) and (Gear^.dY > _0_001) then |
8579
d18bc19d780a
graphics tweak. flag a couple more overeager setall HH
nemo
parents:
8578
diff
changeset
|
2633 |
SetAllHHToActive(false); |
7661
3046ad5b361e
fix for issue 376 (embedding barrels in ceiling)
sheepluva
parents:
7659
diff
changeset
|
2634 |
|
6081
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
2635 |
if (not Gear^.dY.isNegative) and (TestCollisionYwithGear(Gear, 1) <> 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2636 |
begin |
3473
f80431269806
Increase minimum threshold for barrel damage to reduce likelihood of blowing one up on jumping out, increase damage to compensate (may need tweaking). Only apply dX for collision w/ kick if barrel is rolling.
nemo
parents:
3471
diff
changeset
|
2637 |
if (Gear^.dY > _0_2) and (k = gtExplosives) then |
f80431269806
Increase minimum threshold for barrel damage to reduce likelihood of blowing one up on jumping out, increase damage to compensate (may need tweaking). Only apply dX for collision w/ kick if barrel is rolling.
nemo
parents:
3471
diff
changeset
|
2638 |
inc(Gear^.Damage, hwRound(Gear^.dY * _70)); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2639 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2640 |
if Gear^.dY > _0_2 then |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2641 |
for i:= min(12, hwRound(Gear^.dY*_10)) downto 0 do |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2642 |
AddVisualGear(hwRound(Gear^.X) - 5 + Random(10), hwRound(Gear^.Y) + 12, vgtDust); |
8795 | 2643 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2644 |
Gear^.dY := - Gear^.dY * Gear^.Elasticity; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2645 |
if Gear^.dY > - _0_001 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2646 |
Gear^.dY := _0 |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2647 |
else if Gear^.dY < - _0_03 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2648 |
PlaySound(Gear^.ImpactSound); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2649 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2650 |
CheckGearDrowning(Gear); |
14958
896707084562
Don't render health crate and barrel health when drowning
Wuzzy <Wuzzy2@mail.ru>
parents:
14957
diff
changeset
|
2651 |
if ((Gear^.State and gstDrowning) <> 0) then |
896707084562
Don't render health crate and barrel health when drowning
Wuzzy <Wuzzy2@mail.ru>
parents:
14957
diff
changeset
|
2652 |
Gear^.RenderHealth:= false; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2653 |
end; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2654 |
|
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2655 |
if (Gear^.dY.QWordValue = 0) then |
9291
15f7bb217b66
Make add/delete consistent (this has bugged me for so long)
nemo
parents:
9289
diff
changeset
|
2656 |
AddCI(Gear) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2657 |
else if (Gear^.dY.QWordValue <> 0) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2658 |
DeleteCI(Gear) |
14
81f125629b25
- Mine checks whether a hedgehog is near less frequently
unc0rr
parents:
13
diff
changeset
|
2659 |
end; |
49 | 2660 |
|
2661 |
//////////////////////////////////////////////////////////////////////////////// |
|
2460 | 2662 |
|
2663 |
procedure doStepTarget(Gear: PGear); |
|
2664 |
begin |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2665 |
if (Gear^.Timer = 0) and (Gear^.Tag = 0) then |
9724
b3fefde4cff7
fixing position of spawning sparkles of target gears by applying a filthy workaround for a filthy bug in the filthy filthy doStepCase handler.
sheepluva
parents:
9723
diff
changeset
|
2666 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2667 |
PlaySound(sndWarp); |
9724
b3fefde4cff7
fixing position of spawning sparkles of target gears by applying a filthy workaround for a filthy bug in the filthy filthy doStepCase handler.
sheepluva
parents:
9723
diff
changeset
|
2668 |
// workaround: save spawn Y for doStepCase (which is a mess atm) |
b3fefde4cff7
fixing position of spawning sparkles of target gears by applying a filthy workaround for a filthy bug in the filthy filthy doStepCase handler.
sheepluva
parents:
9723
diff
changeset
|
2669 |
Gear^.Angle:= hwRound(Gear^.Y); |
b3fefde4cff7
fixing position of spawning sparkles of target gears by applying a filthy workaround for a filthy bug in the filthy filthy doStepCase handler.
sheepluva
parents:
9723
diff
changeset
|
2670 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2671 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2672 |
if (Gear^.Tag = 0) and (Gear^.Timer < 1000) then |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2673 |
inc(Gear^.Timer) |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2674 |
else if Gear^.Tag = 1 then |
4808 | 2675 |
Gear^.Tag := 2 |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2676 |
else if Gear^.Tag = 2 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2677 |
if Gear^.Timer > 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2678 |
dec(Gear^.Timer) |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
2679 |
else |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2680 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2681 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2682 |
exit; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2683 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2684 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2685 |
doStepCase(Gear) |
2460 | 2686 |
end; |
2687 |
||
2688 |
//////////////////////////////////////////////////////////////////////////////// |
|
854 | 2689 |
procedure doStepIdle(Gear: PGear); |
2690 |
begin |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2691 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2692 |
dec(Gear^.Timer); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2693 |
if Gear^.Timer = 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2694 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2695 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2696 |
AfterAttack |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2697 |
end |
854 | 2698 |
end; |
2699 |
||
5313
5e18eaef65d0
now scripts can create unique crates: dummy (empty) crates and booby traps. scripts can also set health crate values
Henek
parents:
5298
diff
changeset
|
2700 |
//////////////////////////////////////////////////////////////////////////////// |
79 | 2701 |
procedure doStepShover(Gear: PGear); |
8795 | 2702 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2703 |
HHGear: PGear; |
79 | 2704 |
begin |
12119 | 2705 |
dec(Gear^.Timer); |
2706 |
if Gear^.Timer = 0 then |
|
2707 |
begin |
|
2708 |
inc(Gear^.Tag); |
|
14030
d203bb36225f
and finally make the bat hit moving gears for completeness
alfadur
parents:
14029
diff
changeset
|
2709 |
Gear^.Timer := 50; |
d203bb36225f
and finally make the bat hit moving gears for completeness
alfadur
parents:
14029
diff
changeset
|
2710 |
if Gear^.Tag = 3 then |
d203bb36225f
and finally make the bat hit moving gears for completeness
alfadur
parents:
14029
diff
changeset
|
2711 |
begin |
d203bb36225f
and finally make the bat hit moving gears for completeness
alfadur
parents:
14029
diff
changeset
|
2712 |
ClearHitOrder(); |
d203bb36225f
and finally make the bat hit moving gears for completeness
alfadur
parents:
14029
diff
changeset
|
2713 |
RefillProximityCache(Gear, 100); |
d203bb36225f
and finally make the bat hit moving gears for completeness
alfadur
parents:
14029
diff
changeset
|
2714 |
end; |
12828 | 2715 |
end; |
2716 |
||
2717 |
if Gear^.Tag = 3 then |
|
12119 | 2718 |
begin |
2719 |
HHGear := Gear^.Hedgehog^.Gear; |
|
2720 |
HHGear^.State := HHGear^.State or gstNoDamage; |
|
2721 |
DeleteCI(HHGear); |
|
2722 |
||
14030
d203bb36225f
and finally make the bat hit moving gears for completeness
alfadur
parents:
14029
diff
changeset
|
2723 |
AmmoShoveCache(Gear, Gear^.Boom, 115); |
12119 | 2724 |
|
2725 |
HHGear^.State := (HHGear^.State and (not gstNoDamage)) or gstMoving; |
|
12828 | 2726 |
end |
2727 |
else if Gear^.Tag = 4 then |
|
2728 |
begin |
|
14030
d203bb36225f
and finally make the bat hit moving gears for completeness
alfadur
parents:
14029
diff
changeset
|
2729 |
ClearHitOrder(); |
d203bb36225f
and finally make the bat hit moving gears for completeness
alfadur
parents:
14029
diff
changeset
|
2730 |
ClearProximityCache(); |
12119 | 2731 |
Gear^.Timer := 250; |
2732 |
Gear^.doStep := @doStepIdle |
|
2733 |
end |
|
79 | 2734 |
end; |
2735 |
||
2736 |
//////////////////////////////////////////////////////////////////////////////// |
|
925 | 2737 |
procedure doStepWhip(Gear: PGear); |
8795 | 2738 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2739 |
HHGear: PGear; |
925 | 2740 |
i: LongInt; |
2741 |
begin |
|
4365 | 2742 |
HHGear := Gear^.Hedgehog^.Gear; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2743 |
HHGear^.State := HHGear^.State or gstNoDamage; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2744 |
DeleteCI(HHGear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2745 |
|
14029 | 2746 |
ClearHitOrder(); |
2747 |
RefillProximityCache(Gear, 100); |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2748 |
for i:= 0 to 3 do |
4578 | 2749 |
begin |
9723
31d10d684e90
whip: visual enhancements (hat'n'dust) as suggested by nemo
sheepluva
parents:
9721
diff
changeset
|
2750 |
AddVisualGear(hwRound(Gear^.X) + hwSign(Gear^.dX) * (10 + 6 * i), hwRound(Gear^.Y) + 12 + Random(6), vgtDust); |
14029 | 2751 |
AmmoShoveCache(Gear, Gear^.Boom, 25); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2752 |
Gear^.X := Gear^.X + Gear^.dX * 5 |
4578 | 2753 |
end; |
925 | 2754 |
|
14029 | 2755 |
ClearHitOrder(); |
2756 |
ClearProximityCache(); |
|
4182 | 2757 |
HHGear^.State := (HHGear^.State and (not gstNoDamage)) or gstMoving; |
2758 |
||
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2759 |
Gear^.Timer := 250; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2760 |
Gear^.doStep := @doStepIdle |
925 | 2761 |
end; |
2762 |
||
2763 |
//////////////////////////////////////////////////////////////////////////////// |
|
79 | 2764 |
procedure doStepFlame(Gear: PGear); |
8795 | 2765 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2766 |
gX,gY,i: LongInt; |
3609
bc63ed514b70
Minor fire tweak for readability and lethalness, remove exit condition that was hanging game (identified by jaylittle)
nemo
parents:
3603
diff
changeset
|
2767 |
sticky: Boolean; |
3751 | 2768 |
vgt: PVisualGear; |
10591 | 2769 |
tdX,tdY, f: HWFloat; |
9362
c9fdf8a3baf0
crude ice check that probably works well enough in most cases (so far there's just one ucollisions that returns a land pixel - might want to extend that)
nemo
parents:
9356
diff
changeset
|
2770 |
landPixel: Word; |
79 | 2771 |
begin |
15246
ebbc2f04b863
Make flames collide with bounce world edge again, properly this time
Wuzzy <Wuzzy2@mail.ru>
parents:
15245
diff
changeset
|
2772 |
WorldWrap(Gear); |
10586
dbb77726f0c6
add a half-second flighttime delay to flamethrower flames so they can leave the "barrel" of the flamethrower without burning the hog
nemo
parents:
10582
diff
changeset
|
2773 |
if Gear^.FlightTime > 0 then dec(Gear^.FlightTime); |
15014 | 2774 |
// There are 2 flame types: normal and sticky |
3609
bc63ed514b70
Minor fire tweak for readability and lethalness, remove exit condition that was hanging game (identified by jaylittle)
nemo
parents:
3603
diff
changeset
|
2775 |
sticky:= (Gear^.State and gsttmpFlag) <> 0; |
bc63ed514b70
Minor fire tweak for readability and lethalness, remove exit condition that was hanging game (identified by jaylittle)
nemo
parents:
3603
diff
changeset
|
2776 |
if not sticky then AllInactive := false; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2777 |
|
9362
c9fdf8a3baf0
crude ice check that probably works well enough in most cases (so far there's just one ucollisions that returns a land pixel - might want to extend that)
nemo
parents:
9356
diff
changeset
|
2778 |
landPixel:= TestCollisionYwithGear(Gear, 1); |
15014 | 2779 |
// Flame is in mid-air |
9362
c9fdf8a3baf0
crude ice check that probably works well enough in most cases (so far there's just one ucollisions that returns a land pixel - might want to extend that)
nemo
parents:
9356
diff
changeset
|
2780 |
if landPixel = 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2781 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2782 |
AllInactive := false; |
3751 | 2783 |
|
15014 | 2784 |
// Deals damage in mid-air if FlightTime = 0. |
2785 |
// Otherwise, flame is harmless in mid-air. |
|
2786 |
// Intended for use with scripts. |
|
10586
dbb77726f0c6
add a half-second flighttime delay to flamethrower flames so they can leave the "barrel" of the flamethrower without burning the hog
nemo
parents:
10582
diff
changeset
|
2787 |
if (GameTicks and $F = 0) and (Gear^.FlightTime = 0) then |
10578
814acf1511be
duplicate the ammoshove block into the falling fire area - this will make falling flames take out hogs in saucers, on rope, etc. no more dodging your own napalm strike by taking to the skies...
nemo
parents:
10547
diff
changeset
|
2788 |
begin |
814acf1511be
duplicate the ammoshove block into the falling fire area - this will make falling flames take out hogs in saucers, on rope, etc. no more dodging your own napalm strike by taking to the skies...
nemo
parents:
10547
diff
changeset
|
2789 |
Gear^.Radius := 7; |
814acf1511be
duplicate the ammoshove block into the falling fire area - this will make falling flames take out hogs in saucers, on rope, etc. no more dodging your own napalm strike by taking to the skies...
nemo
parents:
10547
diff
changeset
|
2790 |
tdX:= Gear^.dX; |
814acf1511be
duplicate the ammoshove block into the falling fire area - this will make falling flames take out hogs in saucers, on rope, etc. no more dodging your own napalm strike by taking to the skies...
nemo
parents:
10547
diff
changeset
|
2791 |
tdY:= Gear^.dY; |
814acf1511be
duplicate the ammoshove block into the falling fire area - this will make falling flames take out hogs in saucers, on rope, etc. no more dodging your own napalm strike by taking to the skies...
nemo
parents:
10547
diff
changeset
|
2792 |
Gear^.dX.QWordValue:= 120000000; |
814acf1511be
duplicate the ammoshove block into the falling fire area - this will make falling flames take out hogs in saucers, on rope, etc. no more dodging your own napalm strike by taking to the skies...
nemo
parents:
10547
diff
changeset
|
2793 |
Gear^.dY.QWordValue:= 429496730; |
814acf1511be
duplicate the ammoshove block into the falling fire area - this will make falling flames take out hogs in saucers, on rope, etc. no more dodging your own napalm strike by taking to the skies...
nemo
parents:
10547
diff
changeset
|
2794 |
Gear^.dX.isNegative:= getrandom(2)<>1; |
814acf1511be
duplicate the ammoshove block into the falling fire area - this will make falling flames take out hogs in saucers, on rope, etc. no more dodging your own napalm strike by taking to the skies...
nemo
parents:
10547
diff
changeset
|
2795 |
Gear^.dY.isNegative:= true; |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
2796 |
AmmoShove(Gear, Gear^.Boom, 125); |
10578
814acf1511be
duplicate the ammoshove block into the falling fire area - this will make falling flames take out hogs in saucers, on rope, etc. no more dodging your own napalm strike by taking to the skies...
nemo
parents:
10547
diff
changeset
|
2797 |
Gear^.dX:= tdX; |
814acf1511be
duplicate the ammoshove block into the falling fire area - this will make falling flames take out hogs in saucers, on rope, etc. no more dodging your own napalm strike by taking to the skies...
nemo
parents:
10547
diff
changeset
|
2798 |
Gear^.dY:= tdY; |
814acf1511be
duplicate the ammoshove block into the falling fire area - this will make falling flames take out hogs in saucers, on rope, etc. no more dodging your own napalm strike by taking to the skies...
nemo
parents:
10547
diff
changeset
|
2799 |
Gear^.Radius := 1 |
14362
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
2800 |
end; |
10578
814acf1511be
duplicate the ammoshove block into the falling fire area - this will make falling flames take out hogs in saucers, on rope, etc. no more dodging your own napalm strike by taking to the skies...
nemo
parents:
10547
diff
changeset
|
2801 |
|
3751 | 2802 |
if ((GameTicks mod 100) = 0) then |
2803 |
begin |
|
4443
d393b9ccd328
Add an extra pass in FindPlace for AI resurrection mode to try to make it unwinnable, add DeleteGear, DeleteVisualGear, AddVisualGear, GetVisualGearValues, SetVisualGearValues to Lua
nemo
parents:
4405
diff
changeset
|
2804 |
vgt:= AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtFire, gstTmpFlag); |
3751 | 2805 |
if vgt <> nil then |
2806 |
begin |
|
2807 |
vgt^.dx:= 0; |
|
2808 |
vgt^.dy:= 0; |
|
2809 |
vgt^.FrameTicks:= 1800 div (Gear^.Tag mod 3 + 2); |
|
2810 |
end; |
|
2811 |
end; |
|
2812 |
||
10591 | 2813 |
if (Gear^.dX.QWordValue > _2.QWordValue) |
2814 |
or (Gear^.dY.QWordValue > _2.QWordValue) |
|
2815 |
then |
|
2816 |
begin |
|
2817 |
// norm speed vector to length of 2 for fire particles to keep flying in the same direction |
|
10642
8fdfa2b77d83
Normalize to length of _1_9 to avoid endless normalization leading to fire particles floating midair indefinitely
unc0rr
parents:
10634
diff
changeset
|
2818 |
f:= _1_9 / Distance(Gear^.dX, Gear^.dY); |
10591 | 2819 |
Gear^.dX:= Gear^.dX * f; |
2820 |
Gear^.dY:= Gear^.dY * f; |
|
2821 |
end |
|
2822 |
else begin |
|
15014 | 2823 |
// Gravity and wind |
10591 | 2824 |
if Gear^.dX.QWordValue > _0_01.QWordValue then |
2825 |
Gear^.dX := Gear^.dX * _0_995; |
|
2826 |
||
2827 |
Gear^.dY := Gear^.dY + cGravity; |
|
2828 |
||
2829 |
if Gear^.dY.QWordValue > _0_2.QWordValue then |
|
2830 |
Gear^.dY := Gear^.dY * _0_995; |
|
2831 |
||
15246
ebbc2f04b863
Make flames collide with bounce world edge again, properly this time
Wuzzy <Wuzzy2@mail.ru>
parents:
15245
diff
changeset
|
2832 |
// Apply speed changes |
ebbc2f04b863
Make flames collide with bounce world edge again, properly this time
Wuzzy <Wuzzy2@mail.ru>
parents:
15245
diff
changeset
|
2833 |
|
ebbc2f04b863
Make flames collide with bounce world edge again, properly this time
Wuzzy <Wuzzy2@mail.ru>
parents:
15245
diff
changeset
|
2834 |
tdX:= Gear^.dX + cWindSpeed * 640; |
ebbc2f04b863
Make flames collide with bounce world edge again, properly this time
Wuzzy <Wuzzy2@mail.ru>
parents:
15245
diff
changeset
|
2835 |
// Don't apply wind speed if moving against bounce world edge |
ebbc2f04b863
Make flames collide with bounce world edge again, properly this time
Wuzzy <Wuzzy2@mail.ru>
parents:
15245
diff
changeset
|
2836 |
if (WorldEdge = weBounce) and |
ebbc2f04b863
Make flames collide with bounce world edge again, properly this time
Wuzzy <Wuzzy2@mail.ru>
parents:
15245
diff
changeset
|
2837 |
(((hwRound(Gear^.X + tdX) - Gear^.Radius < leftX) and (hwSign(tdX) = -1)) or |
ebbc2f04b863
Make flames collide with bounce world edge again, properly this time
Wuzzy <Wuzzy2@mail.ru>
parents:
15245
diff
changeset
|
2838 |
((hwRound(Gear^.X + tdX) + Gear^.Radius > rightX) and (hwSign(tdX) = 1))) then |
ebbc2f04b863
Make flames collide with bounce world edge again, properly this time
Wuzzy <Wuzzy2@mail.ru>
parents:
15245
diff
changeset
|
2839 |
Gear^.X := Gear^.X + Gear^.dX |
ebbc2f04b863
Make flames collide with bounce world edge again, properly this time
Wuzzy <Wuzzy2@mail.ru>
parents:
15245
diff
changeset
|
2840 |
else |
ebbc2f04b863
Make flames collide with bounce world edge again, properly this time
Wuzzy <Wuzzy2@mail.ru>
parents:
15245
diff
changeset
|
2841 |
// Apply dX and wind speed |
ebbc2f04b863
Make flames collide with bounce world edge again, properly this time
Wuzzy <Wuzzy2@mail.ru>
parents:
15245
diff
changeset
|
2842 |
Gear^.X := Gear^.X + tdX; |
ebbc2f04b863
Make flames collide with bounce world edge again, properly this time
Wuzzy <Wuzzy2@mail.ru>
parents:
15245
diff
changeset
|
2843 |
|
10591 | 2844 |
Gear^.Y := Gear^.Y + Gear^.dY; |
2845 |
end; |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2846 |
|
10354 | 2847 |
gX := hwRound(Gear^.X); |
2848 |
gY := hwRound(Gear^.Y); |
|
2849 |
||
15014 | 2850 |
// Extinguish in water |
10354 | 2851 |
if CheckCoordInWater(gX, gY) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2852 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2853 |
for i:= 0 to 3 do |
10354 | 2854 |
AddVisualGear(gX - 8 + Random(16), gY - 8 + Random(16), vgtSteam); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2855 |
PlaySound(sndVaporize); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2856 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2857 |
exit |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2858 |
end |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
2859 |
end |
15014 | 2860 |
// Flame is on terrain |
10015 | 2861 |
else |
9362
c9fdf8a3baf0
crude ice check that probably works well enough in most cases (so far there's just one ucollisions that returns a land pixel - might want to extend that)
nemo
parents:
9356
diff
changeset
|
2862 |
begin |
c9fdf8a3baf0
crude ice check that probably works well enough in most cases (so far there's just one ucollisions that returns a land pixel - might want to extend that)
nemo
parents:
9356
diff
changeset
|
2863 |
if (Gear^.Timer = 1) and (GameTicks and $3 = 0) then |
c9fdf8a3baf0
crude ice check that probably works well enough in most cases (so far there's just one ucollisions that returns a land pixel - might want to extend that)
nemo
parents:
9356
diff
changeset
|
2864 |
begin |
c9fdf8a3baf0
crude ice check that probably works well enough in most cases (so far there's just one ucollisions that returns a land pixel - might want to extend that)
nemo
parents:
9356
diff
changeset
|
2865 |
Gear^.Y:= Gear^.Y+_6; |
15014 | 2866 |
// Extinguish on ice |
9362
c9fdf8a3baf0
crude ice check that probably works well enough in most cases (so far there's just one ucollisions that returns a land pixel - might want to extend that)
nemo
parents:
9356
diff
changeset
|
2867 |
if (landPixel and lfIce <> 0) or (TestCollisionYwithGear(Gear, 1) and lfIce <> 0) then |
c9fdf8a3baf0
crude ice check that probably works well enough in most cases (so far there's just one ucollisions that returns a land pixel - might want to extend that)
nemo
parents:
9356
diff
changeset
|
2868 |
begin |
10379
caa5b40e405b
I a recent commit I caused flames to use uninitialized values. that lead to fire burning slow and desyncs. this commit fixes/reverts this
sheepluva
parents:
10372
diff
changeset
|
2869 |
gX := hwRound(Gear^.X); |
caa5b40e405b
I a recent commit I caused flames to use uninitialized values. that lead to fire burning slow and desyncs. this commit fixes/reverts this
sheepluva
parents:
10372
diff
changeset
|
2870 |
gY := hwRound(Gear^.Y) - 6; |
13566
acc69f506914
Use wrap-aware doMakeExplosion instead of DrawExplosion in uHandlersMess
Wuzzy <Wuzzy2@mail.ru>
parents:
13470
diff
changeset
|
2871 |
doMakeExplosion(gX, gY, 4, Gear^.Hedgehog, EXPLNoDamage or EXPLDoNotTouchAny or EXPLNoGfx); |
9362
c9fdf8a3baf0
crude ice check that probably works well enough in most cases (so far there's just one ucollisions that returns a land pixel - might want to extend that)
nemo
parents:
9356
diff
changeset
|
2872 |
PlaySound(sndVaporize); |
c9fdf8a3baf0
crude ice check that probably works well enough in most cases (so far there's just one ucollisions that returns a land pixel - might want to extend that)
nemo
parents:
9356
diff
changeset
|
2873 |
AddVisualGear(gX - 3 + Random(6), gY - 2, vgtSteam); |
c9fdf8a3baf0
crude ice check that probably works well enough in most cases (so far there's just one ucollisions that returns a land pixel - might want to extend that)
nemo
parents:
9356
diff
changeset
|
2874 |
DeleteGear(Gear); |
c9fdf8a3baf0
crude ice check that probably works well enough in most cases (so far there's just one ucollisions that returns a land pixel - might want to extend that)
nemo
parents:
9356
diff
changeset
|
2875 |
exit |
c9fdf8a3baf0
crude ice check that probably works well enough in most cases (so far there's just one ucollisions that returns a land pixel - might want to extend that)
nemo
parents:
9356
diff
changeset
|
2876 |
end; |
c9fdf8a3baf0
crude ice check that probably works well enough in most cases (so far there's just one ucollisions that returns a land pixel - might want to extend that)
nemo
parents:
9356
diff
changeset
|
2877 |
Gear^.Y:= Gear^.Y-_6 |
c9fdf8a3baf0
crude ice check that probably works well enough in most cases (so far there's just one ucollisions that returns a land pixel - might want to extend that)
nemo
parents:
9356
diff
changeset
|
2878 |
end; |
15014 | 2879 |
// Sticky flame damage |
9277
ad1ec7212ac7
reduce shove frequency (perf). reduce dX so that less time is spent sliding.
nemo
parents:
9251
diff
changeset
|
2880 |
if sticky and (GameTicks and $F = 0) then |
5024 | 2881 |
begin |
3603
b6b1989744ef
Grid the landscape, and shortcircuit checks on the collision array if there are no nearby checked in collisions to be collided with. This is a big win for fire's ammoshove in particular. Also add a +2 that seemed missing in the check, and update fire accordingly.
nemo
parents:
3594
diff
changeset
|
2882 |
Gear^.Radius := 7; |
5415
94e26612e2ec
Adjust "sticky" fire (molotov) so it makes better fire pits, by making the kicks more regular, yet of random left/right. Tweak napalm slightly along same lines. Probably needs more balancing.
nemo
parents:
5413
diff
changeset
|
2883 |
tdX:= Gear^.dX; |
94e26612e2ec
Adjust "sticky" fire (molotov) so it makes better fire pits, by making the kicks more regular, yet of random left/right. Tweak napalm slightly along same lines. Probably needs more balancing.
nemo
parents:
5413
diff
changeset
|
2884 |
tdY:= Gear^.dY; |
9277
ad1ec7212ac7
reduce shove frequency (perf). reduce dX so that less time is spent sliding.
nemo
parents:
9251
diff
changeset
|
2885 |
Gear^.dX.QWordValue:= 120000000; |
5415
94e26612e2ec
Adjust "sticky" fire (molotov) so it makes better fire pits, by making the kicks more regular, yet of random left/right. Tweak napalm slightly along same lines. Probably needs more balancing.
nemo
parents:
5413
diff
changeset
|
2886 |
Gear^.dY.QWordValue:= 429496730; |
94e26612e2ec
Adjust "sticky" fire (molotov) so it makes better fire pits, by making the kicks more regular, yet of random left/right. Tweak napalm slightly along same lines. Probably needs more balancing.
nemo
parents:
5413
diff
changeset
|
2887 |
Gear^.dX.isNegative:= getrandom(2)<>1; |
94e26612e2ec
Adjust "sticky" fire (molotov) so it makes better fire pits, by making the kicks more regular, yet of random left/right. Tweak napalm slightly along same lines. Probably needs more balancing.
nemo
parents:
5413
diff
changeset
|
2888 |
Gear^.dY.isNegative:= true; |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
2889 |
AmmoShove(Gear, Gear^.Boom, 125); |
5415
94e26612e2ec
Adjust "sticky" fire (molotov) so it makes better fire pits, by making the kicks more regular, yet of random left/right. Tweak napalm slightly along same lines. Probably needs more balancing.
nemo
parents:
5413
diff
changeset
|
2890 |
Gear^.dX:= tdX; |
94e26612e2ec
Adjust "sticky" fire (molotov) so it makes better fire pits, by making the kicks more regular, yet of random left/right. Tweak napalm slightly along same lines. Probably needs more balancing.
nemo
parents:
5413
diff
changeset
|
2891 |
Gear^.dY:= tdY; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2892 |
Gear^.Radius := 1 |
5024 | 2893 |
end; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
2894 |
if Gear^.Timer > 0 then |
5024 | 2895 |
begin |
2475 | 2896 |
dec(Gear^.Timer); |
2897 |
inc(Gear^.Damage) |
|
5024 | 2898 |
end |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2899 |
else |
15014 | 2900 |
// Flame burn-down handling |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2901 |
begin |
10379
caa5b40e405b
I a recent commit I caused flames to use uninitialized values. that lead to fire burning slow and desyncs. this commit fixes/reverts this
sheepluva
parents:
10372
diff
changeset
|
2902 |
gX := hwRound(Gear^.X); |
caa5b40e405b
I a recent commit I caused flames to use uninitialized values. that lead to fire burning slow and desyncs. this commit fixes/reverts this
sheepluva
parents:
10372
diff
changeset
|
2903 |
gY := hwRound(Gear^.Y); |
15014 | 2904 |
// Normal flame: Burns down quickly and must be destroyed before the turn ends |
3609
bc63ed514b70
Minor fire tweak for readability and lethalness, remove exit condition that was hanging game (identified by jaylittle)
nemo
parents:
3603
diff
changeset
|
2905 |
if not sticky then |
5024 | 2906 |
begin |
15014 | 2907 |
// Deal damage |
3640
54676a34b9ad
Reduce calls to expensive operations in fire. Slightly alters fire behaviour, but should still be reasonable
nemo
parents:
3609
diff
changeset
|
2908 |
if ((GameTicks and $1) = 0) then |
54676a34b9ad
Reduce calls to expensive operations in fire. Slightly alters fire behaviour, but should still be reasonable
nemo
parents:
3609
diff
changeset
|
2909 |
begin |
54676a34b9ad
Reduce calls to expensive operations in fire. Slightly alters fire behaviour, but should still be reasonable
nemo
parents:
3609
diff
changeset
|
2910 |
Gear^.Radius := 7; |
5415
94e26612e2ec
Adjust "sticky" fire (molotov) so it makes better fire pits, by making the kicks more regular, yet of random left/right. Tweak napalm slightly along same lines. Probably needs more balancing.
nemo
parents:
5413
diff
changeset
|
2911 |
tdX:= Gear^.dX; |
94e26612e2ec
Adjust "sticky" fire (molotov) so it makes better fire pits, by making the kicks more regular, yet of random left/right. Tweak napalm slightly along same lines. Probably needs more balancing.
nemo
parents:
5413
diff
changeset
|
2912 |
tdY:= Gear^.dY; |
94e26612e2ec
Adjust "sticky" fire (molotov) so it makes better fire pits, by making the kicks more regular, yet of random left/right. Tweak napalm slightly along same lines. Probably needs more balancing.
nemo
parents:
5413
diff
changeset
|
2913 |
Gear^.dX.QWordValue:= 214748365; |
94e26612e2ec
Adjust "sticky" fire (molotov) so it makes better fire pits, by making the kicks more regular, yet of random left/right. Tweak napalm slightly along same lines. Probably needs more balancing.
nemo
parents:
5413
diff
changeset
|
2914 |
Gear^.dY.QWordValue:= 429496730; |
94e26612e2ec
Adjust "sticky" fire (molotov) so it makes better fire pits, by making the kicks more regular, yet of random left/right. Tweak napalm slightly along same lines. Probably needs more balancing.
nemo
parents:
5413
diff
changeset
|
2915 |
Gear^.dX.isNegative:= getrandom(2)<>1; |
94e26612e2ec
Adjust "sticky" fire (molotov) so it makes better fire pits, by making the kicks more regular, yet of random left/right. Tweak napalm slightly along same lines. Probably needs more balancing.
nemo
parents:
5413
diff
changeset
|
2916 |
Gear^.dY.isNegative:= true; |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
2917 |
AmmoShove(Gear, Gear^.Boom * 3, 100); |
5415
94e26612e2ec
Adjust "sticky" fire (molotov) so it makes better fire pits, by making the kicks more regular, yet of random left/right. Tweak napalm slightly along same lines. Probably needs more balancing.
nemo
parents:
5413
diff
changeset
|
2918 |
Gear^.dX:= tdX; |
94e26612e2ec
Adjust "sticky" fire (molotov) so it makes better fire pits, by making the kicks more regular, yet of random left/right. Tweak napalm slightly along same lines. Probably needs more balancing.
nemo
parents:
5413
diff
changeset
|
2919 |
Gear^.dY:= tdY; |
3640
54676a34b9ad
Reduce calls to expensive operations in fire. Slightly alters fire behaviour, but should still be reasonable
nemo
parents:
3609
diff
changeset
|
2920 |
Gear^.Radius := 1; |
54676a34b9ad
Reduce calls to expensive operations in fire. Slightly alters fire behaviour, but should still be reasonable
nemo
parents:
3609
diff
changeset
|
2921 |
end |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2922 |
else if ((GameTicks and $3) = 3) then |
14593
34e810295d08
Remove a bunch of dead out-commented code
Wuzzy <Wuzzy2@mail.ru>
parents:
14591
diff
changeset
|
2923 |
doMakeExplosion(gX, gY, Gear^.Boom * 4, Gear^.Hedgehog, 0); |
8795 | 2924 |
|
3096
9330eead14fa
Remove Distance from flake kick, reduce calls to Random() in flame replacing w/ checks on game tick and a little randomness.
nemo
parents:
3094
diff
changeset
|
2925 |
if ((GameTicks and $7) = 0) and (Random(2) = 0) then |
7426
55b49cc1f33a
Changes for the benefit of pas2c. Use downto in for loops to avoid repeated calls of Random/GetRandom. Wrap nots.
nemo
parents:
7416
diff
changeset
|
2926 |
for i:= Random(2) downto 0 do |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2927 |
AddVisualGear(gX - 3 + Random(6), gY - 2, vgtSmoke); |
8795 | 2928 |
|
15014 | 2929 |
// Flame burn-out due to time |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2930 |
if Gear^.Health > 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2931 |
dec(Gear^.Health); |
15014 | 2932 |
|
2933 |
// Calculate time for next flame update with a bit of random jitter |
|
9809 | 2934 |
Gear^.Timer := 450 - Gear^.Tag * 8 + LongInt(GetRandom(2)) |
5024 | 2935 |
end |
15014 | 2936 |
// Sticky flame: Burns down slowly and persists between turns |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2937 |
else |
5024 | 2938 |
begin |
15014 | 2939 |
// Destroy land very slowly (low chance this gets called) |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2940 |
if ((GameTicks and $7FF) = 0) and ((GameFlags and gfSolidLand) = 0) then |
5024 | 2941 |
begin |
13566
acc69f506914
Use wrap-aware doMakeExplosion instead of DrawExplosion in uHandlersMess
Wuzzy <Wuzzy2@mail.ru>
parents:
13470
diff
changeset
|
2942 |
doMakeExplosion(gX, gY, 4, Gear^.Hedgehog, EXPLNoDamage or EXPLDoNotTouchAny or EXPLNoGfx); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2943 |
|
7426
55b49cc1f33a
Changes for the benefit of pas2c. Use downto in for loops to avoid repeated calls of Random/GetRandom. Wrap nots.
nemo
parents:
7416
diff
changeset
|
2944 |
for i:= Random(3) downto 0 do |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2945 |
AddVisualGear(gX - 3 + Random(6), gY - 2, vgtSmoke); |
5024 | 2946 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2947 |
|
15014 | 2948 |
// Calculate time for next flame update with a bit of random jitter |
9809 | 2949 |
Gear^.Timer := 100 - Gear^.Tag * 3 + LongInt(GetRandom(2)); |
15014 | 2950 |
|
2951 |
// Flame burn-out due to time |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2952 |
if (Gear^.Damage > 3000+Gear^.Tag*1500) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2953 |
Gear^.Health := 0 |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2954 |
end |
2424
b52344de23ae
In progress, trying to make a fire for molotov cocktail. Normal fire should still work fairly normally.
nemo
parents:
2376
diff
changeset
|
2955 |
end |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2956 |
end; |
15014 | 2957 |
// This kills the flame |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2958 |
if Gear^.Health = 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2959 |
begin |
10379
caa5b40e405b
I a recent commit I caused flames to use uninitialized values. that lead to fire burning slow and desyncs. this commit fixes/reverts this
sheepluva
parents:
10372
diff
changeset
|
2960 |
gX := hwRound(Gear^.X); |
caa5b40e405b
I a recent commit I caused flames to use uninitialized values. that lead to fire burning slow and desyncs. this commit fixes/reverts this
sheepluva
parents:
10372
diff
changeset
|
2961 |
gY := hwRound(Gear^.Y); |
3609
bc63ed514b70
Minor fire tweak for readability and lethalness, remove exit condition that was hanging game (identified by jaylittle)
nemo
parents:
3603
diff
changeset
|
2962 |
if not sticky then |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2963 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2964 |
if ((GameTicks and $3) = 0) and (Random(1) = 0) then |
7426
55b49cc1f33a
Changes for the benefit of pas2c. Use downto in for loops to avoid repeated calls of Random/GetRandom. Wrap nots.
nemo
parents:
7416
diff
changeset
|
2965 |
for i:= Random(2) downto 0 do |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2966 |
AddVisualGear(gX - 3 + Random(6), gY - 2, vgtSmoke); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2967 |
end |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2968 |
else |
7426
55b49cc1f33a
Changes for the benefit of pas2c. Use downto in for loops to avoid repeated calls of Random/GetRandom. Wrap nots.
nemo
parents:
7416
diff
changeset
|
2969 |
for i:= Random(3) downto 0 do |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2970 |
AddVisualGear(gX - 3 + Random(6), gY - 2, vgtSmoke); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2971 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2972 |
DeleteGear(Gear) |
14575 | 2973 |
end |
79 | 2974 |
end; |
82 | 2975 |
|
2976 |
//////////////////////////////////////////////////////////////////////////////// |
|
2977 |
procedure doStepFirePunchWork(Gear: PGear); |
|
8795 | 2978 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2979 |
HHGear: PGear; |
82 | 2980 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2981 |
AllInactive := false; |
3894 | 2982 |
if ((Gear^.Message and gmDestroy) <> 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2983 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2984 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2985 |
AfterAttack; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2986 |
exit |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2987 |
end; |
82 | 2988 |
|
4365 | 2989 |
HHGear := Gear^.Hedgehog^.Gear; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2990 |
if hwRound(HHGear^.Y) <= Gear^.Tag - 2 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2991 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2992 |
Gear^.Tag := hwRound(HHGear^.Y); |
10887 | 2993 |
DrawTunnel(HHGear^.X - int2hwFloat(cHHRadius), HHGear^.Y - _1, _0_5, _0, cHHRadius * 4+2, 2); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2994 |
HHGear^.State := HHGear^.State or gstNoDamage; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
2995 |
Gear^.Y := HHGear^.Y; |
14027
105793e575d6
make firepunch hit moving gears (airmines are not amused)
alfadur
parents:
14026
diff
changeset
|
2996 |
AmmoShoveCache(Gear, Gear^.Boom, 40); |
6450 | 2997 |
HHGear^.State := HHGear^.State and (not gstNoDamage) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
2998 |
end; |
351 | 2999 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3000 |
HHGear^.dY := HHGear^.dY + cGravity; |
9824 | 3001 |
if Gear^.Timer > 0 then dec(Gear^.Timer); |
3002 |
if not (HHGear^.dY.isNegative) or (Gear^.Timer = 0) then |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3003 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3004 |
HHGear^.State := HHGear^.State or gstMoving; |
14026
31bdb759d98b
prevent firepunch from hitting the same gear multiple times
alfadur
parents:
14019
diff
changeset
|
3005 |
ClearHitOrder(); |
14027
105793e575d6
make firepunch hit moving gears (airmines are not amused)
alfadur
parents:
14026
diff
changeset
|
3006 |
ClearProximityCache(); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3007 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3008 |
AfterAttack; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3009 |
exit |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3010 |
end; |
2089 | 3011 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3012 |
if CheckLandValue(hwRound(HHGear^.X), hwRound(HHGear^.Y + HHGear^.dY + SignAs(_6,Gear^.dY)), |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3013 |
lfIndestructible) then |
14027
105793e575d6
make firepunch hit moving gears (airmines are not amused)
alfadur
parents:
14026
diff
changeset
|
3014 |
HHGear^.Y := HHGear^.Y + HHGear^.dY; |
105793e575d6
make firepunch hit moving gears (airmines are not amused)
alfadur
parents:
14026
diff
changeset
|
3015 |
|
105793e575d6
make firepunch hit moving gears (airmines are not amused)
alfadur
parents:
14026
diff
changeset
|
3016 |
if (Gear^.Timer mod 200) = 0 then |
105793e575d6
make firepunch hit moving gears (airmines are not amused)
alfadur
parents:
14026
diff
changeset
|
3017 |
RefillProximityCache(Gear, 300); |
82 | 3018 |
end; |
3019 |
||
3020 |
procedure doStepFirePunch(Gear: PGear); |
|
8795 | 3021 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3022 |
HHGear: PGear; |
82 | 3023 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3024 |
AllInactive := false; |
4365 | 3025 |
HHGear := Gear^.Hedgehog^.Gear; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3026 |
DeleteCI(HHGear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3027 |
HHGear^.dX := SignAs(cLittle, Gear^.dX); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3028 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3029 |
HHGear^.dY := - _0_3; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3030 |
|
14026
31bdb759d98b
prevent firepunch from hitting the same gear multiple times
alfadur
parents:
14019
diff
changeset
|
3031 |
ClearHitOrder(); |
14027
105793e575d6
make firepunch hit moving gears (airmines are not amused)
alfadur
parents:
14026
diff
changeset
|
3032 |
RefillProximityCache(Gear, 300); |
14026
31bdb759d98b
prevent firepunch from hitting the same gear multiple times
alfadur
parents:
14019
diff
changeset
|
3033 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3034 |
Gear^.X := HHGear^.X; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3035 |
Gear^.dX := SignAs(_0_45, Gear^.dX); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3036 |
Gear^.dY := - _0_9; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3037 |
Gear^.doStep := @doStepFirePunchWork; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3038 |
DrawTunnel(HHGear^.X - int2hwFloat(cHHRadius), HHGear^.Y + _1, _0_5, _0, cHHRadius * 4, 5); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3039 |
|
7053 | 3040 |
PlaySoundV(TSound(ord(sndFirePunch1) + GetRandom(6)), HHGear^.Hedgehog^.Team^.voicepack) |
82 | 3041 |
end; |
3042 |
||
263 | 3043 |
//////////////////////////////////////////////////////////////////////////////// |
3044 |
||
929
9456e1e77369
- Continue preparation for implementing attack from rope and parachute
unc0rr
parents:
928
diff
changeset
|
3045 |
procedure doStepParachuteWork(Gear: PGear); |
8795 | 3046 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3047 |
HHGear: PGear; |
15166
d47122a0e4b4
Properly set dx/dy of hedgehog on parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15155
diff
changeset
|
3048 |
deltaX, deltaY: hwFloat; |
211 | 3049 |
begin |
4365 | 3050 |
HHGear := Gear^.Hedgehog^.Gear; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3051 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3052 |
inc(Gear^.Timer); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3053 |
|
6081
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
3054 |
if (TestCollisionYwithGear(HHGear, 1) <> 0) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3055 |
or ((HHGear^.State and gstHHDriven) = 0) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3056 |
or CheckGearDrowning(HHGear) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3057 |
or ((Gear^.Message and gmAttack) <> 0) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3058 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3059 |
with HHGear^ do |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3060 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3061 |
Message := 0; |
15169
95b72e81a866
Fix hog facing direction when landing with parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15166
diff
changeset
|
3062 |
if Gear^.Tag = 1 then |
95b72e81a866
Fix hog facing direction when landing with parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15166
diff
changeset
|
3063 |
dX := _1 |
95b72e81a866
Fix hog facing direction when landing with parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15166
diff
changeset
|
3064 |
else |
95b72e81a866
Fix hog facing direction when landing with parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15166
diff
changeset
|
3065 |
dX := - _1; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3066 |
SetLittle(dX); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3067 |
dY := _0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3068 |
State := State or gstMoving; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3069 |
end; |
13977
2568fa516733
Fix hog can drop more than 2 s. mines if first one was dropped from utility, then stop using that utility
Wuzzy <Wuzzy2@mail.ru>
parents:
13898
diff
changeset
|
3070 |
if (GetAmmoEntry(HHGear^.Hedgehog^, amParachute)^.Count >= 1) and ((Ammoz[HHGear^.Hedgehog^.CurAmmoType].Ammo.Propz and ammoprop_AltUse) <> 0) and (HHGear^.Hedgehog^.MultiShootAttacks = 0) then |
12820
4c1c468725ff
Fix desync when dropping weapon from parachute or jetpack
Wuzzy <Wuzzy2@mail.ru>
parents:
12815
diff
changeset
|
3071 |
HHGear^.Hedgehog^.CurAmmoType:= amParachute; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3072 |
isCursorVisible := false; |
4372 | 3073 |
ApplyAmmoChanges(HHGear^.Hedgehog^); |
14575 | 3074 |
DeleteGear(Gear); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3075 |
exit |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3076 |
end; |
211 | 3077 |
|
14957
d6a8ef85cf53
Fix parachute moving hog very fast or making it stuck when bumping into wall while facing the opposite direction (bug 742)
Wuzzy <Wuzzy2@mail.ru>
parents:
14899
diff
changeset
|
3078 |
deltaX:= _0; |
d6a8ef85cf53
Fix parachute moving hog very fast or making it stuck when bumping into wall while facing the opposite direction (bug 742)
Wuzzy <Wuzzy2@mail.ru>
parents:
14899
diff
changeset
|
3079 |
deltaX:= deltaX + cWindSpeed * 200; |
15166
d47122a0e4b4
Properly set dx/dy of hedgehog on parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15155
diff
changeset
|
3080 |
deltaY:= _0; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3081 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3082 |
if (Gear^.Message and gmLeft) <> 0 then |
14957
d6a8ef85cf53
Fix parachute moving hog very fast or making it stuck when bumping into wall while facing the opposite direction (bug 742)
Wuzzy <Wuzzy2@mail.ru>
parents:
14899
diff
changeset
|
3083 |
deltaX := deltaX - cMaxWindSpeed * 80 |
8795 | 3084 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3085 |
else if (Gear^.Message and gmRight) <> 0 then |
14957
d6a8ef85cf53
Fix parachute moving hog very fast or making it stuck when bumping into wall while facing the opposite direction (bug 742)
Wuzzy <Wuzzy2@mail.ru>
parents:
14899
diff
changeset
|
3086 |
deltaX := deltaX + cMaxWindSpeed * 80; |
8795 | 3087 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3088 |
if (Gear^.Message and gmUp) <> 0 then |
15166
d47122a0e4b4
Properly set dx/dy of hedgehog on parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15155
diff
changeset
|
3089 |
deltaY := deltaY - cGravity * 40 |
8795 | 3090 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3091 |
else if (Gear^.Message and gmDown) <> 0 then |
15166
d47122a0e4b4
Properly set dx/dy of hedgehog on parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15155
diff
changeset
|
3092 |
deltaY := deltaY + cGravity * 40; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3093 |
|
14957
d6a8ef85cf53
Fix parachute moving hog very fast or making it stuck when bumping into wall while facing the opposite direction (bug 742)
Wuzzy <Wuzzy2@mail.ru>
parents:
14899
diff
changeset
|
3094 |
HHGear^.X := HHGear^.X + deltaX; |
4774 | 3095 |
// don't drift into obstacles |
14957
d6a8ef85cf53
Fix parachute moving hog very fast or making it stuck when bumping into wall while facing the opposite direction (bug 742)
Wuzzy <Wuzzy2@mail.ru>
parents:
14899
diff
changeset
|
3096 |
if TestCollisionXwithGear(HHGear, hwSign(deltaX)) <> 0 then |
15166
d47122a0e4b4
Properly set dx/dy of hedgehog on parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15155
diff
changeset
|
3097 |
begin |
14957
d6a8ef85cf53
Fix parachute moving hog very fast or making it stuck when bumping into wall while facing the opposite direction (bug 742)
Wuzzy <Wuzzy2@mail.ru>
parents:
14899
diff
changeset
|
3098 |
HHGear^.X := HHGear^.X - int2hwFloat(hwSign(deltaX)); |
15166
d47122a0e4b4
Properly set dx/dy of hedgehog on parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15155
diff
changeset
|
3099 |
deltaX:= _0; |
d47122a0e4b4
Properly set dx/dy of hedgehog on parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15155
diff
changeset
|
3100 |
end; |
d47122a0e4b4
Properly set dx/dy of hedgehog on parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15155
diff
changeset
|
3101 |
deltaY := deltaY + cGravity * 100; |
d47122a0e4b4
Properly set dx/dy of hedgehog on parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15155
diff
changeset
|
3102 |
HHGear^.Y := HHGear^.Y + deltaY; |
d47122a0e4b4
Properly set dx/dy of hedgehog on parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15155
diff
changeset
|
3103 |
|
d47122a0e4b4
Properly set dx/dy of hedgehog on parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15155
diff
changeset
|
3104 |
HHGear^.dX := deltaX; |
d47122a0e4b4
Properly set dx/dy of hedgehog on parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15155
diff
changeset
|
3105 |
HHGear^.dY := deltaY; |
d47122a0e4b4
Properly set dx/dy of hedgehog on parachute
Wuzzy <Wuzzy2@mail.ru>
parents:
15155
diff
changeset
|
3106 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3107 |
Gear^.X := HHGear^.X; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3108 |
Gear^.Y := HHGear^.Y |
263 | 3109 |
end; |
211 | 3110 |
|
929
9456e1e77369
- Continue preparation for implementing attack from rope and parachute
unc0rr
parents:
928
diff
changeset
|
3111 |
procedure doStepParachute(Gear: PGear); |
8795 | 3112 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3113 |
HHGear: PGear; |
929
9456e1e77369
- Continue preparation for implementing attack from rope and parachute
unc0rr
parents:
928
diff
changeset
|
3114 |
begin |
4365 | 3115 |
HHGear := Gear^.Hedgehog^.Gear; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3116 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3117 |
DeleteCI(HHGear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3118 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3119 |
AfterAttack; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3120 |
|
15531
6ddfde71ba6a
Remove parachute early if hog is inside land
Wuzzy <Wuzzy2@mail.ru>
parents:
15498
diff
changeset
|
3121 |
// Delete parachute early if hog already collides |
6ddfde71ba6a
Remove parachute early if hog is inside land
Wuzzy <Wuzzy2@mail.ru>
parents:
15498
diff
changeset
|
3122 |
if (TestCollisionXwithGear(HHGear, -1) <> 0) and (TestCollisionXwithGear(HHGear, 1) <> 0) then |
6ddfde71ba6a
Remove parachute early if hog is inside land
Wuzzy <Wuzzy2@mail.ru>
parents:
15498
diff
changeset
|
3123 |
begin |
6ddfde71ba6a
Remove parachute early if hog is inside land
Wuzzy <Wuzzy2@mail.ru>
parents:
15498
diff
changeset
|
3124 |
HHGear^.dY := cGravity * 100; |
6ddfde71ba6a
Remove parachute early if hog is inside land
Wuzzy <Wuzzy2@mail.ru>
parents:
15498
diff
changeset
|
3125 |
isCursorVisible:= false; |
6ddfde71ba6a
Remove parachute early if hog is inside land
Wuzzy <Wuzzy2@mail.ru>
parents:
15498
diff
changeset
|
3126 |
ApplyAmmoChanges(HHGear^.Hedgehog^); |
6ddfde71ba6a
Remove parachute early if hog is inside land
Wuzzy <Wuzzy2@mail.ru>
parents:
15498
diff
changeset
|
3127 |
DeleteGear(Gear); |
6ddfde71ba6a
Remove parachute early if hog is inside land
Wuzzy <Wuzzy2@mail.ru>
parents:
15498
diff
changeset
|
3128 |
exit; |
6ddfde71ba6a
Remove parachute early if hog is inside land
Wuzzy <Wuzzy2@mail.ru>
parents:
15498
diff
changeset
|
3129 |
end; |
6ddfde71ba6a
Remove parachute early if hog is inside land
Wuzzy <Wuzzy2@mail.ru>
parents:
15498
diff
changeset
|
3130 |
|
11342
aa3f886c6298
fix hedgehog on parachute facing in wrong direction if parachute opens during double-jump
sheepluva
parents:
11305
diff
changeset
|
3131 |
// make sure hog doesn't end up facing in wrong direction due to high jump |
aa3f886c6298
fix hedgehog on parachute facing in wrong direction if parachute opens during double-jump
sheepluva
parents:
11305
diff
changeset
|
3132 |
if (HHGear^.State and gstHHHJump) <> 0 then |
aa3f886c6298
fix hedgehog on parachute facing in wrong direction if parachute opens during double-jump
sheepluva
parents:
11305
diff
changeset
|
3133 |
HHGear^.dX.isNegative := (not HHGear^.dX.isNegative); |
aa3f886c6298
fix hedgehog on parachute facing in wrong direction if parachute opens during double-jump
sheepluva
parents:
11305
diff
changeset
|
3134 |
|
aa3f886c6298
fix hedgehog on parachute facing in wrong direction if parachute opens during double-jump
sheepluva
parents:
11305
diff
changeset
|
3135 |
HHGear^.State := HHGear^.State and (not (gstAttacking or gstAttacked or gstMoving or gstHHJumping or gstHHHJump)); |
6450 | 3136 |
HHGear^.Message := HHGear^.Message and (not gmAttack); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3137 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3138 |
Gear^.doStep := @doStepParachuteWork; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3139 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3140 |
Gear^.Message := HHGear^.Message; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3141 |
doStepParachuteWork(Gear) |
929
9456e1e77369
- Continue preparation for implementing attack from rope and parachute
unc0rr
parents:
928
diff
changeset
|
3142 |
end; |
9456e1e77369
- Continue preparation for implementing attack from rope and parachute
unc0rr
parents:
928
diff
changeset
|
3143 |
|
263 | 3144 |
//////////////////////////////////////////////////////////////////////////////// |
3145 |
procedure doStepAirAttackWork(Gear: PGear); |
|
15251
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3146 |
var uw, nuw: boolean; |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3147 |
tmpFloat: hwFloat; |
15258
5c91c5191085
Give snorkel to air plane pilot in weSea
Wuzzy <Wuzzy2@mail.ru>
parents:
15256
diff
changeset
|
3148 |
i: LongInt; |
263 | 3149 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3150 |
AllInactive := false; |
15254
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3151 |
if (WorldEdge = weWrap) then |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3152 |
if (WorldWrap(Gear)) then |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3153 |
inc(Gear^.Power); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3154 |
Gear^.X := Gear^.X + cAirPlaneSpeed * Gear^.Tag; |
15254
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3155 |
if (Gear^.Health > 0) and (Gear^.Power >= Gear^.WDTimer) and (((Gear^.Tag = 1) and (not (Gear^.X < Gear^.dX))) or ((Gear^.Tag = -1) and (not (Gear^.X > Gear^.dX)))) then |
5612
2638dec1b323
This really should have been a TPoint for consistency
nemo
parents:
5606
diff
changeset
|
3156 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3157 |
dec(Gear^.Health); |
15254
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3158 |
Gear^.FlightTime:= 0; |
15245
f16376e9374f
Remove all placement restrictions of air attack and friends
Wuzzy <Wuzzy2@mail.ru>
parents:
15243
diff
changeset
|
3159 |
// Spawn missile |
f16376e9374f
Remove all placement restrictions of air attack and friends
Wuzzy <Wuzzy2@mail.ru>
parents:
15243
diff
changeset
|
3160 |
case Gear^.State of |
f16376e9374f
Remove all placement restrictions of air attack and friends
Wuzzy <Wuzzy2@mail.ru>
parents:
15243
diff
changeset
|
3161 |
0: FollowGear := AddGear(hwRound(Gear^.X), hwRound(Gear^.Y), gtAirBomb, 0, cBombsSpeed * Gear^.Tag, _0, 0); |
f16376e9374f
Remove all placement restrictions of air attack and friends
Wuzzy <Wuzzy2@mail.ru>
parents:
15243
diff
changeset
|
3162 |
1: FollowGear := AddGear(hwRound(Gear^.X), hwRound(Gear^.Y), gtMine, 0, cBombsSpeed * Gear^.Tag, _0, 0); |
f16376e9374f
Remove all placement restrictions of air attack and friends
Wuzzy <Wuzzy2@mail.ru>
parents:
15243
diff
changeset
|
3163 |
2: FollowGear := AddGear(hwRound(Gear^.X), hwRound(Gear^.Y), gtNapalmBomb, 0, cBombsSpeed * Gear^.Tag, _0, 0); |
f16376e9374f
Remove all placement restrictions of air attack and friends
Wuzzy <Wuzzy2@mail.ru>
parents:
15243
diff
changeset
|
3164 |
3: FollowGear := AddGear(hwRound(Gear^.X), hwRound(Gear^.Y), gtDrill, gsttmpFlag, cBombsSpeed * Gear^.Tag, _0, Gear^.Timer + 1); |
f16376e9374f
Remove all placement restrictions of air attack and friends
Wuzzy <Wuzzy2@mail.ru>
parents:
15243
diff
changeset
|
3165 |
end; |
15254
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3166 |
Gear^.dX := Gear^.X + int2hwFloat(Gear^.Damage * Gear^.Tag); |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3167 |
if (WorldEdge = weWrap) then |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3168 |
begin |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3169 |
Gear^.dX := int2hwFloat(CalcWorldWrap(hwRound(Gear^.dX), 0)); |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3170 |
if (((Gear^.Tag = 1) and (not (Gear^.X < Gear^.dX))) or ((Gear^.Tag = -1) and (not (Gear^.X > Gear^.dX)))) then |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3171 |
inc(Gear^.WDTimer); |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3172 |
end; |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3173 |
|
15245
f16376e9374f
Remove all placement restrictions of air attack and friends
Wuzzy <Wuzzy2@mail.ru>
parents:
15243
diff
changeset
|
3174 |
if CheckCoordInWater(hwRound(Gear^.X), hwRound(Gear^.Y)) then |
f16376e9374f
Remove all placement restrictions of air attack and friends
Wuzzy <Wuzzy2@mail.ru>
parents:
15243
diff
changeset
|
3175 |
FollowGear^.State:= FollowGear^.State or gstSubmersible; |
15250
b96868956514
Air attack: Fix some issues with sound channel
Wuzzy <Wuzzy2@mail.ru>
parents:
15249
diff
changeset
|
3176 |
end; |
b96868956514
Air attack: Fix some issues with sound channel
Wuzzy <Wuzzy2@mail.ru>
parents:
15249
diff
changeset
|
3177 |
|
15254
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3178 |
if (Gear^.Health = 0) then |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3179 |
inc(Gear^.FlightTime); |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3180 |
|
15256
66dcb7728e01
Air attack: Fix infintie sound when target is at extreme X pos
Wuzzy <Wuzzy2@mail.ru>
parents:
15255
diff
changeset
|
3181 |
if (Gear^.SoundChannel <> -1) and (WorldEdge <> weSea) and (Gear^.FlightTime > 20) then |
66dcb7728e01
Air attack: Fix infintie sound when target is at extreme X pos
Wuzzy <Wuzzy2@mail.ru>
parents:
15255
diff
changeset
|
3182 |
begin |
66dcb7728e01
Air attack: Fix infintie sound when target is at extreme X pos
Wuzzy <Wuzzy2@mail.ru>
parents:
15255
diff
changeset
|
3183 |
StopSoundChan(Gear^.SoundChannel, 4000); |
66dcb7728e01
Air attack: Fix infintie sound when target is at extreme X pos
Wuzzy <Wuzzy2@mail.ru>
parents:
15255
diff
changeset
|
3184 |
Gear^.SoundChannel := -1; |
66dcb7728e01
Air attack: Fix infintie sound when target is at extreme X pos
Wuzzy <Wuzzy2@mail.ru>
parents:
15255
diff
changeset
|
3185 |
end; |
66dcb7728e01
Air attack: Fix infintie sound when target is at extreme X pos
Wuzzy <Wuzzy2@mail.ru>
parents:
15255
diff
changeset
|
3186 |
|
15250
b96868956514
Air attack: Fix some issues with sound channel
Wuzzy <Wuzzy2@mail.ru>
parents:
15249
diff
changeset
|
3187 |
// Particles |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3188 |
if (GameTicks and $3F) = 0 then |
15249
1dd99fc2a0e8
Air attack: Replace smoke with bubbles when underwater
Wuzzy <Wuzzy2@mail.ru>
parents:
15247
diff
changeset
|
3189 |
if CheckCoordInWater(hwRound(Gear^.X), hwRound(Gear^.Y)) then |
15258
5c91c5191085
Give snorkel to air plane pilot in weSea
Wuzzy <Wuzzy2@mail.ru>
parents:
15256
diff
changeset
|
3190 |
begin |
5c91c5191085
Give snorkel to air plane pilot in weSea
Wuzzy <Wuzzy2@mail.ru>
parents:
15256
diff
changeset
|
3191 |
// air plane bubbles |
5c91c5191085
Give snorkel to air plane pilot in weSea
Wuzzy <Wuzzy2@mail.ru>
parents:
15256
diff
changeset
|
3192 |
for i:=1 to 3 do |
5c91c5191085
Give snorkel to air plane pilot in weSea
Wuzzy <Wuzzy2@mail.ru>
parents:
15256
diff
changeset
|
3193 |
AddVisualGear(hwRound(Gear^.X) - 8 + Random(16), hwRound(Gear^.Y) - 8 + Random(16), vgtBubble); |
5c91c5191085
Give snorkel to air plane pilot in weSea
Wuzzy <Wuzzy2@mail.ru>
parents:
15256
diff
changeset
|
3194 |
// pilot's snorkel bubbles |
5c91c5191085
Give snorkel to air plane pilot in weSea
Wuzzy <Wuzzy2@mail.ru>
parents:
15256
diff
changeset
|
3195 |
if random(2) = 0 then |
5c91c5191085
Give snorkel to air plane pilot in weSea
Wuzzy <Wuzzy2@mail.ru>
parents:
15256
diff
changeset
|
3196 |
AddVisualGear(hwRound(Gear^.X) + 10, hwRound(Gear^.Y) - 50, vgtBubble); |
5c91c5191085
Give snorkel to air plane pilot in weSea
Wuzzy <Wuzzy2@mail.ru>
parents:
15256
diff
changeset
|
3197 |
end |
15249
1dd99fc2a0e8
Air attack: Replace smoke with bubbles when underwater
Wuzzy <Wuzzy2@mail.ru>
parents:
15247
diff
changeset
|
3198 |
else |
15258
5c91c5191085
Give snorkel to air plane pilot in weSea
Wuzzy <Wuzzy2@mail.ru>
parents:
15256
diff
changeset
|
3199 |
// smoke |
15249
1dd99fc2a0e8
Air attack: Replace smoke with bubbles when underwater
Wuzzy <Wuzzy2@mail.ru>
parents:
15247
diff
changeset
|
3200 |
AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtSmokeTrace); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3201 |
|
15250
b96868956514
Air attack: Fix some issues with sound channel
Wuzzy <Wuzzy2@mail.ru>
parents:
15249
diff
changeset
|
3202 |
// Get rid of gear and cleanup |
15254
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3203 |
if ((WorldEdge = weWrap) and (Gear^.FlightTime >= 4000)) or |
15674
3d8c2ab2b98b
Tweak airplane spawn point to avoid appear out of nowhere
Wuzzy <Wuzzy2@mail.ru>
parents:
15670
diff
changeset
|
3204 |
((WorldEdge <> weWrap) and (((hwRound(Gear^.X) - Gear^.Radius > (LAND_WIDTH+2048)) or (hwRound(Gear^.X) + Gear^.Radius < -2048) or ((Gear^.Message and gmDestroy) > 0)))) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3205 |
begin |
15250
b96868956514
Air attack: Fix some issues with sound channel
Wuzzy <Wuzzy2@mail.ru>
parents:
15249
diff
changeset
|
3206 |
// fail-safe: instanly stop sound if it wasn't disabled before |
b96868956514
Air attack: Fix some issues with sound channel
Wuzzy <Wuzzy2@mail.ru>
parents:
15249
diff
changeset
|
3207 |
if (Gear^.SoundChannel <> -1) then |
b96868956514
Air attack: Fix some issues with sound channel
Wuzzy <Wuzzy2@mail.ru>
parents:
15249
diff
changeset
|
3208 |
begin |
b96868956514
Air attack: Fix some issues with sound channel
Wuzzy <Wuzzy2@mail.ru>
parents:
15249
diff
changeset
|
3209 |
StopSoundChan(Gear^.SoundChannel); |
b96868956514
Air attack: Fix some issues with sound channel
Wuzzy <Wuzzy2@mail.ru>
parents:
15249
diff
changeset
|
3210 |
Gear^.SoundChannel := -1; |
b96868956514
Air attack: Fix some issues with sound channel
Wuzzy <Wuzzy2@mail.ru>
parents:
15249
diff
changeset
|
3211 |
end; |
15253
a9a1f5824076
Air attack: Add simple appear/disappear effect in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15251
diff
changeset
|
3212 |
if (WorldEdge = weWrap) then |
a9a1f5824076
Air attack: Add simple appear/disappear effect in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15251
diff
changeset
|
3213 |
AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtBigExplosion); |
15251
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3214 |
DeleteGear(Gear); |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3215 |
exit; |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3216 |
end; |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3217 |
|
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3218 |
uw := (Gear^.Karma <> 0); // Was plane underwater last tick? |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3219 |
nuw := CheckCoordInWater(hwRound(Gear^.X) + Gear^.Radius * Gear^.Tag, hwRound(Gear^.Y)); // Is plane underwater now? |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3220 |
|
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3221 |
// if water entered or left |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3222 |
if nuw <> uw then |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3223 |
begin |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3224 |
tmpFloat:= Gear^.dX; |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3225 |
Gear^.dX := cAirPlaneSpeed * Gear^.Tag; |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3226 |
AddSplashForGear(Gear, false); |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3227 |
Gear^.dX := tmpFloat; |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3228 |
StopSoundChan(Gear^.SoundChannel); |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3229 |
if nuw then |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3230 |
begin |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3231 |
Gear^.SoundChannel := LoopSound(sndPlaneWater); |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3232 |
StopSoundChan(Gear^.SoundChannel, 4000); |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3233 |
Gear^.SoundChannel := -1; |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3234 |
Gear^.Karma := 1; |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3235 |
end |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3236 |
else |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3237 |
begin |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3238 |
Gear^.SoundChannel := LoopSound(sndPlane); |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3239 |
Gear^.Karma := 0; |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3240 |
end; |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3241 |
end; |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3242 |
|
263 | 3243 |
end; |
3244 |
||
3245 |
procedure doStepAirAttack(Gear: PGear); |
|
15245
f16376e9374f
Remove all placement restrictions of air attack and friends
Wuzzy <Wuzzy2@mail.ru>
parents:
15243
diff
changeset
|
3246 |
var HHGear: PGear; |
263 | 3247 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3248 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3249 |
|
15775 | 3250 |
HHGear:= nil; |
3251 |
||
14586
833ab5b359e5
Deny air attack in bounce world edge if target is in "impossible" position
Wuzzy <Wuzzy2@mail.ru>
parents:
14581
diff
changeset
|
3252 |
if (Gear^.Hedgehog <> nil) and (Gear^.Hedgehog^.Gear <> nil) then |
833ab5b359e5
Deny air attack in bounce world edge if target is in "impossible" position
Wuzzy <Wuzzy2@mail.ru>
parents:
14581
diff
changeset
|
3253 |
HHGear:= Gear^.Hedgehog^.Gear; |
833ab5b359e5
Deny air attack in bounce world edge if target is in "impossible" position
Wuzzy <Wuzzy2@mail.ru>
parents:
14581
diff
changeset
|
3254 |
|
833ab5b359e5
Deny air attack in bounce world edge if target is in "impossible" position
Wuzzy <Wuzzy2@mail.ru>
parents:
14581
diff
changeset
|
3255 |
if (HHGear <> nil) then |
833ab5b359e5
Deny air attack in bounce world edge if target is in "impossible" position
Wuzzy <Wuzzy2@mail.ru>
parents:
14581
diff
changeset
|
3256 |
PlaySoundV(sndIncoming, Gear^.Hedgehog^.Team^.voicepack); |
14756
2d859d34e6f6
Fix turn end if placing air attack in bouncy world edge map was denied
Wuzzy <Wuzzy2@mail.ru>
parents:
14753
diff
changeset
|
3257 |
AfterAttack; |
2d859d34e6f6
Fix turn end if placing air attack in bouncy world edge map was denied
Wuzzy <Wuzzy2@mail.ru>
parents:
14753
diff
changeset
|
3258 |
CurAmmoGear := nil; |
14586
833ab5b359e5
Deny air attack in bounce world edge if target is in "impossible" position
Wuzzy <Wuzzy2@mail.ru>
parents:
14581
diff
changeset
|
3259 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3260 |
if Gear^.X.QWordValue = 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3261 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3262 |
Gear^.Tag := 1; |
15254
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3263 |
if (WorldEdge = weWrap) then |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3264 |
Gear^.X := int2hwFloat(CalcWorldWrap(Gear^.Target.X + max(384, LAND_WIDTH shr 2), 0)) |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3265 |
else |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3266 |
Gear^.X := -_2048; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3267 |
end |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3268 |
else |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3269 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3270 |
Gear^.Tag := -1; |
15254
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3271 |
if (WorldEdge = weWrap) then |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3272 |
Gear^.X := int2hwFloat(CalcWorldWrap(Gear^.Target.X - max(384, LAND_WIDTH shr 2), 0)) |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3273 |
else |
15674
3d8c2ab2b98b
Tweak airplane spawn point to avoid appear out of nowhere
Wuzzy <Wuzzy2@mail.ru>
parents:
15670
diff
changeset
|
3274 |
Gear^.X := int2hwFloat(LAND_WIDTH + 2048); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3275 |
end; |
1507 | 3276 |
|
14588
5de4d470dafe
Tweak height limit of air attack in bounce edge maps
Wuzzy <Wuzzy2@mail.ru>
parents:
14587
diff
changeset
|
3277 |
Gear^.Y := int2hwFloat(topY - 300); |
15253
a9a1f5824076
Air attack: Add simple appear/disappear effect in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15251
diff
changeset
|
3278 |
|
a9a1f5824076
Air attack: Add simple appear/disappear effect in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15251
diff
changeset
|
3279 |
// Appear out of nowhere in wrap |
a9a1f5824076
Air attack: Add simple appear/disappear effect in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15251
diff
changeset
|
3280 |
if (WorldEdge = weWrap) then |
a9a1f5824076
Air attack: Add simple appear/disappear effect in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15251
diff
changeset
|
3281 |
AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtBigExplosion); |
a9a1f5824076
Air attack: Add simple appear/disappear effect in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15251
diff
changeset
|
3282 |
|
11540 | 3283 |
Gear^.dX := int2hwFloat(Gear^.Target.X) - int2hwFloat(Gear^.Tag * (Gear^.Health-1) * Gear^.Damage) / 2; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3284 |
|
4778
1565a553d200
have napalm strike bombs explode right over the target
sheepluva
parents:
4774
diff
changeset
|
3285 |
// calcs for Napalm Strike, so that it will hit the target (without wind at least :P) |
1565a553d200
have napalm strike bombs explode right over the target
sheepluva
parents:
4774
diff
changeset
|
3286 |
if (Gear^.State = 2) then |
8795 | 3287 |
Gear^.dX := Gear^.dX - cBombsSpeed * Gear^.Tag * 900 |
4778
1565a553d200
have napalm strike bombs explode right over the target
sheepluva
parents:
4774
diff
changeset
|
3288 |
// calcs for regular falling gears |
5612
2638dec1b323
This really should have been a TPoint for consistency
nemo
parents:
5606
diff
changeset
|
3289 |
else if (int2hwFloat(Gear^.Target.Y) - Gear^.Y > _0) then |
2638dec1b323
This really should have been a TPoint for consistency
nemo
parents:
5606
diff
changeset
|
3290 |
Gear^.dX := Gear^.dX - cBombsSpeed * hwSqrt((int2hwFloat(Gear^.Target.Y) - Gear^.Y) * 2 / |
4778
1565a553d200
have napalm strike bombs explode right over the target
sheepluva
parents:
4774
diff
changeset
|
3291 |
cGravity) * Gear^.Tag; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3292 |
|
15254
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3293 |
if (WorldEdge = weWrap) then |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3294 |
begin |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3295 |
Gear^.dX := int2hwFloat(CalcWorldWrap(hwRound(Gear^.dX), 0)); |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3296 |
if (((Gear^.Tag = 1) and (not (Gear^.X < Gear^.dX))) or ((Gear^.Tag = -1) and (not (Gear^.X > Gear^.dX)))) then |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3297 |
Gear^.WDTimer:= 1; |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3298 |
end; |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3299 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3300 |
Gear^.doStep := @doStepAirAttackWork; |
15251
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3301 |
|
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3302 |
if (WorldEdge = weSea) then |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3303 |
begin |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3304 |
Gear^.SoundChannel := LoopSound(sndPlaneWater, 4000); |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3305 |
Gear^.Karma := 1; |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3306 |
end |
15254
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3307 |
else if (WorldEdge = weWrap) then |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3308 |
begin |
15264
c70de34686ac
Add small plane sound fade-in in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15258
diff
changeset
|
3309 |
Gear^.SoundChannel := LoopSound(sndPlane, 500); |
15254
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3310 |
Gear^.Karma := 0; |
b189d6a2ecda
Cleanup gtAirAttack behaviour in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
15253
diff
changeset
|
3311 |
end |
15251
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3312 |
else |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3313 |
begin |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3314 |
Gear^.SoundChannel := LoopSound(sndPlane, 4000); |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3315 |
Gear^.Karma := 0; |
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3316 |
end; |
4956
48e1f9a04c28
usound: added function for loops with fade in and out
koda
parents:
4886
diff
changeset
|
3317 |
|
15699 | 3318 |
if (GameFlags and gfInfAttack) = 0 then |
3319 |
FollowGear:= Gear; |
|
3320 |
||
263 | 3321 |
end; |
3322 |
||
3323 |
//////////////////////////////////////////////////////////////////////////////// |
|
3324 |
||
3325 |
procedure doStepAirBomb(Gear: PGear); |
|
3326 |
begin |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3327 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3328 |
doStepFallingGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3329 |
if (Gear^.State and gstCollision) <> 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3330 |
begin |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
3331 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
9954 | 3332 |
{$IFNDEF PAS2C} |
8204 | 3333 |
with mobileRecord do |
3334 |
if (performRumble <> nil) and (not fastUntilLag) then |
|
3335 |
performRumble(kSystemSoundID_Vibrate); |
|
9954 | 3336 |
{$ENDIF} |
14575 | 3337 |
DeleteGear(Gear); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3338 |
exit |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3339 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3340 |
if (GameTicks and $3F) = 0 then |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3341 |
AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtSmokeTrace) |
211 | 3342 |
end; |
409 | 3343 |
|
3344 |
//////////////////////////////////////////////////////////////////////////////// |
|
3345 |
||
3346 |
procedure doStepGirder(Gear: PGear); |
|
8795 | 3347 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3348 |
HHGear: PGear; |
1915 | 3349 |
x, y, tx, ty: hwFloat; |
9505
56e0cca99e20
Allow girder construction to wrap. Makes wrapping w/ large bodies of water a bit more interesting.
nemo
parents:
9487
diff
changeset
|
3350 |
rx: LongInt; |
9768
08799c901a42
Add rubber utility. Graphics are still incomplete. Also flag snow/ice in theme config.
nemo
parents:
9767
diff
changeset
|
3351 |
LandFlags: Word; |
10251
a3b42e81803c
collision indicator on failed girder placement (especially useful with rubberband I guess). still needs some tweaks but I am going to bed now :P
sheepluva
parents:
10234
diff
changeset
|
3352 |
warn: PVisualGear; |
a3b42e81803c
collision indicator on failed girder placement (especially useful with rubberband I guess). still needs some tweaks but I am going to bed now :P
sheepluva
parents:
10234
diff
changeset
|
3353 |
distFail: boolean; |
409 | 3354 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3355 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3356 |
|
4365 | 3357 |
HHGear := Gear^.Hedgehog^.Gear; |
5612
2638dec1b323
This really should have been a TPoint for consistency
nemo
parents:
5606
diff
changeset
|
3358 |
tx := int2hwFloat(Gear^.Target.X); |
2638dec1b323
This really should have been a TPoint for consistency
nemo
parents:
5606
diff
changeset
|
3359 |
ty := int2hwFloat(Gear^.Target.Y); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3360 |
x := HHGear^.X; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3361 |
y := HHGear^.Y; |
9505
56e0cca99e20
Allow girder construction to wrap. Makes wrapping w/ large bodies of water a bit more interesting.
nemo
parents:
9487
diff
changeset
|
3362 |
rx:= hwRound(x); |
56e0cca99e20
Allow girder construction to wrap. Makes wrapping w/ large bodies of water a bit more interesting.
nemo
parents:
9487
diff
changeset
|
3363 |
|
9768
08799c901a42
Add rubber utility. Graphics are still incomplete. Also flag snow/ice in theme config.
nemo
parents:
9767
diff
changeset
|
3364 |
LandFlags:= 0; |
9811
66a7959869f0
make rubber bouncy even in winter. was considering icy as well but, one, evil, two, would prob want ice sprite like girder
nemo
parents:
9809
diff
changeset
|
3365 |
if Gear^.AmmoType = amRubber then LandFlags:= lfBouncy |
66a7959869f0
make rubber bouncy even in winter. was considering icy as well but, one, evil, two, would prob want ice sprite like girder
nemo
parents:
9809
diff
changeset
|
3366 |
else if cIce then LandFlags:= lfIce; |
9768
08799c901a42
Add rubber utility. Graphics are still incomplete. Also flag snow/ice in theme config.
nemo
parents:
9767
diff
changeset
|
3367 |
|
11057
adb5ef54da54
global variable for defining construction distance limit. value smaller 1 means no limit (wip)
sheepluva
parents:
11046
diff
changeset
|
3368 |
distFail:= (cBuildMaxDist > 0) and ((hwRound(Distance(tx - x, ty - y)) > cBuildMaxDist) and ((WorldEdge <> weWrap) or |
9505
56e0cca99e20
Allow girder construction to wrap. Makes wrapping w/ large bodies of water a bit more interesting.
nemo
parents:
9487
diff
changeset
|
3369 |
( |
11057
adb5ef54da54
global variable for defining construction distance limit. value smaller 1 means no limit (wip)
sheepluva
parents:
11046
diff
changeset
|
3370 |
(hwRound(Distance(tx - int2hwFloat(rightX+(rx-leftX)), ty - y)) > cBuildMaxDist) and |
adb5ef54da54
global variable for defining construction distance limit. value smaller 1 means no limit (wip)
sheepluva
parents:
11046
diff
changeset
|
3371 |
(hwRound(Distance(tx - int2hwFloat(leftX-(rightX-rx)), ty - y)) > cBuildMaxDist) |
10251
a3b42e81803c
collision indicator on failed girder placement (especially useful with rubberband I guess). still needs some tweaks but I am going to bed now :P
sheepluva
parents:
10234
diff
changeset
|
3372 |
))); |
a3b42e81803c
collision indicator on failed girder placement (especially useful with rubberband I guess). still needs some tweaks but I am going to bed now :P
sheepluva
parents:
10234
diff
changeset
|
3373 |
if distFail |
15323
9299f43ba0ec
disallow placing girders over airmines and moving hogs
alfadur
parents:
15318
diff
changeset
|
3374 |
or CheckGearsUnderSprite(Ammoz[Gear^.AmmoType].PosSprite, Gear^.Target.X - SpritesData[Ammoz[Gear^.AmmoType].PosSprite].Width div 2, Gear^.Target.Y - SpritesData[Ammoz[Gear^.AmmoType].PosSprite].Height div 2, Gear^.State) |
10286
1940e937fc08
fix TryPlaceOnLand's ambiguity/messup wrt to making terrain indestructible (had boolean parameter for indestructible AND landflags parameters that could contain lfIndestructibly)
sheepluva
parents:
10253
diff
changeset
|
3375 |
or (not TryPlaceOnLand(Gear^.Target.X - SpritesData[Ammoz[Gear^.AmmoType].PosSprite].Width div 2, Gear^.Target.Y - SpritesData[Ammoz[Gear^.AmmoType].PosSprite].Height div 2, Ammoz[Gear^.AmmoType].PosSprite, Gear^.State, true, LandFlags)) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3376 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3377 |
PlaySound(sndDenied); |
10251
a3b42e81803c
collision indicator on failed girder placement (especially useful with rubberband I guess). still needs some tweaks but I am going to bed now :P
sheepluva
parents:
10234
diff
changeset
|
3378 |
if not distFail then |
a3b42e81803c
collision indicator on failed girder placement (especially useful with rubberband I guess). still needs some tweaks but I am going to bed now :P
sheepluva
parents:
10234
diff
changeset
|
3379 |
begin |
10298
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3380 |
warn:= AddVisualGear(Gear^.Target.X, Gear^.Target.Y, vgtNoPlaceWarn, 0, true); |
10251
a3b42e81803c
collision indicator on failed girder placement (especially useful with rubberband I guess). still needs some tweaks but I am going to bed now :P
sheepluva
parents:
10234
diff
changeset
|
3381 |
if warn <> nil then |
a3b42e81803c
collision indicator on failed girder placement (especially useful with rubberband I guess). still needs some tweaks but I am going to bed now :P
sheepluva
parents:
10234
diff
changeset
|
3382 |
warn^.Tex := GetPlaceCollisionTex(Gear^.Target.X - SpritesData[Ammoz[Gear^.AmmoType].PosSprite].Width div 2, Gear^.Target.Y - SpritesData[Ammoz[Gear^.AmmoType].PosSprite].Height div 2, Ammoz[Gear^.AmmoType].PosSprite, Gear^.State); |
a3b42e81803c
collision indicator on failed girder placement (especially useful with rubberband I guess). still needs some tweaks but I am going to bed now :P
sheepluva
parents:
10234
diff
changeset
|
3383 |
end; |
6450 | 3384 |
HHGear^.Message := HHGear^.Message and (not gmAttack); |
3385 |
HHGear^.State := HHGear^.State and (not gstAttacking); |
|
10818
f642a28cab0c
Add placement of airmines in engine outside of hog proximity. Has a bug, only protecting 1st team. Also fix a spelling error and rename gstHHChooseTarget to gstChooseTarget
nemo
parents:
10815
diff
changeset
|
3386 |
HHGear^.State := HHGear^.State or gstChooseTarget; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3387 |
isCursorVisible := true; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3388 |
DeleteGear(Gear) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3389 |
end |
8795 | 3390 |
else |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3391 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3392 |
PlaySound(sndPlaced); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3393 |
DeleteGear(Gear); |
14575 | 3394 |
AfterAttack |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3395 |
end; |
1914 | 3396 |
|
6450 | 3397 |
HHGear^.State := HHGear^.State and (not (gstAttacking or gstAttacked)); |
3398 |
HHGear^.Message := HHGear^.Message and (not gmAttack); |
|
409 | 3399 |
end; |
520 | 3400 |
|
3401 |
//////////////////////////////////////////////////////////////////////////////// |
|
525 | 3402 |
procedure doStepTeleportAfter(Gear: PGear); |
8795 | 3403 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3404 |
HHGear: PGear; |
912 | 3405 |
begin |
4365 | 3406 |
HHGear := Gear^.Hedgehog^.Gear; |
11070
f9a03078dd4f
Add some HHGear nil checks to teleport. google bug #974
nemo
parents:
11057
diff
changeset
|
3407 |
if HHGear <> nil then doStepHedgehogMoving(HHGear); |
7659 | 3408 |
// if not infattack mode wait for hedgehog finish falling to collect cases |
3409 |
if ((GameFlags and gfInfAttack) <> 0) |
|
11070
f9a03078dd4f
Add some HHGear nil checks to teleport. google bug #974
nemo
parents:
11057
diff
changeset
|
3410 |
or (HHGear = nil) |
7659 | 3411 |
or ((HHGear^.State and gstMoving) = 0) |
11070
f9a03078dd4f
Add some HHGear nil checks to teleport. google bug #974
nemo
parents:
11057
diff
changeset
|
3412 |
or (HHGear^.Damage > 0) |
15267
4aa19b21707d
Fix cursor not being disabled when teleporting hog into water
Wuzzy <Wuzzy2@mail.ru>
parents:
15265
diff
changeset
|
3413 |
or ((HHGear^.State and gstDrowning) <> 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3414 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3415 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3416 |
AfterAttack |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3417 |
end |
912 | 3418 |
end; |
3419 |
||
3420 |
procedure doStepTeleportAnim(Gear: PGear); |
|
525 | 3421 |
begin |
11070
f9a03078dd4f
Add some HHGear nil checks to teleport. google bug #974
nemo
parents:
11057
diff
changeset
|
3422 |
if (Gear^.Hedgehog^.Gear = nil) or (Gear^.Hedgehog^.Gear^.Damage > 0) then |
7659 | 3423 |
begin |
3424 |
DeleteGear(Gear); |
|
3425 |
AfterAttack; |
|
14577 | 3426 |
exit |
7659 | 3427 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3428 |
inc(Gear^.Timer); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3429 |
if Gear^.Timer = 65 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3430 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3431 |
Gear^.Timer := 0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3432 |
inc(Gear^.Pos); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3433 |
if Gear^.Pos = 11 then |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3434 |
Gear^.doStep := @doStepTeleportAfter |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3435 |
end; |
525 | 3436 |
end; |
520 | 3437 |
|
3438 |
procedure doStepTeleport(Gear: PGear); |
|
8795 | 3439 |
var |
10298
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3440 |
lx, ty, y, oy: LongInt; |
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3441 |
HHGear : PGear; |
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3442 |
valid : Boolean; |
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3443 |
warn : PVisualGear; |
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3444 |
const |
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3445 |
ytol = cHHRadius; |
520 | 3446 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3447 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3448 |
|
4365 | 3449 |
HHGear := Gear^.Hedgehog^.Gear; |
11070
f9a03078dd4f
Add some HHGear nil checks to teleport. google bug #974
nemo
parents:
11057
diff
changeset
|
3450 |
if HHGear = nil then |
f9a03078dd4f
Add some HHGear nil checks to teleport. google bug #974
nemo
parents:
11057
diff
changeset
|
3451 |
begin |
f9a03078dd4f
Add some HHGear nil checks to teleport. google bug #974
nemo
parents:
11057
diff
changeset
|
3452 |
DeleteGear(Gear); |
f9a03078dd4f
Add some HHGear nil checks to teleport. google bug #974
nemo
parents:
11057
diff
changeset
|
3453 |
exit |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
3454 |
end; |
10298
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3455 |
|
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3456 |
valid:= false; |
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3457 |
|
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3458 |
lx:= Gear^.Target.X - SpritesData[sprHHTelepMask].Width div 2; // left |
12789
28782e03b8f0
Fix CheckWorldWrap not correctly checking for bounce edge. Also fix teleport @ bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12764
diff
changeset
|
3459 |
if WorldEdge <> weBounce then |
28782e03b8f0
Fix CheckWorldWrap not correctly checking for bounce edge. Also fix teleport @ bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12764
diff
changeset
|
3460 |
lx:= CalcWorldWrap(lx, SpritesData[sprHHTelepMask].Width div 2); // Take world edge into account |
10298
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3461 |
ty:= Gear^.Target.Y - SpritesData[sprHHTelepMask].Height div 2; // top |
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3462 |
|
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3463 |
// remember original target location |
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3464 |
oy:= Gear^.Target.Y; |
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3465 |
|
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3466 |
for y:= ty downto ty - ytol do |
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3467 |
begin |
10897
8ea636ce120a
Add options to set colouring, behind existing land, and horizontal/vertical flipping to PlaceSprite
nemo
parents:
10895
diff
changeset
|
3468 |
if TryPlaceOnLand(lx, y, sprHHTelepMask, 0, false, not hasBorder, false, false, false, false, 0, $FFFFFFFF) then |
10298
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3469 |
begin |
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3470 |
valid:= true; |
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3471 |
break; |
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3472 |
end; |
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3473 |
dec(Gear^.Target.Y); |
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3474 |
end; |
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3475 |
|
12789
28782e03b8f0
Fix CheckWorldWrap not correctly checking for bounce edge. Also fix teleport @ bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12764
diff
changeset
|
3476 |
if (WorldEdge = weBounce) and ((Gear^.Target.X < LeftX) or (Gear^.Target.X > RightX)) then |
28782e03b8f0
Fix CheckWorldWrap not correctly checking for bounce edge. Also fix teleport @ bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12764
diff
changeset
|
3477 |
valid:= false; |
28782e03b8f0
Fix CheckWorldWrap not correctly checking for bounce edge. Also fix teleport @ bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12764
diff
changeset
|
3478 |
|
10298
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3479 |
if not valid then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3480 |
begin |
6450 | 3481 |
HHGear^.Message := HHGear^.Message and (not gmAttack); |
3482 |
HHGear^.State := HHGear^.State and (not gstAttacking); |
|
10818
f642a28cab0c
Add placement of airmines in engine outside of hog proximity. Has a bug, only protecting 1st team. Also fix a spelling error and rename gstHHChooseTarget to gstChooseTarget
nemo
parents:
10815
diff
changeset
|
3483 |
HHGear^.State := HHGear^.State or gstChooseTarget; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3484 |
isCursorVisible := true; |
10298
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3485 |
warn:= AddVisualGear(Gear^.Target.X, oy, vgtNoPlaceWarn, 0, true); |
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3486 |
if warn <> nil then |
7d5d93f9a515
make using the teleporter a bit less challenging
sheepluva
parents:
10286
diff
changeset
|
3487 |
warn^.Tex := GetPlaceCollisionTex(lx, ty, sprHHTelepMask, 0); |
10676
7111b4a46b5c
fix for Issue 855: Failure to teleport rarely makes engine crash
sheepluva
parents:
10663
diff
changeset
|
3488 |
DeleteGear(Gear); |
7111b4a46b5c
fix for Issue 855: Failure to teleport rarely makes engine crash
sheepluva
parents:
10663
diff
changeset
|
3489 |
PlaySound(sndDenied); |
7111b4a46b5c
fix for Issue 855: Failure to teleport rarely makes engine crash
sheepluva
parents:
10663
diff
changeset
|
3490 |
exit |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3491 |
end |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3492 |
else |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3493 |
begin |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
3494 |
DeleteCI(HHGear); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
3495 |
SetAllHHToActive; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3496 |
Gear^.doStep := @doStepTeleportAnim; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3497 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3498 |
// copy old HH position and direction to Gear (because we need them for drawing the vanishing hog) |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3499 |
Gear^.dX := HHGear^.dX; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3500 |
// retrieve the cursor direction (it was previously copied to X so it doesn't get lost) |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3501 |
HHGear^.dX.isNegative := (Gear^.X.QWordValue <> 0); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3502 |
Gear^.X := HHGear^.X; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3503 |
Gear^.Y := HHGear^.Y; |
5612
2638dec1b323
This really should have been a TPoint for consistency
nemo
parents:
5606
diff
changeset
|
3504 |
HHGear^.X := int2hwFloat(Gear^.Target.X); |
2638dec1b323
This really should have been a TPoint for consistency
nemo
parents:
5606
diff
changeset
|
3505 |
HHGear^.Y := int2hwFloat(Gear^.Target.Y); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3506 |
HHGear^.State := HHGear^.State or gstMoving; |
10547
cc439790ebae
fix for Issue 828: Manual placement animation is drawn twice
sheepluva
parents:
10545
diff
changeset
|
3507 |
if not Gear^.Hedgehog^.Unplaced then |
cc439790ebae
fix for Issue 828: Manual placement animation is drawn twice
sheepluva
parents:
10545
diff
changeset
|
3508 |
Gear^.State:= Gear^.State or gstAnimation; |
7659 | 3509 |
Gear^.Hedgehog^.Unplaced := false; |
3510 |
isCursorVisible := false; |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
3511 |
playSound(sndWarp) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3512 |
end; |
5612
2638dec1b323
This really should have been a TPoint for consistency
nemo
parents:
5606
diff
changeset
|
3513 |
Gear^.Target.X:= NoPointX |
520 | 3514 |
end; |
534 | 3515 |
|
3516 |
//////////////////////////////////////////////////////////////////////////////// |
|
3517 |
procedure doStepSwitcherWork(Gear: PGear); |
|
8795 | 3518 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3519 |
HHGear: PGear; |
7341
d70478d265ec
Fix crash when hedgehog dies while switching from it
unc0rr
parents:
7339
diff
changeset
|
3520 |
hedgehog: PHedgehog; |
6992 | 3521 |
State: Longword; |
10494 | 3522 |
switchDir: Longword; |
14997 | 3523 |
oldUid: Longword; |
534 | 3524 |
begin |
15873
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
3525 |
if CurrentHedgehog^.Gear = nil then |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
3526 |
begin |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
3527 |
DeleteGear(Gear); |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
3528 |
exit |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
3529 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3530 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3531 |
|
10145
67b255f839db
allow switching through hogs in reverse order with PRECISE+HOGSWITCH
sheepluva
parents:
10135
diff
changeset
|
3532 |
if ((Gear^.Message and (not (gmSwitch or gmPrecise))) <> 0) or (TurnTimeLeft = 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3533 |
begin |
7341
d70478d265ec
Fix crash when hedgehog dies while switching from it
unc0rr
parents:
7339
diff
changeset
|
3534 |
hedgehog := Gear^.Hedgehog; |
d70478d265ec
Fix crash when hedgehog dies while switching from it
unc0rr
parents:
7339
diff
changeset
|
3535 |
ApplyAmmoChanges(hedgehog^); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3536 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3537 |
HHGear := CurrentHedgehog^.Gear; |
4372 | 3538 |
ApplyAmmoChanges(HHGear^.Hedgehog^); |
14575 | 3539 |
DeleteGear(Gear); |
15348
2196aa902d2d
Fix switching arrows overlapping with hog tags of own hog (while finger is active)
Wuzzy <Wuzzy2@mail.ru>
parents:
15323
diff
changeset
|
3540 |
bShowSwitcher:= false; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3541 |
exit |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3542 |
end; |
534 | 3543 |
|
15155
0e0b5fc1674e
Fix floating hog when switching to moving hog
Wuzzy <Wuzzy2@mail.ru>
parents:
15072
diff
changeset
|
3544 |
HHGear := CurrentHedgehog^.Gear; |
3894 | 3545 |
if (Gear^.Message and gmSwitch) <> 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3546 |
begin |
14997 | 3547 |
oldUid:= HHGear^.uid; |
6450 | 3548 |
HHGear^.Message := HHGear^.Message and (not gmSwitch); |
3549 |
Gear^.Message := Gear^.Message and (not gmSwitch); |
|
10145
67b255f839db
allow switching through hogs in reverse order with PRECISE+HOGSWITCH
sheepluva
parents:
10135
diff
changeset
|
3550 |
|
67b255f839db
allow switching through hogs in reverse order with PRECISE+HOGSWITCH
sheepluva
parents:
10135
diff
changeset
|
3551 |
// switching in reverse direction |
67b255f839db
allow switching through hogs in reverse order with PRECISE+HOGSWITCH
sheepluva
parents:
10135
diff
changeset
|
3552 |
if (Gear^.Message and gmPrecise) <> 0 then |
67b255f839db
allow switching through hogs in reverse order with PRECISE+HOGSWITCH
sheepluva
parents:
10135
diff
changeset
|
3553 |
begin |
67b255f839db
allow switching through hogs in reverse order with PRECISE+HOGSWITCH
sheepluva
parents:
10135
diff
changeset
|
3554 |
HHGear^.Message := HHGear^.Message and (not gmPrecise); |
67b255f839db
allow switching through hogs in reverse order with PRECISE+HOGSWITCH
sheepluva
parents:
10135
diff
changeset
|
3555 |
switchDir:= CurrentTeam^.HedgehogsNumber - 1; |
67b255f839db
allow switching through hogs in reverse order with PRECISE+HOGSWITCH
sheepluva
parents:
10135
diff
changeset
|
3556 |
end |
67b255f839db
allow switching through hogs in reverse order with PRECISE+HOGSWITCH
sheepluva
parents:
10135
diff
changeset
|
3557 |
else |
67b255f839db
allow switching through hogs in reverse order with PRECISE+HOGSWITCH
sheepluva
parents:
10135
diff
changeset
|
3558 |
switchDir:= 1; |
67b255f839db
allow switching through hogs in reverse order with PRECISE+HOGSWITCH
sheepluva
parents:
10135
diff
changeset
|
3559 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3560 |
State := HHGear^.State; |
15155
0e0b5fc1674e
Fix floating hog when switching to moving hog
Wuzzy <Wuzzy2@mail.ru>
parents:
15072
diff
changeset
|
3561 |
if (HHGear^.State and gstMoving) = 0 then |
0e0b5fc1674e
Fix floating hog when switching to moving hog
Wuzzy <Wuzzy2@mail.ru>
parents:
15072
diff
changeset
|
3562 |
HHGear^.Active := false; |
0e0b5fc1674e
Fix floating hog when switching to moving hog
Wuzzy <Wuzzy2@mail.ru>
parents:
15072
diff
changeset
|
3563 |
HHGear^.State := HHGear^.State and gstMoving; |
7400
09427dbec1d8
Fix TARDIS, make switcher work w/ the new more stringent check.
nemo
parents:
7399
diff
changeset
|
3564 |
HHGear^.Z := cHHZ; |
09427dbec1d8
Fix TARDIS, make switcher work w/ the new more stringent check.
nemo
parents:
7399
diff
changeset
|
3565 |
HHGear^.Message:= HHGear^.Message or gmRemoveFromList or gmAddToList; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3566 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3567 |
PlaySound(sndSwitchHog); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3568 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3569 |
repeat |
10494 | 3570 |
CurrentTeam^.CurrHedgehog := (CurrentTeam^.CurrHedgehog + switchDir) mod CurrentTeam^.HedgehogsNumber; |
8795 | 3571 |
until (CurrentTeam^.Hedgehogs[CurrentTeam^.CurrHedgehog].Gear <> nil) and |
3572 |
(CurrentTeam^.Hedgehogs[CurrentTeam^.CurrHedgehog].Gear^.Damage = 0) and |
|
12679
6f05a02d43b2
Fix player being able to switch to dying hog
Wuzzy <almikes@aol.com>
parents:
12676
diff
changeset
|
3573 |
(CurrentTeam^.Hedgehogs[CurrentTeam^.CurrHedgehog].Gear^.Health > 0) and |
6f05a02d43b2
Fix player being able to switch to dying hog
Wuzzy <almikes@aol.com>
parents:
12676
diff
changeset
|
3574 |
((CurrentTeam^.Hedgehogs[CurrentTeam^.CurrHedgehog].Gear^.State and gstHHDeath) = 0) and |
8563
4d9d8287e601
Trying to improve rendering, sliding and thawing. Messing around w/ making fire thaw faster.
nemo
parents:
8560
diff
changeset
|
3575 |
(CurrentTeam^.Hedgehogs[CurrentTeam^.CurrHedgehog].Effects[heFrozen]=0); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3576 |
|
7270
93e92e82d5c8
Step 1. Add current hedgehog as top bit of bottom byte.
nemo
parents:
7268
diff
changeset
|
3577 |
SwitchCurrentHedgehog(@CurrentTeam^.Hedgehogs[CurrentTeam^.CurrHedgehog]); |
8795 | 3578 |
AmmoMenuInvalidated:= true; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3579 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3580 |
HHGear := CurrentHedgehog^.Gear; |
14997 | 3581 |
ScriptCall('onHogSwitch', oldUid); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3582 |
HHGear^.State := State; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3583 |
HHGear^.Active := true; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3584 |
FollowGear := HHGear; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3585 |
HHGear^.Z := cCurrHHZ; |
10145
67b255f839db
allow switching through hogs in reverse order with PRECISE+HOGSWITCH
sheepluva
parents:
10135
diff
changeset
|
3586 |
// restore precise key |
67b255f839db
allow switching through hogs in reverse order with PRECISE+HOGSWITCH
sheepluva
parents:
10135
diff
changeset
|
3587 |
if (switchDir <> 1) then |
67b255f839db
allow switching through hogs in reverse order with PRECISE+HOGSWITCH
sheepluva
parents:
10135
diff
changeset
|
3588 |
HHGear^.Message:= HHGear^.Message or gmPrecise; |
7400
09427dbec1d8
Fix TARDIS, make switcher work w/ the new more stringent check.
nemo
parents:
7399
diff
changeset
|
3589 |
HHGear^.Message:= HHGear^.Message or gmRemoveFromList or gmAddToList; |
15155
0e0b5fc1674e
Fix floating hog when switching to moving hog
Wuzzy <Wuzzy2@mail.ru>
parents:
15072
diff
changeset
|
3590 |
end; |
0e0b5fc1674e
Fix floating hog when switching to moving hog
Wuzzy <Wuzzy2@mail.ru>
parents:
15072
diff
changeset
|
3591 |
doStepHedgehogMoving(HHGear); |
0e0b5fc1674e
Fix floating hog when switching to moving hog
Wuzzy <Wuzzy2@mail.ru>
parents:
15072
diff
changeset
|
3592 |
Gear^.X := HHGear^.X; |
0e0b5fc1674e
Fix floating hog when switching to moving hog
Wuzzy <Wuzzy2@mail.ru>
parents:
15072
diff
changeset
|
3593 |
Gear^.Y := HHGear^.Y |
534 | 3594 |
end; |
3595 |
||
3596 |
procedure doStepSwitcher(Gear: PGear); |
|
8795 | 3597 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3598 |
HHGear: PGear; |
534 | 3599 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3600 |
Gear^.doStep := @doStepSwitcherWork; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3601 |
|
15348
2196aa902d2d
Fix switching arrows overlapping with hog tags of own hog (while finger is active)
Wuzzy <Wuzzy2@mail.ru>
parents:
15323
diff
changeset
|
3602 |
// Note: The game assumes there's at most only one gtSwitcher gear in the game. |
2196aa902d2d
Fix switching arrows overlapping with hog tags of own hog (while finger is active)
Wuzzy <Wuzzy2@mail.ru>
parents:
15323
diff
changeset
|
3603 |
bShowSwitcher:= true; |
2196aa902d2d
Fix switching arrows overlapping with hog tags of own hog (while finger is active)
Wuzzy <Wuzzy2@mail.ru>
parents:
15323
diff
changeset
|
3604 |
|
4365 | 3605 |
HHGear := Gear^.Hedgehog^.Gear; |
5358 | 3606 |
OnUsedAmmo(HHGear^.Hedgehog^); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3607 |
with HHGear^ do |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3608 |
begin |
6450 | 3609 |
State := State and (not gstAttacking); |
13825
096cc009e0b8
Clear gmSwitch before activating switcher
Wuzzy <Wuzzy2@mail.ru>
parents:
13806
diff
changeset
|
3610 |
Message := Message and (not (gmAttack or gmSwitch)) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3611 |
end |
534 | 3612 |
end; |
924 | 3613 |
|
3614 |
//////////////////////////////////////////////////////////////////////////////// |
|
3615 |
procedure doStepMortar(Gear: PGear); |
|
8795 | 3616 |
var |
8413
454191defee6
restore former cluster behaviour (makes the most diff for the bomb)
nemo
parents:
8370
diff
changeset
|
3617 |
dX, dY, gdX, gdY: hwFloat; |
924 | 3618 |
i: LongInt; |
3619 |
begin |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3620 |
AllInactive := false; |
8945
145bf64a9579
this should improve consistency of mortar cluster spread and snowball knocks
nemo
parents:
8934
diff
changeset
|
3621 |
gdX := Gear^.dX; |
145bf64a9579
this should improve consistency of mortar cluster spread and snowball knocks
nemo
parents:
8934
diff
changeset
|
3622 |
gdY := Gear^.dY; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3623 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3624 |
doStepFallingGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3625 |
if (Gear^.State and gstCollision) <> 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3626 |
begin |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
3627 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
8945
145bf64a9579
this should improve consistency of mortar cluster spread and snowball knocks
nemo
parents:
8934
diff
changeset
|
3628 |
gdX.isNegative := not gdX.isNegative; |
145bf64a9579
this should improve consistency of mortar cluster spread and snowball knocks
nemo
parents:
8934
diff
changeset
|
3629 |
gdY.isNegative := not gdY.isNegative; |
145bf64a9579
this should improve consistency of mortar cluster spread and snowball knocks
nemo
parents:
8934
diff
changeset
|
3630 |
gdX:= gdX*_0_2; |
145bf64a9579
this should improve consistency of mortar cluster spread and snowball knocks
nemo
parents:
8934
diff
changeset
|
3631 |
gdY:= gdY*_0_2; |
145bf64a9579
this should improve consistency of mortar cluster spread and snowball knocks
nemo
parents:
8934
diff
changeset
|
3632 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3633 |
for i:= 0 to 4 do |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3634 |
begin |
8945
145bf64a9579
this should improve consistency of mortar cluster spread and snowball knocks
nemo
parents:
8934
diff
changeset
|
3635 |
dX := gdX + rndSign(GetRandomf) * _0_03; |
145bf64a9579
this should improve consistency of mortar cluster spread and snowball knocks
nemo
parents:
8934
diff
changeset
|
3636 |
dY := gdY + rndSign(GetRandomf) * _0_03; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3637 |
AddGear(hwRound(Gear^.X), hwRound(Gear^.Y), gtCluster, 0, dX, dY, 25); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3638 |
end; |
2376 | 3639 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3640 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3641 |
exit |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3642 |
end; |
963 | 3643 |
|
15251
4576e41c0692
Add air plane underwater sound and add water splashes
Wuzzy <Wuzzy2@mail.ru>
parents:
15250
diff
changeset
|
3644 |
// particles |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3645 |
if (GameTicks and $3F) = 0 then |
10352 | 3646 |
AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtSmokeTrace); |
924 | 3647 |
end; |
984 | 3648 |
|
3649 |
//////////////////////////////////////////////////////////////////////////////// |
|
3650 |
procedure doStepKamikazeWork(Gear: PGear); |
|
8795 | 3651 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3652 |
i: LongWord; |
984 | 3653 |
HHGear: PGear; |
5866
9017a0ff4201
aaaallways, I want to beeee with you, and make belieeeeve with you
nemo
parents:
5841
diff
changeset
|
3654 |
sparkles: PVisualGear; |
5913 | 3655 |
hasWishes: boolean; |
12169
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12120
diff
changeset
|
3656 |
s: ansistring; |
984 | 3657 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3658 |
AllInactive := false; |
5913 | 3659 |
hasWishes:= ((Gear^.Message and (gmPrecise or gmSwitch)) = (gmPrecise or gmSwitch)); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3660 |
if hasWishes then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3661 |
Gear^.AdvBounce:= 1; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3662 |
|
4365 | 3663 |
HHGear := Gear^.Hedgehog^.Gear; |
7958 | 3664 |
if HHGear = nil then |
3665 |
begin |
|
14028 | 3666 |
ClearHitOrder(); |
3667 |
ClearProximityCache(); |
|
7958 | 3668 |
DeleteGear(Gear); |
3669 |
exit |
|
3670 |
end; |
|
3671 |
||
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3672 |
HHGear^.State := HHGear^.State or gstNoDamage; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3673 |
DeleteCI(HHGear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3674 |
|
3852 | 3675 |
Gear^.X := HHGear^.X; |
3676 |
Gear^.Y := HHGear^.Y; |
|
5913 | 3677 |
if (GameTicks mod 2 = 0) and hasWishes then |
5866
9017a0ff4201
aaaallways, I want to beeee with you, and make belieeeeve with you
nemo
parents:
5841
diff
changeset
|
3678 |
begin |
9017a0ff4201
aaaallways, I want to beeee with you, and make belieeeeve with you
nemo
parents:
5841
diff
changeset
|
3679 |
sparkles:= AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtDust, 1); |
6131 | 3680 |
if sparkles <> nil then |
5924
82fc26c53d2a
Tweak sparkles, glass. Left glass commented out in case he prefers old behaviour.
nemo
parents:
5922
diff
changeset
|
3681 |
begin |
82fc26c53d2a
Tweak sparkles, glass. Left glass commented out in case he prefers old behaviour.
nemo
parents:
5922
diff
changeset
|
3682 |
sparkles^.Tint:= ((random(210)+45) shl 24) or ((random(210)+45) shl 16) or ((random(210)+45) shl 8) or $FF; |
7066
12cc2bd84b0b
Make pas2c even more happier with uGears.c, allow assigning arrays in some cases
unc0rr
parents:
7062
diff
changeset
|
3683 |
sparkles^.Angle:= random(360); |
5924
82fc26c53d2a
Tweak sparkles, glass. Left glass commented out in case he prefers old behaviour.
nemo
parents:
5922
diff
changeset
|
3684 |
end |
5866
9017a0ff4201
aaaallways, I want to beeee with you, and make belieeeeve with you
nemo
parents:
5841
diff
changeset
|
3685 |
end; |
3852 | 3686 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3687 |
i := 2; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3688 |
repeat |
8795 | 3689 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3690 |
Gear^.X := Gear^.X + HHGear^.dX; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3691 |
Gear^.Y := Gear^.Y + HHGear^.dY; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3692 |
HHGear^.X := Gear^.X; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3693 |
HHGear^.Y := Gear^.Y; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3694 |
|
10354 | 3695 |
// check for drowning |
3696 |
if CheckGearDrowning(HHGear) then |
|
3697 |
begin |
|
3698 |
AfterAttack; |
|
14028 | 3699 |
ClearHitOrder(); |
3700 |
ClearProximityCache(); |
|
10354 | 3701 |
DeleteGear(Gear); |
3702 |
exit; |
|
3703 |
end; |
|
3704 |
||
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3705 |
inc(Gear^.Damage, 2); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3706 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3707 |
dec(i) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3708 |
until (i = 0) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3709 |
or (Gear^.Damage > Gear^.Health); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3710 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3711 |
inc(upd); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3712 |
if upd > 3 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3713 |
begin |
5913 | 3714 |
if Gear^.Health < 1500 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3715 |
begin |
5913 | 3716 |
if Gear^.AdvBounce <> 0 then |
3717 |
Gear^.Pos := 3 |
|
3718 |
else |
|
3719 |
Gear^.Pos := 2; |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3720 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3721 |
|
14028 | 3722 |
AmmoShoveCache(Gear, Gear^.Boom, 40); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3723 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3724 |
DrawTunnel(HHGear^.X - HHGear^.dX * 10, |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3725 |
HHGear^.Y - _2 - HHGear^.dY * 10 + hwAbs(HHGear^.dY) * 2, |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3726 |
HHGear^.dX, |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3727 |
HHGear^.dY, |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3728 |
20 + cHHRadius * 2, |
6130 | 3729 |
cHHRadius * 2 + 7); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3730 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3731 |
upd := 0 |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3732 |
end; |
984 | 3733 |
|
14028 | 3734 |
inc(Gear^.Timer); |
3735 |
if (Gear^.Timer mod 100) = 0 then |
|
3736 |
RefillProximityCache(Gear, 300); |
|
3737 |
||
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3738 |
if Gear^.Health < Gear^.Damage then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3739 |
begin |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
3740 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
6112
7839a2ae90ae
Restrict slipperiness to girders and bridges. Make girders more obviously ice.
nemo
parents:
6092
diff
changeset
|
3741 |
if hasWishes then |
7839a2ae90ae
Restrict slipperiness to girders and bridges. Make girders more obviously ice.
nemo
parents:
6092
diff
changeset
|
3742 |
for i:= 0 to 31 do |
7839a2ae90ae
Restrict slipperiness to girders and bridges. Make girders more obviously ice.
nemo
parents:
6092
diff
changeset
|
3743 |
begin |
7839a2ae90ae
Restrict slipperiness to girders and bridges. Make girders more obviously ice.
nemo
parents:
6092
diff
changeset
|
3744 |
sparkles:= AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtStraightShot); |
7839a2ae90ae
Restrict slipperiness to girders and bridges. Make girders more obviously ice.
nemo
parents:
6092
diff
changeset
|
3745 |
if sparkles <> nil then |
7839a2ae90ae
Restrict slipperiness to girders and bridges. Make girders more obviously ice.
nemo
parents:
6092
diff
changeset
|
3746 |
with sparkles^ do |
7839a2ae90ae
Restrict slipperiness to girders and bridges. Make girders more obviously ice.
nemo
parents:
6092
diff
changeset
|
3747 |
begin |
7839a2ae90ae
Restrict slipperiness to girders and bridges. Make girders more obviously ice.
nemo
parents:
6092
diff
changeset
|
3748 |
Tint:= ((random(210)+45) shl 24) or ((random(210)+45) shl 16) or ((random(210)+45) shl 8) or $FF; |
7066
12cc2bd84b0b
Make pas2c even more happier with uGears.c, allow assigning arrays in some cases
unc0rr
parents:
7062
diff
changeset
|
3749 |
Angle:= random(360); |
6112
7839a2ae90ae
Restrict slipperiness to girders and bridges. Make girders more obviously ice.
nemo
parents:
6092
diff
changeset
|
3750 |
dx:= 0.001 * (random(200)); |
7839a2ae90ae
Restrict slipperiness to girders and bridges. Make girders more obviously ice.
nemo
parents:
6092
diff
changeset
|
3751 |
dy:= 0.001 * (random(200)); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3752 |
if random(2) = 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3753 |
dx := -dx; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3754 |
if random(2) = 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3755 |
dy := -dy; |
6112
7839a2ae90ae
Restrict slipperiness to girders and bridges. Make girders more obviously ice.
nemo
parents:
6092
diff
changeset
|
3756 |
FrameTicks:= random(400) + 250 |
7839a2ae90ae
Restrict slipperiness to girders and bridges. Make girders more obviously ice.
nemo
parents:
6092
diff
changeset
|
3757 |
end |
7839a2ae90ae
Restrict slipperiness to girders and bridges. Make girders more obviously ice.
nemo
parents:
6092
diff
changeset
|
3758 |
end; |
12169
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12120
diff
changeset
|
3759 |
s:= ansistring(Gear^.Hedgehog^.Name); |
13642
3d14950641a4
Refactor text color variable names, export 2 color values to Lua
Wuzzy <Wuzzy2@mail.ru>
parents:
13640
diff
changeset
|
3760 |
AddCaption(FormatA(GetEventString(eidKamikaze), s), capcolDefault, capgrpMessage); |
12292
93434ab299a0
Take sacrifices into account for the “Stupid” taunt
Wuzzy <almikes@aol.com>
parents:
12277
diff
changeset
|
3761 |
uStats.HedgehogSacrificed(Gear^.Hedgehog); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3762 |
AfterAttack; |
7395 | 3763 |
HHGear^.Message:= HHGear^.Message or gmDestroy; |
14028 | 3764 |
ClearHitOrder(); |
3765 |
ClearProximityCache(); |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3766 |
DeleteGear(Gear); |
12837 | 3767 |
end |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3768 |
else |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3769 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3770 |
dec(Gear^.Health, Gear^.Damage); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3771 |
Gear^.Damage := 0 |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3772 |
end |
984 | 3773 |
end; |
3774 |
||
987 | 3775 |
procedure doStepKamikazeIdle(Gear: PGear); |
15217
a0bb57d3d272
Fix buggy kamikaze when hog took damage during short waiting phase at start
Wuzzy <Wuzzy2@mail.ru>
parents:
15202
diff
changeset
|
3776 |
var HHGear: PGear; |
987 | 3777 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3778 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3779 |
dec(Gear^.Timer); |
15217
a0bb57d3d272
Fix buggy kamikaze when hog took damage during short waiting phase at start
Wuzzy <Wuzzy2@mail.ru>
parents:
15202
diff
changeset
|
3780 |
HHGear := Gear^.Hedgehog^.Gear; |
a0bb57d3d272
Fix buggy kamikaze when hog took damage during short waiting phase at start
Wuzzy <Wuzzy2@mail.ru>
parents:
15202
diff
changeset
|
3781 |
if (HHGear = nil) or (HHGear^.Damage <> 0) then |
a0bb57d3d272
Fix buggy kamikaze when hog took damage during short waiting phase at start
Wuzzy <Wuzzy2@mail.ru>
parents:
15202
diff
changeset
|
3782 |
begin |
a0bb57d3d272
Fix buggy kamikaze when hog took damage during short waiting phase at start
Wuzzy <Wuzzy2@mail.ru>
parents:
15202
diff
changeset
|
3783 |
if (HHGear <> nil) then |
a0bb57d3d272
Fix buggy kamikaze when hog took damage during short waiting phase at start
Wuzzy <Wuzzy2@mail.ru>
parents:
15202
diff
changeset
|
3784 |
AfterAttack; |
a0bb57d3d272
Fix buggy kamikaze when hog took damage during short waiting phase at start
Wuzzy <Wuzzy2@mail.ru>
parents:
15202
diff
changeset
|
3785 |
ClearHitOrder(); |
a0bb57d3d272
Fix buggy kamikaze when hog took damage during short waiting phase at start
Wuzzy <Wuzzy2@mail.ru>
parents:
15202
diff
changeset
|
3786 |
ClearProximityCache(); |
a0bb57d3d272
Fix buggy kamikaze when hog took damage during short waiting phase at start
Wuzzy <Wuzzy2@mail.ru>
parents:
15202
diff
changeset
|
3787 |
DeleteGear(Gear); |
a0bb57d3d272
Fix buggy kamikaze when hog took damage during short waiting phase at start
Wuzzy <Wuzzy2@mail.ru>
parents:
15202
diff
changeset
|
3788 |
exit; |
a0bb57d3d272
Fix buggy kamikaze when hog took damage during short waiting phase at start
Wuzzy <Wuzzy2@mail.ru>
parents:
15202
diff
changeset
|
3789 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3790 |
if Gear^.Timer = 0 then |
5922 | 3791 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3792 |
Gear^.Pos := 1; |
7053 | 3793 |
PlaySoundV(sndKamikaze, Gear^.Hedgehog^.Team^.voicepack); |
14028 | 3794 |
ClearHitOrder(); |
3795 |
RefillProximityCache(Gear, 300); |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3796 |
Gear^.doStep := @doStepKamikazeWork |
5922 | 3797 |
end |
987 | 3798 |
end; |
3799 |
||
984 | 3800 |
procedure doStepKamikaze(Gear: PGear); |
8795 | 3801 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3802 |
HHGear: PGear; |
984 | 3803 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3804 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3805 |
|
4365 | 3806 |
HHGear := Gear^.Hedgehog^.Gear; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3807 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3808 |
HHGear^.dX := Gear^.dX; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3809 |
HHGear^.dY := Gear^.dY; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3810 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3811 |
Gear^.dX := SignAs(_0_45, Gear^.dX); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3812 |
Gear^.dY := - _0_9; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3813 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3814 |
Gear^.Timer := 550; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3815 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3816 |
Gear^.doStep := @doStepKamikazeIdle |
984 | 3817 |
end; |
3818 |
||
1103 | 3819 |
//////////////////////////////////////////////////////////////////////////////// |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3820 |
|
1110 | 3821 |
procedure doStepCakeExpl(Gear: PGear); |
12745
c162995831d8
Fix cake party face not working across wrap world border
Wuzzy <Wuzzy2@mail.ru>
parents:
12744
diff
changeset
|
3822 |
var gi: PGear; |
1110 | 3823 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3824 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3825 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3826 |
inc(Gear^.Tag); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3827 |
if Gear^.Tag < 2250 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3828 |
exit; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3829 |
|
11523 | 3830 |
InCinematicMode:= false; |
12745
c162995831d8
Fix cake party face not working across wrap world border
Wuzzy <Wuzzy2@mail.ru>
parents:
12744
diff
changeset
|
3831 |
gi := GearsList; |
c162995831d8
Fix cake party face not working across wrap world border
Wuzzy <Wuzzy2@mail.ru>
parents:
12744
diff
changeset
|
3832 |
while gi <> nil do |
c162995831d8
Fix cake party face not working across wrap world border
Wuzzy <Wuzzy2@mail.ru>
parents:
12744
diff
changeset
|
3833 |
begin |
c162995831d8
Fix cake party face not working across wrap world border
Wuzzy <Wuzzy2@mail.ru>
parents:
12744
diff
changeset
|
3834 |
if gi^.Kind = gtHedgehog then |
c162995831d8
Fix cake party face not working across wrap world border
Wuzzy <Wuzzy2@mail.ru>
parents:
12744
diff
changeset
|
3835 |
gi^.State := gi^.State and (not gstLoser); |
c162995831d8
Fix cake party face not working across wrap world border
Wuzzy <Wuzzy2@mail.ru>
parents:
12744
diff
changeset
|
3836 |
gi:= gi^.NextGear; |
c162995831d8
Fix cake party face not working across wrap world border
Wuzzy <Wuzzy2@mail.ru>
parents:
12744
diff
changeset
|
3837 |
end; |
c162995831d8
Fix cake party face not working across wrap world border
Wuzzy <Wuzzy2@mail.ru>
parents:
12744
diff
changeset
|
3838 |
|
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
3839 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3840 |
AfterAttack; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3841 |
DeleteGear(Gear) |
1110 | 3842 |
end; |
3843 |
||
1109 | 3844 |
procedure doStepCakeDown(Gear: PGear); |
8795 | 3845 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3846 |
gi: PGear; |
11523 | 3847 |
dmg, dmgBase, partyEpicness, i: LongInt; |
12806 | 3848 |
fX, fY, tdX, tdY: hwFloat; |
11523 | 3849 |
sparkles: PVisualGear; |
1109 | 3850 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3851 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3852 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3853 |
inc(Gear^.Tag); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3854 |
if Gear^.Tag < 100 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3855 |
exit; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3856 |
Gear^.Tag := 0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3857 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3858 |
if Gear^.Pos = 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3859 |
begin |
6765 | 3860 |
///////////// adapted from doMakeExplosion /////////////////////////// |
3861 |
fX:= int2hwFloat(hwRound(Gear^.X)); |
|
3862 |
fY:= int2hwFloat(hwRound(Gear^.Y)); |
|
12746
e1395ba033e8
Use Gear^.Boom to calculate cake party faces
Wuzzy <Wuzzy2@mail.ru>
parents:
12745
diff
changeset
|
3863 |
dmgBase:= Gear^.Boom shl 1 + cHHRadius div 2; |
11523 | 3864 |
partyEpicness:= 0; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3865 |
gi := GearsList; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3866 |
while gi <> nil do |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3867 |
begin |
6765 | 3868 |
if gi^.Kind = gtHedgehog then |
3869 |
begin |
|
3870 |
dmg:= 0; |
|
12806 | 3871 |
tdX:= gi^.X-fX; |
3872 |
tdY:= gi^.Y-fY; |
|
3873 |
if hwRound(hwAbs(tdX)+hwAbs(tdY)) < dmgBase then |
|
3874 |
dmg:= dmgBase - max(hwRound(Distance(tdX, tdY)),gi^.Radius); |
|
12746
e1395ba033e8
Use Gear^.Boom to calculate cake party faces
Wuzzy <Wuzzy2@mail.ru>
parents:
12745
diff
changeset
|
3875 |
if (dmg > 1) then dmg:= ModifyDamage(min(dmg div 2, Gear^.Boom), gi); |
6765 | 3876 |
if (dmg > 1) then |
10011
ead5e4b21671
Add check for gear kind of hedgehog on invulnerability effect. This probably fixes bug #766, is similar to change in previous r2a1483d91977 and was introduced by r7d925e82e572
nemo
parents:
9998
diff
changeset
|
3877 |
if (CurrentHedgehog^.Gear = gi) and (gi^.Hedgehog^.Effects[heInvulnerable] = 0) then |
11523 | 3878 |
begin |
3879 |
gi^.State := gi^.State or gstLoser; |
|
3880 |
// probably not too epic if hitting self too... |
|
3881 |
dec(partyEpicness, 45); |
|
3882 |
end |
|
6765 | 3883 |
else |
11523 | 3884 |
begin |
6765 | 3885 |
gi^.State := gi^.State or gstWinner; |
11523 | 3886 |
if CurrentHedgehog^.Gear = gi then |
3887 |
dec(partyEpicness, 45) |
|
3888 |
else |
|
3889 |
inc(partyEpicness); |
|
3890 |
end; |
|
6765 | 3891 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3892 |
gi := gi^.NextGear |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3893 |
end; |
6765 | 3894 |
////////////////////////////////////////////////////////////////////// |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3895 |
Gear^.doStep := @doStepCakeExpl; |
11530 | 3896 |
if (partyEpicness > 6) and (abs(90 - abs(trunc(Gear^.DirAngle))) < 20) then |
11523 | 3897 |
begin |
3898 |
for i := 0 to (2 * partyEpicness) do |
|
3899 |
begin |
|
3900 |
sparkles:= AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtEgg, 1); |
|
3901 |
if sparkles <> nil then |
|
3902 |
begin |
|
3903 |
sparkles^.dX:= 0.008 * (random(100) - 50); |
|
3904 |
sparkles^.dY:= -0.3 + 0.002 * (random(100) - 50); |
|
3905 |
sparkles^.Tint:= ((random(210)+45) shl 24) or ((random(210)+45) shl 16) or ((random(210)+45) shl 8) or $FF; |
|
3906 |
sparkles^.Angle:= random(360); |
|
3907 |
end |
|
3908 |
end; |
|
3909 |
InCinematicMode:= true; |
|
3910 |
end; |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3911 |
PlaySound(sndCake) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3912 |
end |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3913 |
else dec(Gear^.Pos) |
1109 | 3914 |
end; |
3915 |
||
3916 |
||
11531 | 3917 |
procedure doStepCakeWalk(Gear: PGear); |
7370
d50b874e7ee8
Introduce uGearsHandlers.pas, for now only part of cake handlers is moved there
unc0rr
parents:
7341
diff
changeset
|
3918 |
var |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
3919 |
tdx, tdy: hwFloat; |
10874
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
3920 |
cakeData: PCakeData; |
13608
92b87845beeb
Fix cake rotation angle after bounce from bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13607
diff
changeset
|
3921 |
i: Longword; |
1088 | 3922 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3923 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3924 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3925 |
inc(Gear^.Tag); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3926 |
if Gear^.Tag < 7 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
3927 |
exit; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
3928 |
|
7416
2f2f78fc65a3
AI uses cake! Known issues: AI could damage itself for no reason, could let cake go looping in a hole with exit closed by AI hog.
unc0rr
parents:
7408
diff
changeset
|
3929 |
dec(Gear^.Health); |
2f2f78fc65a3
AI uses cake! Known issues: AI could damage itself for no reason, could let cake go looping in a hole with exit closed by AI hog.
unc0rr
parents:
7408
diff
changeset
|
3930 |
Gear^.Timer := Gear^.Health*10; |
2f2f78fc65a3
AI uses cake! Known issues: AI could damage itself for no reason, could let cake go looping in a hole with exit closed by AI hog.
unc0rr
parents:
7408
diff
changeset
|
3931 |
if Gear^.Health mod 100 = 0 then |
2f2f78fc65a3
AI uses cake! Known issues: AI could damage itself for no reason, could let cake go looping in a hole with exit closed by AI hog.
unc0rr
parents:
7408
diff
changeset
|
3932 |
Gear^.PortalCounter:= 0; |
2f2f78fc65a3
AI uses cake! Known issues: AI could damage itself for no reason, could let cake go looping in a hole with exit closed by AI hog.
unc0rr
parents:
7408
diff
changeset
|
3933 |
// This is not seconds, but at least it is *some* feedback |
12641
f30b70976577
Fix cake taking >200s to explode when it's completely stuck and can't move (bug 194)
Wuzzy <almikes@aol.com>
parents:
12621
diff
changeset
|
3934 |
if (Gear^.Health <= 0) or ((Gear^.Message and gmAttack) <> 0) then |
7416
2f2f78fc65a3
AI uses cake! Known issues: AI could damage itself for no reason, could let cake go looping in a hole with exit closed by AI hog.
unc0rr
parents:
7408
diff
changeset
|
3935 |
begin |
2f2f78fc65a3
AI uses cake! Known issues: AI could damage itself for no reason, could let cake go looping in a hole with exit closed by AI hog.
unc0rr
parents:
7408
diff
changeset
|
3936 |
FollowGear := Gear; |
2f2f78fc65a3
AI uses cake! Known issues: AI could damage itself for no reason, could let cake go looping in a hole with exit closed by AI hog.
unc0rr
parents:
7408
diff
changeset
|
3937 |
Gear^.RenderTimer := false; |
2f2f78fc65a3
AI uses cake! Known issues: AI could damage itself for no reason, could let cake go looping in a hole with exit closed by AI hog.
unc0rr
parents:
7408
diff
changeset
|
3938 |
Gear^.doStep := @doStepCakeDown; |
2f2f78fc65a3
AI uses cake! Known issues: AI could damage itself for no reason, could let cake go looping in a hole with exit closed by AI hog.
unc0rr
parents:
7408
diff
changeset
|
3939 |
exit |
10875 | 3940 |
end |
3941 |
else if Gear^.Timer < 6000 then |
|
3942 |
Gear^.RenderTimer:= true; |
|
7416
2f2f78fc65a3
AI uses cake! Known issues: AI could damage itself for no reason, could let cake go looping in a hole with exit closed by AI hog.
unc0rr
parents:
7408
diff
changeset
|
3943 |
|
9969 | 3944 |
if not cakeStep(Gear) then Gear^.doStep:= @doStepCakeFall; |
1103 | 3945 |
|
13614
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3946 |
// Cake passed world edge. |
13607
212036414957
Make cake bounce off bounce edge, stop cake at wrap edge to prevent other bug
Wuzzy <Wuzzy2@mail.ru>
parents:
13605
diff
changeset
|
3947 |
if (Gear^.Karma = 1) then |
13614
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3948 |
(* This code is not ideal, but at least not horribly broken. |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3949 |
The cake tries to reach the other side and continue to walk, |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3950 |
but there are some exceptions. |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3951 |
This code is called *after* the X coordinate have been wrapped. |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3952 |
Depending on terrain on the other side, the cake does this: |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3953 |
* Cake collides horizontally (even by 1 pixel): Turn around |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3954 |
* Cake does not see walkable ground above or below: Fall |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3955 |
* Otherwise: Walk normally |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3956 |
*) |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3957 |
begin |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3958 |
// Update coordinates |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3959 |
tdx:=Gear^.X; |
14303
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14225
diff
changeset
|
3960 |
if (hwRound(Gear^.X) < leftX) then |
13614
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3961 |
Gear^.X:= Gear^.X + int2hwfloat(rightX - leftX) |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3962 |
else Gear^.X:= Gear^.X - int2hwfloat(rightX - leftX); |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3963 |
|
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3964 |
Gear^.Tag:= 0; |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3965 |
if ((TestCollisionXwithGear(Gear, 1) <> 0) or (TestCollisionXwithGear(Gear, -1) <> 0)) then |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3966 |
// Cake collided horizontally, turn around. Prevents cake from being stuck in infinite loop. |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3967 |
// This can also happen if the terrain is just a slight slope. :-( |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3968 |
begin |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3969 |
Gear^.X := tdx; |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3970 |
Gear^.Karma := 3; |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3971 |
end |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3972 |
else |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3973 |
begin |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3974 |
// Check if cake has something to walk on the other side. If not, make it drop. |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3975 |
// There is nothing for the cake to stand on. |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3976 |
if (TestCollisionYwithGear(Gear, 1) = 0) and (TestCollisionYwithGear(Gear, -1) = 0) then |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3977 |
Gear^.doStep:= @doStepCakeFall; |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3978 |
Gear^.Karma := 4; |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3979 |
end; |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3980 |
end; |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3981 |
// Cake bounced! |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3982 |
if (Gear^.Karma = 2) or (Gear^.Karma = 3) then |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3983 |
begin |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3984 |
// Turn cake around |
13607
212036414957
Make cake bounce off bounce edge, stop cake at wrap edge to prevent other bug
Wuzzy <Wuzzy2@mail.ru>
parents:
13605
diff
changeset
|
3985 |
Gear^.dX.isNegative := (not Gear^.dX.isNegative); |
212036414957
Make cake bounce off bounce edge, stop cake at wrap edge to prevent other bug
Wuzzy <Wuzzy2@mail.ru>
parents:
13605
diff
changeset
|
3986 |
Gear^.WDTimer := 0; |
212036414957
Make cake bounce off bounce edge, stop cake at wrap edge to prevent other bug
Wuzzy <Wuzzy2@mail.ru>
parents:
13605
diff
changeset
|
3987 |
Gear^.Angle := (LongInt(Gear^.Angle) + 2) and 3; |
13608
92b87845beeb
Fix cake rotation angle after bounce from bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13607
diff
changeset
|
3988 |
|
13609
13f68f3e7153
Add bounce effect to cake when it touches bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13608
diff
changeset
|
3989 |
// Bounce effect |
14595
6e5cda26f676
Tweak bounce effects of some gears
Wuzzy <Wuzzy2@mail.ru>
parents:
14593
diff
changeset
|
3990 |
if (Gear^.Karma = 2) then |
13609
13f68f3e7153
Add bounce effect to cake when it touches bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13608
diff
changeset
|
3991 |
AddBounceEffectForGear(Gear, 0.55); |
13f68f3e7153
Add bounce effect to cake when it touches bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13608
diff
changeset
|
3992 |
|
13614
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3993 |
Gear^.Tag:= 0; |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3994 |
Gear^.Karma := 4; |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3995 |
end; |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3996 |
if (Gear^.Karma = 4) then |
c9642782778b
Fix cake walking through land when reaching wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13613
diff
changeset
|
3997 |
begin |
13608
92b87845beeb
Fix cake rotation angle after bounce from bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13607
diff
changeset
|
3998 |
// Reset CakePoints to fix cake angle |
92b87845beeb
Fix cake rotation angle after bounce from bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13607
diff
changeset
|
3999 |
cakeData:= PCakeData(Gear^.Data); |
92b87845beeb
Fix cake rotation angle after bounce from bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13607
diff
changeset
|
4000 |
with cakeData^ do |
92b87845beeb
Fix cake rotation angle after bounce from bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13607
diff
changeset
|
4001 |
begin |
92b87845beeb
Fix cake rotation angle after bounce from bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13607
diff
changeset
|
4002 |
for i:= 0 to Pred(cakeh) do |
92b87845beeb
Fix cake rotation angle after bounce from bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13607
diff
changeset
|
4003 |
begin |
92b87845beeb
Fix cake rotation angle after bounce from bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13607
diff
changeset
|
4004 |
CakePoints[i].x := Gear^.X; |
92b87845beeb
Fix cake rotation angle after bounce from bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13607
diff
changeset
|
4005 |
CakePoints[i].y := Gear^.Y; |
92b87845beeb
Fix cake rotation angle after bounce from bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13607
diff
changeset
|
4006 |
end; |
92b87845beeb
Fix cake rotation angle after bounce from bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13607
diff
changeset
|
4007 |
CakeI:= 0; |
92b87845beeb
Fix cake rotation angle after bounce from bounce edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13607
diff
changeset
|
4008 |
end; |
13607
212036414957
Make cake bounce off bounce edge, stop cake at wrap edge to prevent other bug
Wuzzy <Wuzzy2@mail.ru>
parents:
13605
diff
changeset
|
4009 |
Gear^.Karma := 0; |
212036414957
Make cake bounce off bounce edge, stop cake at wrap edge to prevent other bug
Wuzzy <Wuzzy2@mail.ru>
parents:
13605
diff
changeset
|
4010 |
end; |
212036414957
Make cake bounce off bounce edge, stop cake at wrap edge to prevent other bug
Wuzzy <Wuzzy2@mail.ru>
parents:
13605
diff
changeset
|
4011 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4012 |
if Gear^.Tag = 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4013 |
begin |
10874
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4014 |
cakeData:= PCakeData(Gear^.Data); |
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4015 |
with cakeData^ do |
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4016 |
begin |
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4017 |
CakeI := (CakeI + 1) mod cakeh; |
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4018 |
tdx := CakePoints[CakeI].x - Gear^.X; |
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4019 |
tdy := - CakePoints[CakeI].y + Gear^.Y; |
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4020 |
CakePoints[CakeI].x := Gear^.X; |
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4021 |
CakePoints[CakeI].y := Gear^.Y; |
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4022 |
Gear^.DirAngle := DxDy2Angle(tdx, tdy); |
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4023 |
end; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4024 |
end; |
1088 | 4025 |
end; |
1089 | 4026 |
|
1103 | 4027 |
procedure doStepCakeUp(Gear: PGear); |
8795 | 4028 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4029 |
i: Longword; |
10874
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4030 |
cakeData: PCakeData; |
1103 | 4031 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4032 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4033 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4034 |
inc(Gear^.Tag); |
12641
f30b70976577
Fix cake taking >200s to explode when it's completely stuck and can't move (bug 194)
Wuzzy <almikes@aol.com>
parents:
12621
diff
changeset
|
4035 |
// Animation delay. Skipped if cake only dropped a very short distance. |
f30b70976577
Fix cake taking >200s to explode when it's completely stuck and can't move (bug 194)
Wuzzy <almikes@aol.com>
parents:
12621
diff
changeset
|
4036 |
if (Gear^.Tag < 100) and (Gear^.FlightTime > 1) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4037 |
exit; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4038 |
Gear^.Tag := 0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4039 |
|
12641
f30b70976577
Fix cake taking >200s to explode when it's completely stuck and can't move (bug 194)
Wuzzy <almikes@aol.com>
parents:
12621
diff
changeset
|
4040 |
if (Gear^.Pos = 6) or (Gear^.FlightTime <= 1) then |
f30b70976577
Fix cake taking >200s to explode when it's completely stuck and can't move (bug 194)
Wuzzy <almikes@aol.com>
parents:
12621
diff
changeset
|
4041 |
begin |
f30b70976577
Fix cake taking >200s to explode when it's completely stuck and can't move (bug 194)
Wuzzy <almikes@aol.com>
parents:
12621
diff
changeset
|
4042 |
Gear^.Pos := 6; |
10874
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4043 |
cakeData:= PCakeData(Gear^.Data); |
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4044 |
with cakeData^ do |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4045 |
begin |
10874
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4046 |
for i:= 0 to Pred(cakeh) do |
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4047 |
begin |
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4048 |
CakePoints[i].x := Gear^.X; |
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4049 |
CakePoints[i].y := Gear^.Y |
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4050 |
end; |
059a6492176e
allow gear specific data (with gear type specific type). applied to cake
sheepluva
parents:
10831
diff
changeset
|
4051 |
CakeI := 0; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4052 |
end; |
12641
f30b70976577
Fix cake taking >200s to explode when it's completely stuck and can't move (bug 194)
Wuzzy <almikes@aol.com>
parents:
12621
diff
changeset
|
4053 |
(* This is called frequently if the cake is completely stuck. |
f30b70976577
Fix cake taking >200s to explode when it's completely stuck and can't move (bug 194)
Wuzzy <almikes@aol.com>
parents:
12621
diff
changeset
|
4054 |
With this a stuck cake takes equally long to explode then |
f30b70976577
Fix cake taking >200s to explode when it's completely stuck and can't move (bug 194)
Wuzzy <almikes@aol.com>
parents:
12621
diff
changeset
|
4055 |
a normal cake. Removing this code just makes the cake walking |
f30b70976577
Fix cake taking >200s to explode when it's completely stuck and can't move (bug 194)
Wuzzy <almikes@aol.com>
parents:
12621
diff
changeset
|
4056 |
for a few seconds longer. *) |
f30b70976577
Fix cake taking >200s to explode when it's completely stuck and can't move (bug 194)
Wuzzy <almikes@aol.com>
parents:
12621
diff
changeset
|
4057 |
if (Gear^.FlightTime <= 1) and (Gear^.Health > 2) then |
f30b70976577
Fix cake taking >200s to explode when it's completely stuck and can't move (bug 194)
Wuzzy <almikes@aol.com>
parents:
12621
diff
changeset
|
4058 |
dec(Gear^.Health); |
f30b70976577
Fix cake taking >200s to explode when it's completely stuck and can't move (bug 194)
Wuzzy <almikes@aol.com>
parents:
12621
diff
changeset
|
4059 |
Gear^.FlightTime := 0; |
11531 | 4060 |
Gear^.doStep := @doStepCakeWalk |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4061 |
end |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4062 |
else |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4063 |
inc(Gear^.Pos) |
1103 | 4064 |
end; |
4065 |
||
1089 | 4066 |
procedure doStepCakeFall(Gear: PGear); |
4067 |
begin |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4068 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4069 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4070 |
Gear^.dY := Gear^.dY + cGravity; |
12641
f30b70976577
Fix cake taking >200s to explode when it's completely stuck and can't move (bug 194)
Wuzzy <almikes@aol.com>
parents:
12621
diff
changeset
|
4071 |
// FlightTime remembers the drop time |
f30b70976577
Fix cake taking >200s to explode when it's completely stuck and can't move (bug 194)
Wuzzy <almikes@aol.com>
parents:
12621
diff
changeset
|
4072 |
inc(Gear^.FlightTime); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4073 |
if TestCollisionYwithGear(Gear, 1) <> 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4074 |
Gear^.doStep := @doStepCakeUp |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4075 |
else |
6081
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
4076 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4077 |
Gear^.Y := Gear^.Y + Gear^.dY; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4078 |
if CheckGearDrowning(Gear) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4079 |
AfterAttack |
6081
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
4080 |
end |
1089 | 4081 |
end; |
4082 |
||
4083 |
procedure doStepCake(Gear: PGear); |
|
4084 |
begin |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4085 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4086 |
|
13469
f1d349a52bc7
Refactor: lfCurrentHog→lfCurHogCrate, lfNotCurrentMask→lfNotCurHogCrate
Wuzzy <Wuzzy2@mail.ru>
parents:
13408
diff
changeset
|
4087 |
Gear^.CollisionMask:= lfNotCurHogCrate; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4088 |
|
10038
0a5e651d494c
Fix uGearsHandlersMess.pas changes lost in merge r1c02143bfe9c.
sheepluva
parents:
10011
diff
changeset
|
4089 |
Gear^.dY:= cMaxWindSpeed * 100; |
0a5e651d494c
Fix uGearsHandlersMess.pas changes lost in merge r1c02143bfe9c.
sheepluva
parents:
10011
diff
changeset
|
4090 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4091 |
Gear^.doStep := @doStepCakeFall |
1089 | 4092 |
end; |
4093 |
||
1259 | 4094 |
//////////////////////////////////////////////////////////////////////////////// |
1284 | 4095 |
procedure doStepSeductionWork(Gear: PGear); |
5706 | 4096 |
var i: LongInt; |
15847 | 4097 |
hits: PGearArrayS; |
14015
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4098 |
HHGear: PGear; |
1259 | 4099 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4100 |
AllInactive := false; |
14015
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4101 |
|
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4102 |
HHGear := Gear^.Hedgehog^.Gear; |
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4103 |
if (HHGear <> nil) and ((HHGear^.State and gstHHDriven) = 0) then |
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4104 |
begin |
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4105 |
StopSound(sndYoohoo); |
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4106 |
AfterAttack; |
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4107 |
DeleteGear(Gear); |
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4108 |
exit; |
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4109 |
end; |
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4110 |
|
15847 | 4111 |
hits := GearsNear(Gear^.X, Gear^.Y, gtHedgehog, Gear^.Radius); |
4112 |
if hits.size > 0 then |
|
4113 |
begin |
|
4114 |
for i:= 0 to hits.size - 1 do |
|
4115 |
with hits.ar^[i]^ do |
|
4116 |
if (hits.ar^[i] <> CurrentHedgehog^.Gear) and (Hedgehog^.Effects[heFrozen] = 0) then |
|
7335 | 4117 |
begin |
12743
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12737
diff
changeset
|
4118 |
if (WorldEdge <> weWrap) or (not (hwAbs(Gear^.X - X) > int2hwFloat(Gear^.Radius))) then |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12737
diff
changeset
|
4119 |
dX:= _50 * cGravity * (Gear^.X - X) / _25 |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12737
diff
changeset
|
4120 |
else if (not (hwAbs(Gear^.X + int2hwFloat(RightX-LeftX) - X) > int2hwFloat(Gear^.Radius))) then |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12737
diff
changeset
|
4121 |
dX:= _50 * cGravity * ((Gear^.X + int2hwFloat(RightX-LeftX)) - X) / _25 |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12737
diff
changeset
|
4122 |
else |
f45ffb4cf1e1
Make GearsNear and CheckGearNear check gears across wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
12737
diff
changeset
|
4123 |
dX:= _50 * cGravity * ((Gear^.X - int2hwFloat(RightX-LeftX)) - X) / _25; |
13058
004f4f7dc9d4
Enemy hogs should at least try to get to you in low gravity
nemo
parents:
12989
diff
changeset
|
4124 |
dY:= -_450 * cMaxWindSpeed * 2; |
7335 | 4125 |
Active:= true; |
4126 |
end |
|
10545 | 4127 |
else if Hedgehog^.Effects[heFrozen] > 255 then |
4128 |
Hedgehog^.Effects[heFrozen]:= 255 |
|
5525 | 4129 |
end ; |
15847 | 4130 |
|
4131 |
hits := GearsNear(Gear^.X, Gear^.Y, gtSentry, Gear^.Radius); |
|
4132 |
if hits.size > 0 then |
|
4133 |
for i:= 0 to hits.size - 1 do |
|
4134 |
with hits.ar^[i]^ do |
|
4135 |
if (Gear^.Hedgehog <> nil) and (Hedgehog <> Gear^.Hedgehog) then |
|
4136 |
begin |
|
4137 |
dX := SignAs(_0, dX); |
|
4138 |
dY := -_0_15; |
|
4139 |
Hedgehog := Gear^.Hedgehog; |
|
4140 |
ResetSentryState(hits.ar^[i], 0, 10000); |
|
4141 |
end; |
|
4142 |
||
14015
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4143 |
AfterAttack; |
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4144 |
DeleteGear(Gear); |
1286 | 4145 |
end; |
4146 |
||
4147 |
procedure doStepSeductionWear(Gear: PGear); |
|
5562 | 4148 |
var heart: PVisualGear; |
14015
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4149 |
HHGear: PGear; |
1286 | 4150 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4151 |
AllInactive := false; |
14015
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4152 |
|
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4153 |
HHGear := Gear^.Hedgehog^.Gear; |
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4154 |
if (HHGear <> nil) and ((HHGear^.State and gstHHDriven) = 0) then |
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4155 |
begin |
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4156 |
StopSound(sndYoohoo); |
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4157 |
AfterAttack; |
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4158 |
DeleteGear(Gear); |
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4159 |
exit; |
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4160 |
end; |
996ef4c5d064
Fix seduction not stopping if hog took damage before attack was complete
Wuzzy <Wuzzy2@mail.ru>
parents:
14006
diff
changeset
|
4161 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4162 |
inc(Gear^.Timer); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4163 |
if Gear^.Timer > 250 then |
5562 | 4164 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4165 |
Gear^.Timer := 0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4166 |
inc(Gear^.Pos); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4167 |
if Gear^.Pos = 5 then |
11698
e86feecadced
Fix issue 12: “Yoohoo” sound for seduction is missing
sheepluva
parents:
11553
diff
changeset
|
4168 |
PlaySound(sndYoohoo); |
14841
183677a07c8d
Separate Yoohoo.ogg into "Yoohoo" voice and kiss sound
Wuzzy <Wuzzy2@mail.ru>
parents:
14782
diff
changeset
|
4169 |
if Gear^.Pos = 14 then |
183677a07c8d
Separate Yoohoo.ogg into "Yoohoo" voice and kiss sound
Wuzzy <Wuzzy2@mail.ru>
parents:
14782
diff
changeset
|
4170 |
PlaySound(sndKiss); |
5562 | 4171 |
end; |
4172 |
||
11858 | 4173 |
|
4174 |
// note: use GameTicks, not RealTicks, otherwise amount can vary greatly |
|
11860
0abbe6f1e4f2
increase heart count in seduction effect. FPS are overrated anyway
sheepluva
parents:
11858
diff
changeset
|
4175 |
if (Gear^.Pos = 14) and (GameTicks and $1 = 0) then |
5562 | 4176 |
begin |
4177 |
heart:= AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtStraightShot); |
|
6131 | 4178 |
if heart <> nil then |
5564
4f42009237df
For mikade's sake, use old dx/dy/frametick as default, so health crosses move the same
nemo
parents:
5563
diff
changeset
|
4179 |
with heart^ do |
4f42009237df
For mikade's sake, use old dx/dy/frametick as default, so health crosses move the same
nemo
parents:
5563
diff
changeset
|
4180 |
begin |
11858 | 4181 |
|
4182 |
// randomize speed in both directions |
|
4183 |
dx:= 0.001 * (random(201)); |
|
4184 |
dy:= 0.001 * (random(201)); |
|
4185 |
||
4186 |
// half of hearts go down |
|
4187 |
if random(2) = 0 then |
|
4188 |
begin |
|
4189 |
// create a pointy shape |
|
4190 |
if 0.2 < dx + dy then |
|
4191 |
begin |
|
4192 |
dy:= 0.2 - dy; |
|
4193 |
dx:= 0.2 - dx; |
|
4194 |
end; |
|
4195 |
// sin bulge it out a little to avoid corners on the side |
|
4196 |
dx:= dx + (dx/0.2) * ((0.2 * sin(pi * ((0.2 - dy) / 0.4))) - (0.2 - dy)); |
|
4197 |
// change sign |
|
4198 |
dy:= -dy; |
|
4199 |
end |
|
4200 |
else // shape hearts on top into 2 arcs |
|
4201 |
dy:= dy * (0.3 + 0.7 * sin(pi * dx / 0.2)); |
|
4202 |
||
4203 |
// half of the hearts go left |
|
4204 |
if random(2) = 0 then |
|
4205 |
dx := -dx; |
|
5564
4f42009237df
For mikade's sake, use old dx/dy/frametick as default, so health crosses move the same
nemo
parents:
5563
diff
changeset
|
4206 |
FrameTicks:= random(750) + 1000; |
5748
70d7f8e40f53
Just for fun. Flowers! Also, use a less blatant image in ammo menu.
nemo
parents:
5738
diff
changeset
|
4207 |
State:= ord(sprSeduction) |
5564
4f42009237df
For mikade's sake, use old dx/dy/frametick as default, so health crosses move the same
nemo
parents:
5563
diff
changeset
|
4208 |
end; |
5562 | 4209 |
end; |
4210 |
||
4211 |
if Gear^.Pos = 15 then |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4212 |
Gear^.doStep := @doStepSeductionWork |
1259 | 4213 |
end; |
1284 | 4214 |
|
4215 |
procedure doStepSeduction(Gear: PGear); |
|
4216 |
begin |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4217 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4218 |
Gear^.doStep := @doStepSeductionWear |
1284 | 4219 |
end; |
1298 | 4220 |
|
4221 |
//////////////////////////////////////////////////////////////////////////////// |
|
4222 |
procedure doStepWaterUp(Gear: PGear); |
|
8795 | 4223 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4224 |
i: LongWord; |
1298 | 4225 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4226 |
if (Gear^.Tag = 0) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4227 |
or (cWaterLine = 0) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4228 |
begin |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4229 |
DeleteGear(Gear); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4230 |
exit |
4153
6bd94e4c5d65
2 more variables to control water rise and health loss during sudden death.
henek
parents:
4135
diff
changeset
|
4231 |
end; |
6bd94e4c5d65
2 more variables to control water rise and health loss during sudden death.
henek
parents:
4135
diff
changeset
|
4232 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4233 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4234 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4235 |
inc(Gear^.Timer); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4236 |
if Gear^.Timer = 17 then |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4237 |
Gear^.Timer := 0 |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4238 |
else |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4239 |
exit; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4240 |
|
10359 | 4241 |
if (WorldEdge = weSea) and (playWidth > cMinPlayWidth) then |
10354 | 4242 |
begin |
4243 |
inc(leftX); |
|
4244 |
dec(rightX); |
|
4245 |
dec(playWidth, 2); |
|
4246 |
for i:= 0 to LAND_HEIGHT - 1 do |
|
4247 |
begin |
|
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
4248 |
LandSet(i, leftX, 0); |
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
4249 |
LandSet(i, rightX, 0); |
10354 | 4250 |
end; |
4251 |
end; |
|
4252 |
||
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4253 |
if cWaterLine > 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4254 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4255 |
dec(cWaterLine); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4256 |
for i:= 0 to LAND_WIDTH - 1 do |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
4257 |
LandSet(cWaterLine, i, 0); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4258 |
SetAllToActive |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4259 |
end; |
1298 | 4260 |
|
4153
6bd94e4c5d65
2 more variables to control water rise and health loss during sudden death.
henek
parents:
4135
diff
changeset
|
4261 |
dec(Gear^.Tag); |
1298 | 4262 |
end; |
1573 | 4263 |
|
4264 |
//////////////////////////////////////////////////////////////////////////////// |
|
1590 | 4265 |
procedure doStepDrillDrilling(Gear: PGear); |
8795 | 4266 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4267 |
t: PGearArray; |
8795 | 4268 |
tempColl: Word; |
1573 | 4269 |
begin |
13624
6a06904c7bb8
Fix drill rocket exploding when digging at bounce/wrap world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
13614
diff
changeset
|
4270 |
WorldWrap(Gear); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4271 |
AllInactive := false; |
8822
fc9877ff7f1a
Don't reward digging close w/ drill rocket. Doesn't offer much benefit. Reduce final bonus slightly to avoid using drill like bazooka. Better would be AI doing this for all weps based on count. Make main drill loop a little more efficient.
nemo
parents:
8814
diff
changeset
|
4272 |
if (Gear^.Timer > 0) and (Gear^.Timer mod 10 <> 0) then |
fc9877ff7f1a
Don't reward digging close w/ drill rocket. Doesn't offer much benefit. Reduce final bonus slightly to avoid using drill like bazooka. Better would be AI doing this for all weps based on count. Make main drill loop a little more efficient.
nemo
parents:
8814
diff
changeset
|
4273 |
begin |
fc9877ff7f1a
Don't reward digging close w/ drill rocket. Doesn't offer much benefit. Reduce final bonus slightly to avoid using drill like bazooka. Better would be AI doing this for all weps based on count. Make main drill loop a little more efficient.
nemo
parents:
8814
diff
changeset
|
4274 |
dec(Gear^.Timer); |
fc9877ff7f1a
Don't reward digging close w/ drill rocket. Doesn't offer much benefit. Reduce final bonus slightly to avoid using drill like bazooka. Better would be AI doing this for all weps based on count. Make main drill loop a little more efficient.
nemo
parents:
8814
diff
changeset
|
4275 |
exit; |
fc9877ff7f1a
Don't reward digging close w/ drill rocket. Doesn't offer much benefit. Reduce final bonus slightly to avoid using drill like bazooka. Better would be AI doing this for all weps based on count. Make main drill loop a little more efficient.
nemo
parents:
8814
diff
changeset
|
4276 |
end; |
fc9877ff7f1a
Don't reward digging close w/ drill rocket. Doesn't offer much benefit. Reduce final bonus slightly to avoid using drill like bazooka. Better would be AI doing this for all weps based on count. Make main drill loop a little more efficient.
nemo
parents:
8814
diff
changeset
|
4277 |
|
fc9877ff7f1a
Don't reward digging close w/ drill rocket. Doesn't offer much benefit. Reduce final bonus slightly to avoid using drill like bazooka. Better would be AI doing this for all weps based on count. Make main drill loop a little more efficient.
nemo
parents:
8814
diff
changeset
|
4278 |
DrawTunnel(Gear^.X, Gear^.Y, Gear^.dX, Gear^.dY, 2, 6); |
fc9877ff7f1a
Don't reward digging close w/ drill rocket. Doesn't offer much benefit. Reduce final bonus slightly to avoid using drill like bazooka. Better would be AI doing this for all weps based on count. Make main drill loop a little more efficient.
nemo
parents:
8814
diff
changeset
|
4279 |
Gear^.X := Gear^.X + Gear^.dX; |
fc9877ff7f1a
Don't reward digging close w/ drill rocket. Doesn't offer much benefit. Reduce final bonus slightly to avoid using drill like bazooka. Better would be AI doing this for all weps based on count. Make main drill loop a little more efficient.
nemo
parents:
8814
diff
changeset
|
4280 |
Gear^.Y := Gear^.Y + Gear^.dY; |
fc9877ff7f1a
Don't reward digging close w/ drill rocket. Doesn't offer much benefit. Reduce final bonus slightly to avoid using drill like bazooka. Better would be AI doing this for all weps based on count. Make main drill loop a little more efficient.
nemo
parents:
8814
diff
changeset
|
4281 |
if (Gear^.Timer mod 30) = 0 then |
fc9877ff7f1a
Don't reward digging close w/ drill rocket. Doesn't offer much benefit. Reduce final bonus slightly to avoid using drill like bazooka. Better would be AI doing this for all weps based on count. Make main drill loop a little more efficient.
nemo
parents:
8814
diff
changeset
|
4282 |
AddVisualGear(hwRound(Gear^.X + _20 * Gear^.dX), hwRound(Gear^.Y + _20 * Gear^.dY), vgtDust); |
fc9877ff7f1a
Don't reward digging close w/ drill rocket. Doesn't offer much benefit. Reduce final bonus slightly to avoid using drill like bazooka. Better would be AI doing this for all weps based on count. Make main drill loop a little more efficient.
nemo
parents:
8814
diff
changeset
|
4283 |
if (CheckGearDrowning(Gear)) then |
fc9877ff7f1a
Don't reward digging close w/ drill rocket. Doesn't offer much benefit. Reduce final bonus slightly to avoid using drill like bazooka. Better would be AI doing this for all weps based on count. Make main drill loop a little more efficient.
nemo
parents:
8814
diff
changeset
|
4284 |
begin |
fc9877ff7f1a
Don't reward digging close w/ drill rocket. Doesn't offer much benefit. Reduce final bonus slightly to avoid using drill like bazooka. Better would be AI doing this for all weps based on count. Make main drill loop a little more efficient.
nemo
parents:
8814
diff
changeset
|
4285 |
StopSoundChan(Gear^.SoundChannel); |
fc9877ff7f1a
Don't reward digging close w/ drill rocket. Doesn't offer much benefit. Reduce final bonus slightly to avoid using drill like bazooka. Better would be AI doing this for all weps based on count. Make main drill loop a little more efficient.
nemo
parents:
8814
diff
changeset
|
4286 |
exit |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
4287 |
end; |
8822
fc9877ff7f1a
Don't reward digging close w/ drill rocket. Doesn't offer much benefit. Reduce final bonus slightly to avoid using drill like bazooka. Better would be AI doing this for all weps based on count. Make main drill loop a little more efficient.
nemo
parents:
8814
diff
changeset
|
4288 |
|
8564 | 4289 |
tempColl:= Gear^.CollisionMask; |
13470
7b4643ff60ea
Refactor collision mask checks, remove hardcoded numbers
Wuzzy <Wuzzy2@mail.ru>
parents:
13469
diff
changeset
|
4290 |
Gear^.CollisionMask:= lfObjMask; |
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9698
diff
changeset
|
4291 |
if (TestCollisionYWithGear(Gear, hwSign(Gear^.dY)) <> 0) or (TestCollisionXWithGear(Gear, hwSign(Gear^.dX)) <> 0) or (GameTicks > Gear^.FlightTime) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4292 |
t := CheckGearsCollision(Gear) |
6532
76d63e00002f
Little tweak to reduce noob fail. Delay drill rocket explosion by 250ms after spawn in Attack. Unless you drop it straight down w/ no power, it should not explode immediately in your face.
nemo
parents:
6507
diff
changeset
|
4293 |
else t := nil; |
8564 | 4294 |
Gear^.CollisionMask:= tempColl; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4295 |
//fixes drill not exploding when touching HH bug |
8795 | 4296 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4297 |
if (Gear^.Timer = 0) or ((t <> nil) and (t^.Count <> 0)) |
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9698
diff
changeset
|
4298 |
or ( ((Gear^.State and gsttmpFlag) = 0) and (TestCollisionYWithGear(Gear, hwSign(Gear^.dY)) = 0) and (TestCollisionXWithGear(Gear, hwSign(Gear^.dX)) = 0)) |
3509
d72c2219595d
Make land types flagged (to allow stacking future attributes such as indestructible ice, but also for a damaged flag)
nemo
parents:
3505
diff
changeset
|
4299 |
// CheckLandValue returns true if the type isn't matched |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4300 |
or (not CheckLandValue(hwRound(Gear^.X), hwRound(Gear^.Y), lfIndestructible)) then |
4758
73aef6a577ba
drill strike falling instead of exploding when exiting ground
Henek
parents:
4708
diff
changeset
|
4301 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4302 |
//out of time or exited ground |
7053 | 4303 |
StopSoundChan(Gear^.SoundChannel); |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
4304 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4305 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4306 |
exit |
4758
73aef6a577ba
drill strike falling instead of exploding when exiting ground
Henek
parents:
4708
diff
changeset
|
4307 |
end |
8795 | 4308 |
|
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9698
diff
changeset
|
4309 |
else if (TestCollisionYWithGear(Gear, hwSign(Gear^.dY)) = 0) and (TestCollisionXWithGear(Gear, hwSign(Gear^.dX)) = 0) then |
4758
73aef6a577ba
drill strike falling instead of exploding when exiting ground
Henek
parents:
4708
diff
changeset
|
4310 |
begin |
7053 | 4311 |
StopSoundChan(Gear^.SoundChannel); |
4867
e604ee83e34f
let players set timer of drill strike. yes. drill strike :3 the timer starts to tick on first impact
sheepluva
parents:
4837
diff
changeset
|
4312 |
Gear^.Tag := 1; |
10895
bce67defd804
Make bouncing a bit less wtf for various gears tested (hog, 'zooka, saucer hog, drill strike). Less hacky is another matter.
nemo
parents:
10887
diff
changeset
|
4313 |
Gear^.AdvBounce:= 50; |
4758
73aef6a577ba
drill strike falling instead of exploding when exiting ground
Henek
parents:
4708
diff
changeset
|
4314 |
Gear^.doStep := @doStepDrill |
73aef6a577ba
drill strike falling instead of exploding when exiting ground
Henek
parents:
4708
diff
changeset
|
4315 |
end; |
1590 | 4316 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4317 |
dec(Gear^.Timer); |
1573 | 4318 |
end; |
4319 |
||
4320 |
procedure doStepDrill(Gear: PGear); |
|
8795 | 4321 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4322 |
t: PGearArray; |
10038
0a5e651d494c
Fix uGearsHandlersMess.pas changes lost in merge r1c02143bfe9c.
sheepluva
parents:
10011
diff
changeset
|
4323 |
oldX, oldY, oldDx, oldDy: hwFloat; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
4324 |
t2: hwFloat; |
1573 | 4325 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4326 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4327 |
|
11391 | 4328 |
if (Gear^.State and gsttmpFlag = 0) and (GameFlags and gfMoreWind = 0) then |
4293
d79ffcdd77df
makes drill attack drills weaker and not affected by wind
Henek
parents:
4282
diff
changeset
|
4329 |
Gear^.dX := Gear^.dX + cWindSpeed; |
d79ffcdd77df
makes drill attack drills weaker and not affected by wind
Henek
parents:
4282
diff
changeset
|
4330 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4331 |
oldDx := Gear^.dX; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4332 |
oldDy := Gear^.dY; |
10038
0a5e651d494c
Fix uGearsHandlersMess.pas changes lost in merge r1c02143bfe9c.
sheepluva
parents:
10011
diff
changeset
|
4333 |
oldX := Gear^.X; |
0a5e651d494c
Fix uGearsHandlersMess.pas changes lost in merge r1c02143bfe9c.
sheepluva
parents:
10011
diff
changeset
|
4334 |
oldY := Gear^.Y; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4335 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4336 |
doStepFallingGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4337 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4338 |
if (GameTicks and $3F) = 0 then |
10352 | 4339 |
AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtSmokeTrace); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4340 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4341 |
if ((Gear^.State and gstCollision) <> 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4342 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4343 |
//hit |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4344 |
Gear^.dX := oldDx; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4345 |
Gear^.dY := oldDy; |
10038
0a5e651d494c
Fix uGearsHandlersMess.pas changes lost in merge r1c02143bfe9c.
sheepluva
parents:
10011
diff
changeset
|
4346 |
Gear^.X := oldX; |
0a5e651d494c
Fix uGearsHandlersMess.pas changes lost in merge r1c02143bfe9c.
sheepluva
parents:
10011
diff
changeset
|
4347 |
Gear^.Y := oldY; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4348 |
|
8795 | 4349 |
if GameTicks > Gear^.FlightTime then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4350 |
t := CheckGearsCollision(Gear) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4351 |
else |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4352 |
t := nil; |
6532
76d63e00002f
Little tweak to reduce noob fail. Delay drill rocket explosion by 250ms after spawn in Attack. Unless you drop it straight down w/ no power, it should not explode immediately in your face.
nemo
parents:
6507
diff
changeset
|
4353 |
if (t = nil) or (t^.Count = 0) then |
76d63e00002f
Little tweak to reduce noob fail. Delay drill rocket explosion by 250ms after spawn in Attack. Unless you drop it straight down w/ no power, it should not explode immediately in your face.
nemo
parents:
6507
diff
changeset
|
4354 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4355 |
//hit the ground not the HH |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4356 |
t2 := _0_5 / Distance(Gear^.dX, Gear^.dY); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4357 |
Gear^.dX := Gear^.dX * t2; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4358 |
Gear^.dY := Gear^.dY * t2; |
6532
76d63e00002f
Little tweak to reduce noob fail. Delay drill rocket explosion by 250ms after spawn in Attack. Unless you drop it straight down w/ no power, it should not explode immediately in your face.
nemo
parents:
6507
diff
changeset
|
4359 |
end |
8795 | 4360 |
|
6532
76d63e00002f
Little tweak to reduce noob fail. Delay drill rocket explosion by 250ms after spawn in Attack. Unless you drop it straight down w/ no power, it should not explode immediately in your face.
nemo
parents:
6507
diff
changeset
|
4361 |
else if (t <> nil) then |
76d63e00002f
Little tweak to reduce noob fail. Delay drill rocket explosion by 250ms after spawn in Attack. Unless you drop it straight down w/ no power, it should not explode immediately in your face.
nemo
parents:
6507
diff
changeset
|
4362 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4363 |
//explode right on contact with HH |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
4364 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4365 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4366 |
exit; |
6532
76d63e00002f
Little tweak to reduce noob fail. Delay drill rocket explosion by 250ms after spawn in Attack. Unless you drop it straight down w/ no power, it should not explode immediately in your face.
nemo
parents:
6507
diff
changeset
|
4367 |
end; |
2376 | 4368 |
|
10038
0a5e651d494c
Fix uGearsHandlersMess.pas changes lost in merge r1c02143bfe9c.
sheepluva
parents:
10011
diff
changeset
|
4369 |
Gear^.X:= Gear^.X+Gear^.dX*4; |
0a5e651d494c
Fix uGearsHandlersMess.pas changes lost in merge r1c02143bfe9c.
sheepluva
parents:
10011
diff
changeset
|
4370 |
Gear^.Y:= Gear^.Y+Gear^.dY*4; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4371 |
Gear^.SoundChannel := LoopSound(sndDrillRocket); |
15059 | 4372 |
Gear^.Pos:= 1; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4373 |
Gear^.doStep := @doStepDrillDrilling; |
8795 | 4374 |
|
4867
e604ee83e34f
let players set timer of drill strike. yes. drill strike :3 the timer starts to tick on first impact
sheepluva
parents:
4837
diff
changeset
|
4375 |
if (Gear^.State and gsttmpFlag) <> 0 then |
e604ee83e34f
let players set timer of drill strike. yes. drill strike :3 the timer starts to tick on first impact
sheepluva
parents:
4837
diff
changeset
|
4376 |
gear^.RenderTimer:= true; |
6761 | 4377 |
if Gear^.Timer > 0 then dec(Gear^.Timer) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4378 |
end |
6761 | 4379 |
else if ((Gear^.State and gsttmpFlag) <> 0) and (Gear^.Tag <> 0) then |
4380 |
begin |
|
8795 | 4381 |
if Gear^.Timer > 0 then |
7325 | 4382 |
dec(Gear^.Timer) |
4383 |
else |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4384 |
begin |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
4385 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
6761 | 4386 |
DeleteGear(Gear); |
4387 |
end |
|
4388 |
end; |
|
1590 | 4389 |
end; |
1601 | 4390 |
|
1633 | 4391 |
//////////////////////////////////////////////////////////////////////////////// |
1601 | 4392 |
procedure doStepBallgunWork(Gear: PGear); |
8795 | 4393 |
var |
7296 | 4394 |
HHGear, ball: PGear; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
4395 |
rx, ry: hwFloat; |
3143 | 4396 |
gX, gY: LongInt; |
1601 | 4397 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4398 |
AllInactive := false; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
4399 |
dec(Gear^.Timer); |
4365 | 4400 |
HHGear := Gear^.Hedgehog^.Gear; |
10831
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
4401 |
if HHGear = nil then |
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
4402 |
begin |
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
4403 |
DeleteGear(gear); |
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
4404 |
exit |
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
4405 |
end; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
4406 |
HedgehogChAngle(HHGear); |
3484 | 4407 |
gX := hwRound(Gear^.X) + GetLaunchX(amBallgun, hwSign(HHGear^.dX), HHGear^.Angle); |
4408 |
gY := hwRound(Gear^.Y) + GetLaunchY(amBallgun, HHGear^.Angle); |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
4409 |
if (Gear^.Timer mod 100) = 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4410 |
begin |
7001 | 4411 |
rx := rndSign(getRandomf * _0_1); |
4412 |
ry := rndSign(getRandomf * _0_1); |
|
2376 | 4413 |
|
7296 | 4414 |
ball:= AddGear(gx, gy, gtBall, 0, SignAs(AngleSin(HHGear^.Angle) * _0_8, HHGear^.dX) + rx, AngleCos(HHGear^.Angle) * ( - _0_8) + ry, 0); |
13469
f1d349a52bc7
Refactor: lfCurrentHog→lfCurHogCrate, lfNotCurrentMask→lfNotCurHogCrate
Wuzzy <Wuzzy2@mail.ru>
parents:
13408
diff
changeset
|
4415 |
ball^.CollisionMask:= lfNotCurHogCrate; |
2376 | 4416 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
4417 |
PlaySound(sndGun); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4418 |
end; |
1601 | 4419 |
|
7195
9e6e8e5a4c2e
Check for gstHHDriven instead of damage check, so ballgun stops when turn ends in multiattack mode
unc0rr
parents:
7170
diff
changeset
|
4420 |
if (Gear^.Timer = 0) or ((HHGear^.State and gstHHDriven) = 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4421 |
begin |
10831
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
4422 |
HHGear^.State := HHGear^.State and (not gstNotKickable); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
4423 |
DeleteGear(Gear); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
4424 |
AfterAttack |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4425 |
end |
1601 | 4426 |
end; |
4427 |
||
4428 |
procedure doStepBallgun(Gear: PGear); |
|
8795 | 4429 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4430 |
HHGear: PGear; |
1601 | 4431 |
begin |
4365 | 4432 |
HHGear := Gear^.Hedgehog^.Gear; |
6450 | 4433 |
HHGear^.Message := HHGear^.Message and (not (gmUp or gmDown)); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4434 |
HHGear^.State := HHGear^.State or gstNotKickable; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4435 |
Gear^.doStep := @doStepBallgunWork |
1633 | 4436 |
end; |
1689 | 4437 |
|
1696 | 4438 |
//////////////////////////////////////////////////////////////////////////////// |
1689 | 4439 |
procedure doStepRCPlaneWork(Gear: PGear); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4440 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4441 |
const cAngleSpeed = 3; |
8795 | 4442 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4443 |
HHGear: PGear; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
4444 |
i: LongInt; |
12989
c08c53624c0f
Show remaining ammo when using Birdy egg or RC Plane bomb
Wuzzy <Wuzzy2@mail.ru>
parents:
12914
diff
changeset
|
4445 |
s: ansistring; |
10110
a7aed2eea727
simplify rc-plane's angle-adjustment-after-wrap code
sheepluva
parents:
10108
diff
changeset
|
4446 |
dX, dY : hwFloat; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
4447 |
fChanged: boolean; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
4448 |
trueAngle: Longword; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2944
diff
changeset
|
4449 |
t: PGear; |
1689 | 4450 |
begin |
10110
a7aed2eea727
simplify rc-plane's angle-adjustment-after-wrap code
sheepluva
parents:
10108
diff
changeset
|
4451 |
if WorldWrap(Gear) then |
a7aed2eea727
simplify rc-plane's angle-adjustment-after-wrap code
sheepluva
parents:
10108
diff
changeset
|
4452 |
begin |
10112
275ad81e4718
fix indentation of previous commit and simplify rc-plane's angle-fix after portal code
sheepluva
parents:
10110
diff
changeset
|
4453 |
if (WorldEdge = weBounce) then // mirror |
275ad81e4718
fix indentation of previous commit and simplify rc-plane's angle-fix after portal code
sheepluva
parents:
10110
diff
changeset
|
4454 |
Gear^.Angle:= 4096 - Gear^.Angle |
275ad81e4718
fix indentation of previous commit and simplify rc-plane's angle-fix after portal code
sheepluva
parents:
10110
diff
changeset
|
4455 |
else if (WorldEdge = weSea) then // rotate 90 degree |
275ad81e4718
fix indentation of previous commit and simplify rc-plane's angle-fix after portal code
sheepluva
parents:
10110
diff
changeset
|
4456 |
begin |
275ad81e4718
fix indentation of previous commit and simplify rc-plane's angle-fix after portal code
sheepluva
parents:
10110
diff
changeset
|
4457 |
// sea-wrapped gears move upwards, so let's mirror angle if needed |
275ad81e4718
fix indentation of previous commit and simplify rc-plane's angle-fix after portal code
sheepluva
parents:
10110
diff
changeset
|
4458 |
if Gear^.Angle < 2048 then |
275ad81e4718
fix indentation of previous commit and simplify rc-plane's angle-fix after portal code
sheepluva
parents:
10110
diff
changeset
|
4459 |
Gear^.Angle:= 4096 - Gear^.Angle; |
275ad81e4718
fix indentation of previous commit and simplify rc-plane's angle-fix after portal code
sheepluva
parents:
10110
diff
changeset
|
4460 |
Gear^.Angle:= (Gear^.Angle + 1024) mod 4096; |
275ad81e4718
fix indentation of previous commit and simplify rc-plane's angle-fix after portal code
sheepluva
parents:
10110
diff
changeset
|
4461 |
end; |
9477 | 4462 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4463 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4464 |
|
4365 | 4465 |
HHGear := Gear^.Hedgehog^.Gear; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4466 |
FollowGear := Gear; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4467 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4468 |
if Gear^.Timer > 0 then |
11152
3ac7f6d43200
stop rc plane prop/engine sound when out of fuel
sheepluva
parents:
11070
diff
changeset
|
4469 |
begin |
3ac7f6d43200
stop rc plane prop/engine sound when out of fuel
sheepluva
parents:
11070
diff
changeset
|
4470 |
if Gear^.Timer = 1 then |
3ac7f6d43200
stop rc plane prop/engine sound when out of fuel
sheepluva
parents:
11070
diff
changeset
|
4471 |
begin |
3ac7f6d43200
stop rc plane prop/engine sound when out of fuel
sheepluva
parents:
11070
diff
changeset
|
4472 |
StopSoundChan(Gear^.SoundChannel); |
3ac7f6d43200
stop rc plane prop/engine sound when out of fuel
sheepluva
parents:
11070
diff
changeset
|
4473 |
Gear^.SoundChannel:= -1; |
3ac7f6d43200
stop rc plane prop/engine sound when out of fuel
sheepluva
parents:
11070
diff
changeset
|
4474 |
end; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4475 |
dec(Gear^.Timer); |
11152
3ac7f6d43200
stop rc plane prop/engine sound when out of fuel
sheepluva
parents:
11070
diff
changeset
|
4476 |
end; |
4886 | 4477 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4478 |
fChanged := false; |
9559 | 4479 |
if (HHGear = nil) or ((HHGear^.State and gstHHDriven) = 0) or (Gear^.Timer = 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4480 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4481 |
fChanged := true; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4482 |
if Gear^.Angle > 2048 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4483 |
dec(Gear^.Angle) |
6785 | 4484 |
else if Gear^.Angle < 2048 then |
4485 |
inc(Gear^.Angle) |
|
4486 |
else fChanged := false |
|
10831
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
4487 |
end |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4488 |
else |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4489 |
begin |
3894 | 4490 |
if ((Gear^.Message and gmLeft) <> 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4491 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4492 |
fChanged := true; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4493 |
Gear^.Angle := (Gear^.Angle + (4096 - cAngleSpeed)) mod 4096 |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4494 |
end; |
1689 | 4495 |
|
3894 | 4496 |
if ((Gear^.Message and gmRight) <> 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4497 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4498 |
fChanged := true; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4499 |
Gear^.Angle := (Gear^.Angle + cAngleSpeed) mod 4096 |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4500 |
end |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4501 |
end; |
1689 | 4502 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4503 |
if fChanged then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4504 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4505 |
Gear^.dX.isNegative := (Gear^.Angle > 2048); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4506 |
if Gear^.dX.isNegative then |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4507 |
trueAngle := 4096 - Gear^.Angle |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4508 |
else |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4509 |
trueAngle := Gear^.Angle; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4510 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4511 |
Gear^.dX := SignAs(AngleSin(trueAngle), Gear^.dX) * _0_25; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4512 |
Gear^.dY := AngleCos(trueAngle) * -_0_25; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4513 |
end; |
1689 | 4514 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4515 |
Gear^.X := Gear^.X + Gear^.dX; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4516 |
Gear^.Y := Gear^.Y + Gear^.dY; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4517 |
|
4808 | 4518 |
if (GameTicks and $FF) = 0 then |
4519 |
if Gear^.Timer < 3500 then |
|
4520 |
AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtEvilTrace) |
|
4521 |
else |
|
4522 |
AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtSmokeTrace); |
|
4523 |
||
12989
c08c53624c0f
Show remaining ammo when using Birdy egg or RC Plane bomb
Wuzzy <Wuzzy2@mail.ru>
parents:
12914
diff
changeset
|
4524 |
if (HHGear <> nil) and ((HHGear^.Message and gmAttack) <> 0) then |
c08c53624c0f
Show remaining ammo when using Birdy egg or RC Plane bomb
Wuzzy <Wuzzy2@mail.ru>
parents:
12914
diff
changeset
|
4525 |
begin |
c08c53624c0f
Show remaining ammo when using Birdy egg or RC Plane bomb
Wuzzy <Wuzzy2@mail.ru>
parents:
12914
diff
changeset
|
4526 |
if (Gear^.Health) <> 0 then |
c08c53624c0f
Show remaining ammo when using Birdy egg or RC Plane bomb
Wuzzy <Wuzzy2@mail.ru>
parents:
12914
diff
changeset
|
4527 |
begin |
c08c53624c0f
Show remaining ammo when using Birdy egg or RC Plane bomb
Wuzzy <Wuzzy2@mail.ru>
parents:
12914
diff
changeset
|
4528 |
HHGear^.Message := HHGear^.Message and (not gmAttack); |
c08c53624c0f
Show remaining ammo when using Birdy egg or RC Plane bomb
Wuzzy <Wuzzy2@mail.ru>
parents:
12914
diff
changeset
|
4529 |
AddGear(hwRound(Gear^.X), hwRound(Gear^.Y), gtAirBomb, 0, Gear^.dX * _0_5, Gear^.dY * |
c08c53624c0f
Show remaining ammo when using Birdy egg or RC Plane bomb
Wuzzy <Wuzzy2@mail.ru>
parents:
12914
diff
changeset
|
4530 |
_0_5, 0); |
c08c53624c0f
Show remaining ammo when using Birdy egg or RC Plane bomb
Wuzzy <Wuzzy2@mail.ru>
parents:
12914
diff
changeset
|
4531 |
dec(Gear^.Health) |
c08c53624c0f
Show remaining ammo when using Birdy egg or RC Plane bomb
Wuzzy <Wuzzy2@mail.ru>
parents:
12914
diff
changeset
|
4532 |
end; |
c08c53624c0f
Show remaining ammo when using Birdy egg or RC Plane bomb
Wuzzy <Wuzzy2@mail.ru>
parents:
12914
diff
changeset
|
4533 |
s:= ansistring(inttostr(Gear^.Health)); |
13642
3d14950641a4
Refactor text color variable names, export 2 color values to Lua
Wuzzy <Wuzzy2@mail.ru>
parents:
13640
diff
changeset
|
4534 |
AddCaption(formatA(trmsg[sidRemaining], s), capcolDefault, capgrpAmmostate); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4535 |
end; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4536 |
|
9559 | 4537 |
if (HHGear <> nil) and ((HHGear^.Message and gmLJump) <> 0) and ((Gear^.State and gsttmpFlag) = 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4538 |
begin |
4808 | 4539 |
Gear^.State := Gear^.State or gsttmpFlag; |
13996
350adfa0e896
Refactor usage of sndRideOfTheValkyries, now can play if music is on and sound is off
Wuzzy <Wuzzy2@mail.ru>
parents:
13995
diff
changeset
|
4540 |
PlayMusicSound(sndRideOfTheValkyries); |
11519
aab4767d9a50
adding a "cinematic mode" - currently: black bars on bottom/top. triggered by rcplane when pressing enter
sheepluva
parents:
11475
diff
changeset
|
4541 |
inCinematicMode:= true; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4542 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4543 |
|
4808 | 4544 |
// pickup bonuses |
4545 |
t := CheckGearNear(Gear, gtCase, 36, 36); |
|
10234 | 4546 |
if (t <> nil) and (HHGear <> nil) then |
4808 | 4547 |
PickUp(HHGear, t); |
4548 |
||
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4549 |
CheckCollision(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4550 |
|
4808 | 4551 |
if ((Gear^.State and gstCollision) <> 0) or CheckGearDrowning(Gear) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4552 |
begin |
11519
aab4767d9a50
adding a "cinematic mode" - currently: black bars on bottom/top. triggered by rcplane when pressing enter
sheepluva
parents:
11475
diff
changeset
|
4553 |
inCinematicMode:= false; |
7053 | 4554 |
StopSoundChan(Gear^.SoundChannel); |
13996
350adfa0e896
Refactor usage of sndRideOfTheValkyries, now can play if music is on and sound is off
Wuzzy <Wuzzy2@mail.ru>
parents:
13995
diff
changeset
|
4555 |
StopMusicSound(sndRideOfTheValkyries); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4556 |
|
4808 | 4557 |
if ((Gear^.State and gstCollision) <> 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4558 |
begin |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
4559 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
5228 | 4560 |
for i:= 0 to 15 do |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4561 |
begin |
7001 | 4562 |
dX := AngleCos(i * 64) * _0_5 * (GetRandomf + _1); |
4563 |
dY := AngleSin(i * 64) * _0_5 * (GetRandomf + _1); |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4564 |
AddGear(hwRound(Gear^.X), hwRound(Gear^.Y), gtFlame, 0, dX, dY, 0); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4565 |
AddGear(hwRound(Gear^.X), hwRound(Gear^.Y), gtFlame, 0, dX, -dY, 0); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4566 |
end; |
10831
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
4567 |
if HHGear <> nil then HHGear^.State := HHGear^.State and (not gstNotKickable); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4568 |
DeleteGear(Gear) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4569 |
end; |
1713 | 4570 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4571 |
AfterAttack; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4572 |
CurAmmoGear := nil; |
5016
9347d82a26cc
added game mode Tag Team, mostly untested, please test :)
Henek
parents:
5013
diff
changeset
|
4573 |
if (GameFlags and gfInfAttack) = 0 then |
9347d82a26cc
added game mode Tag Team, mostly untested, please test :)
Henek
parents:
5013
diff
changeset
|
4574 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4575 |
if TagTurnTimeLeft = 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4576 |
TagTurnTimeLeft:= TurnTimeLeft; |
8795 | 4577 |
|
5016
9347d82a26cc
added game mode Tag Team, mostly untested, please test :)
Henek
parents:
5013
diff
changeset
|
4578 |
TurnTimeLeft:= 14 * 125; |
9347d82a26cc
added game mode Tag Team, mostly untested, please test :)
Henek
parents:
5013
diff
changeset
|
4579 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4580 |
|
10510 | 4581 |
if HHGear <> nil then |
12815
92218a06c9ff
Don't send taunt message for automatically happening taunt animation
unc0rr
parents:
12806
diff
changeset
|
4582 |
begin |
10234 | 4583 |
HHGear^.Message := 0; |
12815
92218a06c9ff
Don't send taunt message for automatically happening taunt animation
unc0rr
parents:
12806
diff
changeset
|
4584 |
PlayTaunt(1) |
92218a06c9ff
Don't send taunt message for automatically happening taunt animation
unc0rr
parents:
12806
diff
changeset
|
4585 |
end |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4586 |
end |
1689 | 4587 |
end; |
4588 |
||
4589 |
procedure doStepRCPlane(Gear: PGear); |
|
8795 | 4590 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4591 |
HHGear: PGear; |
1689 | 4592 |
begin |
4365 | 4593 |
HHGear := Gear^.Hedgehog^.Gear; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4594 |
HHGear^.Message := 0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4595 |
HHGear^.State := HHGear^.State or gstNotKickable; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4596 |
Gear^.Angle := HHGear^.Angle; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4597 |
Gear^.Tag := hwSign(HHGear^.dX); |
8795 | 4598 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4599 |
if HHGear^.dX.isNegative then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4600 |
Gear^.Angle := 4096 - Gear^.Angle; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4601 |
Gear^.doStep := @doStepRCPlaneWork |
1712 | 4602 |
end; |
2177
c045698e044f
Initial attempt at jetpack. Pluses, more like lunar lander (takes fall damage). Minuses, can't seem to cancel it or use alt weapon
nemo
parents:
2143
diff
changeset
|
4603 |
|
5313
5e18eaef65d0
now scripts can create unique crates: dummy (empty) crates and booby traps. scripts can also set health crate values
Henek
parents:
5298
diff
changeset
|
4604 |
//////////////////////////////////////////////////////////////////////////////// |
2177
c045698e044f
Initial attempt at jetpack. Pluses, more like lunar lander (takes fall damage). Minuses, can't seem to cancel it or use alt weapon
nemo
parents:
2143
diff
changeset
|
4605 |
procedure doStepJetpackWork(Gear: PGear); |
8795 | 4606 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4607 |
HHGear: PGear; |
3909
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4608 |
fuel, i: LongInt; |
2177
c045698e044f
Initial attempt at jetpack. Pluses, more like lunar lander (takes fall damage). Minuses, can't seem to cancel it or use alt weapon
nemo
parents:
2143
diff
changeset
|
4609 |
move: hwFloat; |
3909
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4610 |
isUnderwater: Boolean; |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4611 |
bubble: PVisualGear; |
2177
c045698e044f
Initial attempt at jetpack. Pluses, more like lunar lander (takes fall damage). Minuses, can't seem to cancel it or use alt weapon
nemo
parents:
2143
diff
changeset
|
4612 |
begin |
10354 | 4613 |
isUnderwater:= CheckCoordInWater(hwRound(Gear^.X), hwRound(Gear^.Y) + Gear^.Radius); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4614 |
if Gear^.Pos > 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4615 |
dec(Gear^.Pos); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4616 |
AllInactive := false; |
4365 | 4617 |
HHGear := Gear^.Hedgehog^.Gear; |
3907
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4618 |
move := _0_2; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4619 |
fuel := 50; |
8987
47cf32305d99
some saucer thing for firing weps underwater and aiming and such. bit drunk and sleepy so testing I guess
nemo
parents:
8973
diff
changeset
|
4620 |
if HHGear^.Message and gmPrecise <> 0 then |
47cf32305d99
some saucer thing for firing weps underwater and aiming and such. bit drunk and sleepy so testing I guess
nemo
parents:
8973
diff
changeset
|
4621 |
HedgehogChAngle(HHGear) |
13593
083733ec7941
Add support for infinite fly time of jetpack and Birdy
Wuzzy <Wuzzy2@mail.ru>
parents:
13572
diff
changeset
|
4622 |
else if (Gear^.Health > 0) or (Gear^.Health = JETPACK_FUEL_INFINITE) then |
8987
47cf32305d99
some saucer thing for firing weps underwater and aiming and such. bit drunk and sleepy so testing I guess
nemo
parents:
8973
diff
changeset
|
4623 |
begin |
47cf32305d99
some saucer thing for firing weps underwater and aiming and such. bit drunk and sleepy so testing I guess
nemo
parents:
8973
diff
changeset
|
4624 |
if HHGear^.Message and gmUp <> 0 then |
3907
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4625 |
begin |
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4626 |
if (not HHGear^.dY.isNegative) or (HHGear^.Y > -_256) then |
3909
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4627 |
begin |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4628 |
if isUnderwater then |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4629 |
begin |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4630 |
HHGear^.dY := HHGear^.dY - (move * _0_7); |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4631 |
for i:= random(10)+10 downto 0 do |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4632 |
begin |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4633 |
bubble := AddVisualGear(hwRound(HHGear^.X) - 8 + random(16), hwRound(HHGear^.Y) + 16 + random(8), vgtBubble); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4634 |
if bubble <> nil then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4635 |
bubble^.dY:= random(20)/10+0.1; |
3909
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4636 |
end |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4637 |
end |
11911
6145efcff302
Add sounds for blowtorch, invuln., f. saucer, lasersight, portal gun
Wuzzy <almikes@aol.com>
parents:
11860
diff
changeset
|
4638 |
else |
6145efcff302
Add sounds for blowtorch, invuln., f. saucer, lasersight, portal gun
Wuzzy <almikes@aol.com>
parents:
11860
diff
changeset
|
4639 |
begin |
6145efcff302
Add sounds for blowtorch, invuln., f. saucer, lasersight, portal gun
Wuzzy <almikes@aol.com>
parents:
11860
diff
changeset
|
4640 |
PlaySound(sndJetpackBoost); |
6145efcff302
Add sounds for blowtorch, invuln., f. saucer, lasersight, portal gun
Wuzzy <almikes@aol.com>
parents:
11860
diff
changeset
|
4641 |
HHGear^.dY := HHGear^.dY - move; |
6145efcff302
Add sounds for blowtorch, invuln., f. saucer, lasersight, portal gun
Wuzzy <almikes@aol.com>
parents:
11860
diff
changeset
|
4642 |
end |
3909
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4643 |
end; |
13593
083733ec7941
Add support for infinite fly time of jetpack and Birdy
Wuzzy <Wuzzy2@mail.ru>
parents:
13572
diff
changeset
|
4644 |
if Gear^.Health <> JETPACK_FUEL_INFINITE then |
083733ec7941
Add support for infinite fly time of jetpack and Birdy
Wuzzy <Wuzzy2@mail.ru>
parents:
13572
diff
changeset
|
4645 |
dec(Gear^.Health, fuel); |
3907
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4646 |
Gear^.MsgParam := Gear^.MsgParam or gmUp; |
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4647 |
Gear^.Timer := GameTicks |
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4648 |
end; |
3909
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4649 |
move.isNegative := (HHGear^.Message and gmLeft) <> 0; |
3907
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4650 |
if (HHGear^.Message and (gmLeft or gmRight)) <> 0 then |
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4651 |
begin |
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4652 |
HHGear^.dX := HHGear^.dX + (move * _0_1); |
3909
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4653 |
if isUnderwater then |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4654 |
begin |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4655 |
for i:= random(5)+5 downto 0 do |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4656 |
begin |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4657 |
bubble := AddVisualGear(hwRound(HHGear^.X)+random(8), hwRound(HHGear^.Y) - 8 + random(16), vgtBubble); |
6131 | 4658 |
if bubble <> nil then |
3909
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4659 |
begin |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4660 |
bubble^.dX:= (random(10)/10 + 0.02) * -1; |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4661 |
if (move.isNegative) then |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4662 |
begin |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4663 |
bubble^.X := bubble^.X + 28; |
4187 | 4664 |
bubble^.dX:= bubble^.dX * (-1) |
3909
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4665 |
end |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4666 |
else bubble^.X := bubble^.X - 28; |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4667 |
end; |
4ba25a3d15af
remove windspeed from bubbles, remove initial dY from bubbles, apply dY/dX to bubbles, correct offsets on flying saucer flame graphics, add bubbles when flying saucer thrusts underwater, make flying saucer sink more slowly underwater
nemo
parents:
3907
diff
changeset
|
4668 |
end |
11911
6145efcff302
Add sounds for blowtorch, invuln., f. saucer, lasersight, portal gun
Wuzzy <almikes@aol.com>
parents:
11860
diff
changeset
|
4669 |
end |
6145efcff302
Add sounds for blowtorch, invuln., f. saucer, lasersight, portal gun
Wuzzy <almikes@aol.com>
parents:
11860
diff
changeset
|
4670 |
else PlaySound(sndJetpackBoost); |
13593
083733ec7941
Add support for infinite fly time of jetpack and Birdy
Wuzzy <Wuzzy2@mail.ru>
parents:
13572
diff
changeset
|
4671 |
if Gear^.Health <> JETPACK_FUEL_INFINITE then |
083733ec7941
Add support for infinite fly time of jetpack and Birdy
Wuzzy <Wuzzy2@mail.ru>
parents:
13572
diff
changeset
|
4672 |
dec(Gear^.Health, fuel div 5); |
3907
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4673 |
Gear^.MsgParam := Gear^.MsgParam or (HHGear^.Message and (gmLeft or gmRight)); |
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4674 |
Gear^.Timer := GameTicks |
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4675 |
end |
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4676 |
end; |
2182
ed7e7eb3f9ed
Ugly graphic for jetpack - jetpack should be essentially functional.
nemo
parents:
2181
diff
changeset
|
4677 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4678 |
// erases them all at once :-/ |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4679 |
if (Gear^.Timer <> 0) and (GameTicks - Gear^.Timer > 250) then |
4262
154253f77b03
ok... combine a tick check with texture percentage check. this should be a lot less frequent
nemo
parents:
4260
diff
changeset
|
4680 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4681 |
Gear^.Timer := 0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4682 |
Gear^.MsgParam := 0 |
4262
154253f77b03
ok... combine a tick check with texture percentage check. this should be a lot less frequent
nemo
parents:
4260
diff
changeset
|
4683 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4684 |
|
13593
083733ec7941
Add support for infinite fly time of jetpack and Birdy
Wuzzy <Wuzzy2@mail.ru>
parents:
13572
diff
changeset
|
4685 |
if (Gear^.Health < 0) and (Gear^.Health <> JETPACK_FUEL_INFINITE) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4686 |
Gear^.Health := 0; |
8795 | 4687 |
|
4260
472fd2fc1f31
Also switch saucer from updating every N ticks to updating as-needed.
nemo
parents:
4258
diff
changeset
|
4688 |
i:= Gear^.Health div 20; |
8795 | 4689 |
|
15381
c117e17b90bc
flag some of the renderstringtex which are taking up a ton of processing time with --stats-only and pas2c
nemo
parents:
15354
diff
changeset
|
4690 |
if (not cOnlyStats) and (i <> Gear^.Damage) and ((GameTicks and $3F) = 0) then |
3907
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4691 |
begin |
4260
472fd2fc1f31
Also switch saucer from updating every N ticks to updating as-needed.
nemo
parents:
4258
diff
changeset
|
4692 |
Gear^.Damage:= i; |
10634
35d059bd0932
Use FreeAndNil across the board. Even if we are immediately assigning after, probably avoids accidental mistakes. Also free neglected owner tex on shutdown, and delete hog gears using the normal deletion procedure if for any reason they still exist (EndGame call?).
nemo
parents:
10597
diff
changeset
|
4693 |
FreeAndNilTexture(Gear^.Tex); |
13593
083733ec7941
Add support for infinite fly time of jetpack and Birdy
Wuzzy <Wuzzy2@mail.ru>
parents:
13572
diff
changeset
|
4694 |
if Gear^.Health <> JETPACK_FUEL_INFINITE then |
13898 | 4695 |
Gear^.Tex := RenderStringTex(FormatA(trmsg[sidFuel], ansistring(inttostr(i))), cWhiteColor, fntSmall) |
3907
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4696 |
end; |
2182
ed7e7eb3f9ed
Ugly graphic for jetpack - jetpack should be essentially functional.
nemo
parents:
2181
diff
changeset
|
4697 |
|
8987
47cf32305d99
some saucer thing for firing weps underwater and aiming and such. bit drunk and sleepy so testing I guess
nemo
parents:
8973
diff
changeset
|
4698 |
if (HHGear^.Message and (gmAttack or gmUp or gmLeft or gmRight) <> 0) and |
15318
6afce21e60c3
Saucer: Restore dX after "freeze" state
Wuzzy <Wuzzy2@mail.ru>
parents:
15317
diff
changeset
|
4699 |
(HHGear^.Message and gmPrecise = 0) and |
6afce21e60c3
Saucer: Restore dX after "freeze" state
Wuzzy <Wuzzy2@mail.ru>
parents:
15317
diff
changeset
|
4700 |
((Gear^.State and gsttmpFlag) <> 0) then |
6afce21e60c3
Saucer: Restore dX after "freeze" state
Wuzzy <Wuzzy2@mail.ru>
parents:
15317
diff
changeset
|
4701 |
begin |
6450 | 4702 |
Gear^.State := Gear^.State and (not gsttmpFlag); |
15318
6afce21e60c3
Saucer: Restore dX after "freeze" state
Wuzzy <Wuzzy2@mail.ru>
parents:
15317
diff
changeset
|
4703 |
HHGear^.dX := Gear^.dX; |
6afce21e60c3
Saucer: Restore dX after "freeze" state
Wuzzy <Wuzzy2@mail.ru>
parents:
15317
diff
changeset
|
4704 |
end; |
8795 | 4705 |
|
8987
47cf32305d99
some saucer thing for firing weps underwater and aiming and such. bit drunk and sleepy so testing I guess
nemo
parents:
8973
diff
changeset
|
4706 |
if HHGear^.Message and gmPrecise = 0 then |
47cf32305d99
some saucer thing for firing weps underwater and aiming and such. bit drunk and sleepy so testing I guess
nemo
parents:
8973
diff
changeset
|
4707 |
HHGear^.Message := HHGear^.Message and (not (gmUp or gmLeft or gmRight)); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4708 |
HHGear^.State := HHGear^.State or gstMoving; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4709 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4710 |
Gear^.X := HHGear^.X; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4711 |
Gear^.Y := HHGear^.Y; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4712 |
|
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4713 |
if not isUnderWater and hasBorder and ((HHGear^.X < _0) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4714 |
or (hwRound(HHGear^.X) > LAND_WIDTH)) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4715 |
HHGear^.dY.isNegative:= false; |
8795 | 4716 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4717 |
if ((Gear^.State and gsttmpFlag) = 0) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4718 |
or (HHGear^.dY < _0) then |
15317
b5171e6c94a4
Fix movement stopping when activating saucer after longjump
Wuzzy <Wuzzy2@mail.ru>
parents:
15299
diff
changeset
|
4719 |
doStepHedgehogMoving(HHGear) |
b5171e6c94a4
Fix movement stopping when activating saucer after longjump
Wuzzy <Wuzzy2@mail.ru>
parents:
15299
diff
changeset
|
4720 |
else |
b5171e6c94a4
Fix movement stopping when activating saucer after longjump
Wuzzy <Wuzzy2@mail.ru>
parents:
15299
diff
changeset
|
4721 |
HHGear^.dX:= SignAs(_0, HHGear^.dX); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4722 |
|
14593
34e810295d08
Remove a bunch of dead out-commented code
Wuzzy <Wuzzy2@mail.ru>
parents:
14591
diff
changeset
|
4723 |
if |
3907
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4724 |
(HHGear^.Damage <> 0) |
10354 | 4725 |
// drown if too deep under water |
8990 | 4726 |
or (cWaterLine + cVisibleWater * 4 < hwRound(HHGear^.Y)) |
3907
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4727 |
or (TurnTimeLeft = 0) |
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4728 |
// allow brief ground touches - to be fair on this, might need another counter |
6081
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
4729 |
or (((GameTicks and $1FF) = 0) and (not HHGear^.dY.isNegative) and (TestCollisionYwithGear(HHGear, 1) <> 0)) |
3907
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4730 |
or ((Gear^.Message and gmAttack) <> 0) then |
4233
b4ad20bfe310
make weapons on rope/parachute/UFO inherit momentum of the hog. needs testing of course
nemo
parents:
4224
diff
changeset
|
4731 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4732 |
with HHGear^ do |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4733 |
begin |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4734 |
Message := 0; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4735 |
Active := true; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4736 |
State := State or gstMoving |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4737 |
end; |
13977
2568fa516733
Fix hog can drop more than 2 s. mines if first one was dropped from utility, then stop using that utility
Wuzzy <Wuzzy2@mail.ru>
parents:
13898
diff
changeset
|
4738 |
if (GetAmmoEntry(HHGear^.Hedgehog^, amJetpack)^.Count >= 1) and ((Ammoz[HHGear^.Hedgehog^.CurAmmoType].Ammo.Propz and ammoprop_AltUse) <> 0) and (HHGear^.Hedgehog^.MultiShootAttacks = 0) then |
12820
4c1c468725ff
Fix desync when dropping weapon from parachute or jetpack
Wuzzy <Wuzzy2@mail.ru>
parents:
12815
diff
changeset
|
4739 |
HHGear^.Hedgehog^.CurAmmoType:= amJetpack; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4740 |
isCursorVisible := false; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4741 |
ApplyAmmoChanges(HHGear^.Hedgehog^); |
14575 | 4742 |
DeleteGear(Gear); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4743 |
end |
2177
c045698e044f
Initial attempt at jetpack. Pluses, more like lunar lander (takes fall damage). Minuses, can't seem to cancel it or use alt weapon
nemo
parents:
2143
diff
changeset
|
4744 |
end; |
c045698e044f
Initial attempt at jetpack. Pluses, more like lunar lander (takes fall damage). Minuses, can't seem to cancel it or use alt weapon
nemo
parents:
2143
diff
changeset
|
4745 |
|
c045698e044f
Initial attempt at jetpack. Pluses, more like lunar lander (takes fall damage). Minuses, can't seem to cancel it or use alt weapon
nemo
parents:
2143
diff
changeset
|
4746 |
procedure doStepJetpack(Gear: PGear); |
8795 | 4747 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4748 |
HHGear: PGear; |
2177
c045698e044f
Initial attempt at jetpack. Pluses, more like lunar lander (takes fall damage). Minuses, can't seem to cancel it or use alt weapon
nemo
parents:
2143
diff
changeset
|
4749 |
begin |
3907
5b516f0d9957
Allow UFO to go underwater. Keep UFO active if it runs out of fuel in the air/water, just disable controls.
nemo
parents:
3894
diff
changeset
|
4750 |
Gear^.Pos:= 0; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4751 |
Gear^.doStep := @doStepJetpackWork; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4752 |
|
4365 | 4753 |
HHGear := Gear^.Hedgehog^.Gear; |
11911
6145efcff302
Add sounds for blowtorch, invuln., f. saucer, lasersight, portal gun
Wuzzy <almikes@aol.com>
parents:
11860
diff
changeset
|
4754 |
|
6145efcff302
Add sounds for blowtorch, invuln., f. saucer, lasersight, portal gun
Wuzzy <almikes@aol.com>
parents:
11860
diff
changeset
|
4755 |
PlaySound(sndJetpackLaunch); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4756 |
FollowGear := HHGear; |
3965
09eea558ba83
Call OnUsedAmmo *after* doing the normal CurAmmoType stuff so CurAmmoType actually points to the right bloody weapon
nemo
parents:
3963
diff
changeset
|
4757 |
AfterAttack; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4758 |
with HHGear^ do |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4759 |
begin |
6450 | 4760 |
State := State and (not gstAttacking); |
4761 |
Message := Message and (not (gmAttack or gmUp or gmPrecise or gmLeft or gmRight)); |
|
8795 | 4762 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4763 |
if (dY < _0_1) and (dY > -_0_1) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4764 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4765 |
Gear^.State := Gear^.State or gsttmpFlag; |
15318
6afce21e60c3
Saucer: Restore dX after "freeze" state
Wuzzy <Wuzzy2@mail.ru>
parents:
15317
diff
changeset
|
4766 |
dY := dY - _0_2; |
6afce21e60c3
Saucer: Restore dX after "freeze" state
Wuzzy <Wuzzy2@mail.ru>
parents:
15317
diff
changeset
|
4767 |
Gear^.dX:= dX; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4768 |
end |
2301 | 4769 |
end |
2177
c045698e044f
Initial attempt at jetpack. Pluses, more like lunar lander (takes fall damage). Minuses, can't seem to cancel it or use alt weapon
nemo
parents:
2143
diff
changeset
|
4770 |
end; |
2983 | 4771 |
|
4772 |
//////////////////////////////////////////////////////////////////////////////// |
|
3149 | 4773 |
procedure doStepBirdyDisappear(Gear: PGear); |
2983 | 4774 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4775 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4776 |
Gear^.Pos := 0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4777 |
if Gear^.Timer < 2000 then |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4778 |
inc(Gear^.Timer, 1) |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4779 |
else |
14575 | 4780 |
DeleteGear(Gear) |
2983 | 4781 |
end; |
4782 |
||
4783 |
procedure doStepBirdyFly(Gear: PGear); |
|
8795 | 4784 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4785 |
HHGear: PGear; |
13593
083733ec7941
Add support for infinite fly time of jetpack and Birdy
Wuzzy <Wuzzy2@mail.ru>
parents:
13572
diff
changeset
|
4786 |
energy, i: LongInt; |
2983 | 4787 |
move: hwFloat; |
12989
c08c53624c0f
Show remaining ammo when using Birdy egg or RC Plane bomb
Wuzzy <Wuzzy2@mail.ru>
parents:
12914
diff
changeset
|
4788 |
s: ansistring; |
2983 | 4789 |
begin |
6154 | 4790 |
HHGear := Gear^.Hedgehog^.Gear; |
8795 | 4791 |
if HHGear = nil then |
6154 | 4792 |
begin |
9698 | 4793 |
Gear^.Timer := 0; |
4794 |
Gear^.State := Gear^.State or gstAnimation or gstTmpFlag; |
|
4795 |
Gear^.Timer := 0; |
|
4796 |
Gear^.doStep := @doStepBirdyDisappear; |
|
4797 |
CurAmmoGear := nil; |
|
4798 |
isCursorVisible := false; |
|
4799 |
AfterAttack; |
|
6154 | 4800 |
exit |
4801 |
end; |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4802 |
|
3915
c05855146440
Correct bug in flight ceiling for birdy as well, increase clip on velocity to 1.9 (shouldn't cause problems with most collision checks still), apply clip to both + and -
nemo
parents:
3909
diff
changeset
|
4803 |
move := _0_2; |
13593
083733ec7941
Add support for infinite fly time of jetpack and Birdy
Wuzzy <Wuzzy2@mail.ru>
parents:
13572
diff
changeset
|
4804 |
energy:= 50; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4805 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4806 |
if Gear^.Pos > 0 then |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4807 |
dec(Gear^.Pos, 1) |
3894 | 4808 |
else if (HHGear^.Message and (gmLeft or gmRight or gmUp)) <> 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4809 |
Gear^.Pos := 500; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4810 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4811 |
if HHGear^.dX.isNegative then |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4812 |
Gear^.Tag := -1 |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4813 |
else |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4814 |
Gear^.Tag := 1; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4815 |
|
3894 | 4816 |
if (HHGear^.Message and gmUp) <> 0 then |
4272
cf18de7ea3d4
engine side of a more wind patch. no frontend hook. just want to check it in to pull it from another machine
nemo
parents:
4265
diff
changeset
|
4817 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4818 |
if (not HHGear^.dY.isNegative) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4819 |
or (HHGear^.Y > -_256) then |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4820 |
HHGear^.dY := HHGear^.dY - move; |
8795 | 4821 |
|
13593
083733ec7941
Add support for infinite fly time of jetpack and Birdy
Wuzzy <Wuzzy2@mail.ru>
parents:
13572
diff
changeset
|
4822 |
if (Gear^.Health <> BIRDY_ENERGY_INFINITE) then |
083733ec7941
Add support for infinite fly time of jetpack and Birdy
Wuzzy <Wuzzy2@mail.ru>
parents:
13572
diff
changeset
|
4823 |
dec(Gear^.Health, energy); |
3894 | 4824 |
Gear^.MsgParam := Gear^.MsgParam or gmUp; |
4272
cf18de7ea3d4
engine side of a more wind patch. no frontend hook. just want to check it in to pull it from another machine
nemo
parents:
4265
diff
changeset
|
4825 |
end; |
8795 | 4826 |
|
3894 | 4827 |
if (HHGear^.Message and gmLeft) <> 0 then move.isNegative := true; |
4828 |
if (HHGear^.Message and (gmLeft or gmRight)) <> 0 then |
|
4272
cf18de7ea3d4
engine side of a more wind patch. no frontend hook. just want to check it in to pull it from another machine
nemo
parents:
4265
diff
changeset
|
4829 |
begin |
3915
c05855146440
Correct bug in flight ceiling for birdy as well, increase clip on velocity to 1.9 (shouldn't cause problems with most collision checks still), apply clip to both + and -
nemo
parents:
3909
diff
changeset
|
4830 |
HHGear^.dX := HHGear^.dX + (move * _0_1); |
13593
083733ec7941
Add support for infinite fly time of jetpack and Birdy
Wuzzy <Wuzzy2@mail.ru>
parents:
13572
diff
changeset
|
4831 |
if (Gear^.Health <> BIRDY_ENERGY_INFINITE) then |
083733ec7941
Add support for infinite fly time of jetpack and Birdy
Wuzzy <Wuzzy2@mail.ru>
parents:
13572
diff
changeset
|
4832 |
dec(Gear^.Health, energy div 5); |
3894 | 4833 |
Gear^.MsgParam := Gear^.MsgParam or (HHGear^.Message and (gmLeft or gmRight)); |
4272
cf18de7ea3d4
engine side of a more wind patch. no frontend hook. just want to check it in to pull it from another machine
nemo
parents:
4265
diff
changeset
|
4834 |
end; |
2983 | 4835 |
|
13593
083733ec7941
Add support for infinite fly time of jetpack and Birdy
Wuzzy <Wuzzy2@mail.ru>
parents:
13572
diff
changeset
|
4836 |
if (Gear^.Health < 0) and (Gear^.Health <> BIRDY_ENERGY_INFINITE) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4837 |
Gear^.Health := 0; |
8795 | 4838 |
|
13593
083733ec7941
Add support for infinite fly time of jetpack and Birdy
Wuzzy <Wuzzy2@mail.ru>
parents:
13572
diff
changeset
|
4839 |
if ((GameTicks and $FF) = 0) and (Gear^.Health < 500) and (Gear^.Health <> BIRDY_ENERGY_INFINITE) then |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4840 |
for i:= ((500-Gear^.Health) div 250) downto 0 do |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4841 |
AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtFeather); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4842 |
|
3894 | 4843 |
if (HHGear^.Message and gmAttack <> 0) then |
4272
cf18de7ea3d4
engine side of a more wind patch. no frontend hook. just want to check it in to pull it from another machine
nemo
parents:
4265
diff
changeset
|
4844 |
begin |
6450 | 4845 |
HHGear^.Message := HHGear^.Message and (not gmAttack); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4846 |
if Gear^.FlightTime > 0 then |
4272
cf18de7ea3d4
engine side of a more wind patch. no frontend hook. just want to check it in to pull it from another machine
nemo
parents:
4265
diff
changeset
|
4847 |
begin |
cf18de7ea3d4
engine side of a more wind patch. no frontend hook. just want to check it in to pull it from another machine
nemo
parents:
4265
diff
changeset
|
4848 |
AddGear(hwRound(Gear^.X), hwRound(Gear^.Y) + 32, gtEgg, 0, Gear^.dX * _0_5, Gear^.dY, 0); |
3123 | 4849 |
PlaySound(sndBirdyLay); |
3115 | 4850 |
dec(Gear^.FlightTime) |
4272
cf18de7ea3d4
engine side of a more wind patch. no frontend hook. just want to check it in to pull it from another machine
nemo
parents:
4265
diff
changeset
|
4851 |
end; |
12989
c08c53624c0f
Show remaining ammo when using Birdy egg or RC Plane bomb
Wuzzy <Wuzzy2@mail.ru>
parents:
12914
diff
changeset
|
4852 |
s:= ansistring(inttostr(Gear^.FlightTime)); |
13642
3d14950641a4
Refactor text color variable names, export 2 color values to Lua
Wuzzy <Wuzzy2@mail.ru>
parents:
13640
diff
changeset
|
4853 |
AddCaption(formatA(trmsg[sidRemaining], s), capcolDefault, capgrpAmmostate); |
3115 | 4854 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4855 |
|
6131 | 4856 |
if HHGear^.Message and (gmUp or gmPrecise or gmLeft or gmRight) <> 0 then |
6450 | 4857 |
Gear^.State := Gear^.State and (not gsttmpFlag); |
8795 | 4858 |
|
6450 | 4859 |
HHGear^.Message := HHGear^.Message and (not (gmUp or gmPrecise or gmLeft or gmRight)); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4860 |
HHGear^.State := HHGear^.State or gstMoving; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4861 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4862 |
Gear^.X := HHGear^.X; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4863 |
Gear^.Y := HHGear^.Y - int2hwFloat(32); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4864 |
// For some reason I need to reapply followgear here, something else grabs it otherwise. |
6325
cdd3d8c723ec
Update changelog, comment on possibly redundant lines in GSHandlers
nemo
parents:
6314
diff
changeset
|
4865 |
// this is probably not needed anymore |
cdd3d8c723ec
Update changelog, comment on possibly redundant lines in GSHandlers
nemo
parents:
6314
diff
changeset
|
4866 |
if not CurrentTeam^.ExtDriven then FollowGear := HHGear; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4867 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4868 |
if ((Gear^.State and gsttmpFlag) = 0) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4869 |
or (HHGear^.dY < _0) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4870 |
doStepHedgehogMoving(HHGear); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4871 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4872 |
if (Gear^.Health = 0) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4873 |
or (HHGear^.Damage <> 0) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4874 |
or CheckGearDrowning(HHGear) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4875 |
or (TurnTimeLeft = 0) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4876 |
// allow brief ground touches - to be fair on this, might need another counter |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4877 |
or (((GameTicks and $1FF) = 0) and (not HHGear^.dY.isNegative) and (TestCollisionYwithGear(HHGear, 1) <> 0)) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4878 |
or ((Gear^.Message and gmAttack) <> 0) then |
4272
cf18de7ea3d4
engine side of a more wind patch. no frontend hook. just want to check it in to pull it from another machine
nemo
parents:
4265
diff
changeset
|
4879 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4880 |
with HHGear^ do |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4881 |
begin |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4882 |
Message := 0; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4883 |
Active := true; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4884 |
State := State or gstMoving |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4885 |
end; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4886 |
Gear^.State := Gear^.State or gstAnimation or gstTmpFlag; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4887 |
if HHGear^.dY < _0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4888 |
begin |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4889 |
Gear^.dX := HHGear^.dX; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4890 |
Gear^.dY := HHGear^.dY; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4891 |
end; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4892 |
Gear^.Timer := 0; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4893 |
Gear^.doStep := @doStepBirdyDisappear; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4894 |
CurAmmoGear := nil; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4895 |
isCursorVisible := false; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4896 |
AfterAttack; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4897 |
end |
2983 | 4898 |
end; |
4899 |
||
4900 |
procedure doStepBirdyDescend(Gear: PGear); |
|
8795 | 4901 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4902 |
HHGear: PGear; |
2983 | 4903 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4904 |
if Gear^.Timer > 0 then |
9698 | 4905 |
dec(Gear^.Timer, 1); |
4906 |
||
4907 |
HHGear := Gear^.Hedgehog^.Gear; |
|
12644
59b46e6f36ff
Fix Birdy descending into water if hog took damage before it got picked up (bug 160)
Wuzzy <almikes@aol.com>
parents:
12641
diff
changeset
|
4908 |
if (HHGear = nil) or ((HHGear^.State and gstHHDriven) = 0) then |
59b46e6f36ff
Fix Birdy descending into water if hog took damage before it got picked up (bug 160)
Wuzzy <almikes@aol.com>
parents:
12641
diff
changeset
|
4909 |
begin |
59b46e6f36ff
Fix Birdy descending into water if hog took damage before it got picked up (bug 160)
Wuzzy <almikes@aol.com>
parents:
12641
diff
changeset
|
4910 |
Gear^.Hedgehog := nil; |
9698 | 4911 |
Gear^.Timer := 0; |
4912 |
Gear^.State := Gear^.State or gstAnimation or gstTmpFlag; |
|
4913 |
Gear^.doStep := @doStepBirdyDisappear; |
|
4914 |
CurAmmoGear := nil; |
|
4915 |
isCursorVisible := false; |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4916 |
AfterAttack; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4917 |
exit |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4918 |
end; |
9698 | 4919 |
|
6450 | 4920 |
HHGear^.Message := HHGear^.Message and (not (gmUp or gmPrecise or gmLeft or gmRight)); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4921 |
if abs(hwRound(HHGear^.Y - Gear^.Y)) > 32 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4922 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4923 |
if Gear^.Timer = 0 then |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4924 |
Gear^.Y := Gear^.Y + _0_1 |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4925 |
end |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4926 |
else if Gear^.Timer = 0 then |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4927 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4928 |
Gear^.doStep := @doStepBirdyFly; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4929 |
HHGear^.dY := -_0_2 |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4930 |
end |
2983 | 4931 |
end; |
4932 |
||
3149 | 4933 |
procedure doStepBirdyAppear(Gear: PGear); |
4934 |
begin |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4935 |
Gear^.Pos := 0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4936 |
if Gear^.Timer < 2000 then |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4937 |
inc(Gear^.Timer, 1) |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4938 |
else |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4939 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4940 |
Gear^.Timer := 500; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4941 |
Gear^.dX := _0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4942 |
Gear^.dY := _0; |
6450 | 4943 |
Gear^.State := Gear^.State and (not gstAnimation); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4944 |
Gear^.doStep := @doStepBirdyDescend; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4945 |
end |
3149 | 4946 |
end; |
4947 |
||
2983 | 4948 |
procedure doStepBirdy(Gear: PGear); |
8795 | 4949 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4950 |
HHGear: PGear; |
2983 | 4951 |
begin |
6450 | 4952 |
gear^.State := gear^.State or gstAnimation and (not gstTmpFlag); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4953 |
Gear^.doStep := @doStepBirdyAppear; |
8795 | 4954 |
|
15873
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
4955 |
if CurrentHedgehog^.Gear = nil then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4956 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4957 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4958 |
exit |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4959 |
end; |
2995 | 4960 |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4961 |
HHGear := CurrentHedgehog^.Gear; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4962 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4963 |
if HHGear^.dX.isNegative then |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4964 |
Gear^.Tag := -1 |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4965 |
else |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4966 |
Gear^.Tag := 1; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4967 |
Gear^.Pos := 0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4968 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4969 |
FollowGear := HHGear; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4970 |
with HHGear^ do |
5706 | 4971 |
begin |
6450 | 4972 |
State := State and (not gstAttacking); |
4973 |
Message := Message and (not (gmAttack or gmUp or gmPrecise or gmLeft or gmRight)) |
|
5706 | 4974 |
end |
2983 | 4975 |
end; |
3032 | 4976 |
|
4977 |
//////////////////////////////////////////////////////////////////////////////// |
|
3065 | 4978 |
procedure doStepEggWork(Gear: PGear); |
8795 | 4979 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4980 |
vg: PVisualGear; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4981 |
i: LongInt; |
3065 | 4982 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4983 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4984 |
Gear^.dX := Gear^.dX; |
3115 | 4985 |
doStepFallingGear(Gear); |
4986 |
CalcRotationDirAngle(Gear); |
|
4987 |
||
4988 |
if (Gear^.State and gstCollision) <> 0 then |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4989 |
begin |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
4990 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLPoisoned, $C0E0FFE0); |
3115 | 4991 |
PlaySound(sndEggBreak); |
4992 |
AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtEgg); |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4993 |
vg := AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtEgg); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4994 |
if vg <> nil then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4995 |
vg^.Frame := 2; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4996 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4997 |
for i:= 10 downto 0 do |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
4998 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
4999 |
vg := AddVisualGear(hwRound(Gear^.X) - 3 + Random(6), hwRound(Gear^.Y) - 3 + Random(6), |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5000 |
vgtDust); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5001 |
if vg <> nil then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5002 |
vg^.dX := vg^.dX + (Gear^.dX.QWordValue / 21474836480); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5003 |
end; |
3115 | 5004 |
|
5005 |
DeleteGear(Gear); |
|
5006 |
exit |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5007 |
end; |
3065 | 5008 |
end; |
3342
b4f01613dcd7
Some initial stubs for portal just so Tiy will quit nagging. Also let folks know what approximation of physics I plan to try, here.
nemo
parents:
3320
diff
changeset
|
5009 |
|
3401
d5d31d16eccc
add a part of my landslide vector collision and use if for the portal gun DirAngle, not flawless yet
sheepluva
parents:
3399
diff
changeset
|
5010 |
//////////////////////////////////////////////////////////////////////////////// |
3428 | 5011 |
procedure doPortalColorSwitch(); |
4790 | 5012 |
var CurWeapon: PAmmo; |
3428 | 5013 |
begin |
15873
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5014 |
if (CurrentHedgehog^.Gear <> nil) and ((CurrentHedgehog^.Gear^.State and gstHHDriven) <> 0) and ((CurrentHedgehog^.Gear^.Message and gmSwitch) <> 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5015 |
with CurrentHedgehog^ do |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5016 |
if (CurAmmoType = amPortalGun) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5017 |
begin |
11911
6145efcff302
Add sounds for blowtorch, invuln., f. saucer, lasersight, portal gun
Wuzzy <almikes@aol.com>
parents:
11860
diff
changeset
|
5018 |
PlaySound(sndPortalSwitch); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5019 |
CurrentHedgehog^.Gear^.Message := CurrentHedgehog^.Gear^.Message and (not gmSwitch); |
8795 | 5020 |
|
6924 | 5021 |
CurWeapon:= GetCurAmmoEntry(CurrentHedgehog^); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5022 |
if CurWeapon^.Pos <> 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5023 |
CurWeapon^.Pos := 0 |
8795 | 5024 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5025 |
else |
4790 | 5026 |
CurWeapon^.Pos := 1; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5027 |
end; |
3428 | 5028 |
end; |
5029 |
||
3342
b4f01613dcd7
Some initial stubs for portal just so Tiy will quit nagging. Also let folks know what approximation of physics I plan to try, here.
nemo
parents:
3320
diff
changeset
|
5030 |
procedure doStepPortal(Gear: PGear); |
8795 | 5031 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5032 |
iterator, conPortal: PGear; |
5594 | 5033 |
s, r, nx, ny, ox, oy, poffs, noffs, pspeed, nspeed, |
5034 |
resetx, resety, resetdx, resetdy: hwFloat; |
|
5035 |
sx, sy, rh, resetr: LongInt; |
|
5036 |
hasdxy, isbullet, iscake, isCollision: Boolean; |
|
3342
b4f01613dcd7
Some initial stubs for portal just so Tiy will quit nagging. Also let folks know what approximation of physics I plan to try, here.
nemo
parents:
3320
diff
changeset
|
5037 |
begin |
3428 | 5038 |
doPortalColorSwitch(); |
5039 |
||
3422
41ae3c48faa0
* some changes/cleanups to portal, still much to do :/ * reverted nemo's temporary loop fix * notice: small loops possible again, so take care :P, bigger onces should be interrupted
sheepluva
parents:
3419
diff
changeset
|
5040 |
// destroy portal if ground it was attached too is gone |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
5041 |
if (LandGet(hwRound(Gear^.Y), hwRound(Gear^.X)) <= lfAllObjMask) |
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
5042 |
or (LandGet(hwRound(Gear^.Y), hwRound(Gear^.X)) and lfBouncy <> 0) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5043 |
or (Gear^.Timer < 1) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5044 |
or (Gear^.Hedgehog^.Team <> CurrentHedgehog^.Team) |
10354 | 5045 |
or CheckCoordInWater(hwRound(Gear^.X), hwRound(Gear^.Y)) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5046 |
begin |
3428 | 5047 |
deleteGear(Gear); |
5048 |
EXIT; |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5049 |
end; |
3428 | 5050 |
|
5051 |
if (TurnTimeLeft < 1) |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5052 |
or (Gear^.Health < 1) then |
3428 | 5053 |
dec(Gear^.Timer); |
5054 |
||
5055 |
if Gear^.Timer < 10000 then |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5056 |
gear^.RenderTimer := true; |
3422
41ae3c48faa0
* some changes/cleanups to portal, still much to do :/ * reverted nemo's temporary loop fix * notice: small loops possible again, so take care :P, bigger onces should be interrupted
sheepluva
parents:
3419
diff
changeset
|
5057 |
|
41ae3c48faa0
* some changes/cleanups to portal, still much to do :/ * reverted nemo's temporary loop fix * notice: small loops possible again, so take care :P, bigger onces should be interrupted
sheepluva
parents:
3419
diff
changeset
|
5058 |
// abort if there is no other portal connected to this one |
7272
71df899c4163
Second part of the change. Make collision check use the new mask bit.
nemo
parents:
7270
diff
changeset
|
5059 |
if (Gear^.LinkedGear = nil) then |
3428 | 5060 |
exit; |
7272
71df899c4163
Second part of the change. Make collision check use the new mask bit.
nemo
parents:
7270
diff
changeset
|
5061 |
if ((Gear^.LinkedGear^.Tag and 1) = 0) then // or if it's still moving; |
3422
41ae3c48faa0
* some changes/cleanups to portal, still much to do :/ * reverted nemo's temporary loop fix * notice: small loops possible again, so take care :P, bigger onces should be interrupted
sheepluva
parents:
3419
diff
changeset
|
5062 |
exit; |
41ae3c48faa0
* some changes/cleanups to portal, still much to do :/ * reverted nemo's temporary loop fix * notice: small loops possible again, so take care :P, bigger onces should be interrupted
sheepluva
parents:
3419
diff
changeset
|
5063 |
|
7272
71df899c4163
Second part of the change. Make collision check use the new mask bit.
nemo
parents:
7270
diff
changeset
|
5064 |
conPortal := Gear^.LinkedGear; |
3422
41ae3c48faa0
* some changes/cleanups to portal, still much to do :/ * reverted nemo's temporary loop fix * notice: small loops possible again, so take care :P, bigger onces should be interrupted
sheepluva
parents:
3419
diff
changeset
|
5065 |
|
41ae3c48faa0
* some changes/cleanups to portal, still much to do :/ * reverted nemo's temporary loop fix * notice: small loops possible again, so take care :P, bigger onces should be interrupted
sheepluva
parents:
3419
diff
changeset
|
5066 |
// check all gears for stuff to port through |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5067 |
iterator := nil; |
3422
41ae3c48faa0
* some changes/cleanups to portal, still much to do :/ * reverted nemo's temporary loop fix * notice: small loops possible again, so take care :P, bigger onces should be interrupted
sheepluva
parents:
3419
diff
changeset
|
5068 |
while true do |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5069 |
begin |
3422
41ae3c48faa0
* some changes/cleanups to portal, still much to do :/ * reverted nemo's temporary loop fix * notice: small loops possible again, so take care :P, bigger onces should be interrupted
sheepluva
parents:
3419
diff
changeset
|
5070 |
|
3571 | 5071 |
// iterate through GearsList |
3422
41ae3c48faa0
* some changes/cleanups to portal, still much to do :/ * reverted nemo's temporary loop fix * notice: small loops possible again, so take care :P, bigger onces should be interrupted
sheepluva
parents:
3419
diff
changeset
|
5072 |
if iterator = nil then |
3571 | 5073 |
iterator := GearsList |
3422
41ae3c48faa0
* some changes/cleanups to portal, still much to do :/ * reverted nemo's temporary loop fix * notice: small loops possible again, so take care :P, bigger onces should be interrupted
sheepluva
parents:
3419
diff
changeset
|
5074 |
else |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5075 |
iterator := iterator^.NextGear; |
3571 | 5076 |
|
5077 |
// end of list? |
|
3422
41ae3c48faa0
* some changes/cleanups to portal, still much to do :/ * reverted nemo's temporary loop fix * notice: small loops possible again, so take care :P, bigger onces should be interrupted
sheepluva
parents:
3419
diff
changeset
|
5078 |
if iterator = nil then |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5079 |
break; |
3422
41ae3c48faa0
* some changes/cleanups to portal, still much to do :/ * reverted nemo's temporary loop fix * notice: small loops possible again, so take care :P, bigger onces should be interrupted
sheepluva
parents:
3419
diff
changeset
|
5080 |
|
41ae3c48faa0
* some changes/cleanups to portal, still much to do :/ * reverted nemo's temporary loop fix * notice: small loops possible again, so take care :P, bigger onces should be interrupted
sheepluva
parents:
3419
diff
changeset
|
5081 |
// don't port portals or other gear that wouldn't make sense |
8634
5dcb1dc9e01b
fix portal/hammer interaction, ban freezer from portal
nemo
parents:
8632
diff
changeset
|
5082 |
if (iterator^.Kind in [gtPortal, gtRope, gtAirAttack, gtIceGun]) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5083 |
or (iterator^.PortalCounter > 32) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5084 |
continue; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5085 |
|
3428 | 5086 |
// don't port hogs on rope |
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5087 |
// TODO: this will also prevent hogs while falling after rope use from |
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5088 |
// falling through portals... fix that! |
3422
41ae3c48faa0
* some changes/cleanups to portal, still much to do :/ * reverted nemo's temporary loop fix * notice: small loops possible again, so take care :P, bigger onces should be interrupted
sheepluva
parents:
3419
diff
changeset
|
5089 |
|
3571 | 5090 |
// check if gear fits through portal |
3422
41ae3c48faa0
* some changes/cleanups to portal, still much to do :/ * reverted nemo's temporary loop fix * notice: small loops possible again, so take care :P, bigger onces should be interrupted
sheepluva
parents:
3419
diff
changeset
|
5091 |
if (iterator^.Radius > Gear^.Radius) then |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5092 |
continue; |
3571 | 5093 |
|
5094 |
// this is the max range we accept incoming gears in |
|
4050
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5095 |
r := Int2hwFloat(iterator^.Radius+Gear^.Radius); |
3422
41ae3c48faa0
* some changes/cleanups to portal, still much to do :/ * reverted nemo's temporary loop fix * notice: small loops possible again, so take care :P, bigger onces should be interrupted
sheepluva
parents:
3419
diff
changeset
|
5096 |
|
3571 | 5097 |
// too far away? |
4050
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5098 |
if (iterator^.X < Gear^.X - r) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5099 |
or (iterator^.X > Gear^.X + r) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5100 |
or (iterator^.Y < Gear^.Y - r) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5101 |
or (iterator^.Y > Gear^.Y + r) then |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5102 |
continue; |
5044 | 5103 |
|
10490 | 5104 |
hasdxy := (((iterator^.dX.QWordValue <> 0) or (iterator^.dY.QWordValue <> 0)) or ((iterator^.State and gstMoving) = 0)); |
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5105 |
|
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5106 |
// in case the object is not moving, let's asume it's falling towards the portal |
4038
8972dd38bbad
potential fix for Issue #86: 'Objects behind a portal will sometimes go through the portal.' please test
sheepluva
parents:
4036
diff
changeset
|
5107 |
if not hasdxy then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5108 |
begin |
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5109 |
if Gear^.Y < iterator^.Y then |
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5110 |
continue; |
4038
8972dd38bbad
potential fix for Issue #86: 'Objects behind a portal will sometimes go through the portal.' please test
sheepluva
parents:
4036
diff
changeset
|
5111 |
ox:= Gear^.X - iterator^.X; |
8972dd38bbad
potential fix for Issue #86: 'Objects behind a portal will sometimes go through the portal.' please test
sheepluva
parents:
4036
diff
changeset
|
5112 |
oy:= Gear^.Y - iterator^.Y; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5113 |
end |
4038
8972dd38bbad
potential fix for Issue #86: 'Objects behind a portal will sometimes go through the portal.' please test
sheepluva
parents:
4036
diff
changeset
|
5114 |
else |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5115 |
begin |
4038
8972dd38bbad
potential fix for Issue #86: 'Objects behind a portal will sometimes go through the portal.' please test
sheepluva
parents:
4036
diff
changeset
|
5116 |
ox:= iterator^.dX; |
8972dd38bbad
potential fix for Issue #86: 'Objects behind a portal will sometimes go through the portal.' please test
sheepluva
parents:
4036
diff
changeset
|
5117 |
oy:= iterator^.dY; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5118 |
end; |
4038
8972dd38bbad
potential fix for Issue #86: 'Objects behind a portal will sometimes go through the portal.' please test
sheepluva
parents:
4036
diff
changeset
|
5119 |
|
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5120 |
// cake will need extra treatment... it's so delicious and moist! |
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5121 |
iscake:= (iterator^.Kind = gtCake); |
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5122 |
|
4050
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5123 |
// won't port stuff that does not move towards the front/portal entrance |
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5124 |
if iscake then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5125 |
begin |
6452 | 5126 |
if not (((iterator^.X - Gear^.X)*ox + (iterator^.Y - Gear^.Y)*oy).isNegative) then |
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5127 |
continue; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5128 |
end |
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5129 |
else |
6453
11c578d30bd3
Countless imporvements to the parser and countless help to the parser in sources.
unc0rr
parents:
6452
diff
changeset
|
5130 |
if not ((Gear^.dX*ox + Gear^.dY*oy).isNegative) then |
3571 | 5131 |
continue; |
5132 |
||
12898 | 5133 |
isbullet:= (iterator^.Kind in [gtShotgunShot, gtDEagleShot, gtSniperRifleShot, gtSineGunShot, gtMinigunBullet]); |
4050
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5134 |
|
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5135 |
r:= int2hwFloat(iterator^.Radius); |
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5136 |
|
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5137 |
if not (isbullet or iscake) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5138 |
begin |
3571 | 5139 |
// wow! good candidate there, let's see if the distance and direction is okay! |
5140 |
if hasdxy then |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5141 |
begin |
8900
b77fd3c2eec5
whoops, unbreak build. how come that cmake doesn't stop anymore on engine build error?
sheepluva
parents:
8898
diff
changeset
|
5142 |
s := Distance(iterator^.dX, iterator^.dY); |
8898 | 5143 |
// if the resulting distance is 0 skip this gear |
5144 |
if s.QWordValue = 0 then |
|
5145 |
continue; |
|
8900
b77fd3c2eec5
whoops, unbreak build. how come that cmake doesn't stop anymore on engine build error?
sheepluva
parents:
8898
diff
changeset
|
5146 |
s := r / s; |
3571 | 5147 |
ox:= iterator^.X + s * iterator^.dX; |
5148 |
oy:= iterator^.Y + s * iterator^.dY; |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5149 |
end |
3571 | 5150 |
else |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5151 |
begin |
3571 | 5152 |
ox:= iterator^.X; |
4050
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5153 |
oy:= iterator^.Y + r; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5154 |
end; |
3571 | 5155 |
|
3578 | 5156 |
if (hwRound(Distance(Gear^.X-ox,Gear^.Y-oy)) > Gear^.Radius + 1 ) then |
3571 | 5157 |
continue; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5158 |
end; |
3571 | 5159 |
|
12898 | 5160 |
if (iterator^.Kind in [gtDEagleShot, gtSniperRifleShot, gtMinigunBullet]) then |
11550
881231c1ba46
disallow bullets to hit the hedgehog that fired them (unless bounced/wrapped/portal'd)
sheepluva
parents:
11540
diff
changeset
|
5161 |
begin |
881231c1ba46
disallow bullets to hit the hedgehog that fired them (unless bounced/wrapped/portal'd)
sheepluva
parents:
11540
diff
changeset
|
5162 |
// draw bullet trail |
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
5163 |
spawnBulletTrail(iterator, iterator^.X, iterator^.Y, iterator^.FlightTime = 0); |
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
5164 |
iterator^.FlightTime := 1; |
11550
881231c1ba46
disallow bullets to hit the hedgehog that fired them (unless bounced/wrapped/portal'd)
sheepluva
parents:
11540
diff
changeset
|
5165 |
// the bullet can now hurt the hog that fired it |
881231c1ba46
disallow bullets to hit the hedgehog that fired them (unless bounced/wrapped/portal'd)
sheepluva
parents:
11540
diff
changeset
|
5166 |
iterator^.Data:= nil; |
881231c1ba46
disallow bullets to hit the hedgehog that fired them (unless bounced/wrapped/portal'd)
sheepluva
parents:
11540
diff
changeset
|
5167 |
end; |
5841 | 5168 |
|
4050
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5169 |
// calc gear offset in portal vector direction |
3571 | 5170 |
ox := (iterator^.X - Gear^.X); |
5171 |
oy := (iterator^.Y - Gear^.Y); |
|
5172 |
poffs:= (Gear^.dX * ox + Gear^.dY * oy); |
|
4050
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5173 |
|
5841 | 5174 |
if not isBullet and poffs.isNegative then |
5175 |
continue; |
|
5176 |
||
5177 |
// only port bullets close to the portal |
|
6450 | 5178 |
if isBullet and (not (hwAbs(poffs) < _3)) then |
4050
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5179 |
continue; |
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5180 |
|
4076 | 5181 |
// |
5182 |
// gears that make it till here will definately be ported |
|
5183 |
// |
|
5594 | 5184 |
// (but old position/movement vector might be restored in case there's |
5185 |
// not enough space on the other side) |
|
5186 |
// |
|
5187 |
||
5188 |
resetr := iterator^.Radius; |
|
5189 |
resetx := iterator^.X; |
|
5190 |
resety := iterator^.Y; |
|
5191 |
resetdx := iterator^.dX; |
|
5192 |
resetdy := iterator^.dY; |
|
4050
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5193 |
|
3578 | 5194 |
// create a normal of the portal vector, but ... |
5195 |
nx := Gear^.dY; |
|
3570 | 5196 |
ny := Gear^.dX; |
3578 | 5197 |
// ... decide where the top is based on the hog's direction when firing the portal |
5198 |
if Gear^.Elasticity.isNegative then |
|
6453
11c578d30bd3
Countless imporvements to the parser and countless help to the parser in sources.
unc0rr
parents:
6452
diff
changeset
|
5199 |
nx.isNegative := (not nx.isNegative) |
3578 | 5200 |
else |
3570 | 5201 |
ny.isNegative := not ny.isNegative; |
3578 | 5202 |
|
4050
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5203 |
// calc gear offset in portal normal vector direction |
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5204 |
noffs:= (nx * ox + ny * oy); |
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5205 |
|
7721 | 5206 |
if isBullet and (noffs.Round >= Longword(Gear^.Radius)) then |
5841 | 5207 |
continue; |
5208 |
||
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5209 |
// avoid gravity related loops of not really moving gear |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5210 |
if not (iscake or isbullet) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5211 |
and (Gear^.dY.isNegative) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5212 |
and (conPortal^.dY.isNegative) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5213 |
and ((iterator^.dX.QWordValue + iterator^.dY.QWordValue) < _0_08.QWordValue) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5214 |
and (iterator^.PortalCounter > 0) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5215 |
continue; |
4050
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5216 |
|
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5217 |
// calc gear speed along to the vector and the normal vector of the portal |
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5218 |
if hasdxy then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5219 |
begin |
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5220 |
pspeed:= (Gear^.dX * iterator^.dX + Gear^.dY * iterator^.dY); |
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5221 |
nspeed:= (nx * iterator^.dX + ny * iterator^.dY); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5222 |
end |
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5223 |
else |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5224 |
begin |
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5225 |
pspeed:= hwAbs(cGravity * oy); |
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5226 |
nspeed:= _0; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5227 |
end; |
4050
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5228 |
|
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5229 |
// creating normal vector of connected (exit) portal |
3578 | 5230 |
nx := conPortal^.dY; |
3570 | 5231 |
ny := conPortal^.dX; |
3578 | 5232 |
if conPortal^.Elasticity.isNegative then |
6453
11c578d30bd3
Countless imporvements to the parser and countless help to the parser in sources.
unc0rr
parents:
6452
diff
changeset
|
5233 |
nx.isNegative := (not nx.isNegative) |
3578 | 5234 |
else |
3570 | 5235 |
ny.isNegative := not ny.isNegative; |
3578 | 5236 |
|
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5237 |
// inverse cake's normal movement direction, |
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5238 |
// as if it just walked through a hole |
5750
6bbf7aee2cdf
Reenable a bunch of old portal play stuff, like dropping grenade into portal on hog, jumping through portal w/ hog on other end, collecting crate w/ portal etc. Also add cooldown to cake/portal interaction. It may still not do what you expect, but it probably shouldn't spin in place.
nemo
parents:
5748
diff
changeset
|
5239 |
//if iscake then nspeed.isNegative:= not nspeed.isNegative; |
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5240 |
|
3571 | 5241 |
//AddFileLog('poffs:'+cstr(poffs)+' noffs:'+cstr(noffs)+' pspeed:'+cstr(pspeed)+' nspeed:'+cstr(nspeed)); |
3578 | 5242 |
iterator^.dX := -pspeed * conPortal^.dX + nspeed * nx; |
5243 |
iterator^.dY := -pspeed * conPortal^.dY + nspeed * ny; |
|
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5244 |
|
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5245 |
// make the gear's exit position close to the portal while |
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5246 |
// still respecting the movement direction |
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5247 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5248 |
// determine the distance (in exit vector direction) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5249 |
// that we want the gear at |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5250 |
if iscake then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5251 |
ox:= (r - _0_7) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5252 |
else |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5253 |
ox:= (r * _1_5); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5254 |
s:= ox / poffs; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5255 |
poffs:= ox; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5256 |
if (nspeed.QWordValue <> 0) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5257 |
and (pspeed > _0) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5258 |
noffs:= noffs * s * (nspeed / pspeed); |
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5259 |
|
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5260 |
// move stuff with high normal offset closer to the portal's center |
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5261 |
if not isbullet then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5262 |
begin |
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5263 |
s := hwAbs(noffs) + r - int2hwFloat(Gear^.Radius); |
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5264 |
if s > _0 then |
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5265 |
noffs:= noffs - SignAs(s,noffs) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5266 |
end; |
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5267 |
|
3571 | 5268 |
iterator^.X := conPortal^.X + poffs * conPortal^.dX + noffs * nx; |
5269 |
iterator^.Y := conPortal^.Y + poffs * conPortal^.dY + noffs * ny; |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5270 |
|
6450 | 5271 |
if not hasdxy and (not (conPortal^.dY.isNegative)) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5272 |
begin |
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5273 |
iterator^.dY:= iterator^.dY + hwAbs(cGravity * (iterator^.Y - conPortal^.Y)) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5274 |
end; |
4092
bf13068194b3
more portal tweaks (closer exit position, cake stuff, etc)
sheepluva
parents:
4076
diff
changeset
|
5275 |
|
5594 | 5276 |
// see if the space on the exit side actually is enough |
5277 |
||
5278 |
if not (isBullet or isCake) then |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5279 |
begin |
5594 | 5280 |
// TestCollisionXwithXYShift requires a hwFloat for xShift |
5281 |
ox.QWordValue := _1.QWordValue; |
|
5282 |
ox.isNegative := not iterator^.dX.isNegative; |
|
5283 |
||
5284 |
sx := hwSign(iterator^.dX); |
|
5285 |
sy := hwSign(iterator^.dY); |
|
5286 |
||
5287 |
if iterator^.Radius > 1 then |
|
5288 |
iterator^.Radius := iterator^.Radius - 1; |
|
5289 |
||
5290 |
// check front |
|
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9698
diff
changeset
|
5291 |
isCollision := (TestCollisionY(iterator, sy) <> 0) or (TestCollisionX(iterator, sx) <> 0); |
5594 | 5292 |
|
5293 |
if not isCollision then |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5294 |
begin |
5594 | 5295 |
// check center area (with half the radius so that the |
5296 |
// the square check won't check more pixels than we want to) |
|
5297 |
iterator^.Radius := 1 + resetr div 2; |
|
5298 |
rh := resetr div 4; |
|
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9698
diff
changeset
|
5299 |
isCollision := (TestCollisionYwithXYShift(iterator, 0, -sy * rh, sy, false) <> 0) |
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9698
diff
changeset
|
5300 |
or (TestCollisionXwithXYShift(iterator, ox * rh, 0, sx, false) <> 0); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5301 |
end; |
5594 | 5302 |
|
5303 |
iterator^.Radius := resetr; |
|
5304 |
||
5305 |
if isCollision then |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5306 |
begin |
5594 | 5307 |
// collision! oh crap! go back! |
5308 |
iterator^.X := resetx; |
|
5309 |
iterator^.Y := resety; |
|
5310 |
iterator^.dX := resetdx; |
|
5311 |
iterator^.dY := resetdy; |
|
5312 |
continue; |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5313 |
end; |
5594 | 5314 |
end; |
5315 |
||
14222 | 5316 |
if iterator^.Kind = gtKamikaze then |
5317 |
RefillProximityCache(iterator, 300); |
|
5318 |
||
5594 | 5319 |
// |
5320 |
// You're now officially portaled! |
|
5321 |
// |
|
5322 |
||
5323 |
// Until loops are reliably broken |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5324 |
if iscake then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5325 |
iterator^.PortalCounter:= 33 |
5940 | 5326 |
else |
5327 |
begin |
|
5328 |
inc(iterator^.PortalCounter); |
|
7658 | 5329 |
iterator^.Active:= true; |
7992 | 5330 |
iterator^.State:= iterator^.State and (not gstHHHJump) or gstMoving; |
5940 | 5331 |
end; |
5594 | 5332 |
|
6785 | 5333 |
// is it worth adding an arcsin table? Just how often would we end up doing something like this? |
6787 | 5334 |
// SYNCED ANGLE UPDATE |
6785 | 5335 |
if iterator^.Kind = gtRCPlane then |
10112
275ad81e4718
fix indentation of previous commit and simplify rc-plane's angle-fix after portal code
sheepluva
parents:
10110
diff
changeset
|
5336 |
iterator^.Angle:= (1024 + vector2Angle(iterator^.dX, iterator^.dY) mod 4096) |
6787 | 5337 |
// VISUAL USE OF ANGLE ONLY |
5338 |
else if (CurAmmoGear <> nil) and (CurAmmoGear^.Kind = gtKamikaze) and (CurAmmoGear^.Hedgehog = iterator^.Hedgehog) then |
|
5339 |
begin |
|
5340 |
iterator^.Angle:= DxDy2AttackAngle(iterator^.dX, iterator^.dY); |
|
5341 |
iterator^.Angle:= 2048-iterator^.Angle; |
|
6786 | 5342 |
if iterator^.dX.isNegative then iterator^.Angle:= 4096-iterator^.Angle; |
6785 | 5343 |
end; |
5344 |
||
15873
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5345 |
if (CurrentHedgehog^.Gear <> nil) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5346 |
and (iterator = CurrentHedgehog^.Gear) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5347 |
and (CurAmmoGear <> nil) |
9539 | 5348 |
and (CurAmmoGear^.Kind = gtRope) |
5349 |
and (CurAmmoGear^.Elasticity <> _0) then |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5350 |
CurAmmoGear^.PortalCounter:= 1; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5351 |
|
8795 | 5352 |
if not isbullet and (iterator^.State and gstInvisible = 0) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5353 |
and (iterator^.Kind <> gtFlake) then |
4050
8e4f4b72c132
various portal tweaks, also: nemo's gear jiggling is back
sheepluva
parents:
4047
diff
changeset
|
5354 |
FollowGear := iterator; |
5594 | 5355 |
|
5841 | 5356 |
// store X/Y values of exit for net bullet trail |
5357 |
if isbullet then |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5358 |
begin |
5841 | 5359 |
iterator^.Elasticity:= iterator^.X; |
5360 |
iterator^.Friction := iterator^.Y; |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5361 |
end; |
5841 | 5362 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5363 |
if Gear^.Health > 1 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5364 |
dec(Gear^.Health); |
3571 | 5365 |
end; |
3342
b4f01613dcd7
Some initial stubs for portal just so Tiy will quit nagging. Also let folks know what approximation of physics I plan to try, here.
nemo
parents:
3320
diff
changeset
|
5366 |
end; |
3350 | 5367 |
|
6490 | 5368 |
|
3428 | 5369 |
|
5370 |
procedure loadNewPortalBall(oldPortal: PGear; destroyGear: Boolean); |
|
4790 | 5371 |
var |
3836
833c0f32e326
Change all use of curslot/idx to CurAmmoType to try and avoid some bugs with use of last weapon.
nemo
parents:
3821
diff
changeset
|
5372 |
CurWeapon: PAmmo; |
3388
ab9352a4ddcc
Fix portal graphic name, continuing work on portal movement
nemo
parents:
3384
diff
changeset
|
5373 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5374 |
if CurrentHedgehog <> nil then |
3836
833c0f32e326
Change all use of curslot/idx to CurAmmoType to try and avoid some bugs with use of last weapon.
nemo
parents:
3821
diff
changeset
|
5375 |
with CurrentHedgehog^ do |
3428 | 5376 |
begin |
6924 | 5377 |
CurWeapon:= GetCurAmmoEntry(CurrentHedgehog^); |
3836
833c0f32e326
Change all use of curslot/idx to CurAmmoType to try and avoid some bugs with use of last weapon.
nemo
parents:
3821
diff
changeset
|
5378 |
if (CurAmmoType = amPortalGun) then |
833c0f32e326
Change all use of curslot/idx to CurAmmoType to try and avoid some bugs with use of last weapon.
nemo
parents:
3821
diff
changeset
|
5379 |
begin |
4790 | 5380 |
if not destroyGear then |
5381 |
begin |
|
5382 |
// switch color of ball to opposite of oldPortal |
|
5383 |
if (oldPortal^.Tag and 2) = 0 then |
|
5384 |
CurWeapon^.Pos:= 1 |
|
5385 |
else |
|
5386 |
CurWeapon^.Pos:= 0; |
|
5387 |
end; |
|
5388 |
||
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5389 |
// make the ball visible |
4790 | 5390 |
CurWeapon^.Timer := 0; |
3836
833c0f32e326
Change all use of curslot/idx to CurAmmoType to try and avoid some bugs with use of last weapon.
nemo
parents:
3821
diff
changeset
|
5391 |
end |
3428 | 5392 |
end; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5393 |
if destroyGear then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5394 |
oldPortal^.Timer:= 0; |
3428 | 5395 |
end; |
5396 |
||
6490 | 5397 |
procedure doStepMovingPortal_real(Gear: PGear); |
8795 | 5398 |
var |
6490 | 5399 |
x, y, tx, ty: LongInt; |
5400 |
s: hwFloat; |
|
3428 | 5401 |
begin |
9477 | 5402 |
WorldWrap(Gear); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5403 |
x := hwRound(Gear^.X); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5404 |
y := hwRound(Gear^.Y); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5405 |
tx := 0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5406 |
ty := 0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5407 |
// avoid compiler hints |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5408 |
|
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
5409 |
if ((y and LAND_HEIGHT_MASK) = 0) and ((x and LAND_WIDTH_MASK) = 0) and (LandGet(y, x) > 255) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5410 |
begin |
3569 | 5411 |
Gear^.State := Gear^.State or gstCollision; |
6450 | 5412 |
Gear^.State := Gear^.State and (not gstMoving); |
8795 | 5413 |
|
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
5414 |
if (LandGet(y, x) and lfBouncy <> 0) |
7426
55b49cc1f33a
Changes for the benefit of pas2c. Use downto in for loops to avoid repeated calls of Random/GetRandom. Wrap nots.
nemo
parents:
7416
diff
changeset
|
5415 |
or (not CalcSlopeTangent(Gear, x, y, tx, ty, 255)) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5416 |
or (DistanceI(tx,ty) < _12) then // reject shots at too irregular terrain |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5417 |
begin |
3428 | 5418 |
loadNewPortalBall(Gear, true); |
5419 |
EXIT; |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5420 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5421 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5422 |
// making a normalized normal vector |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5423 |
s := _1/DistanceI(tx,ty); |
3562 | 5424 |
Gear^.dX := s * ty; |
5425 |
Gear^.dY := -s * tx; |
|
5426 |
||
5427 |
Gear^.DirAngle := DxDy2Angle(-Gear^.dY,Gear^.dX); |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5428 |
if not Gear^.dX.isNegative then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5429 |
Gear^.DirAngle := 180-Gear^.DirAngle; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5430 |
|
7272
71df899c4163
Second part of the change. Make collision check use the new mask bit.
nemo
parents:
7270
diff
changeset
|
5431 |
if ((Gear^.LinkedGear = nil) |
71df899c4163
Second part of the change. Make collision check use the new mask bit.
nemo
parents:
7270
diff
changeset
|
5432 |
or (hwRound(Distance(Gear^.X - Gear^.LinkedGear^.X,Gear^.Y-Gear^.LinkedGear^.Y)) >=Gear^.Radius*2)) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5433 |
begin |
11911
6145efcff302
Add sounds for blowtorch, invuln., f. saucer, lasersight, portal gun
Wuzzy <almikes@aol.com>
parents:
11860
diff
changeset
|
5434 |
PlaySound(sndPortalOpen); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5435 |
loadNewPortalBall(Gear, false); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5436 |
inc(Gear^.Tag); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5437 |
Gear^.doStep := @doStepPortal; |
3396
e5b3e5f2818e
More portal changes. Allows for a multishoot utility. Hopefully not breaking anything.
nemo
parents:
3391
diff
changeset
|
5438 |
end |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5439 |
else |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5440 |
loadNewPortalBall(Gear, true); |
3388
ab9352a4ddcc
Fix portal graphic name, continuing work on portal movement
nemo
parents:
3384
diff
changeset
|
5441 |
end |
8795 | 5442 |
|
10354 | 5443 |
else if CheckCoordInWater(x, y) |
7829
c1dc7839d7b9
Set minimums on a few values to avoid camera zooming out past them. partly Issue #430. Might be worth defining a new constant for this.
nemo
parents:
7784
diff
changeset
|
5444 |
or (y < -max(LAND_WIDTH,4096)) |
c1dc7839d7b9
Set minimums on a few values to avoid camera zooming out past them. partly Issue #430. Might be worth defining a new constant for this.
nemo
parents:
7784
diff
changeset
|
5445 |
or (x > 2*max(LAND_WIDTH,4096)) |
c1dc7839d7b9
Set minimums on a few values to avoid camera zooming out past them. partly Issue #430. Might be worth defining a new constant for this.
nemo
parents:
7784
diff
changeset
|
5446 |
or (x < -max(LAND_WIDTH,4096)) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5447 |
loadNewPortalBall(Gear, true); |
3428 | 5448 |
end; |
5449 |
||
3569 | 5450 |
procedure doStepMovingPortal(Gear: PGear); |
5451 |
begin |
|
5452 |
doPortalColorSwitch(); |
|
5453 |
doStepPerPixel(Gear, @doStepMovingPortal_real, true); |
|
8795 | 5454 |
if (Gear^.Timer < 1) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5455 |
or (Gear^.Hedgehog^.Team <> CurrentHedgehog^.Team) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5456 |
deleteGear(Gear); |
3569 | 5457 |
end; |
5458 |
||
3428 | 5459 |
procedure doStepPortalShot(newPortal: PGear); |
8795 | 5460 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5461 |
iterator: PGear; |
3560
3e51dad04026
portal: make shot 2 times faster, add hog movement speed to shot speed (only the part in shot direction, so that aiming is not messed up)
sheepluva
parents:
3552
diff
changeset
|
5462 |
s: hwFloat; |
3836
833c0f32e326
Change all use of curslot/idx to CurAmmoType to try and avoid some bugs with use of last weapon.
nemo
parents:
3821
diff
changeset
|
5463 |
CurWeapon: PAmmo; |
3428 | 5464 |
begin |
15873
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5465 |
if CurrentHedgehog^.Gear = nil then |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5466 |
begin |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5467 |
DeleteGear(newPortal); |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5468 |
exit |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5469 |
end; |
3560
3e51dad04026
portal: make shot 2 times faster, add hog movement speed to shot speed (only the part in shot direction, so that aiming is not messed up)
sheepluva
parents:
3552
diff
changeset
|
5470 |
s:= Distance (newPortal^.dX, newPortal^.dY); |
3e51dad04026
portal: make shot 2 times faster, add hog movement speed to shot speed (only the part in shot direction, so that aiming is not messed up)
sheepluva
parents:
3552
diff
changeset
|
5471 |
|
3e51dad04026
portal: make shot 2 times faster, add hog movement speed to shot speed (only the part in shot direction, so that aiming is not messed up)
sheepluva
parents:
3552
diff
changeset
|
5472 |
// Adds the hog speed (only that part in/directly against shot direction) |
3e51dad04026
portal: make shot 2 times faster, add hog movement speed to shot speed (only the part in shot direction, so that aiming is not messed up)
sheepluva
parents:
3552
diff
changeset
|
5473 |
// to the shot speed (which we triple previously btw) |
3e51dad04026
portal: make shot 2 times faster, add hog movement speed to shot speed (only the part in shot direction, so that aiming is not messed up)
sheepluva
parents:
3552
diff
changeset
|
5474 |
// (This is done my projecting the hog movement vector onto the shot movement vector and then adding the resulting length |
3e51dad04026
portal: make shot 2 times faster, add hog movement speed to shot speed (only the part in shot direction, so that aiming is not messed up)
sheepluva
parents:
3552
diff
changeset
|
5475 |
// to the scaler) |
3562 | 5476 |
s := (_2 * s + (newPortal^.dX * CurrentHedgehog^.Gear^.dX + newPortal^.dY * CurrentHedgehog^.Gear^.dY ) / s) / s; |
3560
3e51dad04026
portal: make shot 2 times faster, add hog movement speed to shot speed (only the part in shot direction, so that aiming is not messed up)
sheepluva
parents:
3552
diff
changeset
|
5477 |
newPortal^.dX := newPortal^.dX * s; |
3e51dad04026
portal: make shot 2 times faster, add hog movement speed to shot speed (only the part in shot direction, so that aiming is not messed up)
sheepluva
parents:
3552
diff
changeset
|
5478 |
newPortal^.dY := newPortal^.dY * s; |
3e51dad04026
portal: make shot 2 times faster, add hog movement speed to shot speed (only the part in shot direction, so that aiming is not messed up)
sheepluva
parents:
3552
diff
changeset
|
5479 |
|
7272
71df899c4163
Second part of the change. Make collision check use the new mask bit.
nemo
parents:
7270
diff
changeset
|
5480 |
newPortal^.LinkedGear := nil; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5481 |
|
11911
6145efcff302
Add sounds for blowtorch, invuln., f. saucer, lasersight, portal gun
Wuzzy <almikes@aol.com>
parents:
11860
diff
changeset
|
5482 |
PlaySound(sndPortalShot); |
6145efcff302
Add sounds for blowtorch, invuln., f. saucer, lasersight, portal gun
Wuzzy <almikes@aol.com>
parents:
11860
diff
changeset
|
5483 |
|
15873
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5484 |
with CurrentHedgehog^ do |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5485 |
begin |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5486 |
CurWeapon:= GetCurAmmoEntry(CurrentHedgehog^); |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5487 |
// let's save the HH's dX's direction so we can decide where the "top" of the portal hole |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5488 |
newPortal^.Elasticity.isNegative := CurrentHedgehog^.Gear^.dX.isNegative; |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5489 |
// when doing a backjump the dx is the opposite of the facing direction |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5490 |
if ((Gear^.State and gstHHHJump) <> 0) and (Effects[heArtillery] = 0) then |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5491 |
newPortal^.Elasticity.isNegative := not newPortal^.Elasticity.isNegative; |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5492 |
|
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5493 |
// make portal gun look unloaded |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5494 |
if (CurWeapon <> nil) and (CurAmmoType = amPortalGun) then |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5495 |
CurWeapon^.Timer := CurWeapon^.Timer or 2; |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5496 |
|
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5497 |
iterator := GearsList; |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5498 |
while iterator <> nil do |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5499 |
begin |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5500 |
if (iterator^.Kind = gtPortal) then |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5501 |
if (iterator <> newPortal) and (iterator^.Timer > 0) and (iterator^.Hedgehog = CurrentHedgehog) then |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5502 |
begin |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5503 |
if ((iterator^.Tag and 2) = (newPortal^.Tag and 2)) then |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5504 |
begin |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5505 |
iterator^.Timer:= 0; |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5506 |
end |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5507 |
else |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5508 |
begin |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5509 |
// link portals with each other |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5510 |
newPortal^.LinkedGear := iterator; |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5511 |
iterator^.LinkedGear := newPortal; |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5512 |
iterator^.Health := newPortal^.Health; |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5513 |
end; |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5514 |
end; |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5515 |
iterator^.PortalCounter:= 0; |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5516 |
iterator := iterator^.NextGear |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5517 |
end; |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5518 |
|
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5519 |
if newPortal^.LinkedGear <> nil then |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5520 |
begin |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5521 |
// This jiggles gears, to ensure a portal connection just placed under a gear takes effect. |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5522 |
iterator:= GearsList; |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5523 |
while iterator <> nil do |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5524 |
begin |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5525 |
if not (iterator^.Kind in [gtPortal, gtAirAttack, gtKnife, gtSMine]) and ((iterator^.Hedgehog <> CurrentHedgehog) |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5526 |
or ((iterator^.Message and gmAllStoppable) = 0)) then |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5527 |
begin |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5528 |
iterator^.Active:= true; |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5529 |
if iterator^.dY.QWordValue = 0 then |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5530 |
iterator^.dY.isNegative:= false; |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5531 |
iterator^.State:= iterator^.State or gstMoving; |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5532 |
DeleteCI(iterator); |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5533 |
//inc(iterator^.dY.QWordValue,10); |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5534 |
end; |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5535 |
iterator:= iterator^.NextGear |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5536 |
end |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5537 |
end |
9bb85e43e492
add more checks on nil current hedgehog gear, remove checks on nil current hedgehog which should never happen.
nemo
parents:
15869
diff
changeset
|
5538 |
end; |
6450 | 5539 |
newPortal^.State := newPortal^.State and (not gstCollision); |
3569 | 5540 |
newPortal^.State := newPortal^.State or gstMoving; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5541 |
newPortal^.doStep := @doStepMovingPortal; |
3388
ab9352a4ddcc
Fix portal graphic name, continuing work on portal movement
nemo
parents:
3384
diff
changeset
|
5542 |
end; |
ab9352a4ddcc
Fix portal graphic name, continuing work on portal movement
nemo
parents:
3384
diff
changeset
|
5543 |
|
14587
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5544 |
procedure doStepPiano(Gear: PGear); |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5545 |
var valid: boolean; |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5546 |
HHGear: PGear; |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5547 |
begin |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5548 |
AllInactive := false; |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5549 |
valid := true; |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5550 |
|
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5551 |
if (Gear^.Hedgehog <> nil) and (Gear^.Hedgehog^.Gear <> nil) then |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5552 |
HHGear := Gear^.Hedgehog^.Gear; |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5553 |
|
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5554 |
if (WorldEdge = weBounce) then |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5555 |
if (hwRound(Gear^.X) - Gear^.Radius < leftX) then |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5556 |
valid := false |
14753
52916435d9b1
Fix right limit of piano placement in bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14719
diff
changeset
|
5557 |
else if (hwRound(Gear^.X) + Gear^.Radius > rightX) then |
14587
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5558 |
valid := false; |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5559 |
|
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5560 |
if (not valid) then |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5561 |
begin |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5562 |
if (HHGear <> nil) then |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5563 |
begin |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5564 |
HHGear^.Message := HHGear^.Message and (not gmAttack); |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5565 |
HHGear^.State := HHGear^.State and (not gstAttacking); |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5566 |
HHGear^.State := HHGear^.State or gstChooseTarget; |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5567 |
isCursorVisible := true; |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5568 |
end; |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5569 |
DeleteGear(Gear); |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5570 |
PlaySound(sndDenied); |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5571 |
exit; |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5572 |
end; |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5573 |
|
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5574 |
isCursorVisible := false; |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5575 |
if (HHGear <> nil) then |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5576 |
begin |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5577 |
PlaySoundV(sndIncoming, Gear^.Hedgehog^.Team^.voicepack); |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5578 |
// Tuck the hedgehog away until the piano attack is completed |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5579 |
Gear^.Hedgehog^.Unplaced:= true; |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5580 |
HHGear^.X:= _0; |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5581 |
HHGear^.Y:= _0; |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5582 |
end; |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5583 |
|
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5584 |
PauseMusic; |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5585 |
Gear^.doStep:= @doStepPianoWork; |
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5586 |
end; |
5313
5e18eaef65d0
now scripts can create unique crates: dummy (empty) crates and booby traps. scripts can also set health crate values
Henek
parents:
5298
diff
changeset
|
5587 |
//////////////////////////////////////////////////////////////////////////////// |
14587
85921db6f7c3
Disallow placement of piano beyond bounce world edge
Wuzzy <Wuzzy2@mail.ru>
parents:
14586
diff
changeset
|
5588 |
procedure doStepPianoWork(Gear: PGear); |
8795 | 5589 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5590 |
r0, r1: LongInt; |
3728 | 5591 |
odY: hwFloat; |
3350 | 5592 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5593 |
AllInactive := false; |
13999
3ae88a9f9dca
If u play Piano, you can now hear the notes if sound effects OR music is enabled
Wuzzy <Wuzzy2@mail.ru>
parents:
13996
diff
changeset
|
5594 |
// Play piano notes with slot keys |
8795 | 5595 |
if (CurrentHedgehog <> nil) and (CurrentHedgehog^.Gear <> nil) and |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5596 |
((CurrentHedgehog^.Gear^.Message and gmSlot) <> 0) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5597 |
begin |
13999
3ae88a9f9dca
If u play Piano, you can now hear the notes if sound effects OR music is enabled
Wuzzy <Wuzzy2@mail.ru>
parents:
13996
diff
changeset
|
5598 |
// Piano notes are played if sound OR music (or both) is enabled |
8795 | 5599 |
case CurrentHedgehog^.Gear^.MsgParam of |
13999
3ae88a9f9dca
If u play Piano, you can now hear the notes if sound effects OR music is enabled
Wuzzy <Wuzzy2@mail.ru>
parents:
13996
diff
changeset
|
5600 |
0: PlaySound(sndPiano0, false, false, true); |
3ae88a9f9dca
If u play Piano, you can now hear the notes if sound effects OR music is enabled
Wuzzy <Wuzzy2@mail.ru>
parents:
13996
diff
changeset
|
5601 |
1: PlaySound(sndPiano1, false, false, true); |
3ae88a9f9dca
If u play Piano, you can now hear the notes if sound effects OR music is enabled
Wuzzy <Wuzzy2@mail.ru>
parents:
13996
diff
changeset
|
5602 |
2: PlaySound(sndPiano2, false, false, true); |
3ae88a9f9dca
If u play Piano, you can now hear the notes if sound effects OR music is enabled
Wuzzy <Wuzzy2@mail.ru>
parents:
13996
diff
changeset
|
5603 |
3: PlaySound(sndPiano3, false, false, true); |
3ae88a9f9dca
If u play Piano, you can now hear the notes if sound effects OR music is enabled
Wuzzy <Wuzzy2@mail.ru>
parents:
13996
diff
changeset
|
5604 |
4: PlaySound(sndPiano4, false, false, true); |
3ae88a9f9dca
If u play Piano, you can now hear the notes if sound effects OR music is enabled
Wuzzy <Wuzzy2@mail.ru>
parents:
13996
diff
changeset
|
5605 |
5: PlaySound(sndPiano5, false, false, true); |
3ae88a9f9dca
If u play Piano, you can now hear the notes if sound effects OR music is enabled
Wuzzy <Wuzzy2@mail.ru>
parents:
13996
diff
changeset
|
5606 |
6: PlaySound(sndPiano6, false, false, true); |
3ae88a9f9dca
If u play Piano, you can now hear the notes if sound effects OR music is enabled
Wuzzy <Wuzzy2@mail.ru>
parents:
13996
diff
changeset
|
5607 |
7: PlaySound(sndPiano7, false, false, true); |
3ae88a9f9dca
If u play Piano, you can now hear the notes if sound effects OR music is enabled
Wuzzy <Wuzzy2@mail.ru>
parents:
13996
diff
changeset
|
5608 |
8: PlaySound(sndPiano8, false, false, true); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5609 |
end; |
15753
26247a74d823
Fix piano spawning vgtNote if slot key without sound was pressed
Wuzzy <Wuzzy2@mail.ru>
parents:
15746
diff
changeset
|
5610 |
if CurrentHedgehog^.Gear^.MsgParam <= 8 then |
26247a74d823
Fix piano spawning vgtNote if slot key without sound was pressed
Wuzzy <Wuzzy2@mail.ru>
parents:
15746
diff
changeset
|
5611 |
AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtNote); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5612 |
CurrentHedgehog^.Gear^.MsgParam := 0; |
6450 | 5613 |
CurrentHedgehog^.Gear^.Message := CurrentHedgehog^.Gear^.Message and (not gmSlot); |
6304
3036c242b19d
Set CurrentAmmoGear on piano (should fix notes again). Also disable focus on current hog if unplaced.
nemo
parents:
6278
diff
changeset
|
5614 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5615 |
|
14593
34e810295d08
Remove a bunch of dead out-commented code
Wuzzy <Wuzzy2@mail.ru>
parents:
14591
diff
changeset
|
5616 |
if (Gear^.Pos = 5) then |
6305
5f7480c2a08d
Set default water colours in greyscale mode in case the theme does not define them, decrement piano weapon on use
nemo
parents:
6304
diff
changeset
|
5617 |
begin |
3728 | 5618 |
Gear^.dY := Gear^.dY + cGravity * 2; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5619 |
Gear^.Y := Gear^.Y + Gear^.dY; |
6803
0e70f3ea3bf8
bit of an experiment in variable splash sizes based on object/speed. not sure if it looks good yet. need to drown more stuff.
nemo
parents:
6792
diff
changeset
|
5620 |
if CheckGearDrowning(Gear) then |
6305
5f7480c2a08d
Set default water colours in greyscale mode in case the theme does not define them, decrement piano weapon on use
nemo
parents:
6304
diff
changeset
|
5621 |
begin |
6803
0e70f3ea3bf8
bit of an experiment in variable splash sizes based on object/speed. not sure if it looks good yet. need to drown more stuff.
nemo
parents:
6792
diff
changeset
|
5622 |
Gear^.Y:= Gear^.Y + _50; |
6305
5f7480c2a08d
Set default water colours in greyscale mode in case the theme does not define them, decrement piano weapon on use
nemo
parents:
6304
diff
changeset
|
5623 |
OnUsedAmmo(CurrentHedgehog^); |
12292
93434ab299a0
Take sacrifices into account for the “Stupid” taunt
Wuzzy <almikes@aol.com>
parents:
12277
diff
changeset
|
5624 |
uStats.HedgehogSacrificed(CurrentHedgehog); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5625 |
if CurrentHedgehog^.Gear <> nil then |
6305
5f7480c2a08d
Set default water colours in greyscale mode in case the theme does not define them, decrement piano weapon on use
nemo
parents:
6304
diff
changeset
|
5626 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5627 |
// Drown the hedgehog. Could also just delete it, but hey, this gets a caption |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5628 |
CurrentHedgehog^.Gear^.Active := true; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5629 |
CurrentHedgehog^.Gear^.X := Gear^.X; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5630 |
CurrentHedgehog^.Gear^.Y := int2hwFloat(cWaterLine+cVisibleWater)+_128; |
3954
ae3583ad6ea9
Hopefully fix the last of the more obvious weapon bugs w/ infinite attack mode, add a depixeling sweep every 5s too.
nemo
parents:
3953
diff
changeset
|
5631 |
CurrentHedgehog^.Unplaced := false; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5632 |
if TagTurnTimeLeft = 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5633 |
TagTurnTimeLeft:= TurnTimeLeft; |
3954
ae3583ad6ea9
Hopefully fix the last of the more obvious weapon bugs w/ infinite attack mode, add a depixeling sweep every 5s too.
nemo
parents:
3953
diff
changeset
|
5634 |
TurnTimeLeft:= 0 |
6305
5f7480c2a08d
Set default water colours in greyscale mode in case the theme does not define them, decrement piano weapon on use
nemo
parents:
6304
diff
changeset
|
5635 |
end; |
5f7480c2a08d
Set default water colours in greyscale mode in case the theme does not define them, decrement piano weapon on use
nemo
parents:
6304
diff
changeset
|
5636 |
ResumeMusic |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5637 |
end; |
6305
5f7480c2a08d
Set default water colours in greyscale mode in case the theme does not define them, decrement piano weapon on use
nemo
parents:
6304
diff
changeset
|
5638 |
exit |
3351 | 5639 |
end; |
5640 |
||
3728 | 5641 |
odY:= Gear^.dY; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5642 |
doStepFallingGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5643 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5644 |
if (Gear^.State and gstDrowning) <> 0 then |
6305
5f7480c2a08d
Set default water colours in greyscale mode in case the theme does not define them, decrement piano weapon on use
nemo
parents:
6304
diff
changeset
|
5645 |
begin |
6803
0e70f3ea3bf8
bit of an experiment in variable splash sizes based on object/speed. not sure if it looks good yet. need to drown more stuff.
nemo
parents:
6792
diff
changeset
|
5646 |
Gear^.Y:= Gear^.Y + _50; |
6305
5f7480c2a08d
Set default water colours in greyscale mode in case the theme does not define them, decrement piano weapon on use
nemo
parents:
6304
diff
changeset
|
5647 |
OnUsedAmmo(CurrentHedgehog^); |
12292
93434ab299a0
Take sacrifices into account for the “Stupid” taunt
Wuzzy <almikes@aol.com>
parents:
12277
diff
changeset
|
5648 |
uStats.HedgehogSacrificed(CurrentHedgehog); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5649 |
if CurrentHedgehog^.Gear <> nil then |
6305
5f7480c2a08d
Set default water colours in greyscale mode in case the theme does not define them, decrement piano weapon on use
nemo
parents:
6304
diff
changeset
|
5650 |
begin |
3419
b66a1b597f88
Add drown-the-playing-hog check for case of piano falling off the landscape.
nemo
parents:
3417
diff
changeset
|
5651 |
// Drown the hedgehog. Could also just delete it, but hey, this gets a caption |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5652 |
CurrentHedgehog^.Gear^.Active := true; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5653 |
CurrentHedgehog^.Gear^.X := Gear^.X; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5654 |
CurrentHedgehog^.Gear^.Y := int2hwFloat(cWaterLine+cVisibleWater)+_128; |
3954
ae3583ad6ea9
Hopefully fix the last of the more obvious weapon bugs w/ infinite attack mode, add a depixeling sweep every 5s too.
nemo
parents:
3953
diff
changeset
|
5655 |
CurrentHedgehog^.Unplaced := false; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5656 |
if TagTurnTimeLeft = 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5657 |
TagTurnTimeLeft:= TurnTimeLeft; |
3954
ae3583ad6ea9
Hopefully fix the last of the more obvious weapon bugs w/ infinite attack mode, add a depixeling sweep every 5s too.
nemo
parents:
3953
diff
changeset
|
5658 |
TurnTimeLeft:= 0 |
6305
5f7480c2a08d
Set default water colours in greyscale mode in case the theme does not define them, decrement piano weapon on use
nemo
parents:
6304
diff
changeset
|
5659 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5660 |
ResumeMusic |
6305
5f7480c2a08d
Set default water colours in greyscale mode in case the theme does not define them, decrement piano weapon on use
nemo
parents:
6304
diff
changeset
|
5661 |
end |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5662 |
else if (Gear^.State and gstCollision) <> 0 then |
3399 | 5663 |
begin |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
5664 |
r0 := GetRandom(Gear^.Boom div 4 + 1); |
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
5665 |
r1 := GetRandom(Gear^.Boom div 4 + 1); |
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
5666 |
doMakeExplosion(hwRound(Gear^.X) - 30 - r0, hwRound(Gear^.Y) + 40, Gear^.Boom div 2 + r1, Gear^.Hedgehog, 0); |
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
5667 |
doMakeExplosion(hwRound(Gear^.X) + 30 + r1, hwRound(Gear^.Y) + 40, Gear^.Boom div 2 + r0, Gear^.Hedgehog, 0); |
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
5668 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom + r0, Gear^.Hedgehog, EXPLAutoSound); |
6305
5f7480c2a08d
Set default water colours in greyscale mode in case the theme does not define them, decrement piano weapon on use
nemo
parents:
6304
diff
changeset
|
5669 |
for r0:= 0 to 4 do |
5f7480c2a08d
Set default water colours in greyscale mode in case the theme does not define them, decrement piano weapon on use
nemo
parents:
6304
diff
changeset
|
5670 |
AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtNote); |
7066
12cc2bd84b0b
Make pas2c even more happier with uGears.c, allow assigning arrays in some cases
unc0rr
parents:
7062
diff
changeset
|
5671 |
Gear^.dY := cGravity * 2 - odY; |
6305
5f7480c2a08d
Set default water colours in greyscale mode in case the theme does not define them, decrement piano weapon on use
nemo
parents:
6304
diff
changeset
|
5672 |
Gear^.Pos := Gear^.Pos + 1; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5673 |
end |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5674 |
else |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5675 |
Gear^.dY := Gear^.dY + cGravity * 2; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5676 |
// let it fall faster so itdoesn't take too long for the whole attack |
3382 | 5677 |
end; |
3384 | 5678 |
|
5679 |
||
5680 |
//////////////////////////////////////////////////////////////////////////////// |
|
5681 |
procedure doStepSineGunShotWork(Gear: PGear); |
|
8795 | 5682 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5683 |
x, y, rX, rY, t, tmp, initHealth: LongInt; |
3384 | 5684 |
oX, oY, ldX, ldY, sdX, sdY, sine, lx, ly, amp: hwFloat; |
10657 | 5685 |
justCollided, justBounced: boolean; |
3384 | 5686 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5687 |
AllInactive := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5688 |
initHealth := Gear^.Health; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5689 |
lX := Gear^.X; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5690 |
lY := Gear^.Y; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5691 |
ldX := Gear^.dX; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5692 |
ldY := Gear^.dY; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5693 |
sdy := _0_5/Distance(Gear^.dX,Gear^.dY); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5694 |
ldX := ldX * sdy; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5695 |
ldY := ldY * sdy; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5696 |
sdY := hwAbs(ldX) + hwAbs(ldY); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5697 |
sdX := _1 - hwAbs(ldX/sdY); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5698 |
sdY := _1 - hwAbs(ldY/sdY); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5699 |
if (ldX.isNegative = ldY.isNegative) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5700 |
sdY := -sdY; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5701 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5702 |
// initial angle depends on current GameTicks |
7745 | 5703 |
t := getRandom(4096); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5704 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5705 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5706 |
// used for a work-around detection of area that is within land array, but outside borders |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5707 |
justCollided := false; |
10657 | 5708 |
// this variable is just to ensure we don't run in infinite loop due to precision errors |
5709 |
justBounced:= false; |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5710 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5711 |
repeat |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5712 |
lX := lX + ldX; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5713 |
lY := lY + ldY; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5714 |
oX := Gear^.X; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5715 |
oY := Gear^.Y; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5716 |
rX := hwRound(oX); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5717 |
rY := hwRound(oY); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5718 |
tmp := t mod 4096; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5719 |
amp := _128 * (_1 - hwSqr(int2hwFloat(Gear^.Health)/initHealth)); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5720 |
sine := amp * AngleSin(tmp mod 2048); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5721 |
sine.isNegative := (tmp < 2048); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5722 |
Gear^.X := lX + (sine * sdX); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5723 |
Gear^.Y := ly + (sine * sdY); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5724 |
Gear^.dX := Gear^.X - oX; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5725 |
Gear^.dY := Gear^.Y - oY; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5726 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5727 |
x := hwRound(Gear^.X); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5728 |
y := hwRound(Gear^.Y); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5729 |
|
10652 | 5730 |
if WorldEdge = weWrap then |
5731 |
begin |
|
14303
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14225
diff
changeset
|
5732 |
if x > rightX then |
10659 | 5733 |
repeat |
5734 |
dec(x, playWidth); |
|
5735 |
dec(rx, playWidth); |
|
14303
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14225
diff
changeset
|
5736 |
until x <= rightX |
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14225
diff
changeset
|
5737 |
else if x < leftX then |
10659 | 5738 |
repeat |
5739 |
inc(x, playWidth); |
|
5740 |
inc(rx, playWidth); |
|
14303
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14225
diff
changeset
|
5741 |
until x >= leftX; |
10657 | 5742 |
end |
5743 |
else if (WorldEdge = weBounce) then |
|
5744 |
begin |
|
14303
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14225
diff
changeset
|
5745 |
if (not justBounced) and ((x > rightX) or (x < leftX)) then |
10657 | 5746 |
begin |
5747 |
// reflect |
|
5748 |
lX:= lX - ldX + ((oX - lX) * 2); |
|
5749 |
lY:= lY - ldY; |
|
5750 |
Gear^.X:= oX; |
|
5751 |
Gear^.Y:= oY; |
|
5752 |
ldX.isNegative:= (not ldX.isNegative); |
|
5753 |
sdX.isNegative:= (not sdX.isNegative); |
|
5754 |
justBounced:= true; |
|
5755 |
continue; |
|
5756 |
end |
|
5757 |
else |
|
5758 |
justBounced:= false; |
|
10652 | 5759 |
end; |
5760 |
||
10657 | 5761 |
|
5762 |
inc(t,Gear^.Health div 313); |
|
5763 |
||
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5764 |
// if borders are on, stop outside land array |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5765 |
if hasBorder and (((x and LAND_WIDTH_MASK) <> 0) or ((y and LAND_HEIGHT_MASK) <> 0)) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5766 |
begin |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5767 |
Gear^.Damage := 0; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5768 |
Gear^.Health := 0; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5769 |
end |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5770 |
else |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5771 |
begin |
10372 | 5772 |
if (not CheckCoordInWater(rX, rY)) or (not CheckCoordInWater(x, y)) then |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5773 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5774 |
if ((y and LAND_HEIGHT_MASK) = 0) and ((x and LAND_WIDTH_MASK) = 0) |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
5775 |
and (LandGet(y, x) <> 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5776 |
begin |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
5777 |
if ((GameFlags and gfSolidLand) <> 0) and (LandGet(y, x) > 255) then |
10118 | 5778 |
Gear^.Damage := initHealth |
5779 |
else if justCollided then |
|
5780 |
begin |
|
5781 |
Gear^.Damage := initHealth; |
|
5782 |
end |
|
5783 |
else |
|
5784 |
begin |
|
5785 |
inc(Gear^.Damage,3); |
|
5786 |
justCollided := true; |
|
5787 |
end; |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5788 |
end |
3384 | 5789 |
else |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5790 |
justCollided := false; |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5791 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5792 |
// kick nearby hogs, dig tunnel and add some fire |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5793 |
// if at least 5 collisions occured |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5794 |
if Gear^.Damage > 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5795 |
begin |
10118 | 5796 |
if ((GameFlags and gfSolidLand) = 0) then |
5797 |
begin |
|
13566
acc69f506914
Use wrap-aware doMakeExplosion instead of DrawExplosion in uHandlersMess
Wuzzy <Wuzzy2@mail.ru>
parents:
13470
diff
changeset
|
5798 |
doMakeExplosion(rX,rY,Gear^.Radius, Gear^.Hedgehog, EXPLNoDamage or EXPLDoNotTouchAny or EXPLNoGfx); |
10118 | 5799 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5800 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5801 |
// kick nearby hogs |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
5802 |
AmmoShove(Gear, Gear^.Boom, 50); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5803 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5804 |
dec(Gear^.Health, Gear^.Damage); |
10118 | 5805 |
|
5806 |
// explode when impacting on solid land/borders |
|
5807 |
if Gear^.Damage >= initHealth then |
|
5808 |
begin |
|
5809 |
// add some random offset to angles |
|
5810 |
tmp := getRandom(256); |
|
5811 |
// spawn some flames |
|
5812 |
for t:= 0 to 3 do |
|
5813 |
begin |
|
5814 |
if not isZero(Gear^.dX) then rX := rx - hwSign(Gear^.dX); |
|
5815 |
if not isZero(Gear^.dY) then rY := ry - hwSign(Gear^.dY); |
|
5816 |
lX := AngleCos(tmp + t * 512) * _0_25 * (GetRandomf + _1); |
|
5817 |
lY := AngleSin(tmp + t * 512) * _0_25 * (GetRandomf + _1); |
|
5818 |
AddGear(rX, rY, gtFlame, 0, lX, lY, 0); |
|
5819 |
AddGear(rX, rY, gtFlame, 0, lX, -lY, 0); |
|
5820 |
end; |
|
5821 |
end |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5822 |
// add some fire to the tunnel |
10118 | 5823 |
else if getRandom(6) = 0 then |
7391
588eabb4b384
Apparently order of multiple getrandom in params is undefined. Also remove broken and pointless getrandom call.
nemo
parents:
7389
diff
changeset
|
5824 |
begin |
588eabb4b384
Apparently order of multiple getrandom in params is undefined. Also remove broken and pointless getrandom call.
nemo
parents:
7389
diff
changeset
|
5825 |
tmp:= GetRandom(2 * Gear^.Radius); |
588eabb4b384
Apparently order of multiple getrandom in params is undefined. Also remove broken and pointless getrandom call.
nemo
parents:
7389
diff
changeset
|
5826 |
AddGear(x - Gear^.Radius + tmp, y - GetRandom(Gear^.Radius + 1), gtFlame, gsttmpFlag, _0, _0, 0) |
10118 | 5827 |
end; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5828 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5829 |
|
10118 | 5830 |
Gear^.Damage := 0; |
5831 |
||
7391
588eabb4b384
Apparently order of multiple getrandom in params is undefined. Also remove broken and pointless getrandom call.
nemo
parents:
7389
diff
changeset
|
5832 |
if random(100) = 0 then |
8795 | 5833 |
AddVisualGear(x, y, vgtSmokeTrace); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5834 |
end |
10118 | 5835 |
else dec(Gear^.Health, 5); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5836 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5837 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5838 |
dec(Gear^.Health); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5839 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5840 |
// decrease bullet size towards the end |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5841 |
if (Gear^.Radius > 4) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5842 |
begin |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5843 |
if (Gear^.Health <= (initHealth div 3)) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5844 |
dec(Gear^.Radius) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5845 |
end |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5846 |
else if (Gear^.Radius > 3) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5847 |
begin |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5848 |
if (Gear^.Health <= (initHealth div 4)) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5849 |
dec(Gear^.Radius) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5850 |
end |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5851 |
else if (Gear^.Radius > 2) then begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5852 |
if (Gear^.Health <= (initHealth div 5)) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5853 |
dec(Gear^.Radius) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5854 |
end |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5855 |
else if (Gear^.Radius > 1) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5856 |
begin |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5857 |
if (Gear^.Health <= (initHealth div 6)) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5858 |
dec(Gear^.Radius) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5859 |
end; |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5860 |
until (Gear^.Health <= 0); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5861 |
|
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5862 |
DeleteGear(Gear); |
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5863 |
AfterAttack; |
3384 | 5864 |
end; |
5865 |
||
5866 |
procedure doStepSineGunShot(Gear: PGear); |
|
7745 | 5867 |
var |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5868 |
HHGear: PGear; |
3384 | 5869 |
begin |
8795 | 5870 |
PlaySound(sndSineGun); |
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5871 |
|
11551 | 5872 |
if (Gear^.Hedgehog <> nil) and (Gear^.Hedgehog^.Gear <> nil) then |
5873 |
begin |
|
5874 |
HHGear := Gear^.Hedgehog^.Gear; |
|
5875 |
// push the shooting Hedgehog back |
|
5876 |
Gear^.dX.isNegative := not Gear^.dX.isNegative; |
|
5877 |
Gear^.dY.isNegative := not Gear^.dY.isNegative; |
|
5878 |
HHGear^.dX := Gear^.dX; |
|
5879 |
HHGear^.dY := Gear^.dY; |
|
13806
506cca5a48cb
Fix sinegun dealing 1 damage when shooting straight up. Reduces sine gun knockback strength by 1.25%
alfadur
parents:
13760
diff
changeset
|
5880 |
AmmoShove(Gear, 0, 79); |
11551 | 5881 |
Gear^.dX.isNegative := not Gear^.dX.isNegative; |
5882 |
Gear^.dY.isNegative := not Gear^.dY.isNegative; |
|
5883 |
end; |
|
3454
a9bef74bd6e0
Code restlyling: experimental restyling of one module
mbait
parents:
3440
diff
changeset
|
5884 |
|
4034
634a8c8682de
add some phone rumbling to big explosions, airbomb and sinegun
koda
parents:
4026
diff
changeset
|
5885 |
Gear^.doStep := @doStepSineGunShotWork; |
9954 | 5886 |
{$IFNDEF PAS2C} |
8204 | 5887 |
with mobileRecord do |
5888 |
if (performRumble <> nil) and (not fastUntilLag) then |
|
5889 |
performRumble(kSystemSoundID_Vibrate); |
|
9954 | 5890 |
{$ENDIF} |
3384 | 5891 |
end; |
3476
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
5892 |
|
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
5893 |
//////////////////////////////////////////////////////////////////////////////// |
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
5894 |
procedure doStepFlamethrowerWork(Gear: PGear); |
8795 | 5895 |
var |
7281 | 5896 |
HHGear, flame: PGear; |
3485 | 5897 |
rx, ry, speed: hwFloat; |
4254
47515c926984
only update flamethrower texture when the percentage changes
nemo
parents:
4246
diff
changeset
|
5898 |
i, gX, gY: LongInt; |
3476
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
5899 |
begin |
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
5900 |
AllInactive := false; |
4365 | 5901 |
HHGear := Gear^.Hedgehog^.Gear; |
10831
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
5902 |
if HHGear = nil then |
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
5903 |
begin |
14004 | 5904 |
StopSoundChan(Gear^.SoundChannel, 300); |
10831
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
5905 |
DeleteGear(gear); |
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
5906 |
exit |
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
5907 |
end; |
3476
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
5908 |
HedgehogChAngle(HHGear); |
3484 | 5909 |
gX := hwRound(Gear^.X) + GetLaunchX(amBallgun, hwSign(HHGear^.dX), HHGear^.Angle); |
5910 |
gY := hwRound(Gear^.Y) + GetLaunchY(amBallgun, HHGear^.Angle); |
|
8795 | 5911 |
|
3485 | 5912 |
if (GameTicks and $FF) = 0 then |
4254
47515c926984
only update flamethrower texture when the percentage changes
nemo
parents:
4246
diff
changeset
|
5913 |
begin |
3894 | 5914 |
if (HHGear^.Message and gmRight) <> 0 then |
4254
47515c926984
only update flamethrower texture when the percentage changes
nemo
parents:
4246
diff
changeset
|
5915 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5916 |
if HHGear^.dX.isNegative and (Gear^.Tag < 20) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5917 |
inc(Gear^.Tag) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5918 |
else if Gear^.Tag > 5 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5919 |
dec(Gear^.Tag); |
4254
47515c926984
only update flamethrower texture when the percentage changes
nemo
parents:
4246
diff
changeset
|
5920 |
end |
3894 | 5921 |
else if (HHGear^.Message and gmLeft) <> 0 then |
4254
47515c926984
only update flamethrower texture when the percentage changes
nemo
parents:
4246
diff
changeset
|
5922 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5923 |
if HHGear^.dX.isNegative and (Gear^.Tag > 5) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5924 |
dec(Gear^.Tag) |
8795 | 5925 |
else if Gear^.Tag < 20 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
5926 |
inc(Gear^.Tag); |
4254
47515c926984
only update flamethrower texture when the percentage changes
nemo
parents:
4246
diff
changeset
|
5927 |
end |
47515c926984
only update flamethrower texture when the percentage changes
nemo
parents:
4246
diff
changeset
|
5928 |
end; |
8795 | 5929 |
|
3485 | 5930 |
dec(Gear^.Timer); |
5931 |
if Gear^.Timer = 0 then |
|
4254
47515c926984
only update flamethrower texture when the percentage changes
nemo
parents:
4246
diff
changeset
|
5932 |
begin |
3485 | 5933 |
dec(Gear^.Health); |
5417
c56a6be662bf
try to tweak flamethrower a bit to do more damage with fire changes. An optimal firepit test dealt 68.
nemo
parents:
5415
diff
changeset
|
5934 |
if (Gear^.Health mod 5) = 0 then |
4254
47515c926984
only update flamethrower texture when the percentage changes
nemo
parents:
4246
diff
changeset
|
5935 |
begin |
7001 | 5936 |
rx := rndSign(getRandomf * _0_1); |
5937 |
ry := rndSign(getRandomf * _0_1); |
|
5417
c56a6be662bf
try to tweak flamethrower a bit to do more damage with fire changes. An optimal firepit test dealt 68.
nemo
parents:
5415
diff
changeset
|
5938 |
speed := _0_5 * (_10 / Gear^.Tag); |
8795 | 5939 |
|
7281 | 5940 |
flame:= AddGear(gx, gy, gtFlame, gstTmpFlag, |
6126
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
5941 |
SignAs(AngleSin(HHGear^.Angle) * speed, HHGear^.dX) + rx, |
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
5942 |
AngleCos(HHGear^.Angle) * ( - speed) + ry, 0); |
13469
f1d349a52bc7
Refactor: lfCurrentHog→lfCurHogCrate, lfNotCurrentMask→lfNotCurHogCrate
Wuzzy <Wuzzy2@mail.ru>
parents:
13408
diff
changeset
|
5943 |
flame^.CollisionMask:= lfNotCurHogCrate; |
8795 | 5944 |
|
6131 | 5945 |
if (Gear^.Health mod 30) = 0 then |
7281 | 5946 |
begin |
5947 |
flame:= AddGear(gx, gy, gtFlame, 0, |
|
6126
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
5948 |
SignAs(AngleSin(HHGear^.Angle) * speed, HHGear^.dX) + rx, |
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
5949 |
AngleCos(HHGear^.Angle) * ( - speed) + ry, 0); |
13469
f1d349a52bc7
Refactor: lfCurrentHog→lfCurHogCrate, lfNotCurrentMask→lfNotCurHogCrate
Wuzzy <Wuzzy2@mail.ru>
parents:
13408
diff
changeset
|
5950 |
flame^.CollisionMask:= lfNotCurHogCrate; |
7281 | 5951 |
end |
4254
47515c926984
only update flamethrower texture when the percentage changes
nemo
parents:
4246
diff
changeset
|
5952 |
end; |
3485 | 5953 |
Gear^.Timer:= Gear^.Tag |
4254
47515c926984
only update flamethrower texture when the percentage changes
nemo
parents:
4246
diff
changeset
|
5954 |
end; |
3476
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
5955 |
|
7539 | 5956 |
if (Gear^.Health = 0) or ((HHGear^.State and gstHHDriven) = 0) then |
4254
47515c926984
only update flamethrower texture when the percentage changes
nemo
parents:
4246
diff
changeset
|
5957 |
begin |
14019
23fb123bd70c
Clear gmLeft/gmRight after using landspray/flamethrower to prevent accidental walking
Wuzzy <Wuzzy2@mail.ru>
parents:
14017
diff
changeset
|
5958 |
HHGear^.Message:= HHGear^.Message and (not (gmAttack or gmLeft or gmRight)); |
10831
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
5959 |
HHGear^.State := HHGear^.State and (not gstNotKickable); |
14004 | 5960 |
StopSoundChan(Gear^.SoundChannel, 300); |
3476
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
5961 |
DeleteGear(Gear); |
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
5962 |
AfterAttack |
4254
47515c926984
only update flamethrower texture when the percentage changes
nemo
parents:
4246
diff
changeset
|
5963 |
end |
3485 | 5964 |
else |
4254
47515c926984
only update flamethrower texture when the percentage changes
nemo
parents:
4246
diff
changeset
|
5965 |
begin |
4256 | 5966 |
i:= Gear^.Health div 5; |
15381
c117e17b90bc
flag some of the renderstringtex which are taking up a ton of processing time with --stats-only and pas2c
nemo
parents:
15354
diff
changeset
|
5967 |
if (not cOnlyStats) and (i <> Gear^.Damage) and ((GameTicks and $3F) = 0) then |
4254
47515c926984
only update flamethrower texture when the percentage changes
nemo
parents:
4246
diff
changeset
|
5968 |
begin |
4258 | 5969 |
Gear^.Damage:= i; |
10634
35d059bd0932
Use FreeAndNil across the board. Even if we are immediately assigning after, probably avoids accidental mistakes. Also free neglected owner tex on shutdown, and delete hog gears using the normal deletion procedure if for any reason they still exist (EndGame call?).
nemo
parents:
10597
diff
changeset
|
5970 |
FreeAndNilTexture(Gear^.Tex); |
13898 | 5971 |
Gear^.Tex := RenderStringTex(FormatA(trmsg[sidFuel], ansistring(inttostr(i))), |
13640
cb0191394133
Use full string for sidFuel and avoid string concatenation
Wuzzy <Wuzzy2@mail.ru>
parents:
13624
diff
changeset
|
5972 |
cWhiteColor, fntSmall) |
4254
47515c926984
only update flamethrower texture when the percentage changes
nemo
parents:
4246
diff
changeset
|
5973 |
end |
47515c926984
only update flamethrower texture when the percentage changes
nemo
parents:
4246
diff
changeset
|
5974 |
end |
3476
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
5975 |
end; |
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
5976 |
|
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
5977 |
procedure doStepFlamethrower(Gear: PGear); |
8795 | 5978 |
var |
3476
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
5979 |
HHGear: PGear; |
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
5980 |
begin |
4365 | 5981 |
HHGear := Gear^.Hedgehog^.Gear; |
6450 | 5982 |
HHGear^.Message := HHGear^.Message and (not (gmUp or gmDown or gmLeft or gmRight)); |
3476
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
5983 |
HHGear^.State := HHGear^.State or gstNotKickable; |
14653
5132548cdb77
Add workaround around an SDL_mixer bug that screws up volume after using flamethrower (bug 721)
Wuzzy <Wuzzy2@mail.ru>
parents:
14637
diff
changeset
|
5984 |
(* NOTE: Flamethrower sound is supposed to start instantly (no fade in), |
5132548cdb77
Add workaround around an SDL_mixer bug that screws up volume after using flamethrower (bug 721)
Wuzzy <Wuzzy2@mail.ru>
parents:
14637
diff
changeset
|
5985 |
but this would cause the game volume to screw up because of a bug in SDL_mixer: |
5132548cdb77
Add workaround around an SDL_mixer bug that screws up volume after using flamethrower (bug 721)
Wuzzy <Wuzzy2@mail.ru>
parents:
14637
diff
changeset
|
5986 |
https://bugzilla.libsdl.org/show_bug.cgi?id=4205 |
5132548cdb77
Add workaround around an SDL_mixer bug that screws up volume after using flamethrower (bug 721)
Wuzzy <Wuzzy2@mail.ru>
parents:
14637
diff
changeset
|
5987 |
As workaround, a tiny fade-in delay was added. |
5132548cdb77
Add workaround around an SDL_mixer bug that screws up volume after using flamethrower (bug 721)
Wuzzy <Wuzzy2@mail.ru>
parents:
14637
diff
changeset
|
5988 |
FIXME: Remove the fade-in delay argument when the SDL bug has been fixed. *) |
5132548cdb77
Add workaround around an SDL_mixer bug that screws up volume after using flamethrower (bug 721)
Wuzzy <Wuzzy2@mail.ru>
parents:
14637
diff
changeset
|
5989 |
Gear^.SoundChannel := LoopSound(sndFlamethrower, 20); |
3476
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
5990 |
Gear^.doStep := @doStepFlamethrowerWork |
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
5991 |
end; |
1ec68b8d3bd1
Henek adds a flamethrower, updates some translations, and tweaks how fire works.
nemo
parents:
3475
diff
changeset
|
5992 |
|
5313
5e18eaef65d0
now scripts can create unique crates: dummy (empty) crates and booby traps. scripts can also set health crate values
Henek
parents:
5298
diff
changeset
|
5993 |
//////////////////////////////////////////////////////////////////////////////// |
5024 | 5994 |
procedure doStepLandGunWork(Gear: PGear); |
8795 | 5995 |
var |
7281 | 5996 |
HHGear, land: PGear; |
5024 | 5997 |
rx, ry, speed: hwFloat; |
5998 |
i, gX, gY: LongInt; |
|
5999 |
begin |
|
6000 |
AllInactive := false; |
|
6001 |
HHGear := Gear^.Hedgehog^.Gear; |
|
10831
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
6002 |
if HHGear = nil then |
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
6003 |
begin |
14006 | 6004 |
StopSoundChan(gear^.SoundChannel); |
10831
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
6005 |
DeleteGear(gear); |
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
6006 |
exit |
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
6007 |
end; |
5024 | 6008 |
HedgehogChAngle(HHGear); |
6009 |
gX := hwRound(Gear^.X) + GetLaunchX(amBallgun, hwSign(HHGear^.dX), HHGear^.Angle); |
|
6010 |
gY := hwRound(Gear^.Y) + GetLaunchY(amBallgun, HHGear^.Angle); |
|
8795 | 6011 |
|
5024 | 6012 |
if (GameTicks and $FF) = 0 then |
6013 |
begin |
|
6014 |
if (HHGear^.Message and gmRight) <> 0 then |
|
6015 |
begin |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6016 |
if HHGear^.dX.isNegative and (Gear^.Tag < 20) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6017 |
inc(Gear^.Tag) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6018 |
else if Gear^.Tag > 5 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6019 |
dec(Gear^.Tag); |
5024 | 6020 |
end |
6021 |
else if (HHGear^.Message and gmLeft) <> 0 then |
|
6022 |
begin |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6023 |
if HHGear^.dX.isNegative and (Gear^.Tag > 5) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6024 |
dec(Gear^.Tag) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6025 |
else if Gear^.Tag < 20 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6026 |
inc(Gear^.Tag); |
5024 | 6027 |
end |
6028 |
end; |
|
8795 | 6029 |
|
5024 | 6030 |
dec(Gear^.Timer); |
6031 |
if Gear^.Timer = 0 then |
|
6032 |
begin |
|
6033 |
dec(Gear^.Health); |
|
5480 | 6034 |
|
7001 | 6035 |
rx := rndSign(getRandomf * _0_1); |
6036 |
ry := rndSign(getRandomf * _0_1); |
|
5480 | 6037 |
speed := (_3 / Gear^.Tag); |
6038 |
||
8795 | 6039 |
land:= AddGear(gx, gy, gtFlake, gstTmpFlag, |
6040 |
SignAs(AngleSin(HHGear^.Angle) * speed, HHGear^.dX) + rx, |
|
6126
61c1161ee32f
Remove unnecessary assignments post-creation. Simplifies Lua manipulation of these adds as well as just being tidier.
nemo
parents:
6122
diff
changeset
|
6041 |
AngleCos(HHGear^.Angle) * ( - speed) + ry, 0); |
13469
f1d349a52bc7
Refactor: lfCurrentHog→lfCurHogCrate, lfNotCurrentMask→lfNotCurHogCrate
Wuzzy <Wuzzy2@mail.ru>
parents:
13408
diff
changeset
|
6042 |
land^.CollisionMask:= lfNotCurHogCrate; |
8795 | 6043 |
|
5024 | 6044 |
Gear^.Timer:= Gear^.Tag |
6045 |
end; |
|
6046 |
||
7539 | 6047 |
if (Gear^.Health = 0) or ((HHGear^.State and gstHHDriven) = 0) or ((HHGear^.Message and gmAttack) <> 0) then |
5024 | 6048 |
begin |
14019
23fb123bd70c
Clear gmLeft/gmRight after using landspray/flamethrower to prevent accidental walking
Wuzzy <Wuzzy2@mail.ru>
parents:
14017
diff
changeset
|
6049 |
HHGear^.Message:= HHGear^.Message and (not (gmAttack or gmLeft or gmRight)); |
10831
19d056c10bbd
Clear flag set by gear on gear deletion. Also added a few more nil checks on HHGear
nemo
parents:
10827
diff
changeset
|
6050 |
HHGear^.State := HHGear^.State and (not gstNotKickable); |
14006 | 6051 |
StopSoundChan(gear^.SoundChannel); |
5024 | 6052 |
DeleteGear(Gear); |
6053 |
AfterAttack |
|
6054 |
end |
|
6055 |
else |
|
6056 |
begin |
|
6057 |
i:= Gear^.Health div 10; |
|
15381
c117e17b90bc
flag some of the renderstringtex which are taking up a ton of processing time with --stats-only and pas2c
nemo
parents:
15354
diff
changeset
|
6058 |
if (not cOnlyStats) and (i <> Gear^.Damage) and ((GameTicks and $3F) = 0) then |
5024 | 6059 |
begin |
6060 |
Gear^.Damage:= i; |
|
10634
35d059bd0932
Use FreeAndNil across the board. Even if we are immediately assigning after, probably avoids accidental mistakes. Also free neglected owner tex on shutdown, and delete hog gears using the normal deletion procedure if for any reason they still exist (EndGame call?).
nemo
parents:
10597
diff
changeset
|
6061 |
FreeAndNilTexture(Gear^.Tex); |
13898 | 6062 |
Gear^.Tex := RenderStringTex(FormatA(trmsg[sidFuel], ansistring(inttostr(i))), |
13640
cb0191394133
Use full string for sidFuel and avoid string concatenation
Wuzzy <Wuzzy2@mail.ru>
parents:
13624
diff
changeset
|
6063 |
cWhiteColor, fntSmall) |
5024 | 6064 |
end |
6065 |
end |
|
6066 |
end; |
|
6067 |
||
6068 |
procedure doStepLandGun(Gear: PGear); |
|
8795 | 6069 |
var |
5024 | 6070 |
HHGear: PGear; |
6071 |
begin |
|
6072 |
HHGear := Gear^.Hedgehog^.Gear; |
|
6450 | 6073 |
HHGear^.Message := HHGear^.Message and (not (gmUp or gmDown or gmLeft or gmRight or gmAttack)); |
5024 | 6074 |
HHGear^.State := HHGear^.State or gstNotKickable; |
14006 | 6075 |
Gear^.SoundChannel := LoopSound(sndLandGun); |
5024 | 6076 |
Gear^.doStep := @doStepLandGunWork |
6077 |
end; |
|
6078 |
||
5313
5e18eaef65d0
now scripts can create unique crates: dummy (empty) crates and booby traps. scripts can also set health crate values
Henek
parents:
5298
diff
changeset
|
6079 |
//////////////////////////////////////////////////////////////////////////////// |
3712 | 6080 |
procedure doStepPoisonCloud(Gear: PGear); |
6081 |
begin |
|
11236 | 6082 |
// don't bounce |
6083 |
if WorldEdge <> weBounce then |
|
6084 |
WorldWrap(Gear); |
|
3712 | 6085 |
if Gear^.Timer = 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6086 |
begin |
3712 | 6087 |
DeleteGear(Gear); |
6088 |
exit |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6089 |
end; |
3712 | 6090 |
dec(Gear^.Timer); |
6091 |
Gear^.X:= Gear^.X + Gear^.dX; |
|
6092 |
Gear^.Y:= Gear^.Y + Gear^.dY; |
|
3713 | 6093 |
Gear^.dX := Gear^.dX + cWindSpeed / 4; |
3712 | 6094 |
Gear^.dY := Gear^.dY + cGravity / 100; |
5340
6963e37f2dd2
- Allow snow to drop a bit outside the map, where it already is allowed to spawn
unc0rr
parents:
5336
diff
changeset
|
6095 |
if (GameTicks and $FF) = 0 then |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
6096 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLDontDraw or EXPLNoGfx or EXPLNoDamage or EXPLDoNotTouchAny or EXPLPoisoned); |
9817 | 6097 |
if Gear^.State and gstTmpFlag = 0 then |
6098 |
AllInactive:= false; |
|
3717 | 6099 |
end; |
6100 |
||
6101 |
//////////////////////////////////////////////////////////////////////////////// |
|
6102 |
procedure doStepHammer(Gear: PGear); |
|
3720 | 6103 |
var HHGear, tmp, tmp2: PGear; |
3717 | 6104 |
t: PGearArray; |
12621 | 6105 |
i, dmg: LongInt; |
3717 | 6106 |
begin |
4365 | 6107 |
HHGear:= Gear^.Hedgehog^.Gear; |
3717 | 6108 |
HHGear^.State:= HHGear^.State or gstNoDamage; |
6109 |
DeleteCI(HHGear); |
|
11044
c3d76daae637
this should prevent hogs from hovering in air after using hammer
sheepluva
parents:
11042
diff
changeset
|
6110 |
SetLittle(HHGear^.dY); |
c3d76daae637
this should prevent hogs from hovering in air after using hammer
sheepluva
parents:
11042
diff
changeset
|
6111 |
HHGear^.dY.IsNegative:= true; |
c3d76daae637
this should prevent hogs from hovering in air after using hammer
sheepluva
parents:
11042
diff
changeset
|
6112 |
HHGear^.State:= HHGear^.State or gstMoving; |
3717 | 6113 |
|
6114 |
t:= CheckGearsCollision(Gear); |
|
3720 | 6115 |
|
6116 |
for i:= 5 downto 0 do |
|
6117 |
AddVisualGear(hwRound(Gear^.X) - 5 + Random(10), hwRound(Gear^.Y) + 12, vgtDust); |
|
6118 |
||
3717 | 6119 |
i:= t^.Count; |
6120 |
while i > 0 do |
|
6121 |
begin |
|
6122 |
dec(i); |
|
6123 |
tmp:= t^.ar[i]; |
|
6124 |
if (tmp^.State and gstNoDamage) = 0 then |
|
5624
b6f70f6335ee
Allow hammer to bash mines/barrels too, increase escape time to 3s
nemo
parents:
5612
diff
changeset
|
6125 |
if (tmp^.Kind = gtHedgehog) or (tmp^.Kind = gtMine) or (tmp^.Kind = gtExplosives) then |
3717 | 6126 |
begin |
11042 | 6127 |
dmg:= 0; |
15764
0b5aea8e5eab
Fix hammer not digging when hitting hog with 0 health
Wuzzy <Wuzzy2@mail.ru>
parents:
15763
diff
changeset
|
6128 |
if (tmp^.Kind <> gtHedgehog) or |
0b5aea8e5eab
Fix hammer not digging when hitting hog with 0 health
Wuzzy <Wuzzy2@mail.ru>
parents:
15763
diff
changeset
|
6129 |
((tmp^.Hedgehog^.Effects[heInvulnerable] = 0) and ((tmp^.State and gstHHDeath) = 0)) then |
11039
cd4b0851b060
Hammer changes/fixes: honor extra-damage (Issue 975), round up damage, do correct damage when being spammed in infinite-attack mode
sheepluva
parents:
11020
diff
changeset
|
6130 |
begin |
cd4b0851b060
Hammer changes/fixes: honor extra-damage (Issue 975), round up damage, do correct damage when being spammed in infinite-attack mode
sheepluva
parents:
11020
diff
changeset
|
6131 |
// base damage on remaining health |
cd4b0851b060
Hammer changes/fixes: honor extra-damage (Issue 975), round up damage, do correct damage when being spammed in infinite-attack mode
sheepluva
parents:
11020
diff
changeset
|
6132 |
dmg:= (tmp^.Health - tmp^.Damage); |
15764
0b5aea8e5eab
Fix hammer not digging when hitting hog with 0 health
Wuzzy <Wuzzy2@mail.ru>
parents:
15763
diff
changeset
|
6133 |
// always rounding down |
0b5aea8e5eab
Fix hammer not digging when hitting hog with 0 health
Wuzzy <Wuzzy2@mail.ru>
parents:
15763
diff
changeset
|
6134 |
dmg:= dmg div Gear^.Boom; |
0b5aea8e5eab
Fix hammer not digging when hitting hog with 0 health
Wuzzy <Wuzzy2@mail.ru>
parents:
15763
diff
changeset
|
6135 |
|
11039
cd4b0851b060
Hammer changes/fixes: honor extra-damage (Issue 975), round up damage, do correct damage when being spammed in infinite-attack mode
sheepluva
parents:
11020
diff
changeset
|
6136 |
if dmg > 0 then |
15764
0b5aea8e5eab
Fix hammer not digging when hitting hog with 0 health
Wuzzy <Wuzzy2@mail.ru>
parents:
15763
diff
changeset
|
6137 |
ApplyDamage(tmp, CurrentHedgehog, dmg, dsHammer); |
0b5aea8e5eab
Fix hammer not digging when hitting hog with 0 health
Wuzzy <Wuzzy2@mail.ru>
parents:
15763
diff
changeset
|
6138 |
tmp^.dY:= _0_03 * Gear^.Boom |
11042 | 6139 |
end; |
6140 |
||
15764
0b5aea8e5eab
Fix hammer not digging when hitting hog with 0 health
Wuzzy <Wuzzy2@mail.ru>
parents:
15763
diff
changeset
|
6141 |
if ((tmp^.Kind = gtHedgehog) and ((tmp^.State and gstHHDeath) = 0)) or (tmp^.Health > tmp^.Damage) then |
11042 | 6142 |
begin |
6143 |
tmp2:= AddGear(hwRound(tmp^.X), hwRound(tmp^.Y), gtHammerHit, 0, _0, _0, 0); |
|
6144 |
tmp2^.LinkedGear:= tmp; |
|
6145 |
SetAllToActive |
|
6146 |
end; |
|
11039
cd4b0851b060
Hammer changes/fixes: honor extra-damage (Issue 975), round up damage, do correct damage when being spammed in infinite-attack mode
sheepluva
parents:
11020
diff
changeset
|
6147 |
end; |
3717 | 6148 |
end; |
6149 |
||
6450 | 6150 |
HHGear^.State:= HHGear^.State and (not gstNoDamage); |
3717 | 6151 |
Gear^.Timer:= 250; |
6152 |
Gear^.doStep:= @doStepIdle |
|
6153 |
end; |
|
3720 | 6154 |
|
6155 |
procedure doStepHammerHitWork(Gear: PGear); |
|
8795 | 6156 |
var |
5628 | 6157 |
i, j, ei: LongInt; |
5624
b6f70f6335ee
Allow hammer to bash mines/barrels too, increase escape time to 3s
nemo
parents:
5612
diff
changeset
|
6158 |
HitGear: PGear; |
3720 | 6159 |
begin |
6160 |
AllInactive := false; |
|
7272
71df899c4163
Second part of the change. Make collision check use the new mask bit.
nemo
parents:
7270
diff
changeset
|
6161 |
HitGear := Gear^.LinkedGear; |
3720 | 6162 |
dec(Gear^.Timer); |
5624
b6f70f6335ee
Allow hammer to bash mines/barrels too, increase escape time to 3s
nemo
parents:
5612
diff
changeset
|
6163 |
if (HitGear = nil) or (Gear^.Timer = 0) or ((Gear^.Message and gmDestroy) <> 0) then |
5628 | 6164 |
begin |
3720 | 6165 |
DeleteGear(Gear); |
6166 |
exit |
|
5628 | 6167 |
end; |
3720 | 6168 |
|
6169 |
if (Gear^.Timer mod 5) = 0 then |
|
5628 | 6170 |
begin |
3720 | 6171 |
AddVisualGear(hwRound(Gear^.X) - 5 + Random(10), hwRound(Gear^.Y) + 12, vgtDust); |
6172 |
||
5628 | 6173 |
i := hwRound(Gear^.X) - HitGear^.Radius + 2; |
6174 |
ei := hwRound(Gear^.X) + HitGear^.Radius - 2; |
|
13604
73b096e1d895
Fix hammer/pickhammer not digging land with gfSolidLand on
Wuzzy <Wuzzy2@mail.ru>
parents:
13603
diff
changeset
|
6175 |
for j := 1 to 4 do doMakeExplosion(i - GetRandom(5), hwRound(Gear^.Y) + 6*j, 3, Gear^.Hedgehog, EXPLNoDamage or EXPLDoNotTouchAny or EXPLNoGfx or EXPLForceDraw); |
73b096e1d895
Fix hammer/pickhammer not digging land with gfSolidLand on
Wuzzy <Wuzzy2@mail.ru>
parents:
13603
diff
changeset
|
6176 |
for j := 1 to 4 do doMakeExplosion(ei + LongInt(GetRandom(5)), hwRound(Gear^.Y) + 6*j, 3, Gear^.Hedgehog, EXPLNoDamage or EXPLDoNotTouchAny or EXPLNoGfx or EXPLForceDraw); |
3720 | 6177 |
while i <= ei do |
5628 | 6178 |
begin |
13604
73b096e1d895
Fix hammer/pickhammer not digging land with gfSolidLand on
Wuzzy <Wuzzy2@mail.ru>
parents:
13603
diff
changeset
|
6179 |
for j := 1 to 11 do doMakeExplosion(i, hwRound(Gear^.Y) + 3*j, 3, Gear^.Hedgehog, EXPLNoDamage or EXPLDoNotTouchAny or EXPLNoGfx or EXPLForceDraw); |
3720 | 6180 |
inc(i, 1) |
5628 | 6181 |
end; |
3720 | 6182 |
|
6183 |
if CheckLandValue(hwRound(Gear^.X + Gear^.dX + SignAs(_6,Gear^.dX)), hwRound(Gear^.Y + _1_9) |
|
13603 | 6184 |
, lfIndestructible) then |
6185 |
begin |
|
6186 |
Gear^.Y := Gear^.Y + _1_9 |
|
6187 |
end; |
|
3720 | 6188 |
end; |
6081
537bbd5c1a62
Basic test implementation of an ice flag. Allows for slick parts of terrain. Intended for ice gun, or "ice" mask on portions of land objects.
nemo
parents:
6011
diff
changeset
|
6189 |
if TestCollisionYwithGear(Gear, 1) <> 0 then |
5628 | 6190 |
begin |
3720 | 6191 |
Gear^.dY := _0; |
5624
b6f70f6335ee
Allow hammer to bash mines/barrels too, increase escape time to 3s
nemo
parents:
5612
diff
changeset
|
6192 |
SetLittle(HitGear^.dX); |
b6f70f6335ee
Allow hammer to bash mines/barrels too, increase escape time to 3s
nemo
parents:
5612
diff
changeset
|
6193 |
HitGear^.dY := _0; |
5628 | 6194 |
end |
3720 | 6195 |
else |
5628 | 6196 |
begin |
10354 | 6197 |
if CheckCoordInWater(hwRound(Gear^.X), hwRound(Gear^.Y)) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6198 |
Gear^.Timer := 1 |
5628 | 6199 |
end; |
3720 | 6200 |
|
5624
b6f70f6335ee
Allow hammer to bash mines/barrels too, increase escape time to 3s
nemo
parents:
5612
diff
changeset
|
6201 |
HitGear^.X := Gear^.X; |
8634
5dcb1dc9e01b
fix portal/hammer interaction, ban freezer from portal
nemo
parents:
8632
diff
changeset
|
6202 |
HitGear^.Y := Gear^.Y; |
5628 | 6203 |
SetLittle(HitGear^.dY); |
6204 |
HitGear^.Active:= true; |
|
3720 | 6205 |
end; |
6206 |
||
6207 |
procedure doStepHammerHit(Gear: PGear); |
|
8795 | 6208 |
var |
3720 | 6209 |
i, y: LongInt; |
6210 |
ar: TRangeArray; |
|
6211 |
HHGear: PGear; |
|
6212 |
begin |
|
6213 |
i := 0; |
|
4365 | 6214 |
HHGear := Gear^.Hedgehog^.Gear; |
3720 | 6215 |
|
6216 |
y := hwRound(Gear^.Y) - cHHRadius * 2; |
|
6217 |
while y < hwRound(Gear^.Y) do |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6218 |
begin |
3720 | 6219 |
ar[i].Left := hwRound(Gear^.X) - Gear^.Radius - LongInt(GetRandom(2)); |
6220 |
ar[i].Right := hwRound(Gear^.X) + Gear^.Radius + LongInt(GetRandom(2)); |
|
6221 |
inc(y, 2); |
|
6222 |
inc(i) |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6223 |
end; |
3720 | 6224 |
|
6225 |
DrawHLinesExplosions(@ar, 3, hwRound(Gear^.Y) - cHHRadius * 2, 2, Pred(i)); |
|
6226 |
Gear^.dY := HHGear^.dY; |
|
6227 |
DeleteCI(HHGear); |
|
6228 |
||
6229 |
doStepHammerHitWork(Gear); |
|
3821 | 6230 |
Gear^.doStep := @doStepHammerHitWork |
3720 | 6231 |
end; |
3963
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6232 |
|
4293
d79ffcdd77df
makes drill attack drills weaker and not affected by wind
Henek
parents:
4282
diff
changeset
|
6233 |
//////////////////////////////////////////////////////////////////////////////// |
3963
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6234 |
procedure doStepResurrectorWork(Gear: PGear); |
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6235 |
var |
7335 | 6236 |
graves: PGearArrayS; |
3963
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6237 |
resgear: PGear; |
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6238 |
hh: PHedgehog; |
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6239 |
i: LongInt; |
12169
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12120
diff
changeset
|
6240 |
s: ansistring; |
3963
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6241 |
begin |
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6242 |
AllInactive := false; |
4365 | 6243 |
hh := Gear^.Hedgehog; |
4387 | 6244 |
|
6131 | 6245 |
if ((Gear^.Message and gmUp) <> 0) then |
4017
048bcb8c72ae
Kill off hog immediately on using up health, use more common formatting, call render less often
nemo
parents:
4005
diff
changeset
|
6246 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6247 |
if (GameTicks and $F) <> 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6248 |
exit; |
8795 | 6249 |
end |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6250 |
else if (GameTicks and $1FF) <> 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6251 |
exit; |
4017
048bcb8c72ae
Kill off hog immediately on using up health, use more common formatting, call render less often
nemo
parents:
4005
diff
changeset
|
6252 |
|
6131 | 6253 |
if Gear^.Power < 45 then |
4044
de7170e51cc6
Check for collision with surfaces above when levitating hog, use more typical drawing syntax for the resurrector wep, restore typical indentation
nemo
parents:
4038
diff
changeset
|
6254 |
begin |
4023
8de77872ef21
Resurrector: Levitate hog + show cross
Tobias Neumann <mail@tobias-neumann.eu>
parents:
4021
diff
changeset
|
6255 |
inc(Gear^.Power); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6256 |
if TestCollisionYwithGear(hh^.Gear, -1) = 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6257 |
hh^.Gear^.Y := hh^.Gear^.Y - _1; |
4044
de7170e51cc6
Check for collision with surfaces above when levitating hog, use more typical drawing syntax for the resurrector wep, restore typical indentation
nemo
parents:
4038
diff
changeset
|
6258 |
end; |
de7170e51cc6
Check for collision with surfaces above when levitating hog, use more typical drawing syntax for the resurrector wep, restore typical indentation
nemo
parents:
4038
diff
changeset
|
6259 |
|
4184
bc2b88eea8c4
fix stray offset in resurrector, make resurrector use time
nemo
parents:
4182
diff
changeset
|
6260 |
graves := GearsNear(Gear^.X, Gear^.Y, gtGrave, Gear^.Radius); |
4024
1ffb84b3823d
Resurrector: respect modified Gear position for resurrection range circle
Tobias Neumann <mail@tobias-neumann.eu>
parents:
4023
diff
changeset
|
6261 |
|
7335 | 6262 |
if graves.size = 0 then |
4044
de7170e51cc6
Check for collision with surfaces above when levitating hog, use more typical drawing syntax for the resurrector wep, restore typical indentation
nemo
parents:
4038
diff
changeset
|
6263 |
begin |
7053 | 6264 |
StopSoundChan(Gear^.SoundChannel); |
3975
3f605cca9215
Resurrector weapon: do not make it end turn, add description,
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3971
diff
changeset
|
6265 |
Gear^.Timer := 250; |
3f605cca9215
Resurrector weapon: do not make it end turn, add description,
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3971
diff
changeset
|
6266 |
Gear^.doStep := @doStepIdle; |
3f605cca9215
Resurrector weapon: do not make it end turn, add description,
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3971
diff
changeset
|
6267 |
exit; |
4044
de7170e51cc6
Check for collision with surfaces above when levitating hog, use more typical drawing syntax for the resurrector wep, restore typical indentation
nemo
parents:
4038
diff
changeset
|
6268 |
end; |
de7170e51cc6
Check for collision with surfaces above when levitating hog, use more typical drawing syntax for the resurrector wep, restore typical indentation
nemo
parents:
4038
diff
changeset
|
6269 |
|
6131 | 6270 |
if ((Gear^.Message and gmAttack) <> 0) and (hh^.Gear^.Health > 0) and (TurnTimeLeft > 0) then |
4044
de7170e51cc6
Check for collision with surfaces above when levitating hog, use more typical drawing syntax for the resurrector wep, restore typical indentation
nemo
parents:
4038
diff
changeset
|
6271 |
begin |
7721 | 6272 |
if LongInt(graves.size) <= Gear^.Tag then Gear^.Tag:= 0; |
3963
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6273 |
dec(hh^.Gear^.Health); |
4017
048bcb8c72ae
Kill off hog immediately on using up health, use more common formatting, call render less often
nemo
parents:
4005
diff
changeset
|
6274 |
if (hh^.Gear^.Health = 0) and (hh^.Gear^.Damage = 0) then |
048bcb8c72ae
Kill off hog immediately on using up health, use more common formatting, call render less often
nemo
parents:
4005
diff
changeset
|
6275 |
hh^.Gear^.Damage:= 1; |
048bcb8c72ae
Kill off hog immediately on using up health, use more common formatting, call render less often
nemo
parents:
4005
diff
changeset
|
6276 |
RenderHealth(hh^); |
7399 | 6277 |
RecountTeamHealth(hh^.Team); |
7335 | 6278 |
inc(graves.ar^[Gear^.Tag]^.Health); |
4265
039b08012887
distribute health evenly amongst graves instead of randomly - avoid situation where a grave stays dead
nemo
parents:
4262
diff
changeset
|
6279 |
inc(Gear^.Tag) |
8795 | 6280 |
end |
6281 |
else |
|
4044
de7170e51cc6
Check for collision with surfaces above when levitating hog, use more typical drawing syntax for the resurrector wep, restore typical indentation
nemo
parents:
4038
diff
changeset
|
6282 |
begin |
3963
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6283 |
// now really resurrect the hogs with the hp saved in the graves |
7335 | 6284 |
for i:= 0 to graves.size - 1 do |
6285 |
if graves.ar^[i]^.Health > 0 then |
|
4044
de7170e51cc6
Check for collision with surfaces above when levitating hog, use more typical drawing syntax for the resurrector wep, restore typical indentation
nemo
parents:
4038
diff
changeset
|
6286 |
begin |
11203 | 6287 |
resgear := AddGear(hwRound(graves.ar^[i]^.X), hwRound(graves.ar^[i]^.Y), gtHedgehog, gstWait, _0, _0, 0,graves.ar^[i]^.Pos); |
7335 | 6288 |
resgear^.Hedgehog := graves.ar^[i]^.Hedgehog; |
6289 |
resgear^.Health := graves.ar^[i]^.Health; |
|
6290 |
PHedgehog(graves.ar^[i]^.Hedgehog)^.Gear := resgear; |
|
7394 | 6291 |
graves.ar^[i]^.Message:= graves.ar^[i]^.Message or gmDestroy; |
7399 | 6292 |
graves.ar^[i]^.Active:= true; |
4372 | 6293 |
RenderHealth(resgear^.Hedgehog^); |
6294 |
RecountTeamHealth(resgear^.Hedgehog^.Team); |
|
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:
7007
diff
changeset
|
6295 |
resgear^.Hedgehog^.Effects[heResurrected]:= 1; |
14419
87562a68c41f
Fix some King Mode bugs causing minions not always being properly killed
Wuzzy <Wuzzy2@mail.ru>
parents:
14379
diff
changeset
|
6296 |
if resgear^.Hedgehog^.King then |
87562a68c41f
Fix some King Mode bugs causing minions not always being properly killed
Wuzzy <Wuzzy2@mail.ru>
parents:
14379
diff
changeset
|
6297 |
resgear^.Hedgehog^.Team^.hasKing:= true; |
13760
b1177e9c9ee9
Fix player rankings getting confused if a clan was revived
Wuzzy <Wuzzy2@mail.ru>
parents:
13739
diff
changeset
|
6298 |
{ Reviving a hog implies its clan is now alive, too. } |
b1177e9c9ee9
Fix player rankings getting confused if a clan was revived
Wuzzy <Wuzzy2@mail.ru>
parents:
13739
diff
changeset
|
6299 |
resgear^.Hedgehog^.Team^.Clan^.DeathLogged:= false; |
14637
4638aa2ea8f2
Update clan passive status when team died / got resurrected
Wuzzy <Wuzzy2@mail.ru>
parents:
14595
diff
changeset
|
6300 |
if (not resgear^.Hedgehog^.Team^.Passive) then |
4638aa2ea8f2
Update clan passive status when team died / got resurrected
Wuzzy <Wuzzy2@mail.ru>
parents:
14595
diff
changeset
|
6301 |
resgear^.Hedgehog^.Team^.Clan^.Passive:= false; |
12169
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12120
diff
changeset
|
6302 |
s:= ansistring(resgear^.Hedgehog^.Name); |
13642
3d14950641a4
Refactor text color variable names, export 2 color values to Lua
Wuzzy <Wuzzy2@mail.ru>
parents:
13640
diff
changeset
|
6303 |
AddCaption(FormatA(GetEventString(eidResurrected), s), capcolDefault, capgrpMessage); |
4874 | 6304 |
// only make hat-less hedgehogs look like zombies, preserve existing hats |
7394 | 6305 |
|
4372 | 6306 |
if resgear^.Hedgehog^.Hat = 'NoHat' then |
7754 | 6307 |
LoadHedgehogHat(resgear^.Hedgehog^, 'Reserved/Zombie'); |
4044
de7170e51cc6
Check for collision with surfaces above when levitating hog, use more typical drawing syntax for the resurrector wep, restore typical indentation
nemo
parents:
4038
diff
changeset
|
6308 |
end; |
4023
8de77872ef21
Resurrector: Levitate hog + show cross
Tobias Neumann <mail@tobias-neumann.eu>
parents:
4021
diff
changeset
|
6309 |
|
15716
2a69c6693fbb
Fix hog sometimes not falling after using resurrector
Wuzzy <Wuzzy2@mail.ru>
parents:
15699
diff
changeset
|
6310 |
hh^.Gear^.dY := -cLittle; |
4045 | 6311 |
hh^.Gear^.dX := _0; |
4044
de7170e51cc6
Check for collision with surfaces above when levitating hog, use more typical drawing syntax for the resurrector wep, restore typical indentation
nemo
parents:
4038
diff
changeset
|
6312 |
doStepHedgehogMoving(hh^.Gear); |
7053 | 6313 |
StopSoundChan(Gear^.SoundChannel); |
3963
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6314 |
Gear^.Timer := 250; |
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6315 |
Gear^.doStep := @doStepIdle; |
4044
de7170e51cc6
Check for collision with surfaces above when levitating hog, use more typical drawing syntax for the resurrector wep, restore typical indentation
nemo
parents:
4038
diff
changeset
|
6316 |
end |
3963
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6317 |
end; |
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6318 |
|
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6319 |
procedure doStepResurrector(Gear: PGear); |
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6320 |
var |
7335 | 6321 |
graves: PGearArrayS; |
8730
b39f433f8ab4
at vatten's request. make resurrection always resurrect at least 1 hp out of kindness to noobs who can't be bothered to read tooltips
nemo
parents:
8727
diff
changeset
|
6322 |
hh: PHedgehog; |
3963
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6323 |
i: LongInt; |
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6324 |
begin |
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6325 |
AllInactive := false; |
4044
de7170e51cc6
Check for collision with surfaces above when levitating hog, use more typical drawing syntax for the resurrector wep, restore typical indentation
nemo
parents:
4038
diff
changeset
|
6326 |
graves := GearsNear(Gear^.X, Gear^.Y, gtGrave, Gear^.Radius); |
de7170e51cc6
Check for collision with surfaces above when levitating hog, use more typical drawing syntax for the resurrector wep, restore typical indentation
nemo
parents:
4038
diff
changeset
|
6327 |
|
7335 | 6328 |
if graves.size > 0 then |
6329 |
begin |
|
8730
b39f433f8ab4
at vatten's request. make resurrection always resurrect at least 1 hp out of kindness to noobs who can't be bothered to read tooltips
nemo
parents:
8727
diff
changeset
|
6330 |
hh := Gear^.Hedgehog; |
7335 | 6331 |
for i:= 0 to graves.size - 1 do |
4044
de7170e51cc6
Check for collision with surfaces above when levitating hog, use more typical drawing syntax for the resurrector wep, restore typical indentation
nemo
parents:
4038
diff
changeset
|
6332 |
begin |
7335 | 6333 |
PHedgehog(graves.ar^[i]^.Hedgehog)^.Gear := nil; |
6334 |
graves.ar^[i]^.Health := 0; |
|
4044
de7170e51cc6
Check for collision with surfaces above when levitating hog, use more typical drawing syntax for the resurrector wep, restore typical indentation
nemo
parents:
4038
diff
changeset
|
6335 |
end; |
3963
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6336 |
Gear^.doStep := @doStepResurrectorWork; |
8730
b39f433f8ab4
at vatten's request. make resurrection always resurrect at least 1 hp out of kindness to noobs who can't be bothered to read tooltips
nemo
parents:
8727
diff
changeset
|
6337 |
if ((Gear^.Message and gmAttack) <> 0) and (hh^.Gear^.Health > 0) and (TurnTimeLeft > 0) then |
b39f433f8ab4
at vatten's request. make resurrection always resurrect at least 1 hp out of kindness to noobs who can't be bothered to read tooltips
nemo
parents:
8727
diff
changeset
|
6338 |
begin |
b39f433f8ab4
at vatten's request. make resurrection always resurrect at least 1 hp out of kindness to noobs who can't be bothered to read tooltips
nemo
parents:
8727
diff
changeset
|
6339 |
if LongInt(graves.size) <= Gear^.Tag then Gear^.Tag:= 0; |
b39f433f8ab4
at vatten's request. make resurrection always resurrect at least 1 hp out of kindness to noobs who can't be bothered to read tooltips
nemo
parents:
8727
diff
changeset
|
6340 |
dec(hh^.Gear^.Health); |
b39f433f8ab4
at vatten's request. make resurrection always resurrect at least 1 hp out of kindness to noobs who can't be bothered to read tooltips
nemo
parents:
8727
diff
changeset
|
6341 |
if (hh^.Gear^.Health = 0) and (hh^.Gear^.Damage = 0) then |
b39f433f8ab4
at vatten's request. make resurrection always resurrect at least 1 hp out of kindness to noobs who can't be bothered to read tooltips
nemo
parents:
8727
diff
changeset
|
6342 |
hh^.Gear^.Damage:= 1; |
b39f433f8ab4
at vatten's request. make resurrection always resurrect at least 1 hp out of kindness to noobs who can't be bothered to read tooltips
nemo
parents:
8727
diff
changeset
|
6343 |
RenderHealth(hh^); |
b39f433f8ab4
at vatten's request. make resurrection always resurrect at least 1 hp out of kindness to noobs who can't be bothered to read tooltips
nemo
parents:
8727
diff
changeset
|
6344 |
RecountTeamHealth(hh^.Team); |
b39f433f8ab4
at vatten's request. make resurrection always resurrect at least 1 hp out of kindness to noobs who can't be bothered to read tooltips
nemo
parents:
8727
diff
changeset
|
6345 |
inc(graves.ar^[Gear^.Tag]^.Health); |
b39f433f8ab4
at vatten's request. make resurrection always resurrect at least 1 hp out of kindness to noobs who can't be bothered to read tooltips
nemo
parents:
8727
diff
changeset
|
6346 |
inc(Gear^.Tag) |
8795 | 6347 |
end |
6348 |
end |
|
6349 |
else |
|
4044
de7170e51cc6
Check for collision with surfaces above when levitating hog, use more typical drawing syntax for the resurrector wep, restore typical indentation
nemo
parents:
4038
diff
changeset
|
6350 |
begin |
7053 | 6351 |
StopSoundChan(Gear^.SoundChannel); |
3963
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6352 |
Gear^.Timer := 250; |
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6353 |
Gear^.doStep := @doStepIdle; |
4044
de7170e51cc6
Check for collision with surfaces above when levitating hog, use more typical drawing syntax for the resurrector wep, restore typical indentation
nemo
parents:
4038
diff
changeset
|
6354 |
end |
3963
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6355 |
end; |
6090d2a2472e
New Weapon: Resurrector (TODO: ammo icon + sprites)
Tobias Neumann <mail@tobias-neumann.eu>
parents:
3959
diff
changeset
|
6356 |
|
4293
d79ffcdd77df
makes drill attack drills weaker and not affected by wind
Henek
parents:
4282
diff
changeset
|
6357 |
//////////////////////////////////////////////////////////////////////////////// |
4313
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6358 |
procedure doStepNapalmBomb(Gear: PGear); |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6359 |
var |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6360 |
i, gX, gY: LongInt; |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6361 |
dX, dY: hwFloat; |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6362 |
begin |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6363 |
AllInactive := false; |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6364 |
doStepFallingGear(Gear); |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6365 |
if (Gear^.Timer > 0) and ((Gear^.State and gstCollision) <> 0) then |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6366 |
begin |
4837
2ea0a152c319
Pass PHedgehog instead of PGear to stats. Fixes crash.
unc0rr
parents:
4824
diff
changeset
|
6367 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), 10, Gear^.Hedgehog, EXPLAutoSound); |
4313
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6368 |
gX := hwRound(Gear^.X); |
8795 | 6369 |
gY := hwRound(Gear^.Y); |
4313
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6370 |
for i:= 0 to 10 do |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6371 |
begin |
7001 | 6372 |
dX := AngleCos(i * 2) * ((_0_1*(i div 5))) * (GetRandomf + _1); |
6373 |
dY := AngleSin(i * 8) * _0_5 * (GetRandomf + _1); |
|
4313
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6374 |
AddGear(gX, gY, gtFlame, 0, dX, dY, 0); |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6375 |
AddGear(gX, gY, gtFlame, 0, dX, -dY, 0); |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6376 |
AddGear(gX, gY, gtFlame, 0, -dX, dY, 0); |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6377 |
AddGear(gX, gY, gtFlame, 0, -dX, -dY, 0); |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6378 |
end; |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6379 |
DeleteGear(Gear); |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6380 |
exit |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6381 |
end; |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6382 |
if (Gear^.Timer = 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6383 |
begin |
4837
2ea0a152c319
Pass PHedgehog instead of PGear to stats. Fixes crash.
unc0rr
parents:
4824
diff
changeset
|
6384 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), 10, Gear^.Hedgehog, EXPLAutoSound); |
4313
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6385 |
for i:= -19 to 19 do |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6386 |
FollowGear := AddGear(hwRound(Gear^.X) + i div 3, hwRound(Gear^.Y), gtFlame, 0, _0_001 * i, _0, 0); |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6387 |
DeleteGear(Gear); |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6388 |
exit |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6389 |
end; |
4313
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6390 |
if (GameTicks and $3F) = 0 then |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6391 |
AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtSmokeTrace); |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6392 |
dec(Gear^.Timer) |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6393 |
end; |
0690067bc5ff
made napalm use napalmbombs instead of just dropping fire
Henek
parents:
4301
diff
changeset
|
6394 |
|
5313
5e18eaef65d0
now scripts can create unique crates: dummy (empty) crates and booby traps. scripts can also set health crate values
Henek
parents:
5298
diff
changeset
|
6395 |
//////////////////////////////////////////////////////////////////////////////// |
5706 | 6396 |
(* |
8795 | 6397 |
TARDIS needs |
5706 | 6398 |
Warp in. Pos = 1 |
6399 |
Pause. Pos = 2 |
|
6400 |
Hide gear (TARDIS hedgehog was nil) |
|
6401 |
Warp out. Pos = 3 |
|
6402 |
... idle active for some time period ... Pos = 4 |
|
6403 |
Warp in. Pos = 1 |
|
6404 |
Pause. Pos = 2 |
|
6405 |
Restore gear (TARDIS hedgehog was not nil) |
|
6406 |
Warp out. Pos = 3 |
|
6407 |
*) |
|
6408 |
||
6409 |
procedure doStepTardisWarp(Gear: PGear); |
|
6410 |
var HH: PHedgehog; |
|
6411 |
i,j,cnt: LongWord; |
|
12169
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12120
diff
changeset
|
6412 |
s: ansistring; |
5197
9fa96377a69c
Basic TARDIS implementation. Still needs proper animation, and probably a check to force reappearance on death of last team mate
nemo
parents:
5186
diff
changeset
|
6413 |
begin |
5706 | 6414 |
HH:= Gear^.Hedgehog; |
15243
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6415 |
if Gear^.Tag = 0 then |
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6416 |
begin |
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6417 |
if HH^.Gear <> nil then |
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6418 |
begin |
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6419 |
if (HH^.Gear^.Damage <> 0) or (HH^.Gear^.Health = 0) or |
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6420 |
((HH^.Gear^.State and (gstMoving or gstHHDeath or gstHHGone or gstDrowning)) <> 0) then |
15274
000d3262244c
Fix multiple timeboxes spawning when hog moves before timebox arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15267
diff
changeset
|
6421 |
begin |
15243
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6422 |
Gear^.Tag:= 1; |
15274
000d3262244c
Fix multiple timeboxes spawning when hog moves before timebox arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15267
diff
changeset
|
6423 |
HH^.Gear^.State:= HH^.Gear^.State and (not gstAttacking); |
000d3262244c
Fix multiple timeboxes spawning when hog moves before timebox arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15267
diff
changeset
|
6424 |
HH^.Gear^.Message:= HH^.Gear^.Message and (not gmAttack); |
000d3262244c
Fix multiple timeboxes spawning when hog moves before timebox arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15267
diff
changeset
|
6425 |
AfterAttack; |
000d3262244c
Fix multiple timeboxes spawning when hog moves before timebox arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15267
diff
changeset
|
6426 |
end; |
15243
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6427 |
end |
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6428 |
else if HH^.GearHidden = nil then |
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6429 |
Gear^.Tag:= 1; |
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6430 |
if (Gear^.Tag = 1) and (Gear = CurAmmoGear) then |
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6431 |
CurAmmoGear:= nil; |
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6432 |
end; |
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6433 |
|
5706 | 6434 |
if Gear^.Pos = 2 then |
6435 |
begin |
|
7053 | 6436 |
StopSoundChan(Gear^.SoundChannel); |
12672
c98179b00740
Fix short sound breakdown shortly after using time box
Wuzzy <almikes@aol.com>
parents:
12656
diff
changeset
|
6437 |
Gear^.SoundChannel:= -1; |
5706 | 6438 |
if (Gear^.Timer = 0) then |
5197
9fa96377a69c
Basic TARDIS implementation. Still needs proper animation, and probably a check to force reappearance on death of last team mate
nemo
parents:
5186
diff
changeset
|
6439 |
begin |
5715
59a8dd33f274
Restore gear ASAP, add denied sound for illegal activation without wasting ammo.
nemo
parents:
5710
diff
changeset
|
6440 |
if (HH^.Gear <> nil) and (HH^.Gear^.State and gstInvisible = 0) then |
5197
9fa96377a69c
Basic TARDIS implementation. Still needs proper animation, and probably a check to force reappearance on death of last team mate
nemo
parents:
5186
diff
changeset
|
6441 |
begin |
15243
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6442 |
if Gear^.Tag = 0 then |
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6443 |
AfterAttack; |
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6444 |
if Gear = CurAmmoGear then |
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6445 |
CurAmmoGear:= nil; |
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6446 |
if Gear^.Tag = 0 then |
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6447 |
HideHog(HH); |
5706 | 6448 |
end |
14593
34e810295d08
Remove a bunch of dead out-commented code
Wuzzy <Wuzzy2@mail.ru>
parents:
14591
diff
changeset
|
6449 |
else if (HH^.GearHidden <> nil) then |
12169
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12120
diff
changeset
|
6450 |
begin |
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12120
diff
changeset
|
6451 |
RestoreHog(HH); |
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12120
diff
changeset
|
6452 |
s:= ansistring(HH^.Name); |
13642
3d14950641a4
Refactor text color variable names, export 2 color values to Lua
Wuzzy <Wuzzy2@mail.ru>
parents:
13640
diff
changeset
|
6453 |
AddCaption(FormatA(GetEventString(eidTimeTravelEnd), s), capcolDefault, capgrpMessage) |
12169
869cf5f34700
More ticker messages: Sick, king died, resurrect, time box return, timeout, kamikaze
Wuzzy <almikes@aol.com>
parents:
12120
diff
changeset
|
6454 |
end |
5706 | 6455 |
end; |
6456 |
||
5971 | 6457 |
inc(Gear^.Timer); |
5706 | 6458 |
if (Gear^.Timer > 2000) and ((GameTicks mod 2000) = 1000) then |
6459 |
begin |
|
5728 | 6460 |
Gear^.SoundChannel := LoopSound(sndTardis); |
6461 |
Gear^.Pos:= 3 |
|
6462 |
end |
|
5706 | 6463 |
end; |
6464 |
||
6131 | 6465 |
if (Gear^.Pos = 1) and (GameTicks and $1F = 0) and (Gear^.Power < 255) then |
5935 | 6466 |
begin |
6467 |
inc(Gear^.Power); |
|
8795 | 6468 |
if (Gear^.Power = 172) and (HH^.Gear <> nil) and |
15243
deaa316af414
TimeBox: Fix buggy behaviour if hog took damage or died before time box arrived
Wuzzy <Wuzzy2@mail.ru>
parents:
15242
diff
changeset
|
6469 |
(Gear^.Tag = 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6470 |
with HH^.Gear^ do |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6471 |
begin |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6472 |
State:= State or gstAnimation; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6473 |
Tag:= 2; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6474 |
Timer:= 0; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6475 |
Pos:= 0 |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6476 |
end |
5935 | 6477 |
end; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6478 |
if (Gear^.Pos = 3) and (GameTicks and $1F = 0) and (Gear^.Power > 0) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6479 |
dec(Gear^.Power); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6480 |
if (Gear^.Pos = 1) and (Gear^.Power = 255) and ((GameTicks mod 2000) = 1000) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6481 |
Gear^.Pos:= 2; |
5706 | 6482 |
if (Gear^.Pos = 3) and (Gear^.Power = 0) then |
6483 |
begin |
|
7053 | 6484 |
StopSoundChan(Gear^.SoundChannel); |
12672
c98179b00740
Fix short sound breakdown shortly after using time box
Wuzzy <almikes@aol.com>
parents:
12656
diff
changeset
|
6485 |
Gear^.SoundChannel:= -1; |
5710 | 6486 |
if HH^.GearHidden = nil then |
6487 |
begin |
|
6488 |
DeleteGear(Gear); |
|
6489 |
exit |
|
6490 |
end; |
|
5706 | 6491 |
Gear^.Pos:= 4; |
6492 |
// This condition might need tweaking |
|
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:
8628
diff
changeset
|
6493 |
Gear^.Timer:= GetRandom(cHedgehogTurnTime*TeamsCount)+cHedgehogTurnTime |
5706 | 6494 |
end; |
6495 |
||
6496 |
if (Gear^.Pos = 4) then |
|
6497 |
begin |
|
6498 |
cnt:= 0; |
|
6499 |
for j:= 0 to Pred(HH^.Team^.Clan^.TeamsNumber) do |
|
9470 | 6500 |
with HH^.Team^.Clan^.Teams[j]^ do |
6501 |
for i:= 0 to Pred(HedgehogsNumber) do |
|
6502 |
if (Hedgehogs[i].Gear <> nil) |
|
6503 |
and ((Hedgehogs[i].Gear^.State and gstDrowning) = 0) |
|
6504 |
and (Hedgehogs[i].Gear^.Health > Hedgehogs[i].Gear^.Damage) then |
|
6505 |
inc(cnt); |
|
5706 | 6506 |
if (cnt = 0) or SuddenDeathDmg or (Gear^.Timer = 0) then |
5197
9fa96377a69c
Basic TARDIS implementation. Still needs proper animation, and probably a check to force reappearance on death of last team mate
nemo
parents:
5186
diff
changeset
|
6507 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6556
diff
changeset
|
6508 |
if HH^.GearHidden <> nil then |
15763
8997e212be4c
Fix hog not returning from TimeBox when all land was destroyed
Wuzzy <Wuzzy2@mail.ru>
parents:
15753
diff
changeset
|
6509 |
FindPlace(HH^.GearHidden, false, 0, LAND_WIDTH, true, false); |
8795 | 6510 |
|
6131 | 6511 |
if HH^.GearHidden <> nil then |
5197
9fa96377a69c
Basic TARDIS implementation. Still needs proper animation, and probably a check to force reappearance on death of last team mate
nemo
parents:
5186
diff
changeset
|
6512 |
begin |
5738 | 6513 |
Gear^.X:= HH^.GearHidden^.X; |
6514 |
Gear^.Y:= HH^.GearHidden^.Y; |
|
7092
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7068
diff
changeset
|
6515 |
end; |
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7068
diff
changeset
|
6516 |
Gear^.Timer:= 0; |
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7068
diff
changeset
|
6517 |
|
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7068
diff
changeset
|
6518 |
if (HH^.GearHidden <> nil) and (cnt = 0) then // do an emergency jump back in this case. the team needs you! |
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7068
diff
changeset
|
6519 |
begin |
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7068
diff
changeset
|
6520 |
AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtExplosion); |
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7068
diff
changeset
|
6521 |
Gear^.Pos:= 2; |
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7068
diff
changeset
|
6522 |
Gear^.Power:= 255; |
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7068
diff
changeset
|
6523 |
end |
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7068
diff
changeset
|
6524 |
else begin |
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7068
diff
changeset
|
6525 |
Gear^.SoundChannel := LoopSound(sndTardis); |
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7068
diff
changeset
|
6526 |
Gear^.Pos:= 1; |
c9ca770fd7fc
Add an emergency return to the timebox in the case of death of rest of team. Also add a small visual effect to AI survival
nemo
parents:
7068
diff
changeset
|
6527 |
Gear^.Power:= 0; |
5706 | 6528 |
end |
5197
9fa96377a69c
Basic TARDIS implementation. Still needs proper animation, and probably a check to force reappearance on death of last team mate
nemo
parents:
5186
diff
changeset
|
6529 |
end |
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:
8628
diff
changeset
|
6530 |
else if (CurrentHedgehog^.Team^.Clan = Gear^.Hedgehog^.Team^.Clan) then dec(Gear^.Timer) |
5706 | 6531 |
end; |
6532 |
||
6533 |
end; |
|
6534 |
||
6535 |
procedure doStepTardis(Gear: PGear); |
|
12712
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12700
diff
changeset
|
6536 |
var HH: PHedgehog; |
5706 | 6537 |
begin |
6538 |
HH:= Gear^.Hedgehog; |
|
12712
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12700
diff
changeset
|
6539 |
if (not CanUseTardis(HH^.Gear)) then |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12700
diff
changeset
|
6540 |
begin |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12700
diff
changeset
|
6541 |
HH^.Gear^.Message := HH^.Gear^.Message and (not gmAttack); |
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12700
diff
changeset
|
6542 |
HH^.Gear^.State:= HH^.Gear^.State and (not gstAttacking); |
5715
59a8dd33f274
Restore gear ASAP, add denied sound for illegal activation without wasting ammo.
nemo
parents:
5710
diff
changeset
|
6543 |
PlaySound(sndDenied); |
12712
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12700
diff
changeset
|
6544 |
DeleteGear(Gear); |
5706 | 6545 |
exit |
12712
31f7e0a31736
AI player checks if it can use tardis before selecting it
Wuzzy <almikes@aol.com>
parents:
12700
diff
changeset
|
6546 |
end; |
5728 | 6547 |
Gear^.SoundChannel := LoopSound(sndTardis); |
5706 | 6548 |
Gear^.doStep:= @doStepTardisWarp |
5197
9fa96377a69c
Basic TARDIS implementation. Still needs proper animation, and probably a check to force reappearance on death of last team mate
nemo
parents:
5186
diff
changeset
|
6549 |
end; |
5313
5e18eaef65d0
now scripts can create unique crates: dummy (empty) crates and booby traps. scripts can also set health crate values
Henek
parents:
5298
diff
changeset
|
6550 |
|
5e18eaef65d0
now scripts can create unique crates: dummy (empty) crates and booby traps. scripts can also set health crate values
Henek
parents:
5298
diff
changeset
|
6551 |
//////////////////////////////////////////////////////////////////////////////// |
5e18eaef65d0
now scripts can create unique crates: dummy (empty) crates and booby traps. scripts can also set health crate values
Henek
parents:
5298
diff
changeset
|
6552 |
|
7007 | 6553 |
(* |
14593
34e810295d08
Remove a bunch of dead out-commented code
Wuzzy <Wuzzy2@mail.ru>
parents:
14591
diff
changeset
|
6554 |
The ice gun has the following effects: |
34e810295d08
Remove a bunch of dead out-commented code
Wuzzy <Wuzzy2@mail.ru>
parents:
14591
diff
changeset
|
6555 |
A "ray" like a deagle is projected out from the gun. |
8795 | 6556 |
All these effects assume the ray's angle is not changed and that the target type was unchanged over a number of ticks. This is a simplifying assumption for "gun was applying freezing effect to the same target". |
7007 | 6557 |
* When fired at water a layer of ice textured land is added above the water. |
8751
4609823efc94
More flagging of Land values. Also use less than for tests of non-terrain, instead of "and $FF00 = 0". Saves a couple of ops, which actually matters a small amount in a few places.
nemo
parents:
8744
diff
changeset
|
6558 |
* When fired at non-ice land (land and lfLandMask and not lfIce) the land is overlaid with a thin layer of ice textured land around that point (say, 1 or 2px into land, 1px above). For attractiveness, a slope would probably be needed. |
11191 | 6559 |
* When fired at a hog (land and $00FF <> 0), while the hog is targetted, the hog's state is set to frozen. |
6560 |
As long as the gun is on the hog, a frozen hog sprite creeps up from the feet to the head. |
|
6561 |
If the effect is interrupted before reaching the top, the freezing state is cleared. |
|
6562 |
A frozen hog will animate differently. |
|
14593
34e810295d08
Remove a bunch of dead out-commented code
Wuzzy <Wuzzy2@mail.ru>
parents:
14591
diff
changeset
|
6563 |
Frozen hogs take less damage and are harder to push. |
11191 | 6564 |
This might make freezing potentially useful for friendlies in a bad position. |
6565 |
A frozen hog stays frozen for a certain number of turns. |
|
6566 |
Each turn the frozen overlay becomes fainter, until it fades and the hog animates normally again. |
|
7007 | 6567 |
*) |
8548 | 6568 |
|
6569 |
||
6570 |
procedure updateFuel(Gear: PGear); |
|
8795 | 6571 |
var |
8548 | 6572 |
t:LongInt; |
6573 |
begin |
|
6574 |
t:= Gear^.Health div 10; |
|
15381
c117e17b90bc
flag some of the renderstringtex which are taking up a ton of processing time with --stats-only and pas2c
nemo
parents:
15354
diff
changeset
|
6575 |
if (not cOnlyStats) and (t <> Gear^.Damage) and ((GameTicks and $3F) = 0) then |
8548 | 6576 |
begin |
6577 |
Gear^.Damage:= t; |
|
10634
35d059bd0932
Use FreeAndNil across the board. Even if we are immediately assigning after, probably avoids accidental mistakes. Also free neglected owner tex on shutdown, and delete hog gears using the normal deletion procedure if for any reason they still exist (EndGame call?).
nemo
parents:
10597
diff
changeset
|
6578 |
FreeAndNilTexture(Gear^.Tex); |
13898 | 6579 |
Gear^.Tex := RenderStringTex(FormatA(trmsg[sidFuel], ansistring(inttostr(t))), |
13640
cb0191394133
Use full string for sidFuel and avoid string concatenation
Wuzzy <Wuzzy2@mail.ru>
parents:
13624
diff
changeset
|
6580 |
cWhiteColor, fntSmall) |
8548 | 6581 |
end; |
8934
a4ec39eac0be
So. This should fix ammo delays being off on a team that is resurrected later in the game, even up freezing delays a bit, prevent an infinite loop in freezing, and reduces fuel burn when adjusting freezer to one-fourth.
nemo
parents:
8924
diff
changeset
|
6582 |
if Gear^.Message and (gmUp or gmDown) <> 0 then |
a4ec39eac0be
So. This should fix ammo delays being off on a team that is resurrected later in the game, even up freezing delays a bit, prevent an infinite loop in freezing, and reduces fuel burn when adjusting freezer to one-fourth.
nemo
parents:
8924
diff
changeset
|
6583 |
begin |
14005 | 6584 |
if (Gear^.Tag <> 2) then |
6585 |
begin |
|
6586 |
StopSoundChan(Gear^.SoundChannel); |
|
6587 |
Gear^.SoundChannel:= LoopSound(sndIceBeamIdle); |
|
6588 |
Gear^.Tag:= 2; |
|
6589 |
end; |
|
8934
a4ec39eac0be
So. This should fix ammo delays being off on a team that is resurrected later in the game, even up freezing delays a bit, prevent an infinite loop in freezing, and reduces fuel burn when adjusting freezer to one-fourth.
nemo
parents:
8924
diff
changeset
|
6590 |
if GameTicks mod 40 = 0 then dec(Gear^.Health) |
a4ec39eac0be
So. This should fix ammo delays being off on a team that is resurrected later in the game, even up freezing delays a bit, prevent an infinite loop in freezing, and reduces fuel burn when adjusting freezer to one-fourth.
nemo
parents:
8924
diff
changeset
|
6591 |
end |
10015 | 6592 |
else |
9072 | 6593 |
begin |
14005 | 6594 |
if (Gear^.Tag <> 1) then |
6595 |
begin |
|
6596 |
StopSoundChan(Gear^.SoundChannel); |
|
6597 |
Gear^.SoundChannel:= LoopSound(sndIceBeam); |
|
6598 |
Gear^.Tag:= 1; |
|
6599 |
end; |
|
9072 | 6600 |
if GameTicks mod 10 = 0 then dec(Gear^.Health) |
6601 |
end |
|
8548 | 6602 |
end; |
6603 |
||
6604 |
||
6605 |
procedure updateTarget(Gear:PGear; newX, newY:HWFloat); |
|
6606 |
begin |
|
6607 |
with Gear^ do |
|
6608 |
begin |
|
6609 |
dX:= newX; |
|
6610 |
dY:= newY; |
|
6611 |
Pos:= 0; |
|
6612 |
Target.X:= NoPointX; |
|
6613 |
LastDamage:= nil; |
|
6614 |
X:= Hedgehog^.Gear^.X; |
|
6615 |
Y:= Hedgehog^.Gear^.Y; |
|
6616 |
end; |
|
6617 |
end; |
|
6618 |
||
7007 | 6619 |
procedure doStepIceGun(Gear: PGear); |
9145 | 6620 |
const iceWaitCollision = 0; |
6621 |
const iceCollideWithGround = 1; |
|
6622 |
const iceCollideWithWater = 5; |
|
6623 |
const groundFreezingTime = 1000; |
|
8601
7668f92734b8
Make refactoring. Remove DrawIce function
Urbertar@gmail.com
parents:
8599
diff
changeset
|
6624 |
const iceRadius = 32; |
8602 | 6625 |
const iceHeight = 40; |
7716 | 6626 |
var |
9026
f6074540bab2
Add gstFrozen state to mines/gears in range on frozen land creation, and set the mines to dud state. gstFrozen does nothing yet. Visually or otherwise.
nemo
parents:
8993
diff
changeset
|
6627 |
HHGear, iter: PGear; |
8783
f1231a48fc48
Remove some duplicating code from uLandGraphics.pas
Urbertar
parents:
8773
diff
changeset
|
6628 |
landRect: TSDL_Rect; |
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:
7007
diff
changeset
|
6629 |
ndX, ndY: hwFloat; |
9137
d987230b85ed
fixed all engine compilation hints and notes (that I could see)
sheepluva
parents:
9080
diff
changeset
|
6630 |
i, t, gX, gY: LongInt; |
7335 | 6631 |
hogs: PGearArrayS; |
8934
a4ec39eac0be
So. This should fix ammo delays being off on a team that is resurrected later in the game, even up freezing delays a bit, prevent an infinite loop in freezing, and reduces fuel burn when adjusting freezer to one-fourth.
nemo
parents:
8924
diff
changeset
|
6632 |
vg: PVisualGear; |
7007 | 6633 |
begin |
7093 | 6634 |
HHGear := Gear^.Hedgehog^.Gear; |
9356 | 6635 |
if (Gear^.Message and gmAttack <> 0) or (Gear^.Health = 0) or (HHGear = nil) or ((HHGear^.State and gstHHDriven) = 0) or (HHGear^.dX.QWordValue > 4294967) then |
7093 | 6636 |
begin |
9072 | 6637 |
StopSoundChan(Gear^.SoundChannel); |
7093 | 6638 |
DeleteGear(Gear); |
6639 |
AfterAttack; |
|
6640 |
exit |
|
8934
a4ec39eac0be
So. This should fix ammo delays being off on a team that is resurrected later in the game, even up freezing delays a bit, prevent an infinite loop in freezing, and reduces fuel burn when adjusting freezer to one-fourth.
nemo
parents:
8924
diff
changeset
|
6641 |
end; |
a4ec39eac0be
So. This should fix ammo delays being off on a team that is resurrected later in the game, even up freezing delays a bit, prevent an infinite loop in freezing, and reduces fuel burn when adjusting freezer to one-fourth.
nemo
parents:
8924
diff
changeset
|
6642 |
updateFuel(Gear); |
14591
0da43a3d5500
Properly stop freezeray at bounce edge (instead of restarting the ray over and over again)
Wuzzy <Wuzzy2@mail.ru>
parents:
14589
diff
changeset
|
6643 |
if (WorldEdge <> weBounce) then |
0da43a3d5500
Properly stop freezeray at bounce edge (instead of restarting the ray over and over again)
Wuzzy <Wuzzy2@mail.ru>
parents:
14589
diff
changeset
|
6644 |
if WorldWrap(Gear) and (WorldEdge = weWrap) and (Gear^.Target.X = NoPointX) then |
0da43a3d5500
Properly stop freezeray at bounce edge (instead of restarting the ray over and over again)
Wuzzy <Wuzzy2@mail.ru>
parents:
14589
diff
changeset
|
6645 |
// Use FlightTime to count number of times the gear has world-wrapped |
0da43a3d5500
Properly stop freezeray at bounce edge (instead of restarting the ray over and over again)
Wuzzy <Wuzzy2@mail.ru>
parents:
14589
diff
changeset
|
6646 |
inc(Gear^.FlightTime); |
8548 | 6647 |
|
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:
7007
diff
changeset
|
6648 |
with Gear^ do |
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:
7007
diff
changeset
|
6649 |
begin |
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:
7007
diff
changeset
|
6650 |
HedgehogChAngle(HHGear); |
7093 | 6651 |
ndX:= SignAs(AngleSin(HHGear^.Angle), HHGear^.dX) * _4; |
6652 |
ndY:= -AngleCos(HHGear^.Angle) * _4; |
|
13995
4d0c80f7aa32
Fix freezer ray extending with low fuel usage when firing straight up/down while holding up/down key
Wuzzy <Wuzzy2@mail.ru>
parents:
13977
diff
changeset
|
6653 |
if (ndX <> dX) or (ndY <> dY) or (Gear^.Message and (gmUp or gmDown) <> 0) or |
13399 | 6654 |
(((Target.X <> NoPointX) and (Target.X and LAND_WIDTH_MASK = 0) and |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
6655 |
(Target.Y and LAND_HEIGHT_MASK = 0) and ((LandGet(Target.Y, Target.X) = 0)) and |
14591
0da43a3d5500
Properly stop freezeray at bounce edge (instead of restarting the ray over and over again)
Wuzzy <Wuzzy2@mail.ru>
parents:
14589
diff
changeset
|
6656 |
(not CheckCoordInWater(Target.X, Target.Y))) and (CheckGearNear(gtAirMine, int2hwFloat(Target.X),int2hwFloat(Target.Y), Gear^.Radius*3, Gear^.Radius*3) = nil) and |
0da43a3d5500
Properly stop freezeray at bounce edge (instead of restarting the ray over and over again)
Wuzzy <Wuzzy2@mail.ru>
parents:
14589
diff
changeset
|
6657 |
(not ((WorldEdge = weBounce) and ((Target.X > rightX) or (Target.X < leftX))))) then |
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:
7007
diff
changeset
|
6658 |
begin |
8812
fdac638c6f9a
oups. reused same variable twice. my bad. You know, maybe somewhere in uVariables or uGearsList should define what we use Gear variables for in each gear
nemo
parents:
8795
diff
changeset
|
6659 |
updateTarget(Gear, ndX, ndY); |
fdac638c6f9a
oups. reused same variable twice. my bad. You know, maybe somewhere in uVariables or uGearsList should define what we use Gear variables for in each gear
nemo
parents:
8795
diff
changeset
|
6660 |
Timer := iceWaitCollision; |
13572
a71e6856ffab
Fix freeze ray not working through wrap world edge; add DrawLineWrapped
Wuzzy <Wuzzy2@mail.ru>
parents:
13566
diff
changeset
|
6661 |
FlightTime := 0; |
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:
7007
diff
changeset
|
6662 |
end |
14581
45c6c12c12e2
Fix wrong ice beam angle if it goes diagonally up out of map thru world wrap (bug 718)
Wuzzy <Wuzzy2@mail.ru>
parents:
14578
diff
changeset
|
6663 |
// Extend ice beam, unless it is far outside he map boundaries |
45c6c12c12e2
Fix wrong ice beam angle if it goes diagonally up out of map thru world wrap (bug 718)
Wuzzy <Wuzzy2@mail.ru>
parents:
14578
diff
changeset
|
6664 |
else if (not ((hwRound(X + dX) > max(LAND_WIDTH,4096)*2) or |
45c6c12c12e2
Fix wrong ice beam angle if it goes diagonally up out of map thru world wrap (bug 718)
Wuzzy <Wuzzy2@mail.ru>
parents:
14578
diff
changeset
|
6665 |
(hwRound(X + dX) < -max(LAND_WIDTH,4096)*2) or |
45c6c12c12e2
Fix wrong ice beam angle if it goes diagonally up out of map thru world wrap (bug 718)
Wuzzy <Wuzzy2@mail.ru>
parents:
14578
diff
changeset
|
6666 |
(hwRound(Y + dY) < -max(LAND_HEIGHT,4096)*2) or |
45c6c12c12e2
Fix wrong ice beam angle if it goes diagonally up out of map thru world wrap (bug 718)
Wuzzy <Wuzzy2@mail.ru>
parents:
14578
diff
changeset
|
6667 |
(hwRound(Y + dY) > max(LAND_HEIGHT,4096)+512))) then |
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:
7007
diff
changeset
|
6668 |
begin |
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:
7007
diff
changeset
|
6669 |
X:= X + dX; |
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:
7007
diff
changeset
|
6670 |
Y:= Y + dY; |
7093 | 6671 |
gX:= hwRound(X); |
8795 | 6672 |
gY:= hwRound(Y); |
8812
fdac638c6f9a
oups. reused same variable twice. my bad. You know, maybe somewhere in uVariables or uGearsList should define what we use Gear variables for in each gear
nemo
parents:
8795
diff
changeset
|
6673 |
if Target.X = NoPointX then t:= hwRound(hwSqr(X-HHGear^.X)+hwSqr(Y-HHGear^.Y)); |
8548 | 6674 |
|
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:
7007
diff
changeset
|
6675 |
if Target.X <> NoPointX then |
8812
fdac638c6f9a
oups. reused same variable twice. my bad. You know, maybe somewhere in uVariables or uGearsList should define what we use Gear variables for in each gear
nemo
parents:
8795
diff
changeset
|
6676 |
begin |
9041
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6677 |
CheckCollision(Gear); |
13404
8ce83caec236
Make mine active/hunting glow a bit more obvious. Add frozen sprite, increase ice beam mine "hit" radius a bit
nemo
parents:
13403
diff
changeset
|
6678 |
if ((State and gstCollision) <> 0) or (CheckGearNear(gtAirMine, int2hwFloat(Target.X),int2hwFloat(Target.Y), Gear^.Radius*4, Gear^.Radius*4) <> nil) then |
8548 | 6679 |
begin |
8812
fdac638c6f9a
oups. reused same variable twice. my bad. You know, maybe somewhere in uVariables or uGearsList should define what we use Gear variables for in each gear
nemo
parents:
8795
diff
changeset
|
6680 |
if Timer = iceWaitCollision then |
fdac638c6f9a
oups. reused same variable twice. my bad. You know, maybe somewhere in uVariables or uGearsList should define what we use Gear variables for in each gear
nemo
parents:
8795
diff
changeset
|
6681 |
begin |
fdac638c6f9a
oups. reused same variable twice. my bad. You know, maybe somewhere in uVariables or uGearsList should define what we use Gear variables for in each gear
nemo
parents:
8795
diff
changeset
|
6682 |
Timer := iceCollideWithGround; |
fdac638c6f9a
oups. reused same variable twice. my bad. You know, maybe somewhere in uVariables or uGearsList should define what we use Gear variables for in each gear
nemo
parents:
8795
diff
changeset
|
6683 |
Power := GameTicks; |
fdac638c6f9a
oups. reused same variable twice. my bad. You know, maybe somewhere in uVariables or uGearsList should define what we use Gear variables for in each gear
nemo
parents:
8795
diff
changeset
|
6684 |
end |
8795 | 6685 |
end |
10582 | 6686 |
else if CheckCoordInWater(Target.X, Target.Y) or |
6687 |
((Target.X and LAND_WIDTH_MASK = 0) and |
|
6688 |
(Target.Y and LAND_HEIGHT_MASK = 0) and |
|
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
6689 |
(LandGet(Target.Y, Target.X) = lfIce) and |
10582 | 6690 |
((Target.Y+iceHeight+5 > cWaterLine) or |
6691 |
((WorldEdge = weSea) and |
|
14303
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14225
diff
changeset
|
6692 |
((Target.X+iceHeight+5 > rightX) or |
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14225
diff
changeset
|
6693 |
(Target.X-iceHeight-5 < leftX)))) |
10582 | 6694 |
) then |
8602 | 6695 |
begin |
8812
fdac638c6f9a
oups. reused same variable twice. my bad. You know, maybe somewhere in uVariables or uGearsList should define what we use Gear variables for in each gear
nemo
parents:
8795
diff
changeset
|
6696 |
if Timer = iceWaitCollision then |
8602 | 6697 |
begin |
8812
fdac638c6f9a
oups. reused same variable twice. my bad. You know, maybe somewhere in uVariables or uGearsList should define what we use Gear variables for in each gear
nemo
parents:
8795
diff
changeset
|
6698 |
Timer := iceCollideWithWater; |
8795 | 6699 |
Power := GameTicks; |
8602 | 6700 |
end; |
8548 | 6701 |
end; |
6702 |
||
7098
f8c453ade379
Minor tweaks to freezer, mostly to simplify current state to laptop
nemo
parents:
7093
diff
changeset
|
6703 |
if (abs(gX-Target.X) < 2) and (abs(gY-Target.Y) < 2) then |
8602 | 6704 |
begin |
7098
f8c453ade379
Minor tweaks to freezer, mostly to simplify current state to laptop
nemo
parents:
7093
diff
changeset
|
6705 |
X:= HHGear^.X; |
f8c453ade379
Minor tweaks to freezer, mostly to simplify current state to laptop
nemo
parents:
7093
diff
changeset
|
6706 |
Y:= HHGear^.Y |
8602 | 6707 |
end; |
8548 | 6708 |
|
8812
fdac638c6f9a
oups. reused same variable twice. my bad. You know, maybe somewhere in uVariables or uGearsList should define what we use Gear variables for in each gear
nemo
parents:
8795
diff
changeset
|
6709 |
if (Timer = iceCollideWithGround) and ((GameTicks - Power) > groundFreezingTime) then |
8795 | 6710 |
begin |
9885
34e8880f1f0a
missed this in the merge. rejected the uGearsHandlersMess changes thinking they were all desyncing, but there was the function rename from uLandGraphics
nemo
parents:
9881
diff
changeset
|
6711 |
FillRoundInLandFT(target.x, target.y, iceRadius, icePixel); |
8783
f1231a48fc48
Remove some duplicating code from uLandGraphics.pas
Urbertar
parents:
8773
diff
changeset
|
6712 |
landRect.x := min(max(target.x - iceRadius, 0), LAND_WIDTH - 1); |
f1231a48fc48
Remove some duplicating code from uLandGraphics.pas
Urbertar
parents:
8773
diff
changeset
|
6713 |
landRect.y := min(max(target.y - iceRadius, 0), LAND_HEIGHT - 1); |
f1231a48fc48
Remove some duplicating code from uLandGraphics.pas
Urbertar
parents:
8773
diff
changeset
|
6714 |
landRect.w := min(2*iceRadius, LAND_WIDTH - landRect.x - 1); |
f1231a48fc48
Remove some duplicating code from uLandGraphics.pas
Urbertar
parents:
8773
diff
changeset
|
6715 |
landRect.h := min(2*iceRadius, LAND_HEIGHT - landRect.y - 1); |
f1231a48fc48
Remove some duplicating code from uLandGraphics.pas
Urbertar
parents:
8773
diff
changeset
|
6716 |
UpdateLandTexture(landRect.x, landRect.w, landRect.y, landRect.h, true); |
10015 | 6717 |
|
9026
f6074540bab2
Add gstFrozen state to mines/gears in range on frozen land creation, and set the mines to dud state. gstFrozen does nothing yet. Visually or otherwise.
nemo
parents:
8993
diff
changeset
|
6718 |
// Freeze nearby mines/explosives/cases too |
f6074540bab2
Add gstFrozen state to mines/gears in range on frozen land creation, and set the mines to dud state. gstFrozen does nothing yet. Visually or otherwise.
nemo
parents:
8993
diff
changeset
|
6719 |
iter := GearsList; |
f6074540bab2
Add gstFrozen state to mines/gears in range on frozen land creation, and set the mines to dud state. gstFrozen does nothing yet. Visually or otherwise.
nemo
parents:
8993
diff
changeset
|
6720 |
while iter <> nil do |
f6074540bab2
Add gstFrozen state to mines/gears in range on frozen land creation, and set the mines to dud state. gstFrozen does nothing yet. Visually or otherwise.
nemo
parents:
8993
diff
changeset
|
6721 |
begin |
9041
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6722 |
if (iter^.State and gstFrozen = 0) and |
13399 | 6723 |
((iter^.Kind = gtExplosives) or (iter^.Kind = gtAirMine) or (iter^.Kind = gtCase) or (iter^.Kind = gtMine) or (iter^.Kind = gtSMine)) and |
14368
1dcc37b6913e
Fix freezer failing to freeze gears with negative coordinate
Wuzzy <Wuzzy2@mail.ru>
parents:
14367
diff
changeset
|
6724 |
(abs(hwRound(iter^.X) - target.x) + abs(hwRound(iter^.Y) - target.y) + 2 < 2 * iceRadius) |
9954 | 6725 |
and (Distance(iter^.X - int2hwFloat(target.x), iter^.Y - int2hwFloat(target.y)) < int2hwFloat(iceRadius * 2)) then |
9026
f6074540bab2
Add gstFrozen state to mines/gears in range on frozen land creation, and set the mines to dud state. gstFrozen does nothing yet. Visually or otherwise.
nemo
parents:
8993
diff
changeset
|
6726 |
begin |
9041
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6727 |
for t:= 0 to 5 do |
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6728 |
begin |
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6729 |
vg:= AddVisualGear(hwRound(iter^.X)+random(4)-8, hwRound(iter^.Y)+random(8), vgtDust, 1); |
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6730 |
if vg <> nil then |
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6731 |
begin |
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6732 |
i:= random(100) + 155; |
9145 | 6733 |
vg^.Tint:= (i shl 24) or (i shl 16) or ($FF shl 8) or (random(200) + 55); |
9041
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6734 |
vg^.Angle:= random(360); |
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6735 |
vg^.dx:= 0.001 * random(80); |
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6736 |
vg^.dy:= 0.001 * random(80) |
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6737 |
end |
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6738 |
end; |
9077
e8d9d94c122f
Waddaya think. Add it for iced up water and mines/cases/explosives
nemo
parents:
9076
diff
changeset
|
6739 |
PlaySound(sndHogFreeze); |
9026
f6074540bab2
Add gstFrozen state to mines/gears in range on frozen land creation, and set the mines to dud state. gstFrozen does nothing yet. Visually or otherwise.
nemo
parents:
8993
diff
changeset
|
6740 |
if iter^.Kind = gtMine then // dud mine block |
f6074540bab2
Add gstFrozen state to mines/gears in range on frozen land creation, and set the mines to dud state. gstFrozen does nothing yet. Visually or otherwise.
nemo
parents:
8993
diff
changeset
|
6741 |
begin |
9251 | 6742 |
iter^.State:= iter^.State or gstFrozen; |
9041
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6743 |
vg:= AddVisualGear(hwRound(iter^.X) - 4 + Random(8), hwRound(iter^.Y) - 4 - Random(4), vgtSmoke); |
9026
f6074540bab2
Add gstFrozen state to mines/gears in range on frozen land creation, and set the mines to dud state. gstFrozen does nothing yet. Visually or otherwise.
nemo
parents:
8993
diff
changeset
|
6744 |
if vg <> nil then |
f6074540bab2
Add gstFrozen state to mines/gears in range on frozen land creation, and set the mines to dud state. gstFrozen does nothing yet. Visually or otherwise.
nemo
parents:
8993
diff
changeset
|
6745 |
vg^.Scale:= 0.5; |
f6074540bab2
Add gstFrozen state to mines/gears in range on frozen land creation, and set the mines to dud state. gstFrozen does nothing yet. Visually or otherwise.
nemo
parents:
8993
diff
changeset
|
6746 |
PlaySound(sndVaporize); |
9041
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6747 |
iter^.Health := 0; |
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6748 |
iter^.Damage := 0; |
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6749 |
iter^.State := iter^.State and (not gstAttacking) |
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6750 |
end |
12300
6486a012987e
Make sticky mines fall off the map when frozen
Wuzzy <almikes@aol.com>
parents:
12299
diff
changeset
|
6751 |
else if iter^.Kind = gtSMine then // disabe sticky mine and drop it into the water |
12299
6b25d117a904
Freezer allows to freeze sticky mines (currently only disables them)
Wuzzy <almikes@aol.com>
parents:
12292
diff
changeset
|
6752 |
begin |
6b25d117a904
Freezer allows to freeze sticky mines (currently only disables them)
Wuzzy <almikes@aol.com>
parents:
12292
diff
changeset
|
6753 |
iter^.State:= iter^.State or gstFrozen; |
12300
6486a012987e
Make sticky mines fall off the map when frozen
Wuzzy <almikes@aol.com>
parents:
12299
diff
changeset
|
6754 |
iter^.CollisionMask:= 0; |
12299
6b25d117a904
Freezer allows to freeze sticky mines (currently only disables them)
Wuzzy <almikes@aol.com>
parents:
12292
diff
changeset
|
6755 |
vg:= AddVisualGear(hwRound(iter^.X) - 2 + Random(4), hwRound(iter^.Y) - 2 - Random(2), vgtSmoke); |
6b25d117a904
Freezer allows to freeze sticky mines (currently only disables them)
Wuzzy <almikes@aol.com>
parents:
12292
diff
changeset
|
6756 |
if vg <> nil then |
6b25d117a904
Freezer allows to freeze sticky mines (currently only disables them)
Wuzzy <almikes@aol.com>
parents:
12292
diff
changeset
|
6757 |
vg^.Scale:= 0.4; |
6b25d117a904
Freezer allows to freeze sticky mines (currently only disables them)
Wuzzy <almikes@aol.com>
parents:
12292
diff
changeset
|
6758 |
PlaySound(sndVaporize); |
6b25d117a904
Freezer allows to freeze sticky mines (currently only disables them)
Wuzzy <almikes@aol.com>
parents:
12292
diff
changeset
|
6759 |
iter^.State := iter^.State and (not gstAttacking) |
6b25d117a904
Freezer allows to freeze sticky mines (currently only disables them)
Wuzzy <almikes@aol.com>
parents:
12292
diff
changeset
|
6760 |
end |
9041
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6761 |
else if iter^.Kind = gtCase then |
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6762 |
begin |
aefe46d64dd9
Make frozen crates uncollectable, add some tinting to frozen items. Suggestions needed for what should happen to explosives
nemo
parents:
9026
diff
changeset
|
6763 |
DeleteCI(iter); |
9251 | 6764 |
iter^.State:= iter^.State or gstFrozen; |
9291
15f7bb217b66
Make add/delete consistent (this has bugged me for so long)
nemo
parents:
9289
diff
changeset
|
6765 |
AddCI(iter) |
9026
f6074540bab2
Add gstFrozen state to mines/gears in range on frozen land creation, and set the mines to dud state. gstFrozen does nothing yet. Visually or otherwise.
nemo
parents:
8993
diff
changeset
|
6766 |
end |
13399 | 6767 |
else if iter^.Kind = gtAirMine then |
6768 |
begin |
|
14362
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6769 |
iter^.Damage:= 0; |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6770 |
iter^.State:= iter^.State or gstFrozen; |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
6771 |
if (hwRound(iter^.X) < RightX-16) and (hwRound(iter^.X) > LeftX+16) and |
14362
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6772 |
(hwRound(iter^.Y) > topY+16) and (hwRound(iter^.Y) < LAND_HEIGHT-16) then |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6773 |
begin |
14367
22c91ac48d38
Do not call AddCI when air mine is frozen without creating land
Wuzzy <Wuzzy2@mail.ru>
parents:
14365
diff
changeset
|
6774 |
AddCI(iter); |
14577 | 6775 |
iter^.X:= int2hwFloat(min(RightX-16,max(hwRound(iter^.X), LeftX+16))); |
6776 |
iter^.Y:= int2hwFloat(min(LAND_HEIGHT-16,max(hwRound(iter^.Y),TopY+16))); |
|
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
6777 |
ForcePlaceOnLand(hwRound(iter^.X)-16, hwRound(iter^.Y)-16, sprFrozenAirMine, 0, lfIce, $FFFFFFFF, false, false, false); |
14362
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6778 |
iter^.State:= iter^.State or gstInvisible |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6779 |
end |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6780 |
else |
14577 | 6781 |
begin |
6782 |
updateTarget(Gear, ndX, ndY); |
|
6783 |
FlightTime := 0; |
|
6784 |
Timer := iceWaitCollision; |
|
6785 |
Power := GameTicks; |
|
14379
1f87c7c2b151
Make sad Pas2C happy again (add missing parenthesis around a "not")
Wuzzy <Wuzzy2@mail.ru>
parents:
14368
diff
changeset
|
6786 |
iter^.State:= iter^.State and (not gstNoGravity) |
14577 | 6787 |
end |
13399 | 6788 |
end |
9045
6561c42399d3
sheepluva suggestion for frozen barrel behaviour. untested.
nemo
parents:
9043
diff
changeset
|
6789 |
else // gtExplosives |
9251 | 6790 |
begin |
6791 |
iter^.State:= iter^.State or gstFrozen; |
|
9045
6561c42399d3
sheepluva suggestion for frozen barrel behaviour. untested.
nemo
parents:
9043
diff
changeset
|
6792 |
iter^.Health:= iter^.Health + cBarrelHealth |
9251 | 6793 |
end |
9026
f6074540bab2
Add gstFrozen state to mines/gears in range on frozen land creation, and set the mines to dud state. gstFrozen does nothing yet. Visually or otherwise.
nemo
parents:
8993
diff
changeset
|
6794 |
end; |
f6074540bab2
Add gstFrozen state to mines/gears in range on frozen land creation, and set the mines to dud state. gstFrozen does nothing yet. Visually or otherwise.
nemo
parents:
8993
diff
changeset
|
6795 |
iter:= iter^.NextGear |
f6074540bab2
Add gstFrozen state to mines/gears in range on frozen land creation, and set the mines to dud state. gstFrozen does nothing yet. Visually or otherwise.
nemo
parents:
8993
diff
changeset
|
6796 |
end; |
8795 | 6797 |
|
8783
f1231a48fc48
Remove some duplicating code from uLandGraphics.pas
Urbertar
parents:
8773
diff
changeset
|
6798 |
SetAllHHToActive; |
8812
fdac638c6f9a
oups. reused same variable twice. my bad. You know, maybe somewhere in uVariables or uGearsList should define what we use Gear variables for in each gear
nemo
parents:
8795
diff
changeset
|
6799 |
Timer := iceWaitCollision; |
14362
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6800 |
Power:= GameTicks |
8602 | 6801 |
end; |
6802 |
||
10411 | 6803 |
if (Timer = iceCollideWithWater) and ((GameTicks - Power) > groundFreezingTime div 2) then |
8795 | 6804 |
begin |
9077
e8d9d94c122f
Waddaya think. Add it for iced up water and mines/cases/explosives
nemo
parents:
9076
diff
changeset
|
6805 |
PlaySound(sndHogFreeze); |
10582 | 6806 |
if CheckCoordInWater(Target.X, Target.Y) then |
6807 |
DrawIceBreak(Target.X, Target.Y, iceRadius, iceHeight) |
|
6808 |
else if Target.Y+iceHeight+5 > cWaterLine then |
|
6809 |
DrawIceBreak(Target.X, Target.Y+iceHeight+5, iceRadius, iceHeight) |
|
14303
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14225
diff
changeset
|
6810 |
else if Target.X+iceHeight+5 > rightX then |
10582 | 6811 |
DrawIceBreak(Target.X+iceHeight+5, Target.Y, iceRadius, iceHeight) |
6812 |
else |
|
6813 |
DrawIceBreak(Target.X-iceHeight-5, Target.Y, iceRadius, iceHeight); |
|
8795 | 6814 |
SetAllHHToActive; |
8812
fdac638c6f9a
oups. reused same variable twice. my bad. You know, maybe somewhere in uVariables or uGearsList should define what we use Gear variables for in each gear
nemo
parents:
8795
diff
changeset
|
6815 |
Timer := iceWaitCollision; |
8602 | 6816 |
end; |
7128
574b385ce7df
Minor freezer changes, allow snow to accumulate on indestructible terrain too.
nemo
parents:
7101
diff
changeset
|
6817 |
// freeze nearby hogs |
8560 | 6818 |
hogs := GearsNear(int2hwFloat(Target.X), int2hwFloat(Target.Y), gtHedgehog, Gear^.Radius*2); |
7335 | 6819 |
if hogs.size > 0 then |
6820 |
for i:= 0 to hogs.size - 1 do |
|
6821 |
if hogs.ar^[i] <> HHGear then |
|
8795 | 6822 |
if GameTicks mod 5 = 0 then |
8563
4d9d8287e601
Trying to improve rendering, sliding and thawing. Messing around w/ making fire thaw faster.
nemo
parents:
8560
diff
changeset
|
6823 |
begin |
8565 | 6824 |
hogs.ar^[i]^.Active:= true; |
6825 |
if hogs.ar^[i]^.Hedgehog^.Effects[heFrozen] < 256 then |
|
6826 |
hogs.ar^[i]^.Hedgehog^.Effects[heFrozen] := hogs.ar^[i]^.Hedgehog^.Effects[heFrozen] + 1 |
|
6827 |
else if hogs.ar^[i]^.Hedgehog^.Effects[heFrozen] = 256 then |
|
9073 | 6828 |
begin |
9059 | 6829 |
hogs.ar^[i]^.Hedgehog^.Effects[heFrozen]:= 200000-1;//cHedgehogTurnTime + cReadyDelay |
9073 | 6830 |
PlaySound(sndHogFreeze); |
6831 |
end; |
|
8563
4d9d8287e601
Trying to improve rendering, sliding and thawing. Messing around w/ making fire thaw faster.
nemo
parents:
8560
diff
changeset
|
6832 |
end; |
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:
7007
diff
changeset
|
6833 |
inc(Pos) |
8812
fdac638c6f9a
oups. reused same variable twice. my bad. You know, maybe somewhere in uVariables or uGearsList should define what we use Gear variables for in each gear
nemo
parents:
8795
diff
changeset
|
6834 |
end |
10582 | 6835 |
else if (t > 400) and (CheckCoordInWater(gX, gY) or |
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:
7007
diff
changeset
|
6836 |
(((gX and LAND_WIDTH_MASK = 0) and (gY and LAND_HEIGHT_MASK = 0)) |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
6837 |
and (LandGet(gY, gX) <> 0))) then |
8812
fdac638c6f9a
oups. reused same variable twice. my bad. You know, maybe somewhere in uVariables or uGearsList should define what we use Gear variables for in each gear
nemo
parents:
8795
diff
changeset
|
6838 |
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:
7007
diff
changeset
|
6839 |
Target.X:= gX; |
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:
7007
diff
changeset
|
6840 |
Target.Y:= gY; |
7093 | 6841 |
X:= HHGear^.X; |
6842 |
Y:= HHGear^.Y |
|
13399 | 6843 |
end |
14591
0da43a3d5500
Properly stop freezeray at bounce edge (instead of restarting the ray over and over again)
Wuzzy <Wuzzy2@mail.ru>
parents:
14589
diff
changeset
|
6844 |
else if (WorldEdge = weBounce) and ((gX > rightX) or (gX < leftX)) then |
0da43a3d5500
Properly stop freezeray at bounce edge (instead of restarting the ray over and over again)
Wuzzy <Wuzzy2@mail.ru>
parents:
14589
diff
changeset
|
6845 |
begin |
0da43a3d5500
Properly stop freezeray at bounce edge (instead of restarting the ray over and over again)
Wuzzy <Wuzzy2@mail.ru>
parents:
14589
diff
changeset
|
6846 |
Target.X:= gX; |
0da43a3d5500
Properly stop freezeray at bounce edge (instead of restarting the ray over and over again)
Wuzzy <Wuzzy2@mail.ru>
parents:
14589
diff
changeset
|
6847 |
Target.Y:= gY; |
0da43a3d5500
Properly stop freezeray at bounce edge (instead of restarting the ray over and over again)
Wuzzy <Wuzzy2@mail.ru>
parents:
14589
diff
changeset
|
6848 |
X:= HHGear^.X; |
0da43a3d5500
Properly stop freezeray at bounce edge (instead of restarting the ray over and over again)
Wuzzy <Wuzzy2@mail.ru>
parents:
14589
diff
changeset
|
6849 |
Y:= HHGear^.Y |
0da43a3d5500
Properly stop freezeray at bounce edge (instead of restarting the ray over and over again)
Wuzzy <Wuzzy2@mail.ru>
parents:
14589
diff
changeset
|
6850 |
end |
14362
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6851 |
else |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6852 |
begin |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6853 |
iter:= CheckGearNear(Gear, gtAirMine, Gear^.Radius*2, Gear^.Radius*2); |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6854 |
if (iter <> nil) and (iter^.State <> gstFrozen) then |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6855 |
begin |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6856 |
Target.X:= gX; |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6857 |
Target.Y:= gY; |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6858 |
X:= HHGear^.X; |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6859 |
Y:= HHGear^.Y |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
6860 |
end |
14362
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6861 |
end; |
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:
7007
diff
changeset
|
6862 |
end |
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:
7007
diff
changeset
|
6863 |
end; |
7007 | 6864 |
end; |
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:
7370
diff
changeset
|
6865 |
|
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:
7370
diff
changeset
|
6866 |
procedure doStepAddAmmo(Gear: PGear); |
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:
7370
diff
changeset
|
6867 |
var a: TAmmoType; |
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:
7370
diff
changeset
|
6868 |
gi: PGear; |
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:
7370
diff
changeset
|
6869 |
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:
7370
diff
changeset
|
6870 |
if Gear^.Timer > 0 then dec(Gear^.Timer) |
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:
7370
diff
changeset
|
6871 |
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:
7370
diff
changeset
|
6872 |
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:
7370
diff
changeset
|
6873 |
CheckSum:= CheckSum xor GameTicks; |
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:
7370
diff
changeset
|
6874 |
gi := GearsList; |
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:
7370
diff
changeset
|
6875 |
while gi <> nil do |
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:
7370
diff
changeset
|
6876 |
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:
7370
diff
changeset
|
6877 |
with gi^ do CheckSum:= CheckSum xor X.round xor X.frac xor dX.round xor dX.frac xor Y.round xor Y.frac xor dY.round xor dY.frac; |
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:
7370
diff
changeset
|
6878 |
AddRandomness(CheckSum); |
13214
9c81e34f1933
gtGenericFaller: Use Tag=1 to allow gtGenericFaller to be displaced randomly. Otherwise it is left alone
Wuzzy <Wuzzy2@mail.ru>
parents:
13161
diff
changeset
|
6879 |
if (gi^.Kind = gtGenericFaller) and (gi^.Tag = 1) then |
9c81e34f1933
gtGenericFaller: Use Tag=1 to allow gtGenericFaller to be displaced randomly. Otherwise it is left alone
Wuzzy <Wuzzy2@mail.ru>
parents:
13161
diff
changeset
|
6880 |
gi^.State:= gi^.State and (not gstTmpFlag); |
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:
7370
diff
changeset
|
6881 |
gi := gi^.NextGear |
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:
7370
diff
changeset
|
6882 |
end; |
13285 | 6883 |
if Gear^.Pos = posCaseUtility then |
6884 |
a:= GetUtility(Gear^.Hedgehog) |
|
6885 |
else a:= GetAmmo(Gear^.Hedgehog); |
|
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:
7370
diff
changeset
|
6886 |
AddPickup(Gear^.Hedgehog^, a, 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:
7370
diff
changeset
|
6887 |
DeleteGear(Gear) |
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:
7370
diff
changeset
|
6888 |
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:
7370
diff
changeset
|
6889 |
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:
7370
diff
changeset
|
6890 |
|
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:
7370
diff
changeset
|
6891 |
procedure doStepGenericFaller(Gear: PGear); |
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:
7370
diff
changeset
|
6892 |
begin |
7406
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7400
diff
changeset
|
6893 |
if Gear^.Timer < $FFFFFFFF then |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7400
diff
changeset
|
6894 |
if Gear^.Timer > 0 then |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7400
diff
changeset
|
6895 |
dec(Gear^.Timer) |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7400
diff
changeset
|
6896 |
else |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7400
diff
changeset
|
6897 |
begin |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7400
diff
changeset
|
6898 |
DeleteGear(Gear); |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7400
diff
changeset
|
6899 |
exit |
1fe2c821f9bf
Try avoiding spamming the log by retaining the gears. untested.
nemo
parents:
7400
diff
changeset
|
6900 |
end; |
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
|
6901 |
if (Gear^.State and gstTmpFlag <> 0) or (GameTicks and $7 = 0) then |
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
|
6902 |
begin |
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
|
6903 |
doStepFallingGear(Gear); |
14307 | 6904 |
if (Gear^.Tag = 1) and (GameTicks and $FF = 0) and (hwRound(Gear^.X) < leftX) or (hwRound(Gear^.X) > rightX) or (hwRound(Gear^.Y) < topY) then |
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
|
6905 |
begin |
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
|
6906 |
Gear^.X:= int2hwFloat(GetRandom(rightX-leftX)+leftX); |
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
|
6907 |
Gear^.Y:= int2hwFloat(GetRandom(LAND_HEIGHT-topY)+topY); |
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
|
6908 |
Gear^.dX:= _90-(GetRandomf*_360); |
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
|
6909 |
Gear^.dY:= _90-(GetRandomf*_360) |
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
|
6910 |
end; |
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
|
6911 |
end |
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:
7370
diff
changeset
|
6912 |
end; |
13605
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6913 |
|
13872
f01798038c2e
Rename amDuck and related symbols to amCreeper, gtCreeper, etc.
Wuzzy <Wuzzy2@mail.ru>
parents:
13871
diff
changeset
|
6914 |
// TODO: Finish creeper implementation |
7627 | 6915 |
procedure doStepCreeper(Gear: PGear); |
13605
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6916 |
var i,t,targDist,tmpDist: LongWord; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6917 |
targ, tmpG: PGear; |
13613
d6b79a080a3e
Remove unused variables of creeper handler
Wuzzy <Wuzzy2@mail.ru>
parents:
13610
diff
changeset
|
6918 |
tX, tY: hwFloat; |
13605
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6919 |
vg: PVisualGear; |
7627 | 6920 |
begin |
14362
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6921 |
targ:= nil; |
13605
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6922 |
doStepFallingGear(Gear); |
14362
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6923 |
if (Gear^.State and gstFrozen) <> 0 then |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6924 |
begin |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6925 |
if Gear^.Damage > 0 then |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6926 |
begin |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6927 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6928 |
DeleteGear(Gear) |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6929 |
end; |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6930 |
exit |
d5317635f368
fix bounds check, make out of bounds air mines fall since there's no land to check them into
nemo
parents:
14361
diff
changeset
|
6931 |
end; |
13605
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6932 |
if (TurnTimeLeft = 0) or (Gear^.Angle = 0) or (Gear^.Hedgehog = nil) or (Gear^.Hedgehog^.Gear = nil) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6933 |
begin |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6934 |
Gear^.Hedgehog:= nil; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6935 |
targ:= nil; |
7627 | 6936 |
end |
13605
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6937 |
else if Gear^.Hedgehog <> nil then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6938 |
targ:= Gear^.Hedgehog^.Gear; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6939 |
if (targ <> nil) and ((GameTicks and $3F) = 0) and (TestCollisionYKick(Gear, 1) <> 0) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6940 |
begin |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6941 |
vg:= AddVisualGear(hwRound(Gear^.X), hwRound(Gear^.Y), vgtSmokeWhite); |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6942 |
if vg <> nil then vg^.Tint:= $FF0000FF; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6943 |
if (Gear^.X < targ^.X) then // need to add collision checks to avoid walking off edges or getting too close to obstacles where jumping is needed |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6944 |
if (WorldEdge = weWrap) and ((targ^.X - Gear^.X) > ((Gear^.X - int2hwFloat(LeftX)) + (int2hwFloat(RightX) - targ^.X))) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6945 |
Gear^.dX:= -cLittle |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6946 |
else |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6947 |
Gear^.dX:= cLittle |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6948 |
else if (Gear^.X > targ^.X) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6949 |
if (WorldEdge = weWrap) and ((Gear^.X - targ^.X) > ((targ^.X - int2hwFloat(LeftX)) + (int2hwFloat(RightX) - Gear^.X))) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6950 |
Gear^.dX:= cLittle |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6951 |
else |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6952 |
Gear^.dX:= -cLittle; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6953 |
if (GetRandom(30) = 0) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6954 |
begin |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6955 |
Gear^.dY := -_0_15; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6956 |
Gear^.dX:= SignAs(_0_15, Gear^.dX); |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6957 |
end; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6958 |
MakeHedgehogsStep(Gear); |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6959 |
end; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6960 |
if (TurnTimeLeft = 0) and ((Gear^.dX.QWordValue + Gear^.dY.QWordValue) > _0_02.QWordValue) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6961 |
AllInactive := false; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6962 |
|
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6963 |
if targ <> nil then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6964 |
begin |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6965 |
tX:=Gear^.X-targ^.X; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6966 |
tY:=Gear^.Y-targ^.Y; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6967 |
// allow escaping - should maybe flag this too |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
6968 |
if (GameTicks > Gear^.FlightTime+10000) or |
13605
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6969 |
((tX.Round+tY.Round > Gear^.Angle*6) and |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6970 |
(hwRound(hwSqr(tX) + hwSqr(tY)) > sqr(Gear^.Angle*6))) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6971 |
targ:= nil |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6972 |
end; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6973 |
|
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6974 |
// If in ready timer, or after turn, or in first 5 seconds of turn (really a window due to extra time utility) |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6975 |
// or mine is inactive due to lack of gsttmpflag or hunting is disabled due to seek radius of 0 |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6976 |
// then we aren't hunting |
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
6977 |
if (ReadyTimeLeft > 0) or (TurnTimeLeft = 0) or |
13605
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6978 |
((TurnTimeLeft < cHedgehogTurnTime) and (cHedgehogTurnTime-TurnTimeLeft < 5000)) or |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6979 |
(Gear^.State and gsttmpFlag = 0) or |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6980 |
(Gear^.Angle = 0) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6981 |
gear^.State:= gear^.State and (not gstChooseTarget) |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6982 |
else if |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6983 |
// todo, allow not finding new target, set timeout on target retention |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6984 |
(Gear^.State and gstAttacking = 0) and |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6985 |
((GameTicks and $FF) = 17) and |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6986 |
(GameTicks > Gear^.FlightTime) then // recheck hunted hog |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6987 |
begin |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6988 |
gear^.State:= gear^.State or gstChooseTarget; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6989 |
if targ <> nil then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6990 |
targDist:= Distance(Gear^.X-targ^.X,Gear^.Y-targ^.Y).Round |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6991 |
else targDist:= 0; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6992 |
for t:= 0 to Pred(TeamsCount) do |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6993 |
with TeamsArray[t]^ do |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6994 |
for i:= 0 to cMaxHHIndex do |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6995 |
if Hedgehogs[i].Gear <> nil then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6996 |
begin |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6997 |
tmpG:= Hedgehogs[i].Gear; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6998 |
tX:=Gear^.X-tmpG^.X; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
6999 |
tY:=Gear^.Y-tmpG^.Y; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7000 |
if (Gear^.Angle = $FFFFFFFF) or |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7001 |
((tX.Round+tY.Round < Gear^.Angle) and |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7002 |
(hwRound(hwSqr(tX) + hwSqr(tY)) < sqr(Gear^.Angle))) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7003 |
begin |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7004 |
if targ <> nil then tmpDist:= Distance(tX,tY).Round; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7005 |
if (targ = nil) or (tmpDist < targDist) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7006 |
begin |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7007 |
if targ = nil then targDist:= Distance(tX,tY).Round |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7008 |
else targDist:= tmpDist; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7009 |
Gear^.Hedgehog:= @Hedgehogs[i]; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7010 |
targ:= tmpG; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7011 |
end |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7012 |
end |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7013 |
end; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7014 |
if targ <> nil then Gear^.FlightTime:= GameTicks + 5000 |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7015 |
end; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7016 |
|
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7017 |
if ((Gear^.State and gsttmpFlag) <> 0) and (Gear^.Health <> 0) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7018 |
begin |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7019 |
if ((Gear^.State and gstAttacking) = 0) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7020 |
begin |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7021 |
if ((GameTicks and $1F) = 0) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7022 |
begin |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7023 |
if targ <> nil then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7024 |
begin |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7025 |
tX:=Gear^.X-targ^.X; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7026 |
tY:=Gear^.Y-targ^.Y; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7027 |
if (tX.Round+tY.Round < Gear^.Boom) and |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7028 |
(hwRound(hwSqr(tX) + hwSqr(tY)) < sqr(Gear^.Boom)) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7029 |
Gear^.State := Gear^.State or gstAttacking |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7030 |
end |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7031 |
else if (Gear^.Angle > 0) and (CheckGearNear(Gear, gtHedgehog, Gear^.Boom, Gear^.Boom) <> nil) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7032 |
Gear^.State := Gear^.State or gstAttacking |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7033 |
end |
7627 | 7034 |
end |
13605
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7035 |
else // gstAttacking <> 0 |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7036 |
begin |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7037 |
AllInactive := false; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7038 |
if (Gear^.Timer and $1FF) = 0 then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7039 |
PlaySound(sndVaporize); |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7040 |
if Gear^.Timer = 0 then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7041 |
begin |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7042 |
// recheck |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7043 |
if targ <> nil then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7044 |
begin |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7045 |
tX:=Gear^.X-targ^.X; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7046 |
tY:=Gear^.Y-targ^.Y; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7047 |
if (tX.Round+tY.Round < Gear^.Boom) and |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7048 |
(hwRound(hwSqr(tX) + hwSqr(tY)) < sqr(Gear^.Boom)) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7049 |
begin |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7050 |
Gear^.Hedgehog:= CurrentHedgehog; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7051 |
tmpG:= FollowGear; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7052 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7053 |
FollowGear:= tmpG; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7054 |
DeleteGear(Gear); |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7055 |
exit |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7056 |
end |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7057 |
end |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7058 |
else if (Gear^.Angle > 0) and (CheckGearNear(Gear, gtHedgehog, Gear^.Boom, Gear^.Boom) <> nil) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7059 |
begin |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7060 |
Gear^.Hedgehog:= CurrentHedgehog; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7061 |
doMakeExplosion(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Boom, Gear^.Hedgehog, EXPLAutoSound); |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7062 |
DeleteGear(Gear); |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7063 |
exit |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7064 |
end; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7065 |
Gear^.State:= Gear^.State and (not gstAttacking); |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7066 |
Gear^.Timer:= Gear^.WDTimer |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7067 |
end; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7068 |
if Gear^.Timer > 0 then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7069 |
dec(Gear^.Timer); |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7070 |
end |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7071 |
end |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7072 |
else // gsttmpFlag = 0 |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7073 |
if (TurnTimeLeft = 0) |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7074 |
or ((GameFlags and gfInfAttack <> 0) and (GameTicks > Gear^.FlightTime)) |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7075 |
or (CurrentHedgehog^.Gear = nil) then |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7076 |
begin |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7077 |
Gear^.FlightTime:= GameTicks; |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7078 |
Gear^.State := Gear^.State or gsttmpFlag |
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7079 |
end |
7627 | 7080 |
end; |
13605
422d6062620a
hijack the duck for an attempted resurrection of the creeper. initial pass.
nemo
parents:
13604
diff
changeset
|
7081 |
|
7730
2013733f9ca9
A bit more on the knife. Also add missing files to CMakeLists
nemo
parents:
7729
diff
changeset
|
7082 |
//////////////////////////////////////////////////////////////////////////////// |
7754 | 7083 |
procedure doStepKnife(Gear: PGear); |
8370 | 7084 |
var a: real; |
7754 | 7085 |
begin |
7086 |
// Gear is shrunk so it can actually escape the hog without carving into the terrain |
|
13470
7b4643ff60ea
Refactor collision mask checks, remove hardcoded numbers
Wuzzy <Wuzzy2@mail.ru>
parents:
13469
diff
changeset
|
7087 |
if (Gear^.Radius = 4) and (Gear^.CollisionMask = lfAll) then Gear^.Radius:= 7; |
7872
ab6db9e07c4d
Allow cleavers to be knocked loose by explosions. Probabilities might need tweaking.
nemo
parents:
7864
diff
changeset
|
7088 |
if Gear^.Damage > 100 then Gear^.CollisionMask:= 0 |
7874
c8aba48f38dc
Arbitrarily tweaked to not firepunch loose, and to increase chance of bazooka doing it to about 20%
nemo
parents:
7872
diff
changeset
|
7089 |
else if Gear^.Damage > 30 then |
c8aba48f38dc
Arbitrarily tweaked to not firepunch loose, and to increase chance of bazooka doing it to about 20%
nemo
parents:
7872
diff
changeset
|
7090 |
if GetRandom(max(4,18-Gear^.Damage div 10)) < 3 then Gear^.CollisionMask:= 0; |
7872
ab6db9e07c4d
Allow cleavers to be knocked loose by explosions. Probabilities might need tweaking.
nemo
parents:
7864
diff
changeset
|
7091 |
Gear^.Damage:= 0; |
7759 | 7092 |
if Gear^.Timer > 0 then dec(Gear^.Timer); |
7754 | 7093 |
if (Gear^.State and gstMoving <> 0) and (Gear^.State and gstCollision = 0) then |
7094 |
begin |
|
7095 |
DeleteCI(Gear); |
|
8494
53b91a602955
Cleaver tweaks based on feedback. Nerf damage, shrink radius. This means cleaver will embed into ground quite a bit further.
nemo
parents:
8413
diff
changeset
|
7096 |
Gear^.Radius:= 7; |
7754 | 7097 |
// used for damage and impact calc. needs balancing I think |
11468
2f6f8baa2a97
Make weapon damage in most cases be a structure value and also expose it to lua. Needs testing/review due to conditions at time of doing this (w/ one arm, dizzy/tingling due to sodium citrate), and just number of places changed..
nemo
parents:
11391
diff
changeset
|
7098 |
Gear^.Health:= hwRound(hwSqr((hwAbs(Gear^.dY)+hwAbs(Gear^.dX))*Gear^.Boom/10000)); |
7754 | 7099 |
doStepFallingGear(Gear); |
7100 |
AllInactive := false; |
|
7864
667b7583c389
double cleaver rotation speed, also make spin direction dX dependent.
nemo
parents:
7829
diff
changeset
|
7101 |
a:= Gear^.DirAngle; |
667b7583c389
double cleaver rotation speed, also make spin direction dX dependent.
nemo
parents:
7829
diff
changeset
|
7102 |
CalcRotationDirAngle(Gear); |
667b7583c389
double cleaver rotation speed, also make spin direction dX dependent.
nemo
parents:
7829
diff
changeset
|
7103 |
Gear^.DirAngle:= a+(Gear^.DirAngle-a)*2*hwSign(Gear^.dX) // double rotation |
7754 | 7104 |
end |
7759 | 7105 |
else if (Gear^.CollisionIndex = -1) and (Gear^.Timer = 0) then |
7754 | 7106 |
begin |
11765
10860d4bca22
Add sound effects for: cleaver impact, air mine impact, using extra time
Wuzzy <almikes@aol.com>
parents:
11553
diff
changeset
|
7107 |
if Gear^.Health > 0 then |
10860d4bca22
Add sound effects for: cleaver impact, air mine impact, using extra time
Wuzzy <almikes@aol.com>
parents:
11553
diff
changeset
|
7108 |
PlaySound(Gear^.ImpactSound); |
10860d4bca22
Add sound effects for: cleaver impact, air mine impact, using extra time
Wuzzy <almikes@aol.com>
parents:
11553
diff
changeset
|
7109 |
|
7784
cf6261f7fdb5
Disable jiggling of cleavers 'cause it just looks odd. Adding a constraint based on proximity to portal is an option too, this was just easier.
nemo
parents:
7777
diff
changeset
|
7110 |
Gear^.DirAngle:= DxDy2Angle(Gear^.dX, Gear^.dY) + (random(30)-15); |
7758
a225cc45513e
Remove slot overcrowding, disable angle detection which isn't doing what I want.
nemo
parents:
7754
diff
changeset
|
7111 |
if (Gear^.dX.isNegative and Gear^.dY.isNegative) or |
a225cc45513e
Remove slot overcrowding, disable angle detection which isn't doing what I want.
nemo
parents:
7754
diff
changeset
|
7112 |
((not Gear^.dX.isNegative) and (not Gear^.dY.isNegative)) then Gear^.DirAngle:= Gear^.DirAngle-90; |
7754 | 7113 |
Gear^.dX:= _0; |
7114 |
Gear^.dY:= _0; |
|
7115 |
Gear^.State:= Gear^.State and (not gstMoving) or gstCollision; |
|
8494
53b91a602955
Cleaver tweaks based on feedback. Nerf damage, shrink radius. This means cleaver will embed into ground quite a bit further.
nemo
parents:
8413
diff
changeset
|
7116 |
Gear^.Radius:= 16; |
7754 | 7117 |
if Gear^.Health > 0 then AmmoShove(Gear, Gear^.Health, 0); |
7118 |
Gear^.Health:= 0; |
|
7759 | 7119 |
Gear^.Timer:= 500; |
9291
15f7bb217b66
Make add/delete consistent (this has bugged me for so long)
nemo
parents:
9289
diff
changeset
|
7120 |
AddCI(Gear) |
7754 | 7121 |
end |
7122 |
else if GameTicks and $3F = 0 then |
|
7123 |
begin |
|
9706
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9698
diff
changeset
|
7124 |
if (TestCollisionYwithGear(Gear,-1) = 0) |
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9698
diff
changeset
|
7125 |
and (TestCollisionXwithGear(Gear, 1) = 0) |
5178d2263521
return land word from uCollisions to make decisions based on it. Should be handy for trampoline.
nemo
parents:
9698
diff
changeset
|
7126 |
and (TestCollisionXwithGear(Gear,-1) = 0) |
7754 | 7127 |
and (TestCollisionYwithGear(Gear, 1) = 0) then Gear^.State:= Gear^.State and (not gstCollision) or gstMoving; |
7128 |
end |
|
7129 |
end; |
|
12192 | 7130 |
|
7131 |
//////////////////////////////////////////////////////////////////////////////// |
|
12898 | 7132 |
procedure doStepMinigunWork(Gear: PGear); |
7133 |
var HHGear: PGear; |
|
7134 |
bullet: PGear; |
|
7135 |
rx, ry: hwFloat; |
|
7136 |
gX, gY: LongInt; |
|
7137 |
begin |
|
7138 |
AllInactive:= false; |
|
7139 |
HHGear := Gear^.Hedgehog^.Gear; |
|
7140 |
if HHGear = nil then |
|
7141 |
begin |
|
7142 |
ClearHitOrder(); |
|
7143 |
DeleteGear(gear); |
|
7144 |
exit |
|
7145 |
end; |
|
7146 |
||
7147 |
HedgehogChAngle(HHGear); |
|
7148 |
||
7149 |
dec(Gear^.Timer); |
|
7150 |
if (Gear^.Timer mod 50) = 0 then |
|
7151 |
begin |
|
7152 |
Gear^.Tag := ((Gear^.Tag - 1) and 1) + 2; |
|
7153 |
||
7154 |
gX := hwRound(Gear^.X) + GetLaunchX(amMinigun, hwSign(HHGear^.dX), HHGear^.Angle); |
|
7155 |
gY := hwRound(Gear^.Y) + GetLaunchY(amMinigun, HHGear^.Angle); |
|
7156 |
rx := rndSign(getRandomf * _0_2); |
|
7157 |
ry := rndSign(getRandomf * _0_2); |
|
7158 |
||
7159 |
bullet:= AddGear(gx, gy, gtMinigunBullet, 0, SignAs(AngleSin(HHGear^.Angle) * _0_8, HHGear^.dX) + rx, AngleCos(HHGear^.Angle) * ( - _0_8) + ry, 0); |
|
13469
f1d349a52bc7
Refactor: lfCurrentHog→lfCurHogCrate, lfNotCurrentMask→lfNotCurHogCrate
Wuzzy <Wuzzy2@mail.ru>
parents:
13408
diff
changeset
|
7160 |
bullet^.CollisionMask:= lfNotCurHogCrate; |
12898 | 7161 |
bullet^.WDTimer := Gear^.WDTimer; |
7162 |
Inc(Gear^.WDTimer); |
|
7163 |
||
13147
7040506c831f
Fix direction of dispensed bullet shells from shotgun/sniper/minigun
alfadur
parents:
13140
diff
changeset
|
7164 |
CreateShellForGear(Gear, Gear^.Tag and 1); |
12898 | 7165 |
end; |
7166 |
||
7167 |
if (Gear^.Timer = 0) or ((HHGear^.State and gstHHDriven) = 0) then |
|
7168 |
begin |
|
13323 | 7169 |
if (HHGear^.State and gstHHDriven) = 0 then |
7170 |
StopSound(sndMinigun); |
|
12898 | 7171 |
HHGear^.State := HHGear^.State and (not gstNotKickable); |
7172 |
ClearHitOrder(); |
|
7173 |
DeleteGear(Gear); |
|
7174 |
AfterAttack |
|
7175 |
end |
|
7176 |
end; |
|
7177 |
||
7178 |
procedure doStepMinigun(Gear: PGear); |
|
7179 |
var HHGear: PGear; |
|
7180 |
begin |
|
7181 |
dec(Gear^.Timer); |
|
7182 |
if (Gear^.Timer mod 100) = 0 then |
|
7183 |
Gear^.Tag := (Gear^.Tag + 1) and 1; |
|
7184 |
||
7185 |
if Gear^.Timer = 0 then |
|
7186 |
begin |
|
7187 |
Gear^.Tag := 2; |
|
7188 |
HHGear := Gear^.Hedgehog^.Gear; |
|
7189 |
HHGear^.Message := HHGear^.Message and (not (gmUp or gmDown)); |
|
7190 |
HHGear^.State := HHGear^.State or gstNotKickable; |
|
7191 |
||
13154
44351ea57b71
Minigun: Move attack timer to Karma to make gear type more Lua-friendly
Wuzzy <Wuzzy2@mail.ru>
parents:
13153
diff
changeset
|
7192 |
Gear^.Timer := Gear^.Karma; |
12898 | 7193 |
Gear^.WDTimer := 0; // Order of the next bullet; |
7194 |
ClearHitOrder(); |
|
7195 |
Gear^.doStep := @doStepMinigunWork |
|
7196 |
end; |
|
7197 |
end; |
|
7198 |
||
7199 |
//////////////////////////////////////////////////////////////////////////////// |
|
7200 |
||
7201 |
procedure doStepMinigunBullet(Gear: PGear); |
|
7202 |
begin |
|
15678 | 7203 |
if Gear^.Data = nil then |
7204 |
// remember who fired this |
|
7205 |
if (Gear^.Hedgehog <> nil) and (Gear^.Hedgehog^.Gear <> nil) then |
|
7206 |
Gear^.Data:= Pointer(Gear^.Hedgehog^.Gear); |
|
12898 | 7207 |
|
7208 |
Gear^.X := Gear^.X + Gear^.dX * 2; |
|
7209 |
Gear^.Y := Gear^.Y + Gear^.dY * 2; |
|
13151
deab88f1f6f7
Improve appearance of bullet trails, slight fade out at beginning
alfadur
parents:
13147
diff
changeset
|
7210 |
Gear^.FlightTime := 0; |
12898 | 7211 |
Gear^.doStep := @doStepBulletWork |
7212 |
end; |
|
7213 |
||
15661 | 7214 |
//////////////////////////////////////////////////////////////////////////////// |
15663 | 7215 |
|
15681 | 7216 |
function MakeSentryStep(Sentry: PGear; maxYStep: LongInt; TestOnly: Boolean): Boolean; |
15669 | 7217 |
var x, y, offset, direction: LongInt; |
7218 |
begin |
|
7219 |
MakeSentryStep := false; |
|
7220 |
x := hwRound(Sentry^.X); |
|
7221 |
y := hwRound(Sentry^.Y); |
|
7222 |
direction := hwSign(Sentry^.dX); |
|
7223 |
||
7224 |
for offset := -maxYStep - 1 to maxYStep + 1 do |
|
7225 |
begin |
|
7226 |
if TestCollisionYImpl(x + direction, y + offset, Sentry^.Radius, 1, Sentry^.CollisionMask) <> 0 then |
|
7227 |
break; |
|
7228 |
end; |
|
7229 |
||
15736
7a4b719ac611
prevent sentries from getting stuck in the corners
alfadur
parents:
15735
diff
changeset
|
7230 |
if (offset >= -maxYStep) and (offset <= maxYStep) |
7a4b719ac611
prevent sentries from getting stuck in the corners
alfadur
parents:
15735
diff
changeset
|
7231 |
and (TestCollisionYImpl(x + direction, y + offset, Sentry^.Radius, -1, Sentry^.CollisionMask) = 0) then |
15669 | 7232 |
begin |
15681 | 7233 |
if not TestOnly then |
7234 |
begin |
|
7235 |
Sentry^.X := Sentry^.X + signAs(_1, Sentry^.dX); |
|
7236 |
Sentry^.Y := Sentry^.Y + int2hwFloat(offset); |
|
7237 |
end; |
|
15669 | 7238 |
MakeSentryStep := true |
7239 |
end |
|
7240 |
end; |
|
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
7241 |
|
15692 | 7242 |
function MakeSentryJump(Sentry: PGear; maxXStep, maxYStep: LongInt): Boolean; |
15735 | 7243 |
var x, y, offsetX, offsetY, direction: LongInt; |
15692 | 7244 |
jumpTime: hwFloat; |
7245 |
begin |
|
7246 |
MakeSentryJump := false; |
|
7247 |
x := hwRound(Sentry^.X); |
|
7248 |
y := hwRound(Sentry^.Y); |
|
15735 | 7249 |
offsetX := maxXStep - Sentry^.Radius; |
7250 |
direction := hwSign(Sentry^.dX); |
|
7251 |
||
15692 | 7252 |
repeat |
7253 |
for offsetY := -maxYStep - 1 to maxYStep + 1 do |
|
15735 | 7254 |
if TestCollisionYImpl(x + offsetX * direction, y + offsetY, Sentry^.Radius, 1, Sentry^.CollisionMask) <> 0 then |
15692 | 7255 |
break; |
7256 |
if (offsetY >= -maxYStep) and (offsetY <= maxYStep) then |
|
7257 |
break; |
|
15735 | 7258 |
Dec(offsetX, Sentry^.Radius); |
15692 | 7259 |
until offsetX <= 0; |
7260 |
||
15735 | 7261 |
if (offsetX >= Sentry^.Radius) and (not cGravity.isNegative) then |
15692 | 7262 |
begin |
7263 |
Sentry^.dY := -_0_25; |
|
7264 |
jumpTime := _2 * Sentry^.dY / cGravity; |
|
15735 | 7265 |
Sentry^.dX := SignAs(int2hwFloat(offsetX - Sentry^.Radius) / jumpTime, Sentry^.dX); |
15869 | 7266 |
Sentry^.State := Sentry^.State or gstHHJumping; |
15692 | 7267 |
MakeSentryJump := true; |
7268 |
end; |
|
7269 |
end; |
|
15669 | 7270 |
|
15670 | 7271 |
function TraceAttackPath(fromX, fromY, toX, toY, step: hwFloat; mask: Word): LongWord; |
7272 |
var distX, distY, dist, invDistance: HwFloat; |
|
7273 |
i, count: LongInt; |
|
7274 |
begin |
|
7275 |
TraceAttackPath := 0; |
|
7276 |
if (step < _1) |
|
7277 |
or ((hwRound(fromX) and LAND_WIDTH_MASK) <> 0) |
|
7278 |
or ((hwRound(toX) and LAND_WIDTH_MASK) <> 0) |
|
7279 |
or ((hwRound(fromY) and LAND_HEIGHT_MASK) <> 0) |
|
7280 |
or ((hwRound(toY) and LAND_HEIGHT_MASK) <> 0) then |
|
7281 |
exit; |
|
7282 |
||
7283 |
distX := toX - fromX; |
|
7284 |
distY := toY - fromY; |
|
7285 |
dist := Distance(distX, distY); |
|
7286 |
count := hwRound(dist / step); |
|
7287 |
||
7288 |
invDistance := step / dist; |
|
7289 |
distX := distX * invDistance; |
|
7290 |
distY := distY * invDistance; |
|
7291 |
||
7292 |
for i := 0 to count - 1 do |
|
7293 |
begin |
|
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15927
diff
changeset
|
7294 |
if (LandGet(hwRound(fromY), hwRound(fromX)) and mask) <> 0 then |
15670 | 7295 |
Inc(TraceAttackPath); |
7296 |
fromX := fromX + distX; |
|
7297 |
fromY := fromY + distY; |
|
7298 |
end |
|
7299 |
end; |
|
7300 |
||
15682
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7301 |
function CheckSentryAttackRange(Sentry: PGear; targetX, targetY: HwFloat): Boolean; |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7302 |
var distX, distY: hwFloat; |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7303 |
begin |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7304 |
distX := targetX - Sentry^.X; |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7305 |
distY := targetY - Sentry^.Y; |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7306 |
CheckSentryAttackRange := |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7307 |
(distX.isNegative = Sentry^.dX.isNegative) |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7308 |
and (distX.Round > 24) |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7309 |
and (distX.Round < 500) |
15683 | 7310 |
and (hwAbs(distY) < hwAbs(distX * _1_5)) |
15682
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7311 |
and (TraceAttackPath(Sentry^.X, Sentry^.Y, targetX, targetY, _4, lfLandMask) <= 18); |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7312 |
end; |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7313 |
|
15734 | 7314 |
procedure ResetSentryState(Gear: PGear; state, timer: LongInt); |
7315 |
begin |
|
7316 |
Gear^.Timer := timer; |
|
7317 |
Gear^.Tag := state; |
|
7318 |
Gear^.Target.X := 0; |
|
7319 |
Gear^.Target.Y := 0; |
|
7320 |
if Gear^.Karma <> 0 then |
|
7321 |
begin |
|
7322 |
ClearGlobalHitOrderLeq(Gear^.Karma); |
|
7323 |
Gear^.Karma := 0; |
|
7324 |
end; |
|
7325 |
end; |
|
7326 |
||
15739 | 7327 |
function CheckSentryDestroyed(Sentry: PGear; damagedState: LongInt): Boolean; |
7328 |
begin |
|
7329 |
CheckSentryDestroyed := false; |
|
7330 |
if Sentry^.Damage > 0 then |
|
7331 |
begin |
|
7332 |
dec(Sentry^.Health, Sentry^.Damage); |
|
7333 |
Sentry^.Damage := 0; |
|
7334 |
if Sentry^.Health <= 0 then |
|
7335 |
begin |
|
7336 |
doMakeExplosion(hwRound(Sentry^.X), hwRound(Sentry^.Y), Sentry^.Boom, Sentry^.Hedgehog, EXPLAutoSound); |
|
7337 |
DeleteGear(Sentry); |
|
7338 |
CheckSentryDestroyed := true; |
|
7339 |
exit; |
|
7340 |
end |
|
7341 |
else |
|
7342 |
ResetSentryState(Sentry, damagedState, 10000) |
|
7343 |
end; |
|
7344 |
||
7345 |
if ((Sentry^.Health * 100) < random(cSentryHealth * 90)) and ((GameTicks and $FF) = 0) then |
|
7346 |
if Sentry^.Health * 2 < cSentryHealth then |
|
7347 |
AddVisualGear(hwRound(Sentry^.X) - 8 + Random(16), hwRound(Sentry^.Y) - 2, vgtSmoke) |
|
7348 |
else |
|
7349 |
AddVisualGear(hwRound(Sentry^.X) - 8 + Random(16), hwRound(Sentry^.Y) - 2, vgtSmokeWhite); |
|
7350 |
end; |
|
7351 |
||
7352 |
procedure AimSentry(Sentry: PGear); |
|
7353 |
var HHGear: PGear; |
|
7354 |
begin |
|
7355 |
if CurrentHedgehog <> nil then |
|
7356 |
begin |
|
7357 |
HHGear := CurrentHedgehog^.Gear; |
|
7358 |
if HHGear <> nil then |
|
7359 |
begin |
|
7360 |
Sentry^.Target.X := Sentry^.Target.X + hwSign(HHGear^.X - int2hwFloat(Sentry^.Target.X)); |
|
7361 |
Sentry^.Target.Y := Sentry^.Target.Y + hwSign(HHGear^.Y - int2hwFloat(Sentry^.Target.Y)); |
|
7362 |
end; |
|
7363 |
end; |
|
7364 |
end; |
|
7365 |
||
7366 |
procedure MakeSentryShot(Sentry: PGear); |
|
7367 |
var bullet: PGear; |
|
7368 |
distX, distY, invDistance: HwFloat; |
|
7369 |
begin |
|
7370 |
distX := int2hwFloat(Sentry^.Target.X) - Sentry^.X; |
|
7371 |
distY := int2hwFloat(Sentry^.Target.Y) - Sentry^.Y; |
|
7372 |
invDistance := _1 / Distance(distX, distY); |
|
7373 |
distX := distX * invDistance; |
|
7374 |
distY := distY * invDistance; |
|
7375 |
||
7376 |
bullet := AddGear( |
|
7377 |
hwRound(Sentry^.X), hwRound(Sentry^.Y), |
|
7378 |
gtMinigunBullet, 0, |
|
7379 |
distX * _0_9 + rndSign(getRandomf * _0_1), |
|
7380 |
distY * _0_9 + rndSign(getRandomf * _0_1), |
|
7381 |
0); |
|
7382 |
||
7383 |
bullet^.Karma := 12; |
|
15864 | 7384 |
bullet^.Pos := 1; // To tell apart from minigun bullets |
15739 | 7385 |
bullet^.WDTimer := GameTicks; |
7386 |
bullet^.PortalCounter := 1; |
|
7387 |
bullet^.Elasticity := Sentry^.X; |
|
7388 |
bullet^.Friction := Sentry^.Y; |
|
7389 |
bullet^.Data := Pointer(Sentry); |
|
15845 | 7390 |
bullet^.Hedgehog := Sentry^.Hedgehog; |
15739 | 7391 |
|
7392 |
CreateShellForGear(Sentry, Sentry^.WDTimer and 1); |
|
7393 |
PlaySound(sndGun); |
|
7394 |
end; |
|
7395 |
||
15843
4a1e3d824c34
make domesticated sentries not target their owners
alfadur
parents:
15841
diff
changeset
|
7396 |
function GetSentryTarget(sentry: PGear): PGear; |
15740 | 7397 |
var HHGear: PGear; |
15843
4a1e3d824c34
make domesticated sentries not target their owners
alfadur
parents:
15841
diff
changeset
|
7398 |
friendlyTarget: boolean; |
15740 | 7399 |
begin |
7400 |
GetSentryTarget := nil; |
|
15843
4a1e3d824c34
make domesticated sentries not target their owners
alfadur
parents:
15841
diff
changeset
|
7401 |
friendlyTarget := false; |
4a1e3d824c34
make domesticated sentries not target their owners
alfadur
parents:
15841
diff
changeset
|
7402 |
|
4a1e3d824c34
make domesticated sentries not target their owners
alfadur
parents:
15841
diff
changeset
|
7403 |
if CurrentHedgehog <> nil then |
15740 | 7404 |
begin |
7405 |
HHGear := CurrentHedgehog^.Gear; |
|
7406 |
if HHGear <> nil then |
|
15843
4a1e3d824c34
make domesticated sentries not target their owners
alfadur
parents:
15841
diff
changeset
|
7407 |
if ((HHGear^.State and gstHHDriven) <> 0) and (HHGear^.CollisionIndex < 0) then |
4a1e3d824c34
make domesticated sentries not target their owners
alfadur
parents:
15841
diff
changeset
|
7408 |
begin |
4a1e3d824c34
make domesticated sentries not target their owners
alfadur
parents:
15841
diff
changeset
|
7409 |
if sentry^.Hedgehog <> nil then |
15844 | 7410 |
friendlyTarget := sentry^.Hedgehog^.Team^.Clan = CurrentHedgehog^.Team^.Clan; |
15843
4a1e3d824c34
make domesticated sentries not target their owners
alfadur
parents:
15841
diff
changeset
|
7411 |
if not friendlyTarget then |
4a1e3d824c34
make domesticated sentries not target their owners
alfadur
parents:
15841
diff
changeset
|
7412 |
GetSentryTarget := HHGear; |
4a1e3d824c34
make domesticated sentries not target their owners
alfadur
parents:
15841
diff
changeset
|
7413 |
end |
15740 | 7414 |
end |
7415 |
end; |
|
7416 |
||
15737 | 7417 |
procedure doStepSentryLand(Gear: PGear); |
15739 | 7418 |
var HHGear: PGear; |
15869 | 7419 |
land: Word; |
15664 | 7420 |
const sentry_Idle = 0; |
7421 |
sentry_Walking = 1; |
|
7422 |
sentry_Aiming = 2; |
|
7423 |
sentry_Attacking = 3; |
|
7424 |
sentry_Reloading = 4; |
|
15661 | 7425 |
begin |
15663 | 7426 |
HHGear:= nil; |
7427 |
||
15662 | 7428 |
if CheckGearDrowning(Gear) then |
7429 |
exit; |
|
7430 |
||
15739 | 7431 |
if CheckSentryDestroyed(Gear, sentry_Reloading) then |
7432 |
exit; |
|
15733 | 7433 |
|
15869 | 7434 |
land := TestCollisionYwithGear(Gear, 1); |
7435 |
if Gear^.dY.isNegative or (land = 0) or |
|
7436 |
((Gear^.dY.QWordValue > _0_01.QWordValue) and ((Gear^.State and gstHHJumping) = 0)) then |
|
15662 | 7437 |
begin |
15744 | 7438 |
DeleteCI(Gear); |
15662 | 7439 |
doStepFallingGear(Gear); |
15734 | 7440 |
if not (Gear^.Tag in [sentry_Idle, sentry_Reloading]) then |
7441 |
ResetSentryState(Gear, sentry_Idle, 1000); |
|
15662 | 7442 |
exit; |
15744 | 7443 |
end |
7444 |
else |
|
15869 | 7445 |
begin |
15744 | 7446 |
AddCI(Gear); |
15869 | 7447 |
Gear^.State := Gear^.State and (not gstHHJumping); |
7448 |
Gear^.dX := SignAs(_0, Gear^.dX); |
|
7449 |
Gear^.dY := SignAs(_0, Gear^.dY); |
|
7450 |
end; |
|
15662 | 7451 |
|
15664 | 7452 |
if Gear^.Timer > 0 then dec(Gear^.Timer); |
7453 |
||
7454 |
if Gear^.Timer = 0 then |
|
15662 | 7455 |
begin |
15744 | 7456 |
DeleteCI(Gear); |
15664 | 7457 |
if Gear^.Tag = sentry_Idle then |
7458 |
begin |
|
7459 |
Gear^.Tag := sentry_Walking; |
|
7460 |
Gear^.Timer := 1000 + GetRandom(3000); |
|
15692 | 7461 |
if GetRandom(4) = 0 then |
7462 |
begin |
|
7463 |
if MakeSentryJump(Gear, 80, 60) then |
|
7464 |
Gear^.Timer := 4000 |
|
7465 |
else |
|
7466 |
Gear^.Timer := 1000; |
|
7467 |
Gear^.Tag := sentry_Idle; |
|
7468 |
end |
|
7469 |
else |
|
7470 |
begin |
|
7471 |
Gear^.dX.isNegative := GetRandom(2) = 1; |
|
7472 |
||
7473 |
if MakeSentryStep(Gear, 6, true) then |
|
15681 | 7474 |
begin |
15692 | 7475 |
if GetRandom(4) = 0 then |
7476 |
begin |
|
7477 |
Gear^.Timer := 2000; |
|
7478 |
Gear^.Tag := sentry_Idle; |
|
7479 |
end; |
|
7480 |
end |
|
7481 |
else |
|
7482 |
begin |
|
7483 |
Gear^.dX.isNegative := not Gear^.dX.isNegative; |
|
7484 |
if not MakeSentryStep(Gear, 6, true) then |
|
7485 |
begin |
|
7486 |
if GetRandom(2) = 0 then |
|
7487 |
begin |
|
15741 | 7488 |
Gear^.dY := - _0_1; |
7489 |
if TestCollisionYKick(Gear, -1) = 0 then |
|
7490 |
Gear^.dY := - _0_25; |
|
15692 | 7491 |
Gear^.Timer := 3000; |
7492 |
end |
|
7493 |
else |
|
7494 |
Gear^.Timer := 5000; |
|
7495 |
Gear^.Tag := sentry_Idle; |
|
7496 |
end; |
|
7497 |
end |
|
15681 | 7498 |
end |
15664 | 7499 |
end |
7500 |
else if Gear^.Tag in [sentry_Walking, sentry_Reloading] then |
|
7501 |
begin |
|
7502 |
Gear^.Tag := sentry_Idle; |
|
15662 | 7503 |
Gear^.Timer := 1000 + GetRandom(1000); |
7504 |
end |
|
15664 | 7505 |
else if Gear^.Tag = sentry_Aiming then |
7506 |
begin |
|
15682
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7507 |
if CheckSentryAttackRange(Gear, int2hwFloat(Gear^.Target.X), int2hwFloat(Gear^.Target.Y)) then |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7508 |
begin |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7509 |
Gear^.WDTimer := 5 + GetRandom(3); |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7510 |
Gear^.Tag := sentry_Attacking; |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7511 |
Gear^.Timer := 100; |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7512 |
end |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7513 |
else |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7514 |
begin |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7515 |
Gear^.Target.X := 0; |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7516 |
Gear^.Target.Y := 0; |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7517 |
Gear^.Tag := sentry_Idle; |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7518 |
Gear^.Timer := 5000; |
5ce76c658c22
don't shoot if the target moves out of range while aiming
alfadur
parents:
15681
diff
changeset
|
7519 |
end |
15664 | 7520 |
end |
7521 |
else if Gear^.Tag = sentry_Attacking then |
|
7522 |
begin |
|
15739 | 7523 |
MakeSentryShot(Gear); |
15664 | 7524 |
|
7525 |
if Gear^.WDTimer = 0 then |
|
15739 | 7526 |
ResetSentryState(Gear, sentry_Reloading, 6000 + GetRandom(2000)) |
15664 | 7527 |
else |
7528 |
begin |
|
7529 |
dec(Gear^.WDTimer); |
|
15678 | 7530 |
Gear^.Timer := 100; |
15664 | 7531 |
end |
7532 |
end; |
|
15744 | 7533 |
AddCI(Gear); |
15662 | 7534 |
end; |
7535 |
||
15664 | 7536 |
if (Gear^.Tag = sentry_Walking) and ((GameTicks and $1F) = 0) then |
15662 | 7537 |
begin |
15744 | 7538 |
DeleteCI(Gear); |
15681 | 7539 |
if not MakeSentryStep(Gear, 6, false) then |
15744 | 7540 |
Gear^.Timer := 0; |
7541 |
AddCI(Gear); |
|
15662 | 7542 |
end; |
15663 | 7543 |
|
15739 | 7544 |
if ((GameTicks and $1F) = 0) and (Gear^.Tag = sentry_Aiming) then |
7545 |
AimSentry(Gear); |
|
15679 | 7546 |
|
15663 | 7547 |
if ((GameTicks and $FF) = 0) |
15740 | 7548 |
and (Gear^.Tag in [sentry_Idle, sentry_Walking]) then |
15663 | 7549 |
begin |
15843
4a1e3d824c34
make domesticated sentries not target their owners
alfadur
parents:
15841
diff
changeset
|
7550 |
HHGear := GetSentryTarget(Gear); |
15740 | 7551 |
if HHGear <> nil then |
7552 |
if CheckSentryAttackRange(Gear, HHGear^.X, HHGear^.Y) then |
|
7553 |
begin |
|
7554 |
Gear^.Target.X := hwRound(HHGear^.X); |
|
7555 |
Gear^.Target.Y := hwRound(HHGear^.Y); |
|
7556 |
Gear^.Karma := GameTicks; |
|
7557 |
Gear^.Tag := sentry_Aiming; |
|
7558 |
Gear^.Timer := 1800 + GetRandom(400); |
|
7559 |
end |
|
15663 | 7560 |
end |
15661 | 7561 |
end; |
7562 |
||
15738 | 7563 |
procedure doStepSentryWater(Gear: PGear); |
15739 | 7564 |
var HHGear: PGear; |
7565 |
const sentry_Idle = 0; |
|
7566 |
sentry_Walking = 1; |
|
7567 |
sentry_Aiming = 2; |
|
7568 |
sentry_Attacking = 3; |
|
7569 |
sentry_Reloading = 4; |
|
15738 | 7570 |
begin |
7571 |
if Gear^.Tag < 0 then |
|
7572 |
begin |
|
7573 |
CheckGearDrowning(Gear); |
|
7574 |
exit; |
|
7575 |
end; |
|
7576 |
||
7577 |
Gear^.Y := int2hwFloat(cWaterLine - 3 * Gear^.Radius); |
|
15746 | 7578 |
if TestCollisionYImpl(hwRound(Gear^.X), hwRound(Gear^.Y), Gear^.Radius - 1, -1, Gear^.CollisionMask and lfLandMask) <> 0 then |
15738 | 7579 |
begin |
7580 |
Gear^.Tag := -1; |
|
7581 |
exit; |
|
7582 |
end; |
|
15739 | 7583 |
|
7584 |
if CheckSentryDestroyed(Gear, sentry_Reloading) then |
|
7585 |
exit; |
|
7586 |
||
7587 |
if Gear^.Timer > 0 then dec(Gear^.Timer); |
|
7588 |
||
7589 |
if Gear^.Timer = 0 then |
|
7590 |
begin |
|
7591 |
if Gear^.Tag = sentry_Idle then |
|
7592 |
begin |
|
7593 |
Gear^.Tag := sentry_Walking; |
|
7594 |
Gear^.Timer := 3000 + GetRandom(3000); |
|
7595 |
Gear^.dX.isNegative := GetRandom(2) = 1; |
|
7596 |
if TestCollisionXwithGear(Gear, hwSign(Gear^.dX)) <> 0 then |
|
7597 |
Gear^.dX.isNegative := not Gear^.dX.isNegative; |
|
7598 |
end |
|
7599 |
else if Gear^.Tag in [sentry_Walking, sentry_Reloading] then |
|
7600 |
begin |
|
7601 |
Gear^.Tag := sentry_Idle; |
|
7602 |
Gear^.Timer := 1000 + GetRandom(1000); |
|
7603 |
end |
|
7604 |
else if Gear^.Tag = sentry_Aiming then |
|
7605 |
begin |
|
7606 |
if CheckSentryAttackRange(Gear, int2hwFloat(Gear^.Target.X), int2hwFloat(Gear^.Target.Y)) then |
|
7607 |
begin |
|
7608 |
Gear^.WDTimer := 5 + GetRandom(3); |
|
7609 |
Gear^.Tag := sentry_Attacking; |
|
7610 |
Gear^.Timer := 100; |
|
7611 |
end |
|
7612 |
else |
|
7613 |
begin |
|
7614 |
Gear^.Target.X := 0; |
|
7615 |
Gear^.Target.Y := 0; |
|
7616 |
Gear^.Tag := sentry_Idle; |
|
7617 |
Gear^.Timer := 5000; |
|
7618 |
end |
|
7619 |
end |
|
7620 |
else if Gear^.Tag = sentry_Attacking then |
|
7621 |
begin |
|
7622 |
MakeSentryShot(Gear); |
|
7623 |
||
7624 |
if Gear^.WDTimer = 0 then |
|
7625 |
ResetSentryState(Gear, sentry_Reloading, 6000 + GetRandom(2000)) |
|
7626 |
else |
|
7627 |
begin |
|
7628 |
dec(Gear^.WDTimer); |
|
7629 |
Gear^.Timer := 100; |
|
7630 |
end |
|
7631 |
end; |
|
7632 |
end; |
|
7633 |
||
7634 |
if (Gear^.Tag = sentry_Walking) and ((GameTicks and $1F) = 0) then |
|
7635 |
begin |
|
7636 |
if TestCollisionXwithGear(Gear, hwSign(Gear^.dX)) = 0 then |
|
15743 | 7637 |
begin |
7638 |
Gear^.dX := SignAs(_1, Gear^.dX); |
|
7639 |
Gear^.X := Gear^.X + Gear^.dX; |
|
7640 |
WorldWrap(Gear); |
|
7641 |
end |
|
15739 | 7642 |
else |
7643 |
Gear^.Timer := 0 |
|
7644 |
end; |
|
7645 |
||
7646 |
if ((GameTicks and $1F) = 0) and (Gear^.Tag = sentry_Aiming) then |
|
7647 |
AimSentry(Gear); |
|
7648 |
||
7649 |
if ((GameTicks and $FF) = 0) |
|
15740 | 7650 |
and (Gear^.Tag in [sentry_Idle, sentry_Walking]) then |
15739 | 7651 |
begin |
15843
4a1e3d824c34
make domesticated sentries not target their owners
alfadur
parents:
15841
diff
changeset
|
7652 |
HHGear := GetSentryTarget(Gear); |
15740 | 7653 |
if HHGear <> nil then |
7654 |
if CheckSentryAttackRange(Gear, HHGear^.X, HHGear^.Y) then |
|
7655 |
begin |
|
7656 |
Gear^.Target.X := hwRound(HHGear^.X); |
|
7657 |
Gear^.Target.Y := hwRound(HHGear^.Y); |
|
7658 |
Gear^.Karma := GameTicks; |
|
7659 |
Gear^.Tag := sentry_Aiming; |
|
7660 |
Gear^.Timer := 1800 + GetRandom(400); |
|
7661 |
end |
|
15739 | 7662 |
end |
15738 | 7663 |
end; |
7664 |
||
15737 | 7665 |
procedure doStepSentryDeploy(Gear: PGear); |
7666 |
begin |
|
7667 |
Gear^.Tag := -1; |
|
15738 | 7668 |
if hwRound(Gear^.Y) + 3 * Gear^.Radius >= cWaterLine then |
7669 |
begin |
|
7670 |
Gear^.Y := int2hwFloat(cWaterLine - 3 * Gear^.Radius); |
|
7671 |
if Gear^.Timer > 0 then dec(Gear^.Timer); |
|
7672 |
if Gear^.Timer = 0 then |
|
7673 |
begin |
|
7674 |
Gear^.Tag := 0; |
|
7675 |
Gear^.doStep := @doStepSentryWater; |
|
7676 |
end; |
|
7677 |
end |
|
7678 |
else if Gear^.dY.isNegative or (TestCollisionYwithGear(Gear, 1) = 0) then |
|
15737 | 7679 |
doStepFallingGear(Gear) |
7680 |
else |
|
7681 |
begin |
|
7682 |
if Gear^.Timer > 0 then dec(Gear^.Timer); |
|
7683 |
if Gear^.Timer = 0 then |
|
7684 |
begin |
|
7685 |
Gear^.Tag := 0; |
|
7686 |
Gear^.doStep := @doStepSentryLand; |
|
7687 |
end; |
|
7688 |
end; |
|
7689 |
end; |
|
7690 |
||
15674
3d8c2ab2b98b
Tweak airplane spawn point to avoid appear out of nowhere
Wuzzy <Wuzzy2@mail.ru>
parents:
15670
diff
changeset
|
7691 |
end. |