author | celestar |
Wed, 22 Mar 2006 11:23:22 +0000 | |
branch | 0.4.5 |
changeset 9946 | d3cb7e05c5a6 |
parent 9939 | c4797077028a |
permissions | -rw-r--r-- |
2186 | 1 |
/* $Id$ */ |
2 |
||
0 | 3 |
#include "stdafx.h" |
1891
92a3b0aa0946
(svn r2397) - CodeChange: rename all "ttd" files to "openttd" files.
Darkvater
parents:
1829
diff
changeset
|
4 |
#include "openttd.h" |
2163
637ec3c361f5
(svn r2673) Include functions.h directly, not globally via openttd.h
tron
parents:
2154
diff
changeset
|
5 |
#include "functions.h" |
2154
63a6b880b4c0
(svn r2664) Remove depedency on player.h from variables.h
tron
parents:
2153
diff
changeset
|
6 |
#include "player.h" |
1349
07514c2cc6d1
(svn r1853) Move spritecache function declarations into a header of their own and use SpriteID as parameter type where appropriate
tron
parents:
1348
diff
changeset
|
7 |
#include "spritecache.h" |
1309
dab90d4cbf2d
(svn r1813) Declare functions implemented in strings.c in their own shiny new header (though i think some of these function don't belong into strings.c)
tron
parents:
1130
diff
changeset
|
8 |
#include "strings.h" |
2097
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
9 |
#include "string.h" |
0 | 10 |
#include "gfx.h" |
11 |
#include "table/palettes.h" |
|
2187
2a51f8925eeb
(svn r2702) -Codechange: Cleaned up the sprite code and replaced many magic numbers
celestar
parents:
2186
diff
changeset
|
12 |
#include "table/sprites.h" |
0 | 13 |
#include "hal.h" |
2153
91e89aa8c299
(svn r2663) Include variables.h only in these files which need it, not globally via openttd.h
tron
parents:
2134
diff
changeset
|
14 |
#include "variables.h" |
0 | 15 |
|
2649
7cd504bd4e51
(svn r3191) Move declaration and definition of _dbg_screen_rect to a place where it somewhat makes sense and wrap them in #ifdef _DEBUG
tron
parents:
2645
diff
changeset
|
16 |
#ifdef _DEBUG |
7cd504bd4e51
(svn r3191) Move declaration and definition of _dbg_screen_rect to a place where it somewhat makes sense and wrap them in #ifdef _DEBUG
tron
parents:
2645
diff
changeset
|
17 |
bool _dbg_screen_rect; |
7cd504bd4e51
(svn r3191) Move declaration and definition of _dbg_screen_rect to a place where it somewhat makes sense and wrap them in #ifdef _DEBUG
tron
parents:
2645
diff
changeset
|
18 |
#endif |
7cd504bd4e51
(svn r3191) Move declaration and definition of _dbg_screen_rect to a place where it somewhat makes sense and wrap them in #ifdef _DEBUG
tron
parents:
2645
diff
changeset
|
19 |
|
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
20 |
Colour _cur_palette[256]; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
21 |
|
1357 | 22 |
static void GfxMainBlitter(const Sprite *sprite, int x, int y, int mode); |
0 | 23 |
|
24 |
static int _stringwidth_out; |
|
2062 | 25 |
static Pixel _cursor_backup[64 * 64]; |
0 | 26 |
static Rect _invalid_rect; |
1357 | 27 |
static const byte *_color_remap_ptr; |
0 | 28 |
static byte _string_colorremap[3]; |
29 |
||
2010 | 30 |
#define DIRTY_BYTES_PER_LINE (MAX_SCREEN_WIDTH / 64) |
0 | 31 |
static byte _dirty_blocks[DIRTY_BYTES_PER_LINE * MAX_SCREEN_HEIGHT / 8]; |
32 |
||
33 |
||
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
510
diff
changeset
|
34 |
|
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
510
diff
changeset
|
35 |
void memcpy_pitch(void *d, void *s, int w, int h, int spitch, int dpitch) |
0 | 36 |
{ |
37 |
byte *dp = (byte*)d; |
|
38 |
byte *sp = (byte*)s; |
|
39 |
||
40 |
assert(h >= 0); |
|
1056
ff3cfd9042a3
(svn r1557) Replace strange if () do while () construct with a plain for ()
tron
parents:
1009
diff
changeset
|
41 |
for (; h != 0; --h) { |
0 | 42 |
memcpy(dp, sp, w); |
43 |
dp += dpitch; |
|
44 |
sp += spitch; |
|
1056
ff3cfd9042a3
(svn r1557) Replace strange if () do while () construct with a plain for ()
tron
parents:
1009
diff
changeset
|
45 |
} |
0 | 46 |
} |
47 |
||
48 |
||
2010 | 49 |
void GfxScroll(int left, int top, int width, int height, int xo, int yo) |
50 |
{ |
|
2062 | 51 |
const Pixel *src; |
52 |
Pixel *dst; |
|
0 | 53 |
int p; |
54 |
int ht; |
|
55 |
||
2010 | 56 |
if (xo == 0 && yo == 0) return; |
0 | 57 |
|
2010 | 58 |
if (_cursor.visible) UndrawMouseCursor(); |
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
510
diff
changeset
|
59 |
UndrawTextMessage(); |
0 | 60 |
|
61 |
p = _screen.pitch; |
|
62 |
||
375
6a1e279049d2
(svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents:
332
diff
changeset
|
63 |
if (yo > 0) { |
0 | 64 |
// Calculate pointers |
375
6a1e279049d2
(svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents:
332
diff
changeset
|
65 |
dst = _screen.dst_ptr + (top + height - 1) * p + left; |
0 | 66 |
src = dst - yo * p; |
67 |
||
68 |
// Decrease height and increase top |
|
69 |
top += yo; |
|
70 |
height -= yo; |
|
71 |
assert(height > 0); |
|
72 |
||
73 |
// Adjust left & width |
|
74 |
if (xo >= 0) { |
|
375
6a1e279049d2
(svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents:
332
diff
changeset
|
75 |
dst += xo; |
0 | 76 |
left += xo; |
77 |
width -= xo; |
|
78 |
} else { |
|
375
6a1e279049d2
(svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents:
332
diff
changeset
|
79 |
src -= xo; |
0 | 80 |
width += xo; |
81 |
} |
|
82 |
||
375
6a1e279049d2
(svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents:
332
diff
changeset
|
83 |
for (ht = height; ht > 0; --ht) { |
6a1e279049d2
(svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents:
332
diff
changeset
|
84 |
memcpy(dst, src, width); |
0 | 85 |
src -= p; |
86 |
dst -= p; |
|
375
6a1e279049d2
(svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents:
332
diff
changeset
|
87 |
} |
0 | 88 |
} else { |
375
6a1e279049d2
(svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents:
332
diff
changeset
|
89 |
// Calculate pointers |
0 | 90 |
dst = _screen.dst_ptr + top * p + left; |
91 |
src = dst - yo * p; |
|
92 |
||
93 |
// Decrese height. (yo is <=0). |
|
94 |
height += yo; |
|
95 |
assert(height > 0); |
|
96 |
||
97 |
// Adjust left & width |
|
98 |
if (xo >= 0) { |
|
99 |
dst += xo; |
|
100 |
left += xo; |
|
101 |
width -= xo; |
|
102 |
} else { |
|
103 |
src -= xo; |
|
104 |
width += xo; |
|
105 |
} |
|
106 |
||
375
6a1e279049d2
(svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents:
332
diff
changeset
|
107 |
// the y-displacement may be 0 therefore we have to use memmove, |
6a1e279049d2
(svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents:
332
diff
changeset
|
108 |
// because source and destination may overlap |
6a1e279049d2
(svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents:
332
diff
changeset
|
109 |
for (ht = height; ht > 0; --ht) { |
6a1e279049d2
(svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents:
332
diff
changeset
|
110 |
memmove(dst, src, width); |
0 | 111 |
src += p; |
112 |
dst += p; |
|
375
6a1e279049d2
(svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents:
332
diff
changeset
|
113 |
} |
0 | 114 |
} |
375
6a1e279049d2
(svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents:
332
diff
changeset
|
115 |
// This part of the screen is now dirty. |
6a1e279049d2
(svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents:
332
diff
changeset
|
116 |
_video_driver->make_dirty(left, top, width, height); |
0 | 117 |
} |
118 |
||
119 |
||
2010 | 120 |
void GfxFillRect(int left, int top, int right, int bottom, int color) |
121 |
{ |
|
2548
97ada3bd2702
(svn r3077) static, const, bracing, indentation, 0 -> '\0'/NULL, typos in comments, excess empty lines, minor other changes
tron
parents:
2436
diff
changeset
|
122 |
const DrawPixelInfo* dpi = _cur_dpi; |
2062 | 123 |
Pixel *dst; |
332 | 124 |
const int otop = top; |
125 |
const int oleft = left; |
|
0 | 126 |
|
2010 | 127 |
if (dpi->zoom != 0) return; |
128 |
if (left > right || top > bottom) return; |
|
129 |
if (right < dpi->left || left >= dpi->left + dpi->width) return; |
|
130 |
if (bottom < dpi->top || top >= dpi->top + dpi->height) return; |
|
0 | 131 |
|
132 |
if ( (left -= dpi->left) < 0) left = 0; |
|
133 |
right = right - dpi->left + 1; |
|
2010 | 134 |
if (right > dpi->width) right = dpi->width; |
0 | 135 |
right -= left; |
136 |
assert(right > 0); |
|
137 |
||
138 |
if ( (top -= dpi->top) < 0) top = 0; |
|
139 |
bottom = bottom - dpi->top + 1; |
|
2010 | 140 |
if (bottom > dpi->height) bottom = dpi->height; |
0 | 141 |
bottom -= top; |
142 |
assert(bottom > 0); |
|
143 |
||
144 |
dst = dpi->dst_ptr + top * dpi->pitch + left; |
|
145 |
||
2218
abd47ef7d902
(svn r2736) -Codechange: De-mystified GfxDrawFillRect a bit, and used enums from table/sprites.h. You can now change the number of bits used for sprites and switches in the SpriteSetup enum and the rest should work automagically. Can be used to increase the number of active sprites to 2^19 in case there are no colortables (recolor sprites) in any newgrf. We should possibly move the the colortables to an own list, but how to detect them in a newgrf.
celestar
parents:
2204
diff
changeset
|
146 |
if (!(color & PALETTE_MODIFIER_GREYOUT)) { |
abd47ef7d902
(svn r2736) -Codechange: De-mystified GfxDrawFillRect a bit, and used enums from table/sprites.h. You can now change the number of bits used for sprites and switches in the SpriteSetup enum and the rest should work automagically. Can be used to increase the number of active sprites to 2^19 in case there are no colortables (recolor sprites) in any newgrf. We should possibly move the the colortables to an own list, but how to detect them in a newgrf.
celestar
parents:
2204
diff
changeset
|
147 |
if (!(color & USE_COLORTABLE)) { |
0 | 148 |
do { |
149 |
memset(dst, color, right); |
|
150 |
dst += dpi->pitch; |
|
151 |
} while (--bottom); |
|
152 |
} else { |
|
153 |
/* use colortable mode */ |
|
2218
abd47ef7d902
(svn r2736) -Codechange: De-mystified GfxDrawFillRect a bit, and used enums from table/sprites.h. You can now change the number of bits used for sprites and switches in the SpriteSetup enum and the rest should work automagically. Can be used to increase the number of active sprites to 2^19 in case there are no colortables (recolor sprites) in any newgrf. We should possibly move the the colortables to an own list, but how to detect them in a newgrf.
celestar
parents:
2204
diff
changeset
|
154 |
const byte* ctab = GetNonSprite(color & COLORTABLE_MASK) + 1; |
1357 | 155 |
|
0 | 156 |
do { |
157 |
int i; |
|
2005 | 158 |
for (i = 0; i != right; i++) dst[i] = ctab[dst[i]]; |
0 | 159 |
dst += dpi->pitch; |
160 |
} while (--bottom); |
|
161 |
} |
|
162 |
} else { |
|
332 | 163 |
byte bo = (oleft - left + dpi->left + otop - top + dpi->top) & 1; |
0 | 164 |
do { |
165 |
int i; |
|
2005 | 166 |
for (i = (bo ^= 1); i < right; i += 2) dst[i] = (byte)color; |
0 | 167 |
dst += dpi->pitch; |
332 | 168 |
} while (--bottom > 0); |
0 | 169 |
} |
170 |
} |
|
171 |
||
410 | 172 |
static void GfxSetPixel(int x, int y, int color) |
0 | 173 |
{ |
2548
97ada3bd2702
(svn r3077) static, const, bracing, indentation, 0 -> '\0'/NULL, typos in comments, excess empty lines, minor other changes
tron
parents:
2436
diff
changeset
|
174 |
const DrawPixelInfo* dpi = _cur_dpi; |
0 | 175 |
if ((x-=dpi->left) < 0 || x>=dpi->width || (y-=dpi->top)<0 || y>=dpi->height) |
176 |
return; |
|
2010 | 177 |
dpi->dst_ptr[y * dpi->pitch + x] = color; |
0 | 178 |
} |
179 |
||
180 |
void GfxDrawLine(int x, int y, int x2, int y2, int color) |
|
181 |
{ |
|
182 |
int dy; |
|
183 |
int dx; |
|
2010 | 184 |
int stepx; |
185 |
int stepy; |
|
0 | 186 |
int frac; |
187 |
||
188 |
// Check clipping first |
|
189 |
{ |
|
190 |
DrawPixelInfo *dpi = _cur_dpi; |
|
191 |
int t; |
|
192 |
||
2010 | 193 |
if (x < dpi->left && x2 < dpi->left) return; |
0 | 194 |
|
2010 | 195 |
if (y < dpi->top && y2 < dpi->top) return; |
0 | 196 |
|
197 |
t = dpi->left + dpi->width; |
|
2010 | 198 |
if (x > t && x2 > t) return; |
0 | 199 |
|
200 |
t = dpi->top + dpi->height; |
|
2010 | 201 |
if (y > t && y2 > t) return; |
0 | 202 |
} |
203 |
||
204 |
dy = (y2 - y) * 2; |
|
2010 | 205 |
if (dy < 0) { |
206 |
dy = -dy; |
|
207 |
stepy = -1; |
|
208 |
} else { |
|
209 |
stepy = 1; |
|
210 |
} |
|
0 | 211 |
|
212 |
dx = (x2 - x) * 2; |
|
2010 | 213 |
if (dx < 0) { |
214 |
dx = -dx; |
|
215 |
stepx = -1; |
|
216 |
} else { |
|
217 |
stepx = 1; |
|
218 |
} |
|
0 | 219 |
|
220 |
GfxSetPixel(x, y, color); |
|
221 |
if (dx > dy) { |
|
222 |
frac = dy - (dx >> 1); |
|
223 |
while (x != x2) { |
|
224 |
if (frac >= 0) { |
|
225 |
y += stepy; |
|
226 |
frac -= dx; |
|
227 |
} |
|
228 |
x += stepx; |
|
229 |
frac += dy; |
|
230 |
GfxSetPixel(x, y, color); |
|
231 |
} |
|
232 |
} else { |
|
233 |
frac = dx - (dy >> 1); |
|
234 |
while (y != y2) { |
|
235 |
if (frac >= 0) { |
|
236 |
x += stepx; |
|
237 |
frac -= dy; |
|
238 |
} |
|
239 |
y += stepy; |
|
240 |
frac += dx; |
|
241 |
GfxSetPixel(x, y, color); |
|
242 |
} |
|
243 |
} |
|
244 |
} |
|
245 |
||
246 |
// ASSIGNMENT OF ASCII LETTERS < 32 |
|
247 |
// 0 - end of string |
|
248 |
// 1 - SETX <BYTE> |
|
249 |
// 2 - SETXY <BYTE> <BYTE> |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
126
diff
changeset
|
250 |
// 3-7 - |
0 | 251 |
// 8 - TINYFONT |
252 |
// 9 - BIGFONT |
|
253 |
// 10 - newline |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
126
diff
changeset
|
254 |
// 11-14 - |
0 | 255 |
// 15-31 - 17 colors |
256 |
||
257 |
||
258 |
enum { |
|
259 |
ASCII_SETX = 1, |
|
260 |
ASCII_SETXY = 2, |
|
261 |
||
262 |
ASCII_TINYFONT = 8, |
|
263 |
ASCII_BIGFONT = 9, |
|
264 |
ASCII_NL = 10, |
|
265 |
||
266 |
ASCII_COLORSTART = 15, |
|
267 |
}; |
|
268 |
||
2097
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
269 |
/** Truncate a given string to a maximum width if neccessary. |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
270 |
* If the string is truncated, add three dots ('...') to show this. |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
271 |
* @param *dest string that is checked and possibly truncated |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
272 |
* @param maxw maximum width in pixels of the string |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
273 |
* @return new width of (truncated) string */ |
2113
f228b399da01
(svn r2623) - CodeChange: rework DrawStringCenteredTruncated() a bit. Instead of giving center + width you give the coordinates of the bounding box (left, right) it has to fit in (ludde)
Darkvater
parents:
2107
diff
changeset
|
274 |
static int TruncateString(char *str, int maxw) |
2097
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
275 |
{ |
2113
f228b399da01
(svn r2623) - CodeChange: rework DrawStringCenteredTruncated() a bit. Instead of giving center + width you give the coordinates of the bounding box (left, right) it has to fit in (ludde)
Darkvater
parents:
2107
diff
changeset
|
276 |
int w = 0; |
2097
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
277 |
int base = _stringwidth_base; |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
278 |
int ddd, ddd_w; |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
279 |
|
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
280 |
byte c; |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
281 |
char *ddd_pos; |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
282 |
|
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
283 |
base = _stringwidth_base; |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
284 |
ddd_w = ddd = GetCharacterWidth(base + '.') * 3; |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
285 |
|
2113
f228b399da01
(svn r2623) - CodeChange: rework DrawStringCenteredTruncated() a bit. Instead of giving center + width you give the coordinates of the bounding box (left, right) it has to fit in (ludde)
Darkvater
parents:
2107
diff
changeset
|
286 |
for (ddd_pos = str; (c = *str++) != '\0'; ) { |
2097
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
287 |
if (c >= ASCII_LETTERSTART) { |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
288 |
w += GetCharacterWidth(base + c); |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
289 |
|
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
290 |
if (w >= maxw) { |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
291 |
// string got too big... insert dotdotdot |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
292 |
ddd_pos[0] = ddd_pos[1] = ddd_pos[2] = '.'; |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
293 |
ddd_pos[3] = 0; |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
294 |
return ddd_w; |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
295 |
} |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
296 |
} else { |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
297 |
if (c == ASCII_SETX) str++; |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
298 |
else if (c == ASCII_SETXY) str += 2; |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
299 |
else if (c == ASCII_TINYFONT) { |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
300 |
base = 224; |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
301 |
ddd = GetCharacterWidth(base + '.') * 3; |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
302 |
} else if (c == ASCII_BIGFONT) { |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
303 |
base = 448; |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
304 |
ddd = GetCharacterWidth(base + '.') * 3; |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
305 |
} |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
306 |
} |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
307 |
|
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
308 |
// Remember the last position where three dots fit. |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
309 |
if (w + ddd < maxw) { |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
310 |
ddd_w = w + ddd; |
2113
f228b399da01
(svn r2623) - CodeChange: rework DrawStringCenteredTruncated() a bit. Instead of giving center + width you give the coordinates of the bounding box (left, right) it has to fit in (ludde)
Darkvater
parents:
2107
diff
changeset
|
311 |
ddd_pos = str; |
2097
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
312 |
} |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
313 |
} |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
314 |
|
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
315 |
return w; |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
316 |
} |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
317 |
|
2113
f228b399da01
(svn r2623) - CodeChange: rework DrawStringCenteredTruncated() a bit. Instead of giving center + width you give the coordinates of the bounding box (left, right) it has to fit in (ludde)
Darkvater
parents:
2107
diff
changeset
|
318 |
static inline int TruncateStringID(StringID src, char *dest, int maxw) |
2097
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
319 |
{ |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
320 |
GetString(dest, src); |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
321 |
return TruncateString(dest, maxw); |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
322 |
} |
0 | 323 |
|
324 |
/* returns right coordinate */ |
|
2097
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
325 |
int DrawString(int x, int y, StringID str, uint16 color) |
0 | 326 |
{ |
1336
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
327 |
char buffer[512]; |
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
328 |
|
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
329 |
GetString(buffer, str); |
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
330 |
return DoDrawString(buffer, x, y, color); |
0 | 331 |
} |
332 |
||
2097
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
333 |
int DrawStringTruncated(int x, int y, StringID str, uint16 color, uint maxw) |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
334 |
{ |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
335 |
char buffer[512]; |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
336 |
TruncateStringID(str, buffer, maxw); |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
337 |
return DoDrawString(buffer, x, y, color); |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
338 |
} |
0 | 339 |
|
2097
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
340 |
|
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
341 |
void DrawStringRightAligned(int x, int y, StringID str, uint16 color) |
0 | 342 |
{ |
1336
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
343 |
char buffer[512]; |
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
344 |
|
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
345 |
GetString(buffer, str); |
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
346 |
DoDrawString(buffer, x - GetStringWidth(buffer), y, color); |
0 | 347 |
} |
348 |
||
2097
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
349 |
void DrawStringRightAlignedTruncated(int x, int y, StringID str, uint16 color, uint maxw) |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
350 |
{ |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
351 |
char buffer[512]; |
0 | 352 |
|
2097
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
353 |
TruncateStringID(str, buffer, maxw); |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
354 |
DoDrawString(buffer, x - GetStringWidth(buffer), y, color); |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
355 |
} |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
356 |
|
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
357 |
|
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
358 |
int DrawStringCentered(int x, int y, StringID str, uint16 color) |
0 | 359 |
{ |
1336
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
360 |
char buffer[512]; |
0 | 361 |
int w; |
362 |
||
1336
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
363 |
GetString(buffer, str); |
0 | 364 |
|
1336
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
365 |
w = GetStringWidth(buffer); |
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
366 |
DoDrawString(buffer, x - w / 2, y, color); |
0 | 367 |
|
368 |
return w; |
|
369 |
} |
|
370 |
||
2113
f228b399da01
(svn r2623) - CodeChange: rework DrawStringCenteredTruncated() a bit. Instead of giving center + width you give the coordinates of the bounding box (left, right) it has to fit in (ludde)
Darkvater
parents:
2107
diff
changeset
|
371 |
int DrawStringCenteredTruncated(int xl, int xr, int y, StringID str, uint16 color) |
2097
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
372 |
{ |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
373 |
char buffer[512]; |
2113
f228b399da01
(svn r2623) - CodeChange: rework DrawStringCenteredTruncated() a bit. Instead of giving center + width you give the coordinates of the bounding box (left, right) it has to fit in (ludde)
Darkvater
parents:
2107
diff
changeset
|
374 |
int w = TruncateStringID(str, buffer, xr - xl); |
f228b399da01
(svn r2623) - CodeChange: rework DrawStringCenteredTruncated() a bit. Instead of giving center + width you give the coordinates of the bounding box (left, right) it has to fit in (ludde)
Darkvater
parents:
2107
diff
changeset
|
375 |
return DoDrawString(buffer, (xl + xr - w) / 2, y, color); |
2097
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
376 |
} |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
377 |
|
2134 | 378 |
int DoDrawStringCentered(int x, int y, const char *str, uint16 color) |
379 |
{ |
|
380 |
int w = GetStringWidth(str); |
|
381 |
DoDrawString(str, x - w / 2, y, color); |
|
382 |
return w; |
|
383 |
} |
|
384 |
||
2097
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
385 |
void DrawStringCenterUnderline(int x, int y, StringID str, uint16 color) |
0 | 386 |
{ |
387 |
int w = DrawStringCentered(x, y, str, color); |
|
2010 | 388 |
GfxFillRect(x - (w >> 1), y + 10, x - (w >> 1) + w, y + 10, _string_colorremap[1]); |
0 | 389 |
} |
390 |
||
2113
f228b399da01
(svn r2623) - CodeChange: rework DrawStringCenteredTruncated() a bit. Instead of giving center + width you give the coordinates of the bounding box (left, right) it has to fit in (ludde)
Darkvater
parents:
2107
diff
changeset
|
391 |
void DrawStringCenterUnderlineTruncated(int xl, int xr, int y, StringID str, uint16 color) |
2097
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
392 |
{ |
2113
f228b399da01
(svn r2623) - CodeChange: rework DrawStringCenteredTruncated() a bit. Instead of giving center + width you give the coordinates of the bounding box (left, right) it has to fit in (ludde)
Darkvater
parents:
2107
diff
changeset
|
393 |
int w = DrawStringCenteredTruncated(xl, xr, y, str, color); |
f228b399da01
(svn r2623) - CodeChange: rework DrawStringCenteredTruncated() a bit. Instead of giving center + width you give the coordinates of the bounding box (left, right) it has to fit in (ludde)
Darkvater
parents:
2107
diff
changeset
|
394 |
GfxFillRect((xl + xr - w) / 2, y + 10, (xl + xr + w) / 2, y + 10, _string_colorremap[1]); |
2097
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
395 |
} |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
396 |
|
1323
41397685320a
(svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents:
1309
diff
changeset
|
397 |
static uint32 FormatStringLinebreaks(char *str, int maxw) |
1095 | 398 |
{ |
0 | 399 |
int num = 0; |
400 |
int base = _stringwidth_base; |
|
401 |
int w; |
|
1323
41397685320a
(svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents:
1309
diff
changeset
|
402 |
char *last_space; |
0 | 403 |
byte c; |
404 |
||
405 |
for(;;) { |
|
406 |
w = 0; |
|
407 |
last_space = NULL; |
|
408 |
||
409 |
for(;;) { |
|
410 |
c = *str++; |
|
1390
53a5713cf3f9
(svn r1894) - Codechange: cleaned up the console a bit, wholly unified handling of text with that of editboxes
Darkvater
parents:
1357
diff
changeset
|
411 |
if (c == ASCII_LETTERSTART) last_space = str; |
0 | 412 |
|
413 |
if (c >= ASCII_LETTERSTART) { |
|
1390
53a5713cf3f9
(svn r1894) - Codechange: cleaned up the console a bit, wholly unified handling of text with that of editboxes
Darkvater
parents:
1357
diff
changeset
|
414 |
w += GetCharacterWidth(base + (byte)c); |
0 | 415 |
if (w > maxw) { |
416 |
str = last_space; |
|
417 |
if (str == NULL) |
|
418 |
return num + (base << 16); |
|
419 |
break; |
|
420 |
} |
|
421 |
} else { |
|
422 |
if (c == 0) return num + (base << 16); |
|
423 |
if (c == ASCII_NL) break; |
|
424 |
||
425 |
if (c == ASCII_SETX) str++; |
|
426 |
else if (c == ASCII_SETXY) str += 2; |
|
427 |
else if (c == ASCII_TINYFONT) base = 224; |
|
428 |
else if (c == ASCII_BIGFONT) base = 448; |
|
429 |
} |
|
430 |
} |
|
431 |
||
432 |
num++; |
|
2548
97ada3bd2702
(svn r3077) static, const, bracing, indentation, 0 -> '\0'/NULL, typos in comments, excess empty lines, minor other changes
tron
parents:
2436
diff
changeset
|
433 |
str[-1] = '\0'; |
0 | 434 |
} |
435 |
} |
|
436 |
||
2634
16334e1a4862
(svn r3176) Use proper types, not some variants of int
tron
parents:
2631
diff
changeset
|
437 |
void DrawStringMultiCenter(int x, int y, StringID str, int maxw) |
0 | 438 |
{ |
1336
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
439 |
char buffer[512]; |
0 | 440 |
uint32 tmp; |
2631
13daba67f217
(svn r3173) Use the trinary operator and switch to improve readability
tron
parents:
2548
diff
changeset
|
441 |
int num, w, mt; |
1323
41397685320a
(svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents:
1309
diff
changeset
|
442 |
const char *src; |
0 | 443 |
byte c; |
444 |
||
1336
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
445 |
GetString(buffer, str); |
0 | 446 |
|
1336
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
447 |
tmp = FormatStringLinebreaks(buffer, maxw); |
2635 | 448 |
num = GB(tmp, 0, 16); |
0 | 449 |
|
2631
13daba67f217
(svn r3173) Use the trinary operator and switch to improve readability
tron
parents:
2548
diff
changeset
|
450 |
switch (GB(tmp, 16, 16)) { |
13daba67f217
(svn r3173) Use the trinary operator and switch to improve readability
tron
parents:
2548
diff
changeset
|
451 |
case 0: mt = 10; break; |
13daba67f217
(svn r3173) Use the trinary operator and switch to improve readability
tron
parents:
2548
diff
changeset
|
452 |
case 244: mt = 6; break; |
13daba67f217
(svn r3173) Use the trinary operator and switch to improve readability
tron
parents:
2548
diff
changeset
|
453 |
default: mt = 18; break; |
0 | 454 |
} |
455 |
||
456 |
y -= (mt >> 1) * num; |
|
457 |
||
1336
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
458 |
src = buffer; |
0 | 459 |
|
460 |
for(;;) { |
|
461 |
w = GetStringWidth(src); |
|
462 |
DoDrawString(src, x - (w>>1), y, 0xFE); |
|
463 |
_stringwidth_base = _stringwidth_out; |
|
464 |
||
465 |
for(;;) { |
|
466 |
c = *src++; |
|
467 |
if (c == 0) { |
|
468 |
y += mt; |
|
469 |
if (--num < 0) { |
|
470 |
_stringwidth_base = 0; |
|
471 |
return; |
|
472 |
} |
|
473 |
break; |
|
474 |
} else if (c == ASCII_SETX) { |
|
475 |
src++; |
|
476 |
} else if (c == ASCII_SETXY) { |
|
477 |
src+=2; |
|
478 |
} |
|
479 |
} |
|
480 |
} |
|
481 |
} |
|
482 |
||
2634
16334e1a4862
(svn r3176) Use proper types, not some variants of int
tron
parents:
2631
diff
changeset
|
483 |
void DrawStringMultiLine(int x, int y, StringID str, int maxw) |
2010 | 484 |
{ |
1336
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
485 |
char buffer[512]; |
0 | 486 |
uint32 tmp; |
2753 | 487 |
int num, mt; |
1323
41397685320a
(svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents:
1309
diff
changeset
|
488 |
const char *src; |
0 | 489 |
byte c; |
490 |
||
1336
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
491 |
GetString(buffer, str); |
0 | 492 |
|
1336
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
493 |
tmp = FormatStringLinebreaks(buffer, maxw); |
2635 | 494 |
num = GB(tmp, 0, 16); |
2631
13daba67f217
(svn r3173) Use the trinary operator and switch to improve readability
tron
parents:
2548
diff
changeset
|
495 |
|
13daba67f217
(svn r3173) Use the trinary operator and switch to improve readability
tron
parents:
2548
diff
changeset
|
496 |
switch (GB(tmp, 16, 16)) { |
13daba67f217
(svn r3173) Use the trinary operator and switch to improve readability
tron
parents:
2548
diff
changeset
|
497 |
case 0: mt = 10; break; |
13daba67f217
(svn r3173) Use the trinary operator and switch to improve readability
tron
parents:
2548
diff
changeset
|
498 |
case 244: mt = 6; break; |
13daba67f217
(svn r3173) Use the trinary operator and switch to improve readability
tron
parents:
2548
diff
changeset
|
499 |
default: mt = 18; break; |
0 | 500 |
} |
501 |
||
1336
c9e6b766bf21
(svn r1840) Repel str_buffr and use local buffers where possible
tron
parents:
1323
diff
changeset
|
502 |
src = buffer; |
0 | 503 |
|
504 |
for(;;) { |
|
505 |
DoDrawString(src, x, y, 0xFE); |
|
506 |
_stringwidth_base = _stringwidth_out; |
|
507 |
||
508 |
for(;;) { |
|
509 |
c = *src++; |
|
510 |
if (c == 0) { |
|
511 |
y += mt; |
|
512 |
if (--num < 0) { |
|
513 |
_stringwidth_base = 0; |
|
514 |
return; |
|
515 |
} |
|
516 |
break; |
|
517 |
} else if (c == ASCII_SETX) { |
|
518 |
src++; |
|
519 |
} else if (c == ASCII_SETXY) { |
|
520 |
src+=2; |
|
521 |
} |
|
522 |
} |
|
523 |
} |
|
524 |
} |
|
525 |
||
1323
41397685320a
(svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents:
1309
diff
changeset
|
526 |
int GetStringWidth(const char *str) |
41397685320a
(svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents:
1309
diff
changeset
|
527 |
{ |
1390
53a5713cf3f9
(svn r1894) - Codechange: cleaned up the console a bit, wholly unified handling of text with that of editboxes
Darkvater
parents:
1357
diff
changeset
|
528 |
int w = 0; |
0 | 529 |
byte c; |
530 |
int base = _stringwidth_base; |
|
1390
53a5713cf3f9
(svn r1894) - Codechange: cleaned up the console a bit, wholly unified handling of text with that of editboxes
Darkvater
parents:
1357
diff
changeset
|
531 |
for (c = *str; c != '\0'; c = *(++str)) { |
0 | 532 |
if (c >= ASCII_LETTERSTART) { |
1390
53a5713cf3f9
(svn r1894) - Codechange: cleaned up the console a bit, wholly unified handling of text with that of editboxes
Darkvater
parents:
1357
diff
changeset
|
533 |
w += GetCharacterWidth(base + c); |
0 | 534 |
} else { |
535 |
if (c == ASCII_SETX) str++; |
|
536 |
else if (c == ASCII_SETXY) str += 2; |
|
537 |
else if (c == ASCII_TINYFONT) base = 224; |
|
538 |
else if (c == ASCII_BIGFONT) base = 448; |
|
539 |
} |
|
540 |
} |
|
1390
53a5713cf3f9
(svn r1894) - Codechange: cleaned up the console a bit, wholly unified handling of text with that of editboxes
Darkvater
parents:
1357
diff
changeset
|
541 |
return w; |
0 | 542 |
} |
543 |
||
2010 | 544 |
void DrawFrameRect(int left, int top, int right, int bottom, int ctab, int flags) |
545 |
{ |
|
0 | 546 |
byte color_2 = _color_list[ctab].window_color_1a; |
547 |
byte color_interior = _color_list[ctab].window_color_bga; |
|
548 |
byte color_3 = _color_list[ctab].window_color_bgb; |
|
549 |
byte color = _color_list[ctab].window_color_2; |
|
550 |
||
2025 | 551 |
if (!(flags & 0x8)) { |
0 | 552 |
if (!(flags & 0x20)) { |
2010 | 553 |
GfxFillRect(left, top, left, bottom - 1, color); |
554 |
GfxFillRect(left + 1, top, right - 1, top, color); |
|
555 |
GfxFillRect(right, top, right, bottom - 1, color_2); |
|
0 | 556 |
GfxFillRect(left, bottom, right, bottom, color_2); |
557 |
if (!(flags & 0x10)) { |
|
2010 | 558 |
GfxFillRect(left + 1, top + 1, right - 1, bottom - 1, color_interior); |
0 | 559 |
} |
560 |
} else { |
|
561 |
GfxFillRect(left, top, left, bottom, color_2); |
|
2010 | 562 |
GfxFillRect(left + 1, top, right, top, color_2); |
563 |
GfxFillRect(right, top + 1, right, bottom - 1, color); |
|
564 |
GfxFillRect(left + 1, bottom, right, bottom, color); |
|
0 | 565 |
if (!(flags & 0x10)) { |
2010 | 566 |
GfxFillRect(left + 1, top + 1, right - 1, bottom - 1, |
567 |
flags & 0x40 ? color_interior : color_3); |
|
0 | 568 |
} |
569 |
} |
|
570 |
} else if (flags & 0x1) { |
|
571 |
// transparency |
|
2218
abd47ef7d902
(svn r2736) -Codechange: De-mystified GfxDrawFillRect a bit, and used enums from table/sprites.h. You can now change the number of bits used for sprites and switches in the SpriteSetup enum and the rest should work automagically. Can be used to increase the number of active sprites to 2^19 in case there are no colortables (recolor sprites) in any newgrf. We should possibly move the the colortables to an own list, but how to detect them in a newgrf.
celestar
parents:
2204
diff
changeset
|
572 |
GfxFillRect(left, top, right, bottom, 0x322 | USE_COLORTABLE); |
0 | 573 |
} else { |
574 |
GfxFillRect(left, top, right, bottom, color_interior); |
|
575 |
} |
|
576 |
} |
|
577 |
||
1323
41397685320a
(svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents:
1309
diff
changeset
|
578 |
int DoDrawString(const char *string, int x, int y, uint16 real_color) |
41397685320a
(svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents:
1309
diff
changeset
|
579 |
{ |
0 | 580 |
DrawPixelInfo *dpi = _cur_dpi; |
581 |
int base = _stringwidth_base; |
|
509
52dde395d888
(svn r819) Code cleanup: colors for langfile strings are now taken from a color table instead of a sprite
dominik
parents:
461
diff
changeset
|
582 |
byte c; |
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
510
diff
changeset
|
583 |
byte color; |
0 | 584 |
int xo = x, yo = y; |
585 |
||
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
510
diff
changeset
|
586 |
color = real_color & 0xFF; |
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
510
diff
changeset
|
587 |
|
0 | 588 |
if (color != 0xFE) { |
589 |
if (x >= dpi->left + dpi->width || |
|
590 |
x + _screen.width*2 <= dpi->left || |
|
591 |
y >= dpi->top + dpi->height || |
|
592 |
y + _screen.height <= dpi->top) |
|
593 |
return x; |
|
594 |
||
595 |
if (color != 0xFF) { |
|
596 |
switch_color:; |
|
657
40a9032b454b
(svn r1091) Fix: Finally station names use 100% the correct color in transparent mode
dominik
parents:
619
diff
changeset
|
597 |
if (real_color & IS_PALETTE_COLOR) { |
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
510
diff
changeset
|
598 |
_string_colorremap[1] = color; |
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
510
diff
changeset
|
599 |
_string_colorremap[2] = 215; |
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
510
diff
changeset
|
600 |
} else { |
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
510
diff
changeset
|
601 |
_string_colorremap[1] = _string_colormap[color].text; |
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
510
diff
changeset
|
602 |
_string_colorremap[2] = _string_colormap[color].shadow; |
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
510
diff
changeset
|
603 |
} |
0 | 604 |
_color_remap_ptr = _string_colorremap; |
605 |
} |
|
606 |
} |
|
607 |
||
608 |
check_bounds: |
|
609 |
if (y + 19 <= dpi->top || dpi->top + dpi->height <= y) { |
|
610 |
skip_char:; |
|
611 |
for(;;) { |
|
612 |
c = *string++; |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
126
diff
changeset
|
613 |
if (c < ASCII_LETTERSTART) goto skip_cont; |
0 | 614 |
} |
615 |
} |
|
616 |
||
617 |
for(;;) { |
|
618 |
c = *string++; |
|
619 |
skip_cont:; |
|
620 |
if (c == 0) { |
|
621 |
_stringwidth_out = base; |
|
622 |
return x; |
|
623 |
} |
|
624 |
if (c >= ASCII_LETTERSTART) { |
|
625 |
if (x >= dpi->left + dpi->width) goto skip_char; |
|
626 |
if (x + 26 >= dpi->left) { |
|
1350
067b22970f19
(svn r1854) Split GetSpritePtr() into GetSprite() for regular sprites (returning a Sprite*) and GetNonSprite() for "sprites" of type 0xFF (returning byte*)
tron
parents:
1349
diff
changeset
|
627 |
GfxMainBlitter(GetSprite(base + 2 + c - ASCII_LETTERSTART), x, y, 1); |
0 | 628 |
} |
1390
53a5713cf3f9
(svn r1894) - Codechange: cleaned up the console a bit, wholly unified handling of text with that of editboxes
Darkvater
parents:
1357
diff
changeset
|
629 |
x += GetCharacterWidth(base + c); |
0 | 630 |
} else if (c == ASCII_NL) { // newline = {} |
631 |
x = xo; |
|
632 |
y += 10; |
|
633 |
if (base != 0) { |
|
634 |
y -= 4; |
|
635 |
if (base != 0xE0) |
|
636 |
y += 12; |
|
637 |
} |
|
638 |
goto check_bounds; |
|
639 |
} else if (c >= ASCII_COLORSTART) { // change color? |
|
640 |
color = (byte)(c - ASCII_COLORSTART); |
|
641 |
goto switch_color; |
|
642 |
} else if (c == ASCII_SETX) { // {SETX} |
|
1323
41397685320a
(svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents:
1309
diff
changeset
|
643 |
x = xo + (byte)*string++; |
0 | 644 |
} else if (c == ASCII_SETXY) {// {SETXY} |
1323
41397685320a
(svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents:
1309
diff
changeset
|
645 |
x = xo + (byte)*string++; |
41397685320a
(svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents:
1309
diff
changeset
|
646 |
y = yo + (byte)*string++; |
0 | 647 |
} else if (c == ASCII_TINYFONT) { // {TINYFONT} |
648 |
base = 0xE0; |
|
649 |
} else if (c == ASCII_BIGFONT) { // {BIGFONT} |
|
650 |
base = 0x1C0; |
|
651 |
} else { |
|
652 |
printf("Unknown string command character %d\n", c); |
|
653 |
} |
|
654 |
} |
|
655 |
} |
|
656 |
||
2097
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
657 |
int DoDrawStringTruncated(const char *str, int x, int y, uint16 color, uint maxw) |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
658 |
{ |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
659 |
char buffer[512]; |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
660 |
ttd_strlcpy(buffer, str, sizeof(buffer)); |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
661 |
TruncateString(buffer, maxw); |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
662 |
return DoDrawString(buffer, x, y, color); |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
663 |
} |
82b1e11883fd
(svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents:
2062
diff
changeset
|
664 |
|
2010 | 665 |
void DrawSprite(uint32 img, int x, int y) |
666 |
{ |
|
2187
2a51f8925eeb
(svn r2702) -Codechange: Cleaned up the sprite code and replaced many magic numbers
celestar
parents:
2186
diff
changeset
|
667 |
if (img & PALETTE_MODIFIER_COLOR) { |
2a51f8925eeb
(svn r2702) -Codechange: Cleaned up the sprite code and replaced many magic numbers
celestar
parents:
2186
diff
changeset
|
668 |
_color_remap_ptr = GetNonSprite(GB(img, PALETTE_SPRITE_START, PALETTE_SPRITE_WIDTH)) + 1; |
2a51f8925eeb
(svn r2702) -Codechange: Cleaned up the sprite code and replaced many magic numbers
celestar
parents:
2186
diff
changeset
|
669 |
GfxMainBlitter(GetSprite(img & SPRITE_MASK), x, y, 1); |
2a51f8925eeb
(svn r2702) -Codechange: Cleaned up the sprite code and replaced many magic numbers
celestar
parents:
2186
diff
changeset
|
670 |
} else if (img & PALETTE_MODIFIER_TRANSPARENT) { |
2a51f8925eeb
(svn r2702) -Codechange: Cleaned up the sprite code and replaced many magic numbers
celestar
parents:
2186
diff
changeset
|
671 |
_color_remap_ptr = GetNonSprite(GB(img, PALETTE_SPRITE_START, PALETTE_SPRITE_WIDTH)) + 1; |
2a51f8925eeb
(svn r2702) -Codechange: Cleaned up the sprite code and replaced many magic numbers
celestar
parents:
2186
diff
changeset
|
672 |
GfxMainBlitter(GetSprite(img & SPRITE_MASK), x, y, 2); |
0 | 673 |
} else { |
2187
2a51f8925eeb
(svn r2702) -Codechange: Cleaned up the sprite code and replaced many magic numbers
celestar
parents:
2186
diff
changeset
|
674 |
GfxMainBlitter(GetSprite(img & SPRITE_MASK), x, y, 0); |
0 | 675 |
} |
676 |
} |
|
677 |
||
678 |
typedef struct BlitterParams { |
|
679 |
int start_x, start_y; |
|
1357 | 680 |
const byte* sprite; |
681 |
const byte* sprite_org; |
|
2062 | 682 |
Pixel *dst; |
0 | 683 |
int mode; |
684 |
int width, height; |
|
2010 | 685 |
int width_org; |
686 |
int height_org; |
|
0 | 687 |
int pitch; |
688 |
byte info; |
|
689 |
} BlitterParams; |
|
690 |
||
691 |
static void GfxBlitTileZoomIn(BlitterParams *bp) |
|
692 |
{ |
|
1357 | 693 |
const byte* src_o = bp->sprite; |
694 |
const byte* src; |
|
0 | 695 |
int num, skip; |
696 |
byte done; |
|
2062 | 697 |
Pixel *dst; |
1357 | 698 |
const byte* ctab; |
0 | 699 |
|
700 |
if (bp->mode & 1) { |
|
9918
a151c4749c7a
(svn r3948) - Fix: [ 1415782 ] crash in string code with openbsd/zaurus; alignment issues (thanks Tron for the help). Backport of r3529, r3553 from trunk
Darkvater
parents:
2753
diff
changeset
|
701 |
src_o += ReadLE16Aligned(src_o + bp->start_y * 2); |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
126
diff
changeset
|
702 |
|
0 | 703 |
do { |
704 |
do { |
|
705 |
done = src_o[0]; |
|
706 |
num = done & 0x7F; |
|
707 |
skip = src_o[1]; |
|
708 |
src = src_o + 2; |
|
709 |
src_o += num + 2; |
|
710 |
||
711 |
dst = bp->dst; |
|
712 |
||
713 |
if ( (skip -= bp->start_x) > 0) { |
|
714 |
dst += skip; |
|
715 |
} else { |
|
716 |
src -= skip; |
|
717 |
num += skip; |
|
2010 | 718 |
if (num <= 0) continue; |
0 | 719 |
skip = 0; |
720 |
} |
|
721 |
||
722 |
skip = skip + num - bp->width; |
|
723 |
if (skip > 0) { |
|
724 |
num -= skip; |
|
2010 | 725 |
if (num <= 0) continue; |
0 | 726 |
} |
727 |
||
728 |
ctab = _color_remap_ptr; |
|
729 |
||
1997 | 730 |
for (; num >= 4; num -=4) { |
0 | 731 |
dst[3] = ctab[src[3]]; |
732 |
dst[2] = ctab[src[2]]; |
|
733 |
dst[1] = ctab[src[1]]; |
|
734 |
dst[0] = ctab[src[0]]; |
|
735 |
dst += 4; |
|
736 |
src += 4; |
|
737 |
} |
|
1997 | 738 |
for (; num != 0; num--) *dst++ = ctab[*src++]; |
0 | 739 |
} while (!(done & 0x80)); |
740 |
||
741 |
bp->dst += bp->pitch; |
|
2010 | 742 |
} while (--bp->height != 0); |
0 | 743 |
} else if (bp->mode & 2) { |
9918
a151c4749c7a
(svn r3948) - Fix: [ 1415782 ] crash in string code with openbsd/zaurus; alignment issues (thanks Tron for the help). Backport of r3529, r3553 from trunk
Darkvater
parents:
2753
diff
changeset
|
744 |
src_o += ReadLE16Aligned(src_o + bp->start_y * 2); |
0 | 745 |
do { |
746 |
do { |
|
747 |
done = src_o[0]; |
|
748 |
num = done & 0x7F; |
|
749 |
skip = src_o[1]; |
|
750 |
src_o += num + 2; |
|
751 |
||
752 |
dst = bp->dst; |
|
753 |
||
754 |
if ( (skip -= bp->start_x) > 0) { |
|
755 |
dst += skip; |
|
756 |
} else { |
|
757 |
num += skip; |
|
2010 | 758 |
if (num <= 0) continue; |
0 | 759 |
skip = 0; |
760 |
} |
|
761 |
||
762 |
skip = skip + num - bp->width; |
|
763 |
if (skip > 0) { |
|
764 |
num -= skip; |
|
2010 | 765 |
if (num <= 0) continue; |
0 | 766 |
} |
767 |
||
768 |
ctab = _color_remap_ptr; |
|
1997 | 769 |
for (; num != 0; num--) { |
0 | 770 |
*dst = ctab[*dst]; |
771 |
dst++; |
|
772 |
} |
|
773 |
} while (!(done & 0x80)); |
|
774 |
||
775 |
bp->dst += bp->pitch; |
|
2010 | 776 |
} while (--bp->height != 0); |
0 | 777 |
} else { |
9918
a151c4749c7a
(svn r3948) - Fix: [ 1415782 ] crash in string code with openbsd/zaurus; alignment issues (thanks Tron for the help). Backport of r3529, r3553 from trunk
Darkvater
parents:
2753
diff
changeset
|
778 |
src_o += ReadLE16Aligned(src_o + bp->start_y * 2); |
0 | 779 |
do { |
780 |
do { |
|
781 |
done = src_o[0]; |
|
782 |
num = done & 0x7F; |
|
783 |
skip = src_o[1]; |
|
784 |
src = src_o + 2; |
|
785 |
src_o += num + 2; |
|
786 |
||
787 |
dst = bp->dst; |
|
788 |
||
789 |
if ( (skip -= bp->start_x) > 0) { |
|
790 |
dst += skip; |
|
791 |
} else { |
|
792 |
src -= skip; |
|
793 |
num += skip; |
|
2010 | 794 |
if (num <= 0) continue; |
0 | 795 |
skip = 0; |
796 |
} |
|
797 |
||
798 |
skip = skip + num - bp->width; |
|
799 |
if (skip > 0) { |
|
800 |
num -= skip; |
|
2010 | 801 |
if (num <= 0) continue; |
0 | 802 |
} |
803 |
#if defined(_WIN32) |
|
804 |
if (num & 1) *dst++ = *src++; |
|
805 |
if (num & 2) { *(uint16*)dst = *(uint16*)src; dst += 2; src += 2; } |
|
806 |
if (num >>= 2) { |
|
807 |
do { |
|
808 |
*(uint32*)dst = *(uint32*)src; |
|
809 |
dst += 4; |
|
810 |
src += 4; |
|
2010 | 811 |
} while (--num != 0); |
0 | 812 |
} |
813 |
#else |
|
814 |
memcpy(dst, src, num); |
|
815 |
#endif |
|
816 |
} while (!(done & 0x80)); |
|
817 |
||
818 |
bp->dst += bp->pitch; |
|
2010 | 819 |
} while (--bp->height != 0); |
0 | 820 |
} |
821 |
} |
|
822 |
||
823 |
static void GfxBlitZoomInUncomp(BlitterParams *bp) |
|
824 |
{ |
|
1357 | 825 |
const byte *src = bp->sprite; |
2062 | 826 |
Pixel *dst = bp->dst; |
0 | 827 |
int height = bp->height; |
828 |
int width = bp->width; |
|
829 |
int i; |
|
830 |
||
831 |
assert(height > 0); |
|
832 |
assert(width > 0); |
|
833 |
||
834 |
if (bp->mode & 1) { |
|
835 |
if (bp->info & 1) { |
|
1357 | 836 |
const byte *ctab = _color_remap_ptr; |
0 | 837 |
|
838 |
do { |
|
1996 | 839 |
for (i = 0; i != width; i++) { |
840 |
byte b = ctab[src[i]]; |
|
841 |
||
842 |
if (b != 0) dst[i] = b; |
|
0 | 843 |
} |
844 |
src += bp->width_org; |
|
845 |
dst += bp->pitch; |
|
2010 | 846 |
} while (--height != 0); |
0 | 847 |
} |
848 |
} else if (bp->mode & 2) { |
|
849 |
if (bp->info & 1) { |
|
1357 | 850 |
const byte *ctab = _color_remap_ptr; |
851 |
||
0 | 852 |
do { |
1996 | 853 |
for (i = 0; i != width; i++) |
854 |
if (src[i] != 0) dst[i] = ctab[dst[i]]; |
|
0 | 855 |
src += bp->width_org; |
856 |
dst += bp->pitch; |
|
2010 | 857 |
} while (--height != 0); |
0 | 858 |
} |
859 |
} else { |
|
860 |
if (!(bp->info & 1)) { |
|
861 |
do { |
|
862 |
memcpy(dst, src, width); |
|
863 |
src += bp->width_org; |
|
864 |
dst += bp->pitch; |
|
2010 | 865 |
} while (--height != 0); |
0 | 866 |
} else { |
867 |
do { |
|
868 |
int n = width; |
|
2004 | 869 |
|
870 |
for (; n >= 4; n -= 4) { |
|
1996 | 871 |
if (src[0] != 0) dst[0] = src[0]; |
872 |
if (src[1] != 0) dst[1] = src[1]; |
|
873 |
if (src[2] != 0) dst[2] = src[2]; |
|
874 |
if (src[3] != 0) dst[3] = src[3]; |
|
0 | 875 |
|
876 |
dst += 4; |
|
877 |
src += 4; |
|
878 |
} |
|
879 |
||
2004 | 880 |
for (; n != 0; n--) { |
1996 | 881 |
if (src[0] != 0) dst[0] = src[0]; |
0 | 882 |
src++; |
883 |
dst++; |
|
884 |
} |
|
885 |
||
886 |
src += bp->width_org - width; |
|
887 |
dst += bp->pitch - width; |
|
2010 | 888 |
} while (--height != 0); |
0 | 889 |
} |
890 |
} |
|
891 |
} |
|
892 |
||
893 |
static void GfxBlitTileZoomMedium(BlitterParams *bp) |
|
894 |
{ |
|
1357 | 895 |
const byte* src_o = bp->sprite; |
896 |
const byte* src; |
|
0 | 897 |
int num, skip; |
898 |
byte done; |
|
2062 | 899 |
Pixel *dst; |
1357 | 900 |
const byte* ctab; |
0 | 901 |
|
902 |
if (bp->mode & 1) { |
|
9918
a151c4749c7a
(svn r3948) - Fix: [ 1415782 ] crash in string code with openbsd/zaurus; alignment issues (thanks Tron for the help). Backport of r3529, r3553 from trunk
Darkvater
parents:
2753
diff
changeset
|
903 |
src_o += ReadLE16Aligned(src_o + bp->start_y * 2); |
0 | 904 |
do { |
905 |
do { |
|
906 |
done = src_o[0]; |
|
907 |
num = done & 0x7F; |
|
908 |
skip = src_o[1]; |
|
909 |
src = src_o + 2; |
|
910 |
src_o += num + 2; |
|
911 |
||
912 |
dst = bp->dst; |
|
913 |
||
914 |
if (skip & 1) { |
|
915 |
skip++; |
|
916 |
src++; |
|
2004 | 917 |
if (--num == 0) continue; |
0 | 918 |
} |
919 |
||
920 |
if ( (skip -= bp->start_x) > 0) { |
|
921 |
dst += skip >> 1; |
|
922 |
} else { |
|
923 |
src -= skip; |
|
924 |
num += skip; |
|
2010 | 925 |
if (num <= 0) continue; |
0 | 926 |
skip = 0; |
927 |
} |
|
928 |
||
929 |
skip = skip + num - bp->width; |
|
930 |
if (skip > 0) { |
|
931 |
num -= skip; |
|
2010 | 932 |
if (num <= 0) continue; |
0 | 933 |
} |
934 |
||
935 |
ctab = _color_remap_ptr; |
|
936 |
num = (num + 1) >> 1; |
|
1997 | 937 |
for (; num != 0; num--) { |
0 | 938 |
*dst = ctab[*src]; |
939 |
dst++; |
|
1997 | 940 |
src += 2; |
0 | 941 |
} |
942 |
} while (!(done & 0x80)); |
|
943 |
bp->dst += bp->pitch; |
|
2004 | 944 |
if (--bp->height == 0) return; |
0 | 945 |
|
946 |
do { |
|
947 |
done = src_o[0]; |
|
948 |
src_o += (done & 0x7F) + 2; |
|
949 |
} while (!(done & 0x80)); |
|
2010 | 950 |
} while (--bp->height != 0); |
0 | 951 |
} else if (bp->mode & 2) { |
9918
a151c4749c7a
(svn r3948) - Fix: [ 1415782 ] crash in string code with openbsd/zaurus; alignment issues (thanks Tron for the help). Backport of r3529, r3553 from trunk
Darkvater
parents:
2753
diff
changeset
|
952 |
src_o += ReadLE16Aligned(src_o + bp->start_y * 2); |
0 | 953 |
do { |
954 |
do { |
|
955 |
done = src_o[0]; |
|
956 |
num = done & 0x7F; |
|
957 |
skip = src_o[1]; |
|
958 |
src_o += num + 2; |
|
959 |
||
960 |
dst = bp->dst; |
|
961 |
||
962 |
if (skip & 1) { |
|
963 |
skip++; |
|
2004 | 964 |
if (--num == 0) continue; |
0 | 965 |
} |
966 |
||
967 |
if ( (skip -= bp->start_x) > 0) { |
|
968 |
dst += skip >> 1; |
|
969 |
} else { |
|
970 |
num += skip; |
|
2010 | 971 |
if (num <= 0) continue; |
0 | 972 |
skip = 0; |
973 |
} |
|
974 |
||
975 |
skip = skip + num - bp->width; |
|
976 |
if (skip > 0) { |
|
977 |
num -= skip; |
|
2010 | 978 |
if (num <= 0) continue; |
0 | 979 |
} |
980 |
||
981 |
ctab = _color_remap_ptr; |
|
982 |
num = (num + 1) >> 1; |
|
1997 | 983 |
for (; num != 0; num--) { |
0 | 984 |
*dst = ctab[*dst]; |
985 |
dst++; |
|
986 |
} |
|
987 |
} while (!(done & 0x80)); |
|
988 |
bp->dst += bp->pitch; |
|
2004 | 989 |
if (--bp->height == 0) return; |
0 | 990 |
|
991 |
do { |
|
992 |
done = src_o[0]; |
|
993 |
src_o += (done & 0x7F) + 2; |
|
994 |
} while (!(done & 0x80)); |
|
2010 | 995 |
} while (--bp->height != 0); |
0 | 996 |
} else { |
9918
a151c4749c7a
(svn r3948) - Fix: [ 1415782 ] crash in string code with openbsd/zaurus; alignment issues (thanks Tron for the help). Backport of r3529, r3553 from trunk
Darkvater
parents:
2753
diff
changeset
|
997 |
src_o += ReadLE16Aligned(src_o + bp->start_y * 2); |
0 | 998 |
do { |
999 |
do { |
|
1000 |
done = src_o[0]; |
|
1001 |
num = done & 0x7F; |
|
1002 |
skip = src_o[1]; |
|
1003 |
src = src_o + 2; |
|
1004 |
src_o += num + 2; |
|
1005 |
||
1006 |
dst = bp->dst; |
|
1007 |
||
1008 |
if (skip & 1) { |
|
1009 |
skip++; |
|
1010 |
src++; |
|
2004 | 1011 |
if (--num == 0) continue; |
0 | 1012 |
} |
1013 |
||
1014 |
if ( (skip -= bp->start_x) > 0) { |
|
1015 |
dst += skip >> 1; |
|
1016 |
} else { |
|
1017 |
src -= skip; |
|
1018 |
num += skip; |
|
2010 | 1019 |
if (num <= 0) continue; |
0 | 1020 |
skip = 0; |
1021 |
} |
|
1022 |
||
1023 |
skip = skip + num - bp->width; |
|
1024 |
if (skip > 0) { |
|
1025 |
num -= skip; |
|
2010 | 1026 |
if (num <= 0) continue; |
0 | 1027 |
} |
1028 |
||
1029 |
num = (num + 1) >> 1; |
|
1030 |
||
1997 | 1031 |
for (; num != 0; num--) { |
0 | 1032 |
*dst = *src; |
1033 |
dst++; |
|
1997 | 1034 |
src += 2; |
0 | 1035 |
} |
1036 |
||
1037 |
} while (!(done & 0x80)); |
|
1038 |
||
1039 |
bp->dst += bp->pitch; |
|
2004 | 1040 |
if (--bp->height == 0) return; |
0 | 1041 |
|
1042 |
do { |
|
1043 |
done = src_o[0]; |
|
1044 |
src_o += (done & 0x7F) + 2; |
|
1045 |
} while (!(done & 0x80)); |
|
2010 | 1046 |
} while (--bp->height != 0); |
0 | 1047 |
} |
1048 |
} |
|
1049 |
||
1050 |
static void GfxBlitZoomMediumUncomp(BlitterParams *bp) |
|
1051 |
{ |
|
1357 | 1052 |
const byte *src = bp->sprite; |
2062 | 1053 |
Pixel *dst = bp->dst; |
0 | 1054 |
int height = bp->height; |
1055 |
int width = bp->width; |
|
1056 |
int i; |
|
1057 |
||
1058 |
assert(height > 0); |
|
1059 |
assert(width > 0); |
|
1060 |
||
1061 |
if (bp->mode & 1) { |
|
1062 |
if (bp->info & 1) { |
|
1357 | 1063 |
const byte *ctab = _color_remap_ptr; |
1064 |
||
1996 | 1065 |
for (height >>= 1; height != 0; height--) { |
1066 |
for (i = 0; i != width >> 1; i++) { |
|
1067 |
byte b = ctab[src[i * 2]]; |
|
1068 |
||
1069 |
if (b != 0) dst[i] = b; |
|
1070 |
} |
|
0 | 1071 |
src += bp->width_org * 2; |
1072 |
dst += bp->pitch; |
|
1996 | 1073 |
} |
0 | 1074 |
} |
1075 |
} else if (bp->mode & 2) { |
|
1076 |
if (bp->info & 1) { |
|
1357 | 1077 |
const byte *ctab = _color_remap_ptr; |
1078 |
||
1996 | 1079 |
for (height >>= 1; height != 0; height--) { |
1080 |
for (i = 0; i != width >> 1; i++) |
|
1081 |
if (src[i * 2] != 0) dst[i] = ctab[dst[i]]; |
|
0 | 1082 |
src += bp->width_org * 2; |
1083 |
dst += bp->pitch; |
|
1996 | 1084 |
} |
0 | 1085 |
} |
1086 |
} else { |
|
1087 |
if (bp->info & 1) { |
|
1996 | 1088 |
for (height >>= 1; height != 0; height--) { |
1089 |
for (i = 0; i != width >> 1; i++) |
|
1090 |
if (src[i * 2] != 0) dst[i] = src[i * 2]; |
|
0 | 1091 |
src += bp->width_org * 2; |
1092 |
dst += bp->pitch; |
|
1996 | 1093 |
} |
0 | 1094 |
} |
1095 |
} |
|
1096 |
} |
|
1097 |
||
1098 |
static void GfxBlitTileZoomOut(BlitterParams *bp) |
|
1099 |
{ |
|
1357 | 1100 |
const byte* src_o = bp->sprite; |
1101 |
const byte* src; |
|
0 | 1102 |
int num, skip; |
1103 |
byte done; |
|
2062 | 1104 |
Pixel *dst; |
1357 | 1105 |
const byte* ctab; |
0 | 1106 |
|
1107 |
if (bp->mode & 1) { |
|
9918
a151c4749c7a
(svn r3948) - Fix: [ 1415782 ] crash in string code with openbsd/zaurus; alignment issues (thanks Tron for the help). Backport of r3529, r3553 from trunk
Darkvater
parents:
2753
diff
changeset
|
1108 |
src_o += ReadLE16Aligned(src_o + bp->start_y * 2); |
0 | 1109 |
for(;;) { |
1110 |
do { |
|
1111 |
done = src_o[0]; |
|
1112 |
num = done & 0x7F; |
|
1113 |
skip = src_o[1]; |
|
1114 |
src = src_o + 2; |
|
1115 |
src_o += num + 2; |
|
1116 |
||
1117 |
dst = bp->dst; |
|
1118 |
||
1119 |
if (skip & 1) { |
|
1120 |
skip++; |
|
1121 |
src++; |
|
2004 | 1122 |
if (--num == 0) continue; |
0 | 1123 |
} |
1124 |
||
1125 |
if (skip & 2) { |
|
2004 | 1126 |
skip += 2; |
1127 |
src += 2; |
|
1128 |
num -= 2; |
|
1129 |
if (num <= 0) continue; |
|
0 | 1130 |
} |
1131 |
||
1132 |
if ( (skip -= bp->start_x) > 0) { |
|
1133 |
dst += skip >> 2; |
|
1134 |
} else { |
|
1135 |
src -= skip; |
|
1136 |
num += skip; |
|
2004 | 1137 |
if (num <= 0) continue; |
0 | 1138 |
skip = 0; |
1139 |
} |
|
1140 |
||
1141 |
skip = skip + num - bp->width; |
|
1142 |
if (skip > 0) { |
|
1143 |
num -= skip; |
|
2004 | 1144 |
if (num <= 0) continue; |
0 | 1145 |
} |
1146 |
||
1147 |
ctab = _color_remap_ptr; |
|
1148 |
num = (num + 3) >> 2; |
|
1997 | 1149 |
for (; num != 0; num--) { |
0 | 1150 |
*dst = ctab[*src]; |
1151 |
dst++; |
|
1997 | 1152 |
src += 4; |
0 | 1153 |
} |
1154 |
} while (!(done & 0x80)); |
|
1155 |
bp->dst += bp->pitch; |
|
2004 | 1156 |
if (--bp->height == 0) return; |
0 | 1157 |
|
1158 |
do { |
|
1159 |
done = src_o[0]; |
|
1160 |
src_o += (done & 0x7F) + 2; |
|
1161 |
} while (!(done & 0x80)); |
|
2004 | 1162 |
if (--bp->height == 0) return; |
0 | 1163 |
|
1164 |
do { |
|
1165 |
done = src_o[0]; |
|
1166 |
src_o += (done & 0x7F) + 2; |
|
1167 |
} while (!(done & 0x80)); |
|
2004 | 1168 |
if (--bp->height == 0) return; |
0 | 1169 |
|
1170 |
do { |
|
1171 |
done = src_o[0]; |
|
1172 |
src_o += (done & 0x7F) + 2; |
|
1173 |
} while (!(done & 0x80)); |
|
2004 | 1174 |
if (--bp->height == 0) return; |
0 | 1175 |
} |
1176 |
} else if (bp->mode & 2) { |
|
9918
a151c4749c7a
(svn r3948) - Fix: [ 1415782 ] crash in string code with openbsd/zaurus; alignment issues (thanks Tron for the help). Backport of r3529, r3553 from trunk
Darkvater
parents:
2753
diff
changeset
|
1177 |
src_o += ReadLE16Aligned(src_o + bp->start_y * 2); |
0 | 1178 |
for(;;) { |
1179 |
do { |
|
1180 |
done = src_o[0]; |
|
1181 |
num = done & 0x7F; |
|
1182 |
skip = src_o[1]; |
|
1183 |
src_o += num + 2; |
|
1184 |
||
1185 |
dst = bp->dst; |
|
1186 |
||
1187 |
if (skip & 1) { |
|
1188 |
skip++; |
|
2004 | 1189 |
if (--num == 0) continue; |
0 | 1190 |
} |
1191 |
||
1192 |
if (skip & 2) { |
|
2004 | 1193 |
skip += 2; |
1194 |
num -= 2; |
|
1195 |
if (num <= 0) continue; |
|
0 | 1196 |
} |
1197 |
||
1198 |
if ( (skip -= bp->start_x) > 0) { |
|
1199 |
dst += skip >> 2; |
|
1200 |
} else { |
|
1201 |
num += skip; |
|
2004 | 1202 |
if (num <= 0) continue; |
0 | 1203 |
skip = 0; |
1204 |
} |
|
1205 |
||
1206 |
skip = skip + num - bp->width; |
|
1207 |
if (skip > 0) { |
|
1208 |
num -= skip; |
|
2004 | 1209 |
if (num <= 0) continue; |
0 | 1210 |
} |
1211 |
||
1212 |
ctab = _color_remap_ptr; |
|
1213 |
num = (num + 3) >> 2; |
|
1997 | 1214 |
for (; num != 0; num--) { |
0 | 1215 |
*dst = ctab[*dst]; |
1216 |
dst++; |
|
1217 |
} |
|
1218 |
||
1219 |
} while (!(done & 0x80)); |
|
1220 |
bp->dst += bp->pitch; |
|
2004 | 1221 |
if (--bp->height == 0) return; |
0 | 1222 |
|
1223 |
do { |
|
1224 |
done = src_o[0]; |
|
1225 |
src_o += (done & 0x7F) + 2; |
|
1226 |
} while (!(done & 0x80)); |
|
2004 | 1227 |
if (--bp->height == 0) return; |
0 | 1228 |
|
1229 |
do { |
|
1230 |
done = src_o[0]; |
|
1231 |
src_o += (done & 0x7F) + 2; |
|
1232 |
} while (!(done & 0x80)); |
|
2004 | 1233 |
if (--bp->height == 0) return; |
0 | 1234 |
|
1235 |
do { |
|
1236 |
done = src_o[0]; |
|
1237 |
src_o += (done & 0x7F) + 2; |
|
1238 |
} while (!(done & 0x80)); |
|
2004 | 1239 |
if (--bp->height == 0) return; |
0 | 1240 |
} |
1241 |
} else { |
|
9918
a151c4749c7a
(svn r3948) - Fix: [ 1415782 ] crash in string code with openbsd/zaurus; alignment issues (thanks Tron for the help). Backport of r3529, r3553 from trunk
Darkvater
parents:
2753
diff
changeset
|
1242 |
src_o += ReadLE16Aligned(src_o + bp->start_y * 2); |
0 | 1243 |
for(;;) { |
1244 |
do { |
|
1245 |
done = src_o[0]; |
|
1246 |
num = done & 0x7F; |
|
1247 |
skip = src_o[1]; |
|
1248 |
src = src_o + 2; |
|
1249 |
src_o += num + 2; |
|
1250 |
||
1251 |
dst = bp->dst; |
|
1252 |
||
1253 |
if (skip & 1) { |
|
1254 |
skip++; |
|
1255 |
src++; |
|
2004 | 1256 |
if (--num == 0) continue; |
0 | 1257 |
} |
1258 |
||
1259 |
if (skip & 2) { |
|
2004 | 1260 |
skip += 2; |
1261 |
src += 2; |
|
1262 |
num -= 2; |
|
1263 |
if (num <= 0) continue; |
|
0 | 1264 |
} |
1265 |
||
1266 |
if ( (skip -= bp->start_x) > 0) { |
|
1267 |
dst += skip >> 2; |
|
1268 |
} else { |
|
1269 |
src -= skip; |
|
1270 |
num += skip; |
|
2004 | 1271 |
if (num <= 0) continue; |
0 | 1272 |
skip = 0; |
1273 |
} |
|
1274 |
||
1275 |
skip = skip + num - bp->width; |
|
1276 |
if (skip > 0) { |
|
1277 |
num -= skip; |
|
2004 | 1278 |
if (num <= 0) continue; |
0 | 1279 |
} |
1280 |
||
1281 |
num = (num + 3) >> 2; |
|
1282 |
||
1997 | 1283 |
for (; num != 0; num--) { |
0 | 1284 |
*dst = *src; |
1285 |
dst++; |
|
1997 | 1286 |
src += 4; |
0 | 1287 |
} |
1288 |
} while (!(done & 0x80)); |
|
1289 |
||
1290 |
bp->dst += bp->pitch; |
|
2004 | 1291 |
if (--bp->height == 0) return; |
0 | 1292 |
|
1293 |
do { |
|
1294 |
done = src_o[0]; |
|
1295 |
src_o += (done & 0x7F) + 2; |
|
1296 |
} while (!(done & 0x80)); |
|
2004 | 1297 |
if (--bp->height == 0) return; |
0 | 1298 |
|
1299 |
do { |
|
1300 |
done = src_o[0]; |
|
1301 |
src_o += (done & 0x7F) + 2; |
|
1302 |
} while (!(done & 0x80)); |
|
2004 | 1303 |
if (--bp->height == 0) return; |
0 | 1304 |
|
1305 |
do { |
|
1306 |
done = src_o[0]; |
|
1307 |
src_o += (done & 0x7F) + 2; |
|
1308 |
} while (!(done & 0x80)); |
|
2004 | 1309 |
if (--bp->height == 0) return; |
0 | 1310 |
} |
1311 |
} |
|
1312 |
} |
|
1313 |
||
1314 |
static void GfxBlitZoomOutUncomp(BlitterParams *bp) |
|
1315 |
{ |
|
1357 | 1316 |
const byte* src = bp->sprite; |
2062 | 1317 |
Pixel *dst = bp->dst; |
0 | 1318 |
int height = bp->height; |
1319 |
int width = bp->width; |
|
1320 |
int i; |
|
1321 |
||
1322 |
assert(height > 0); |
|
1323 |
assert(width > 0); |
|
1324 |
||
1325 |
if (bp->mode & 1) { |
|
1326 |
if (bp->info & 1) { |
|
1357 | 1327 |
const byte *ctab = _color_remap_ptr; |
1328 |
||
1996 | 1329 |
for (height >>= 2; height != 0; height--) { |
1330 |
for (i = 0; i != width >> 2; i++) { |
|
1331 |
byte b = ctab[src[i * 4]]; |
|
1332 |
||
1333 |
if (b != 0) dst[i] = b; |
|
1334 |
} |
|
0 | 1335 |
src += bp->width_org * 4; |
1336 |
dst += bp->pitch; |
|
1996 | 1337 |
} |
0 | 1338 |
} |
1339 |
} else if (bp->mode & 2) { |
|
1340 |
if (bp->info & 1) { |
|
1357 | 1341 |
const byte *ctab = _color_remap_ptr; |
1342 |
||
1996 | 1343 |
for (height >>= 2; height != 0; height--) { |
1344 |
for (i = 0; i != width >> 2; i++) |
|
1345 |
if (src[i * 4] != 0) dst[i] = ctab[dst[i]]; |
|
0 | 1346 |
src += bp->width_org * 4; |
1347 |
dst += bp->pitch; |
|
1996 | 1348 |
} |
0 | 1349 |
} |
1350 |
} else { |
|
1351 |
if (bp->info & 1) { |
|
1996 | 1352 |
for (height >>= 2; height != 0; height--) { |
1353 |
for (i = 0; i != width >> 2; i++) |
|
1354 |
if (src[i * 4] != 0) dst[i] = src[i * 4]; |
|
0 | 1355 |
src += bp->width_org * 4; |
1356 |
dst += bp->pitch; |
|
1996 | 1357 |
} |
0 | 1358 |
} |
1359 |
} |
|
1360 |
} |
|
1361 |
||
1362 |
typedef void (*BlitZoomFunc)(BlitterParams *bp); |
|
1363 |
||
1357 | 1364 |
static void GfxMainBlitter(const Sprite* sprite, int x, int y, int mode) |
0 | 1365 |
{ |
2548
97ada3bd2702
(svn r3077) static, const, bracing, indentation, 0 -> '\0'/NULL, typos in comments, excess empty lines, minor other changes
tron
parents:
2436
diff
changeset
|
1366 |
const DrawPixelInfo* dpi = _cur_dpi; |
0 | 1367 |
int start_x, start_y; |
1368 |
byte info; |
|
1369 |
BlitterParams bp; |
|
2005 | 1370 |
int zoom_mask = ~((1 << dpi->zoom) - 1); |
0 | 1371 |
|
1372 |
static const BlitZoomFunc zf_tile[3] = |
|
1373 |
{ |
|
1374 |
GfxBlitTileZoomIn, |
|
1375 |
GfxBlitTileZoomMedium, |
|
1376 |
GfxBlitTileZoomOut |
|
1377 |
}; |
|
1378 |
static const BlitZoomFunc zf_uncomp[3] = |
|
1379 |
{ |
|
1380 |
GfxBlitZoomInUncomp, |
|
1381 |
GfxBlitZoomMediumUncomp, |
|
1382 |
GfxBlitZoomOutUncomp |
|
1383 |
}; |
|
1384 |
||
1385 |
/* decode sprite header */ |
|
1351
3e7aa0d35f8f
(svn r1855) Handle endianness of sprite headers when loading a sprite, not everytime when accessing it
tron
parents:
1350
diff
changeset
|
1386 |
x += sprite->x_offs; |
3e7aa0d35f8f
(svn r1855) Handle endianness of sprite headers when loading a sprite, not everytime when accessing it
tron
parents:
1350
diff
changeset
|
1387 |
y += sprite->y_offs; |
3e7aa0d35f8f
(svn r1855) Handle endianness of sprite headers when loading a sprite, not everytime when accessing it
tron
parents:
1350
diff
changeset
|
1388 |
bp.width_org = bp.width = sprite->width; |
1348 | 1389 |
bp.height_org = bp.height = sprite->height; |
1390 |
info = sprite->info; |
|
0 | 1391 |
bp.info = info; |
1348 | 1392 |
bp.sprite_org = bp.sprite = sprite->data; |
0 | 1393 |
bp.dst = dpi->dst_ptr; |
1394 |
bp.mode = mode; |
|
1395 |
bp.pitch = dpi->pitch; |
|
1396 |
||
1397 |
assert(bp.height > 0); |
|
1398 |
assert(bp.width > 0); |
|
1399 |
||
1400 |
if (info & 8) { |
|
1401 |
/* tile blit */ |
|
1402 |
start_y = 0; |
|
1403 |
||
1404 |
if (dpi->zoom > 0) { |
|
2005 | 1405 |
start_y += bp.height & ~zoom_mask; |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
126
diff
changeset
|
1406 |
bp.height &= zoom_mask; |
0 | 1407 |
if (bp.height == 0) return; |
2005 | 1408 |
y &= zoom_mask; |
0 | 1409 |
} |
1410 |
||
1411 |
if ( (y -= dpi->top) < 0) { |
|
2005 | 1412 |
bp.height += y; |
1413 |
if (bp.height <= 0) return; |
|
0 | 1414 |
start_y -= y; |
1415 |
y = 0; |
|
1416 |
} else { |
|
2005 | 1417 |
bp.dst += bp.pitch * (y >> dpi->zoom); |
0 | 1418 |
} |
1419 |
bp.start_y = start_y; |
|
1420 |
||
1421 |
if ( (y = y + bp.height - dpi->height) > 0) { |
|
2005 | 1422 |
bp.height -= y; |
1423 |
if (bp.height <= 0) return; |
|
0 | 1424 |
} |
1425 |
||
1426 |
start_x = 0; |
|
1427 |
x &= zoom_mask; |
|
1428 |
if ( (x -= dpi->left) < 0) { |
|
2005 | 1429 |
bp.width += x; |
1430 |
if (bp.width <= 0) return; |
|
0 | 1431 |
start_x -= x; |
1432 |
x = 0; |
|
1433 |
} |
|
1434 |
bp.start_x = start_x; |
|
2005 | 1435 |
bp.dst += x >> dpi->zoom; |
0 | 1436 |
|
1437 |
if ( (x = x + bp.width - dpi->width) > 0) { |
|
2005 | 1438 |
bp.width -= x; |
1439 |
if (bp.width <= 0) return; |
|
0 | 1440 |
} |
1441 |
||
1442 |
zf_tile[dpi->zoom](&bp); |
|
1443 |
} else { |
|
1444 |
bp.sprite += bp.width * (bp.height & ~zoom_mask); |
|
1445 |
bp.height &= zoom_mask; |
|
2005 | 1446 |
if (bp.height == 0) return; |
0 | 1447 |
|
1448 |
y &= zoom_mask; |
|
1449 |
||
1450 |
if ( (y -= dpi->top) < 0) { |
|
2005 | 1451 |
bp.height += y; |
1452 |
if (bp.height <= 0) return; |
|
0 | 1453 |
bp.sprite -= bp.width * y; |
1454 |
y = 0; |
|
1455 |
} else { |
|
2005 | 1456 |
bp.dst += bp.pitch * (y >> dpi->zoom); |
0 | 1457 |
} |
1458 |
||
2037
380e80aed97a
(svn r2546) Don't calculate a value which never gets used and simplify some calculations
tron
parents:
2025
diff
changeset
|
1459 |
if (bp.height > dpi->height - y) { |
380e80aed97a
(svn r2546) Don't calculate a value which never gets used and simplify some calculations
tron
parents:
2025
diff
changeset
|
1460 |
bp.height = dpi->height - y; |
2005 | 1461 |
if (bp.height <= 0) return; |
0 | 1462 |
} |
1463 |
||
1464 |
x &= zoom_mask; |
|
1465 |
||
1466 |
if ( (x -= dpi->left) < 0) { |
|
2005 | 1467 |
bp.width += x; |
1468 |
if (bp.width <= 0) return; |
|
0 | 1469 |
bp.sprite -= x; |
1470 |
x = 0; |
|
1471 |
} |
|
2005 | 1472 |
bp.dst += x >> dpi->zoom; |
0 | 1473 |
|
2037
380e80aed97a
(svn r2546) Don't calculate a value which never gets used and simplify some calculations
tron
parents:
2025
diff
changeset
|
1474 |
if (bp.width > dpi->width - x) { |
380e80aed97a
(svn r2546) Don't calculate a value which never gets used and simplify some calculations
tron
parents:
2025
diff
changeset
|
1475 |
bp.width = dpi->width - x; |
2005 | 1476 |
if (bp.width <= 0) return; |
0 | 1477 |
} |
1478 |
||
1479 |
zf_uncomp[dpi->zoom](&bp); |
|
1480 |
} |
|
1481 |
} |
|
1482 |
||
1093
e8d26c7dc42f
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1056
diff
changeset
|
1483 |
void DoPaletteAnimations(void); |
614
e016770cb781
(svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents:
543
diff
changeset
|
1484 |
|
1093
e8d26c7dc42f
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1056
diff
changeset
|
1485 |
void GfxInitPalettes(void) |
0 | 1486 |
{ |
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1487 |
memcpy(_cur_palette, _palettes[_use_dos_palette ? 1 : 0], sizeof(_cur_palette)); |
614
e016770cb781
(svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents:
543
diff
changeset
|
1488 |
|
0 | 1489 |
_pal_first_dirty = 0; |
1490 |
_pal_last_dirty = 255; |
|
614
e016770cb781
(svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents:
543
diff
changeset
|
1491 |
DoPaletteAnimations(); |
0 | 1492 |
} |
1493 |
||
2010 | 1494 |
#define EXTR(p, q) (((uint16)(_timer_counter * (p)) * (q)) >> 16) |
1495 |
#define EXTR2(p, q) (((uint16)(~_timer_counter * (p)) * (q)) >> 16) |
|
0 | 1496 |
|
1093
e8d26c7dc42f
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1056
diff
changeset
|
1497 |
void DoPaletteAnimations(void) |
0 | 1498 |
{ |
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1499 |
const Colour* s; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1500 |
Colour* d; |
614
e016770cb781
(svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents:
543
diff
changeset
|
1501 |
/* Amount of colors to be rotated. |
e016770cb781
(svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents:
543
diff
changeset
|
1502 |
* A few more for the DOS palette, because the water colors are |
e016770cb781
(svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents:
543
diff
changeset
|
1503 |
* 245-254 for DOS and 217-226 for Windows. */ |
0 | 1504 |
const ExtraPaletteValues *ev = &_extra_palette_values; |
2005 | 1505 |
int c = _use_dos_palette ? 38 : 28; |
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1506 |
Colour old_val[38]; // max(38, 28) |
2005 | 1507 |
uint i; |
1508 |
uint j; |
|
0 | 1509 |
|
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1510 |
d = &_cur_palette[217]; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1511 |
memcpy(old_val, d, c * sizeof(*old_val)); |
0 | 1512 |
|
1513 |
// Dark blue water |
|
2005 | 1514 |
s = (_opt.landscape == LT_CANDY) ? ev->ac : ev->a; |
1515 |
j = EXTR(320, 5); |
|
1516 |
for (i = 0; i != 5; i++) { |
|
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1517 |
*d++ = s[j]; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1518 |
j++; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1519 |
if (j == 5) j = 0; |
0 | 1520 |
} |
1521 |
||
1522 |
// Glittery water |
|
2005 | 1523 |
s = (_opt.landscape == LT_CANDY) ? ev->bc : ev->b; |
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1524 |
j = EXTR(128, 15); |
2005 | 1525 |
for (i = 0; i != 5; i++) { |
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1526 |
*d++ = s[j]; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1527 |
j += 3; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1528 |
if (j >= 15) j -= 15; |
0 | 1529 |
} |
1530 |
||
1531 |
s = ev->e; |
|
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1532 |
j = EXTR2(512, 5); |
2005 | 1533 |
for (i = 0; i != 5; i++) { |
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1534 |
*d++ = s[j]; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1535 |
j++; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1536 |
if (j == 5) j = 0; |
0 | 1537 |
} |
1538 |
||
1539 |
// Oil refinery fire animation |
|
1540 |
s = ev->oil_ref; |
|
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1541 |
j = EXTR2(512, 7); |
2005 | 1542 |
for (i = 0; i != 7; i++) { |
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1543 |
*d++ = s[j]; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1544 |
j++; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1545 |
if (j == 7) j = 0; |
0 | 1546 |
} |
1547 |
||
1548 |
// Radio tower blinking |
|
1549 |
{ |
|
2005 | 1550 |
byte i = (_timer_counter >> 1) & 0x7F; |
1551 |
byte v; |
|
1552 |
||
0 | 1553 |
(v = 255, i < 0x3f) || |
1554 |
(v = 128, i < 0x4A || i >= 0x75) || |
|
1555 |
(v = 20); |
|
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1556 |
d->r = v; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1557 |
d->g = 0; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1558 |
d->b = 0; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1559 |
d++; |
0 | 1560 |
|
1561 |
i ^= 0x40; |
|
1562 |
(v = 255, i < 0x3f) || |
|
1563 |
(v = 128, i < 0x4A || i >= 0x75) || |
|
1564 |
(v = 20); |
|
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1565 |
d->r = v; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1566 |
d->g = 0; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1567 |
d->b = 0; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1568 |
d++; |
0 | 1569 |
} |
1570 |
||
1571 |
// Handle lighthouse and stadium animation |
|
1572 |
s = ev->lighthouse; |
|
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1573 |
j = EXTR(256, 4); |
2005 | 1574 |
for (i = 0; i != 4; i++) { |
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1575 |
*d++ = s[j]; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1576 |
j++; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1577 |
if (j == 4) j = 0; |
0 | 1578 |
} |
1579 |
||
614
e016770cb781
(svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents:
543
diff
changeset
|
1580 |
// Animate water for old DOS graphics |
2005 | 1581 |
if (_use_dos_palette) { |
614
e016770cb781
(svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents:
543
diff
changeset
|
1582 |
// Dark blue water DOS |
2005 | 1583 |
s = (_opt.landscape == LT_CANDY) ? ev->ac : ev->a; |
1584 |
j = EXTR(320, 5); |
|
1585 |
for (i = 0; i != 5; i++) { |
|
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1586 |
*d++ = s[j]; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1587 |
j++; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1588 |
if (j == 5) j = 0; |
614
e016770cb781
(svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents:
543
diff
changeset
|
1589 |
} |
915 | 1590 |
|
614
e016770cb781
(svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents:
543
diff
changeset
|
1591 |
// Glittery water DOS |
2005 | 1592 |
s = (_opt.landscape == LT_CANDY) ? ev->bc : ev->b; |
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1593 |
j = EXTR(128, 15); |
2005 | 1594 |
for (i = 0; i != 5; i++) { |
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1595 |
*d++ = s[j]; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1596 |
j += 3; |
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1597 |
if (j >= 15) j -= 15; |
614
e016770cb781
(svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents:
543
diff
changeset
|
1598 |
} |
e016770cb781
(svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents:
543
diff
changeset
|
1599 |
} |
e016770cb781
(svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents:
543
diff
changeset
|
1600 |
|
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1601 |
if (memcmp(old_val, &_cur_palette[217], c * sizeof(*old_val)) != 0) { |
0 | 1602 |
if (_pal_first_dirty > 217) _pal_first_dirty = 217; |
1991
f3d5e35731a2
(svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents:
1914
diff
changeset
|
1603 |
if (_pal_last_dirty < 217 + c) _pal_last_dirty = 217 + c; |
0 | 1604 |
} |
1605 |
} |
|
1606 |
||
1607 |
||
1093
e8d26c7dc42f
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1056
diff
changeset
|
1608 |
void LoadStringWidthTable(void) |
0 | 1609 |
{ |
2005 | 1610 |
byte *b = _stringwidth_table; |
1611 |
uint i; |
|
0 | 1612 |
|
1613 |
// 2 equals space. |
|
2005 | 1614 |
for (i = 2; i != 226; i++) { |
2411 | 1615 |
*b++ = i != 97 && (i < 99 || i > 113) && i != 116 && i != 117 && (i < 123 || i > 129) && (i < 151 || i > 153) && i != 155 ? GetSprite(i)->width : 0; |
0 | 1616 |
} |
1617 |
||
2005 | 1618 |
for (i = 226; i != 450; i++) { |
2411 | 1619 |
*b++ = i != 321 && (i < 323 || i > 353) && i != 367 && (i < 375 || i > 377) && i != 379 ? GetSprite(i)->width + 1 : 0; |
0 | 1620 |
} |
1621 |
||
2005 | 1622 |
for (i = 450; i != 674; i++) { |
9939
c4797077028a
(svn r3970) - FS#56 - [Crash] Missing glyph(s) in big-font. Added several missing glyphs for the big font. Backport of r3940 from trunk
Darkvater
parents:
9918
diff
changeset
|
1623 |
*b++ = (i < 545 || i > 577) && i != 588 && i != 590 && i != 591 && i != 593 && (i < 599 || i > 601) && i != 603 ? GetSprite(i)->width + 1 : 0; |
0 | 1624 |
} |
1625 |
} |
|
1626 |
||
1093
e8d26c7dc42f
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1056
diff
changeset
|
1627 |
void ScreenSizeChanged(void) |
0 | 1628 |
{ |
1629 |
// check the dirty rect |
|
1630 |
if (_invalid_rect.right >= _screen.width) _invalid_rect.right = _screen.width; |
|
1631 |
if (_invalid_rect.bottom >= _screen.height) _invalid_rect.bottom = _screen.height; |
|
1632 |
||
1633 |
// screen size changed and the old bitmap is invalid now, so we don't want to undraw it |
|
1634 |
_cursor.visible = false; |
|
1635 |
} |
|
1636 |
||
1093
e8d26c7dc42f
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1056
diff
changeset
|
1637 |
void UndrawMouseCursor(void) |
0 | 1638 |
{ |
1639 |
if (_cursor.visible) { |
|
1640 |
_cursor.visible = false; |
|
1641 |
memcpy_pitch( |
|
1642 |
_screen.dst_ptr + _cursor.draw_pos.x + _cursor.draw_pos.y * _screen.pitch, |
|
1643 |
_cursor_backup, |
|
1644 |
_cursor.draw_size.x, _cursor.draw_size.y, _cursor.draw_size.x, _screen.pitch); |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
126
diff
changeset
|
1645 |
|
0 | 1646 |
_video_driver->make_dirty(_cursor.draw_pos.x, _cursor.draw_pos.y, _cursor.draw_size.x, _cursor.draw_size.y); |
1647 |
} |
|
1648 |
} |
|
1649 |
||
1093
e8d26c7dc42f
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1056
diff
changeset
|
1650 |
void DrawMouseCursor(void) |
0 | 1651 |
{ |
2010 | 1652 |
int x; |
1653 |
int y; |
|
1654 |
int w; |
|
1655 |
int h; |
|
0 | 1656 |
|
1657 |
// Don't draw the mouse cursor if it's already drawn |
|
1658 |
if (_cursor.visible) { |
|
2010 | 1659 |
if (!_cursor.dirty) return; |
0 | 1660 |
UndrawMouseCursor(); |
1661 |
} |
|
1662 |
||
1663 |
w = _cursor.size.x; |
|
1664 |
x = _cursor.pos.x + _cursor.offs.x; |
|
2010 | 1665 |
if (x < 0) { |
1666 |
w += x; |
|
1667 |
x = 0; |
|
1668 |
} |
|
1669 |
if (w > _screen.width - x) w = _screen.width - x; |
|
0 | 1670 |
if (w <= 0) return; |
1671 |
_cursor.draw_pos.x = x; |
|
1672 |
_cursor.draw_size.x = w; |
|
1673 |
||
1674 |
h = _cursor.size.y; |
|
1675 |
y = _cursor.pos.y + _cursor.offs.y; |
|
2010 | 1676 |
if (y < 0) { |
1677 |
h += y; |
|
1678 |
y = 0; |
|
1679 |
} |
|
1680 |
if (h > _screen.height - y) h = _screen.height - y; |
|
0 | 1681 |
if (h <= 0) return; |
1682 |
_cursor.draw_pos.y = y; |
|
1683 |
_cursor.draw_size.y = h; |
|
1684 |
||
2010 | 1685 |
assert(w * h < (int)sizeof(_cursor_backup)); |
0 | 1686 |
|
1687 |
// Make backup of stuff below cursor |
|
1688 |
memcpy_pitch( |
|
1689 |
_cursor_backup, |
|
1690 |
_screen.dst_ptr + _cursor.draw_pos.x + _cursor.draw_pos.y * _screen.pitch, |
|
306
c44133836566
(svn r312) -Fix: [926105] ctrl + d bug. Longest outstanding bug has been fixed \o/ 2004-03-30 (Tron)
darkvater
parents:
298
diff
changeset
|
1691 |
_cursor.draw_size.x, _cursor.draw_size.y, _screen.pitch, _cursor.draw_size.x); |
0 | 1692 |
|
1693 |
// Draw cursor on screen |
|
1694 |
_cur_dpi = &_screen; |
|
1695 |
DrawSprite(_cursor.sprite, _cursor.pos.x, _cursor.pos.y); |
|
1696 |
||
1697 |
_video_driver->make_dirty(_cursor.draw_pos.x, _cursor.draw_pos.y, _cursor.draw_size.x, _cursor.draw_size.y); |
|
1698 |
||
1699 |
_cursor.visible = true; |
|
1700 |
_cursor.dirty = false; |
|
1701 |
} |
|
1702 |
||
798 | 1703 |
#if defined(_DEBUG) |
410 | 1704 |
static void DbgScreenRect(int left, int top, int right, int bottom) |
0 | 1705 |
{ |
2010 | 1706 |
DrawPixelInfo dp; |
1707 |
DrawPixelInfo* old; |
|
0 | 1708 |
|
1709 |
old = _cur_dpi; |
|
1710 |
_cur_dpi = &dp; |
|
1711 |
dp = _screen; |
|
2010 | 1712 |
GfxFillRect(left, top, right - 1, bottom - 1, rand() & 255); |
0 | 1713 |
_cur_dpi = old; |
1714 |
} |
|
798 | 1715 |
#endif |
0 | 1716 |
|
1717 |
void RedrawScreenRect(int left, int top, int right, int bottom) |
|
1718 |
{ |
|
1719 |
assert(right <= _screen.width && bottom <= _screen.height); |
|
1720 |
if (_cursor.visible) { |
|
1721 |
if (right > _cursor.draw_pos.x && |
|
1722 |
left < _cursor.draw_pos.x + _cursor.draw_size.x && |
|
1723 |
bottom > _cursor.draw_pos.y && |
|
1724 |
top < _cursor.draw_pos.y + _cursor.draw_size.y) { |
|
1725 |
UndrawMouseCursor(); |
|
1726 |
} |
|
1727 |
} |
|
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
510
diff
changeset
|
1728 |
UndrawTextMessage(); |
0 | 1729 |
|
1730 |
#if defined(_DEBUG) |
|
1731 |
if (_dbg_screen_rect) |
|
1732 |
DbgScreenRect(left, top, right, bottom); |
|
1733 |
else |
|
1734 |
#endif |
|
1735 |
DrawOverlappedWindowForAll(left, top, right, bottom); |
|
1736 |
||
2010 | 1737 |
_video_driver->make_dirty(left, top, right - left, bottom - top); |
0 | 1738 |
} |
1739 |
||
1093
e8d26c7dc42f
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1056
diff
changeset
|
1740 |
void DrawDirtyBlocks(void) |
0 | 1741 |
{ |
1742 |
byte *b = _dirty_blocks; |
|
2398
70de6626d65f
(svn r2924) Introduce the ALIGN() macro which aligns values to multiples of a power of 2, for exact semantics see the commment in macros.h
tron
parents:
2367
diff
changeset
|
1743 |
const int w = ALIGN(_screen.width, 64); |
70de6626d65f
(svn r2924) Introduce the ALIGN() macro which aligns values to multiples of a power of 2, for exact semantics see the commment in macros.h
tron
parents:
2367
diff
changeset
|
1744 |
const int h = ALIGN(_screen.height, 8); |
2025 | 1745 |
int x; |
1746 |
int y; |
|
0 | 1747 |
|
2025 | 1748 |
y = 0; |
0 | 1749 |
do { |
2025 | 1750 |
x = 0; |
1751 |
do { |
|
1752 |
if (*b != 0) { |
|
1753 |
int left; |
|
1754 |
int top; |
|
1755 |
int right = x + 64; |
|
1756 |
int bottom = y; |
|
1757 |
byte *p = b; |
|
1758 |
int h2; |
|
0 | 1759 |
|
2025 | 1760 |
// First try coalescing downwards |
0 | 1761 |
do { |
2025 | 1762 |
*p = 0; |
1763 |
p += DIRTY_BYTES_PER_LINE; |
|
1764 |
bottom += 8; |
|
1765 |
} while (bottom != h && *p != 0); |
|
0 | 1766 |
|
2025 | 1767 |
// Try coalescing to the right too. |
1768 |
h2 = (bottom - y) >> 3; |
|
1769 |
assert(h2 > 0); |
|
1770 |
p = b; |
|
0 | 1771 |
|
2025 | 1772 |
while (right != w) { |
1773 |
byte *p2 = ++p; |
|
1774 |
int h = h2; |
|
1775 |
// Check if a full line of dirty flags is set. |
|
1776 |
do { |
|
1777 |
if (!*p2) goto no_more_coalesc; |
|
1778 |
p2 += DIRTY_BYTES_PER_LINE; |
|
1779 |
} while (--h != 0); |
|
1780 |
||
1781 |
// Wohoo, can combine it one step to the right! |
|
1782 |
// Do that, and clear the bits. |
|
1783 |
right += 64; |
|
1784 |
||
1785 |
h = h2; |
|
1786 |
p2 = p; |
|
1787 |
do { |
|
1788 |
*p2 = 0; |
|
1789 |
p2 += DIRTY_BYTES_PER_LINE; |
|
1790 |
} while (--h != 0); |
|
1791 |
} |
|
1792 |
no_more_coalesc: |
|
1793 |
||
1794 |
left = x; |
|
1795 |
top = y; |
|
1796 |
||
1797 |
if (left < _invalid_rect.left ) left = _invalid_rect.left; |
|
1798 |
if (top < _invalid_rect.top ) top = _invalid_rect.top; |
|
1799 |
if (right > _invalid_rect.right ) right = _invalid_rect.right; |
|
1800 |
if (bottom > _invalid_rect.bottom) bottom = _invalid_rect.bottom; |
|
1801 |
||
1802 |
if (left < right && top < bottom) { |
|
1803 |
RedrawScreenRect(left, top, right, bottom); |
|
1804 |
} |
|
1805 |
||
0 | 1806 |
} |
2025 | 1807 |
} while (b++, (x += 64) != w); |
1808 |
} while (b += -(w >> 6) + DIRTY_BYTES_PER_LINE, (y += 8) != h); |
|
0 | 1809 |
|
1810 |
_invalid_rect.left = w; |
|
1811 |
_invalid_rect.top = h; |
|
1812 |
_invalid_rect.right = 0; |
|
1813 |
_invalid_rect.bottom = 0; |
|
1814 |
} |
|
1815 |
||
1816 |
||
1817 |
void SetDirtyBlocks(int left, int top, int right, int bottom) |
|
1818 |
{ |
|
1819 |
byte *b; |
|
2010 | 1820 |
int width; |
1821 |
int height; |
|
0 | 1822 |
|
1823 |
if (left < 0) left = 0; |
|
1824 |
if (top < 0) top = 0; |
|
1825 |
if (right > _screen.width) right = _screen.width; |
|
1826 |
if (bottom > _screen.height) bottom = _screen.height; |
|
1827 |
||
2010 | 1828 |
if (left >= right || top >= bottom) return; |
0 | 1829 |
|
2010 | 1830 |
if (left < _invalid_rect.left ) _invalid_rect.left = left; |
1831 |
if (top < _invalid_rect.top ) _invalid_rect.top = top; |
|
1832 |
if (right > _invalid_rect.right ) _invalid_rect.right = right; |
|
1833 |
if (bottom > _invalid_rect.bottom) _invalid_rect.bottom = bottom; |
|
0 | 1834 |
|
1835 |
left >>= 6; |
|
2010 | 1836 |
top >>= 3; |
0 | 1837 |
|
1838 |
b = _dirty_blocks + top * DIRTY_BYTES_PER_LINE + left; |
|
1839 |
||
2010 | 1840 |
width = ((right - 1) >> 6) - left + 1; |
1841 |
height = ((bottom - 1) >> 3) - top + 1; |
|
0 | 1842 |
|
1843 |
assert(width > 0 && height > 0); |
|
1844 |
||
1845 |
do { |
|
2010 | 1846 |
int i = width; |
1847 |
||
0 | 1848 |
do b[--i] = 0xFF; while (i); |
1849 |
||
1850 |
b += DIRTY_BYTES_PER_LINE; |
|
2010 | 1851 |
} while (--height != 0); |
0 | 1852 |
} |
1853 |
||
1093
e8d26c7dc42f
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1056
diff
changeset
|
1854 |
void MarkWholeScreenDirty(void) |
0 | 1855 |
{ |
1856 |
SetDirtyBlocks(0, 0, _screen.width, _screen.height); |
|
1857 |
} |
|
1858 |
||
2548
97ada3bd2702
(svn r3077) static, const, bracing, indentation, 0 -> '\0'/NULL, typos in comments, excess empty lines, minor other changes
tron
parents:
2436
diff
changeset
|
1859 |
bool FillDrawPixelInfo(DrawPixelInfo* n, const DrawPixelInfo* o, int left, int top, int width, int height) |
0 | 1860 |
{ |
1861 |
int t; |
|
1862 |
||
2010 | 1863 |
if (o == NULL) o = _cur_dpi; |
0 | 1864 |
|
1865 |
n->zoom = 0; |
|
1866 |
||
1867 |
assert(width > 0); |
|
1868 |
assert(height > 0); |
|
1869 |
||
1870 |
n->left = 0; |
|
1871 |
if ((left -= o->left) < 0) { |
|
2010 | 1872 |
width += left; |
1873 |
if (width < 0) return false; |
|
0 | 1874 |
n->left = -left; |
1875 |
left = 0; |
|
1876 |
} |
|
1877 |
||
1878 |
if ((t=width + left - o->width) > 0) { |
|
2010 | 1879 |
width -= t; |
1880 |
if (width < 0) return false; |
|
0 | 1881 |
} |
1882 |
n->width = width; |
|
1883 |
||
1884 |
n->top = 0; |
|
1885 |
if ((top -= o->top) < 0) { |
|
2010 | 1886 |
height += top; |
1887 |
if (height < 0) return false; |
|
0 | 1888 |
n->top = -top; |
1889 |
top = 0; |
|
1890 |
} |
|
1891 |
||
1892 |
n->dst_ptr = o->dst_ptr + left + top * (n->pitch = o->pitch); |
|
1893 |
||
1894 |
if ((t=height + top - o->height) > 0) { |
|
2010 | 1895 |
height -= t; |
1896 |
if (height < 0) return false; |
|
0 | 1897 |
} |
1898 |
n->height = height; |
|
1899 |
||
1900 |
return true; |
|
1901 |
} |
|
1902 |
||
1914
5ede46fd496f
(svn r2420) - Codechange: magic number elminitation of cursorsprites.
Darkvater
parents:
1891
diff
changeset
|
1903 |
static void SetCursorSprite(CursorID cursor) |
0 | 1904 |
{ |
1905 |
CursorVars *cv = &_cursor; |
|
1348 | 1906 |
const Sprite *p; |
0 | 1907 |
|
2010 | 1908 |
if (cv->sprite == cursor) return; |
0 | 1909 |
|
2187
2a51f8925eeb
(svn r2702) -Codechange: Cleaned up the sprite code and replaced many magic numbers
celestar
parents:
2186
diff
changeset
|
1910 |
p = GetSprite(cursor & SPRITE_MASK); |
0 | 1911 |
cv->sprite = cursor; |
1348 | 1912 |
cv->size.y = p->height; |
1351
3e7aa0d35f8f
(svn r1855) Handle endianness of sprite headers when loading a sprite, not everytime when accessing it
tron
parents:
1350
diff
changeset
|
1913 |
cv->size.x = p->width; |
3e7aa0d35f8f
(svn r1855) Handle endianness of sprite headers when loading a sprite, not everytime when accessing it
tron
parents:
1350
diff
changeset
|
1914 |
cv->offs.x = p->x_offs; |
3e7aa0d35f8f
(svn r1855) Handle endianness of sprite headers when loading a sprite, not everytime when accessing it
tron
parents:
1350
diff
changeset
|
1915 |
cv->offs.y = p->y_offs; |
0 | 1916 |
|
1917 |
cv->dirty = true; |
|
1918 |
} |
|
1919 |
||
1093
e8d26c7dc42f
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1056
diff
changeset
|
1920 |
static void SwitchAnimatedCursor(void) |
0 | 1921 |
{ |
1922 |
CursorVars *cv = &_cursor; |
|
1914
5ede46fd496f
(svn r2420) - Codechange: magic number elminitation of cursorsprites.
Darkvater
parents:
1891
diff
changeset
|
1923 |
const CursorID *cur = cv->animate_cur; |
5ede46fd496f
(svn r2420) - Codechange: magic number elminitation of cursorsprites.
Darkvater
parents:
1891
diff
changeset
|
1924 |
CursorID sprite; |
0 | 1925 |
|
1914
5ede46fd496f
(svn r2420) - Codechange: magic number elminitation of cursorsprites.
Darkvater
parents:
1891
diff
changeset
|
1926 |
// ANIM_CURSOR_END is 0xFFFF in table/animcursors.h |
5ede46fd496f
(svn r2420) - Codechange: magic number elminitation of cursorsprites.
Darkvater
parents:
1891
diff
changeset
|
1927 |
if (cur == NULL || *cur == 0xFFFF) cur = cv->animate_list; |
5ede46fd496f
(svn r2420) - Codechange: magic number elminitation of cursorsprites.
Darkvater
parents:
1891
diff
changeset
|
1928 |
|
0 | 1929 |
sprite = cur[0]; |
1930 |
cv->animate_timeout = cur[1]; |
|
1931 |
cv->animate_cur = cur + 2; |
|
1932 |
||
1933 |
SetCursorSprite(sprite); |
|
1934 |
} |
|
1935 |
||
1093
e8d26c7dc42f
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1056
diff
changeset
|
1936 |
void CursorTick(void) |
e8d26c7dc42f
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1056
diff
changeset
|
1937 |
{ |
2010 | 1938 |
if (_cursor.animate_timeout != 0 && --_cursor.animate_timeout == 0) |
0 | 1939 |
SwitchAnimatedCursor(); |
1940 |
} |
|
1941 |
||
1914
5ede46fd496f
(svn r2420) - Codechange: magic number elminitation of cursorsprites.
Darkvater
parents:
1891
diff
changeset
|
1942 |
void SetMouseCursor(CursorID cursor) |
0 | 1943 |
{ |
1944 |
// Turn off animation |
|
1945 |
_cursor.animate_timeout = 0; |
|
1946 |
// Set cursor |
|
1947 |
SetCursorSprite(cursor); |
|
1948 |
} |
|
1949 |
||
1914
5ede46fd496f
(svn r2420) - Codechange: magic number elminitation of cursorsprites.
Darkvater
parents:
1891
diff
changeset
|
1950 |
void SetAnimatedMouseCursor(const CursorID *table) |
0 | 1951 |
{ |
1952 |
_cursor.animate_list = table; |
|
1953 |
_cursor.animate_cur = NULL; |
|
1954 |
SwitchAnimatedCursor(); |
|
1955 |
} |
|
1956 |
||
1957 |
bool ChangeResInGame(int w, int h) |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
126
diff
changeset
|
1958 |
{ |
2645
964bd8fe3ce2
(svn r3187) Simplify overly complicated ifs, especially if (foo) return false; else return true; is confusing
tron
parents:
2639
diff
changeset
|
1959 |
return |
964bd8fe3ce2
(svn r3187) Simplify overly complicated ifs, especially if (foo) return false; else return true; is confusing
tron
parents:
2639
diff
changeset
|
1960 |
(_screen.width == w && _screen.height == h) || |
964bd8fe3ce2
(svn r3187) Simplify overly complicated ifs, especially if (foo) return false; else return true; is confusing
tron
parents:
2639
diff
changeset
|
1961 |
_video_driver->change_resolution(w, h); |
0 | 1962 |
} |
298
b3e83b94be19
(svn r304) -Fix: [967096] fullscreen. New button 'Fullscreen' in 'Game Options' menu which lets you set fullscreen ingame.
darkvater
parents:
193
diff
changeset
|
1963 |
|
1829
0b6de3b4458a
(svn r2334) - Fix (regression): moved togglefullscreen into the video-driver, now windows works, dedicated works and sdl works. Also reverted the change to the makefile.
Darkvater
parents:
1806
diff
changeset
|
1964 |
void ToggleFullScreen(bool fs) {_video_driver->toggle_fullscreen(fs);} |
0b6de3b4458a
(svn r2334) - Fix (regression): moved togglefullscreen into the video-driver, now windows works, dedicated works and sdl works. Also reverted the change to the makefile.
Darkvater
parents:
1806
diff
changeset
|
1965 |
|
1806
75dc9c737892
(svn r2310) - Fix: Game would crash if you full-screened with the 'fullscreen' button than chose a resolution from the dropdown box that was no longer valid. Big thanks to DaleStan for track down the crashing bug.
Darkvater
parents:
1390
diff
changeset
|
1966 |
static int CDECL compare_res(const void *pa, const void *pb) |
298
b3e83b94be19
(svn r304) -Fix: [967096] fullscreen. New button 'Fullscreen' in 'Game Options' menu which lets you set fullscreen ingame.
darkvater
parents:
193
diff
changeset
|
1967 |
{ |
1806
75dc9c737892
(svn r2310) - Fix: Game would crash if you full-screened with the 'fullscreen' button than chose a resolution from the dropdown box that was no longer valid. Big thanks to DaleStan for track down the crashing bug.
Darkvater
parents:
1390
diff
changeset
|
1968 |
int x = ((const uint16*)pa)[0] - ((const uint16*)pb)[0]; |
75dc9c737892
(svn r2310) - Fix: Game would crash if you full-screened with the 'fullscreen' button than chose a resolution from the dropdown box that was no longer valid. Big thanks to DaleStan for track down the crashing bug.
Darkvater
parents:
1390
diff
changeset
|
1969 |
if (x != 0) return x; |
75dc9c737892
(svn r2310) - Fix: Game would crash if you full-screened with the 'fullscreen' button than chose a resolution from the dropdown box that was no longer valid. Big thanks to DaleStan for track down the crashing bug.
Darkvater
parents:
1390
diff
changeset
|
1970 |
return ((const uint16*)pa)[1] - ((const uint16*)pb)[1]; |
75dc9c737892
(svn r2310) - Fix: Game would crash if you full-screened with the 'fullscreen' button than chose a resolution from the dropdown box that was no longer valid. Big thanks to DaleStan for track down the crashing bug.
Darkvater
parents:
1390
diff
changeset
|
1971 |
} |
75dc9c737892
(svn r2310) - Fix: Game would crash if you full-screened with the 'fullscreen' button than chose a resolution from the dropdown box that was no longer valid. Big thanks to DaleStan for track down the crashing bug.
Darkvater
parents:
1390
diff
changeset
|
1972 |
|
75dc9c737892
(svn r2310) - Fix: Game would crash if you full-screened with the 'fullscreen' button than chose a resolution from the dropdown box that was no longer valid. Big thanks to DaleStan for track down the crashing bug.
Darkvater
parents:
1390
diff
changeset
|
1973 |
void SortResolutions(int count) |
75dc9c737892
(svn r2310) - Fix: Game would crash if you full-screened with the 'fullscreen' button than chose a resolution from the dropdown box that was no longer valid. Big thanks to DaleStan for track down the crashing bug.
Darkvater
parents:
1390
diff
changeset
|
1974 |
{ |
75dc9c737892
(svn r2310) - Fix: Game would crash if you full-screened with the 'fullscreen' button than chose a resolution from the dropdown box that was no longer valid. Big thanks to DaleStan for track down the crashing bug.
Darkvater
parents:
1390
diff
changeset
|
1975 |
qsort(_resolutions, count, sizeof(_resolutions[0]), compare_res); |
298
b3e83b94be19
(svn r304) -Fix: [967096] fullscreen. New button 'Fullscreen' in 'Game Options' menu which lets you set fullscreen ingame.
darkvater
parents:
193
diff
changeset
|
1976 |
} |
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
510
diff
changeset
|
1977 |
|
2436
177cb6a8339f
(svn r2962) - const correctness for all Get* functions and most Draw* functions that don't change their pointer parameters
Darkvater
parents:
2429
diff
changeset
|
1978 |
uint16 GetDrawStringPlayerColor(PlayerID player) |
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
510
diff
changeset
|
1979 |
{ |
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
510
diff
changeset
|
1980 |
// Get the color for DrawString-subroutines which matches the color |
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
510
diff
changeset
|
1981 |
// of the player |
2639 | 1982 |
if (player == OWNER_SPECTATOR || player == OWNER_SPECTATOR - 1) return 1; |
657
40a9032b454b
(svn r1091) Fix: Finally station names use 100% the correct color in transparent mode
dominik
parents:
619
diff
changeset
|
1983 |
return (_color_list[_player_colors[player]].window_color_1b) | IS_PALETTE_COLOR; |
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
510
diff
changeset
|
1984 |
} |