author | koda |
Sat, 14 Nov 2009 02:53:04 +0000 | |
changeset 2619 | bc2786a00fb8 |
parent 2518 | 126850aec94d |
child 2622 | 39932161194e |
permissions | -rw-r--r-- |
942 | 1 |
(* |
1066 | 2 |
* Hedgewars, a free turn based strategy game |
942 | 3 |
* Copyright (c) 2008 Andrey Korotaev <unC0Rr@gmail.com> |
4 |
* |
|
5 |
* This program is free software; you can redistribute it and/or modify |
|
6 |
* it under the terms of the GNU General Public License as published by |
|
7 |
* the Free Software Foundation; version 2 of the License |
|
8 |
* |
|
9 |
* This program is distributed in the hope that it will be useful, |
|
10 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
11 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
12 |
* GNU General Public License for more details. |
|
13 |
* |
|
14 |
* You should have received a copy of the GNU General Public License |
|
15 |
* along with this program; if not, write to the Free Software |
|
16 |
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA |
|
17 |
*) |
|
18 |
||
19 |
unit uChat; |
|
20 |
||
21 |
interface |
|
22 |
||
23 |
procedure AddChatString(s: shortstring); |
|
24 |
procedure DrawChat; |
|
946 | 25 |
procedure KeyPressChat(Key: Longword); |
942 | 26 |
|
949 | 27 |
var UserNick: shortstring = ''; |
993 | 28 |
showAll: boolean = false; |
949 | 29 |
|
942 | 30 |
implementation |
1035 | 31 |
uses uMisc, uStore, uConsts, SDLh, uConsole, uKeys, uTeams; |
942 | 32 |
|
990
dfa6a6fe1542
Implement history for chat (27 entries), no key binding yet
unc0rr
parents:
988
diff
changeset
|
33 |
const MaxStrIndex = 27; |
942 | 34 |
|
946 | 35 |
type TChatLine = record |
1431 | 36 |
Tex: PTexture; |
942 | 37 |
Time: Longword; |
1431 | 38 |
Width: LongInt; |
39 |
s: shortstring; |
|
942 | 40 |
end; |
41 |
||
946 | 42 |
var Strs: array[0 .. MaxStrIndex] of TChatLine; |
942 | 43 |
lastStr: Longword = 0; |
945
4ead9cde4e14
- Start chat implementation: chat strings are on the screen
unc0rr
parents:
942
diff
changeset
|
44 |
visibleCount: Longword = 0; |
2376 | 45 |
|
946 | 46 |
InputStr: TChatLine; |
47 |
InputStrL: array[0..260] of char; // for full str + 4-byte utf-8 char |
|
942 | 48 |
|
2396 | 49 |
const colors: array[#1..#4] of Longword = ( |
50 |
$FFFFFF, // chat message |
|
51 |
$FF00FF, // action message |
|
2500 | 52 |
$90FF90, // join/leave message |
2397
2ca4ca6b4bab
- Patch for "Syncronizing" message by Smaxx + some tweaks by me
unc0rr
parents:
2396
diff
changeset
|
53 |
$A0FFFF // team message |
2396 | 54 |
); |
55 |
||
990
dfa6a6fe1542
Implement history for chat (27 entries), no key binding yet
unc0rr
parents:
988
diff
changeset
|
56 |
procedure SetLine(var cl: TChatLine; str: shortstring; isInput: boolean); |
1118 | 57 |
var strSurface, resSurface: PSDL_Surface; |
1431 | 58 |
w, h: LongInt; |
2396 | 59 |
color: Longword; |
942 | 60 |
begin |
1118 | 61 |
if cl.Tex <> nil then |
62 |
FreeTexture(cl.Tex); |
|
942 | 63 |
|
2396 | 64 |
|
990
dfa6a6fe1542
Implement history for chat (27 entries), no key binding yet
unc0rr
parents:
988
diff
changeset
|
65 |
cl.s:= str; |
dfa6a6fe1542
Implement history for chat (27 entries), no key binding yet
unc0rr
parents:
988
diff
changeset
|
66 |
|
2396 | 67 |
if isInput then |
68 |
begin |
|
2397
2ca4ca6b4bab
- Patch for "Syncronizing" message by Smaxx + some tweaks by me
unc0rr
parents:
2396
diff
changeset
|
69 |
color:= $FFFF00; |
2396 | 70 |
str:= UserNick + '> ' + str + '_' |
71 |
end |
|
72 |
else begin |
|
73 |
color:= colors[str[1]]; |
|
74 |
delete(str, 1, 1) |
|
75 |
end; |
|
76 |
||
990
dfa6a6fe1542
Implement history for chat (27 entries), no key binding yet
unc0rr
parents:
988
diff
changeset
|
77 |
|
1118 | 78 |
TTF_SizeUTF8(Fontz[fnt16].Handle, Str2PChar(str), w, h); |
945
4ead9cde4e14
- Start chat implementation: chat strings are on the screen
unc0rr
parents:
942
diff
changeset
|
79 |
|
1118 | 80 |
resSurface:= SDL_CreateRGBSurface(0, |
1431 | 81 |
toPowerOf2(w), |
82 |
toPowerOf2(h), |
|
1118 | 83 |
32, |
84 |
RMask, GMask, BMask, AMask); |
|
945
4ead9cde4e14
- Start chat implementation: chat strings are on the screen
unc0rr
parents:
942
diff
changeset
|
85 |
|
2396 | 86 |
strSurface:= TTF_RenderUTF8_Solid(Fontz[fnt16].Handle, Str2PChar(str), color); |
2619 | 87 |
//strSurface:= doSurfaceConversion(strSurface); |
1431 | 88 |
cl.Width:= w + 4; |
1118 | 89 |
SDL_UpperBlit(strSurface, nil, resSurface, nil); |
90 |
SDL_FreeSurface(strSurface); |
|
91 |
||
92 |
cl.Time:= RealTicks + 12500; |
|
2290
bf87ca44782e
Selectively enable clamping - seeing if this helps avoid weird flake problems while still fixing vertical lines in waves and sky
nemo
parents:
2161
diff
changeset
|
93 |
cl.Tex:= Surface2Tex(resSurface, false); |
1431 | 94 |
|
1118 | 95 |
SDL_FreeSurface(resSurface) |
946 | 96 |
end; |
97 |
||
98 |
procedure AddChatString(s: shortstring); |
|
99 |
begin |
|
100 |
lastStr:= (lastStr + 1) mod (MaxStrIndex + 1); |
|
101 |
||
990
dfa6a6fe1542
Implement history for chat (27 entries), no key binding yet
unc0rr
parents:
988
diff
changeset
|
102 |
SetLine(Strs[lastStr], s, false); |
945
4ead9cde4e14
- Start chat implementation: chat strings are on the screen
unc0rr
parents:
942
diff
changeset
|
103 |
|
4ead9cde4e14
- Start chat implementation: chat strings are on the screen
unc0rr
parents:
942
diff
changeset
|
104 |
inc(visibleCount) |
942 | 105 |
end; |
106 |
||
107 |
procedure DrawChat; |
|
945
4ead9cde4e14
- Start chat implementation: chat strings are on the screen
unc0rr
parents:
942
diff
changeset
|
108 |
var i, t, cnt: Longword; |
1431 | 109 |
r: TSDL_Rect; |
942 | 110 |
begin |
945
4ead9cde4e14
- Start chat implementation: chat strings are on the screen
unc0rr
parents:
942
diff
changeset
|
111 |
cnt:= 0; |
4ead9cde4e14
- Start chat implementation: chat strings are on the screen
unc0rr
parents:
942
diff
changeset
|
112 |
t:= 0; |
4ead9cde4e14
- Start chat implementation: chat strings are on the screen
unc0rr
parents:
942
diff
changeset
|
113 |
i:= lastStr; |
1431 | 114 |
|
2161
0c8634241fa4
Some work on zooming. Hedgewars are now unplayable.
unc0rr
parents:
2131
diff
changeset
|
115 |
r.x:= 6 - cScreenWidth div 2; |
1431 | 116 |
r.y:= (visibleCount - t) * 16 + 10; |
117 |
r.h:= 16; |
|
118 |
||
119 |
if (GameState = gsChat) |
|
120 |
and (InputStr.Tex <> nil) then |
|
121 |
begin |
|
122 |
r.w:= InputStr.Width; |
|
123 |
DrawFillRect(r); |
|
2161
0c8634241fa4
Some work on zooming. Hedgewars are now unplayable.
unc0rr
parents:
2131
diff
changeset
|
124 |
DrawTexture(8 - cScreenWidth div 2, visibleCount * 16 + 10, InputStr.Tex); |
1431 | 125 |
end; |
126 |
||
127 |
dec(r.y, 16); |
|
128 |
||
990
dfa6a6fe1542
Implement history for chat (27 entries), no key binding yet
unc0rr
parents:
988
diff
changeset
|
129 |
while |
dfa6a6fe1542
Implement history for chat (27 entries), no key binding yet
unc0rr
parents:
988
diff
changeset
|
130 |
( |
dfa6a6fe1542
Implement history for chat (27 entries), no key binding yet
unc0rr
parents:
988
diff
changeset
|
131 |
((t < 7) and (Strs[i].Time > RealTicks)) |
dfa6a6fe1542
Implement history for chat (27 entries), no key binding yet
unc0rr
parents:
988
diff
changeset
|
132 |
or |
dfa6a6fe1542
Implement history for chat (27 entries), no key binding yet
unc0rr
parents:
988
diff
changeset
|
133 |
((t < MaxStrIndex) and showAll) |
dfa6a6fe1542
Implement history for chat (27 entries), no key binding yet
unc0rr
parents:
988
diff
changeset
|
134 |
) |
dfa6a6fe1542
Implement history for chat (27 entries), no key binding yet
unc0rr
parents:
988
diff
changeset
|
135 |
and |
1118 | 136 |
(Strs[i].Tex <> nil) do |
945
4ead9cde4e14
- Start chat implementation: chat strings are on the screen
unc0rr
parents:
942
diff
changeset
|
137 |
begin |
1431 | 138 |
r.w:= Strs[i].Width; |
139 |
DrawFillRect(r); |
|
2161
0c8634241fa4
Some work on zooming. Hedgewars are now unplayable.
unc0rr
parents:
2131
diff
changeset
|
140 |
DrawTexture(8 - cScreenWidth div 2, (visibleCount - t) * 16 - 6, Strs[i].Tex); |
1431 | 141 |
dec(r.y, 16); |
2376 | 142 |
|
945
4ead9cde4e14
- Start chat implementation: chat strings are on the screen
unc0rr
parents:
942
diff
changeset
|
143 |
if i = 0 then i:= MaxStrIndex else dec(i); |
4ead9cde4e14
- Start chat implementation: chat strings are on the screen
unc0rr
parents:
942
diff
changeset
|
144 |
inc(cnt); |
4ead9cde4e14
- Start chat implementation: chat strings are on the screen
unc0rr
parents:
942
diff
changeset
|
145 |
inc(t) |
4ead9cde4e14
- Start chat implementation: chat strings are on the screen
unc0rr
parents:
942
diff
changeset
|
146 |
end; |
4ead9cde4e14
- Start chat implementation: chat strings are on the screen
unc0rr
parents:
942
diff
changeset
|
147 |
|
947 | 148 |
visibleCount:= cnt; |
942 | 149 |
end; |
150 |
||
1033 | 151 |
procedure AcceptChatString(s: shortstring); |
1035 | 152 |
var i: TWave; |
2124 | 153 |
|
1033 | 154 |
begin |
2017 | 155 |
// "Make hedgehog say something" |
2376 | 156 |
if (s[1] = '"') and (s[Length(s)] = '"') then |
2017 | 157 |
begin |
2111 | 158 |
if CurrentTeam^.ExtDriven then |
159 |
ParseCommand('/say ' + copy(s, 2, Length(s)-2), true) |
|
160 |
else |
|
161 |
ParseCommand('/hogsay '#1 + copy(s, 2, Length(s)-2), true); |
|
2017 | 162 |
exit |
163 |
end; |
|
164 |
// 'Make hedgehog think something' |
|
2376 | 165 |
if (s[1] = '''') and (s[Length(s)] = '''') then |
2017 | 166 |
begin |
2111 | 167 |
if CurrentTeam^.ExtDriven then |
168 |
ParseCommand('/say ' + copy(s, 2, Length(s)-2), true) |
|
169 |
else |
|
170 |
ParseCommand('/hogsay '#2 + copy(s, 2, Length(s)-2), true); |
|
2017 | 171 |
exit |
172 |
end; |
|
173 |
// -Make hedgehog yell something- |
|
2376 | 174 |
if (s[1] = '-') and (s[Length(s)] = '-') then |
2017 | 175 |
begin |
2111 | 176 |
if CurrentTeam^.ExtDriven then |
177 |
ParseCommand('/say ' + copy(s, 2, Length(s)-2), true) |
|
178 |
else |
|
179 |
ParseCommand('/hogsay '#3 + copy(s, 2, Length(s)-2), true); |
|
2017 | 180 |
exit |
181 |
end; |
|
182 |
// These 3 are same as above, only are to make the hedgehog say it on next attack |
|
183 |
if (s[1] = '/') and (copy(s, 1, 5) = '/hsa ') then |
|
184 |
begin |
|
2111 | 185 |
if CurrentTeam^.ExtDriven then |
2112 | 186 |
ParseCommand('/say ' + copy(s, 6, Length(s)-5), true) |
2111 | 187 |
else |
2112 | 188 |
ParseCommand('/hogsay '#4 + copy(s, 6, Length(s)-5), true); |
2017 | 189 |
exit |
190 |
end; |
|
191 |
if (s[1] = '/') and (copy(s, 1, 5) = '/hta ') then |
|
192 |
begin |
|
2111 | 193 |
if CurrentTeam^.ExtDriven then |
2112 | 194 |
ParseCommand('/say ' + copy(s, 6, Length(s)-5), true) |
2111 | 195 |
else |
2112 | 196 |
ParseCommand('/hogsay '#5 + copy(s, 6, Length(s)-5), true); |
2017 | 197 |
exit |
198 |
end; |
|
199 |
if (s[1] = '/') and (copy(s, 1, 5) = '/hya ') then |
|
200 |
begin |
|
2111 | 201 |
if CurrentTeam^.ExtDriven then |
2112 | 202 |
ParseCommand('/say ' + copy(s, 6, Length(s)-5), true) |
2111 | 203 |
else |
2112 | 204 |
ParseCommand('/hogsay '#6 + copy(s, 6, Length(s)-5), true); |
2017 | 205 |
exit |
206 |
end; |
|
2111 | 207 |
|
2518 | 208 |
if (copy(s, 1, 6) = '/team ') and (length(s) > 6) then |
2124 | 209 |
begin |
2403 | 210 |
ParseCommand(s, true); |
2124 | 211 |
exit |
212 |
end; |
|
1378 | 213 |
if (s[1] = '/') and (copy(s, 1, 4) <> '/me ') then |
1035 | 214 |
begin |
215 |
if CurrentTeam^.ExtDriven then exit; |
|
2376 | 216 |
|
1035 | 217 |
for i:= Low(TWave) to High(TWave) do |
218 |
if (s = Wavez[i].cmd) then |
|
219 |
begin |
|
220 |
ParseCommand('/taunt ' + char(i), true); |
|
221 |
exit |
|
222 |
end; |
|
1821
6b6cf3389f92
Hedgehog drops a grave on "/newgrave" command. Patch by nemo
unc0rr
parents:
1819
diff
changeset
|
223 |
if (s = '/newgrave') then |
2017 | 224 |
begin |
1821
6b6cf3389f92
Hedgehog drops a grave on "/newgrave" command. Patch by nemo
unc0rr
parents:
1819
diff
changeset
|
225 |
ParseCommand('/newgrave', true); |
2017 | 226 |
exit |
227 |
end; |
|
228 |
end |
|
1035 | 229 |
else |
230 |
ParseCommand('/say ' + s, true); |
|
1033 | 231 |
end; |
232 |
||
946 | 233 |
procedure KeyPressChat(Key: Longword); |
234 |
const firstByteMark: array[1..4] of byte = (0, $C0, $E0, $F0); |
|
235 |
var i, btw: integer; |
|
1001 | 236 |
utf8: shortstring; |
946 | 237 |
begin |
1819 | 238 |
|
946 | 239 |
if Key <> 0 then |
240 |
case Key of |
|
1819 | 241 |
{Backspace} |
242 |
8, 127: if Length(InputStr.s) > 0 then |
|
946 | 243 |
begin |
244 |
InputStr.s[0]:= InputStrL[byte(InputStr.s[0])]; |
|
990
dfa6a6fe1542
Implement history for chat (27 entries), no key binding yet
unc0rr
parents:
988
diff
changeset
|
245 |
SetLine(InputStr, InputStr.s, true) |
946 | 246 |
end; |
1819 | 247 |
{Esc} |
990
dfa6a6fe1542
Implement history for chat (27 entries), no key binding yet
unc0rr
parents:
988
diff
changeset
|
248 |
27: SetLine(InputStr, '', true); |
1819 | 249 |
{Return} |
2003 | 250 |
3, 13, 271: begin |
947 | 251 |
if Length(InputStr.s) > 0 then |
252 |
begin |
|
1033 | 253 |
AcceptChatString(InputStr.s); |
1118 | 254 |
SetLine(InputStr, '', false) |
947 | 255 |
end; |
948 | 256 |
FreezeEnterKey; |
946 | 257 |
GameState:= gsGame |
1819 | 258 |
end; |
946 | 259 |
else |
260 |
if (Key < $80) then btw:= 1 |
|
261 |
else if (Key < $800) then btw:= 2 |
|
262 |
else if (Key < $10000) then btw:= 3 |
|
263 |
else btw:= 4; |
|
2376 | 264 |
|
946 | 265 |
utf8:= ''; |
266 |
||
267 |
for i:= btw downto 2 do |
|
268 |
begin |
|
269 |
utf8:= char((Key or $80) and $BF) + utf8; |
|
270 |
Key:= Key shr 6 |
|
271 |
end; |
|
2376 | 272 |
|
946 | 273 |
utf8:= char(Key or firstByteMark[btw]) + utf8; |
274 |
||
1485
51c11e77408a
Fix chat bugs leading to serialized data corruption
unc0rr
parents:
1431
diff
changeset
|
275 |
if byte(InputStr.s[0]) + btw > 240 then exit; |
51c11e77408a
Fix chat bugs leading to serialized data corruption
unc0rr
parents:
1431
diff
changeset
|
276 |
|
946 | 277 |
InputStrL[byte(InputStr.s[0]) + btw]:= InputStr.s[0]; |
990
dfa6a6fe1542
Implement history for chat (27 entries), no key binding yet
unc0rr
parents:
988
diff
changeset
|
278 |
SetLine(InputStr, InputStr.s + utf8, true) |
946 | 279 |
end |
280 |
end; |
|
281 |
||
282 |
||
942 | 283 |
end. |