author | unC0Rr |
Thu, 29 Aug 2024 15:28:20 +0200 | |
branch | transitional_engine |
changeset 16054 | 274a5afc2aec |
parent 15929 | 128ace913837 |
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:
10080
diff
changeset
|
16 |
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA |
4 | 17 |
*) |
18 |
||
2630 | 19 |
{$INCLUDE "options.inc"} |
20 |
||
4 | 21 |
unit uWorld; |
22 |
interface |
|
6622 | 23 |
uses SDLh, uGears, uConsts, uFloat, uRandom, uTypes, uRenderUtils; |
3697 | 24 |
|
3038 | 25 |
procedure initModule; |
26 |
procedure freeModule; |
|
2716
b9ca1bfca24f
complete the replacement of init/free wrappers for every unit
koda
parents:
2713
diff
changeset
|
27 |
|
b9ca1bfca24f
complete the replacement of init/free wrappers for every unit
koda
parents:
2713
diff
changeset
|
28 |
procedure InitWorld; |
6394
f0a9042e7387
yay, finally osx (and likely windows) fullscreen switch works like on linux! ALL textures had to be destroyed and recreated only after the new window got created. In other news, the new window must be cleaned with glClear to skip a first frame of garbage and AddProgress is only called the first time.
koda
parents:
6380
diff
changeset
|
29 |
procedure ResetWorldTex; |
f0a9042e7387
yay, finally osx (and likely windows) fullscreen switch works like on linux! ALL textures had to be destroyed and recreated only after the new window got created. In other news, the new window must be cleaned with glClear to skip a first frame of garbage and AddProgress is only called the first time.
koda
parents:
6380
diff
changeset
|
30 |
|
2716
b9ca1bfca24f
complete the replacement of init/free wrappers for every unit
koda
parents:
2713
diff
changeset
|
31 |
procedure DrawWorld(Lag: LongInt); |
3692 | 32 |
procedure DrawWorldStereo(Lag: LongInt; RM: TRenderMode); |
2905 | 33 |
procedure ShowMission(caption, subcaption, text: ansistring; icon, time : LongInt); |
13467
854caa3c9212
Lua API: Add parameter forceDisplay to ShowMission to prevent manual hiding
Wuzzy <Wuzzy2@mail.ru>
parents:
13465
diff
changeset
|
34 |
procedure ShowMission(caption, subcaption, text: ansistring; icon, time : LongInt; forceDisplay : boolean); |
2786 | 35 |
procedure HideMission; |
13370
e202d58236b1
Lua API: Add 5th parameter showExtra to SetAmmoTexts to hide extra text
Wuzzy <Wuzzy2@mail.ru>
parents:
13174
diff
changeset
|
36 |
procedure SetAmmoTexts(ammoType: TAmmoType; name: ansistring; caption: ansistring; description: ansistring; autoLabels: boolean); |
6011
519f8a58c021
Fix a bunch of warnings (also improves speed a bit in 32 bit code)
unC0Rr
parents:
5862
diff
changeset
|
37 |
procedure ShakeCamera(amount: LongInt); |
5682
06d5f561f772
some camera adjustments (should also fix cam flickering on lowerst res)
sheepluva
parents:
5675
diff
changeset
|
38 |
procedure InitCameraBorders; |
6682 | 39 |
procedure InitTouchInterface; |
7023 | 40 |
procedure SetUtilityWidgetState(ammoType: TAmmoType); |
6688 | 41 |
procedure animateWidget(widget: POnScreenWidget; fade, showWidget: boolean); |
3638
33ee433749ba
touch overlay reworked, improvements to zoom and confirmation
koda
parents:
3629
diff
changeset
|
42 |
procedure MoveCamera; |
5521 | 43 |
procedure onFocusStateChanged; |
10392 | 44 |
procedure updateCursorVisibility; |
14562 | 45 |
procedure updateTouchWidgets(ammoType: TAmmoType); |
4 | 46 |
|
47 |
implementation |
|
4359 | 48 |
uses |
7721 | 49 |
uStore |
50 |
, uMisc |
|
51 |
, uIO |
|
52 |
, uLocale |
|
53 |
, uSound |
|
54 |
, uAmmos |
|
55 |
, uVisualGears |
|
56 |
, uChat |
|
57 |
, uLandTexture |
|
58 |
, uVariables |
|
59 |
, uUtils |
|
60 |
, uTextures |
|
61 |
, uRender |
|
62 |
, uCaptions |
|
63 |
, uCursor |
|
64 |
, uCommands |
|
9720
453a1c29b7e4
Animate hedgehogs healths inside team health bar. Proper animation for the case when max team health grows is lost though.
unc0rr
parents:
9693
diff
changeset
|
65 |
, uTeams |
11940
156f1866b8bd
Make SetAmmoTexts update ammo menu weapon name, too
Wuzzy <almikes@aol.com>
parents:
11939
diff
changeset
|
66 |
, uDebug |
14432
71359339a493
Ammo menu: Show number instead F1, etc. if slot keys differ from default or in Touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14430
diff
changeset
|
67 |
, uInputHandler |
9720
453a1c29b7e4
Animate hedgehogs healths inside team health bar. Proper animation for the case when max team health grows is lost though.
unc0rr
parents:
9693
diff
changeset
|
68 |
{$IFDEF USE_VIDEO_RECORDING} |
7721 | 69 |
, uVideoRec |
9720
453a1c29b7e4
Animate hedgehogs healths inside team health bar. Proper animation for the case when max team health grows is lost though.
unc0rr
parents:
9693
diff
changeset
|
70 |
{$ENDIF} |
4359 | 71 |
; |
4 | 72 |
|
10331 | 73 |
var AMShiftTargetX, AMShiftTargetY, AMShiftX, AMShiftY, SlotsNum: LongInt; |
6796
3e89dbdc7db9
You can now change AMAnimType to enable the animation through the x/y axis and alpha for example
Xeli
parents:
6795
diff
changeset
|
74 |
AMAnimStartTime, AMState : LongInt; |
3e89dbdc7db9
You can now change AMAnimType to enable the animation through the x/y axis and alpha for example
Xeli
parents:
6795
diff
changeset
|
75 |
AMAnimState: Single; |
2699
249adefa9c1c
replace initialization/finalization statements with custom init functions
koda
parents:
2682
diff
changeset
|
76 |
tmpSurface: PSDL_Surface; |
249adefa9c1c
replace initialization/finalization statements with custom init functions
koda
parents:
2682
diff
changeset
|
77 |
fpsTexture: PTexture; |
2850
f6f8db825ce7
A little clock for convenience in finding things in demos
nemo
parents:
2839
diff
changeset
|
78 |
timeTexture: PTexture; |
2716
b9ca1bfca24f
complete the replacement of init/free wrappers for every unit
koda
parents:
2713
diff
changeset
|
79 |
FPS: Longword; |
b9ca1bfca24f
complete the replacement of init/free wrappers for every unit
koda
parents:
2713
diff
changeset
|
80 |
CountTicks: Longword; |
15170 | 81 |
prevPoint: TPoint; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
82 |
amSel: TAmmoType = amNothing; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
83 |
missionTex: PTexture; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
84 |
missionTimer: LongInt; |
7027 | 85 |
isFirstFrame: boolean; |
7028 | 86 |
AMAnimType: LongInt; |
7180 | 87 |
recTexture: PTexture; |
8145
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
88 |
AmmoMenuTex : PTexture; |
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
89 |
HorizontOffset: LongInt; |
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
90 |
cOffsetY: LongInt; |
9557 | 91 |
WorldEnd, WorldFade : array[0..3] of HwColor4f; |
3692 | 92 |
|
4816
c2575faeac3d
use a different depth for different layers (land, water, explosions)
koda
parents:
4812
diff
changeset
|
93 |
const cStereo_Sky = 0.0500; |
c2575faeac3d
use a different depth for different layers (land, water, explosions)
koda
parents:
4812
diff
changeset
|
94 |
cStereo_Horizon = 0.0250; |
6302
db8bdbb34e03
Spread flakes out over 5 layers now (far back, mid distance, just behind land, just in front of lands and hog, near distance). Spread clouds out over 3 layers (far back, mid distance, just behind land). Add a flatten clouds option, use
nemo
parents:
6296
diff
changeset
|
95 |
cStereo_MidDistance = 0.0175; |
4816
c2575faeac3d
use a different depth for different layers (land, water, explosions)
koda
parents:
4812
diff
changeset
|
96 |
cStereo_Water_distant = 0.0125; |
c2575faeac3d
use a different depth for different layers (land, water, explosions)
koda
parents:
4812
diff
changeset
|
97 |
cStereo_Land = 0.0075; |
c2575faeac3d
use a different depth for different layers (land, water, explosions)
koda
parents:
4812
diff
changeset
|
98 |
cStereo_Water_near = 0.0025; |
6289
95ffd59d0f4a
Increase rarity of near flakes (don't want them intruding in game much). Also fix stereo. Near flakes were being drawn far.
nemo
parents:
6276
diff
changeset
|
99 |
cStereo_Outside = -0.0400; |
4 | 100 |
|
8145
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
101 |
AMAnimDuration = 200; |
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
102 |
AMHidden = 0;//AMState values |
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
103 |
AMShowingUp = 1; |
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
104 |
AMShowing = 2; |
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
105 |
AMHiding = 3; |
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
106 |
|
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
107 |
AMTypeMaskX = $00000001; |
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
108 |
AMTypeMaskY = $00000002; |
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
109 |
AMTypeMaskAlpha = $00000004; |
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
110 |
|
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
111 |
{$IFDEF MOBILE} |
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
112 |
AMSlotSize = 48; |
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
113 |
{$ELSE} |
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
114 |
AMSlotSize = 32; |
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
115 |
{$ENDIF} |
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
116 |
AMSlotPadding = (AMSlotSize - 32) shr 1; |
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
117 |
|
15067
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
118 |
{$IFDEF USE_LANDSCAPE_AMMOMENU} |
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
119 |
amNumOffsetX = 0; |
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
120 |
{$IFDEF USE_AM_NUMCOLUMN} |
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
121 |
amNumOffsetY = AMSlotSize; |
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
122 |
{$ELSE} |
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
123 |
amNumOffsetY = 0; |
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
124 |
{$ENDIF} |
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
125 |
{$ELSE} |
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
126 |
amNumOffsetY = 0; |
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
127 |
{$IFDEF USE_AM_NUMCOLUMN} |
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
128 |
amNumOffsetX = AMSlotSize; |
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
129 |
{$ELSE} |
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
130 |
amNumOffsetX = 0; |
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
131 |
{$ENDIF} |
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
132 |
{$ENDIF} |
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
133 |
|
8145
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
134 |
cSendCursorPosTime = 50; |
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
135 |
cCursorEdgesDist = 100; |
6408c0ba4ba1
Move global variables to units that use them
Joe Doyle (Ginto8) <ginto8@gmail.com>
parents:
8138
diff
changeset
|
136 |
|
6492 | 137 |
// helper functions to create the goal/game mode string |
138 |
function AddGoal(s: ansistring; gf: longword; si: TGoalStrId; i: LongInt): ansistring; |
|
139 |
var t: ansistring; |
|
140 |
begin |
|
141 |
if (GameFlags and gf) <> 0 then |
|
142 |
begin |
|
143 |
t:= inttostr(i); |
|
7069 | 144 |
s:= s + FormatA(trgoal[si], t) + '|' |
6492 | 145 |
end; |
146 |
AddGoal:= s; |
|
147 |
end; |
|
148 |
||
149 |
function AddGoal(s: ansistring; gf: longword; si: TGoalStrId): ansistring; |
|
150 |
begin |
|
151 |
if (GameFlags and gf) <> 0 then |
|
152 |
s:= s + trgoal[si] + '|'; |
|
153 |
AddGoal:= s; |
|
154 |
end; |
|
155 |
||
4 | 156 |
procedure InitWorld; |
2704
51cda17b7c3b
Rolling random numbers before land is generated is bad, m'kay? InitWorld probably not the best place for it.
nemo
parents:
2699
diff
changeset
|
157 |
var i, t: LongInt; |
51cda17b7c3b
Rolling random numbers before land is generated is bad, m'kay? InitWorld probably not the best place for it.
nemo
parents:
2699
diff
changeset
|
158 |
cp: PClan; |
2863 | 159 |
g: ansistring; |
4 | 160 |
begin |
3764 | 161 |
missionTimer:= 0; |
2786 | 162 |
|
2704
51cda17b7c3b
Rolling random numbers before land is generated is bad, m'kay? InitWorld probably not the best place for it.
nemo
parents:
2699
diff
changeset
|
163 |
if (GameFlags and gfRandomOrder) <> 0 then // shuffle them up a bit |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
164 |
begin |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
165 |
for i:= 0 to ClansCount * 4 do |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
166 |
begin |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
167 |
t:= GetRandom(ClansCount); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
168 |
if t <> 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
169 |
begin |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
170 |
cp:= ClansArray[0]; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
171 |
ClansArray[0]:= ClansArray[t]; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
172 |
ClansArray[t]:= cp; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
173 |
ClansArray[t]^.ClanIndex:= t; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
174 |
ClansArray[0]^.ClanIndex:= 0; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
175 |
end; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
176 |
end; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
177 |
CurrentTeam:= ClansArray[0]^.Teams[0]; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
178 |
end; |
2704
51cda17b7c3b
Rolling random numbers before land is generated is bad, m'kay? InitWorld probably not the best place for it.
nemo
parents:
2699
diff
changeset
|
179 |
|
14787
cbdfc5b1d5b8
Don't show hog health in gfInvulnerable mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14765
diff
changeset
|
180 |
if (GameFlags and gfInvulnerable) <> 0 then |
cbdfc5b1d5b8
Don't show hog health in gfInvulnerable mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14765
diff
changeset
|
181 |
cTagsMask:= cTagsMask and (not htHealth); |
cbdfc5b1d5b8
Don't show hog health in gfInvulnerable mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14765
diff
changeset
|
182 |
|
2908 | 183 |
// if special game flags/settings are changed, add them to the game mode notice window and then show it |
2863 | 184 |
g:= ''; // no text/things to note yet |
2908 | 185 |
|
4883
7cddc9201a1d
added dummy for tardis and ugly icons for tardis and structure
Henek
parents:
4850
diff
changeset
|
186 |
// add custom goals from lua script if there are any |
12787
a6f51ac9a3f2
Fix bad LuaGoals comparison for pas2c builds
Wuzzy <Wuzzy2@mail.ru>
parents:
12719
diff
changeset
|
187 |
if LuaGoals <> ansistring('') then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
188 |
g:= LuaGoals + '|'; |
4883
7cddc9201a1d
added dummy for tardis and ugly icons for tardis and structure
Henek
parents:
4850
diff
changeset
|
189 |
|
12072
10aad1cafc10
Game mode messages: New messages for PlaceHog+King; All messages get a colon to get highlighted; Reorder messages more logically
Wuzzy <almikes@aol.com>
parents:
11940
diff
changeset
|
190 |
// check different game flags |
2958 | 191 |
g:= AddGoal(g, gfKing, gidKing); // king? |
12072
10aad1cafc10
Game mode messages: New messages for PlaceHog+King; All messages get a colon to get highlighted; Reorder messages more logically
Wuzzy <almikes@aol.com>
parents:
11940
diff
changeset
|
192 |
if ((GameFlags and gfKing) <> 0) and ((GameFlags and gfPlaceHog) = 0) then |
10aad1cafc10
Game mode messages: New messages for PlaceHog+King; All messages get a colon to get highlighted; Reorder messages more logically
Wuzzy <almikes@aol.com>
parents:
11940
diff
changeset
|
193 |
g:= AddGoal(g, gfAny, gidPlaceKing); |
15091
57f7d89067ef
Use crown icon in mission panel for King Mode
Wuzzy <Wuzzy2@mail.ru>
parents:
15073
diff
changeset
|
194 |
g:= AddGoal(g, gfPlaceHog, gidPlaceHog); // placement? |
5022
d2a2f6c9b236
some final work and buggfix for Tag Team, it is now playable
Henek
parents:
4976
diff
changeset
|
195 |
g:= AddGoal(g, gfTagTeam, gidTagTeam); // tag team mode? |
12072
10aad1cafc10
Game mode messages: New messages for PlaceHog+King; All messages get a colon to get highlighted; Reorder messages more logically
Wuzzy <almikes@aol.com>
parents:
11940
diff
changeset
|
196 |
g:= AddGoal(g, gfSharedAmmo, gidSharedAmmo); // shared ammo? |
10aad1cafc10
Game mode messages: New messages for PlaceHog+King; All messages get a colon to get highlighted; Reorder messages more logically
Wuzzy <almikes@aol.com>
parents:
11940
diff
changeset
|
197 |
g:= AddGoal(g, gfPerHogAmmo, gidPerHogAmmo); |
12257
b46b4ec17f8c
Add back "more wind" modifier into mission panel. Fixes regression in 10aad1cafc10
Wuzzy <almikes@aol.com>
parents:
12210
diff
changeset
|
198 |
g:= AddGoal(g, gfMoreWind, gidMoreWind); |
2958 | 199 |
g:= AddGoal(g, gfLowGravity, gidLowGravity); // low gravity? |
12072
10aad1cafc10
Game mode messages: New messages for PlaceHog+King; All messages get a colon to get highlighted; Reorder messages more logically
Wuzzy <almikes@aol.com>
parents:
11940
diff
changeset
|
200 |
g:= AddGoal(g, gfSolidLand, gidSolidLand); // solid land? |
2958 | 201 |
g:= AddGoal(g, gfArtillery, gidArtillery); // artillery? |
4132 | 202 |
g:= AddGoal(g, gfInfAttack, gidInfAttack); |
203 |
g:= AddGoal(g, gfResetWeps, gidResetWeps); |
|
12072
10aad1cafc10
Game mode messages: New messages for PlaceHog+King; All messages get a colon to get highlighted; Reorder messages more logically
Wuzzy <almikes@aol.com>
parents:
11940
diff
changeset
|
204 |
g:= AddGoal(g, gfResetHealth, gidResetHealth); |
10aad1cafc10
Game mode messages: New messages for PlaceHog+King; All messages get a colon to get highlighted; Reorder messages more logically
Wuzzy <almikes@aol.com>
parents:
11940
diff
changeset
|
205 |
g:= AddGoal(g, gfKarma, gidKarma); // karma? |
10aad1cafc10
Game mode messages: New messages for PlaceHog+King; All messages get a colon to get highlighted; Reorder messages more logically
Wuzzy <almikes@aol.com>
parents:
11940
diff
changeset
|
206 |
g:= AddGoal(g, gfVampiric, gidVampiric); // vampirism? |
10aad1cafc10
Game mode messages: New messages for PlaceHog+King; All messages get a colon to get highlighted; Reorder messages more logically
Wuzzy <almikes@aol.com>
parents:
11940
diff
changeset
|
207 |
g:= AddGoal(g, gfInvulnerable, gidInvulnerable); // invulnerability? |
10aad1cafc10
Game mode messages: New messages for PlaceHog+King; All messages get a colon to get highlighted; Reorder messages more logically
Wuzzy <almikes@aol.com>
parents:
11940
diff
changeset
|
208 |
g:= AddGoal(g, gfAISurvival, gidAISurvival); |
2958 | 209 |
|
2908 | 210 |
// modified damage modificator? |
211 |
if cDamagePercent <> 100 then |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
212 |
g:= AddGoal(g, gfAny, gidDamageModifier, cDamagePercent); |
2908 | 213 |
|
3107 | 214 |
// fade in |
215 |
ScreenFade:= sfFromBlack; |
|
216 |
ScreenFadeValue:= sfMax; |
|
217 |
ScreenFadeSpeed:= 1; |
|
218 |
||
2908 | 219 |
// modified mine timers? |
4482 | 220 |
if cMinesTime <> 3000 then |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
221 |
begin |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
222 |
if cMinesTime = 0 then |
4003
ca0600ab38bf
disable gfMines and update variable names (landadds -> minesnum, cLandAdditions -> cLandMines)
koda
parents:
3976
diff
changeset
|
223 |
g:= AddGoal(g, gfAny, gidNoMineTimer) |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
224 |
else if cMinesTime < 0 then |
4003
ca0600ab38bf
disable gfMines and update variable names (landadds -> minesnum, cLandAdditions -> cLandMines)
koda
parents:
3976
diff
changeset
|
225 |
g:= AddGoal(g, gfAny, gidRandomMineTimer) |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
226 |
else |
4482 | 227 |
g:= AddGoal(g, gfAny, gidMineTimer, cMinesTime div 1000); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
228 |
end; |
2908 | 229 |
|
2863 | 230 |
// if the string has been set, show it for (default timeframe) seconds |
10120 | 231 |
if length(g) > 0 then |
15091
57f7d89067ef
Use crown icon in mission panel for King Mode
Wuzzy <Wuzzy2@mail.ru>
parents:
15073
diff
changeset
|
232 |
// choose icon |
57f7d89067ef
Use crown icon in mission panel for King Mode
Wuzzy <Wuzzy2@mail.ru>
parents:
15073
diff
changeset
|
233 |
if ((GameFlags and gfKing) <> 0) then |
57f7d89067ef
Use crown icon in mission panel for King Mode
Wuzzy <Wuzzy2@mail.ru>
parents:
15073
diff
changeset
|
234 |
// crown icon for King Mode |
57f7d89067ef
Use crown icon in mission panel for King Mode
Wuzzy <Wuzzy2@mail.ru>
parents:
15073
diff
changeset
|
235 |
ShowMission(trgoal[gidCaption], trgoal[gidSubCaption], g, 0, 0) |
57f7d89067ef
Use crown icon in mission panel for King Mode
Wuzzy <Wuzzy2@mail.ru>
parents:
15073
diff
changeset
|
236 |
else |
57f7d89067ef
Use crown icon in mission panel for King Mode
Wuzzy <Wuzzy2@mail.ru>
parents:
15073
diff
changeset
|
237 |
// target icon for anything else |
57f7d89067ef
Use crown icon in mission panel for King Mode
Wuzzy <Wuzzy2@mail.ru>
parents:
15073
diff
changeset
|
238 |
ShowMission(trgoal[gidCaption], trgoal[gidSubCaption], g, 1, 0); |
2863 | 239 |
|
2268
053eb81e60ee
little experiment to see if this improve appearance of laser/ufo/cake/laser guided missile - of course, can't actually see it until unc0rr restores waves
nemo
parents:
2226
diff
changeset
|
240 |
cWaveHeight:= 32; |
2292
87af4ad0ec98
New waves rendering procedure based on using texture coodrinates > 1.0
unc0rr
parents:
2290
diff
changeset
|
241 |
|
5682
06d5f561f772
some camera adjustments (should also fix cam flickering on lowerst res)
sheepluva
parents:
5675
diff
changeset
|
242 |
InitCameraBorders(); |
5191
c7000a6b397b
- Implement a thin wrapper over real cursor, which eliminates need in SDL_WarpMouse outside game window
unc0rr
parents:
5149
diff
changeset
|
243 |
uCursor.init(); |
2197 | 244 |
prevPoint.X:= 0; |
74 | 245 |
prevPoint.Y:= cScreenHeight div 2; |
15170 | 246 |
WorldDx:= -(LongInt(leftX + (playWidth div 2))); |
6609 | 247 |
WorldDy:= -(LAND_HEIGHT - (playHeight div 2)) + (cScreenHeight div 2); |
248 |
||
249 |
//aligns it to the bottom of the screen, minus the border |
|
250 |
SkyOffset:= 0; |
|
251 |
HorizontOffset:= 0; |
|
252 |
||
6682 | 253 |
InitTouchInterface(); |
6796
3e89dbdc7db9
You can now change AMAnimType to enable the animation through the x/y axis and alpha for example
Xeli
parents:
6795
diff
changeset
|
254 |
AMAnimType:= AMTypeMaskX or AMTypeMaskAlpha; |
6682 | 255 |
end; |
256 |
||
257 |
procedure InitCameraBorders; |
|
258 |
begin |
|
259 |
cGearScrEdgesDist:= min(2 * cScreenHeight div 5, 2 * cScreenWidth div 5); |
|
260 |
end; |
|
261 |
||
262 |
procedure InitTouchInterface; |
|
263 |
begin |
|
6676
21cf35a570a7
add keywords for landscape ammomenu and touch interface
koda
parents:
6652
diff
changeset
|
264 |
{$IFDEF USE_TOUCH_INTERFACE} |
7167
0b3b306f129a
Android: added a callback to java to determine dpi/dip how much we should scale the ui
Xeli
parents:
7086
diff
changeset
|
265 |
|
6637
b4a3310f2974
show buttons on the screen, similar to the iOS overlay
Xeli
parents:
6631
diff
changeset
|
266 |
//positioning of the buttons |
9377 | 267 |
buttonScale:= 1 / cDefaultZoomLevel; |
6683
75a1d84ac606
small refactoring to touch screen buttons, use a record to store values, added 'offset' fields to adjust active button area
koda
parents:
6682
diff
changeset
|
268 |
|
6714
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
269 |
|
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
270 |
with JumpWidget do |
6695
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
271 |
begin |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
272 |
show:= true; |
6714
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
273 |
sprite:= sprJumpWidget; |
6695
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
274 |
frame.w:= Round(spritesData[sprite].Texture^.w * buttonScale); |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
275 |
frame.h:= Round(spritesData[sprite].Texture^.h * buttonScale); |
6714
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
276 |
frame.x:= (cScreenWidth shr 1) - Round(frame.w * 1.2); |
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
277 |
frame.y:= cScreenHeight - frame.h * 2; |
6710
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
278 |
active.x:= frame.x; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
279 |
active.y:= frame.y; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
280 |
active.w:= frame.w; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
281 |
active.h:= frame.h; |
6695
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
282 |
end; |
6637
b4a3310f2974
show buttons on the screen, similar to the iOS overlay
Xeli
parents:
6631
diff
changeset
|
283 |
|
6714
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
284 |
with AMWidget do |
6695
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
285 |
begin |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
286 |
show:= true; |
6714
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
287 |
sprite:= sprAMWidget; |
6695
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
288 |
frame.w:= Round(spritesData[sprite].Texture^.w * buttonScale); |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
289 |
frame.h:= Round(spritesData[sprite].Texture^.h * buttonScale); |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
290 |
frame.x:= (cScreenWidth shr 1) - frame.w * 2; |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
291 |
frame.y:= cScreenHeight - Round(frame.h * 1.2); |
6710
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
292 |
active.x:= frame.x; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
293 |
active.y:= frame.y; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
294 |
active.w:= frame.w; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
295 |
active.h:= frame.h; |
6695
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
296 |
end; |
6637
b4a3310f2974
show buttons on the screen, similar to the iOS overlay
Xeli
parents:
6631
diff
changeset
|
297 |
|
6688 | 298 |
with arrowLeft do |
299 |
begin |
|
300 |
show:= true; |
|
301 |
sprite:= sprArrowLeft; |
|
6695
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
302 |
frame.w:= Round(spritesData[sprite].Texture^.w * buttonScale); |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
303 |
frame.h:= Round(spritesData[sprite].Texture^.h * buttonScale); |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
304 |
frame.x:= -(cScreenWidth shr 1) + Round(frame.w * 0.25); |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
305 |
frame.y:= cScreenHeight - Round(frame.h * 1.5); |
6710
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
306 |
active.x:= frame.x; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
307 |
active.y:= frame.y; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
308 |
active.w:= frame.w; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
309 |
active.h:= frame.h; |
6688 | 310 |
end; |
6695
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
311 |
|
6688 | 312 |
with arrowRight do |
313 |
begin |
|
314 |
show:= true; |
|
315 |
sprite:= sprArrowRight; |
|
6695
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
316 |
frame.w:= Round(spritesData[sprite].Texture^.w * buttonScale); |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
317 |
frame.h:= Round(spritesData[sprite].Texture^.h * buttonScale); |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
318 |
frame.x:= -(cScreenWidth shr 1) + Round(frame.w * 1.5); |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
319 |
frame.y:= cScreenHeight - Round(frame.h * 1.5); |
6710
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
320 |
active.x:= frame.x; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
321 |
active.y:= frame.y; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
322 |
active.w:= frame.w; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
323 |
active.h:= frame.h; |
6688 | 324 |
end; |
6637
b4a3310f2974
show buttons on the screen, similar to the iOS overlay
Xeli
parents:
6631
diff
changeset
|
325 |
|
6714
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
326 |
with firebutton do |
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
327 |
begin |
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
328 |
show:= true; |
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
329 |
sprite:= sprFireButton; |
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
330 |
frame.w:= Round(spritesData[sprite].Texture^.w * buttonScale); |
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
331 |
frame.h:= Round(spritesData[sprite].Texture^.h * buttonScale); |
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
332 |
frame.x:= arrowRight.frame.x + arrowRight.frame.w; |
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
333 |
frame.y:= arrowRight.frame.y + (arrowRight.frame.w shr 1) - (frame.w shr 1); |
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
334 |
active.x:= frame.x; |
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
335 |
active.y:= frame.y; |
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
336 |
active.w:= frame.w; |
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
337 |
active.h:= frame.h; |
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
338 |
end; |
f2f93017132c
moved the firebutton, added the AMWidget button and removed the forwardjump widget(it's longpress on backjump now)
Xeli
parents:
6710
diff
changeset
|
339 |
|
6688 | 340 |
with arrowUp do |
341 |
begin |
|
342 |
show:= false; |
|
343 |
sprite:= sprArrowUp; |
|
6695
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
344 |
frame.w:= Round(spritesData[sprite].Texture^.w * buttonScale); |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
345 |
frame.h:= Round(spritesData[sprite].Texture^.h * buttonScale); |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
346 |
frame.x:= (cScreenWidth shr 1) - frame.w * 2; |
6798 | 347 |
frame.y:= jumpWidget.frame.y - Round(frame.h * 1.25); |
6710
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
348 |
active.x:= frame.x; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
349 |
active.y:= frame.y; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
350 |
active.w:= frame.w; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
351 |
active.h:= frame.h; |
6688 | 352 |
with moveAnim do |
353 |
begin |
|
6695
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
354 |
target.x:= frame.x; |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
355 |
target.y:= frame.y; |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
356 |
source.x:= frame.x - Round(frame.w * 0.75); |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
357 |
source.y:= frame.y; |
6688 | 358 |
end; |
359 |
end; |
|
6637
b4a3310f2974
show buttons on the screen, similar to the iOS overlay
Xeli
parents:
6631
diff
changeset
|
360 |
|
6688 | 361 |
with arrowDown do |
362 |
begin |
|
363 |
show:= false; |
|
364 |
sprite:= sprArrowDown; |
|
6695
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
365 |
frame.w:= Round(spritesData[sprite].Texture^.w * buttonScale); |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
366 |
frame.h:= Round(spritesData[sprite].Texture^.h * buttonScale); |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
367 |
frame.x:= (cScreenWidth shr 1) - frame.w * 2; |
6798 | 368 |
frame.y:= jumpWidget.frame.y - Round(frame.h * 1.25); |
6710
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
369 |
active.x:= frame.x; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
370 |
active.y:= frame.y; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
371 |
active.w:= frame.w; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
372 |
active.h:= frame.h; |
6688 | 373 |
with moveAnim do |
374 |
begin |
|
6695
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
375 |
target.x:= frame.x; |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
376 |
target.y:= frame.y; |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
377 |
source.x:= frame.x + Round(frame.w * 0.75); |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
378 |
source.y:= frame.y; |
6688 | 379 |
end; |
380 |
end; |
|
6685
ef706fccfb0a
moved other widgets under the USE_TOUCH_INTERFACE, added pause button (at least, graphically...)
koda
parents:
6683
diff
changeset
|
381 |
|
6695
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
382 |
with pauseButton do |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
383 |
begin |
14324 | 384 |
show:= true; |
6695
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
385 |
sprite:= sprPauseButton; |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
386 |
frame.w:= Round(spritesData[sprPauseButton].Texture^.w * buttonScale); |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
387 |
frame.h:= Round(spritesData[sprPauseButton].Texture^.h * buttonScale); |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
388 |
frame.x:= cScreenWidth div 2 - frame.w; |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
389 |
frame.y:= 0; |
6710
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
390 |
active.x:= frame.x; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
391 |
active.y:= frame.y; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
392 |
active.w:= frame.w; |
42504695122d
fixed the active region on widgets when they are animated, added active.x:= in uWorld too
Xeli
parents:
6706
diff
changeset
|
393 |
active.h:= frame.h; |
6695
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
394 |
end; |
6685
ef706fccfb0a
moved other widgets under the USE_TOUCH_INTERFACE, added pause button (at least, graphically...)
koda
parents:
6683
diff
changeset
|
395 |
|
6806
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
396 |
with utilityWidget do |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
397 |
begin |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
398 |
show:= false; |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
399 |
sprite:= sprTimerButton; |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
400 |
frame.w:= Round(spritesData[sprite].Texture^.w * buttonScale); |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
401 |
frame.h:= Round(spritesData[sprite].Texture^.h * buttonScale); |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
402 |
frame.x:= arrowLeft.frame.x; |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
403 |
frame.y:= arrowLeft.frame.y - Round(frame.h * 1.25); |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
404 |
active.x:= frame.x; |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
405 |
active.y:= frame.y; |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
406 |
active.w:= frame.w; |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
407 |
active.h:= frame.h; |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
408 |
with moveAnim do |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
409 |
begin |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
410 |
target.x:= frame.x; |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
411 |
target.y:= frame.y; |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
412 |
source.x:= frame.x; |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
413 |
source.y:= frame.y; |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
414 |
end; |
cdfb6c7099e5
first part of the utilitywidget (grenade timer/swap hogs) code
Xeli
parents:
6802
diff
changeset
|
415 |
end; |
14559
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
416 |
|
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
417 |
with utilityWidget2 do |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
418 |
begin |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
419 |
show:= false; |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
420 |
sprite:= sprBounceButton; |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
421 |
frame.w:= Round(spritesData[sprite].Texture^.w * buttonScale); |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
422 |
frame.h:= Round(spritesData[sprite].Texture^.h * buttonScale); |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
423 |
frame.x:= utilityWidget.frame.x + Round(frame.w * 1.25); |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
424 |
frame.y:= arrowLeft.frame.y - Round(frame.h * 1.25); |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
425 |
active.x:= frame.x; |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
426 |
active.y:= frame.y; |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
427 |
active.w:= frame.w; |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
428 |
active.h:= frame.h; |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
429 |
with moveAnim do |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
430 |
begin |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
431 |
target.x:= frame.x; |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
432 |
target.y:= frame.y; |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
433 |
source.x:= frame.x; |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
434 |
source.y:= frame.y; |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
435 |
end; |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
436 |
end; |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
437 |
|
6637
b4a3310f2974
show buttons on the screen, similar to the iOS overlay
Xeli
parents:
6631
diff
changeset
|
438 |
{$ENDIF} |
161 | 439 |
end; |
440 |
||
6394
f0a9042e7387
yay, finally osx (and likely windows) fullscreen switch works like on linux! ALL textures had to be destroyed and recreated only after the new window got created. In other news, the new window must be cleaned with glClear to skip a first frame of garbage and AddProgress is only called the first time.
koda
parents:
6380
diff
changeset
|
441 |
// for uStore texture resetting |
f0a9042e7387
yay, finally osx (and likely windows) fullscreen switch works like on linux! ALL textures had to be destroyed and recreated only after the new window got created. In other news, the new window must be cleaned with glClear to skip a first frame of garbage and AddProgress is only called the first time.
koda
parents:
6380
diff
changeset
|
442 |
procedure ResetWorldTex; |
f0a9042e7387
yay, finally osx (and likely windows) fullscreen switch works like on linux! ALL textures had to be destroyed and recreated only after the new window got created. In other news, the new window must be cleaned with glClear to skip a first frame of garbage and AddProgress is only called the first time.
koda
parents:
6380
diff
changeset
|
443 |
begin |
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:
10628
diff
changeset
|
444 |
FreeAndNilTexture(fpsTexture); |
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:
10628
diff
changeset
|
445 |
FreeAndNilTexture(timeTexture); |
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:
10628
diff
changeset
|
446 |
FreeAndNilTexture(missionTex); |
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:
10628
diff
changeset
|
447 |
FreeAndNilTexture(recTexture); |
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:
10628
diff
changeset
|
448 |
FreeAndNilTexture(AmmoMenuTex); |
9983 | 449 |
AmmoMenuInvalidated:= true; |
6394
f0a9042e7387
yay, finally osx (and likely windows) fullscreen switch works like on linux! ALL textures had to be destroyed and recreated only after the new window got created. In other news, the new window must be cleaned with glClear to skip a first frame of garbage and AddProgress is only called the first time.
koda
parents:
6380
diff
changeset
|
450 |
end; |
f0a9042e7387
yay, finally osx (and likely windows) fullscreen switch works like on linux! ALL textures had to be destroyed and recreated only after the new window got created. In other news, the new window must be cleaned with glClear to skip a first frame of garbage and AddProgress is only called the first time.
koda
parents:
6380
diff
changeset
|
451 |
|
6622 | 452 |
function GetAmmoMenuTexture(Ammo: PHHAmmo): PTexture; |
3434 | 453 |
const BORDERSIZE = 2; |
6622 | 454 |
var x, y, i, t, SlotsNumY, SlotsNumX, AMFrame: LongInt; |
455 |
STurns: LongInt; |
|
456 |
amSurface: PSDL_Surface; |
|
457 |
AMRect: TSDL_Rect; |
|
14432
71359339a493
Ammo menu: Show number instead F1, etc. if slot keys differ from default or in Touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14430
diff
changeset
|
458 |
{$IFDEF USE_AM_NUMCOLUMN} |
71359339a493
Ammo menu: Show number instead F1, etc. if slot keys differ from default or in Touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14430
diff
changeset
|
459 |
tmpsurf: PSDL_Surface; |
71359339a493
Ammo menu: Show number instead F1, etc. if slot keys differ from default or in Touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14430
diff
changeset
|
460 |
usesDefaultSlotKeys: boolean; |
71359339a493
Ammo menu: Show number instead F1, etc. if slot keys differ from default or in Touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14430
diff
changeset
|
461 |
{$ENDIF} |
161 | 462 |
begin |
10141 | 463 |
if cOnlyStats then exit(nil); |
10139 | 464 |
|
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
465 |
SlotsNum:= 0; |
6606
fb6163ff4ebf
changed the ammomenu to be landscape for MOBILE, also tweaked the positions a bit, needs testing on iOS
Xeli
parents:
6603
diff
changeset
|
466 |
for i:= 0 to cMaxSlotIndex do |
12719
637b1987570e
Fix first ammo row being invisible when there's only one weapon in the first row
Wuzzy <almikes@aol.com>
parents:
12708
diff
changeset
|
467 |
if (i <> cHiddenSlotIndex) and (Ammo^[i, 0].Count > 0) then |
6606
fb6163ff4ebf
changed the ammomenu to be landscape for MOBILE, also tweaked the positions a bit, needs testing on iOS
Xeli
parents:
6603
diff
changeset
|
468 |
inc(SlotsNum); |
6676
21cf35a570a7
add keywords for landscape ammomenu and touch interface
koda
parents:
6652
diff
changeset
|
469 |
{$IFDEF USE_LANDSCAPE_AMMOMENU} |
6622 | 470 |
SlotsNumX:= SlotsNum; |
471 |
SlotsNumY:= cMaxSlotAmmoIndex + 2; |
|
6899 | 472 |
{$IFDEF USE_AM_NUMCOLUMN} |
473 |
inc(SlotsNumY); |
|
474 |
{$ENDIF} |
|
6622 | 475 |
{$ELSE} |
476 |
SlotsNumX:= cMaxSlotAmmoIndex + 1; |
|
477 |
SlotsNumY:= SlotsNum + 1; |
|
6899 | 478 |
{$IFDEF USE_AM_NUMCOLUMN} |
479 |
inc(SlotsNumX); |
|
480 |
{$ENDIF} |
|
6622 | 481 |
{$ENDIF} |
6606
fb6163ff4ebf
changed the ammomenu to be landscape for MOBILE, also tweaked the positions a bit, needs testing on iOS
Xeli
parents:
6603
diff
changeset
|
482 |
|
6899 | 483 |
|
6631 | 484 |
AmmoRect.w:= (BORDERSIZE*2) + (SlotsNumX * AMSlotSize) + (SlotsNumX-1); |
485 |
AmmoRect.h:= (BORDERSIZE*2) + (SlotsNumY * AMSlotSize) + (SlotsNumY-1); |
|
486 |
amSurface := SDL_CreateRGBSurface(SDL_SWSURFACE, AmmoRect.w, AmmoRect.h, 32, RMask, GMask, BMask, AMask); |
|
8330 | 487 |
|
6622 | 488 |
AMRect.x:= BORDERSIZE; |
489 |
AMRect.y:= BORDERSIZE; |
|
6631 | 490 |
AMRect.w:= AmmoRect.w - (BORDERSIZE*2); |
491 |
AMRect.h:= AmmoRect.h - (BORDERSIZE*2); |
|
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
492 |
|
6622 | 493 |
SDL_FillRect(amSurface, @AMRect, SDL_MapRGB(amSurface^.format, 0,0,0)); |
8330 | 494 |
|
6650
56a0b7bf6c15
fixed the blackpixel in the ammomenu, x,y in GetAmmoMenuTexture now initialized correctly
Xeli
parents:
6648
diff
changeset
|
495 |
x:= AMRect.x; |
56a0b7bf6c15
fixed the blackpixel in the ammomenu, x,y in GetAmmoMenuTexture now initialized correctly
Xeli
parents:
6648
diff
changeset
|
496 |
y:= AMRect.y; |
14432
71359339a493
Ammo menu: Show number instead F1, etc. if slot keys differ from default or in Touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14430
diff
changeset
|
497 |
{$IFDEF USE_AM_NUMCOLUMN} |
71359339a493
Ammo menu: Show number instead F1, etc. if slot keys differ from default or in Touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14430
diff
changeset
|
498 |
usesDefaultSlotKeys:= CheckDefaultSlotKeys; |
71359339a493
Ammo menu: Show number instead F1, etc. if slot keys differ from default or in Touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14430
diff
changeset
|
499 |
{$ENDIF USE_AM_NUMCOLUMN} |
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
500 |
for i:= 0 to cMaxSlotIndex do |
12719
637b1987570e
Fix first ammo row being invisible when there's only one weapon in the first row
Wuzzy <almikes@aol.com>
parents:
12708
diff
changeset
|
501 |
if (i <> cHiddenSlotIndex) and (Ammo^[i, 0].Count > 0) then |
3434 | 502 |
begin |
6676
21cf35a570a7
add keywords for landscape ammomenu and touch interface
koda
parents:
6652
diff
changeset
|
503 |
{$IFDEF USE_LANDSCAPE_AMMOMENU} |
6650
56a0b7bf6c15
fixed the blackpixel in the ammomenu, x,y in GetAmmoMenuTexture now initialized correctly
Xeli
parents:
6648
diff
changeset
|
504 |
y:= AMRect.y; |
6622 | 505 |
{$ELSE} |
6650
56a0b7bf6c15
fixed the blackpixel in the ammomenu, x,y in GetAmmoMenuTexture now initialized correctly
Xeli
parents:
6648
diff
changeset
|
506 |
x:= AMRect.x; |
6622 | 507 |
{$ENDIF} |
6899 | 508 |
{$IFDEF USE_AM_NUMCOLUMN} |
14432
71359339a493
Ammo menu: Show number instead F1, etc. if slot keys differ from default or in Touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14430
diff
changeset
|
509 |
// Ammo slot number column |
71359339a493
Ammo menu: Show number instead F1, etc. if slot keys differ from default or in Touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14430
diff
changeset
|
510 |
if usesDefaultSlotKeys then |
71359339a493
Ammo menu: Show number instead F1, etc. if slot keys differ from default or in Touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14430
diff
changeset
|
511 |
// F1, F2, F3, F4, ... |
71359339a493
Ammo menu: Show number instead F1, etc. if slot keys differ from default or in Touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14430
diff
changeset
|
512 |
tmpsurf:= TTF_RenderUTF8_Blended(Fontz[fnt16].Handle, Str2PChar('F'+IntToStr(i+1)), cWhiteColorChannels) |
71359339a493
Ammo menu: Show number instead F1, etc. if slot keys differ from default or in Touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14430
diff
changeset
|
513 |
else |
71359339a493
Ammo menu: Show number instead F1, etc. if slot keys differ from default or in Touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14430
diff
changeset
|
514 |
// 1, 2, 3, 4, ... |
71359339a493
Ammo menu: Show number instead F1, etc. if slot keys differ from default or in Touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14430
diff
changeset
|
515 |
tmpsurf:= TTF_RenderUTF8_Blended(Fontz[fnt16].Handle, Str2PChar(IntToStr(i+1)), cWhiteColorChannels); |
6899 | 516 |
copyToXY(tmpsurf, amSurface, |
517 |
x + AMSlotPadding + (AMSlotSize shr 1) - (tmpsurf^.w shr 1), |
|
518 |
y + AMSlotPadding + (AMSlotSize shr 1) - (tmpsurf^.h shr 1)); |
|
519 |
||
520 |
SDL_FreeSurface(tmpsurf); |
|
521 |
{$IFDEF USE_LANDSCAPE_AMMOMENU} |
|
522 |
y:= AMRect.y + AMSlotSize + 1; |
|
523 |
{$ELSE} |
|
524 |
x:= AMRect.x + AMSlotSize + 1; |
|
525 |
{$ENDIF} |
|
526 |
{$ENDIF} |
|
527 |
||
528 |
||
6606
fb6163ff4ebf
changed the ammomenu to be landscape for MOBILE, also tweaked the positions a bit, needs testing on iOS
Xeli
parents:
6603
diff
changeset
|
529 |
for t:=0 to cMaxSlotAmmoIndex do |
3434 | 530 |
begin |
6622 | 531 |
if (Ammo^[i, t].Count > 0) and (Ammo^[i, t].AmmoType <> amNothing) then |
3434 | 532 |
begin |
6622 | 533 |
STurns:= Ammoz[Ammo^[i, t].AmmoType].SkipTurns - CurrentTeam^.Clan^.TurnNumber; |
534 |
AMFrame:= LongInt(Ammo^[i,t].AmmoType) - 1; |
|
535 |
if STurns >= 0 then //weapon not usable yet, draw grayed out with turns remaining |
|
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
536 |
begin |
8330 | 537 |
DrawSpriteFrame2Surf(sprAMAmmosBW, amSurface, x + AMSlotPadding, |
6650
56a0b7bf6c15
fixed the blackpixel in the ammomenu, x,y in GetAmmoMenuTexture now initialized correctly
Xeli
parents:
6648
diff
changeset
|
538 |
y + AMSlotPadding, AMFrame); |
6622 | 539 |
if STurns < 100 then |
8330 | 540 |
DrawSpriteFrame2Surf(sprTurnsLeft, amSurface, |
541 |
x + AMSlotSize-16, |
|
7013 | 542 |
y + AMSlotSize + 1 - 16, STurns); |
6622 | 543 |
end |
544 |
else //draw colored version |
|
545 |
begin |
|
8330 | 546 |
DrawSpriteFrame2Surf(sprAMAmmos, amSurface, x + AMSlotPadding, |
6899 | 547 |
y + AMSlotPadding, AMFrame); |
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
548 |
end; |
6676
21cf35a570a7
add keywords for landscape ammomenu and touch interface
koda
parents:
6652
diff
changeset
|
549 |
{$IFDEF USE_LANDSCAPE_AMMOMENU} |
8330 | 550 |
inc(y, AMSlotSize + 1); //the plus one is for the border |
6622 | 551 |
{$ELSE} |
8330 | 552 |
inc(x, AMSlotSize + 1); |
6622 | 553 |
{$ENDIF} |
8330 | 554 |
end; |
555 |
end; |
|
6676
21cf35a570a7
add keywords for landscape ammomenu and touch interface
koda
parents:
6652
diff
changeset
|
556 |
{$IFDEF USE_LANDSCAPE_AMMOMENU} |
6622 | 557 |
inc(x, AMSlotSize + 1); |
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
558 |
{$ELSE} |
6622 | 559 |
inc(y, AMSlotSize + 1); |
560 |
{$ENDIF} |
|
561 |
end; |
|
562 |
||
563 |
for i:= 1 to SlotsNumX -1 do |
|
8330 | 564 |
DrawLine2Surf(amSurface, i * (AMSlotSize+1)+1, BORDERSIZE, i * (AMSlotSize+1)+1, AMRect.h + BORDERSIZE - AMSlotSize - 2,160,160,160); |
6622 | 565 |
for i:= 1 to SlotsNumY -1 do |
6652 | 566 |
DrawLine2Surf(amSurface, BORDERSIZE, i * (AMSlotSize+1)+1, AMRect.w + BORDERSIZE, i * (AMSlotSize+1)+1,160,160,160); |
6622 | 567 |
|
568 |
//draw outer border |
|
7013 | 569 |
DrawSpriteFrame2Surf(sprAMCorners, amSurface, 0 , 0 , 0); |
570 |
DrawSpriteFrame2Surf(sprAMCorners, amSurface, AMRect.w + BORDERSIZE, AMRect.y , 1); |
|
571 |
DrawSpriteFrame2Surf(sprAMCorners, amSurface, AMRect.x , AMRect.h + BORDERSIZE, 2); |
|
572 |
DrawSpriteFrame2Surf(sprAMCorners, amSurface, AMRect.w + BORDERSIZE, AMRect.h + BORDERSIZE, 3); |
|
6622 | 573 |
|
574 |
for i:=0 to BORDERSIZE-1 do |
|
575 |
begin |
|
576 |
DrawLine2Surf(amSurface, BORDERSIZE, i, AMRect.w + BORDERSIZE, i,160,160,160);//top |
|
577 |
DrawLine2Surf(amSurface, BORDERSIZE, AMRect.h+BORDERSIZE+i, AMRect.w + BORDERSIZE, AMRect.h+BORDERSIZE+i,160,160,160);//bottom |
|
578 |
DrawLine2Surf(amSurface, i, BORDERSIZE, i, AMRect.h + BORDERSIZE,160,160,160);//left |
|
579 |
DrawLine2Surf(amSurface, AMRect.w+BORDERSIZE+i, BORDERSIZE, AMRect.w + BORDERSIZE+i, AMRect.h + BORDERSIZE, 160,160,160);//right |
|
580 |
end; |
|
581 |
||
582 |
GetAmmoMenuTexture:= Surface2Tex(amSurface, false); |
|
583 |
if amSurface <> nil then SDL_FreeSurface(amSurface); |
|
584 |
end; |
|
585 |
||
586 |
procedure ShowAmmoMenu; |
|
587 |
const BORDERSIZE = 2; |
|
588 |
var Slot, Pos: LongInt; |
|
589 |
Ammo: PHHAmmo; |
|
6648
025473a2c420
prevent the cursor from being shown on the mobile version, and close the menu on tap when the tap is not on the ammo menu
Xeli
parents:
6647
diff
changeset
|
590 |
c,i,g,t,STurns: LongInt; |
6622 | 591 |
begin |
7946
a99a79bbd857
Simplify ammo menu conditions so it shows up in more states. Should fix issue #465. The part w/ sliding in uworld is main #465 problem.
nemo
parents:
7858
diff
changeset
|
592 |
if TurnTimeLeft = 0 then bShowAmmoMenu:= false; |
6622 | 593 |
|
594 |
// give the assigned ammo to hedgehog |
|
595 |
Ammo:= nil; |
|
596 |
if (CurrentTeam <> nil) and (CurrentHedgehog <> nil) |
|
597 |
and (not CurrentTeam^.ExtDriven) and (CurrentHedgehog^.BotLevel = 0) then |
|
6918 | 598 |
Ammo:= CurrentHedgehog^.Ammo |
6622 | 599 |
else if (LocalAmmo <> -1) then |
6918 | 600 |
Ammo:= GetAmmoByNum(LocalAmmo); |
6622 | 601 |
Pos:= -1; |
602 |
if Ammo = nil then |
|
6918 | 603 |
begin |
604 |
bShowAmmoMenu:= false; |
|
605 |
AMState:= AMHidden; |
|
606 |
exit |
|
607 |
end; |
|
6622 | 608 |
|
8330 | 609 |
//Init the menu |
610 |
if(AmmoMenuInvalidated) then |
|
6622 | 611 |
begin |
612 |
AmmoMenuInvalidated:= false; |
|
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:
10628
diff
changeset
|
613 |
FreeAndNilTexture(AmmoMenuTex); |
6622 | 614 |
AmmoMenuTex:= GetAmmoMenuTexture(Ammo); |
3697 | 615 |
|
6676
21cf35a570a7
add keywords for landscape ammomenu and touch interface
koda
parents:
6652
diff
changeset
|
616 |
{$IFDEF USE_LANDSCAPE_AMMOMENU} |
6622 | 617 |
if isPhone() then |
618 |
begin |
|
619 |
AmmoRect.x:= -(AmmoRect.w shr 1); |
|
620 |
AmmoRect.y:= (cScreenHeight shr 1) - (AmmoRect.h shr 1); |
|
621 |
end |
|
622 |
else |
|
623 |
begin |
|
624 |
AmmoRect.x:= -(AmmoRect.w shr 1); |
|
625 |
AmmoRect.y:= cScreenHeight - (AmmoRect.h + AMSlotSize); |
|
626 |
end; |
|
627 |
{$ELSE} |
|
628 |
AmmoRect.x:= (cScreenWidth shr 1) - AmmoRect.w - AMSlotSize; |
|
629 |
AmmoRect.y:= cScreenHeight - (AmmoRect.h + AMSlotSize); |
|
630 |
{$ENDIF} |
|
7946
a99a79bbd857
Simplify ammo menu conditions so it shows up in more states. Should fix issue #465. The part w/ sliding in uworld is main #465 problem.
nemo
parents:
7858
diff
changeset
|
631 |
if AMState <> AMShowing then |
a99a79bbd857
Simplify ammo menu conditions so it shows up in more states. Should fix issue #465. The part w/ sliding in uworld is main #465 problem.
nemo
parents:
7858
diff
changeset
|
632 |
begin |
a99a79bbd857
Simplify ammo menu conditions so it shows up in more states. Should fix issue #465. The part w/ sliding in uworld is main #465 problem.
nemo
parents:
7858
diff
changeset
|
633 |
AMShiftTargetX:= (cScreenWidth shr 1) - AmmoRect.x; |
a99a79bbd857
Simplify ammo menu conditions so it shows up in more states. Should fix issue #465. The part w/ sliding in uworld is main #465 problem.
nemo
parents:
7858
diff
changeset
|
634 |
AMShiftTargetY:= cScreenHeight - AmmoRect.y; |
6802 | 635 |
|
7946
a99a79bbd857
Simplify ammo menu conditions so it shows up in more states. Should fix issue #465. The part w/ sliding in uworld is main #465 problem.
nemo
parents:
7858
diff
changeset
|
636 |
if (AMAnimType and AMTypeMaskX) <> 0 then AMShiftTargetX:= (cScreenWidth shr 1) - AmmoRect.x |
a99a79bbd857
Simplify ammo menu conditions so it shows up in more states. Should fix issue #465. The part w/ sliding in uworld is main #465 problem.
nemo
parents:
7858
diff
changeset
|
637 |
else AMShiftTargetX:= 0; |
a99a79bbd857
Simplify ammo menu conditions so it shows up in more states. Should fix issue #465. The part w/ sliding in uworld is main #465 problem.
nemo
parents:
7858
diff
changeset
|
638 |
if (AMAnimType and AMTypeMaskY) <> 0 then AMShiftTargetY:= cScreenHeight - AmmoRect.y |
a99a79bbd857
Simplify ammo menu conditions so it shows up in more states. Should fix issue #465. The part w/ sliding in uworld is main #465 problem.
nemo
parents:
7858
diff
changeset
|
639 |
else AMShiftTargetY:= 0; |
6802 | 640 |
|
7946
a99a79bbd857
Simplify ammo menu conditions so it shows up in more states. Should fix issue #465. The part w/ sliding in uworld is main #465 problem.
nemo
parents:
7858
diff
changeset
|
641 |
AMShiftX:= AMShiftTargetX; |
a99a79bbd857
Simplify ammo menu conditions so it shows up in more states. Should fix issue #465. The part w/ sliding in uworld is main #465 problem.
nemo
parents:
7858
diff
changeset
|
642 |
AMShiftY:= AMShiftTargetY |
a99a79bbd857
Simplify ammo menu conditions so it shows up in more states. Should fix issue #465. The part w/ sliding in uworld is main #465 problem.
nemo
parents:
7858
diff
changeset
|
643 |
end |
6622 | 644 |
end; |
645 |
||
6795
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
646 |
AMAnimState:= (RealTicks - AMAnimStartTime) / AMAnimDuration; |
6802 | 647 |
|
648 |
if AMState = AMShowing then |
|
649 |
begin |
|
650 |
FollowGear:=nil; |
|
651 |
end; |
|
652 |
||
6795
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
653 |
if AMState = AMShowingUp then // show ammo menu |
6622 | 654 |
begin |
14430
85008b73e118
Skip ammo menu open animation if playing with TurnTime <= 10s
Wuzzy <Wuzzy2@mail.ru>
parents:
14418
diff
changeset
|
655 |
// No "appear" animation in low quality or playing with very short turn time. |
85008b73e118
Skip ammo menu open animation if playing with TurnTime <= 10s
Wuzzy <Wuzzy2@mail.ru>
parents:
14418
diff
changeset
|
656 |
if ((cReducedQuality and rqSlowMenu) <> 0) or (cHedgehogTurnTime <= 10000) then |
6622 | 657 |
begin |
658 |
AMShiftX:= 0; |
|
659 |
AMShiftY:= 0; |
|
15067
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
660 |
CursorPoint.X:= AmmoRect.x + AmmoRect.w - 3; |
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
661 |
CursorPoint.Y:= cScreenHeight - AmmoRect.y - amNumOffsetY - 1; |
6795
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
662 |
AMState:= AMShowing; |
6622 | 663 |
end |
14430
85008b73e118
Skip ammo menu open animation if playing with TurnTime <= 10s
Wuzzy <Wuzzy2@mail.ru>
parents:
14418
diff
changeset
|
664 |
// "Appear" animation |
6622 | 665 |
else |
6795
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
666 |
if AMAnimState < 1 then |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
667 |
begin |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
668 |
AMShiftX:= Round(AMShiftTargetX * (1 - AMAnimState)); |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
669 |
AMShiftY:= Round(AMShiftTargetY * (1 - AMAnimState)); |
8330 | 670 |
if (AMAnimType and AMTypeMaskAlpha) <> 0 then |
6796
3e89dbdc7db9
You can now change AMAnimType to enable the animation through the x/y axis and alpha for example
Xeli
parents:
6795
diff
changeset
|
671 |
Tint($FF, $ff, $ff, Round($ff * AMAnimState)); |
6795
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
672 |
end |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
673 |
else |
6622 | 674 |
begin |
6795
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
675 |
AMShiftX:= 0; |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
676 |
AMShiftY:= 0; |
15067
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
677 |
CursorPoint.X:= AmmoRect.x + AmmoRect.w - 3; |
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
678 |
CursorPoint.Y:= cScreenHeight - AmmoRect.y - amNumOffsetY - 1; |
6795
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
679 |
AMState:= AMShowing; |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
680 |
end; |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
681 |
end; |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
682 |
if AMState = AMHiding then // hide ammo menu |
6622 | 683 |
begin |
14430
85008b73e118
Skip ammo menu open animation if playing with TurnTime <= 10s
Wuzzy <Wuzzy2@mail.ru>
parents:
14418
diff
changeset
|
684 |
// No "disappear" animation (see above) |
85008b73e118
Skip ammo menu open animation if playing with TurnTime <= 10s
Wuzzy <Wuzzy2@mail.ru>
parents:
14418
diff
changeset
|
685 |
if ((cReducedQuality and rqSlowMenu) <> 0) or (cHedgehogTurnTime <= 10000) then |
6622 | 686 |
begin |
687 |
AMShiftX:= AMShiftTargetX; |
|
688 |
AMShiftY:= AMShiftTargetY; |
|
15067
0730c68fdf97
Backed out changeset 76003912e31d (whoops)
Wuzzy <Wuzzy2@mail.ru>
parents:
15065
diff
changeset
|
689 |
prevPoint:= CursorPoint; |
6795
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
690 |
AMState:= AMHidden; |
6622 | 691 |
end |
14430
85008b73e118
Skip ammo menu open animation if playing with TurnTime <= 10s
Wuzzy <Wuzzy2@mail.ru>
parents:
14418
diff
changeset
|
692 |
// "Disappear" animation |
6622 | 693 |
else |
6795
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
694 |
if AMAnimState < 1 then |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
695 |
begin |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
696 |
AMShiftX:= Round(AMShiftTargetX * AMAnimState); |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
697 |
AMShiftY:= Round(AMShiftTargetY * AMAnimState); |
8330 | 698 |
if (AMAnimType and AMTypeMaskAlpha) <> 0 then |
6796
3e89dbdc7db9
You can now change AMAnimType to enable the animation through the x/y axis and alpha for example
Xeli
parents:
6795
diff
changeset
|
699 |
Tint($FF, $ff, $ff, Round($ff * (1-AMAnimState))); |
6795
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
700 |
end |
8330 | 701 |
else |
6622 | 702 |
begin |
6795
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
703 |
AMShiftX:= AMShiftTargetX; |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
704 |
AMShiftY:= AMShiftTargetY; |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
705 |
prevPoint:= CursorPoint; |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
706 |
AMState:= AMHidden; |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
707 |
end; |
6622 | 708 |
end; |
8330 | 709 |
|
6795
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
710 |
DrawTexture(AmmoRect.x + AMShiftX, AmmoRect.y + AMShiftY, AmmoMenuTex); |
6796
3e89dbdc7db9
You can now change AMAnimType to enable the animation through the x/y axis and alpha for example
Xeli
parents:
6795
diff
changeset
|
711 |
|
8330 | 712 |
if ((AMState = AMHiding) or (AMState = AMShowingUp)) and ((AMAnimType and AMTypeMaskAlpha) <> 0 )then |
10032
db65298717da
This adds idle hog tinting. Active hog tinting still needed.
nemo
parents:
10009
diff
changeset
|
713 |
untint; |
6622 | 714 |
|
6796
3e89dbdc7db9
You can now change AMAnimType to enable the animation through the x/y axis and alpha for example
Xeli
parents:
6795
diff
changeset
|
715 |
Pos:= -1; |
3e89dbdc7db9
You can now change AMAnimType to enable the animation through the x/y axis and alpha for example
Xeli
parents:
6795
diff
changeset
|
716 |
Slot:= -1; |
6899 | 717 |
{$IFDEF USE_LANDSCAPE_AMMOMENU} |
6796
3e89dbdc7db9
You can now change AMAnimType to enable the animation through the x/y axis and alpha for example
Xeli
parents:
6795
diff
changeset
|
718 |
c:= -1; |
6622 | 719 |
for i:= 0 to cMaxSlotIndex do |
12719
637b1987570e
Fix first ammo row being invisible when there's only one weapon in the first row
Wuzzy <almikes@aol.com>
parents:
12708
diff
changeset
|
720 |
if (i <> cHiddenSlotIndex) and (Ammo^[i, 0].Count > 0) then |
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
721 |
begin |
6631 | 722 |
inc(c); |
6918 | 723 |
{$IFDEF USE_AM_NUMCOLUMN} |
6899 | 724 |
g:= 1; |
6918 | 725 |
{$ELSE} |
6622 | 726 |
g:= 0; |
6918 | 727 |
{$ENDIF} |
6622 | 728 |
for t:=0 to cMaxSlotAmmoIndex do |
729 |
if (Ammo^[i, t].Count > 0) and (Ammo^[i, t].AmmoType <> amNothing) then |
|
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
730 |
begin |
6622 | 731 |
if (CursorPoint.Y <= (cScreenHeight - AmmoRect.y) - ( g * (AMSlotSize+1))) and |
7841
43e68ac28d79
apply unC0Rr's fix for 435 to landscape and non numbered ammomenu
Xeli
parents:
7840
diff
changeset
|
732 |
(CursorPoint.Y > (cScreenHeight - AmmoRect.y) - ((g+1) * (AMSlotSize+1))) and |
8330 | 733 |
(CursorPoint.X > AmmoRect.x + ( c * (AMSlotSize+1))) and |
6631 | 734 |
(CursorPoint.X <= AmmoRect.x + ((c+1) * (AMSlotSize+1))) then |
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
735 |
begin |
6622 | 736 |
Slot:= i; |
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
737 |
Pos:= t; |
6622 | 738 |
STurns:= Ammoz[Ammo^[i, t].AmmoType].SkipTurns - CurrentTeam^.Clan^.TurnNumber; |
739 |
if (STurns < 0) and (AMShiftX = 0) and (AMShiftY = 0) then |
|
8330 | 740 |
DrawSprite(sprAMSlot, |
741 |
AmmoRect.x + BORDERSIZE + (c * (AMSlotSize+1)) + AMSlotPadding, |
|
6622 | 742 |
AmmoRect.y + BORDERSIZE + (g * (AMSlotSize+1)) + AMSlotPadding -1, 0); |
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
743 |
end; |
6622 | 744 |
inc(g); |
745 |
end; |
|
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
746 |
end; |
6622 | 747 |
{$ELSE} |
6918 | 748 |
c:= -1; |
6622 | 749 |
for i:= 0 to cMaxSlotIndex do |
12719
637b1987570e
Fix first ammo row being invisible when there's only one weapon in the first row
Wuzzy <almikes@aol.com>
parents:
12708
diff
changeset
|
750 |
if (i <> cHiddenSlotIndex) and (Ammo^[i, 0].Count > 0) then |
6622 | 751 |
begin |
6631 | 752 |
inc(c); |
6918 | 753 |
{$IFDEF USE_AM_NUMCOLUMN} |
6899 | 754 |
g:= 1; |
6918 | 755 |
{$ELSE} |
6622 | 756 |
g:= 0; |
6918 | 757 |
{$ENDIF} |
6622 | 758 |
for t:=0 to cMaxSlotAmmoIndex do |
759 |
if (Ammo^[i, t].Count > 0) and (Ammo^[i, t].AmmoType <> amNothing) then |
|
760 |
begin |
|
6631 | 761 |
if (CursorPoint.Y <= (cScreenHeight - AmmoRect.y) - ( c * (AMSlotSize+1))) and |
7840
7d86dbcd6325
Fix issue 435, and also unreported bug when 2 or even 4 entries could have selection at the same time in weapons menu.
unc0rr
parents:
7721
diff
changeset
|
762 |
(CursorPoint.Y > (cScreenHeight - AmmoRect.y) - ((c+1) * (AMSlotSize+1))) and |
8330 | 763 |
(CursorPoint.X > AmmoRect.x + ( g * (AMSlotSize+1))) and |
6622 | 764 |
(CursorPoint.X <= AmmoRect.x + ((g+1) * (AMSlotSize+1))) then |
765 |
begin |
|
766 |
Slot:= i; |
|
767 |
Pos:= t; |
|
768 |
STurns:= Ammoz[Ammo^[i, t].AmmoType].SkipTurns - CurrentTeam^.Clan^.TurnNumber; |
|
769 |
if (STurns < 0) and (AMShiftX = 0) and (AMShiftY = 0) then |
|
8330 | 770 |
DrawSprite(sprAMSlot, |
771 |
AmmoRect.x + BORDERSIZE + (g * (AMSlotSize+1)) + AMSlotPadding, |
|
6631 | 772 |
AmmoRect.y + BORDERSIZE + (c * (AMSlotSize+1)) + AMSlotPadding -1, 0); |
6622 | 773 |
end; |
774 |
inc(g); |
|
775 |
end; |
|
776 |
end; |
|
3395
095273ad0e08
adding a somewhat working autoration for ipad (uStore.pas and uWorld.pas got mixed in the last two commits)
koda
parents:
3390
diff
changeset
|
777 |
{$ENDIF} |
12708
5ef6780b1c05
Move amNothing from F1 slot to new special hidden weapon slot. Move amDuck to F1
Wuzzy <almikes@aol.com>
parents:
12697
diff
changeset
|
778 |
if (Pos >= 0) and (Pos <= cMaxSlotAmmoIndex) and (Slot >= 0) and (Slot <= cMaxSlotIndex) and (Slot <> cHiddenSlotIndex) then |
3967 | 779 |
begin |
6622 | 780 |
if (AMShiftX = 0) and (AMShiftY = 0) then |
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
781 |
if (Ammo^[Slot, Pos].Count > 0) and (Ammo^[Slot, Pos].AmmoType <> amNothing) then |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
782 |
begin |
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
783 |
if (amSel <> Ammo^[Slot, Pos].AmmoType) or (WeaponTooltipTex = nil) then |
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
784 |
begin |
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
785 |
amSel:= Ammo^[Slot, Pos].AmmoType; |
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
786 |
RenderWeaponTooltip(amSel) |
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
787 |
end; |
3697 | 788 |
|
6622 | 789 |
DrawTexture(AmmoRect.x + (AMSlotSize shr 1), |
790 |
AmmoRect.y + AmmoRect.h - BORDERSIZE - (AMSlotSize shr 1) - (Ammoz[Ammo^[Slot, Pos].AmmoType].NameTex^.h shr 1), |
|
6608 | 791 |
Ammoz[Ammo^[Slot, Pos].AmmoType].NameTex); |
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
792 |
if Ammo^[Slot, Pos].Count < AMMO_INFINITE then |
6622 | 793 |
DrawTexture(AmmoRect.x + AmmoRect.w - 20 - (CountTexz[Ammo^[Slot, Pos].Count]^.w), |
13638
039ec6dd304b
Fix slightly misplaced ammo count in ammo menu if count > 9
Wuzzy <Wuzzy2@mail.ru>
parents:
13637
diff
changeset
|
794 |
AmmoRect.y + AmmoRect.h - BORDERSIZE - (AMslotSize shr 1) - (CountTexz[Ammo^[Slot, Pos].Count]^.h shr 1), |
6608 | 795 |
CountTexz[Ammo^[Slot, Pos].Count]); |
1529
3bc916b419cd
Don't hide ammo menu when user clicks on not yet available weapon
unc0rr
parents:
1439
diff
changeset
|
796 |
|
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
797 |
if bSelected and (Ammoz[Ammo^[Slot, Pos].AmmoType].SkipTurns - CurrentTeam^.Clan^.TurnNumber < 0) then |
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
798 |
begin |
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
799 |
bShowAmmoMenu:= false; |
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
800 |
SetWeapon(Ammo^[Slot, Pos].AmmoType); |
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
801 |
bSelected:= false; |
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:
10628
diff
changeset
|
802 |
FreeAndNilTexture(WeaponTooltipTex); |
14562 | 803 |
updateTouchWidgets(Ammo^[Slot, Pos].AmmoType); |
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
804 |
exit |
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
805 |
end; |
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
806 |
end |
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
807 |
end |
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
808 |
else |
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:
10628
diff
changeset
|
809 |
FreeAndNilTexture(WeaponTooltipTex); |
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
810 |
|
6622 | 811 |
if (WeaponTooltipTex <> nil) and (AMShiftX = 0) and (AMShiftY = 0) then |
6676
21cf35a570a7
add keywords for landscape ammomenu and touch interface
koda
parents:
6652
diff
changeset
|
812 |
{$IFDEF USE_LANDSCAPE_AMMOMENU} |
8099
a7f02b902b6f
throw in some 'nots' trying to restore pas2c functionality
koda
parents:
8026
diff
changeset
|
813 |
if (not isPhone()) then |
6622 | 814 |
ShowWeaponTooltip(-WeaponTooltipTex^.w div 2, AmmoRect.y - WeaponTooltipTex^.h - AMSlotSize); |
3395
095273ad0e08
adding a somewhat working autoration for ipad (uStore.pas and uWorld.pas got mixed in the last two commits)
koda
parents:
3390
diff
changeset
|
815 |
{$ELSE} |
6622 | 816 |
ShowWeaponTooltip(AmmoRect.x - WeaponTooltipTex^.w - 3, Min(AmmoRect.y + 1, cScreenHeight - WeaponTooltipTex^.h - 40)); |
3395
095273ad0e08
adding a somewhat working autoration for ipad (uStore.pas and uWorld.pas got mixed in the last two commits)
koda
parents:
3390
diff
changeset
|
817 |
{$ENDIF} |
961
a9a349b2b3fa
Use turnsleft sprites to indicate turns left to activate ammo
unc0rr
parents:
956
diff
changeset
|
818 |
|
6276
1e2f8da1860a
while formatting the ammomenu code i found out that it's simpler to move than i thought, and fixed a small glitch when animation was disabled
koda
parents:
6250
diff
changeset
|
819 |
bSelected:= false; |
6899 | 820 |
{$IFNDEF USE_TOUCH_INTERFACE} |
6648
025473a2c420
prevent the cursor from being shown on the mobile version, and close the menu on tap when the tap is not on the ammo menu
Xeli
parents:
6647
diff
changeset
|
821 |
if (AMShiftX = 0) and (AMShiftY = 0) then |
6622 | 822 |
DrawSprite(sprArrow, CursorPoint.X, cScreenHeight - CursorPoint.Y, (RealTicks shr 6) mod 8); |
6648
025473a2c420
prevent the cursor from being shown on the mobile version, and close the menu on tap when the tap is not on the ammo menu
Xeli
parents:
6647
diff
changeset
|
823 |
{$ENDIF} |
4 | 824 |
end; |
825 |
||
3089 | 826 |
procedure DrawRepeated(spr, sprL, sprR: TSprite; Shift, OffsetY: LongInt); |
3537
8f5b3108f29c
New approach to the low-res problem. Basically, we already have a 1024 minimum, and the tallest maps are restricting themselves to 2048 maximum. All backgrounds are scaled down 50%, then scaled up on draw. Saves memory, and backgrounds are already deliberately fuzzed for depth of field anyway.
nemo
parents:
3523
diff
changeset
|
827 |
var i, w, h, lw, lh, rw, rh, sw: LongInt; |
2426 | 828 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
829 |
sw:= round(cScreenWidth / cScaleFactor); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
830 |
if (SpritesData[sprL].Texture = nil) and (SpritesData[spr].Texture <> nil) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
831 |
begin |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
832 |
w:= SpritesData[spr].Width * SpritesData[spr].Texture^.Scale; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
833 |
h:= SpritesData[spr].Height * SpritesData[spr].Texture^.Scale; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
834 |
i:= Shift mod w; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
835 |
if i > 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
836 |
dec(i, w); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
837 |
dec(i, w * (sw div w + 1)); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
838 |
repeat |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
839 |
DrawTexture(i, WorldDy + LAND_HEIGHT + OffsetY - h, SpritesData[spr].Texture, SpritesData[spr].Texture^.Scale); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
840 |
inc(i, w) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
841 |
until i > sw |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
842 |
end |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
843 |
else if SpritesData[spr].Texture <> nil then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
844 |
begin |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
845 |
w:= SpritesData[spr].Width * SpritesData[spr].Texture^.Scale; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
846 |
h:= SpritesData[spr].Height * SpritesData[spr].Texture^.Scale; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
847 |
lw:= SpritesData[sprL].Width * SpritesData[spr].Texture^.Scale; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
848 |
lh:= SpritesData[sprL].Height * SpritesData[spr].Texture^.Scale; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
849 |
if SpritesData[sprR].Texture <> nil then |
5285
af4dc03dd60d
Make sky, horizon, flakes and clouds optional, replace repeated strips of skyL/skyR with 2x2 transparent PNGs instead of larger images of variable dimensions, remove a number of empty unused images
nemo
parents:
5191
diff
changeset
|
850 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
851 |
rw:= SpritesData[sprR].Width * SpritesData[spr].Texture^.Scale; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
852 |
rh:= SpritesData[sprR].Height * SpritesData[spr].Texture^.Scale |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
853 |
end; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
854 |
dec(Shift, w div 2); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
855 |
DrawTexture(Shift, WorldDy + LAND_HEIGHT + OffsetY - h, SpritesData[spr].Texture, SpritesData[spr].Texture^.Scale); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
856 |
|
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
857 |
i:= Shift - lw; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
858 |
while i >= -sw - lw do |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
859 |
begin |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
860 |
DrawTexture(i, WorldDy + LAND_HEIGHT + OffsetY - lh, SpritesData[sprL].Texture, SpritesData[sprL].Texture^.Scale); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
861 |
dec(i, lw); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
862 |
end; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
863 |
|
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
864 |
i:= Shift + w; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
865 |
if SpritesData[sprR].Texture <> nil then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
866 |
while i <= sw do |
6135
2172330ad52a
Use SkyL if SkyR is not included. Saves a bit of texture memory and removes some redundant files.
nemo
parents:
6131
diff
changeset
|
867 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
868 |
DrawTexture(i, WorldDy + LAND_HEIGHT + OffsetY - rh, SpritesData[sprR].Texture, SpritesData[sprR].Texture^.Scale); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
869 |
inc(i, rw) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
870 |
end |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
871 |
else |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
872 |
while i <= sw do |
5285
af4dc03dd60d
Make sky, horizon, flakes and clouds optional, replace repeated strips of skyL/skyR with 2x2 transparent PNGs instead of larger images of variable dimensions, remove a number of empty unused images
nemo
parents:
5191
diff
changeset
|
873 |
begin |
3537
8f5b3108f29c
New approach to the low-res problem. Basically, we already have a 1024 minimum, and the tallest maps are restricting themselves to 2048 maximum. All backgrounds are scaled down 50%, then scaled up on draw. Saves memory, and backgrounds are already deliberately fuzzed for depth of field anyway.
nemo
parents:
3523
diff
changeset
|
874 |
DrawTexture(i, WorldDy + LAND_HEIGHT + OffsetY - lh, SpritesData[sprL].Texture, SpritesData[sprL].Texture^.Scale); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
875 |
inc(i, lw) |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
876 |
end |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
877 |
end |
2426 | 878 |
end; |
879 |
||
15672
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
880 |
// Force camera to stay within a certain area |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
881 |
procedure CameraBounds; |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
882 |
var lowBound: LongInt; |
15615
f0ac916a0608
Fix camera zooming out too far in pause mode (bug 773)
Wuzzy <Wuzzy2@mail.ru>
parents:
15484
diff
changeset
|
883 |
begin |
15672
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
884 |
if (not hasBorder) then |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
885 |
begin |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
886 |
if WorldDy > (-(cScreenHeight / cScaleFactor) + cScreenHeight div 2 - TopY + cCamLimitY) then |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
887 |
WorldDy:= (-trunc(cScreenHeight / cScaleFactor) + cScreenHeight div 2 - TopY + cCamLimitY); |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
888 |
if (RightX - LeftX + cCamLimitX * 2) div 2 < cScreenWidth / cScaleFactor then |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
889 |
WorldDx:= -((LeftX + RightX) div 2) |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
890 |
else |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
891 |
begin |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
892 |
if WorldDx < -LAND_WIDTH - cCamLimitX + (cScreenWidth / cScaleFactor) then |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
893 |
WorldDx:= -LAND_WIDTH - cCamLimitX + trunc(cScreenWidth / cScaleFactor); |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
894 |
if WorldDx > cCamLimitX - (cScreenWidth / cScaleFactor) then |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
895 |
WorldDx:= cCamLimitX - trunc(cScreenWidth / cScaleFactor); |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
896 |
end; |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
897 |
end |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
898 |
else |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
899 |
begin |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
900 |
if WorldDy > (-(cScreenHeight / cScaleFactor) + cScreenHeight div 2 - TopY + cCamLimitBorderY) then |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
901 |
WorldDy:= (-trunc(cScreenHeight / cScaleFactor) + cScreenHeight div 2 - TopY + cCamLimitBorderY); |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
902 |
if (RightX - LeftX + cCamLimitBorderX * 2) div 2 < cScreenWidth / cScaleFactor then |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
903 |
WorldDx:= -((LeftX + RightX) div 2) |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
904 |
else |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
905 |
begin |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
906 |
if WorldDx > -LeftX + cCamLimitBorderX - (cScreenWidth / cScaleFactor) then |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
907 |
WorldDx:= -LeftX + cCamLimitBorderX - trunc(cScreenWidth / cScaleFactor); |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
908 |
if WorldDx < -RightX - cCamLimitBorderX + (cScreenWidth / cScaleFactor) then |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
909 |
WorldDx:= -RightX - cCamLimitBorderX + trunc(cScreenWidth / cScaleFactor); |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
910 |
end; |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
911 |
end; |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
912 |
|
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
913 |
lowBound:= trunc(cScreenHeight / cScaleFactor) + cScreenHeight div 2 - cWaterLine - (cVisibleWater + trunc(CinematicBarH / (cScaleFactor / 2.0))); |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
914 |
if WorldDy < lowBound then |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
915 |
WorldDy:= lowBound; |
15615
f0ac916a0608
Fix camera zooming out too far in pause mode (bug 773)
Wuzzy <Wuzzy2@mail.ru>
parents:
15484
diff
changeset
|
916 |
end; |
2426 | 917 |
|
956 | 918 |
procedure DrawWorld(Lag: LongInt); |
4 | 919 |
begin |
6734
9709d15dabfa
Revert most of 033e4a8a9c74 and 9d501dc22f71 (see bug #362)
nemo
parents:
6714
diff
changeset
|
920 |
if ZoomValue < zoom then |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
921 |
begin |
6734
9709d15dabfa
Revert most of 033e4a8a9c74 and 9d501dc22f71 (see bug #362)
nemo
parents:
6714
diff
changeset
|
922 |
zoom:= zoom - 0.002 * Lag; |
9709d15dabfa
Revert most of 033e4a8a9c74 and 9d501dc22f71 (see bug #362)
nemo
parents:
6714
diff
changeset
|
923 |
if ZoomValue > zoom then |
9709d15dabfa
Revert most of 033e4a8a9c74 and 9d501dc22f71 (see bug #362)
nemo
parents:
6714
diff
changeset
|
924 |
zoom:= ZoomValue |
9709d15dabfa
Revert most of 033e4a8a9c74 and 9d501dc22f71 (see bug #362)
nemo
parents:
6714
diff
changeset
|
925 |
end |
9709d15dabfa
Revert most of 033e4a8a9c74 and 9d501dc22f71 (see bug #362)
nemo
parents:
6714
diff
changeset
|
926 |
else |
9709d15dabfa
Revert most of 033e4a8a9c74 and 9d501dc22f71 (see bug #362)
nemo
parents:
6714
diff
changeset
|
927 |
if ZoomValue > zoom then |
3444 | 928 |
begin |
6734
9709d15dabfa
Revert most of 033e4a8a9c74 and 9d501dc22f71 (see bug #362)
nemo
parents:
6714
diff
changeset
|
929 |
zoom:= zoom + 0.002 * Lag; |
9709d15dabfa
Revert most of 033e4a8a9c74 and 9d501dc22f71 (see bug #362)
nemo
parents:
6714
diff
changeset
|
930 |
if ZoomValue < zoom then |
9709d15dabfa
Revert most of 033e4a8a9c74 and 9d501dc22f71 (see bug #362)
nemo
parents:
6714
diff
changeset
|
931 |
zoom:= ZoomValue |
3444 | 932 |
end |
3611 | 933 |
else |
934 |
ZoomValue:= zoom; |
|
2376 | 935 |
|
9670
1954f692e8c6
Quick and simple implementation of afk mode (toggled by /pause)
unc0rr
parents:
9666
diff
changeset
|
936 |
if (not isPaused) and (not isAFK) and (GameType <> gmtRecord) then |
15615
f0ac916a0608
Fix camera zooming out too far in pause mode (bug 773)
Wuzzy <Wuzzy2@mail.ru>
parents:
15484
diff
changeset
|
937 |
MoveCamera |
f0ac916a0608
Fix camera zooming out too far in pause mode (bug 773)
Wuzzy <Wuzzy2@mail.ru>
parents:
15484
diff
changeset
|
938 |
else if (isPaused) then |
15672
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
939 |
CameraBounds; |
162 | 940 |
|
3696 | 941 |
if cStereoMode = smNone then |
942 |
begin |
|
10869 | 943 |
RenderClear(); |
3692 | 944 |
DrawWorldStereo(Lag, rmDefault) |
8138
cfb228baa598
Invert S3D_DISABLED to more consistent USE_S3D_RENDERING
Chris Wong <lambda.fairy@gmail.com>
parents:
7946
diff
changeset
|
945 |
{$IFDEF USE_S3D_RENDERING} |
3696 | 946 |
end |
947 |
else |
|
948 |
begin |
|
10869 | 949 |
// draw frame for left eye |
950 |
RenderClear(rmLeftEye); |
|
3696 | 951 |
DrawWorldStereo(Lag, rmLeftEye); |
3692 | 952 |
|
10869 | 953 |
// draw frame for right eye |
954 |
RenderClear(rmRightEye); |
|
3692 | 955 |
DrawWorldStereo(0, rmRightEye); |
4347
0ddb100fea61
add a S3D_DISABLED symbol to disable/enable stereo rendering at compilation time
koda
parents:
4345
diff
changeset
|
956 |
{$ENDIF} |
10869 | 957 |
end; |
3692 | 958 |
|
10869 | 959 |
FinishRender(); |
3692 | 960 |
end; |
961 |
||
10494 | 962 |
procedure RenderWorldEdge; |
9654 | 963 |
var |
10360
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
964 |
tmp, w: LongInt; |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
965 |
rect: TSDL_Rect; |
3692 | 966 |
begin |
10318 | 967 |
if (WorldEdge <> weNone) and (WorldEdge <> weSea) then |
9654 | 968 |
begin |
969 |
(* I think for a bounded world, will fill the left and right areas with black or something. Also will probably want various border effects/animations based on border type. Prob also, say, trigger a border animation timer on an impact. *) |
|
970 |
||
10360
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
971 |
rect.y:= ViewTopY; |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
972 |
rect.h:= ViewHeight; |
14303
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14302
diff
changeset
|
973 |
tmp:= leftX + WorldDx; |
10360
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
974 |
w:= tmp - ViewLeftX; |
3692 | 975 |
|
10360
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
976 |
if w > 0 then |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
977 |
begin |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
978 |
rect.w:= w; |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
979 |
rect.x:= ViewLeftX; |
10627 | 980 |
DrawRect(rect, $10, $10, $10, $80, true); |
10360
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
981 |
if WorldEdge = weBounce then |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
982 |
DrawLineOnScreen(tmp - 1, ViewTopY, tmp - 1, ViewBottomY, 2, $54, $54, $FF, $FF); |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
983 |
end; |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
984 |
|
14303
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14302
diff
changeset
|
985 |
tmp:= rightX + WorldDx; |
10360
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
986 |
w:= ViewRightX - tmp; |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
987 |
|
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
988 |
if w > 0 then |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
989 |
begin |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
990 |
rect.w:= w; |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
991 |
rect.x:= tmp; |
10627 | 992 |
DrawRect(rect, $10, $10, $10, $80, true); |
10360
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
993 |
if WorldEdge = weBounce then |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
994 |
DrawLineOnScreen(tmp - 1, ViewTopY, tmp - 1, ViewBottomY, 2, $54, $54, $FF, $FF); |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
995 |
end; |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
996 |
|
9654 | 997 |
end; |
998 |
end; |
|
999 |
||
1000 |
||
1001 |
procedure RenderTeamsHealth; |
|
13174
061d55939e47
Use visible team count instead of total team count to determine rendered team bar height
Wuzzy <Wuzzy2@mail.ru>
parents:
13156
diff
changeset
|
1002 |
var t, i, h, v, smallScreenOffset, TeamHealthBarWidth : LongInt; |
9654 | 1003 |
r: TSDL_Rect; |
1004 |
highlight: boolean; |
|
13140
e330feceb662
Hide team bar if all hedgehogs in it are hidden or dead
Wuzzy <Wuzzy2@mail.ru>
parents:
13018
diff
changeset
|
1005 |
hasVisibleHog: boolean; |
9656 | 1006 |
htex: PTexture; |
9654 | 1007 |
begin |
13174
061d55939e47
Use visible team count instead of total team count to determine rendered team bar height
Wuzzy <Wuzzy2@mail.ru>
parents:
13156
diff
changeset
|
1008 |
if VisibleTeamsCount * 20 > Longword(cScreenHeight) div 7 then // take up less screen on small displays |
9654 | 1009 |
begin |
1010 |
SetScale(1.5); |
|
1011 |
smallScreenOffset:= cScreenHeight div 6; |
|
13174
061d55939e47
Use visible team count instead of total team count to determine rendered team bar height
Wuzzy <Wuzzy2@mail.ru>
parents:
13156
diff
changeset
|
1012 |
if VisibleTeamsCount * 100 > Longword(cScreenHeight) then |
9654 | 1013 |
Tint($FF,$FF,$FF,$80); |
1014 |
end |
|
1015 |
else smallScreenOffset:= 0; |
|
13174
061d55939e47
Use visible team count instead of total team count to determine rendered team bar height
Wuzzy <Wuzzy2@mail.ru>
parents:
13156
diff
changeset
|
1016 |
v:= 0; // for updating VisibleTeamsCount |
9654 | 1017 |
for t:= 0 to Pred(TeamsCount) do |
1018 |
with TeamsArray[t]^ do |
|
13140
e330feceb662
Hide team bar if all hedgehogs in it are hidden or dead
Wuzzy <Wuzzy2@mail.ru>
parents:
13018
diff
changeset
|
1019 |
begin |
e330feceb662
Hide team bar if all hedgehogs in it are hidden or dead
Wuzzy <Wuzzy2@mail.ru>
parents:
13018
diff
changeset
|
1020 |
hasVisibleHog:= false; |
e330feceb662
Hide team bar if all hedgehogs in it are hidden or dead
Wuzzy <Wuzzy2@mail.ru>
parents:
13018
diff
changeset
|
1021 |
for i:= 0 to cMaxHHIndex do |
e330feceb662
Hide team bar if all hedgehogs in it are hidden or dead
Wuzzy <Wuzzy2@mail.ru>
parents:
13018
diff
changeset
|
1022 |
if (Hedgehogs[i].Gear <> nil) then |
e330feceb662
Hide team bar if all hedgehogs in it are hidden or dead
Wuzzy <Wuzzy2@mail.ru>
parents:
13018
diff
changeset
|
1023 |
hasVisibleHog:= true; |
e330feceb662
Hide team bar if all hedgehogs in it are hidden or dead
Wuzzy <Wuzzy2@mail.ru>
parents:
13018
diff
changeset
|
1024 |
if (TeamHealth > 0) and hasVisibleHog then |
9654 | 1025 |
begin |
13174
061d55939e47
Use visible team count instead of total team count to determine rendered team bar height
Wuzzy <Wuzzy2@mail.ru>
parents:
13156
diff
changeset
|
1026 |
// count visible teams |
061d55939e47
Use visible team count instead of total team count to determine rendered team bar height
Wuzzy <Wuzzy2@mail.ru>
parents:
13156
diff
changeset
|
1027 |
inc(v); |
9654 | 1028 |
highlight:= bShowFinger and (CurrentTeam = TeamsArray[t]) and ((RealTicks mod 1000) < 500); |
1029 |
||
1030 |
if highlight then |
|
9656 | 1031 |
begin |
9654 | 1032 |
Tint(Clan^.Color shl 8 or $FF); |
9656 | 1033 |
htex:= GenericHealthTexture |
1034 |
end |
|
1035 |
else |
|
1036 |
htex:= Clan^.HealthTex; |
|
9654 | 1037 |
|
9791
446e4919b738
Display team owner in teams widget (addresses issue 174)
unc0rr
parents:
9755
diff
changeset
|
1038 |
// draw owner |
446e4919b738
Display team owner in teams widget (addresses issue 174)
unc0rr
parents:
9755
diff
changeset
|
1039 |
if OwnerTex <> nil then |
446e4919b738
Display team owner in teams widget (addresses issue 174)
unc0rr
parents:
9755
diff
changeset
|
1040 |
DrawTexture(-OwnerTex^.w - NameTagTex^.w - 18, cScreenHeight + DrawHealthY + smallScreenOffset, OwnerTex); |
446e4919b738
Display team owner in teams widget (addresses issue 174)
unc0rr
parents:
9755
diff
changeset
|
1041 |
|
446e4919b738
Display team owner in teams widget (addresses issue 174)
unc0rr
parents:
9755
diff
changeset
|
1042 |
// draw name |
9654 | 1043 |
DrawTexture(-NameTagTex^.w - 16, cScreenHeight + DrawHealthY + smallScreenOffset, NameTagTex); |
1044 |
||
1045 |
// draw flag |
|
1046 |
DrawTexture(-14, cScreenHeight + DrawHealthY + smallScreenOffset, FlagTex); |
|
1047 |
||
9720
453a1c29b7e4
Animate hedgehogs healths inside team health bar. Proper animation for the case when max team health grows is lost though.
unc0rr
parents:
9693
diff
changeset
|
1048 |
TeamHealthBarWidth:= cTeamHealthWidth * TeamHealthBarHealth div MaxTeamHealth; |
453a1c29b7e4
Animate hedgehogs healths inside team health bar. Proper animation for the case when max team health grows is lost though.
unc0rr
parents:
9693
diff
changeset
|
1049 |
|
14757
8563cc40fc1e
Invert colors if clan color is very dark
Wuzzy <Wuzzy2@mail.ru>
parents:
14590
diff
changeset
|
1050 |
// draw team health bar |
9654 | 1051 |
r.x:= 0; |
1052 |
r.y:= 0; |
|
1053 |
r.w:= 2 + TeamHealthBarWidth; |
|
14762
37a781d28e43
Fix team bar height depending on NameTex
Wuzzy <Wuzzy2@mail.ru>
parents:
14760
diff
changeset
|
1054 |
r.h:= htex^.h; |
9656 | 1055 |
DrawTextureFromRect(14, cScreenHeight + DrawHealthY + smallScreenOffset, @r, htex); |
9654 | 1056 |
|
14757
8563cc40fc1e
Invert colors if clan color is very dark
Wuzzy <Wuzzy2@mail.ru>
parents:
14590
diff
changeset
|
1057 |
// draw health bar's right border |
9654 | 1058 |
inc(r.x, cTeamHealthWidth + 2); |
1059 |
r.w:= 3; |
|
9656 | 1060 |
DrawTextureFromRect(TeamHealthBarWidth + 15, cScreenHeight + DrawHealthY + smallScreenOffset, @r, htex); |
9654 | 1061 |
|
14757
8563cc40fc1e
Invert colors if clan color is very dark
Wuzzy <Wuzzy2@mail.ru>
parents:
14590
diff
changeset
|
1062 |
// draw hedgehog health separators in team health bar |
9720
453a1c29b7e4
Animate hedgehogs healths inside team health bar. Proper animation for the case when max team health grows is lost though.
unc0rr
parents:
9693
diff
changeset
|
1063 |
h:= 0; |
9654 | 1064 |
if not hasGone then |
1065 |
for i:= 0 to cMaxHHIndex do |
|
9720
453a1c29b7e4
Animate hedgehogs healths inside team health bar. Proper animation for the case when max team health grows is lost though.
unc0rr
parents:
9693
diff
changeset
|
1066 |
begin |
453a1c29b7e4
Animate hedgehogs healths inside team health bar. Proper animation for the case when max team health grows is lost though.
unc0rr
parents:
9693
diff
changeset
|
1067 |
inc(h, Hedgehogs[i].HealthBarHealth); |
10015 | 1068 |
if (h < TeamHealthBarHealth) and (Hedgehogs[i].HealthBarHealth > 0) then |
14757
8563cc40fc1e
Invert colors if clan color is very dark
Wuzzy <Wuzzy2@mail.ru>
parents:
14590
diff
changeset
|
1069 |
if (IsTooDarkToRead(Clan^.Color)) then |
8563cc40fc1e
Invert colors if clan color is very dark
Wuzzy <Wuzzy2@mail.ru>
parents:
14590
diff
changeset
|
1070 |
DrawTexture(15 + h * TeamHealthBarWidth div TeamHealthBarHealth, cScreenHeight + DrawHealthY + smallScreenOffset + 1, SpritesData[sprSlider].Texture) |
8563cc40fc1e
Invert colors if clan color is very dark
Wuzzy <Wuzzy2@mail.ru>
parents:
14590
diff
changeset
|
1071 |
else |
8563cc40fc1e
Invert colors if clan color is very dark
Wuzzy <Wuzzy2@mail.ru>
parents:
14590
diff
changeset
|
1072 |
DrawTexture(15 + h * TeamHealthBarWidth div TeamHealthBarHealth, cScreenHeight + DrawHealthY + smallScreenOffset + 1, SpritesData[sprSliderInverted].Texture); |
9720
453a1c29b7e4
Animate hedgehogs healths inside team health bar. Proper animation for the case when max team health grows is lost though.
unc0rr
parents:
9693
diff
changeset
|
1073 |
end; |
9654 | 1074 |
|
13018
0248cf0da834
Add SetTeamLabel to Lua API, can set arbitrary string as team label
Wuzzy <Wuzzy2@mail.ru>
parents:
12831
diff
changeset
|
1075 |
// draw Lua value, if set |
0248cf0da834
Add SetTeamLabel to Lua API, can set arbitrary string as team label
Wuzzy <Wuzzy2@mail.ru>
parents:
12831
diff
changeset
|
1076 |
if (hasLuaTeamValue) then |
0248cf0da834
Add SetTeamLabel to Lua API, can set arbitrary string as team label
Wuzzy <Wuzzy2@mail.ru>
parents:
12831
diff
changeset
|
1077 |
DrawTexture(TeamHealthBarWidth + 22, cScreenHeight + DrawHealthY + smallScreenOffset, LuaTeamValueTex) |
0248cf0da834
Add SetTeamLabel to Lua API, can set arbitrary string as team label
Wuzzy <Wuzzy2@mail.ru>
parents:
12831
diff
changeset
|
1078 |
// otherwise, draw AI kill counter for gfAISurvival |
0248cf0da834
Add SetTeamLabel to Lua API, can set arbitrary string as team label
Wuzzy <Wuzzy2@mail.ru>
parents:
12831
diff
changeset
|
1079 |
else if (GameFlags and gfAISurvival) <> 0 then |
9654 | 1080 |
DrawTexture(TeamHealthBarWidth + 22, cScreenHeight + DrawHealthY + smallScreenOffset, AIKillsTex); |
1081 |
||
1082 |
// if highlighted, draw flag and other contents again to keep their colors |
|
1083 |
// this approach should be faster than drawing all borders one by one tinted or not |
|
1084 |
if highlight then |
|
1085 |
begin |
|
13174
061d55939e47
Use visible team count instead of total team count to determine rendered team bar height
Wuzzy <Wuzzy2@mail.ru>
parents:
13156
diff
changeset
|
1086 |
if VisibleTeamsCount * 100 > Longword(cScreenHeight) then |
9654 | 1087 |
Tint($FF,$FF,$FF,$80) |
9666
8dcb25112d96
- Bring back white dot in the center of crosshair. Crosshair is blurred now!
unc0rr
parents:
9656
diff
changeset
|
1088 |
else untint; |
9654 | 1089 |
|
1090 |
// draw name |
|
1091 |
r.x:= 2; |
|
1092 |
r.y:= 2; |
|
1093 |
r.w:= NameTagTex^.w - 4; |
|
1094 |
r.h:= NameTagTex^.h - 4; |
|
1095 |
DrawTextureFromRect(-NameTagTex^.w - 14, cScreenHeight + DrawHealthY + smallScreenOffset + 2, @r, NameTagTex); |
|
10147 | 1096 |
|
1097 |
if OwnerTex <> nil then |
|
1098 |
begin |
|
1099 |
r.w:= OwnerTex^.w - 4; |
|
1100 |
r.h:= OwnerTex^.h - 4; |
|
1101 |
DrawTextureFromRect(-OwnerTex^.w - NameTagTex^.w - 16, cScreenHeight + DrawHealthY + smallScreenOffset + 2, @r, OwnerTex) |
|
1102 |
end; |
|
1103 |
||
13018
0248cf0da834
Add SetTeamLabel to Lua API, can set arbitrary string as team label
Wuzzy <Wuzzy2@mail.ru>
parents:
12831
diff
changeset
|
1104 |
if (hasLuaTeamValue) then |
0248cf0da834
Add SetTeamLabel to Lua API, can set arbitrary string as team label
Wuzzy <Wuzzy2@mail.ru>
parents:
12831
diff
changeset
|
1105 |
begin |
0248cf0da834
Add SetTeamLabel to Lua API, can set arbitrary string as team label
Wuzzy <Wuzzy2@mail.ru>
parents:
12831
diff
changeset
|
1106 |
r.w:= LuaTeamValueTex^.w - 4; |
0248cf0da834
Add SetTeamLabel to Lua API, can set arbitrary string as team label
Wuzzy <Wuzzy2@mail.ru>
parents:
12831
diff
changeset
|
1107 |
r.h:= LuaTeamValueTex^.h - 4; |
0248cf0da834
Add SetTeamLabel to Lua API, can set arbitrary string as team label
Wuzzy <Wuzzy2@mail.ru>
parents:
12831
diff
changeset
|
1108 |
DrawTextureFromRect(TeamHealthBarWidth + 24, cScreenHeight + DrawHealthY + smallScreenOffset + 2, @r, LuaTeamValueTex); |
0248cf0da834
Add SetTeamLabel to Lua API, can set arbitrary string as team label
Wuzzy <Wuzzy2@mail.ru>
parents:
12831
diff
changeset
|
1109 |
end |
0248cf0da834
Add SetTeamLabel to Lua API, can set arbitrary string as team label
Wuzzy <Wuzzy2@mail.ru>
parents:
12831
diff
changeset
|
1110 |
else if (GameFlags and gfAISurvival) <> 0 then |
10147 | 1111 |
begin |
1112 |
r.w:= AIKillsTex^.w - 4; |
|
1113 |
r.h:= AIKillsTex^.h - 4; |
|
1114 |
DrawTextureFromRect(TeamHealthBarWidth + 24, cScreenHeight + DrawHealthY + smallScreenOffset + 2, @r, AIKillsTex); |
|
1115 |
end; |
|
1116 |
||
9654 | 1117 |
// draw flag |
1118 |
r.w:= 22; |
|
1119 |
r.h:= 15; |
|
1120 |
DrawTextureFromRect(-12, cScreenHeight + DrawHealthY + smallScreenOffset + 2, @r, FlagTex); |
|
10317 | 1121 |
end |
1122 |
// draw an arrow next to active team |
|
1123 |
else if (CurrentTeam = TeamsArray[t]) and (TurnTimeLeft > 0) then |
|
1124 |
begin |
|
1125 |
h:= -NameTagTex^.w - 24; |
|
1126 |
if OwnerTex <> nil then |
|
1127 |
h:= h - OwnerTex^.w - 4; |
|
14757
8563cc40fc1e
Invert colors if clan color is very dark
Wuzzy <Wuzzy2@mail.ru>
parents:
14590
diff
changeset
|
1128 |
if (IsTooDarkToRead(TeamsArray[t]^.Clan^.Color)) then |
8563cc40fc1e
Invert colors if clan color is very dark
Wuzzy <Wuzzy2@mail.ru>
parents:
14590
diff
changeset
|
1129 |
DrawSpriteRotatedF(sprFingerBackInv, h, cScreenHeight + DrawHealthY + smallScreenOffset + 2 + SpritesData[sprFingerBackInv].Width div 4, 0, 1, -90) |
8563cc40fc1e
Invert colors if clan color is very dark
Wuzzy <Wuzzy2@mail.ru>
parents:
14590
diff
changeset
|
1130 |
else |
8563cc40fc1e
Invert colors if clan color is very dark
Wuzzy <Wuzzy2@mail.ru>
parents:
14590
diff
changeset
|
1131 |
DrawSpriteRotatedF(sprFingerBack, h, cScreenHeight + DrawHealthY + smallScreenOffset + 2 + SpritesData[sprFingerBack].Width div 4, 0, 1, -90); |
14416
f39d34d78028
Colorize switching arrows, pointing arrow and target cross in clan color
Wuzzy <Wuzzy2@mail.ru>
parents:
14324
diff
changeset
|
1132 |
Tint(TeamsArray[t]^.Clan^.Color shl 8 or $FF); |
10317 | 1133 |
DrawSpriteRotatedF(sprFinger, h, cScreenHeight + DrawHealthY + smallScreenOffset + 2 + SpritesData[sprFinger].Width div 4, 0, 1, -90); |
14416
f39d34d78028
Colorize switching arrows, pointing arrow and target cross in clan color
Wuzzy <Wuzzy2@mail.ru>
parents:
14324
diff
changeset
|
1134 |
untint; |
9654 | 1135 |
end; |
1136 |
end; |
|
13140
e330feceb662
Hide team bar if all hedgehogs in it are hidden or dead
Wuzzy <Wuzzy2@mail.ru>
parents:
13018
diff
changeset
|
1137 |
end; |
9654 | 1138 |
if smallScreenOffset <> 0 then |
1139 |
begin |
|
1140 |
SetScale(cDefaultZoomLevel); |
|
13174
061d55939e47
Use visible team count instead of total team count to determine rendered team bar height
Wuzzy <Wuzzy2@mail.ru>
parents:
13156
diff
changeset
|
1141 |
if VisibleTeamsCount * 20 > Longword(cScreenHeight) div 5 then |
10032
db65298717da
This adds idle hog tinting. Active hog tinting still needed.
nemo
parents:
10009
diff
changeset
|
1142 |
untint; |
9654 | 1143 |
end; |
13174
061d55939e47
Use visible team count instead of total team count to determine rendered team bar height
Wuzzy <Wuzzy2@mail.ru>
parents:
13156
diff
changeset
|
1144 |
VisibleTeamsCount:= v; |
9654 | 1145 |
end; |
1146 |
||
13637
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1147 |
procedure RenderAttackBar(); |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1148 |
var i: LongInt; |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1149 |
tdx, tdy: Double; |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1150 |
begin |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1151 |
if CurrentTeam <> nil then |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1152 |
case AttackBar of |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1153 |
2: with CurrentHedgehog^ do |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1154 |
begin |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1155 |
tdx:= hwSign(Gear^.dX) * Sin(Gear^.Angle * Pi / cMaxAngle); |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1156 |
tdy:= - Cos(Gear^.Angle * Pi / cMaxAngle); |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1157 |
for i:= (Gear^.Power * 24) div cPowerDivisor downto 0 do |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1158 |
DrawSprite(sprPower, |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1159 |
hwRound(Gear^.X) + GetLaunchX(CurAmmoType, hwSign(Gear^.dX), Gear^.Angle) + LongInt(round(WorldDx + tdx * (24 + i * 2))) - 16, |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1160 |
hwRound(Gear^.Y) + GetLaunchY(CurAmmoType, Gear^.Angle) + LongInt(round(WorldDy + tdy * (24 + i * 2))) - 16, |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1161 |
i) |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1162 |
end; |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1163 |
end; |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1164 |
end; |
9654 | 1165 |
|
10360
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
1166 |
var preShiftWorldDx: LongInt; |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
1167 |
|
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15857
diff
changeset
|
1168 |
procedure ShiftWorld(Dir: LongInt); |
3692 | 1169 |
begin |
10360
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
1170 |
preShiftWorldDx:= WorldDx; |
15759 | 1171 |
Dir := Dir * LongInt(playWidth); |
1172 |
WorldDx:= WorldDx + Dir; |
|
3692 | 1173 |
end; |
10360
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
1174 |
|
15929
128ace913837
Introduce hwengine-future library, use Land allocated in it
unC0Rr
parents:
15857
diff
changeset
|
1175 |
procedure UnshiftWorld(); |
10360
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
1176 |
begin |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
1177 |
WorldDx:= preShiftWorldDx; |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
1178 |
end; |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
1179 |
|
3692 | 1180 |
procedure DrawWorldStereo(Lag: LongInt; RM: TRenderMode); |
9654 | 1181 |
var i, t: LongInt; |
11912
d3a852554aa7
Turn timer digits green when it's still the ready timer
Wuzzy <almikes@aol.com>
parents:
11895
diff
changeset
|
1182 |
spr: TSprite; |
3692 | 1183 |
r: TSDL_Rect; |
7016 | 1184 |
s: shortstring; |
9654 | 1185 |
offsetX, offsetY, screenBottom: LongInt; |
15230
fe79f62ef158
Fix hog tags of current hog not rendered in gray area of wrap world edge if finger is shown
Wuzzy <Wuzzy2@mail.ru>
parents:
15227
diff
changeset
|
1186 |
replicateToLeft, replicateToRight, isNotHiddenByCinematic: boolean; |
12697
c71e330d5094
Add missing variable in uWorld.pas in videorec builds
Wuzzy <almikes@aol.com>
parents:
12694
diff
changeset
|
1187 |
{$IFDEF USE_VIDEO_RECORDING} |
c71e330d5094
Add missing variable in uWorld.pas in videorec builds
Wuzzy <almikes@aol.com>
parents:
12694
diff
changeset
|
1188 |
a: Byte; |
c71e330d5094
Add missing variable in uWorld.pas in videorec builds
Wuzzy <almikes@aol.com>
parents:
12694
diff
changeset
|
1189 |
{$ENDIF} |
3692 | 1190 |
begin |
10507
ed5df9cd251f
I'm such a dirty boi... cleaning up my own mess a little
sheepluva
parents:
10494
diff
changeset
|
1191 |
if WorldEdge <> weWrap then |
10360
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
1192 |
begin |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
1193 |
replicateToLeft := false; |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
1194 |
replicateToRight:= false; |
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
1195 |
end |
10358 | 1196 |
else |
10360
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
1197 |
begin |
14303
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14302
diff
changeset
|
1198 |
replicateToLeft := (leftX + WorldDx > ViewLeftX); |
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14302
diff
changeset
|
1199 |
replicateToRight:= (rightX + WorldDx < ViewRightX); |
10360
c243b6a8ad9a
some adjustments and support for mirrored world rendering. disabled atm though, I think it is more confusing than helping
sheepluva
parents:
10359
diff
changeset
|
1200 |
end; |
10358 | 1201 |
|
10318 | 1202 |
ScreenBottom:= (WorldDy - trunc(cScreenHeight/cScaleFactor) - (cScreenHeight div 2) + cWaterLine); |
1203 |
||
1204 |
// note: offsetY is negative! |
|
10319 | 1205 |
offsetY:= 10 * Min(0, -145 - ScreenBottom); // TODO limit this in the other direction too |
10318 | 1206 |
|
14024
58e54e737279
Tweak commenting in uWorld render routine
Wuzzy <Wuzzy2@mail.ru>
parents:
13983
diff
changeset
|
1207 |
// Sky and horizont |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1208 |
if (cReducedQuality and rqNoBackground) = 0 then |
1812 | 1209 |
begin |
3594
aeca3d8f1b29
turn cReducedQuality into a LongInt and provide a series of quality flags (and best of all, this is still compatible with current frontend)
koda
parents:
3582
diff
changeset
|
1210 |
// Offsets relative to camera - spare them to wimpier cpus, no bg or flakes for them anyway |
aeca3d8f1b29
turn cReducedQuality into a LongInt and provide a series of quality flags (and best of all, this is still compatible with current frontend)
koda
parents:
3582
diff
changeset
|
1211 |
SkyOffset:= offsetY div 35 + cWaveHeight; |
aeca3d8f1b29
turn cReducedQuality into a LongInt and provide a series of quality flags (and best of all, this is still compatible with current frontend)
koda
parents:
3582
diff
changeset
|
1212 |
HorizontOffset:= SkyOffset; |
aeca3d8f1b29
turn cReducedQuality into a LongInt and provide a series of quality flags (and best of all, this is still compatible with current frontend)
koda
parents:
3582
diff
changeset
|
1213 |
if ScreenBottom > SkyOffset then |
aeca3d8f1b29
turn cReducedQuality into a LongInt and provide a series of quality flags (and best of all, this is still compatible with current frontend)
koda
parents:
3582
diff
changeset
|
1214 |
HorizontOffset:= HorizontOffset + ((ScreenBottom-SkyOffset) div 20); |
3265
5fe62296fdea
- Parallax effect for horizont when water is out of sight
palewolf
parents:
3249
diff
changeset
|
1215 |
|
3594
aeca3d8f1b29
turn cReducedQuality into a LongInt and provide a series of quality flags (and best of all, this is still compatible with current frontend)
koda
parents:
3582
diff
changeset
|
1216 |
// background |
3688 | 1217 |
ChangeDepth(RM, cStereo_Sky); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1218 |
if SuddenDeathDmg then |
12097
ebe87b6ed182
add alpha for sd-tint, since CopherNeue thinks the textures might need fading
nemo
parents:
12072
diff
changeset
|
1219 |
Tint(SDTint.r, SDTint.g, SDTint.b, SDTint.a); |
3594
aeca3d8f1b29
turn cReducedQuality into a LongInt and provide a series of quality flags (and best of all, this is still compatible with current frontend)
koda
parents:
3582
diff
changeset
|
1220 |
DrawRepeated(sprSky, sprSkyL, sprSkyR, (WorldDx + LAND_WIDTH div 2) * 3 div 8, SkyOffset); |
3688 | 1221 |
ChangeDepth(RM, -cStereo_Horizon); |
3594
aeca3d8f1b29
turn cReducedQuality into a LongInt and provide a series of quality flags (and best of all, this is still compatible with current frontend)
koda
parents:
3582
diff
changeset
|
1222 |
DrawRepeated(sprHorizont, sprHorizontL, sprHorizontR, (WorldDx + LAND_WIDTH div 2) * 3 div 5, HorizontOffset); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1223 |
if SuddenDeathDmg then |
9666
8dcb25112d96
- Bring back white dot in the center of crosshair. Crosshair is blurred now!
unc0rr
parents:
9656
diff
changeset
|
1224 |
untint; |
3611 | 1225 |
end; |
4 | 1226 |
|
13633
35d93b1e7fef
Fix foreground flakes (layer 2+6) disappearing when moving camera in world wrap world
Wuzzy <Wuzzy2@mail.ru>
parents:
13622
diff
changeset
|
1227 |
DrawVisualGears(0, false); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1228 |
ChangeDepth(RM, -cStereo_MidDistance); |
13633
35d93b1e7fef
Fix foreground flakes (layer 2+6) disappearing when moving camera in world wrap world
Wuzzy <Wuzzy2@mail.ru>
parents:
13622
diff
changeset
|
1229 |
DrawVisualGears(4, false); |
3697 | 1230 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1231 |
if (cReducedQuality and rq2DWater) = 0 then |
3611 | 1232 |
begin |
3594
aeca3d8f1b29
turn cReducedQuality into a LongInt and provide a series of quality flags (and best of all, this is still compatible with current frontend)
koda
parents:
3582
diff
changeset
|
1233 |
// Waves |
10318 | 1234 |
DrawWater(255, SkyOffset, 0); |
4816
c2575faeac3d
use a different depth for different layers (land, water, explosions)
koda
parents:
4812
diff
changeset
|
1235 |
ChangeDepth(RM, -cStereo_Water_distant); |
10318 | 1236 |
DrawWaves( 1, 0 - WorldDx div 32, offsetY div 35, -49, 64); |
4816
c2575faeac3d
use a different depth for different layers (land, water, explosions)
koda
parents:
4812
diff
changeset
|
1237 |
ChangeDepth(RM, -cStereo_Water_distant); |
10318 | 1238 |
DrawWaves( -1, 25 + WorldDx div 25, offsetY div 38, -37, 48); |
4816
c2575faeac3d
use a different depth for different layers (land, water, explosions)
koda
parents:
4812
diff
changeset
|
1239 |
ChangeDepth(RM, -cStereo_Water_distant); |
10318 | 1240 |
DrawWaves( 1, 75 - WorldDx div 19, offsetY div 45, -23, 32); |
4816
c2575faeac3d
use a different depth for different layers (land, water, explosions)
koda
parents:
4812
diff
changeset
|
1241 |
ChangeDepth(RM, -cStereo_Water_distant); |
10318 | 1242 |
DrawWaves(-1, 100 + WorldDx div 14, offsetY div 70, -7, 24); |
3265
5fe62296fdea
- Parallax effect for horizont when water is out of sight
palewolf
parents:
3249
diff
changeset
|
1243 |
end |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1244 |
else |
10318 | 1245 |
DrawWaves(-1, 100, - cWaveHeight div 2, - cWaveHeight div 2, 0); |
4 | 1246 |
|
10533 | 1247 |
ChangeDepth(RM, cStereo_Land); |
13633
35d93b1e7fef
Fix foreground flakes (layer 2+6) disappearing when moving camera in world wrap world
Wuzzy <Wuzzy2@mail.ru>
parents:
13622
diff
changeset
|
1248 |
DrawVisualGears(5, false); |
10533 | 1249 |
DrawLand(WorldDx, WorldDy); |
4 | 1250 |
|
10533 | 1251 |
if replicateToLeft then |
1252 |
begin |
|
1253 |
ShiftWorld(-1); |
|
3611 | 1254 |
DrawLand(WorldDx, WorldDy); |
10533 | 1255 |
UnshiftWorld(); |
1256 |
end; |
|
1911 | 1257 |
|
10533 | 1258 |
if replicateToRight then |
1259 |
begin |
|
1260 |
ShiftWorld(1); |
|
1261 |
DrawLand(WorldDx, WorldDy); |
|
1262 |
UnshiftWorld(); |
|
1263 |
end; |
|
4 | 1264 |
|
10533 | 1265 |
DrawWater(255, 0, 0); |
4 | 1266 |
|
10358 | 1267 |
if replicateToLeft then |
10263
6ef900411158
here a personal experimental mockup of how I imagine wrapping world edges should look like. bouncing one could be similar just with mirrored stuff. please test and share opinion. note: you might wanna disable auto-cam
sheepluva
parents:
10251
diff
changeset
|
1268 |
begin |
10507
ed5df9cd251f
I'm such a dirty boi... cleaning up my own mess a little
sheepluva
parents:
10494
diff
changeset
|
1269 |
ShiftWorld(-1); |
13633
35d93b1e7fef
Fix foreground flakes (layer 2+6) disappearing when moving camera in world wrap world
Wuzzy <Wuzzy2@mail.ru>
parents:
13622
diff
changeset
|
1270 |
DrawVisualGears(1, true); |
10263
6ef900411158
here a personal experimental mockup of how I imagine wrapping world edges should look like. bouncing one could be similar just with mirrored stuff. please test and share opinion. note: you might wanna disable auto-cam
sheepluva
parents:
10251
diff
changeset
|
1271 |
DrawGears(); |
13633
35d93b1e7fef
Fix foreground flakes (layer 2+6) disappearing when moving camera in world wrap world
Wuzzy <Wuzzy2@mail.ru>
parents:
13622
diff
changeset
|
1272 |
DrawVisualGears(6, true); |
10507
ed5df9cd251f
I'm such a dirty boi... cleaning up my own mess a little
sheepluva
parents:
10494
diff
changeset
|
1273 |
UnshiftWorld(); |
10358 | 1274 |
end; |
1275 |
||
1276 |
if replicateToRight then |
|
1277 |
begin |
|
10507
ed5df9cd251f
I'm such a dirty boi... cleaning up my own mess a little
sheepluva
parents:
10494
diff
changeset
|
1278 |
ShiftWorld(1); |
13633
35d93b1e7fef
Fix foreground flakes (layer 2+6) disappearing when moving camera in world wrap world
Wuzzy <Wuzzy2@mail.ru>
parents:
13622
diff
changeset
|
1279 |
DrawVisualGears(1, true); |
10263
6ef900411158
here a personal experimental mockup of how I imagine wrapping world edges should look like. bouncing one could be similar just with mirrored stuff. please test and share opinion. note: you might wanna disable auto-cam
sheepluva
parents:
10251
diff
changeset
|
1280 |
DrawGears(); |
13633
35d93b1e7fef
Fix foreground flakes (layer 2+6) disappearing when moving camera in world wrap world
Wuzzy <Wuzzy2@mail.ru>
parents:
13622
diff
changeset
|
1281 |
DrawVisualGears(6, true); |
10507
ed5df9cd251f
I'm such a dirty boi... cleaning up my own mess a little
sheepluva
parents:
10494
diff
changeset
|
1282 |
UnshiftWorld(); |
10263
6ef900411158
here a personal experimental mockup of how I imagine wrapping world edges should look like. bouncing one could be similar just with mirrored stuff. please test and share opinion. note: you might wanna disable auto-cam
sheepluva
parents:
10251
diff
changeset
|
1283 |
end; |
6ef900411158
here a personal experimental mockup of how I imagine wrapping world edges should look like. bouncing one could be similar just with mirrored stuff. please test and share opinion. note: you might wanna disable auto-cam
sheepluva
parents:
10251
diff
changeset
|
1284 |
|
13633
35d93b1e7fef
Fix foreground flakes (layer 2+6) disappearing when moving camera in world wrap world
Wuzzy <Wuzzy2@mail.ru>
parents:
13622
diff
changeset
|
1285 |
DrawVisualGears(1, false); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1286 |
DrawGears; |
13633
35d93b1e7fef
Fix foreground flakes (layer 2+6) disappearing when moving camera in world wrap world
Wuzzy <Wuzzy2@mail.ru>
parents:
13622
diff
changeset
|
1287 |
DrawVisualGears(6, false); |
4 | 1288 |
|
10263
6ef900411158
here a personal experimental mockup of how I imagine wrapping world edges should look like. bouncing one could be similar just with mirrored stuff. please test and share opinion. note: you might wanna disable auto-cam
sheepluva
parents:
10251
diff
changeset
|
1289 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1290 |
if SuddenDeathDmg then |
10318 | 1291 |
DrawWater(SDWaterOpacity, 0, 0) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1292 |
else |
10318 | 1293 |
DrawWater(WaterOpacity, 0, 0); |
2269
00f5704f5f39
add extra semi-opaque layer of water to discolour objects in the water.
nemo
parents:
2268
diff
changeset
|
1294 |
|
14024
58e54e737279
Tweak commenting in uWorld render routine
Wuzzy <Wuzzy2@mail.ru>
parents:
13983
diff
changeset
|
1295 |
// Waves |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1296 |
ChangeDepth(RM, cStereo_Water_near); |
10318 | 1297 |
DrawWaves( 1, 25 - WorldDx div 9, 0, 0, 12); |
3265
5fe62296fdea
- Parallax effect for horizont when water is out of sight
palewolf
parents:
3249
diff
changeset
|
1298 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1299 |
if (cReducedQuality and rq2DWater) = 0 then |
3265
5fe62296fdea
- Parallax effect for horizont when water is out of sight
palewolf
parents:
3249
diff
changeset
|
1300 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1301 |
ChangeDepth(RM, cStereo_Water_near); |
10318 | 1302 |
DrawWaves(-1, 50 + WorldDx div 6, - offsetY div 40, 23, 8); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1303 |
if SuddenDeathDmg then |
10318 | 1304 |
DrawWater(SDWaterOpacity, - offsetY div 20, 23) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1305 |
else |
10318 | 1306 |
DrawWater(WaterOpacity, - offsetY div 20, 23); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1307 |
ChangeDepth(RM, cStereo_Water_near); |
10318 | 1308 |
DrawWaves( 1, 75 - WorldDx div 4, - offsetY div 20, 37, 2); |
4792
68f9b331014a
sudden death changes: only change visual bit on health decrease and support for water transparancy change and clouds number change
Henek
parents:
4748
diff
changeset
|
1309 |
if SuddenDeathDmg then |
10318 | 1310 |
DrawWater(SDWaterOpacity, - offsetY div 10, 47) |
4792
68f9b331014a
sudden death changes: only change visual bit on health decrease and support for water transparancy change and clouds number change
Henek
parents:
4748
diff
changeset
|
1311 |
else |
10318 | 1312 |
DrawWater(WaterOpacity, - offsetY div 10, 47); |
4816
c2575faeac3d
use a different depth for different layers (land, water, explosions)
koda
parents:
4812
diff
changeset
|
1313 |
ChangeDepth(RM, cStereo_Water_near); |
10318 | 1314 |
DrawWaves( -1, 25 + WorldDx div 3, - offsetY div 10, 59, 0); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1315 |
end |
3611 | 1316 |
else |
10318 | 1317 |
DrawWaves(-1, 50, cWaveHeight div 2, cWaveHeight div 2, 0); |
2161
0c8634241fa4
Some work on zooming. Hedgewars are now unplayable.
unc0rr
parents:
2152
diff
changeset
|
1318 |
|
14590
0149d5ed5dc5
Fix airplane line being drawn in front of many HUD elements
Wuzzy <Wuzzy2@mail.ru>
parents:
14565
diff
changeset
|
1319 |
// line at airplane height for certain airstrike types (when spawning height is important) |
0149d5ed5dc5
Fix airplane line being drawn in front of many HUD elements
Wuzzy <Wuzzy2@mail.ru>
parents:
14565
diff
changeset
|
1320 |
with CurrentHedgehog^ do |
0149d5ed5dc5
Fix airplane line being drawn in front of many HUD elements
Wuzzy <Wuzzy2@mail.ru>
parents:
14565
diff
changeset
|
1321 |
if (isCursorVisible) and ((CurAmmoType = amNapalm) or (CurAmmoType = amMineStrike) or (((GameFlags and gfMoreWind) <> 0) and ((CurAmmoType = amDrillStrike) or (CurAmmoType = amAirAttack)))) then |
15676
c1d0ada72cc8
Fix airplane line not being drawn in full for very large maps
Wuzzy <Wuzzy2@mail.ru>
parents:
15675
diff
changeset
|
1322 |
DrawLine(-cCamLimitX, topY-300, LAND_WIDTH + cCamLimitX, topY-300, 3.0, (Team^.Clan^.Color shr 16), (Team^.Clan^.Color shr 8) and $FF, Team^.Clan^.Color and $FF, $FF); |
14590
0149d5ed5dc5
Fix airplane line being drawn in front of many HUD elements
Wuzzy <Wuzzy2@mail.ru>
parents:
14565
diff
changeset
|
1323 |
|
0149d5ed5dc5
Fix airplane line being drawn in front of many HUD elements
Wuzzy <Wuzzy2@mail.ru>
parents:
14565
diff
changeset
|
1324 |
// gear HUD extras (fuel indicator, secondary ammo, etc.) |
13635
571f8110957e
Replicate gear GUI overlays in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
1325 |
if replicateToLeft then |
571f8110957e
Replicate gear GUI overlays in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
1326 |
begin |
571f8110957e
Replicate gear GUI overlays in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
1327 |
ShiftWorld(-1); |
571f8110957e
Replicate gear GUI overlays in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
1328 |
DrawGearsGui(); |
571f8110957e
Replicate gear GUI overlays in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
1329 |
UnshiftWorld(); |
571f8110957e
Replicate gear GUI overlays in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
1330 |
end; |
571f8110957e
Replicate gear GUI overlays in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
1331 |
|
571f8110957e
Replicate gear GUI overlays in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
1332 |
if replicateToRight then |
571f8110957e
Replicate gear GUI overlays in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
1333 |
begin |
571f8110957e
Replicate gear GUI overlays in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
1334 |
ShiftWorld(1); |
571f8110957e
Replicate gear GUI overlays in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
1335 |
DrawGearsGui(); |
571f8110957e
Replicate gear GUI overlays in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
1336 |
UnshiftWorld(); |
571f8110957e
Replicate gear GUI overlays in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
1337 |
end; |
571f8110957e
Replicate gear GUI overlays in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
1338 |
|
571f8110957e
Replicate gear GUI overlays in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13634
diff
changeset
|
1339 |
DrawGearsGui(); |
12210
442bab755bb4
Render gear timers in front of water
Wuzzy <almikes@aol.com>
parents:
12097
diff
changeset
|
1340 |
|
15460 | 1341 |
// Finger (arrow pointing to hedgehog). |
1342 |
// NOT wrapped like the other stuff because it might be confusing. |
|
1343 |
DrawFinger(); |
|
1344 |
||
4816
c2575faeac3d
use a different depth for different layers (land, water, explosions)
koda
parents:
4812
diff
changeset
|
1345 |
// everything after this ChangeDepth will be drawn outside the screen |
4818
202eef454354
rename "frame alternate" to "wiggle" as it's more appropriate
koda
parents:
4816
diff
changeset
|
1346 |
// note: negative parallax gears should last very little for a smooth stereo effect |
202eef454354
rename "frame alternate" to "wiggle" as it's more appropriate
koda
parents:
4816
diff
changeset
|
1347 |
ChangeDepth(RM, cStereo_Outside); |
10358 | 1348 |
|
1349 |
if replicateToLeft then |
|
10263
6ef900411158
here a personal experimental mockup of how I imagine wrapping world edges should look like. bouncing one could be similar just with mirrored stuff. please test and share opinion. note: you might wanna disable auto-cam
sheepluva
parents:
10251
diff
changeset
|
1350 |
begin |
10507
ed5df9cd251f
I'm such a dirty boi... cleaning up my own mess a little
sheepluva
parents:
10494
diff
changeset
|
1351 |
ShiftWorld(-1); |
13633
35d93b1e7fef
Fix foreground flakes (layer 2+6) disappearing when moving camera in world wrap world
Wuzzy <Wuzzy2@mail.ru>
parents:
13622
diff
changeset
|
1352 |
DrawVisualGears(2, true); |
10507
ed5df9cd251f
I'm such a dirty boi... cleaning up my own mess a little
sheepluva
parents:
10494
diff
changeset
|
1353 |
UnshiftWorld(); |
10358 | 1354 |
end; |
1355 |
||
1356 |
if replicateToRight then |
|
1357 |
begin |
|
10507
ed5df9cd251f
I'm such a dirty boi... cleaning up my own mess a little
sheepluva
parents:
10494
diff
changeset
|
1358 |
ShiftWorld(1); |
13633
35d93b1e7fef
Fix foreground flakes (layer 2+6) disappearing when moving camera in world wrap world
Wuzzy <Wuzzy2@mail.ru>
parents:
13622
diff
changeset
|
1359 |
DrawVisualGears(2, true); |
10507
ed5df9cd251f
I'm such a dirty boi... cleaning up my own mess a little
sheepluva
parents:
10494
diff
changeset
|
1360 |
UnshiftWorld(); |
10263
6ef900411158
here a personal experimental mockup of how I imagine wrapping world edges should look like. bouncing one could be similar just with mirrored stuff. please test and share opinion. note: you might wanna disable auto-cam
sheepluva
parents:
10251
diff
changeset
|
1361 |
end; |
10358 | 1362 |
|
13633
35d93b1e7fef
Fix foreground flakes (layer 2+6) disappearing when moving camera in world wrap world
Wuzzy <Wuzzy2@mail.ru>
parents:
13622
diff
changeset
|
1363 |
DrawVisualGears(2, false); |
4816
c2575faeac3d
use a different depth for different layers (land, water, explosions)
koda
parents:
4812
diff
changeset
|
1364 |
|
c2575faeac3d
use a different depth for different layers (land, water, explosions)
koda
parents:
4812
diff
changeset
|
1365 |
// everything after this ResetDepth will be drawn at screen level (depth = 0) |
4818
202eef454354
rename "frame alternate" to "wiggle" as it's more appropriate
koda
parents:
4816
diff
changeset
|
1366 |
// note: everything that needs to be readable should be on this level |
4816
c2575faeac3d
use a different depth for different layers (land, water, explosions)
koda
parents:
4812
diff
changeset
|
1367 |
ResetDepth(RM); |
10358 | 1368 |
|
1369 |
if replicateToLeft then |
|
10263
6ef900411158
here a personal experimental mockup of how I imagine wrapping world edges should look like. bouncing one could be similar just with mirrored stuff. please test and share opinion. note: you might wanna disable auto-cam
sheepluva
parents:
10251
diff
changeset
|
1370 |
begin |
10507
ed5df9cd251f
I'm such a dirty boi... cleaning up my own mess a little
sheepluva
parents:
10494
diff
changeset
|
1371 |
ShiftWorld(-1); |
13633
35d93b1e7fef
Fix foreground flakes (layer 2+6) disappearing when moving camera in world wrap world
Wuzzy <Wuzzy2@mail.ru>
parents:
13622
diff
changeset
|
1372 |
DrawVisualGears(3, true); |
10507
ed5df9cd251f
I'm such a dirty boi... cleaning up my own mess a little
sheepluva
parents:
10494
diff
changeset
|
1373 |
UnshiftWorld(); |
10358 | 1374 |
end; |
1375 |
||
1376 |
if replicateToRight then |
|
1377 |
begin |
|
10507
ed5df9cd251f
I'm such a dirty boi... cleaning up my own mess a little
sheepluva
parents:
10494
diff
changeset
|
1378 |
ShiftWorld(1); |
13633
35d93b1e7fef
Fix foreground flakes (layer 2+6) disappearing when moving camera in world wrap world
Wuzzy <Wuzzy2@mail.ru>
parents:
13622
diff
changeset
|
1379 |
DrawVisualGears(3, true); |
10507
ed5df9cd251f
I'm such a dirty boi... cleaning up my own mess a little
sheepluva
parents:
10494
diff
changeset
|
1380 |
UnshiftWorld(); |
10263
6ef900411158
here a personal experimental mockup of how I imagine wrapping world edges should look like. bouncing one could be similar just with mirrored stuff. please test and share opinion. note: you might wanna disable auto-cam
sheepluva
parents:
10251
diff
changeset
|
1381 |
end; |
10358 | 1382 |
|
13633
35d93b1e7fef
Fix foreground flakes (layer 2+6) disappearing when moving camera in world wrap world
Wuzzy <Wuzzy2@mail.ru>
parents:
13622
diff
changeset
|
1383 |
DrawVisualGears(3, false); |
2161
0c8634241fa4
Some work on zooming. Hedgewars are now unplayable.
unc0rr
parents:
2152
diff
changeset
|
1384 |
|
14024
58e54e737279
Tweak commenting in uWorld render routine
Wuzzy <Wuzzy2@mail.ru>
parents:
13983
diff
changeset
|
1385 |
// Target (e.g. air attack, bee, ...) |
3104 | 1386 |
if (TargetPoint.X <> NoPointX) and (CurrentTeam <> nil) and (CurrentHedgehog <> nil) then |
1387 |
begin |
|
1388 |
with PHedgehog(CurrentHedgehog)^ do |
|
1389 |
begin |
|
5372
7283bc768228
Change bee pos sprite, make aiming napalm a little easier, adjust napalm flames to be more centred on the target
nemo
parents:
5302
diff
changeset
|
1390 |
if CurAmmoType = amBee then |
13636
fc8c8910a281
Replicate target sprite properly in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13635
diff
changeset
|
1391 |
spr:= sprTargetBee |
3110 | 1392 |
else |
13636
fc8c8910a281
Replicate target sprite properly in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13635
diff
changeset
|
1393 |
spr:= sprTargetP; |
fc8c8910a281
Replicate target sprite properly in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13635
diff
changeset
|
1394 |
if replicateToLeft then |
fc8c8910a281
Replicate target sprite properly in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13635
diff
changeset
|
1395 |
begin |
fc8c8910a281
Replicate target sprite properly in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13635
diff
changeset
|
1396 |
ShiftWorld(-1); |
14765
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1397 |
if spr = sprTargetP then |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1398 |
begin |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1399 |
if IsTooDarkToRead(Team^.Clan^.Color) then |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1400 |
DrawSpriteRotatedF(sprTargetPBackInv, TargetPoint.X + WorldDx, TargetPoint.Y + WorldDy, 0, 0, (RealTicks shr 3) mod 360) |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1401 |
else |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1402 |
DrawSpriteRotatedF(sprTargetPBack, TargetPoint.X + WorldDx, TargetPoint.Y + WorldDy, 0, 0, (RealTicks shr 3) mod 360); |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1403 |
Tint(Team^.Clan^.Color shl 8 or $FF); |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1404 |
end; |
13636
fc8c8910a281
Replicate target sprite properly in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13635
diff
changeset
|
1405 |
DrawSpriteRotatedF(spr, TargetPoint.X + WorldDx, TargetPoint.Y + WorldDy, 0, 0, (RealTicks shr 3) mod 360); |
14765
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1406 |
if spr = sprTargetP then |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1407 |
untint; |
13636
fc8c8910a281
Replicate target sprite properly in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13635
diff
changeset
|
1408 |
UnshiftWorld(); |
fc8c8910a281
Replicate target sprite properly in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13635
diff
changeset
|
1409 |
end; |
fc8c8910a281
Replicate target sprite properly in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13635
diff
changeset
|
1410 |
|
fc8c8910a281
Replicate target sprite properly in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13635
diff
changeset
|
1411 |
if replicateToRight then |
fc8c8910a281
Replicate target sprite properly in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13635
diff
changeset
|
1412 |
begin |
fc8c8910a281
Replicate target sprite properly in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13635
diff
changeset
|
1413 |
ShiftWorld(1); |
14765
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1414 |
if spr = sprTargetP then |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1415 |
begin |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1416 |
if IsTooDarkToRead(Team^.Clan^.Color) then |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1417 |
DrawSpriteRotatedF(sprTargetPBackInv, TargetPoint.X + WorldDx, TargetPoint.Y + WorldDy, 0, 0, (RealTicks shr 3) mod 360) |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1418 |
else |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1419 |
DrawSpriteRotatedF(sprTargetPBack, TargetPoint.X + WorldDx, TargetPoint.Y + WorldDy, 0, 0, (RealTicks shr 3) mod 360); |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1420 |
Tint(Team^.Clan^.Color shl 8 or $FF); |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1421 |
end; |
13636
fc8c8910a281
Replicate target sprite properly in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13635
diff
changeset
|
1422 |
DrawSpriteRotatedF(spr, TargetPoint.X + WorldDx, TargetPoint.Y + WorldDy, 0, 0, (RealTicks shr 3) mod 360); |
14765
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1423 |
if spr = sprTargetP then |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1424 |
untint; |
13636
fc8c8910a281
Replicate target sprite properly in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13635
diff
changeset
|
1425 |
UnshiftWorld(); |
fc8c8910a281
Replicate target sprite properly in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13635
diff
changeset
|
1426 |
end; |
fc8c8910a281
Replicate target sprite properly in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13635
diff
changeset
|
1427 |
|
14765
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1428 |
if spr = sprTargetP then |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1429 |
begin |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1430 |
if IsTooDarkToRead(Team^.Clan^.Color) then |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1431 |
DrawSpriteRotatedF(sprTargetPBackInv, TargetPoint.X + WorldDx, TargetPoint.Y + WorldDy, 0, 0, (RealTicks shr 3) mod 360) |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1432 |
else |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1433 |
DrawSpriteRotatedF(sprTargetPBack, TargetPoint.X + WorldDx, TargetPoint.Y + WorldDy, 0, 0, (RealTicks shr 3) mod 360); |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1434 |
Tint(Team^.Clan^.Color shl 8 or $FF); |
f5dadf2b7d03
Fix target marker rendering issues in weWrap
Wuzzy <Wuzzy2@mail.ru>
parents:
14762
diff
changeset
|
1435 |
end; |
13636
fc8c8910a281
Replicate target sprite properly in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13635
diff
changeset
|
1436 |
DrawSpriteRotatedF(spr, TargetPoint.X + WorldDx, TargetPoint.Y + WorldDy, 0, 0, (RealTicks shr 3) mod 360); |
14416
f39d34d78028
Colorize switching arrows, pointing arrow and target cross in clan color
Wuzzy <Wuzzy2@mail.ru>
parents:
14324
diff
changeset
|
1437 |
if spr = sprTargetP then |
f39d34d78028
Colorize switching arrows, pointing arrow and target cross in clan color
Wuzzy <Wuzzy2@mail.ru>
parents:
14324
diff
changeset
|
1438 |
untint; |
13636
fc8c8910a281
Replicate target sprite properly in world wrap
Wuzzy <Wuzzy2@mail.ru>
parents:
13635
diff
changeset
|
1439 |
end; |
3104 | 1440 |
end; |
2161
0c8634241fa4
Some work on zooming. Hedgewars are now unplayable.
unc0rr
parents:
2152
diff
changeset
|
1441 |
|
13637
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1442 |
// Attack bar |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1443 |
if replicateToLeft then |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1444 |
begin |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1445 |
ShiftWorld(-1); |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1446 |
RenderAttackBar(); |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1447 |
UnshiftWorld(); |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1448 |
end; |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1449 |
|
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1450 |
if replicateToRight then |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1451 |
begin |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1452 |
ShiftWorld(1); |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1453 |
RenderAttackBar(); |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1454 |
UnshiftWorld(); |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1455 |
end; |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1456 |
|
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1457 |
RenderAttackBar(); |
28e4a9db4690
Fix attack bar render bugs: Invisible beyond world edge; rendered over GUI (e.g. mission panel)
Wuzzy <Wuzzy2@mail.ru>
parents:
13636
diff
changeset
|
1458 |
|
14024
58e54e737279
Tweak commenting in uWorld render routine
Wuzzy <Wuzzy2@mail.ru>
parents:
13983
diff
changeset
|
1459 |
// World edge |
10494 | 1460 |
RenderWorldEdge(); |
9473
a51a69094c24
partial implementation of non-infinite world (edge wrap/warp/bounce)
nemo
parents:
9377
diff
changeset
|
1461 |
|
14024
58e54e737279
Tweak commenting in uWorld render routine
Wuzzy <Wuzzy2@mail.ru>
parents:
13983
diff
changeset
|
1462 |
// This scale is used to keep the various widgets at the same dimension at all zoom levels |
3523 | 1463 |
SetScale(cDefaultZoomLevel); |
2724 | 1464 |
|
14440 | 1465 |
isNotHiddenByCinematic:= true; |
14418
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1466 |
// Cinematic Mode: Determine effects and state |
11524 | 1467 |
if CinematicScript or (InCinematicMode and autoCameraOn |
11519
aab4767d9a50
adding a "cinematic mode" - currently: black bars on bottom/top. triggered by rcplane when pressing enter
sheepluva
parents:
11362
diff
changeset
|
1468 |
and ((CurrentHedgehog = nil) or CurrentHedgehog^.Team^.ExtDriven |
11520 | 1469 |
or (CurrentHedgehog^.BotLevel <> 0) or (GameType = gmtDemo))) then |
11519
aab4767d9a50
adding a "cinematic mode" - currently: black bars on bottom/top. triggered by rcplane when pressing enter
sheepluva
parents:
11362
diff
changeset
|
1470 |
begin |
11522 | 1471 |
if CinematicSteps < 300 then |
1472 |
begin |
|
1473 |
inc(CinematicSteps, Lag); |
|
1474 |
if CinematicSteps > 300 then |
|
14418
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1475 |
begin |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1476 |
CinematicSteps:= 300; |
14440 | 1477 |
isNotHiddenByCinematic:= false; |
14418
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1478 |
end; |
11522 | 1479 |
end; |
11519
aab4767d9a50
adding a "cinematic mode" - currently: black bars on bottom/top. triggered by rcplane when pressing enter
sheepluva
parents:
11362
diff
changeset
|
1480 |
end |
aab4767d9a50
adding a "cinematic mode" - currently: black bars on bottom/top. triggered by rcplane when pressing enter
sheepluva
parents:
11362
diff
changeset
|
1481 |
else if CinematicSteps > 0 then |
aab4767d9a50
adding a "cinematic mode" - currently: black bars on bottom/top. triggered by rcplane when pressing enter
sheepluva
parents:
11362
diff
changeset
|
1482 |
begin |
aab4767d9a50
adding a "cinematic mode" - currently: black bars on bottom/top. triggered by rcplane when pressing enter
sheepluva
parents:
11362
diff
changeset
|
1483 |
dec(CinematicSteps, Lag); |
aab4767d9a50
adding a "cinematic mode" - currently: black bars on bottom/top. triggered by rcplane when pressing enter
sheepluva
parents:
11362
diff
changeset
|
1484 |
if CinematicSteps < 0 then |
aab4767d9a50
adding a "cinematic mode" - currently: black bars on bottom/top. triggered by rcplane when pressing enter
sheepluva
parents:
11362
diff
changeset
|
1485 |
CinematicSteps:= 0; |
aab4767d9a50
adding a "cinematic mode" - currently: black bars on bottom/top. triggered by rcplane when pressing enter
sheepluva
parents:
11362
diff
changeset
|
1486 |
end; |
aab4767d9a50
adding a "cinematic mode" - currently: black bars on bottom/top. triggered by rcplane when pressing enter
sheepluva
parents:
11362
diff
changeset
|
1487 |
|
2724 | 1488 |
// Turn time |
14440 | 1489 |
if (UIDisplay <> uiNone) and (isNotHiddenByCinematic) then |
3774 | 1490 |
begin |
9693 | 1491 |
{$IFDEF USE_TOUCH_INTERFACE} |
1492 |
offsetX:= cScreenHeight - 13; |
|
1493 |
{$ELSE} |
|
1494 |
offsetX:= 48; |
|
1495 |
{$ENDIF} |
|
1496 |
offsetY:= cOffsetY; |
|
11917
d819c04d0cbe
Show timer at 999s instead of 1000s
Wuzzy <almikes@aol.com>
parents:
11916
diff
changeset
|
1497 |
if ((TurnTimeLeft <> 0) and (TurnTimeLeft < 999000)) or (ReadyTimeLeft <> 0) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1498 |
begin |
9693 | 1499 |
if ReadyTimeLeft <> 0 then |
1500 |
i:= Succ(Pred(ReadyTimeLeft) div 1000) |
|
1501 |
else |
|
1502 |
i:= Succ(Pred(TurnTimeLeft) div 1000); |
|
10015 | 1503 |
|
9693 | 1504 |
if i>99 then |
1505 |
t:= 112 |
|
1506 |
else if i>9 then |
|
1507 |
t:= 96 |
|
1508 |
else |
|
1509 |
t:= 80; |
|
1510 |
DrawSprite(sprFrame, -(cScreenWidth shr 1) + t + offsetY, cScreenHeight - offsetX, 1); |
|
1511 |
while i > 0 do |
|
1512 |
begin |
|
1513 |
dec(t, 32); |
|
11916
38fa4583e7f3
Make timer gray while the time is not running or while it is paused
Wuzzy <almikes@aol.com>
parents:
11913
diff
changeset
|
1514 |
if isPaused or (not IsClockRunning()) then |
38fa4583e7f3
Make timer gray while the time is not running or while it is paused
Wuzzy <almikes@aol.com>
parents:
11913
diff
changeset
|
1515 |
spr := sprBigDigitGray |
38fa4583e7f3
Make timer gray while the time is not running or while it is paused
Wuzzy <almikes@aol.com>
parents:
11913
diff
changeset
|
1516 |
else if (ReadyTimeLeft <> 0) then |
11912
d3a852554aa7
Turn timer digits green when it's still the ready timer
Wuzzy <almikes@aol.com>
parents:
11895
diff
changeset
|
1517 |
spr := sprBigDigitGreen |
11913
232b57a70aca
Make the timer red when it is the get-away time
Wuzzy <almikes@aol.com>
parents:
11912
diff
changeset
|
1518 |
else if IsGetAwayTime then |
232b57a70aca
Make the timer red when it is the get-away time
Wuzzy <almikes@aol.com>
parents:
11912
diff
changeset
|
1519 |
spr := sprBigDigitRed |
11912
d3a852554aa7
Turn timer digits green when it's still the ready timer
Wuzzy <almikes@aol.com>
parents:
11895
diff
changeset
|
1520 |
else |
d3a852554aa7
Turn timer digits green when it's still the ready timer
Wuzzy <almikes@aol.com>
parents:
11895
diff
changeset
|
1521 |
spr := sprBigDigit; |
d3a852554aa7
Turn timer digits green when it's still the ready timer
Wuzzy <almikes@aol.com>
parents:
11895
diff
changeset
|
1522 |
DrawSprite(spr, -(cScreenWidth shr 1) + t + offsetY, cScreenHeight - offsetX, i mod 10); |
9693 | 1523 |
i:= i div 10 |
1524 |
end; |
|
1525 |
DrawSprite(sprFrame, -(cScreenWidth shr 1) + t - 4 + offsetY, cScreenHeight - offsetX, 0); |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1526 |
end; |
79 | 1527 |
|
9693 | 1528 |
end; |
4 | 1529 |
|
14024
58e54e737279
Tweak commenting in uWorld render routine
Wuzzy <Wuzzy2@mail.ru>
parents:
13983
diff
changeset
|
1530 |
// Team bars |
14440 | 1531 |
if (UIDisplay = uiAll) and (isNotHiddenByCinematic) then |
9693 | 1532 |
RenderTeamsHealth; |
47 | 1533 |
|
14985
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1534 |
// Current hedgehog health in top left corner |
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1535 |
if ((UIDisplay = uiAll) or (UIDisplay = uiNoTeams)) and (isNotHiddenByCinematic) and |
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1536 |
(CurrentHedgehog <> nil) and (CurrentHedgehog^.Gear <> nil) and |
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1537 |
(CurrentHedgehog^.HealthTagTex <> nil) and |
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1538 |
((CurrentHedgehog^.Gear^.State and gstHHDriven) <> 0) then |
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1539 |
begin |
14988
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1540 |
t:= 11; |
14985
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1541 |
i:= t; |
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1542 |
{$IFDEF USE_TOUCH_INTERFACE} |
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1543 |
i:= t + pauseButton.frame.y + pauseButton.frame.h; |
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1544 |
{$ENDIF} |
14989 | 1545 |
|
15717
eeab5b90c082
Fix some HUD icon issues in gfInvulnerable
Wuzzy <Wuzzy2@mail.ru>
parents:
15676
diff
changeset
|
1546 |
inc(t, CurrentHedgehog^.HealthTagTex^.h); |
eeab5b90c082
Fix some HUD icon issues in gfInvulnerable
Wuzzy <Wuzzy2@mail.ru>
parents:
15676
diff
changeset
|
1547 |
cDemoClockFPSOffsetY:= t; |
eeab5b90c082
Fix some HUD icon issues in gfInvulnerable
Wuzzy <Wuzzy2@mail.ru>
parents:
15676
diff
changeset
|
1548 |
|
14989 | 1549 |
// Hide health and healh icons in gfInvulnerable mode (except heResurrectable) |
1550 |
if ((GameFlags and gfInvulnerable) = 0) then |
|
1551 |
begin |
|
1552 |
// Health tag |
|
14985
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1553 |
DrawTexture(cScreenWidth div 2 - CurrentHedgehog^.HealthTagTex^.w - 16, i, CurrentHedgehog^.HealthTagTex); |
14988
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1554 |
|
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1555 |
t:= SpritesData[sprHealthHud].Width + 18; |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1556 |
// Main health icon. Appearance depends on game mode and poisoning state |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1557 |
if ((GameFlags and gfResetHealth) = 0) then |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1558 |
if (CurrentHedgehog^.Effects[hePoisoned] <> 0) then |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1559 |
DrawSprite(sprHealthPoisonHud, (cScreenWidth div 2 - CurrentHedgehog^.HealthTagTex^.w - t), i, 0) |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1560 |
else |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1561 |
DrawSprite(sprHealthHud, (cScreenWidth div 2 - CurrentHedgehog^.HealthTagTex^.w - t), i, 0) |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1562 |
else |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1563 |
if (CurrentHedgehog^.Effects[hePoisoned] <> 0) then |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1564 |
DrawSprite(sprMedicPoisonHud, (cScreenWidth div 2 - CurrentHedgehog^.HealthTagTex^.w - t), i, 0) |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1565 |
else |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1566 |
DrawSprite(sprMedicHud, (cScreenWidth div 2 - CurrentHedgehog^.HealthTagTex^.w - t), i, 0); |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1567 |
// Put halo above health icon for resurrectable hog |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1568 |
if (CurrentHedgehog^.Effects[heResurrectable] <> 0) then |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1569 |
DrawSprite(sprHaloHud, (cScreenWidth div 2 - CurrentHedgehog^.HealthTagTex^.w - t - 2), i - SpritesData[sprHaloHud].Height + 1, 0); |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1570 |
|
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1571 |
// Additional health-related states |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1572 |
inc(t, 2); |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1573 |
// Invulnerable |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1574 |
if (CurrentHedgehog^.Effects[heInvulnerable] <> 0) then |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1575 |
begin |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1576 |
inc(t, SpritesData[sprInvulnHud].Width + 2); |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1577 |
DrawSprite(sprInvulnHud, (cScreenWidth div 2 - CurrentHedgehog^.HealthTagTex^.w - t), i, 0) |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1578 |
end |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1579 |
// Karma |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1580 |
else if ((GameFlags and gfKarma) <> 0) then |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1581 |
begin |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1582 |
inc(t, SpritesData[sprKarmaHud].Width + 2); |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1583 |
DrawSprite(sprKarmaHud, (cScreenWidth div 2 - CurrentHedgehog^.HealthTagTex^.w - t), i, 0) |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1584 |
end; |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1585 |
// Vampirism |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1586 |
if cVampiric then |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1587 |
begin |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1588 |
inc(t, SpritesData[sprVampHud].Width + 2); |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1589 |
DrawSprite(sprVampHud, (cScreenWidth div 2 - CurrentHedgehog^.HealthTagTex^.w - t), i, 0); |
9939134b566d
Show more health-related icons in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14987
diff
changeset
|
1590 |
end; |
14985
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1591 |
end |
14989 | 1592 |
// in gfInvulnerable mode ... |
15484
b9b48e8b5ec4
Display invuln icon in gfInvulnerable mode
Wuzzy <Wuzzy2@mail.ru>
parents:
15460
diff
changeset
|
1593 |
else |
b9b48e8b5ec4
Display invuln icon in gfInvulnerable mode
Wuzzy <Wuzzy2@mail.ru>
parents:
15460
diff
changeset
|
1594 |
begin |
15717
eeab5b90c082
Fix some HUD icon issues in gfInvulnerable
Wuzzy <Wuzzy2@mail.ru>
parents:
15676
diff
changeset
|
1595 |
// Invulnerable |
eeab5b90c082
Fix some HUD icon issues in gfInvulnerable
Wuzzy <Wuzzy2@mail.ru>
parents:
15676
diff
changeset
|
1596 |
inc(t, 8); |
eeab5b90c082
Fix some HUD icon issues in gfInvulnerable
Wuzzy <Wuzzy2@mail.ru>
parents:
15676
diff
changeset
|
1597 |
DrawSprite(sprInvulnHud, cScreenWidth div 2 - t, i, 0); |
15484
b9b48e8b5ec4
Display invuln icon in gfInvulnerable mode
Wuzzy <Wuzzy2@mail.ru>
parents:
15460
diff
changeset
|
1598 |
if (CurrentHedgehog^.Effects[heResurrectable] <> 0) then |
b9b48e8b5ec4
Display invuln icon in gfInvulnerable mode
Wuzzy <Wuzzy2@mail.ru>
parents:
15460
diff
changeset
|
1599 |
// show halo for resurrectable hog |
15718
50dc9d0191d1
gfInvulnerable: Fix misplaced halo icon
Wuzzy <Wuzzy2@mail.ru>
parents:
15717
diff
changeset
|
1600 |
DrawSprite(sprHaloHud, cScreenWidth div 2 - t - 2, i - SpritesData[sprHaloHud].Height + 1, 0); |
15717
eeab5b90c082
Fix some HUD icon issues in gfInvulnerable
Wuzzy <Wuzzy2@mail.ru>
parents:
15676
diff
changeset
|
1601 |
// Vampirism |
eeab5b90c082
Fix some HUD icon issues in gfInvulnerable
Wuzzy <Wuzzy2@mail.ru>
parents:
15676
diff
changeset
|
1602 |
if cVampiric then |
eeab5b90c082
Fix some HUD icon issues in gfInvulnerable
Wuzzy <Wuzzy2@mail.ru>
parents:
15676
diff
changeset
|
1603 |
begin |
eeab5b90c082
Fix some HUD icon issues in gfInvulnerable
Wuzzy <Wuzzy2@mail.ru>
parents:
15676
diff
changeset
|
1604 |
inc(t, SpritesData[sprVampHud].Width + 2); |
eeab5b90c082
Fix some HUD icon issues in gfInvulnerable
Wuzzy <Wuzzy2@mail.ru>
parents:
15676
diff
changeset
|
1605 |
DrawSprite(sprVampHud, (cScreenWidth div 2 - t), i, 0); |
eeab5b90c082
Fix some HUD icon issues in gfInvulnerable
Wuzzy <Wuzzy2@mail.ru>
parents:
15676
diff
changeset
|
1606 |
end; |
15484
b9b48e8b5ec4
Display invuln icon in gfInvulnerable mode
Wuzzy <Wuzzy2@mail.ru>
parents:
15460
diff
changeset
|
1607 |
end; |
14989 | 1608 |
end |
14985
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1609 |
else |
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1610 |
cDemoClockFPSOffsetY:= 0; |
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1611 |
|
5 | 1612 |
// Wind bar |
14440 | 1613 |
if (UIDisplay <> uiNone) and (isNotHiddenByCinematic) then |
9693 | 1614 |
begin |
6685
ef706fccfb0a
moved other widgets under the USE_TOUCH_INTERFACE, added pause button (at least, graphically...)
koda
parents:
6683
diff
changeset
|
1615 |
{$IFDEF USE_TOUCH_INTERFACE} |
3405 | 1616 |
offsetX:= cScreenHeight - 13; |
1617 |
offsetY:= (cScreenWidth shr 1) + 74; |
|
2567 | 1618 |
{$ELSE} |
3405 | 1619 |
offsetX:= 30; |
1620 |
offsetY:= 180; |
|
2567 | 1621 |
{$ENDIF} |
3405 | 1622 |
DrawSprite(sprWindBar, (cScreenWidth shr 1) - offsetY, cScreenHeight - offsetX, 0); |
1623 |
if WindBarWidth > 0 then |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1624 |
begin |
3405 | 1625 |
{$WARNINGS OFF} |
14565
3105881d5840
Fix wind bar animation not looping properly
Wuzzy <Wuzzy2@mail.ru>
parents:
14563
diff
changeset
|
1626 |
r.x:= 8 - (RealTicks shr 6) mod 9; |
3405 | 1627 |
{$WARNINGS ON} |
1628 |
r.y:= 0; |
|
1629 |
r.w:= WindBarWidth; |
|
1630 |
r.h:= 13; |
|
1631 |
DrawSpriteFromRect(sprWindR, r, (cScreenWidth shr 1) - offsetY + 77, cScreenHeight - offsetX + 2, 13, 0); |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1632 |
end |
3405 | 1633 |
else |
1634 |
if WindBarWidth < 0 then |
|
1635 |
begin |
|
9693 | 1636 |
{$WARNINGS OFF} |
14565
3105881d5840
Fix wind bar animation not looping properly
Wuzzy <Wuzzy2@mail.ru>
parents:
14563
diff
changeset
|
1637 |
r.x:= (Longword(WindBarWidth) + RealTicks shr 6) mod 9; |
9693 | 1638 |
{$WARNINGS ON} |
1639 |
r.y:= 0; |
|
1640 |
r.w:= - WindBarWidth; |
|
1641 |
r.h:= 13; |
|
1642 |
DrawSpriteFromRect(sprWindL, r, (cScreenWidth shr 1) - offsetY + 74 + WindBarWidth, cScreenHeight - offsetX + 2, 13, 0); |
|
1643 |
end |
|
1644 |
end; |
|
5 | 1645 |
|
11887
083c12795632
Show symbols at bottom right while extra damage / low grav. are active
Wuzzy <almikes@aol.com>
parents:
11881
diff
changeset
|
1646 |
// Indicators for global effects (extra damage, low gravity) |
14440 | 1647 |
if (UIDisplay <> uiNone) and (isNotHiddenByCinematic) then |
11887
083c12795632
Show symbols at bottom right while extra damage / low grav. are active
Wuzzy <almikes@aol.com>
parents:
11881
diff
changeset
|
1648 |
begin |
14320
5cff42e1dd92
Add status indicators (low grav / extra dmg) in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14303
diff
changeset
|
1649 |
{$IFDEF USE_TOUCH_INTERFACE} |
5cff42e1dd92
Add status indicators (low grav / extra dmg) in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14303
diff
changeset
|
1650 |
offsetX:= (cScreenWidth shr 1) - 95; |
5cff42e1dd92
Add status indicators (low grav / extra dmg) in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14303
diff
changeset
|
1651 |
offsetY:= cScreenHeight - 21; |
5cff42e1dd92
Add status indicators (low grav / extra dmg) in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14303
diff
changeset
|
1652 |
{$ELSE} |
11887
083c12795632
Show symbols at bottom right while extra damage / low grav. are active
Wuzzy <almikes@aol.com>
parents:
11881
diff
changeset
|
1653 |
offsetX:= 45; |
083c12795632
Show symbols at bottom right while extra damage / low grav. are active
Wuzzy <almikes@aol.com>
parents:
11881
diff
changeset
|
1654 |
offsetY:= 51; |
14320
5cff42e1dd92
Add status indicators (low grav / extra dmg) in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14303
diff
changeset
|
1655 |
{$ENDIF} |
11887
083c12795632
Show symbols at bottom right while extra damage / low grav. are active
Wuzzy <almikes@aol.com>
parents:
11881
diff
changeset
|
1656 |
|
083c12795632
Show symbols at bottom right while extra damage / low grav. are active
Wuzzy <almikes@aol.com>
parents:
11881
diff
changeset
|
1657 |
if cDamageModifier = _1_5 then |
083c12795632
Show symbols at bottom right while extra damage / low grav. are active
Wuzzy <almikes@aol.com>
parents:
11881
diff
changeset
|
1658 |
begin |
083c12795632
Show symbols at bottom right while extra damage / low grav. are active
Wuzzy <almikes@aol.com>
parents:
11881
diff
changeset
|
1659 |
DrawTextureF(ropeIconTex, 1, (cScreenWidth shr 1) - offsetX, cScreenHeight - offsetY, 0, 1, 32, 32); |
083c12795632
Show symbols at bottom right while extra damage / low grav. are active
Wuzzy <almikes@aol.com>
parents:
11881
diff
changeset
|
1660 |
DrawTextureF(SpritesData[sprAMAmmos].Texture, 0.90, (cScreenWidth shr 1) - offsetX, cScreenHeight - offsetY, ord(amExtraDamage) - 1, 1, 32, 32); |
14320
5cff42e1dd92
Add status indicators (low grav / extra dmg) in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14303
diff
changeset
|
1661 |
{$IFDEF USE_TOUCH_INTERFACE} |
5cff42e1dd92
Add status indicators (low grav / extra dmg) in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14303
diff
changeset
|
1662 |
offsetX := offsetX - 33 |
5cff42e1dd92
Add status indicators (low grav / extra dmg) in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14303
diff
changeset
|
1663 |
{$ELSE} |
11887
083c12795632
Show symbols at bottom right while extra damage / low grav. are active
Wuzzy <almikes@aol.com>
parents:
11881
diff
changeset
|
1664 |
offsetX := offsetX + 33 |
14320
5cff42e1dd92
Add status indicators (low grav / extra dmg) in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14303
diff
changeset
|
1665 |
{$ENDIF} |
11887
083c12795632
Show symbols at bottom right while extra damage / low grav. are active
Wuzzy <almikes@aol.com>
parents:
11881
diff
changeset
|
1666 |
end; |
083c12795632
Show symbols at bottom right while extra damage / low grav. are active
Wuzzy <almikes@aol.com>
parents:
11881
diff
changeset
|
1667 |
if (cLowGravity) or ((GameFlags and gfLowGravity) <> 0) then |
083c12795632
Show symbols at bottom right while extra damage / low grav. are active
Wuzzy <almikes@aol.com>
parents:
11881
diff
changeset
|
1668 |
begin |
083c12795632
Show symbols at bottom right while extra damage / low grav. are active
Wuzzy <almikes@aol.com>
parents:
11881
diff
changeset
|
1669 |
DrawTextureF(ropeIconTex, 1, (cScreenWidth shr 1) - offsetX, cScreenHeight - offsetY, 0, 1, 32, 32); |
083c12795632
Show symbols at bottom right while extra damage / low grav. are active
Wuzzy <almikes@aol.com>
parents:
11881
diff
changeset
|
1670 |
DrawTextureF(SpritesData[sprAMAmmos].Texture, 0.90, (cScreenWidth shr 1) - offsetX, cScreenHeight - offsetY, ord(amLowGravity) - 1, 1, 32, 32); |
15020
6d4a607f2196
Display laser sight icon above wind bar when laser sight utility is active
Wuzzy <Wuzzy2@mail.ru>
parents:
15017
diff
changeset
|
1671 |
{$IFDEF USE_TOUCH_INTERFACE} |
6d4a607f2196
Display laser sight icon above wind bar when laser sight utility is active
Wuzzy <Wuzzy2@mail.ru>
parents:
15017
diff
changeset
|
1672 |
offsetX := offsetX - 33 |
6d4a607f2196
Display laser sight icon above wind bar when laser sight utility is active
Wuzzy <Wuzzy2@mail.ru>
parents:
15017
diff
changeset
|
1673 |
{$ELSE} |
6d4a607f2196
Display laser sight icon above wind bar when laser sight utility is active
Wuzzy <Wuzzy2@mail.ru>
parents:
15017
diff
changeset
|
1674 |
offsetX := offsetX + 33 |
6d4a607f2196
Display laser sight icon above wind bar when laser sight utility is active
Wuzzy <Wuzzy2@mail.ru>
parents:
15017
diff
changeset
|
1675 |
{$ENDIF} |
6d4a607f2196
Display laser sight icon above wind bar when laser sight utility is active
Wuzzy <Wuzzy2@mail.ru>
parents:
15017
diff
changeset
|
1676 |
end; |
6d4a607f2196
Display laser sight icon above wind bar when laser sight utility is active
Wuzzy <Wuzzy2@mail.ru>
parents:
15017
diff
changeset
|
1677 |
if cLaserSighting then |
6d4a607f2196
Display laser sight icon above wind bar when laser sight utility is active
Wuzzy <Wuzzy2@mail.ru>
parents:
15017
diff
changeset
|
1678 |
begin |
6d4a607f2196
Display laser sight icon above wind bar when laser sight utility is active
Wuzzy <Wuzzy2@mail.ru>
parents:
15017
diff
changeset
|
1679 |
DrawTextureF(ropeIconTex, 1, (cScreenWidth shr 1) - offsetX, cScreenHeight - offsetY, 0, 1, 32, 32); |
6d4a607f2196
Display laser sight icon above wind bar when laser sight utility is active
Wuzzy <Wuzzy2@mail.ru>
parents:
15017
diff
changeset
|
1680 |
DrawTextureF(SpritesData[sprAMAmmos].Texture, 0.90, (cScreenWidth shr 1) - offsetX, cScreenHeight - offsetY, ord(amLaserSight) - 1, 1, 32, 32); |
11887
083c12795632
Show symbols at bottom right while extra damage / low grav. are active
Wuzzy <almikes@aol.com>
parents:
11881
diff
changeset
|
1681 |
end; |
083c12795632
Show symbols at bottom right while extra damage / low grav. are active
Wuzzy <almikes@aol.com>
parents:
11881
diff
changeset
|
1682 |
end; |
083c12795632
Show symbols at bottom right while extra damage / low grav. are active
Wuzzy <almikes@aol.com>
parents:
11881
diff
changeset
|
1683 |
|
14418
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1684 |
// Cinematic Mode: Render black bars |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1685 |
if CinematicSteps > 0 then |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1686 |
begin |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1687 |
r.x:= ViewLeftX; |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1688 |
r.w:= ViewWidth; |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1689 |
r.y:= ViewTopY; |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1690 |
CinematicBarH:= (ViewHeight * CinematicSteps) div 2048; |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1691 |
r.h:= CinematicBarH; |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1692 |
DrawRect(r, 0, 0, 0, $FF, true); |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1693 |
r.y:= ViewBottomY - r.h; |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1694 |
DrawRect(r, 0, 0, 0, $FF, true); |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1695 |
end; |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1696 |
|
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1697 |
// Touchscreen interface widgets |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1698 |
{$IFDEF USE_TOUCH_INTERFACE} |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1699 |
DrawScreenWidget(@arrowLeft); |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1700 |
DrawScreenWidget(@arrowRight); |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1701 |
DrawScreenWidget(@arrowUp); |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1702 |
DrawScreenWidget(@arrowDown); |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1703 |
|
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1704 |
DrawScreenWidget(@fireButton); |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1705 |
DrawScreenWidget(@jumpWidget); |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1706 |
DrawScreenWidget(@AMWidget); |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1707 |
DrawScreenWidget(@utilityWidget); |
14559
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
1708 |
DrawScreenWidget(@utilityWidget2); |
14418
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1709 |
DrawScreenWidget(@pauseButton); |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1710 |
{$ENDIF} |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1711 |
|
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1712 |
// Captions |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1713 |
if UIDisplay <> uiNone then |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1714 |
DrawCaptions; |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1715 |
|
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1716 |
// Lag alert |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1717 |
if isInLag then |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1718 |
DrawSprite(sprLag, 32 - (cScreenWidth shr 1), 32, (RealTicks shr 7) mod 12); |
f9a3cfdec1df
Hide most HUD elements in cinematic mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14416
diff
changeset
|
1719 |
|
14025
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1720 |
// Chat |
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1721 |
DrawChat; |
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1722 |
|
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1723 |
|
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1724 |
// Mission panel |
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1725 |
if not isFirstFrame and (missionTimer <> 0) or isShowMission or isPaused or fastUntilLag or (GameState = gsConfirm) then |
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1726 |
begin |
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1727 |
if (ReadyTimeLeft = 0) and (missionTimer > 0) then |
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1728 |
dec(missionTimer, Lag); |
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1729 |
if missionTimer < 0 then |
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1730 |
missionTimer:= 0; // avoid subtracting below 0 |
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1731 |
if missionTex <> nil then |
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1732 |
DrawTextureCentered(0, Min((cScreenHeight shr 1) + 100, cScreenHeight - 48 - missionTex^.h), missionTex); |
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1733 |
end; |
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1734 |
if missionTimer = 0 then |
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1735 |
isForceMission := false; |
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1736 |
|
161 | 1737 |
// AmmoMenu |
6795
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
1738 |
if bShowAmmoMenu and ((AMState = AMHidden) or (AMState = AMHiding)) then |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
1739 |
begin |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
1740 |
if (AMState = AMHidden) then |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
1741 |
AMAnimStartTime:= RealTicks |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
1742 |
else |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
1743 |
AMAnimStartTime:= RealTicks - (AMAnimDuration - (RealTicks - AMAnimStartTime)); |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
1744 |
AMState:= AMShowingUp; |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
1745 |
end; |
8099
a7f02b902b6f
throw in some 'nots' trying to restore pas2c functionality
koda
parents:
8026
diff
changeset
|
1746 |
if (not bShowAmmoMenu) and ((AMstate = AMShowing) or (AMState = AMShowingUp)) then |
6795
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
1747 |
begin |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
1748 |
if (AMState = AMShowing) then |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
1749 |
AMAnimStartTime:= RealTicks |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
1750 |
else |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
1751 |
AMAnimStartTime:= RealTicks - (AMAnimDuration - (RealTicks - AMAnimStartTime)); |
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
1752 |
AMState:= AMHiding; |
8330 | 1753 |
end; |
6795
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
1754 |
|
e4831e13e04a
make ammomenu's speed dependent on RealTicks rather than frames
Xeli
parents:
6794
diff
changeset
|
1755 |
if bShowAmmoMenu or (AMState = AMHiding) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1756 |
ShowAmmoMenu; |
161 | 1757 |
|
14024
58e54e737279
Tweak commenting in uWorld render routine
Wuzzy <Wuzzy2@mail.ru>
parents:
13983
diff
changeset
|
1758 |
// Centered status/menu messages (synchronizing, auto skip, pause, etc.) |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1759 |
if fastUntilLag then |
13734
b83154cc8fad
Prevent pause/synchronizing/AFK mode text being rendered at the same time
Wuzzy <Wuzzy2@mail.ru>
parents:
13638
diff
changeset
|
1760 |
DrawTextureCentered(0, (cScreenHeight shr 1), SyncTexture) |
b83154cc8fad
Prevent pause/synchronizing/AFK mode text being rendered at the same time
Wuzzy <Wuzzy2@mail.ru>
parents:
13638
diff
changeset
|
1761 |
else if isAFK then |
b83154cc8fad
Prevent pause/synchronizing/AFK mode text being rendered at the same time
Wuzzy <Wuzzy2@mail.ru>
parents:
13638
diff
changeset
|
1762 |
DrawTextureCentered(0, (cScreenHeight shr 1), AFKTexture) |
b83154cc8fad
Prevent pause/synchronizing/AFK mode text being rendered at the same time
Wuzzy <Wuzzy2@mail.ru>
parents:
13638
diff
changeset
|
1763 |
else if isPaused then |
6999 | 1764 |
DrawTextureCentered(0, (cScreenHeight shr 1), PauseTexture); |
14024
58e54e737279
Tweak commenting in uWorld render routine
Wuzzy <Wuzzy2@mail.ru>
parents:
13983
diff
changeset
|
1765 |
|
14025
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1766 |
// Cursor |
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1767 |
if isCursorVisible and bShowAmmoMenu then |
97e48a6c2535
Draw mission panel behind ammo menu tooltip
Wuzzy <Wuzzy2@mail.ru>
parents:
14024
diff
changeset
|
1768 |
DrawSprite(sprArrow, CursorPoint.X, cScreenHeight - CursorPoint.Y, (RealTicks shr 6) mod 8); |
2786 | 1769 |
|
14024
58e54e737279
Tweak commenting in uWorld render routine
Wuzzy <Wuzzy2@mail.ru>
parents:
13983
diff
changeset
|
1770 |
// FPS and demo replay time |
6685
ef706fccfb0a
moved other widgets under the USE_TOUCH_INTERFACE, added pause button (at least, graphically...)
koda
parents:
6683
diff
changeset
|
1771 |
{$IFDEF USE_TOUCH_INTERFACE} |
14985
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1772 |
offsetY:= cDemoClockFPSOffsetY + 10 + pauseButton.frame.y + pauseButton.frame.h; |
2724 | 1773 |
{$ELSE} |
14985
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1774 |
offsetY:= cDemoClockFPSOffsetY + 10; |
2724 | 1775 |
{$ENDIF} |
14985
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1776 |
offsetX:= cOffsetY; |
3696 | 1777 |
if (RM = rmDefault) or (RM = rmRightEye) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1778 |
begin |
3692 | 1779 |
inc(Frames); |
2850
f6f8db825ce7
A little clock for convenience in finding things in demos
nemo
parents:
2839
diff
changeset
|
1780 |
|
3692 | 1781 |
if cShowFPS or (GameType = gmtDemo) then |
1782 |
inc(CountTicks, Lag); |
|
14024
58e54e737279
Tweak commenting in uWorld render routine
Wuzzy <Wuzzy2@mail.ru>
parents:
13983
diff
changeset
|
1783 |
|
58e54e737279
Tweak commenting in uWorld render routine
Wuzzy <Wuzzy2@mail.ru>
parents:
13983
diff
changeset
|
1784 |
// Demo replay time |
3692 | 1785 |
if (GameType = gmtDemo) and (CountTicks >= 1000) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1786 |
begin |
7016 | 1787 |
i:= GameTicks div 1000; |
3692 | 1788 |
t:= i mod 60; |
1789 |
s:= inttostr(t); |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1790 |
if t < 10 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1791 |
s:= '0' + s; |
3692 | 1792 |
i:= i div 60; |
1793 |
t:= i mod 60; |
|
1794 |
s:= inttostr(t) + ':' + s; |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1795 |
if t < 10 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1796 |
s:= '0' + s; |
3692 | 1797 |
s:= inttostr(i div 60) + ':' + s; |
8330 | 1798 |
|
1799 |
||
3692 | 1800 |
tmpSurface:= TTF_RenderUTF8_Blended(Fontz[fnt16].Handle, Str2PChar(s), cWhiteColorChannels); |
1801 |
tmpSurface:= doSurfaceConversion(tmpSurface); |
|
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:
10628
diff
changeset
|
1802 |
FreeAndNilTexture(timeTexture); |
3692 | 1803 |
timeTexture:= Surface2Tex(tmpSurface, false); |
1804 |
SDL_FreeSurface(tmpSurface) |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1805 |
end; |
2850
f6f8db825ce7
A little clock for convenience in finding things in demos
nemo
parents:
2839
diff
changeset
|
1806 |
|
14985
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1807 |
if (timeTexture <> nil) and (UIDisplay <> uiNone) then |
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1808 |
DrawTexture((cScreenWidth shr 1) - 20 - timeTexture^.w - offsetX, offsetY, timeTexture); |
2850
f6f8db825ce7
A little clock for convenience in finding things in demos
nemo
parents:
2839
diff
changeset
|
1809 |
|
14024
58e54e737279
Tweak commenting in uWorld render routine
Wuzzy <Wuzzy2@mail.ru>
parents:
13983
diff
changeset
|
1810 |
// FPS counter |
14985
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1811 |
if cShowFPS and (UIDisplay <> uiNone) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1812 |
begin |
3692 | 1813 |
if CountTicks >= 1000 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1814 |
begin |
3692 | 1815 |
FPS:= Frames; |
1816 |
Frames:= 0; |
|
1817 |
CountTicks:= 0; |
|
13898 | 1818 |
s:= Format(shortstring(trmsg[sidFPS]), inttostr(FPS)); |
13983
9be2926890cd
Support CJK fonts for sidFPS as well
Wuzzy <Wuzzy2@mail.ru>
parents:
13898
diff
changeset
|
1819 |
tmpSurface:= TTF_RenderUTF8_Blended(Fontz[CheckCJKFont(trmsg[sidFPS],fnt16)].Handle, Str2PChar(s), cWhiteColorChannels); |
3692 | 1820 |
tmpSurface:= doSurfaceConversion(tmpSurface); |
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:
10628
diff
changeset
|
1821 |
FreeAndNilTexture(fpsTexture); |
3692 | 1822 |
fpsTexture:= Surface2Tex(tmpSurface, false); |
1823 |
SDL_FreeSurface(tmpSurface) |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1824 |
end; |
3692 | 1825 |
if fpsTexture <> nil then |
14985
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1826 |
begin |
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1827 |
if timeTexture <> nil then |
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1828 |
i:= fpsTexture^.h + 5 |
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1829 |
else |
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1830 |
i:= 0; |
15227
d48eba5ac715
Fix sidFPS not being properly right-aligned (again!)
Wuzzy <Wuzzy2@mail.ru>
parents:
15226
diff
changeset
|
1831 |
DrawTexture((cScreenWidth shr 1) - 20 - fpsTexture^.w - offsetX, offsetY + i, fpsTexture); |
14985
bcecb3349948
Display current health in top right corner
Wuzzy <Wuzzy2@mail.ru>
parents:
14935
diff
changeset
|
1832 |
end; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1833 |
end; |
3692 | 1834 |
end; |
1835 |
||
14024
58e54e737279
Tweak commenting in uWorld render routine
Wuzzy <Wuzzy2@mail.ru>
parents:
13983
diff
changeset
|
1836 |
// Quit Y/N question |
2724 | 1837 |
if GameState = gsConfirm then |
8675
3fb25201d303
This has bothered me for the longest time. Move texture so it doesn't overlap. I'd initially had a test for isPaused, but jumping texture bothered me.
nemo
parents:
8471
diff
changeset
|
1838 |
DrawTextureCentered(0, (cScreenHeight shr 1)-40, ConfirmTexture); |
2161
0c8634241fa4
Some work on zooming. Hedgewars are now unplayable.
unc0rr
parents:
2152
diff
changeset
|
1839 |
|
3107 | 1840 |
if ScreenFade <> sfNone then |
1841 |
begin |
|
8099
a7f02b902b6f
throw in some 'nots' trying to restore pas2c functionality
koda
parents:
8026
diff
changeset
|
1842 |
if (not isFirstFrame) then |
3107 | 1843 |
case ScreenFade of |
1844 |
sfToBlack, sfToWhite: if ScreenFadeValue + Lag * ScreenFadeSpeed < sfMax then |
|
1845 |
inc(ScreenFadeValue, Lag * ScreenFadeSpeed) |
|
1846 |
else |
|
3123 | 1847 |
ScreenFadeValue:= sfMax; |
3107 | 1848 |
sfFromBlack, sfFromWhite: if ScreenFadeValue - Lag * ScreenFadeSpeed > 0 then |
1849 |
dec(ScreenFadeValue, Lag * ScreenFadeSpeed) |
|
1850 |
else |
|
3123 | 1851 |
ScreenFadeValue:= 0; |
3107 | 1852 |
end; |
1853 |
if ScreenFade <> sfNone then |
|
1854 |
begin |
|
10871 | 1855 |
r.x:= ViewLeftX; |
1856 |
r.y:= ViewTopY; |
|
1857 |
r.w:= ViewWidth; |
|
1858 |
r.h:= ViewHeight; |
|
1859 |
||
3107 | 1860 |
case ScreenFade of |
10871 | 1861 |
sfToBlack, sfFromBlack: DrawRect(r, 0, 0, 0, ScreenFadeValue * 255 div 1000, true); |
1862 |
sfToWhite, sfFromWhite: DrawRect(r, $FF, $FF, $FF, ScreenFadeValue * 255 div 1000, true); |
|
3107 | 1863 |
end; |
3697 | 1864 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1865 |
if not isFirstFrame and ((ScreenFadeValue = 0) or (ScreenFadeValue = sfMax)) then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1866 |
ScreenFade:= sfNone |
3107 | 1867 |
end |
1868 |
end; |
|
1869 |
||
7198
5debd5fe526e
1. Add IFDEFs for video recording
Stepan777 <stepik-777@mail.ru>
parents:
7194
diff
changeset
|
1870 |
{$IFDEF USE_VIDEO_RECORDING} |
14024
58e54e737279
Tweak commenting in uWorld render routine
Wuzzy <Wuzzy2@mail.ru>
parents:
13983
diff
changeset
|
1871 |
// During video prerecording draw red blinking circle and text 'rec' |
7180 | 1872 |
if flagPrerecording then |
1873 |
begin |
|
1874 |
if recTexture = nil then |
|
1875 |
begin |
|
1876 |
s:= 'rec'; |
|
1877 |
tmpSurface:= TTF_RenderUTF8_Blended(Fontz[fntBig].Handle, Str2PChar(s), cWhiteColorChannels); |
|
1878 |
tmpSurface:= doSurfaceConversion(tmpSurface); |
|
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:
10628
diff
changeset
|
1879 |
FreeAndNilTexture(recTexture); |
7180 | 1880 |
recTexture:= Surface2Tex(tmpSurface, false); |
1881 |
SDL_FreeSurface(tmpSurface) |
|
1882 |
end; |
|
1883 |
DrawTexture( -(cScreenWidth shr 1) + 50, 20, recTexture); |
|
1884 |
||
14935
9ab78e08a34c
Fix Pas2C unable to compile with VIDEOREC
Wuzzy <Wuzzy2@mail.ru>
parents:
14830
diff
changeset
|
1885 |
t:= -255 + ((RealTicks div 2) and 511); |
9ab78e08a34c
Fix Pas2C unable to compile with VIDEOREC
Wuzzy <Wuzzy2@mail.ru>
parents:
14830
diff
changeset
|
1886 |
a:= Byte(min(255, abs(t))); |
10871 | 1887 |
|
7180 | 1888 |
// draw red circle |
10871 | 1889 |
DrawCircleFilled(-(cScreenWidth shr 1) + 30, 35, 10, $FF, $00, $00, a); |
7180 | 1890 |
end; |
7198
5debd5fe526e
1. Add IFDEFs for video recording
Stepan777 <stepik-777@mail.ru>
parents:
7194
diff
changeset
|
1891 |
{$ENDIF} |
7180 | 1892 |
|
3123 | 1893 |
SetScale(zoom); |
1894 |
||
1895 |
// Cursor |
|
10978
54a49174dbec
cursor x/y when targeting for mikade's visual effects. this is not synced
nemo
parents:
10939
diff
changeset
|
1896 |
if isCursorVisible and (not bShowAmmoMenu) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1897 |
begin |
10978
54a49174dbec
cursor x/y when targeting for mikade's visual effects. this is not synced
nemo
parents:
10939
diff
changeset
|
1898 |
if not CurrentTeam^.ExtDriven then TargetCursorPoint:= CursorPoint; |
54a49174dbec
cursor x/y when targeting for mikade's visual effects. this is not synced
nemo
parents:
10939
diff
changeset
|
1899 |
with CurrentHedgehog^ do |
54a49174dbec
cursor x/y when targeting for mikade's visual effects. this is not synced
nemo
parents:
10939
diff
changeset
|
1900 |
if (Gear <> nil) and ((Gear^.State and gstChooseTarget) <> 0) then |
54a49174dbec
cursor x/y when targeting for mikade's visual effects. this is not synced
nemo
parents:
10939
diff
changeset
|
1901 |
begin |
54a49174dbec
cursor x/y when targeting for mikade's visual effects. this is not synced
nemo
parents:
10939
diff
changeset
|
1902 |
i:= GetCurAmmoEntry(CurrentHedgehog^)^.Pos; |
54a49174dbec
cursor x/y when targeting for mikade's visual effects. this is not synced
nemo
parents:
10939
diff
changeset
|
1903 |
with Ammoz[CurAmmoType] do |
15017
7ff86274114e
Refactor PosCount: Use 0 instead of 1 for unused PosSprite
Wuzzy <Wuzzy2@mail.ru>
parents:
14989
diff
changeset
|
1904 |
if PosCount > 0 then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1905 |
begin |
10978
54a49174dbec
cursor x/y when targeting for mikade's visual effects. this is not synced
nemo
parents:
10939
diff
changeset
|
1906 |
if (CurAmmoType = amGirder) or (CurAmmoType = amTeleport) then |
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:
10160
diff
changeset
|
1907 |
begin |
10978
54a49174dbec
cursor x/y when targeting for mikade's visual effects. this is not synced
nemo
parents:
10939
diff
changeset
|
1908 |
// pulsating transparency |
54a49174dbec
cursor x/y when targeting for mikade's visual effects. this is not synced
nemo
parents:
10939
diff
changeset
|
1909 |
if ((GameTicks div 16) mod $80) >= $40 then |
54a49174dbec
cursor x/y when targeting for mikade's visual effects. this is not synced
nemo
parents:
10939
diff
changeset
|
1910 |
Tint($FF, $FF, $FF, $C0 - (GameTicks div 16) mod $40) |
54a49174dbec
cursor x/y when targeting for mikade's visual effects. this is not synced
nemo
parents:
10939
diff
changeset
|
1911 |
else |
54a49174dbec
cursor x/y when targeting for mikade's visual effects. this is not synced
nemo
parents:
10939
diff
changeset
|
1912 |
Tint($FF, $FF, $FF, $80 + (GameTicks div 16) mod $40); |
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:
10160
diff
changeset
|
1913 |
end; |
10978
54a49174dbec
cursor x/y when targeting for mikade's visual effects. this is not synced
nemo
parents:
10939
diff
changeset
|
1914 |
DrawSprite(PosSprite, TargetCursorPoint.X - (SpritesData[PosSprite].Width shr 1), cScreenHeight - TargetCursorPoint.Y - (SpritesData[PosSprite].Height shr 1),i); |
54a49174dbec
cursor x/y when targeting for mikade's visual effects. this is not synced
nemo
parents:
10939
diff
changeset
|
1915 |
Untint(); |
15226
8705ee93f8b3
Display special icon when moving bee cursor over gray wrap area
Wuzzy <Wuzzy2@mail.ru>
parents:
15170
diff
changeset
|
1916 |
if (WorldEdge = weWrap) and (CurAmmoType = amBee) then |
8705ee93f8b3
Display special icon when moving bee cursor over gray wrap area
Wuzzy <Wuzzy2@mail.ru>
parents:
15170
diff
changeset
|
1917 |
begin |
8705ee93f8b3
Display special icon when moving bee cursor over gray wrap area
Wuzzy <Wuzzy2@mail.ru>
parents:
15170
diff
changeset
|
1918 |
if (TargetCursorPoint.X - WorldDx > rightX) then |
8705ee93f8b3
Display special icon when moving bee cursor over gray wrap area
Wuzzy <Wuzzy2@mail.ru>
parents:
15170
diff
changeset
|
1919 |
DrawSprite(sprThroughWrap, TargetCursorPoint.X - (SpritesData[sprThroughWrap].Width shr 1), cScreenHeight - TargetCursorPoint.Y - (SpritesData[PosSprite].Height shr 1) - SpritesData[sprThroughWrap].Height - 2, 0) |
8705ee93f8b3
Display special icon when moving bee cursor over gray wrap area
Wuzzy <Wuzzy2@mail.ru>
parents:
15170
diff
changeset
|
1920 |
else if (TargetCursorPoint.X - WorldDx < leftX) then |
8705ee93f8b3
Display special icon when moving bee cursor over gray wrap area
Wuzzy <Wuzzy2@mail.ru>
parents:
15170
diff
changeset
|
1921 |
DrawSprite(sprThroughWrap, TargetCursorPoint.X - (SpritesData[sprThroughWrap].Width shr 1), cScreenHeight - TargetCursorPoint.Y - (SpritesData[PosSprite].Height shr 1) - SpritesData[sprThroughWrap].Height - 2, 1); |
8705ee93f8b3
Display special icon when moving bee cursor over gray wrap area
Wuzzy <Wuzzy2@mail.ru>
parents:
15170
diff
changeset
|
1922 |
end; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1923 |
end; |
10978
54a49174dbec
cursor x/y when targeting for mikade's visual effects. this is not synced
nemo
parents:
10939
diff
changeset
|
1924 |
end; |
54a49174dbec
cursor x/y when targeting for mikade's visual effects. this is not synced
nemo
parents:
10939
diff
changeset
|
1925 |
DrawTextureF(SpritesData[sprArrow].Texture, cDefaultZoomLevel / cScaleFactor, TargetCursorPoint.X + round(SpritesData[sprArrow].Width / cScaleFactor), cScreenHeight + round(SpritesData[sprArrow].Height / cScaleFactor) - TargetCursorPoint.Y, (RealTicks shr 6) mod 8, 1, SpritesData[sprArrow].Width, SpritesData[sprArrow].Height); |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1926 |
end; |
8026
4a4f21070479
merge xymeng's gsoc engine with a few updates (and further checks on symbol definitions)
koda
parents:
7946
diff
changeset
|
1927 |
|
10304
7e40820b7ed6
fix gl2 build, further rendering cleanup WIP, also new chat command: /debugvl
sheepluva
parents:
10300
diff
changeset
|
1928 |
// debug stuff |
7e40820b7ed6
fix gl2 build, further rendering cleanup WIP, also new chat command: /debugvl
sheepluva
parents:
10300
diff
changeset
|
1929 |
if cViewLimitsDebug then |
7e40820b7ed6
fix gl2 build, further rendering cleanup WIP, also new chat command: /debugvl
sheepluva
parents:
10300
diff
changeset
|
1930 |
begin |
7e40820b7ed6
fix gl2 build, further rendering cleanup WIP, also new chat command: /debugvl
sheepluva
parents:
10300
diff
changeset
|
1931 |
r.x:= ViewLeftX; |
7e40820b7ed6
fix gl2 build, further rendering cleanup WIP, also new chat command: /debugvl
sheepluva
parents:
10300
diff
changeset
|
1932 |
r.y:= ViewTopY; |
7e40820b7ed6
fix gl2 build, further rendering cleanup WIP, also new chat command: /debugvl
sheepluva
parents:
10300
diff
changeset
|
1933 |
r.w:= ViewWidth; |
7e40820b7ed6
fix gl2 build, further rendering cleanup WIP, also new chat command: /debugvl
sheepluva
parents:
10300
diff
changeset
|
1934 |
r.h:= ViewHeight; |
7e40820b7ed6
fix gl2 build, further rendering cleanup WIP, also new chat command: /debugvl
sheepluva
parents:
10300
diff
changeset
|
1935 |
DrawRect(r, 255, 0, 0, 128, false); |
7e40820b7ed6
fix gl2 build, further rendering cleanup WIP, also new chat command: /debugvl
sheepluva
parents:
10300
diff
changeset
|
1936 |
end; |
7e40820b7ed6
fix gl2 build, further rendering cleanup WIP, also new chat command: /debugvl
sheepluva
parents:
10300
diff
changeset
|
1937 |
|
3107 | 1938 |
isFirstFrame:= false |
4 | 1939 |
end; |
1940 |
||
7343 | 1941 |
var PrevSentPointTime: LongWord = 0; |
1942 |
||
79 | 1943 |
procedure MoveCamera; |
15672
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
1944 |
var EdgesDist, shs,z, dstX: LongInt; |
9755
6306b54dd8fc
don't allow autocamera to mess with targetting when e.g. spamming air-attacks in inf attack mode
sheepluva
parents:
9720
diff
changeset
|
1945 |
inbtwnTrgtAttks: Boolean; |
4 | 1946 |
begin |
5502 | 1947 |
{$IFNDEF MOBILE} |
8373
209c9ba77a09
Prevent camera from moving with auto camera disabled when remote teams are targetting
nemo
parents:
8370
diff
changeset
|
1948 |
if (not (CurrentTeam^.ExtDriven and isCursorVisible and (not bShowAmmoMenu) and autoCameraOn)) and cHasFocus and (GameState <> gsConfirm) then |
5191
c7000a6b397b
- Implement a thin wrapper over real cursor, which eliminates need in SDL_WarpMouse outside game window
unc0rr
parents:
5149
diff
changeset
|
1949 |
uCursor.updatePosition(); |
3551 | 1950 |
{$ENDIF} |
5852 | 1951 |
z:= round(200/zoom); |
13622 | 1952 |
inbtwnTrgtAttks := ((GameFlags and gfInfAttack) <> 0) and (CurrentHedgehog <> nil) and ((CurrentHedgehog^.Gear = nil) or (CurrentHedgehog^.Gear <> FollowGear)) and ((Ammoz[CurrentHedgehog^.CurAmmoType].Ammo.Propz and ammoprop_NeedTarget) <> 0); |
9954 | 1953 |
if autoCameraOn and (not PlacingHogs) and (FollowGear <> nil) and (not isCursorVisible) and (not bShowAmmoMenu) and (not fastUntilLag) and (not inbtwnTrgtAttks) then |
7187
aff30d80bd7b
- Allow camera movement while current hedgehog is falling
unc0rr
parents:
7167
diff
changeset
|
1954 |
if ((abs(CursorPoint.X - prevPoint.X) + abs(CursorPoint.Y - prevpoint.Y)) > 4) then |
6296 | 1955 |
begin |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
1956 |
FollowGear:= nil; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
1957 |
prevPoint:= CursorPoint; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
1958 |
exit |
6296 | 1959 |
end |
3680 | 1960 |
else |
6296 | 1961 |
begin |
10917 | 1962 |
dstX:= hwRound(FollowGear^.X) + hwSign(FollowGear^.dX) * z + WorldDx; |
10662 | 1963 |
|
10917 | 1964 |
if (WorldEdge = weWrap) then |
1965 |
begin |
|
14303
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14302
diff
changeset
|
1966 |
if dstX - prevPoint.X < (leftX - rightX) div 2 then |
10917 | 1967 |
CursorPoint.X:= (prevPoint.X * 7 + dstX - (leftX - rightX)) div 8 |
14303
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14302
diff
changeset
|
1968 |
else if dstX - prevPoint.X > (rightX - leftX) div 2 then |
10917 | 1969 |
CursorPoint.X:= (prevPoint.X * 7 + dstX - (rightX - leftX)) div 8 |
1970 |
else |
|
1971 |
CursorPoint.X:= (prevPoint.X * 7 + dstX) div 8; |
|
1972 |
end |
|
1973 |
else // usual camera movement routine |
|
1974 |
begin |
|
1975 |
CursorPoint.X:= (prevPoint.X * 7 + dstX) div 8; |
|
1976 |
end; |
|
10160 | 1977 |
|
11156
efea685933ae
fix pas2c build, it was broken in the long long ago ( 97f9a25024e6 )
sheepluva
parents:
11151
diff
changeset
|
1978 |
if isPhone() or (cScreenHeight < 600) or (hwFloat(FollowGear^.dY * z).Round < 10) then |
6016
85410eef7ba4
disable the followgear vertical offset for small screen devices
koda
parents:
6011
diff
changeset
|
1979 |
CursorPoint.Y:= (prevPoint.Y * 7 + cScreenHeight - (hwRound(FollowGear^.Y) + WorldDy)) div 8 |
85410eef7ba4
disable the followgear vertical offset for small screen devices
koda
parents:
6011
diff
changeset
|
1980 |
else |
85410eef7ba4
disable the followgear vertical offset for small screen devices
koda
parents:
6011
diff
changeset
|
1981 |
CursorPoint.Y:= (prevPoint.Y * 7 + cScreenHeight - (hwRound(FollowGear^.Y) + hwSign(FollowGear^.dY) * z + WorldDy)) div 8; |
6296 | 1982 |
end; |
4 | 1983 |
|
10917 | 1984 |
if (WorldEdge = weWrap) then |
1985 |
begin |
|
14303
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14302
diff
changeset
|
1986 |
if -WorldDx < leftX then |
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14302
diff
changeset
|
1987 |
WorldDx:= WorldDx - rightX + leftX |
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14302
diff
changeset
|
1988 |
else if -WorldDx > rightX then |
6015b74eea55
overall, using LongInt for leftX/rightX results in fewer casts, since most comparisons are against ints.
nemo
parents:
14302
diff
changeset
|
1989 |
WorldDx:= WorldDx + rightX - leftX; |
10917 | 1990 |
end; |
1991 |
||
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1992 |
if ((CursorPoint.X = prevPoint.X) and (CursorPoint.Y = prevpoint.Y)) then |
15672
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
1993 |
begin |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
1994 |
CameraBounds; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
1995 |
exit; |
15672
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
1996 |
end; |
4 | 1997 |
|
6802 | 1998 |
if (AMState = AMShowingUp) or (AMState = AMShowing) then |
3680 | 1999 |
begin |
8330 | 2000 |
if CursorPoint.X < AmmoRect.x + amNumOffsetX + 3 then//check left |
7841
43e68ac28d79
apply unC0Rr's fix for 435 to landscape and non numbered ammomenu
Xeli
parents:
7840
diff
changeset
|
2001 |
CursorPoint.X:= AmmoRect.x + amNumOffsetX + 3; |
43e68ac28d79
apply unC0Rr's fix for 435 to landscape and non numbered ammomenu
Xeli
parents:
7840
diff
changeset
|
2002 |
if CursorPoint.X > AmmoRect.x + AmmoRect.w - 3 then//check right |
43e68ac28d79
apply unC0Rr's fix for 435 to landscape and non numbered ammomenu
Xeli
parents:
7840
diff
changeset
|
2003 |
CursorPoint.X:= AmmoRect.x + AmmoRect.w - 3; |
43e68ac28d79
apply unC0Rr's fix for 435 to landscape and non numbered ammomenu
Xeli
parents:
7840
diff
changeset
|
2004 |
if CursorPoint.Y > cScreenHeight - AmmoRect.y -amNumOffsetY - 1 then//check top |
43e68ac28d79
apply unC0Rr's fix for 435 to landscape and non numbered ammomenu
Xeli
parents:
7840
diff
changeset
|
2005 |
CursorPoint.Y:= cScreenHeight - AmmoRect.y - amNumOffsetY - 1; |
43e68ac28d79
apply unC0Rr's fix for 435 to landscape and non numbered ammomenu
Xeli
parents:
7840
diff
changeset
|
2006 |
if CursorPoint.Y < cScreenHeight - (AmmoRect.y + AmmoRect.h - AMSlotSize - 5) then//check bottom |
43e68ac28d79
apply unC0Rr's fix for 435 to landscape and non numbered ammomenu
Xeli
parents:
7840
diff
changeset
|
2007 |
CursorPoint.Y:= cScreenHeight - (AmmoRect.y + AmmoRect.h - AMSlotSize - 5); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
2008 |
prevPoint:= CursorPoint; |
15672
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
2009 |
CameraBounds; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
2010 |
exit |
3680 | 2011 |
end; |
162 | 2012 |
|
4 | 2013 |
if isCursorVisible then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2014 |
begin |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
2015 |
if (not CurrentTeam^.ExtDriven) and (GameTicks >= PrevSentPointTime + cSendCursorPosTime) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2016 |
begin |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
2017 |
SendIPCXY('P', CursorPoint.X - WorldDx, cScreenHeight - CursorPoint.Y - WorldDy); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
2018 |
PrevSentPointTime:= GameTicks |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2019 |
end; |
3680 | 2020 |
EdgesDist:= cCursorEdgesDist |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2021 |
end |
3680 | 2022 |
else |
2023 |
EdgesDist:= cGearScrEdgesDist; |
|
2024 |
||
2025 |
// this generates the border around the screen that moves the camera when cursor is near it |
|
8373
209c9ba77a09
Prevent camera from moving with auto camera disabled when remote teams are targetting
nemo
parents:
8370
diff
changeset
|
2026 |
if (CurrentTeam^.ExtDriven and isCursorVisible and autoCameraOn) or |
209c9ba77a09
Prevent camera from moving with auto camera disabled when remote teams are targetting
nemo
parents:
8370
diff
changeset
|
2027 |
(not CurrentTeam^.ExtDriven and isCursorVisible) or ((FollowGear <> nil) and autoCameraOn) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2028 |
begin |
15675
d738b2b1249e
Fix cursor being too limited left/right if zoomed out too much
Wuzzy <Wuzzy2@mail.ru>
parents:
15672
diff
changeset
|
2029 |
if CursorPoint.X < - trunc(cScreenWidth / cScaleFactor) + EdgesDist then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2030 |
begin |
15675
d738b2b1249e
Fix cursor being too limited left/right if zoomed out too much
Wuzzy <Wuzzy2@mail.ru>
parents:
15672
diff
changeset
|
2031 |
WorldDx:= WorldDx - CursorPoint.X - trunc(cScreenWidth / cScaleFactor) + EdgesDist; |
d738b2b1249e
Fix cursor being too limited left/right if zoomed out too much
Wuzzy <Wuzzy2@mail.ru>
parents:
15672
diff
changeset
|
2032 |
CursorPoint.X:= - trunc(cScreenWidth / cScaleFactor) + EdgesDist |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2033 |
end |
3680 | 2034 |
else |
15675
d738b2b1249e
Fix cursor being too limited left/right if zoomed out too much
Wuzzy <Wuzzy2@mail.ru>
parents:
15672
diff
changeset
|
2035 |
if CursorPoint.X > trunc(cScreenWidth / cScaleFactor) - EdgesDist then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2036 |
begin |
15675
d738b2b1249e
Fix cursor being too limited left/right if zoomed out too much
Wuzzy <Wuzzy2@mail.ru>
parents:
15672
diff
changeset
|
2037 |
WorldDx:= WorldDx - CursorPoint.X + trunc(cScreenWidth / cScaleFactor) - EdgesDist; |
d738b2b1249e
Fix cursor being too limited left/right if zoomed out too much
Wuzzy <Wuzzy2@mail.ru>
parents:
15672
diff
changeset
|
2038 |
CursorPoint.X:= trunc(cScreenWidth / cScaleFactor) - EdgesDist |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2039 |
end; |
5149
9aa840fdf922
Try to allow cursor to reach water when zooming out
unc0rr
parents:
5022
diff
changeset
|
2040 |
|
5302 | 2041 |
shs:= min(cScreenHeight div 2 - trunc(cScreenHeight / cScaleFactor) + EdgesDist, cScreenHeight - EdgesDist); |
5149
9aa840fdf922
Try to allow cursor to reach water when zooming out
unc0rr
parents:
5022
diff
changeset
|
2042 |
if CursorPoint.Y < shs then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2043 |
begin |
5149
9aa840fdf922
Try to allow cursor to reach water when zooming out
unc0rr
parents:
5022
diff
changeset
|
2044 |
WorldDy:= WorldDy + CursorPoint.Y - shs; |
9aa840fdf922
Try to allow cursor to reach water when zooming out
unc0rr
parents:
5022
diff
changeset
|
2045 |
CursorPoint.Y:= shs; |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2046 |
end |
3680 | 2047 |
else |
5302 | 2048 |
if (CursorPoint.Y > cScreenHeight - EdgesDist) then |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2049 |
begin |
3680 | 2050 |
WorldDy:= WorldDy + CursorPoint.Y - cScreenHeight + EdgesDist; |
2051 |
CursorPoint.Y:= cScreenHeight - EdgesDist |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2052 |
end; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2053 |
end |
3680 | 2054 |
else |
2055 |
if cHasFocus then |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2056 |
begin |
3680 | 2057 |
WorldDx:= WorldDx - CursorPoint.X + prevPoint.X; |
2058 |
WorldDy:= WorldDy + CursorPoint.Y - prevPoint.Y; |
|
2059 |
CursorPoint.X:= 0; |
|
2060 |
CursorPoint.Y:= cScreenHeight div 2; |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2061 |
end; |
351 | 2062 |
|
3680 | 2063 |
// this moves the camera according to CursorPoint X and Y |
4 | 2064 |
prevPoint:= CursorPoint; |
15672
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
2065 |
|
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
2066 |
// enforce camera bounds |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
2067 |
CameraBounds(); |
85d2afe34116
Enforce camera limits regardless of zoom level
Wuzzy <Wuzzy2@mail.ru>
parents:
15615
diff
changeset
|
2068 |
|
4 | 2069 |
end; |
2070 |
||
2905 | 2071 |
procedure ShowMission(caption, subcaption, text: ansistring; icon, time : LongInt); |
13467
854caa3c9212
Lua API: Add parameter forceDisplay to ShowMission to prevent manual hiding
Wuzzy <Wuzzy2@mail.ru>
parents:
13465
diff
changeset
|
2072 |
begin |
854caa3c9212
Lua API: Add parameter forceDisplay to ShowMission to prevent manual hiding
Wuzzy <Wuzzy2@mail.ru>
parents:
13465
diff
changeset
|
2073 |
ShowMission(caption, subcaption, text, icon, time, false); |
854caa3c9212
Lua API: Add parameter forceDisplay to ShowMission to prevent manual hiding
Wuzzy <Wuzzy2@mail.ru>
parents:
13465
diff
changeset
|
2074 |
end; |
854caa3c9212
Lua API: Add parameter forceDisplay to ShowMission to prevent manual hiding
Wuzzy <Wuzzy2@mail.ru>
parents:
13465
diff
changeset
|
2075 |
|
854caa3c9212
Lua API: Add parameter forceDisplay to ShowMission to prevent manual hiding
Wuzzy <Wuzzy2@mail.ru>
parents:
13465
diff
changeset
|
2076 |
procedure ShowMission(caption, subcaption, text: ansistring; icon, time : LongInt; forceDisplay : boolean); |
2786 | 2077 |
var r: TSDL_Rect; |
2078 |
begin |
|
10139 | 2079 |
if cOnlyStats then exit; |
2080 |
||
2786 | 2081 |
r.w:= 32; |
2082 |
r.h:= 32; |
|
2083 |
||
13467
854caa3c9212
Lua API: Add parameter forceDisplay to ShowMission to prevent manual hiding
Wuzzy <Wuzzy2@mail.ru>
parents:
13465
diff
changeset
|
2084 |
// If true, then mission panel cannot be hidden by releasing the mission panel key. |
854caa3c9212
Lua API: Add parameter forceDisplay to ShowMission to prevent manual hiding
Wuzzy <Wuzzy2@mail.ru>
parents:
13465
diff
changeset
|
2085 |
// Is in effect until timer runs out, is hidden with HideMission or ShowMission is called with forceDisplay=false. |
854caa3c9212
Lua API: Add parameter forceDisplay to ShowMission to prevent manual hiding
Wuzzy <Wuzzy2@mail.ru>
parents:
13465
diff
changeset
|
2086 |
isForceMission := forceDisplay; |
854caa3c9212
Lua API: Add parameter forceDisplay to ShowMission to prevent manual hiding
Wuzzy <Wuzzy2@mail.ru>
parents:
13465
diff
changeset
|
2087 |
|
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2088 |
if time = 0 then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2089 |
time:= 5000; |
2786 | 2090 |
missionTimer:= time; |
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:
10628
diff
changeset
|
2091 |
FreeAndNilTexture(missionTex); |
2786 | 2092 |
|
2093 |
if icon > -1 then |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
2094 |
begin |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
2095 |
r.x:= 0; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
2096 |
r.y:= icon * 32; |
10124
aabd1b75d5a3
Even more explicit type conversions and other stuff to help pas2c use ansistrings
unc0rr
parents:
10122
diff
changeset
|
2097 |
missionTex:= RenderHelpWindow(caption, subcaption, text, ansistring(''), 0, MissionIcons, @r) |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
2098 |
end |
2786 | 2099 |
else |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
2100 |
begin |
4626
775f43e90383
fixed showmission so it actually displays the right icons
Henek
parents:
4482
diff
changeset
|
2101 |
r.x:= ((-icon - 1) shr 4) * 32; |
775f43e90383
fixed showmission so it actually displays the right icons
Henek
parents:
4482
diff
changeset
|
2102 |
r.y:= ((-icon - 1) mod 16) * 32; |
10124
aabd1b75d5a3
Even more explicit type conversions and other stuff to help pas2c use ansistrings
unc0rr
parents:
10122
diff
changeset
|
2103 |
missionTex:= RenderHelpWindow(caption, subcaption, text, ansistring(''), 0, SpritesData[sprAMAmmos].Surface, @r) |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2931
diff
changeset
|
2104 |
end; |
2786 | 2105 |
end; |
2106 |
||
2107 |
procedure HideMission; |
|
2108 |
begin |
|
3045 | 2109 |
missionTimer:= 0; |
13467
854caa3c9212
Lua API: Add parameter forceDisplay to ShowMission to prevent manual hiding
Wuzzy <Wuzzy2@mail.ru>
parents:
13465
diff
changeset
|
2110 |
isForceMission:= false; |
2786 | 2111 |
end; |
2112 |
||
13370
e202d58236b1
Lua API: Add 5th parameter showExtra to SetAmmoTexts to hide extra text
Wuzzy <Wuzzy2@mail.ru>
parents:
13174
diff
changeset
|
2113 |
procedure SetAmmoTexts(ammoType: TAmmoType; name: ansistring; caption: ansistring; description: ansistring; autoLabels: boolean); |
11939
c7ec309cd685
Add Lua API function SetAmmoTexts (see issue 82)
Wuzzy <almikes@aol.com>
parents:
11917
diff
changeset
|
2114 |
var |
c7ec309cd685
Add Lua API function SetAmmoTexts (see issue 82)
Wuzzy <almikes@aol.com>
parents:
11917
diff
changeset
|
2115 |
ammoStrId: TAmmoStrId; |
11940
156f1866b8bd
Make SetAmmoTexts update ammo menu weapon name, too
Wuzzy <almikes@aol.com>
parents:
11939
diff
changeset
|
2116 |
ammoStr: ansistring; |
156f1866b8bd
Make SetAmmoTexts update ammo menu weapon name, too
Wuzzy <almikes@aol.com>
parents:
11939
diff
changeset
|
2117 |
tmpsurf: PSDL_Surface; |
11939
c7ec309cd685
Add Lua API function SetAmmoTexts (see issue 82)
Wuzzy <almikes@aol.com>
parents:
11917
diff
changeset
|
2118 |
begin |
13814 | 2119 |
if cOnlyStats then exit; |
2120 |
||
11939
c7ec309cd685
Add Lua API function SetAmmoTexts (see issue 82)
Wuzzy <almikes@aol.com>
parents:
11917
diff
changeset
|
2121 |
ammoStrId := Ammoz[ammoType].NameId; |
11940
156f1866b8bd
Make SetAmmoTexts update ammo menu weapon name, too
Wuzzy <almikes@aol.com>
parents:
11939
diff
changeset
|
2122 |
|
11939
c7ec309cd685
Add Lua API function SetAmmoTexts (see issue 82)
Wuzzy <almikes@aol.com>
parents:
11917
diff
changeset
|
2123 |
trluaammo[ammoStrId] := name; |
11940
156f1866b8bd
Make SetAmmoTexts update ammo menu weapon name, too
Wuzzy <almikes@aol.com>
parents:
11939
diff
changeset
|
2124 |
if length(trluaammo[ammoStrId]) > 0 then |
156f1866b8bd
Make SetAmmoTexts update ammo menu weapon name, too
Wuzzy <almikes@aol.com>
parents:
11939
diff
changeset
|
2125 |
ammoStr:= trluaammo[ammoStrId] |
156f1866b8bd
Make SetAmmoTexts update ammo menu weapon name, too
Wuzzy <almikes@aol.com>
parents:
11939
diff
changeset
|
2126 |
else |
156f1866b8bd
Make SetAmmoTexts update ammo menu weapon name, too
Wuzzy <almikes@aol.com>
parents:
11939
diff
changeset
|
2127 |
ammoStr:= trammo[ammoStrId]; |
156f1866b8bd
Make SetAmmoTexts update ammo menu weapon name, too
Wuzzy <almikes@aol.com>
parents:
11939
diff
changeset
|
2128 |
|
156f1866b8bd
Make SetAmmoTexts update ammo menu weapon name, too
Wuzzy <almikes@aol.com>
parents:
11939
diff
changeset
|
2129 |
if checkFails(length(ammoStr) > 0,'No default text/translation found for ammo type #' + intToStr(ord(ammoType)) + '!',true) then exit; |
13814 | 2130 |
|
11940
156f1866b8bd
Make SetAmmoTexts update ammo menu weapon name, too
Wuzzy <almikes@aol.com>
parents:
11939
diff
changeset
|
2131 |
tmpsurf:= TTF_RenderUTF8_Blended(Fontz[CheckCJKFont(ammoStr,fnt16)].Handle, PChar(ammoStr), cWhiteColorChannels); |
156f1866b8bd
Make SetAmmoTexts update ammo menu weapon name, too
Wuzzy <almikes@aol.com>
parents:
11939
diff
changeset
|
2132 |
if checkFails(tmpsurf <> nil,'Name-texture creation for ammo type #' + intToStr(ord(ammoType)) + ' failed!',true) then exit; |
156f1866b8bd
Make SetAmmoTexts update ammo menu weapon name, too
Wuzzy <almikes@aol.com>
parents:
11939
diff
changeset
|
2133 |
tmpsurf:= doSurfaceConversion(tmpsurf); |
156f1866b8bd
Make SetAmmoTexts update ammo menu weapon name, too
Wuzzy <almikes@aol.com>
parents:
11939
diff
changeset
|
2134 |
FreeAndNilTexture(Ammoz[ammoType].NameTex); |
156f1866b8bd
Make SetAmmoTexts update ammo menu weapon name, too
Wuzzy <almikes@aol.com>
parents:
11939
diff
changeset
|
2135 |
Ammoz[ammoType].NameTex:= Surface2Tex(tmpsurf, false); |
156f1866b8bd
Make SetAmmoTexts update ammo menu weapon name, too
Wuzzy <almikes@aol.com>
parents:
11939
diff
changeset
|
2136 |
SDL_FreeSurface(tmpsurf); |
156f1866b8bd
Make SetAmmoTexts update ammo menu weapon name, too
Wuzzy <almikes@aol.com>
parents:
11939
diff
changeset
|
2137 |
|
11939
c7ec309cd685
Add Lua API function SetAmmoTexts (see issue 82)
Wuzzy <almikes@aol.com>
parents:
11917
diff
changeset
|
2138 |
trluaammoc[ammoStrId] := caption; |
c7ec309cd685
Add Lua API function SetAmmoTexts (see issue 82)
Wuzzy <almikes@aol.com>
parents:
11917
diff
changeset
|
2139 |
trluaammod[ammoStrId] := description; |
13370
e202d58236b1
Lua API: Add 5th parameter showExtra to SetAmmoTexts to hide extra text
Wuzzy <Wuzzy2@mail.ru>
parents:
13174
diff
changeset
|
2140 |
trluaammoe[ammoStrId] := autoLabels; |
11939
c7ec309cd685
Add Lua API function SetAmmoTexts (see issue 82)
Wuzzy <almikes@aol.com>
parents:
11917
diff
changeset
|
2141 |
end; |
c7ec309cd685
Add Lua API function SetAmmoTexts (see issue 82)
Wuzzy <almikes@aol.com>
parents:
11917
diff
changeset
|
2142 |
|
6011
519f8a58c021
Fix a bunch of warnings (also improves speed a bit in 32 bit code)
unC0Rr
parents:
5862
diff
changeset
|
2143 |
procedure ShakeCamera(amount: LongInt); |
3032 | 2144 |
begin |
6580
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2145 |
if isCursorVisible then |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2146 |
exit; |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2147 |
amount:= Max(1, round(amount*zoom/2)); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2148 |
WorldDx:= WorldDx - amount + LongInt(random(1 + amount * 2)); |
6155187bf599
A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents:
6492
diff
changeset
|
2149 |
WorldDy:= WorldDy - amount + LongInt(random(1 + amount * 2)); |
3032 | 2150 |
end; |
2151 |
||
5521 | 2152 |
|
2153 |
procedure onFocusStateChanged; |
|
2154 |
begin |
|
9688 | 2155 |
{$IFDEF MOBILE} |
13224
01ab48b253ef
- Pause game when it goes background (do not show anymore annoying 'confirm quit')
antonc27 <antonc27@mail.ru>
parents:
12831
diff
changeset
|
2156 |
if (not cHasFocus) and (not isPaused) then |
01ab48b253ef
- Pause game when it goes background (do not show anymore annoying 'confirm quit')
antonc27 <antonc27@mail.ru>
parents:
12831
diff
changeset
|
2157 |
ParseCommand('pause', true); |
7847 | 2158 |
// when created SDL receives an exposure event that calls UndampenAudio at full power, muting audio |
2159 |
exit; |
|
2160 |
{$ENDIF} |
|
13224
01ab48b253ef
- Pause game when it goes background (do not show anymore annoying 'confirm quit')
antonc27 <antonc27@mail.ru>
parents:
12831
diff
changeset
|
2161 |
if (not cHasFocus) and (GameState <> gsConfirm) then |
01ab48b253ef
- Pause game when it goes background (do not show anymore annoying 'confirm quit')
antonc27 <antonc27@mail.ru>
parents:
12831
diff
changeset
|
2162 |
ParseCommand('quit', true); |
6862 | 2163 |
|
7286 | 2164 |
{$IFDEF USE_VIDEO_RECORDING} |
7180 | 2165 |
// do not change volume during prerecording as it will affect sound in video file |
8099
a7f02b902b6f
throw in some 'nots' trying to restore pas2c functionality
koda
parents:
8026
diff
changeset
|
2166 |
if (not flagPrerecording) then |
7286 | 2167 |
{$ENDIF} |
7180 | 2168 |
begin |
8099
a7f02b902b6f
throw in some 'nots' trying to restore pas2c functionality
koda
parents:
8026
diff
changeset
|
2169 |
if (not cHasFocus) then DampenAudio() |
7180 | 2170 |
else UndampenAudio(); |
2171 |
end; |
|
5521 | 2172 |
end; |
2173 |
||
10392 | 2174 |
procedure updateCursorVisibility; |
10510 | 2175 |
begin |
14829 | 2176 |
if isPaused or isAFK or (GameState = gsConfirm) then |
2177 |
begin |
|
14830
c2793ff4e887
Fix camera jumping around in touchscreen mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14829
diff
changeset
|
2178 |
{$IFNDEF USE_TOUCH_INTERFACE} |
14829 | 2179 |
SDL_SetRelativeMouseMode(SDL_FALSE); |
14830
c2793ff4e887
Fix camera jumping around in touchscreen mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14829
diff
changeset
|
2180 |
{$ENDIF} |
14829 | 2181 |
if SDL_ShowCursor(SDL_QUERY) = SDL_DISABLE then |
2182 |
begin |
|
2183 |
uCursor.resetPosition; |
|
14830
c2793ff4e887
Fix camera jumping around in touchscreen mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14829
diff
changeset
|
2184 |
{$IFNDEF USE_TOUCH_INTERFACE} |
14829 | 2185 |
SDL_ShowCursor(SDL_ENABLE); |
14830
c2793ff4e887
Fix camera jumping around in touchscreen mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14829
diff
changeset
|
2186 |
{$ENDIF} |
14829 | 2187 |
end; |
2188 |
end |
|
10392 | 2189 |
else |
14829 | 2190 |
begin |
2191 |
uCursor.resetPositionDelta; |
|
14830
c2793ff4e887
Fix camera jumping around in touchscreen mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14829
diff
changeset
|
2192 |
{$IFNDEF USE_TOUCH_INTERFACE} |
14829 | 2193 |
SDL_ShowCursor(SDL_DISABLE); |
2194 |
SDL_SetRelativeMouseMode(SDL_TRUE); |
|
14830
c2793ff4e887
Fix camera jumping around in touchscreen mode
Wuzzy <Wuzzy2@mail.ru>
parents:
14829
diff
changeset
|
2195 |
{$ENDIF} |
14829 | 2196 |
end; |
5521 | 2197 |
end; |
2198 |
||
14562 | 2199 |
procedure updateTouchWidgets(ammoType: TAmmoType); |
2200 |
begin |
|
2201 |
{$IFDEF USE_TOUCH_INTERFACE} |
|
2202 |
//show the aiming buttons + animation |
|
2203 |
if (Ammoz[ammoType].Ammo.Propz and ammoprop_NeedUpDown) <> 0 then |
|
2204 |
begin |
|
2205 |
if (not arrowUp.show) then |
|
2206 |
begin |
|
2207 |
animateWidget(@arrowUp, true, true); |
|
2208 |
animateWidget(@arrowDown, true, true); |
|
2209 |
end; |
|
2210 |
end |
|
2211 |
else |
|
2212 |
if arrowUp.show then |
|
2213 |
begin |
|
2214 |
animateWidget(@arrowUp, true, false); |
|
2215 |
animateWidget(@arrowDown, true, false); |
|
2216 |
end; |
|
2217 |
SetUtilityWidgetState(ammoType); |
|
2218 |
{$ELSE} |
|
2219 |
ammoType:= ammoType; // avoid hint |
|
2220 |
{$ENDIF} |
|
2221 |
end; |
|
2222 |
||
6961
d5ac09894a1b
hide utilitywidget when changing turns, this also fixes some inconsistency when using targetting weapons
Xeli
parents:
6957
diff
changeset
|
2223 |
procedure SetUtilityWidgetState(ammoType: TAmmoType); |
d5ac09894a1b
hide utilitywidget when changing turns, this also fixes some inconsistency when using targetting weapons
Xeli
parents:
6957
diff
changeset
|
2224 |
begin |
7086 | 2225 |
{$IFDEF USE_TOUCH_INTERFACE} |
6961
d5ac09894a1b
hide utilitywidget when changing turns, this also fixes some inconsistency when using targetting weapons
Xeli
parents:
6957
diff
changeset
|
2226 |
if(ammoType = amNothing)then |
d5ac09894a1b
hide utilitywidget when changing turns, this also fixes some inconsistency when using targetting weapons
Xeli
parents:
6957
diff
changeset
|
2227 |
ammoType:= CurrentHedgehog^.CurAmmoType; |
d5ac09894a1b
hide utilitywidget when changing turns, this also fixes some inconsistency when using targetting weapons
Xeli
parents:
6957
diff
changeset
|
2228 |
|
d5ac09894a1b
hide utilitywidget when changing turns, this also fixes some inconsistency when using targetting weapons
Xeli
parents:
6957
diff
changeset
|
2229 |
if(CurrentHedgehog <> nil)then |
11211
1fa57188a469
- Workaround for wrong sprite in utility widget when selecting DrillStrike
antonc27 <antonc27@mail.ru>
parents:
11210
diff
changeset
|
2230 |
if ((Ammoz[ammoType].Ammo.Propz and ammoprop_Timerable) <> 0) and (ammoType <> amDrillStrike) then |
6961
d5ac09894a1b
hide utilitywidget when changing turns, this also fixes some inconsistency when using targetting weapons
Xeli
parents:
6957
diff
changeset
|
2231 |
begin |
d5ac09894a1b
hide utilitywidget when changing turns, this also fixes some inconsistency when using targetting weapons
Xeli
parents:
6957
diff
changeset
|
2232 |
utilityWidget.sprite:= sprTimerButton; |
14563
e68b91abbcf5
Tweak appear/disappear animation of touch widgets
Wuzzy <Wuzzy2@mail.ru>
parents:
14562
diff
changeset
|
2233 |
if (not utilityWidget.show) then |
e68b91abbcf5
Tweak appear/disappear animation of touch widgets
Wuzzy <Wuzzy2@mail.ru>
parents:
14562
diff
changeset
|
2234 |
animateWidget(@utilityWidget, true, true); |
8330 | 2235 |
end |
6961
d5ac09894a1b
hide utilitywidget when changing turns, this also fixes some inconsistency when using targetting weapons
Xeli
parents:
6957
diff
changeset
|
2236 |
else if (Ammoz[ammoType].Ammo.Propz and ammoprop_NeedTarget) <> 0 then |
d5ac09894a1b
hide utilitywidget when changing turns, this also fixes some inconsistency when using targetting weapons
Xeli
parents:
6957
diff
changeset
|
2237 |
begin |
d5ac09894a1b
hide utilitywidget when changing turns, this also fixes some inconsistency when using targetting weapons
Xeli
parents:
6957
diff
changeset
|
2238 |
utilityWidget.sprite:= sprTargetButton; |
14563
e68b91abbcf5
Tweak appear/disappear animation of touch widgets
Wuzzy <Wuzzy2@mail.ru>
parents:
14562
diff
changeset
|
2239 |
if (not utilityWidget.show) then |
e68b91abbcf5
Tweak appear/disappear animation of touch widgets
Wuzzy <Wuzzy2@mail.ru>
parents:
14562
diff
changeset
|
2240 |
animateWidget(@utilityWidget, true, true); |
6961
d5ac09894a1b
hide utilitywidget when changing turns, this also fixes some inconsistency when using targetting weapons
Xeli
parents:
6957
diff
changeset
|
2241 |
end |
6962 | 2242 |
else if ammoType = amSwitch then |
2243 |
begin |
|
11210
22f2e072d31e
- Target button added to mobile touch controls
antonc27 <antonc27@mail.ru>
parents:
11156
diff
changeset
|
2244 |
utilityWidget.sprite:= sprSwitchButton; |
14563
e68b91abbcf5
Tweak appear/disappear animation of touch widgets
Wuzzy <Wuzzy2@mail.ru>
parents:
14562
diff
changeset
|
2245 |
if (not utilityWidget.show) then |
e68b91abbcf5
Tweak appear/disappear animation of touch widgets
Wuzzy <Wuzzy2@mail.ru>
parents:
14562
diff
changeset
|
2246 |
animateWidget(@utilityWidget, true, true); |
6962 | 2247 |
end |
6961
d5ac09894a1b
hide utilitywidget when changing turns, this also fixes some inconsistency when using targetting weapons
Xeli
parents:
6957
diff
changeset
|
2248 |
else if utilityWidget.show then |
6992 | 2249 |
animateWidget(@utilityWidget, true, false); |
14559
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
2250 |
|
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
2251 |
if ((Ammoz[ammoType].Ammo.Propz and ammoprop_SetBounce) <> 0) then |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
2252 |
begin |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
2253 |
utilityWidget2.sprite:= sprBounceButton; |
14563
e68b91abbcf5
Tweak appear/disappear animation of touch widgets
Wuzzy <Wuzzy2@mail.ru>
parents:
14562
diff
changeset
|
2254 |
if (not utilityWidget2.show) then |
e68b91abbcf5
Tweak appear/disappear animation of touch widgets
Wuzzy <Wuzzy2@mail.ru>
parents:
14562
diff
changeset
|
2255 |
animateWidget(@utilityWidget2, true, true); |
14559
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
2256 |
end |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
2257 |
else if utilityWidget2.show then |
1dab5d92aca7
Add button to set bounciness in touch interface
Wuzzy <Wuzzy2@mail.ru>
parents:
14440
diff
changeset
|
2258 |
animateWidget(@utilityWidget2, true, false); |
6992 | 2259 |
{$ELSE} |
2260 |
ammoType:= ammoType; // avoid hint |
|
6963 | 2261 |
{$ENDIF} |
6961
d5ac09894a1b
hide utilitywidget when changing turns, this also fixes some inconsistency when using targetting weapons
Xeli
parents:
6957
diff
changeset
|
2262 |
end; |
d5ac09894a1b
hide utilitywidget when changing turns, this also fixes some inconsistency when using targetting weapons
Xeli
parents:
6957
diff
changeset
|
2263 |
|
6688 | 2264 |
procedure animateWidget(widget: POnScreenWidget; fade, showWidget: boolean); |
2265 |
begin |
|
2266 |
with widget^ do |
|
2267 |
begin |
|
2268 |
show:= showWidget; |
|
2269 |
if fade then fadeAnimStart:= RealTicks; |
|
8330 | 2270 |
|
6688 | 2271 |
with moveAnim do |
2272 |
begin |
|
2273 |
animate:= true; |
|
2274 |
startTime:= RealTicks; |
|
6695
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
2275 |
source.x:= source.x xor target.x; //swap source <-> target |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
2276 |
target.x:= source.x xor target.x; |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
2277 |
source.x:= source.x xor target.x; |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
2278 |
source.y:= source.y xor target.y; |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
2279 |
target.y:= source.y xor target.y; |
32de8965c62c
refactored a few types involved in the touch interface and corrected a few invisible mistakes
koda
parents:
6692
diff
changeset
|
2280 |
source.y:= source.y xor target.y; |
6688 | 2281 |
end; |
2282 |
end; |
|
2283 |
end; |
|
2284 |
||
5521 | 2285 |
|
3038 | 2286 |
procedure initModule; |
2699
249adefa9c1c
replace initialization/finalization statements with custom init functions
koda
parents:
2682
diff
changeset
|
2287 |
begin |
7027 | 2288 |
fpsTexture:= nil; |
7180 | 2289 |
recTexture:= nil; |
7027 | 2290 |
FollowGear:= nil; |
2291 |
WindBarWidth:= 0; |
|
2292 |
bShowAmmoMenu:= false; |
|
2293 |
bSelected:= false; |
|
2294 |
bShowFinger:= false; |
|
2295 |
Frames:= 0; |
|
2296 |
WorldDx:= -512; |
|
2297 |
WorldDy:= -256; |
|
7343 | 2298 |
PrevSentPointTime:= 0; |
3697 | 2299 |
|
7027 | 2300 |
FPS:= 0; |
2301 |
CountTicks:= 0; |
|
2302 |
SoundTimerTicks:= 0; |
|
2303 |
prevPoint.X:= 0; |
|
2304 |
prevPoint.Y:= 0; |
|
2305 |
missionTimer:= 0; |
|
2306 |
missionTex:= nil; |
|
2307 |
cOffsetY:= 0; |
|
2308 |
AMState:= AMHidden; |
|
2309 |
isFirstFrame:= true; |
|
9557 | 2310 |
|
2311 |
FillChar(WorldFade, sizeof(WorldFade), 0); |
|
2312 |
WorldFade[0].a:= 255; |
|
2313 |
WorldFade[1].a:= 255; |
|
2314 |
FillChar(WorldEnd, sizeof(WorldEnd), 0); |
|
2315 |
WorldEnd[0].a:= 255; |
|
2316 |
WorldEnd[1].a:= 255; |
|
2317 |
WorldEnd[2].a:= 255; |
|
2318 |
WorldEnd[3].a:= 255; |
|
2319 |
||
9983 | 2320 |
AmmoMenuTex:= nil; |
2321 |
AmmoMenuInvalidated:= true |
|
2699
249adefa9c1c
replace initialization/finalization statements with custom init functions
koda
parents:
2682
diff
changeset
|
2322 |
end; |
4 | 2323 |
|
3038 | 2324 |
procedure freeModule; |
2716
b9ca1bfca24f
complete the replacement of init/free wrappers for every unit
koda
parents:
2713
diff
changeset
|
2325 |
begin |
7850 | 2326 |
ResetWorldTex(); |
2716
b9ca1bfca24f
complete the replacement of init/free wrappers for every unit
koda
parents:
2713
diff
changeset
|
2327 |
end; |
b9ca1bfca24f
complete the replacement of init/free wrappers for every unit
koda
parents:
2713
diff
changeset
|
2328 |
|
4 | 2329 |
end. |