src/gfx.cpp
author rubidium
Thu, 01 Feb 2007 15:49:12 +0000
changeset 5893 7e431a4abebb
parent 5668 36b39f4a9032
child 6138 f1196498ef66
permissions -rw-r--r--
(svn r8511) -Codechange: make WindowClass an enumerated value.
2186
db48cf29b983 (svn r2701) Insert Id tags into all source files
tron
parents: 2163
diff changeset
     1
/* $Id$ */
db48cf29b983 (svn r2701) Insert Id tags into all source files
tron
parents: 2163
diff changeset
     2
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
     3
#include "stdafx.h"
1891
862800791170 (svn r2397) - CodeChange: rename all "ttd" files to "openttd" files.
Darkvater
parents: 1829
diff changeset
     4
#include "openttd.h"
2163
b17b313113a0 (svn r2673) Include functions.h directly, not globally via openttd.h
tron
parents: 2154
diff changeset
     5
#include "functions.h"
4428
6d9fab57f2af (svn r6183) Move GetDrawStringPlayerColor() out of gfx.[ch]
tron
parents: 4425
diff changeset
     6
#include "macros.h"
1349
15979a2e9001 (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
4403a69da4f8 (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
e95d19e1941f (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
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    10
#include "gfx.h"
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    11
#include "table/palettes.h"
2187
a0e206ce9fbf (svn r2702) -Codechange: Cleaned up the sprite code and replaced many magic numbers
celestar
parents: 2186
diff changeset
    12
#include "table/sprites.h"
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    13
#include "hal.h"
2153
ecfc674410b4 (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"
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
    15
#include "table/control_codes.h"
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
    16
#include "fontcache.h"
4300
c7e43c47a2b9 (svn r5946) -Add: merged the TGP branch to mainline. TGP adds:
truelight
parents: 4171
diff changeset
    17
#include "genworld.h"
5217
7a9e91919a93 (svn r7332) -Fix: segmentation fault, discovered by ln-, in the SDL video driver when one goes to fullscreen and there are no suitable resolutions.
rubidium
parents: 5156
diff changeset
    18
#include "debug.h"
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    19
2649
1392cd1a60cc (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
    20
#ifdef _DEBUG
1392cd1a60cc (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
    21
bool _dbg_screen_rect;
1392cd1a60cc (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
    22
#endif
1392cd1a60cc (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
    23
5636
3c19b56dc982 (svn r8095) -Codechange: stuff that is not related to HAL moved from hal.h to gfx.h
KUDr
parents: 5587
diff changeset
    24
byte _dirkeys;        // 1 = left, 2 = up, 4 = right, 8 = down
3c19b56dc982 (svn r8095) -Codechange: stuff that is not related to HAL moved from hal.h to gfx.h
KUDr
parents: 5587
diff changeset
    25
bool _fullscreen;
3c19b56dc982 (svn r8095) -Codechange: stuff that is not related to HAL moved from hal.h to gfx.h
KUDr
parents: 5587
diff changeset
    26
CursorVars _cursor;
3c19b56dc982 (svn r8095) -Codechange: stuff that is not related to HAL moved from hal.h to gfx.h
KUDr
parents: 5587
diff changeset
    27
bool _ctrl_pressed;   // Is Ctrl pressed?
3c19b56dc982 (svn r8095) -Codechange: stuff that is not related to HAL moved from hal.h to gfx.h
KUDr
parents: 5587
diff changeset
    28
bool _shift_pressed;  // Is Shift pressed?
3c19b56dc982 (svn r8095) -Codechange: stuff that is not related to HAL moved from hal.h to gfx.h
KUDr
parents: 5587
diff changeset
    29
byte _fast_forward;
3c19b56dc982 (svn r8095) -Codechange: stuff that is not related to HAL moved from hal.h to gfx.h
KUDr
parents: 5587
diff changeset
    30
bool _left_button_down;
3c19b56dc982 (svn r8095) -Codechange: stuff that is not related to HAL moved from hal.h to gfx.h
KUDr
parents: 5587
diff changeset
    31
bool _left_button_clicked;
3c19b56dc982 (svn r8095) -Codechange: stuff that is not related to HAL moved from hal.h to gfx.h
KUDr
parents: 5587
diff changeset
    32
bool _right_button_down;
3c19b56dc982 (svn r8095) -Codechange: stuff that is not related to HAL moved from hal.h to gfx.h
KUDr
parents: 5587
diff changeset
    33
bool _right_button_clicked;
3c19b56dc982 (svn r8095) -Codechange: stuff that is not related to HAL moved from hal.h to gfx.h
KUDr
parents: 5587
diff changeset
    34
DrawPixelInfo _screen;
3c19b56dc982 (svn r8095) -Codechange: stuff that is not related to HAL moved from hal.h to gfx.h
KUDr
parents: 5587
diff changeset
    35
bool _exit_game;
3c19b56dc982 (svn r8095) -Codechange: stuff that is not related to HAL moved from hal.h to gfx.h
KUDr
parents: 5587
diff changeset
    36
bool _networking;         ///< are we in networking mode?
3c19b56dc982 (svn r8095) -Codechange: stuff that is not related to HAL moved from hal.h to gfx.h
KUDr
parents: 5587
diff changeset
    37
byte _game_mode;
3c19b56dc982 (svn r8095) -Codechange: stuff that is not related to HAL moved from hal.h to gfx.h
KUDr
parents: 5587
diff changeset
    38
byte _pause;
3c19b56dc982 (svn r8095) -Codechange: stuff that is not related to HAL moved from hal.h to gfx.h
KUDr
parents: 5587
diff changeset
    39
int _pal_first_dirty;
3c19b56dc982 (svn r8095) -Codechange: stuff that is not related to HAL moved from hal.h to gfx.h
KUDr
parents: 5587
diff changeset
    40
int _pal_last_dirty;
3c19b56dc982 (svn r8095) -Codechange: stuff that is not related to HAL moved from hal.h to gfx.h
KUDr
parents: 5587
diff changeset
    41
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
    42
Colour _cur_palette[256];
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
    43
byte _stringwidth_table[FS_END][224];
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
    44
5567
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
    45
typedef enum BlitterModes {
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
    46
	BM_NORMAL,
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
    47
	BM_COLOUR_REMAP,
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
    48
	BM_TRANSPARENT,
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
    49
} BlitterMode;
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
    50
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
    51
static void GfxMainBlitter(const Sprite *sprite, int x, int y, BlitterMode mode);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    52
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
    53
FontSize _cur_fontsize;
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
    54
static FontSize _last_fontsize;
2062
57db03be52ad (svn r2571) Add explicit type Pixel for ... Pixels
tron
parents: 2037
diff changeset
    55
static Pixel _cursor_backup[64 * 64];
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    56
static Rect _invalid_rect;
1357
0a4c07b68673 (svn r1861) Constify Get(Non)Sprite()
tron
parents: 1351
diff changeset
    57
static const byte *_color_remap_ptr;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    58
static byte _string_colorremap[3];
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    59
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
    60
#define DIRTY_BYTES_PER_LINE (MAX_SCREEN_WIDTH / 64)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    61
static byte _dirty_blocks[DIRTY_BYTES_PER_LINE * MAX_SCREEN_HEIGHT / 8];
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    62
4949
6bf60913767f (svn r6938) -Codechange: Comments, typo, variable naming, whitespace, strecpy and simplification
Darkvater
parents: 4928
diff changeset
    63
void memcpy_pitch(void *dst, void *src, int w, int h, int srcpitch, int dstpitch)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    64
{
4949
6bf60913767f (svn r6938) -Codechange: Comments, typo, variable naming, whitespace, strecpy and simplification
Darkvater
parents: 4928
diff changeset
    65
	byte *dstp = (byte*)dst;
6bf60913767f (svn r6938) -Codechange: Comments, typo, variable naming, whitespace, strecpy and simplification
Darkvater
parents: 4928
diff changeset
    66
	byte *srcp = (byte*)src;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    67
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    68
	assert(h >= 0);
1056
24579058c082 (svn r1557) Replace strange if () do while () construct with a plain for ()
tron
parents: 1009
diff changeset
    69
	for (; h != 0; --h) {
4949
6bf60913767f (svn r6938) -Codechange: Comments, typo, variable naming, whitespace, strecpy and simplification
Darkvater
parents: 4928
diff changeset
    70
		memcpy(dstp, srcp, w);
6bf60913767f (svn r6938) -Codechange: Comments, typo, variable naming, whitespace, strecpy and simplification
Darkvater
parents: 4928
diff changeset
    71
		dstp += dstpitch;
6bf60913767f (svn r6938) -Codechange: Comments, typo, variable naming, whitespace, strecpy and simplification
Darkvater
parents: 4928
diff changeset
    72
		srcp += srcpitch;
1056
24579058c082 (svn r1557) Replace strange if () do while () construct with a plain for ()
tron
parents: 1009
diff changeset
    73
	}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    74
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    75
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
    76
void GfxScroll(int left, int top, int width, int height, int xo, int yo)
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
    77
{
2062
57db03be52ad (svn r2571) Add explicit type Pixel for ... Pixels
tron
parents: 2037
diff changeset
    78
	const Pixel *src;
57db03be52ad (svn r2571) Add explicit type Pixel for ... Pixels
tron
parents: 2037
diff changeset
    79
	Pixel *dst;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    80
	int p;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    81
	int ht;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    82
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
    83
	if (xo == 0 && yo == 0) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    84
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
    85
	if (_cursor.visible) UndrawMouseCursor();
543
946badd71033 (svn r942) -Merged branch/network back into the trunk
truelight
parents: 510
diff changeset
    86
	UndrawTextMessage();
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    87
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    88
	p = _screen.pitch;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    89
375
52d7a943c1e7 (svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents: 332
diff changeset
    90
	if (yo > 0) {
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    91
		// Calculate pointers
375
52d7a943c1e7 (svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents: 332
diff changeset
    92
		dst = _screen.dst_ptr + (top + height - 1) * p + left;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    93
		src = dst - yo * p;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    94
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    95
		// Decrease height and increase top
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    96
		top += yo;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    97
		height -= yo;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    98
		assert(height > 0);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    99
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   100
		// Adjust left & width
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   101
		if (xo >= 0) {
375
52d7a943c1e7 (svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents: 332
diff changeset
   102
			dst += xo;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   103
			left += xo;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   104
			width -= xo;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   105
		} else {
375
52d7a943c1e7 (svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents: 332
diff changeset
   106
			src -= xo;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   107
			width += xo;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   108
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   109
375
52d7a943c1e7 (svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents: 332
diff changeset
   110
		for (ht = height; ht > 0; --ht) {
52d7a943c1e7 (svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents: 332
diff changeset
   111
			memcpy(dst, src, width);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   112
			src -= p;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   113
			dst -= p;
375
52d7a943c1e7 (svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents: 332
diff changeset
   114
		}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   115
	} else {
375
52d7a943c1e7 (svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents: 332
diff changeset
   116
		// Calculate pointers
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   117
		dst = _screen.dst_ptr + top * p + left;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   118
		src = dst - yo * p;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   119
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   120
		// Decrese height. (yo is <=0).
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   121
		height += yo;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   122
		assert(height > 0);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   123
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   124
		// Adjust left & width
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   125
		if (xo >= 0) {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   126
			dst += xo;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   127
			left += xo;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   128
			width -= xo;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   129
		} else {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   130
			src -= xo;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   131
			width += xo;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   132
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   133
375
52d7a943c1e7 (svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents: 332
diff changeset
   134
		// the y-displacement may be 0 therefore we have to use memmove,
52d7a943c1e7 (svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents: 332
diff changeset
   135
		// because source and destination may overlap
52d7a943c1e7 (svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents: 332
diff changeset
   136
		for (ht = height; ht > 0; --ht) {
52d7a943c1e7 (svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents: 332
diff changeset
   137
			memmove(dst, src, width);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   138
			src += p;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   139
			dst += p;
375
52d7a943c1e7 (svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents: 332
diff changeset
   140
		}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   141
	}
375
52d7a943c1e7 (svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents: 332
diff changeset
   142
	// This part of the screen is now dirty.
52d7a943c1e7 (svn r564) Simplify scroll logic and correct one erroneous use of memcpy()
tron
parents: 332
diff changeset
   143
	_video_driver->make_dirty(left, top, width, height);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   144
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   145
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   146
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   147
void GfxFillRect(int left, int top, int right, int bottom, int color)
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   148
{
2548
49c8a096033f (svn r3077) static, const, bracing, indentation, 0 -> '\0'/NULL, typos in comments, excess empty lines, minor other changes
tron
parents: 2436
diff changeset
   149
	const DrawPixelInfo* dpi = _cur_dpi;
2062
57db03be52ad (svn r2571) Add explicit type Pixel for ... Pixels
tron
parents: 2037
diff changeset
   150
	Pixel *dst;
332
2e853c8bb691 (svn r499) Merge r498 to trunk:
tron
parents: 306
diff changeset
   151
	const int otop = top;
2e853c8bb691 (svn r499) Merge r498 to trunk:
tron
parents: 306
diff changeset
   152
	const int oleft = left;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   153
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   154
	if (dpi->zoom != 0) return;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   155
	if (left > right || top > bottom) return;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   156
	if (right < dpi->left || left >= dpi->left + dpi->width) return;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   157
	if (bottom < dpi->top || top >= dpi->top + dpi->height) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   158
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   159
	if ( (left -= dpi->left) < 0) left = 0;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   160
	right = right - dpi->left + 1;
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   161
	if (right > dpi->width) right = dpi->width;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   162
	right -= left;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   163
	assert(right > 0);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   164
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   165
	if ( (top -= dpi->top) < 0) top = 0;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   166
	bottom = bottom - dpi->top + 1;
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   167
	if (bottom > dpi->height) bottom = dpi->height;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   168
	bottom -= top;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   169
	assert(bottom > 0);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   170
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   171
	dst = dpi->dst_ptr + top * dpi->pitch + left;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   172
5668
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
   173
	if (!HASBIT(color, PALETTE_MODIFIER_GREYOUT)) {
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
   174
		if (!HASBIT(color, USE_COLORTABLE)) {
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   175
			do {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   176
				memset(dst, color, right);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   177
				dst += dpi->pitch;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   178
			} while (--bottom);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   179
		} else {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   180
			/* use colortable mode */
5668
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
   181
			const byte* ctab = GetNonSprite(GB(color, 0, PALETTE_WIDTH)) + 1;
1357
0a4c07b68673 (svn r1861) Constify Get(Non)Sprite()
tron
parents: 1351
diff changeset
   182
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   183
			do {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   184
				int i;
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
   185
				for (i = 0; i != right; i++) dst[i] = ctab[dst[i]];
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   186
				dst += dpi->pitch;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   187
			} while (--bottom);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   188
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   189
	} else {
332
2e853c8bb691 (svn r499) Merge r498 to trunk:
tron
parents: 306
diff changeset
   190
		byte bo = (oleft - left + dpi->left + otop - top + dpi->top) & 1;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   191
		do {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   192
			int i;
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
   193
			for (i = (bo ^= 1); i < right; i += 2) dst[i] = (byte)color;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   194
			dst += dpi->pitch;
332
2e853c8bb691 (svn r499) Merge r498 to trunk:
tron
parents: 306
diff changeset
   195
		} while (--bottom > 0);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   196
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   197
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   198
410
0efd84450b01 (svn r607) -Patch: [ 985102 ] static cleanup
tron
parents: 375
diff changeset
   199
static void GfxSetPixel(int x, int y, int color)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   200
{
2548
49c8a096033f (svn r3077) static, const, bracing, indentation, 0 -> '\0'/NULL, typos in comments, excess empty lines, minor other changes
tron
parents: 2436
diff changeset
   201
	const DrawPixelInfo* dpi = _cur_dpi;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   202
	if ((x-=dpi->left) < 0 || x>=dpi->width || (y-=dpi->top)<0 || y>=dpi->height)
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   203
		return;
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   204
	dpi->dst_ptr[y * dpi->pitch + x] = color;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   205
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   206
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   207
void GfxDrawLine(int x, int y, int x2, int y2, int color)
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   208
{
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   209
	int dy;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   210
	int dx;
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   211
	int stepx;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   212
	int stepy;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   213
	int frac;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   214
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   215
	// Check clipping first
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   216
	{
4522
6324ef1f0e5b (svn r6347) Undo
tron
parents: 4521
diff changeset
   217
		DrawPixelInfo *dpi = _cur_dpi;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   218
		int t;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   219
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   220
		if (x < dpi->left && x2 < dpi->left) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   221
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   222
		if (y < dpi->top && y2 < dpi->top) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   223
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   224
		t = dpi->left + dpi->width;
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   225
		if (x > t && x2 > t) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   226
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   227
		t = dpi->top + dpi->height;
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   228
		if (y > t && y2 > t) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   229
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   230
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   231
	dy = (y2 - y) * 2;
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   232
	if (dy < 0) {
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   233
		dy = -dy;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   234
		stepy = -1;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   235
	} else {
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   236
		stepy = 1;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   237
	}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   238
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   239
	dx = (x2 - x) * 2;
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   240
	if (dx < 0) {
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   241
		dx = -dx;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   242
		stepx = -1;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   243
	} else {
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   244
		stepx = 1;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   245
	}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   246
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   247
	GfxSetPixel(x, y, color);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   248
	if (dx > dy) {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   249
		frac = dy - (dx >> 1);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   250
		while (x != x2) {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   251
			if (frac >= 0) {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   252
				y += stepy;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   253
				frac -= dx;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   254
			}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   255
			x += stepx;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   256
			frac += dy;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   257
			GfxSetPixel(x, y, color);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   258
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   259
	} else {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   260
		frac = dx - (dy >> 1);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   261
		while (y != y2) {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   262
			if (frac >= 0) {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   263
				x += stepx;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   264
				frac -= dy;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   265
			}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   266
			y += stepy;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   267
			frac += dx;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   268
			GfxSetPixel(x, y, color);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   269
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   270
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   271
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   272
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   273
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   274
/** Truncate a given string to a maximum width if neccessary.
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   275
 * If the string is truncated, add three dots ('...') to show this.
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   276
 * @param *dest string that is checked and possibly truncated
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   277
 * @param maxw maximum width in pixels of the string
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   278
 * @return new width of (truncated) string */
2113
be2f07df0dfa (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
   279
static int TruncateString(char *str, int maxw)
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   280
{
2113
be2f07df0dfa (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
   281
	int w = 0;
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   282
	FontSize size = _cur_fontsize;
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   283
	int ddd, ddd_w;
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   284
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   285
	WChar c;
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   286
	char *ddd_pos;
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   287
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   288
	ddd_w = ddd = GetCharacterWidth(size, '.') * 3;
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   289
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   290
	for (ddd_pos = str; (c = Utf8Consume((const char **)&str)) != '\0'; ) {
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   291
		if (IsPrintable(c)) {
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   292
			w += GetCharacterWidth(size, c);
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   293
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   294
			if (w >= maxw) {
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   295
				// string got too big... insert dotdotdot
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   296
				ddd_pos[0] = ddd_pos[1] = ddd_pos[2] = '.';
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   297
				ddd_pos[3] = 0;
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   298
				return ddd_w;
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   299
			}
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   300
		} else {
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   301
			if (c == SCC_SETX) str++;
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   302
			else if (c == SCC_SETXY) str += 2;
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   303
			else if (c == SCC_TINYFONT) {
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   304
				size = FS_SMALL;
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   305
				ddd = GetCharacterWidth(size, '.') * 3;
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   306
			} else if (c == SCC_BIGFONT) {
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   307
				size = FS_LARGE;
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   308
				ddd = GetCharacterWidth(size, '.') * 3;
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   309
			}
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   310
		}
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   311
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   312
		// Remember the last position where three dots fit.
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   313
		if (w + ddd < maxw) {
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   314
			ddd_w = w + ddd;
2113
be2f07df0dfa (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
   315
			ddd_pos = str;
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   316
		}
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   317
	}
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   318
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   319
	return w;
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   320
}
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   321
4912
0f51b47cb983 (svn r6884) -Codechange: Add strict bounds checking in string formatting system.
Darkvater
parents: 4819
diff changeset
   322
static inline int TruncateStringID(StringID src, char *dest, int maxw, const char* last)
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   323
{
4912
0f51b47cb983 (svn r6884) -Codechange: Add strict bounds checking in string formatting system.
Darkvater
parents: 4819
diff changeset
   324
	GetString(dest, src, last);
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   325
	return TruncateString(dest, maxw);
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   326
}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   327
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   328
/* returns right coordinate */
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   329
int DrawString(int x, int y, StringID str, uint16 color)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   330
{
1336
69391734ce23 (svn r1840) Repel str_buffr and use local buffers where possible
tron
parents: 1323
diff changeset
   331
	char buffer[512];
69391734ce23 (svn r1840) Repel str_buffr and use local buffers where possible
tron
parents: 1323
diff changeset
   332
4912
0f51b47cb983 (svn r6884) -Codechange: Add strict bounds checking in string formatting system.
Darkvater
parents: 4819
diff changeset
   333
	GetString(buffer, str, lastof(buffer));
1336
69391734ce23 (svn r1840) Repel str_buffr and use local buffers where possible
tron
parents: 1323
diff changeset
   334
	return DoDrawString(buffer, x, y, color);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   335
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   336
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   337
int DrawStringTruncated(int x, int y, StringID str, uint16 color, uint maxw)
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   338
{
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   339
	char buffer[512];
4912
0f51b47cb983 (svn r6884) -Codechange: Add strict bounds checking in string formatting system.
Darkvater
parents: 4819
diff changeset
   340
	TruncateStringID(str, buffer, maxw, lastof(buffer));
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   341
	return DoDrawString(buffer, x, y, color);
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   342
}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   343
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   344
4314
5c816195d9d4 (svn r5967) -Change: use right alignment for the year in the player's balance window instead of centering (about) 'string width' / 2 from the right edge
rubidium
parents: 4300
diff changeset
   345
int DrawStringRightAligned(int x, int y, StringID str, uint16 color)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   346
{
1336
69391734ce23 (svn r1840) Repel str_buffr and use local buffers where possible
tron
parents: 1323
diff changeset
   347
	char buffer[512];
4314
5c816195d9d4 (svn r5967) -Change: use right alignment for the year in the player's balance window instead of centering (about) 'string width' / 2 from the right edge
rubidium
parents: 4300
diff changeset
   348
	int w;
1336
69391734ce23 (svn r1840) Repel str_buffr and use local buffers where possible
tron
parents: 1323
diff changeset
   349
4912
0f51b47cb983 (svn r6884) -Codechange: Add strict bounds checking in string formatting system.
Darkvater
parents: 4819
diff changeset
   350
	GetString(buffer, str, lastof(buffer));
4609
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   351
	w = GetStringBoundingBox(buffer).width;
4314
5c816195d9d4 (svn r5967) -Change: use right alignment for the year in the player's balance window instead of centering (about) 'string width' / 2 from the right edge
rubidium
parents: 4300
diff changeset
   352
	DoDrawString(buffer, x - w, y, color);
5c816195d9d4 (svn r5967) -Change: use right alignment for the year in the player's balance window instead of centering (about) 'string width' / 2 from the right edge
rubidium
parents: 4300
diff changeset
   353
5c816195d9d4 (svn r5967) -Change: use right alignment for the year in the player's balance window instead of centering (about) 'string width' / 2 from the right edge
rubidium
parents: 4300
diff changeset
   354
	return w;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   355
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   356
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   357
void DrawStringRightAlignedTruncated(int x, int y, StringID str, uint16 color, uint maxw)
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   358
{
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   359
	char buffer[512];
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   360
4912
0f51b47cb983 (svn r6884) -Codechange: Add strict bounds checking in string formatting system.
Darkvater
parents: 4819
diff changeset
   361
	TruncateStringID(str, buffer, maxw, lastof(buffer));
4609
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   362
	DoDrawString(buffer, x - GetStringBoundingBox(buffer).width, y, color);
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   363
}
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   364
4314
5c816195d9d4 (svn r5967) -Change: use right alignment for the year in the player's balance window instead of centering (about) 'string width' / 2 from the right edge
rubidium
parents: 4300
diff changeset
   365
void DrawStringRightAlignedUnderline(int x, int y, StringID str, uint16 color)
5c816195d9d4 (svn r5967) -Change: use right alignment for the year in the player's balance window instead of centering (about) 'string width' / 2 from the right edge
rubidium
parents: 4300
diff changeset
   366
{
5c816195d9d4 (svn r5967) -Change: use right alignment for the year in the player's balance window instead of centering (about) 'string width' / 2 from the right edge
rubidium
parents: 4300
diff changeset
   367
	int w = DrawStringRightAligned(x, y, str, color);
5c816195d9d4 (svn r5967) -Change: use right alignment for the year in the player's balance window instead of centering (about) 'string width' / 2 from the right edge
rubidium
parents: 4300
diff changeset
   368
	GfxFillRect(x - w, y + 10, x, y + 10, _string_colorremap[1]);
5c816195d9d4 (svn r5967) -Change: use right alignment for the year in the player's balance window instead of centering (about) 'string width' / 2 from the right edge
rubidium
parents: 4300
diff changeset
   369
}
5c816195d9d4 (svn r5967) -Change: use right alignment for the year in the player's balance window instead of centering (about) 'string width' / 2 from the right edge
rubidium
parents: 4300
diff changeset
   370
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   371
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   372
int DrawStringCentered(int x, int y, StringID str, uint16 color)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   373
{
1336
69391734ce23 (svn r1840) Repel str_buffr and use local buffers where possible
tron
parents: 1323
diff changeset
   374
	char buffer[512];
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   375
	int w;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   376
4912
0f51b47cb983 (svn r6884) -Codechange: Add strict bounds checking in string formatting system.
Darkvater
parents: 4819
diff changeset
   377
	GetString(buffer, str, lastof(buffer));
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   378
4609
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   379
	w = GetStringBoundingBox(buffer).width;
1336
69391734ce23 (svn r1840) Repel str_buffr and use local buffers where possible
tron
parents: 1323
diff changeset
   380
	DoDrawString(buffer, x - w / 2, y, color);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   381
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   382
	return w;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   383
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   384
2113
be2f07df0dfa (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
   385
int DrawStringCenteredTruncated(int xl, int xr, int y, StringID str, uint16 color)
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   386
{
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   387
	char buffer[512];
4912
0f51b47cb983 (svn r6884) -Codechange: Add strict bounds checking in string formatting system.
Darkvater
parents: 4819
diff changeset
   388
	int w = TruncateStringID(str, buffer, xr - xl, lastof(buffer));
2113
be2f07df0dfa (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
   389
	return DoDrawString(buffer, (xl + xr - w) / 2, y, color);
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   390
}
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   391
2134
50fafe90c9f0 (svn r2644) - Fix: my name was mistyped ;p
Darkvater
parents: 2113
diff changeset
   392
int DoDrawStringCentered(int x, int y, const char *str, uint16 color)
50fafe90c9f0 (svn r2644) - Fix: my name was mistyped ;p
Darkvater
parents: 2113
diff changeset
   393
{
4609
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   394
	int w = GetStringBoundingBox(str).width;
2134
50fafe90c9f0 (svn r2644) - Fix: my name was mistyped ;p
Darkvater
parents: 2113
diff changeset
   395
	DoDrawString(str, x - w / 2, y, color);
50fafe90c9f0 (svn r2644) - Fix: my name was mistyped ;p
Darkvater
parents: 2113
diff changeset
   396
	return w;
50fafe90c9f0 (svn r2644) - Fix: my name was mistyped ;p
Darkvater
parents: 2113
diff changeset
   397
}
50fafe90c9f0 (svn r2644) - Fix: my name was mistyped ;p
Darkvater
parents: 2113
diff changeset
   398
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   399
void DrawStringCenterUnderline(int x, int y, StringID str, uint16 color)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   400
{
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   401
	int w = DrawStringCentered(x, y, str, color);
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   402
	GfxFillRect(x - (w >> 1), y + 10, x - (w >> 1) + w, y + 10, _string_colorremap[1]);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   403
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   404
2113
be2f07df0dfa (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
   405
void DrawStringCenterUnderlineTruncated(int xl, int xr, int y, StringID str, uint16 color)
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   406
{
2113
be2f07df0dfa (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
   407
	int w = DrawStringCenteredTruncated(xl, xr, y, str, color);
be2f07df0dfa (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
   408
	GfxFillRect((xl + xr - w) / 2, y + 10, (xl + xr + w) / 2, y + 10, _string_colorremap[1]);
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   409
}
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   410
4954
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   411
/** 'Correct' a string to a maximum length. Longer strings will be cut into
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   412
 * additional lines at whitespace characters if possible. The string parameter
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   413
 * is modified with terminating characters mid-string which are the
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   414
 * placeholders for the newlines.<br/>
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   415
 * The string WILL be truncated if there was no whitespace for the current
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   416
 * line's maximum width.
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   417
 *
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   418
 * @note To know if the the terminating '\0' is the string end or just a
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   419
 * newline, the returned 'num' value should be consulted. The num'th '\0',
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   420
 * starting with index 0 is the real string end.
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   421
 *
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   422
 * @param str string to check and correct for length restrictions
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   423
 * @param maxw the maximum width the string can have on one line
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   424
 * @return return a 32bit wide number consisting of 2 packed values:
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   425
 *  0 - 15 the number of lines ADDED to the string
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   426
 * 16 - 31 the fontsize in which the length calculation was done at */
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   427
uint32 FormatStringLinebreaks(char *str, int maxw)
1095
b59632d9df1b (svn r1596) Add some more statics
tron
parents: 1093
diff changeset
   428
{
4954
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   429
	FontSize size = _cur_fontsize;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   430
	int num = 0;
4954
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   431
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   432
	assert(maxw > 0);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   433
2952
58522ed8f0f1 (svn r3511) More whitespace ([FS#46] by Rubidium)
tron
parents: 2753
diff changeset
   434
	for (;;) {
4954
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   435
		char *last_space = NULL;
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   436
		int w = 0;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   437
2952
58522ed8f0f1 (svn r3511) More whitespace ([FS#46] by Rubidium)
tron
parents: 2753
diff changeset
   438
		for (;;) {
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   439
			WChar c = Utf8Consume((const char **)&str);
4954
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   440
			/* whitespace is where we will insert the line-break */
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   441
			if (c == ' ') last_space = str;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   442
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   443
			if (IsPrintable(c)) {
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   444
				w += GetCharacterWidth(size, c);
4954
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   445
				/* string is longer than maximum width so we need to decide what to
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   446
				 * do. We can do two things:
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   447
				 * 1. If no whitespace was found at all up until now (on this line) then
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   448
				 *    we will truncate the string and bail out.
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   449
				 * 2. In all other cases force a linebreak at the last seen whitespace */
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   450
				if (w > maxw) {
4954
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   451
					if (last_space == NULL) {
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   452
						str[-1] = '\0';
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   453
						return num + (size << 16);
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   454
					}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   455
					str = last_space;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   456
					break;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   457
				}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   458
			} else {
4954
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   459
				switch (c) {
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   460
					case '\0': return num + (size << 16); break;
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   461
					case SCC_SETX:  str++; break;
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   462
					case SCC_SETXY: str +=2; break;
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   463
					case SCC_TINYFONT: size = FS_SMALL; break;
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   464
					case SCC_BIGFONT:  size = FS_LARGE; break;
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   465
					case '\n': goto end_of_inner_loop;
4954
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   466
				}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   467
			}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   468
		}
4954
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   469
end_of_inner_loop:
c1f059faa899 (svn r6953) -Codechange: Change FormatStringLinebreaks in such a way that if no whitespace was seen
Darkvater
parents: 4949
diff changeset
   470
		/* string didn't fit on line, so 'dummy' terminate and increase linecount */
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   471
		num++;
2548
49c8a096033f (svn r3077) static, const, bracing, indentation, 0 -> '\0'/NULL, typos in comments, excess empty lines, minor other changes
tron
parents: 2436
diff changeset
   472
		str[-1] = '\0';
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   473
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   474
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   475
5391
18028f19893d (svn r7580) -Fix (r7182): UTF8-merge changed the string handling a bit, now the str pointer for
Darkvater
parents: 5380
diff changeset
   476
/** Draw a given string with the centre around the given x coordinates
18028f19893d (svn r7580) -Fix (r7182): UTF8-merge changed the string handling a bit, now the str pointer for
Darkvater
parents: 5380
diff changeset
   477
 * @param x Centre the string around this pixel width
18028f19893d (svn r7580) -Fix (r7182): UTF8-merge changed the string handling a bit, now the str pointer for
Darkvater
parents: 5380
diff changeset
   478
 * @param y Draw the string at this pixel height (first line's bottom)
18028f19893d (svn r7580) -Fix (r7182): UTF8-merge changed the string handling a bit, now the str pointer for
Darkvater
parents: 5380
diff changeset
   479
 * @param str String to draw
18028f19893d (svn r7580) -Fix (r7182): UTF8-merge changed the string handling a bit, now the str pointer for
Darkvater
parents: 5380
diff changeset
   480
 * @param max Maximum width the string can have before it is wrapped */
2634
0df9396b0067 (svn r3176) Use proper types, not some variants of int
tron
parents: 2631
diff changeset
   481
void DrawStringMultiCenter(int x, int y, StringID str, int maxw)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   482
{
1336
69391734ce23 (svn r1840) Repel str_buffr and use local buffers where possible
tron
parents: 1323
diff changeset
   483
	char buffer[512];
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   484
	uint32 tmp;
2631
2ed0eb408229 (svn r3173) Use the trinary operator and switch to improve readability
tron
parents: 2548
diff changeset
   485
	int num, w, mt;
1323
bac2e38e8b60 (svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents: 1309
diff changeset
   486
	const char *src;
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   487
	WChar c;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   488
4912
0f51b47cb983 (svn r6884) -Codechange: Add strict bounds checking in string formatting system.
Darkvater
parents: 4819
diff changeset
   489
	GetString(buffer, str, lastof(buffer));
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   490
1336
69391734ce23 (svn r1840) Repel str_buffr and use local buffers where possible
tron
parents: 1323
diff changeset
   491
	tmp = FormatStringLinebreaks(buffer, maxw);
2635
7ed07303448d (svn r3177) GB, CLRBIT, HASBIT, TOGGLEBIT
tron
parents: 2634
diff changeset
   492
	num = GB(tmp, 0, 16);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   493
5587
167d9a91ef02 (svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents: 5584
diff changeset
   494
	mt = GetCharacterHeight((FontSize)GB(tmp, 16, 16));
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   495
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   496
	y -= (mt >> 1) * num;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   497
1336
69391734ce23 (svn r1840) Repel str_buffr and use local buffers where possible
tron
parents: 1323
diff changeset
   498
	src = buffer;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   499
2952
58522ed8f0f1 (svn r3511) More whitespace ([FS#46] by Rubidium)
tron
parents: 2753
diff changeset
   500
	for (;;) {
4609
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   501
		w = GetStringBoundingBox(src).width;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   502
		DoDrawString(src, x - (w>>1), y, 0xFE);
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   503
		_cur_fontsize = _last_fontsize;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   504
2952
58522ed8f0f1 (svn r3511) More whitespace ([FS#46] by Rubidium)
tron
parents: 2753
diff changeset
   505
		for (;;) {
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   506
			c = Utf8Consume(&src);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   507
			if (c == 0) {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   508
				y += mt;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   509
				if (--num < 0) {
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   510
					_cur_fontsize = FS_NORMAL;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   511
					return;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   512
				}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   513
				break;
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   514
			} else if (c == SCC_SETX) {
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   515
				src++;
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   516
			} else if (c == SCC_SETXY) {
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   517
				src+=2;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   518
			}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   519
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   520
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   521
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   522
4928
ff53f78c5a87 (svn r6908) - Codechange: Modify DrawStringMultiLine() to return the number of pixel lines used, and use it for drawing NewGRF additional text (mart3p)
peter1138
parents: 4912
diff changeset
   523
ff53f78c5a87 (svn r6908) - Codechange: Modify DrawStringMultiLine() to return the number of pixel lines used, and use it for drawing NewGRF additional text (mart3p)
peter1138
parents: 4912
diff changeset
   524
uint DrawStringMultiLine(int x, int y, StringID str, int maxw)
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   525
{
1336
69391734ce23 (svn r1840) Repel str_buffr and use local buffers where possible
tron
parents: 1323
diff changeset
   526
	char buffer[512];
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   527
	uint32 tmp;
2753
b25bd313785e (svn r3298) Remove unused and write-only variables
tron
parents: 2658
diff changeset
   528
	int num, mt;
4928
ff53f78c5a87 (svn r6908) - Codechange: Modify DrawStringMultiLine() to return the number of pixel lines used, and use it for drawing NewGRF additional text (mart3p)
peter1138
parents: 4912
diff changeset
   529
	uint total_height;
1323
bac2e38e8b60 (svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents: 1309
diff changeset
   530
	const char *src;
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   531
	WChar c;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   532
4912
0f51b47cb983 (svn r6884) -Codechange: Add strict bounds checking in string formatting system.
Darkvater
parents: 4819
diff changeset
   533
	GetString(buffer, str, lastof(buffer));
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   534
1336
69391734ce23 (svn r1840) Repel str_buffr and use local buffers where possible
tron
parents: 1323
diff changeset
   535
	tmp = FormatStringLinebreaks(buffer, maxw);
2635
7ed07303448d (svn r3177) GB, CLRBIT, HASBIT, TOGGLEBIT
tron
parents: 2634
diff changeset
   536
	num = GB(tmp, 0, 16);
2631
2ed0eb408229 (svn r3173) Use the trinary operator and switch to improve readability
tron
parents: 2548
diff changeset
   537
5587
167d9a91ef02 (svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents: 5584
diff changeset
   538
	mt = GetCharacterHeight((FontSize)GB(tmp, 16, 16));
4928
ff53f78c5a87 (svn r6908) - Codechange: Modify DrawStringMultiLine() to return the number of pixel lines used, and use it for drawing NewGRF additional text (mart3p)
peter1138
parents: 4912
diff changeset
   539
	total_height = (num + 1) * mt;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   540
1336
69391734ce23 (svn r1840) Repel str_buffr and use local buffers where possible
tron
parents: 1323
diff changeset
   541
	src = buffer;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   542
2952
58522ed8f0f1 (svn r3511) More whitespace ([FS#46] by Rubidium)
tron
parents: 2753
diff changeset
   543
	for (;;) {
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   544
		DoDrawString(src, x, y, 0xFE);
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   545
		_cur_fontsize = _last_fontsize;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   546
2952
58522ed8f0f1 (svn r3511) More whitespace ([FS#46] by Rubidium)
tron
parents: 2753
diff changeset
   547
		for (;;) {
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   548
			c = Utf8Consume(&src);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   549
			if (c == 0) {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   550
				y += mt;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   551
				if (--num < 0) {
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   552
					_cur_fontsize = FS_NORMAL;
4928
ff53f78c5a87 (svn r6908) - Codechange: Modify DrawStringMultiLine() to return the number of pixel lines used, and use it for drawing NewGRF additional text (mart3p)
peter1138
parents: 4912
diff changeset
   553
					return total_height;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   554
				}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   555
				break;
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   556
			} else if (c == SCC_SETX) {
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   557
				src++;
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   558
			} else if (c == SCC_SETXY) {
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   559
				src+=2;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   560
			}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   561
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   562
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   563
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   564
4609
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   565
/** Return the string dimension in pixels. The height and width are returned
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   566
 * in a single BoundingRect value. TINYFONT, BIGFONT modifiers are only
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   567
 * supported as the first character of the string. The returned dimensions
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   568
 * are therefore a rough estimation correct for all the current strings
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   569
 * but not every possible combination
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   570
 * @param str string to calculate pixel-width
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   571
 * @return string width and height in pixels */
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   572
BoundingRect GetStringBoundingBox(const char *str)
1323
bac2e38e8b60 (svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents: 1309
diff changeset
   573
{
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   574
	FontSize size = _cur_fontsize;
4609
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   575
	BoundingRect br;
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   576
	int max_width;
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   577
	WChar c;
4557
fe3fbd6204aa (svn r6404) -Fix: GetStringWidth failed to calculate correct string width if the string
Darkvater
parents: 4525
diff changeset
   578
4609
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   579
	br.width = br.height = max_width = 0;
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   580
	for (;;) {
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   581
		c = Utf8Consume(&str);
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   582
		if (c == 0) break;
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   583
		if (IsPrintable(c)) {
4609
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   584
			br.width += GetCharacterWidth(size, c);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   585
		} else {
4609
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   586
			switch (c) {
5391
18028f19893d (svn r7580) -Fix (r7182): UTF8-merge changed the string handling a bit, now the str pointer for
Darkvater
parents: 5380
diff changeset
   587
				case SCC_SETX: br.width += (byte)*str++; break;
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   588
				case SCC_SETXY:
5391
18028f19893d (svn r7580) -Fix (r7182): UTF8-merge changed the string handling a bit, now the str pointer for
Darkvater
parents: 5380
diff changeset
   589
					br.width += (byte)*str++;
18028f19893d (svn r7580) -Fix (r7182): UTF8-merge changed the string handling a bit, now the str pointer for
Darkvater
parents: 5380
diff changeset
   590
					br.height += (byte)*str++;
4609
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   591
					break;
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   592
				case SCC_TINYFONT: size = FS_SMALL; break;
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   593
				case SCC_BIGFONT:  size = FS_LARGE; break;
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   594
				case '\n':
4609
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   595
					br.height += GetCharacterHeight(size);
4610
f264efbf7f4f (svn r6463) -Fix (r6462): Reset the string width to zero on every new line of course...
Darkvater
parents: 4609
diff changeset
   596
					if (br.width > max_width) max_width = br.width;
f264efbf7f4f (svn r6463) -Fix (r6462): Reset the string width to zero on every new line of course...
Darkvater
parents: 4609
diff changeset
   597
					br.width = 0;
4609
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   598
					break;
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   599
			}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   600
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   601
	}
4609
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   602
	br.height += GetCharacterHeight(size);
4557
fe3fbd6204aa (svn r6404) -Fix: GetStringWidth failed to calculate correct string width if the string
Darkvater
parents: 4525
diff changeset
   603
4609
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   604
	br.width  = max(br.width, max_width);
954fe701062f (svn r6462) -Codechange: Have GetStringWidth() return width as well as the height bounding
Darkvater
parents: 4557
diff changeset
   605
	return br;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   606
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   607
4949
6bf60913767f (svn r6938) -Codechange: Comments, typo, variable naming, whitespace, strecpy and simplification
Darkvater
parents: 4928
diff changeset
   608
/** Draw a string at the given coordinates with the given colour
6bf60913767f (svn r6938) -Codechange: Comments, typo, variable naming, whitespace, strecpy and simplification
Darkvater
parents: 4928
diff changeset
   609
 * @param string the string to draw
6bf60913767f (svn r6938) -Codechange: Comments, typo, variable naming, whitespace, strecpy and simplification
Darkvater
parents: 4928
diff changeset
   610
 * @param x offset from left side of the screen, if negative offset from the right side
6bf60913767f (svn r6938) -Codechange: Comments, typo, variable naming, whitespace, strecpy and simplification
Darkvater
parents: 4928
diff changeset
   611
 * @param x offset from top side of the screen, if negative offset from the bottom
6bf60913767f (svn r6938) -Codechange: Comments, typo, variable naming, whitespace, strecpy and simplification
Darkvater
parents: 4928
diff changeset
   612
 * @param real_color colour of the string, see _string_colormap in
6bf60913767f (svn r6938) -Codechange: Comments, typo, variable naming, whitespace, strecpy and simplification
Darkvater
parents: 4928
diff changeset
   613
 * table/palettes.h or docs/ottd-colourtext-palette.png
6bf60913767f (svn r6938) -Codechange: Comments, typo, variable naming, whitespace, strecpy and simplification
Darkvater
parents: 4928
diff changeset
   614
 * @return the x-coordinates where the drawing has finished. If nothing is drawn
6bf60913767f (svn r6938) -Codechange: Comments, typo, variable naming, whitespace, strecpy and simplification
Darkvater
parents: 4928
diff changeset
   615
 * the originally passed x-coordinate is returned */
1323
bac2e38e8b60 (svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents: 1309
diff changeset
   616
int DoDrawString(const char *string, int x, int y, uint16 real_color)
bac2e38e8b60 (svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents: 1309
diff changeset
   617
{
4522
6324ef1f0e5b (svn r6347) Undo
tron
parents: 4521
diff changeset
   618
	DrawPixelInfo *dpi = _cur_dpi;
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   619
	FontSize size = _cur_fontsize;
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   620
	WChar c;
543
946badd71033 (svn r942) -Merged branch/network back into the trunk
truelight
parents: 510
diff changeset
   621
	byte color;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   622
	int xo = x, yo = y;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   623
543
946badd71033 (svn r942) -Merged branch/network back into the trunk
truelight
parents: 510
diff changeset
   624
	color = real_color & 0xFF;
946badd71033 (svn r942) -Merged branch/network back into the trunk
truelight
parents: 510
diff changeset
   625
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   626
	if (color != 0xFE) {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   627
		if (x >= dpi->left + dpi->width ||
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   628
				x + _screen.width*2 <= dpi->left ||
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   629
				y >= dpi->top + dpi->height ||
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   630
				y + _screen.height <= dpi->top)
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   631
					return x;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   632
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   633
		if (color != 0xFF) {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   634
switch_color:;
657
d4d36b4853ec (svn r1091) Fix: Finally station names use 100% the correct color in transparent mode
dominik
parents: 619
diff changeset
   635
			if (real_color & IS_PALETTE_COLOR) {
543
946badd71033 (svn r942) -Merged branch/network back into the trunk
truelight
parents: 510
diff changeset
   636
				_string_colorremap[1] = color;
946badd71033 (svn r942) -Merged branch/network back into the trunk
truelight
parents: 510
diff changeset
   637
				_string_colorremap[2] = 215;
946badd71033 (svn r942) -Merged branch/network back into the trunk
truelight
parents: 510
diff changeset
   638
			} else {
946badd71033 (svn r942) -Merged branch/network back into the trunk
truelight
parents: 510
diff changeset
   639
				_string_colorremap[1] = _string_colormap[color].text;
946badd71033 (svn r942) -Merged branch/network back into the trunk
truelight
parents: 510
diff changeset
   640
				_string_colorremap[2] = _string_colormap[color].shadow;
946badd71033 (svn r942) -Merged branch/network back into the trunk
truelight
parents: 510
diff changeset
   641
			}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   642
			_color_remap_ptr = _string_colorremap;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   643
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   644
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   645
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   646
check_bounds:
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   647
	if (y + 19 <= dpi->top || dpi->top + dpi->height <= y) {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   648
skip_char:;
2952
58522ed8f0f1 (svn r3511) More whitespace ([FS#46] by Rubidium)
tron
parents: 2753
diff changeset
   649
		for (;;) {
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   650
			c = Utf8Consume(&string);
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   651
			if (!IsPrintable(c)) goto skip_cont;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   652
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   653
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   654
2952
58522ed8f0f1 (svn r3511) More whitespace ([FS#46] by Rubidium)
tron
parents: 2753
diff changeset
   655
	for (;;) {
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   656
		c = Utf8Consume(&string);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   657
skip_cont:;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   658
		if (c == 0) {
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   659
			_last_fontsize = size;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   660
			return x;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   661
		}
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   662
		if (IsPrintable(c)) {
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   663
			if (x >= dpi->left + dpi->width) goto skip_char;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   664
			if (x + 26 >= dpi->left) {
5567
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
   665
				GfxMainBlitter(GetGlyph(size, c), x, y, BM_COLOUR_REMAP);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   666
			}
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   667
			x += GetCharacterWidth(size, c);
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   668
		} else if (c == '\n') { // newline = {}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   669
			x = xo;
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   670
			y += GetCharacterHeight(size);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   671
			goto check_bounds;
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   672
		} else if (c >= SCC_BLUE && c <= SCC_BLACK) { // change color?
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   673
			color = (byte)(c - SCC_BLUE);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   674
			goto switch_color;
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   675
		} else if (c == SCC_SETX) { // {SETX}
1323
bac2e38e8b60 (svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents: 1309
diff changeset
   676
			x = xo + (byte)*string++;
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   677
		} else if (c == SCC_SETXY) {// {SETXY}
1323
bac2e38e8b60 (svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents: 1309
diff changeset
   678
			x = xo + (byte)*string++;
bac2e38e8b60 (svn r1827) Next iteration of the byte -> char transition: some string drawing functions and buffers
tron
parents: 1309
diff changeset
   679
			y = yo + (byte)*string++;
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   680
		} else if (c == SCC_TINYFONT) { // {TINYFONT}
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   681
			size = FS_SMALL;
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
   682
		} else if (c == SCC_BIGFONT) { // {BIGFONT}
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
   683
			size = FS_LARGE;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   684
		} else {
5391
18028f19893d (svn r7580) -Fix (r7182): UTF8-merge changed the string handling a bit, now the str pointer for
Darkvater
parents: 5380
diff changeset
   685
			DEBUG(misc, 0, "[utf8] unknown string command character %d", c);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   686
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   687
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   688
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   689
2097
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   690
int DoDrawStringTruncated(const char *str, int x, int y, uint16 color, uint maxw)
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   691
{
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   692
	char buffer[512];
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   693
	ttd_strlcpy(buffer, str, sizeof(buffer));
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   694
	TruncateString(buffer, maxw);
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   695
	return DoDrawString(buffer, x, y, color);
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   696
}
e95d19e1941f (svn r2607) - Feature: add support for truncating strings to a given (pixel) length. Function courtesy of Ludde.
Darkvater
parents: 2062
diff changeset
   697
5668
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
   698
void DrawSprite(SpriteID img, SpriteID pal, int x, int y)
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   699
{
5668
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
   700
	if (HASBIT(img, PALETTE_MODIFIER_TRANSPARENT)) {
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
   701
		_color_remap_ptr = GetNonSprite(GB(pal, 0, PALETTE_WIDTH)) + 1;
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
   702
		GfxMainBlitter(GetSprite(GB(img, 0, SPRITE_WIDTH)), x, y, BM_TRANSPARENT);
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
   703
	} else if (pal != PAL_NONE) {
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
   704
		_color_remap_ptr = GetNonSprite(GB(pal, 0, PALETTE_WIDTH)) + 1;
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
   705
		GfxMainBlitter(GetSprite(GB(img, 0, SPRITE_WIDTH)), x, y, BM_COLOUR_REMAP);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   706
	} else {
5668
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
   707
		GfxMainBlitter(GetSprite(GB(img, 0, SPRITE_WIDTH)), x, y, BM_NORMAL);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   708
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   709
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   710
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   711
typedef struct BlitterParams {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   712
	int start_x, start_y;
4171
5c6e60c392c3 (svn r5609) CodeChange : Apply coding style
belugas
parents: 3798
diff changeset
   713
	const byte *sprite;
2062
57db03be52ad (svn r2571) Add explicit type Pixel for ... Pixels
tron
parents: 2037
diff changeset
   714
	Pixel *dst;
5567
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
   715
	BlitterMode mode;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   716
	int width, height;
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
   717
	int width_org;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   718
	int pitch;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   719
} BlitterParams;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   720
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   721
static void GfxBlitTileZoomIn(BlitterParams *bp)
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   722
{
4171
5c6e60c392c3 (svn r5609) CodeChange : Apply coding style
belugas
parents: 3798
diff changeset
   723
	const byte *src_o = bp->sprite;
5c6e60c392c3 (svn r5609) CodeChange : Apply coding style
belugas
parents: 3798
diff changeset
   724
	const byte *src;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   725
	int num, skip;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   726
	byte done;
2062
57db03be52ad (svn r2571) Add explicit type Pixel for ... Pixels
tron
parents: 2037
diff changeset
   727
	Pixel *dst;
4171
5c6e60c392c3 (svn r5609) CodeChange : Apply coding style
belugas
parents: 3798
diff changeset
   728
	const byte *ctab;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   729
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   730
	src_o += ReadLE16Aligned(src_o + bp->start_y * 2);
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   731
	switch (bp->mode) {
5567
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
   732
		case BM_COLOUR_REMAP:
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   733
			do {
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   734
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   735
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   736
					num = done & 0x7F;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   737
					skip = src_o[1];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   738
					src = src_o + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   739
					src_o += num + 2;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   740
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   741
					dst = bp->dst;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   742
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   743
					if ( (skip -= bp->start_x) > 0) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   744
						dst += skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   745
					} else {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   746
						src -= skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   747
						num += skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   748
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   749
						skip = 0;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   750
					}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   751
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   752
					skip = skip + num - bp->width;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   753
					if (skip > 0) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   754
						num -= skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   755
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   756
					}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   757
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   758
					ctab = _color_remap_ptr;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   759
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   760
					for (; num >= 4; num -=4) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   761
						dst[3] = ctab[src[3]];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   762
						dst[2] = ctab[src[2]];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   763
						dst[1] = ctab[src[1]];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   764
						dst[0] = ctab[src[0]];
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   765
						dst += 4;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   766
						src += 4;
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   767
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   768
					for (; num != 0; num--) *dst++ = ctab[*src++];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   769
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   770
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   771
				bp->dst += bp->pitch;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   772
			} while (--bp->height != 0);
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   773
			break;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   774
5567
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
   775
		case BM_TRANSPARENT:
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   776
			do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   777
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   778
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   779
					num = done & 0x7F;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   780
					skip = src_o[1];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   781
					src_o += num + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   782
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   783
					dst = bp->dst;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   784
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   785
					if ( (skip -= bp->start_x) > 0) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   786
						dst += skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   787
					} else {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   788
						num += skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   789
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   790
						skip = 0;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   791
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   792
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   793
					skip = skip + num - bp->width;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   794
					if (skip > 0) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   795
						num -= skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   796
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   797
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   798
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   799
					ctab = _color_remap_ptr;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   800
					for (; num != 0; num--) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   801
						*dst = ctab[*dst];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   802
						dst++;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   803
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   804
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   805
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   806
				bp->dst += bp->pitch;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   807
			} while (--bp->height != 0);
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   808
			break;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   809
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   810
		default:
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   811
			do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   812
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   813
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   814
					num = done & 0x7F;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   815
					skip = src_o[1];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   816
					src = src_o + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   817
					src_o += num + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   818
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   819
					dst = bp->dst;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   820
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   821
					if ( (skip -= bp->start_x) > 0) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   822
						dst += skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   823
					} else {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   824
						src -= skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   825
						num += skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   826
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   827
						skip = 0;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   828
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   829
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   830
					skip = skip + num - bp->width;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   831
					if (skip > 0) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   832
						num -= skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   833
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   834
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   835
#if defined(_WIN32)
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   836
					if (num & 1) *dst++ = *src++;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   837
					if (num & 2) { *(uint16*)dst = *(uint16*)src; dst += 2; src += 2; }
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   838
					if (num >>= 2) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   839
						do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   840
							*(uint32*)dst = *(uint32*)src;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   841
							dst += 4;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   842
							src += 4;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   843
						} while (--num != 0);
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   844
					}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   845
#else
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   846
					memcpy(dst, src, num);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   847
#endif
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   848
				} while (!(done & 0x80));
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   849
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   850
				bp->dst += bp->pitch;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   851
			} while (--bp->height != 0);
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   852
			break;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   853
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   854
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   855
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   856
static void GfxBlitZoomInUncomp(BlitterParams *bp)
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   857
{
1357
0a4c07b68673 (svn r1861) Constify Get(Non)Sprite()
tron
parents: 1351
diff changeset
   858
	const byte *src = bp->sprite;
2062
57db03be52ad (svn r2571) Add explicit type Pixel for ... Pixels
tron
parents: 2037
diff changeset
   859
	Pixel *dst = bp->dst;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   860
	int height = bp->height;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   861
	int width = bp->width;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   862
	int i;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   863
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   864
	assert(height > 0);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   865
	assert(width > 0);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   866
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   867
	switch (bp->mode) {
5567
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
   868
		case BM_COLOUR_REMAP: {
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   869
			const byte *ctab = _color_remap_ptr;
2004
7b01b3dd4b7f (svn r2512) Small cleanup
tron
parents: 1997
diff changeset
   870
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   871
			do {
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   872
				for (i = 0; i != width; i++) {
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   873
					byte b = ctab[src[i]];
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   874
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   875
					if (b != 0) dst[i] = b;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   876
				}
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   877
				src += bp->width_org;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   878
				dst += bp->pitch;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   879
			} while (--height != 0);
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   880
			break;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   881
		}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   882
5567
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
   883
		case BM_TRANSPARENT: {
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   884
			const byte *ctab = _color_remap_ptr;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   885
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   886
			do {
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   887
				for (i = 0; i != width; i++)
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   888
					if (src[i] != 0) dst[i] = ctab[dst[i]];
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   889
				src += bp->width_org;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   890
				dst += bp->pitch;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   891
			} while (--height != 0);
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   892
			break;
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   893
		}
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   894
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   895
		default:
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   896
			do {
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   897
				int n = width;
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   898
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   899
				for (; n >= 4; n -= 4) {
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   900
					if (src[0] != 0) dst[0] = src[0];
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   901
					if (src[1] != 0) dst[1] = src[1];
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   902
					if (src[2] != 0) dst[2] = src[2];
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   903
					if (src[3] != 0) dst[3] = src[3];
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   904
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   905
					dst += 4;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   906
					src += 4;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   907
				}
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   908
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   909
				for (; n != 0; n--) {
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   910
					if (src[0] != 0) dst[0] = src[0];
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   911
					src++;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   912
					dst++;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   913
				}
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   914
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   915
				src += bp->width_org - width;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   916
				dst += bp->pitch - width;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
   917
			} while (--height != 0);
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   918
			break;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   919
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   920
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   921
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   922
static void GfxBlitTileZoomMedium(BlitterParams *bp)
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   923
{
4171
5c6e60c392c3 (svn r5609) CodeChange : Apply coding style
belugas
parents: 3798
diff changeset
   924
	const byte *src_o = bp->sprite;
5c6e60c392c3 (svn r5609) CodeChange : Apply coding style
belugas
parents: 3798
diff changeset
   925
	const byte *src;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   926
	int num, skip;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   927
	byte done;
2062
57db03be52ad (svn r2571) Add explicit type Pixel for ... Pixels
tron
parents: 2037
diff changeset
   928
	Pixel *dst;
4171
5c6e60c392c3 (svn r5609) CodeChange : Apply coding style
belugas
parents: 3798
diff changeset
   929
	const byte *ctab;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   930
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   931
	src_o += ReadLE16Aligned(src_o + bp->start_y * 2);
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   932
	switch (bp->mode) {
5567
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
   933
		case BM_COLOUR_REMAP:
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   934
			do {
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   935
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   936
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   937
					num = done & 0x7F;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   938
					skip = src_o[1];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   939
					src = src_o + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   940
					src_o += num + 2;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   941
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   942
					dst = bp->dst;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   943
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   944
					if (skip & 1) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   945
						skip++;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   946
						src++;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   947
						if (--num == 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   948
					}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   949
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   950
					if ( (skip -= bp->start_x) > 0) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   951
						dst += skip >> 1;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   952
					} else {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   953
						src -= skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   954
						num += skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   955
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   956
						skip = 0;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   957
					}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   958
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   959
					skip = skip + num - bp->width;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   960
					if (skip > 0) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   961
						num -= skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   962
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   963
					}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   964
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   965
					ctab = _color_remap_ptr;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   966
					num = (num + 1) >> 1;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   967
					for (; num != 0; num--) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   968
							*dst = ctab[*src];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   969
							dst++;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   970
							src += 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   971
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   972
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   973
				bp->dst += bp->pitch;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   974
				if (--bp->height == 0) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   975
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   976
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   977
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   978
					src_o += (done & 0x7F) + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   979
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   980
			} while (--bp->height != 0);
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   981
			break;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   982
5567
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
   983
		case BM_TRANSPARENT:
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   984
			do {
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   985
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   986
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   987
					num = done & 0x7F;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   988
					skip = src_o[1];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   989
					src_o += num + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   990
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   991
					dst = bp->dst;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   992
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   993
					if (skip & 1) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   994
						skip++;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   995
						if (--num == 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   996
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   997
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   998
					if ( (skip -= bp->start_x) > 0) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
   999
						dst += skip >> 1;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1000
					} else {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1001
						num += skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1002
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1003
						skip = 0;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1004
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1005
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1006
					skip = skip + num - bp->width;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1007
					if (skip > 0) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1008
						num -= skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1009
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1010
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1011
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1012
					ctab = _color_remap_ptr;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1013
					num = (num + 1) >> 1;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1014
					for (; num != 0; num--) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1015
							*dst = ctab[*dst];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1016
							dst++;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1017
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1018
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1019
				bp->dst += bp->pitch;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1020
				if (--bp->height == 0) return;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1021
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1022
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1023
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1024
					src_o += (done & 0x7F) + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1025
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1026
			} while (--bp->height != 0);
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1027
			break;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1028
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1029
		default:
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1030
			do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1031
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1032
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1033
					num = done & 0x7F;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1034
					skip = src_o[1];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1035
					src = src_o + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1036
					src_o += num + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1037
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1038
					dst = bp->dst;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1039
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1040
					if (skip & 1) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1041
						skip++;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1042
						src++;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1043
						if (--num == 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1044
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1045
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1046
					if ( (skip -= bp->start_x) > 0) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1047
						dst += skip >> 1;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1048
					} else {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1049
						src -= skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1050
						num += skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1051
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1052
						skip = 0;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1053
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1054
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1055
					skip = skip + num - bp->width;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1056
					if (skip > 0) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1057
						num -= skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1058
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1059
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1060
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1061
					num = (num + 1) >> 1;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1062
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1063
					for (; num != 0; num--) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1064
							*dst = *src;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1065
							dst++;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1066
							src += 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1067
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1068
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1069
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1070
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1071
				bp->dst += bp->pitch;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1072
				if (--bp->height == 0) return;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1073
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1074
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1075
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1076
					src_o += (done & 0x7F) + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1077
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1078
			} while (--bp->height != 0);
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1079
			break;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1080
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1081
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1082
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1083
static void GfxBlitZoomMediumUncomp(BlitterParams *bp)
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1084
{
1357
0a4c07b68673 (svn r1861) Constify Get(Non)Sprite()
tron
parents: 1351
diff changeset
  1085
	const byte *src = bp->sprite;
2062
57db03be52ad (svn r2571) Add explicit type Pixel for ... Pixels
tron
parents: 2037
diff changeset
  1086
	Pixel *dst = bp->dst;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1087
	int height = bp->height;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1088
	int width = bp->width;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1089
	int i;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1090
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1091
	assert(height > 0);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1092
	assert(width > 0);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1093
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1094
	switch (bp->mode) {
5567
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
  1095
		case BM_COLOUR_REMAP: {
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1096
			const byte *ctab = _color_remap_ptr;
1357
0a4c07b68673 (svn r1861) Constify Get(Non)Sprite()
tron
parents: 1351
diff changeset
  1097
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1098
			for (height >>= 1; height != 0; height--) {
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1099
				for (i = 0; i != width >> 1; i++) {
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1100
					byte b = ctab[src[i * 2]];
1996
e87f196b0ba9 (svn r2502) Small cleanup
tron
parents: 1991
diff changeset
  1101
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1102
					if (b != 0) dst[i] = b;
1996
e87f196b0ba9 (svn r2502) Small cleanup
tron
parents: 1991
diff changeset
  1103
				}
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1104
				src += bp->width_org * 2;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1105
				dst += bp->pitch;
1996
e87f196b0ba9 (svn r2502) Small cleanup
tron
parents: 1991
diff changeset
  1106
			}
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1107
			break;
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1108
		}
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1109
5567
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
  1110
		case BM_TRANSPARENT: {
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1111
			const byte *ctab = _color_remap_ptr;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1112
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1113
			for (height >>= 1; height != 0; height--) {
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1114
				for (i = 0; i != width >> 1; i++)
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1115
					if (src[i * 2] != 0) dst[i] = ctab[dst[i]];
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1116
				src += bp->width_org * 2;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1117
				dst += bp->pitch;
1996
e87f196b0ba9 (svn r2502) Small cleanup
tron
parents: 1991
diff changeset
  1118
			}
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1119
			break;
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1120
		}
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1121
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1122
		default:
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1123
			for (height >>= 1; height != 0; height--) {
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1124
				for (i = 0; i != width >> 1; i++)
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1125
					if (src[i * 2] != 0) dst[i] = src[i * 2];
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1126
				src += bp->width_org * 2;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1127
				dst += bp->pitch;
1996
e87f196b0ba9 (svn r2502) Small cleanup
tron
parents: 1991
diff changeset
  1128
			}
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1129
			break;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1130
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1131
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1132
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1133
static void GfxBlitTileZoomOut(BlitterParams *bp)
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1134
{
4171
5c6e60c392c3 (svn r5609) CodeChange : Apply coding style
belugas
parents: 3798
diff changeset
  1135
	const byte *src_o = bp->sprite;
5c6e60c392c3 (svn r5609) CodeChange : Apply coding style
belugas
parents: 3798
diff changeset
  1136
	const byte *src;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1137
	int num, skip;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1138
	byte done;
2062
57db03be52ad (svn r2571) Add explicit type Pixel for ... Pixels
tron
parents: 2037
diff changeset
  1139
	Pixel *dst;
4171
5c6e60c392c3 (svn r5609) CodeChange : Apply coding style
belugas
parents: 3798
diff changeset
  1140
	const byte *ctab;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1141
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1142
	src_o += ReadLE16Aligned(src_o + bp->start_y * 2);
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1143
	switch (bp->mode) {
5567
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
  1144
		case BM_COLOUR_REMAP:
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1145
			for (;;) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1146
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1147
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1148
					num = done & 0x7F;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1149
					skip = src_o[1];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1150
					src = src_o + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1151
					src_o += num + 2;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1152
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1153
					dst = bp->dst;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1154
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1155
					if (skip & 1) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1156
						skip++;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1157
						src++;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1158
						if (--num == 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1159
					}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1160
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1161
					if (skip & 2) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1162
						skip += 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1163
						src += 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1164
						num -= 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1165
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1166
					}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1167
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1168
					if ( (skip -= bp->start_x) > 0) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1169
						dst += skip >> 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1170
					} else {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1171
						src -= skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1172
						num += skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1173
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1174
						skip = 0;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1175
					}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1176
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1177
					skip = skip + num - bp->width;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1178
					if (skip > 0) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1179
						num -= skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1180
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1181
					}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1182
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1183
					ctab = _color_remap_ptr;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1184
					num = (num + 3) >> 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1185
					for (; num != 0; num--) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1186
							*dst = ctab[*src];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1187
							dst++;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1188
							src += 4;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1189
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1190
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1191
				bp->dst += bp->pitch;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1192
				if (--bp->height == 0) return;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1193
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1194
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1195
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1196
					src_o += (done & 0x7F) + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1197
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1198
				if (--bp->height == 0) return;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1199
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1200
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1201
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1202
					src_o += (done & 0x7F) + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1203
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1204
				if (--bp->height == 0) return;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1205
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1206
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1207
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1208
					src_o += (done & 0x7F) + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1209
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1210
				if (--bp->height == 0) return;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1211
			}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1212
			break;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1213
5567
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
  1214
		case BM_TRANSPARENT:
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1215
			for (;;) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1216
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1217
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1218
					num = done & 0x7F;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1219
					skip = src_o[1];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1220
					src_o += num + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1221
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1222
					dst = bp->dst;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1223
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1224
					if (skip & 1) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1225
						skip++;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1226
						if (--num == 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1227
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1228
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1229
					if (skip & 2) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1230
						skip += 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1231
						num -= 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1232
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1233
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1234
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1235
					if ( (skip -= bp->start_x) > 0) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1236
						dst += skip >> 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1237
					} else {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1238
						num += skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1239
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1240
						skip = 0;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1241
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1242
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1243
					skip = skip + num - bp->width;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1244
					if (skip > 0) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1245
						num -= skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1246
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1247
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1248
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1249
					ctab = _color_remap_ptr;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1250
					num = (num + 3) >> 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1251
					for (; num != 0; num--) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1252
							*dst = ctab[*dst];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1253
							dst++;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1254
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1255
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1256
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1257
				bp->dst += bp->pitch;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1258
				if (--bp->height == 0) return;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1259
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1260
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1261
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1262
					src_o += (done & 0x7F) + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1263
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1264
				if (--bp->height == 0) return;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1265
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1266
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1267
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1268
					src_o += (done & 0x7F) + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1269
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1270
				if (--bp->height == 0) return;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1271
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1272
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1273
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1274
					src_o += (done & 0x7F) + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1275
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1276
				if (--bp->height == 0) return;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1277
			}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1278
			break;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1279
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1280
		default:
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1281
			for (;;) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1282
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1283
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1284
					num = done & 0x7F;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1285
					skip = src_o[1];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1286
					src = src_o + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1287
					src_o += num + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1288
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1289
					dst = bp->dst;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1290
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1291
					if (skip & 1) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1292
						skip++;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1293
						src++;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1294
						if (--num == 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1295
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1296
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1297
					if (skip & 2) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1298
						skip += 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1299
						src += 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1300
						num -= 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1301
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1302
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1303
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1304
					if ( (skip -= bp->start_x) > 0) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1305
						dst += skip >> 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1306
					} else {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1307
						src -= skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1308
						num += skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1309
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1310
						skip = 0;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1311
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1312
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1313
					skip = skip + num - bp->width;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1314
					if (skip > 0) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1315
						num -= skip;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1316
						if (num <= 0) continue;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1317
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1318
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1319
					num = (num + 3) >> 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1320
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1321
					for (; num != 0; num--) {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1322
							*dst = *src;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1323
							dst++;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1324
							src += 4;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1325
					}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1326
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1327
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1328
				bp->dst += bp->pitch;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1329
				if (--bp->height == 0) return;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1330
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1331
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1332
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1333
					src_o += (done & 0x7F) + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1334
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1335
				if (--bp->height == 0) return;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1336
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1337
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1338
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1339
					src_o += (done & 0x7F) + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1340
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1341
				if (--bp->height == 0) return;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1342
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1343
				do {
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1344
					done = src_o[0];
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1345
					src_o += (done & 0x7F) + 2;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1346
				} while (!(done & 0x80));
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1347
				if (--bp->height == 0) return;
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1348
			}
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1349
			break;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1350
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1351
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1352
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1353
static void GfxBlitZoomOutUncomp(BlitterParams *bp)
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1354
{
4171
5c6e60c392c3 (svn r5609) CodeChange : Apply coding style
belugas
parents: 3798
diff changeset
  1355
	const byte *src = bp->sprite;
2062
57db03be52ad (svn r2571) Add explicit type Pixel for ... Pixels
tron
parents: 2037
diff changeset
  1356
	Pixel *dst = bp->dst;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1357
	int height = bp->height;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1358
	int width = bp->width;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1359
	int i;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1360
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1361
	assert(height > 0);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1362
	assert(width > 0);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1363
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1364
	switch (bp->mode) {
5567
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
  1365
		case BM_COLOUR_REMAP: {
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1366
			const byte *ctab = _color_remap_ptr;
1357
0a4c07b68673 (svn r1861) Constify Get(Non)Sprite()
tron
parents: 1351
diff changeset
  1367
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1368
			for (height >>= 2; height != 0; height--) {
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1369
				for (i = 0; i != width >> 2; i++) {
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1370
					byte b = ctab[src[i * 4]];
1996
e87f196b0ba9 (svn r2502) Small cleanup
tron
parents: 1991
diff changeset
  1371
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1372
					if (b != 0) dst[i] = b;
1996
e87f196b0ba9 (svn r2502) Small cleanup
tron
parents: 1991
diff changeset
  1373
				}
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1374
				src += bp->width_org * 4;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1375
				dst += bp->pitch;
1996
e87f196b0ba9 (svn r2502) Small cleanup
tron
parents: 1991
diff changeset
  1376
			}
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1377
			break;
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1378
		}
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1379
5567
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
  1380
		case BM_TRANSPARENT: {
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1381
			const byte *ctab = _color_remap_ptr;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1382
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1383
			for (height >>= 2; height != 0; height--) {
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1384
				for (i = 0; i != width >> 2; i++)
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1385
					if (src[i * 4] != 0) dst[i] = ctab[dst[i]];
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1386
				src += bp->width_org * 4;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1387
				dst += bp->pitch;
1996
e87f196b0ba9 (svn r2502) Small cleanup
tron
parents: 1991
diff changeset
  1388
			}
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1389
			break;
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1390
		}
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1391
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1392
		default:
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1393
			for (height >>= 2; height != 0; height--) {
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1394
				for (i = 0; i != width >> 2; i++)
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1395
					if (src[i * 4] != 0) dst[i] = src[i * 4];
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1396
				src += bp->width_org * 4;
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1397
				dst += bp->pitch;
1996
e87f196b0ba9 (svn r2502) Small cleanup
tron
parents: 1991
diff changeset
  1398
			}
4516
6ab9dfa5d293 (svn r6301) -Codechange: if () cascades -> switch ()
tron
parents: 4437
diff changeset
  1399
			break;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1400
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1401
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1402
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1403
5567
fe00ab53909b (svn r7982) -Codechange: Enumify graphics blitter modes.
peter1138
parents: 5475
diff changeset
  1404
static void GfxMainBlitter(const Sprite *sprite, int x, int y, BlitterMode mode)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1405
{
4171
5c6e60c392c3 (svn r5609) CodeChange : Apply coding style
belugas
parents: 3798
diff changeset
  1406
	const DrawPixelInfo *dpi = _cur_dpi;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1407
	int start_x, start_y;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1408
	BlitterParams bp;
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1409
	int zoom_mask = ~((1 << dpi->zoom) - 1);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1410
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1411
	/* decode sprite header */
1351
a08ab043dd08 (svn r1855) Handle endianness of sprite headers when loading a sprite, not everytime when accessing it
tron
parents: 1350
diff changeset
  1412
	x += sprite->x_offs;
a08ab043dd08 (svn r1855) Handle endianness of sprite headers when loading a sprite, not everytime when accessing it
tron
parents: 1350
diff changeset
  1413
	y += sprite->y_offs;
a08ab043dd08 (svn r1855) Handle endianness of sprite headers when loading a sprite, not everytime when accessing it
tron
parents: 1350
diff changeset
  1414
	bp.width_org = bp.width = sprite->width;
4518
2d003b496097 (svn r6303) -Codechange: Remove dead code
tron
parents: 4517
diff changeset
  1415
	bp.height = sprite->height;
2d003b496097 (svn r6303) -Codechange: Remove dead code
tron
parents: 4517
diff changeset
  1416
	bp.sprite = sprite->data;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1417
	bp.dst = dpi->dst_ptr;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1418
	bp.mode = mode;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1419
	bp.pitch = dpi->pitch;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1420
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1421
	assert(bp.height > 0);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1422
	assert(bp.width > 0);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1423
4517
2ec69fcbafa8 (svn r6302) -Codechange: Remove dead code paths, because the lowest bit of Sprite::info is never unset
tron
parents: 4516
diff changeset
  1424
	if (sprite->info & 8) {
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1425
		/* tile blit */
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1426
		start_y = 0;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1427
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1428
		if (dpi->zoom > 0) {
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1429
			start_y += bp.height & ~zoom_mask;
193
0a7025304867 (svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents: 126
diff changeset
  1430
			bp.height &= zoom_mask;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1431
			if (bp.height == 0) return;
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1432
			y &= zoom_mask;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1433
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1434
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1435
		if ( (y -= dpi->top) < 0) {
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1436
			bp.height += y;
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1437
			if (bp.height <= 0) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1438
			start_y -= y;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1439
			y = 0;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1440
		} else {
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1441
			bp.dst += bp.pitch * (y >> dpi->zoom);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1442
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1443
		bp.start_y = start_y;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1444
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1445
		if ( (y = y + bp.height - dpi->height) > 0) {
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1446
			bp.height -= y;
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1447
			if (bp.height <= 0) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1448
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1449
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1450
		start_x = 0;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1451
		x &= zoom_mask;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1452
		if ( (x -= dpi->left) < 0) {
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1453
			bp.width += x;
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1454
			if (bp.width <= 0) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1455
			start_x -= x;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1456
			x = 0;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1457
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1458
		bp.start_x = start_x;
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1459
		bp.dst += x >> dpi->zoom;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1460
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1461
		if ( (x = x + bp.width - dpi->width) > 0) {
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1462
			bp.width -= x;
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1463
			if (bp.width <= 0) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1464
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1465
4425
f15ad32f87e5 (svn r6180) Use a switch instead of function pointers to choose the blitter
tron
parents: 4344
diff changeset
  1466
		switch (dpi->zoom) {
f15ad32f87e5 (svn r6180) Use a switch instead of function pointers to choose the blitter
tron
parents: 4344
diff changeset
  1467
			default: NOT_REACHED();
f15ad32f87e5 (svn r6180) Use a switch instead of function pointers to choose the blitter
tron
parents: 4344
diff changeset
  1468
			case 0: GfxBlitTileZoomIn(&bp);     break;
f15ad32f87e5 (svn r6180) Use a switch instead of function pointers to choose the blitter
tron
parents: 4344
diff changeset
  1469
			case 1: GfxBlitTileZoomMedium(&bp); break;
f15ad32f87e5 (svn r6180) Use a switch instead of function pointers to choose the blitter
tron
parents: 4344
diff changeset
  1470
			case 2: GfxBlitTileZoomOut(&bp);    break;
f15ad32f87e5 (svn r6180) Use a switch instead of function pointers to choose the blitter
tron
parents: 4344
diff changeset
  1471
		}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1472
	} else {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1473
		bp.sprite += bp.width * (bp.height & ~zoom_mask);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1474
		bp.height &= zoom_mask;
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1475
		if (bp.height == 0) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1476
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1477
		y &= zoom_mask;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1478
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1479
		if ( (y -= dpi->top) < 0) {
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1480
			bp.height += y;
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1481
			if (bp.height <= 0) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1482
			bp.sprite -= bp.width * y;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1483
			y = 0;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1484
		} else {
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1485
			bp.dst += bp.pitch * (y >> dpi->zoom);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1486
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1487
2037
1e138067c272 (svn r2546) Don't calculate a value which never gets used and simplify some calculations
tron
parents: 2025
diff changeset
  1488
		if (bp.height > dpi->height - y) {
1e138067c272 (svn r2546) Don't calculate a value which never gets used and simplify some calculations
tron
parents: 2025
diff changeset
  1489
			bp.height = dpi->height - y;
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1490
			if (bp.height <= 0) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1491
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1492
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1493
		x &= zoom_mask;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1494
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1495
		if ( (x -= dpi->left) < 0) {
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1496
			bp.width += x;
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1497
			if (bp.width <= 0) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1498
			bp.sprite -= x;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1499
			x = 0;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1500
		}
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1501
		bp.dst += x >> dpi->zoom;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1502
2037
1e138067c272 (svn r2546) Don't calculate a value which never gets used and simplify some calculations
tron
parents: 2025
diff changeset
  1503
		if (bp.width > dpi->width - x) {
1e138067c272 (svn r2546) Don't calculate a value which never gets used and simplify some calculations
tron
parents: 2025
diff changeset
  1504
			bp.width = dpi->width - x;
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1505
			if (bp.width <= 0) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1506
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1507
4425
f15ad32f87e5 (svn r6180) Use a switch instead of function pointers to choose the blitter
tron
parents: 4344
diff changeset
  1508
		switch (dpi->zoom) {
f15ad32f87e5 (svn r6180) Use a switch instead of function pointers to choose the blitter
tron
parents: 4344
diff changeset
  1509
			default: NOT_REACHED();
f15ad32f87e5 (svn r6180) Use a switch instead of function pointers to choose the blitter
tron
parents: 4344
diff changeset
  1510
			case 0: GfxBlitZoomInUncomp(&bp);     break;
f15ad32f87e5 (svn r6180) Use a switch instead of function pointers to choose the blitter
tron
parents: 4344
diff changeset
  1511
			case 1: GfxBlitZoomMediumUncomp(&bp); break;
f15ad32f87e5 (svn r6180) Use a switch instead of function pointers to choose the blitter
tron
parents: 4344
diff changeset
  1512
			case 2: GfxBlitZoomOutUncomp(&bp);    break;
f15ad32f87e5 (svn r6180) Use a switch instead of function pointers to choose the blitter
tron
parents: 4344
diff changeset
  1513
		}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1514
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1515
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1516
1093
4fdc46eaf423 (svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents: 1056
diff changeset
  1517
void DoPaletteAnimations(void);
614
b96f987dbf80 (svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents: 543
diff changeset
  1518
1093
4fdc46eaf423 (svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents: 1056
diff changeset
  1519
void GfxInitPalettes(void)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1520
{
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1521
	memcpy(_cur_palette, _palettes[_use_dos_palette ? 1 : 0], sizeof(_cur_palette));
614
b96f987dbf80 (svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents: 543
diff changeset
  1522
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1523
	_pal_first_dirty = 0;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1524
	_pal_last_dirty = 255;
614
b96f987dbf80 (svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents: 543
diff changeset
  1525
	DoPaletteAnimations();
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1526
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1527
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1528
#define EXTR(p, q) (((uint16)(_timer_counter * (p)) * (q)) >> 16)
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1529
#define EXTR2(p, q) (((uint16)(~_timer_counter * (p)) * (q)) >> 16)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1530
1093
4fdc46eaf423 (svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents: 1056
diff changeset
  1531
void DoPaletteAnimations(void)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1532
{
4171
5c6e60c392c3 (svn r5609) CodeChange : Apply coding style
belugas
parents: 3798
diff changeset
  1533
	const Colour *s;
5c6e60c392c3 (svn r5609) CodeChange : Apply coding style
belugas
parents: 3798
diff changeset
  1534
	Colour *d;
614
b96f987dbf80 (svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents: 543
diff changeset
  1535
	/* Amount of colors to be rotated.
b96f987dbf80 (svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents: 543
diff changeset
  1536
	 * A few more for the DOS palette, because the water colors are
b96f987dbf80 (svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents: 543
diff changeset
  1537
	 * 245-254 for DOS and 217-226 for Windows.  */
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1538
	const ExtraPaletteValues *ev = &_extra_palette_values;
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1539
	int c = _use_dos_palette ? 38 : 28;
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1540
	Colour old_val[38]; // max(38, 28)
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1541
	uint i;
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1542
	uint j;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1543
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1544
	d = &_cur_palette[217];
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1545
	memcpy(old_val, d, c * sizeof(*old_val));
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1546
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1547
	// Dark blue water
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1548
	s = (_opt.landscape == LT_CANDY) ? ev->ac : ev->a;
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1549
	j = EXTR(320, 5);
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1550
	for (i = 0; i != 5; i++) {
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1551
		*d++ = s[j];
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1552
		j++;
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1553
		if (j == 5) j = 0;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1554
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1555
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1556
	// Glittery water
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1557
	s = (_opt.landscape == LT_CANDY) ? ev->bc : ev->b;
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1558
	j = EXTR(128, 15);
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1559
	for (i = 0; i != 5; i++) {
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1560
		*d++ = s[j];
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1561
		j += 3;
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1562
		if (j >= 15) j -= 15;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1563
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1564
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1565
	s = ev->e;
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1566
	j = EXTR2(512, 5);
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1567
	for (i = 0; i != 5; i++) {
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1568
		*d++ = s[j];
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1569
		j++;
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1570
		if (j == 5) j = 0;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1571
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1572
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1573
	// Oil refinery fire animation
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1574
	s = ev->oil_ref;
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1575
	j = EXTR2(512, 7);
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1576
	for (i = 0; i != 7; i++) {
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1577
		*d++ = s[j];
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1578
		j++;
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1579
		if (j == 7) j = 0;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1580
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1581
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1582
	// Radio tower blinking
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1583
	{
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1584
		byte i = (_timer_counter >> 1) & 0x7F;
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1585
		byte v;
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1586
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1587
		(v = 255, i < 0x3f) ||
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1588
		(v = 128, i < 0x4A || i >= 0x75) ||
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1589
		(v = 20);
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1590
		d->r = v;
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1591
		d->g = 0;
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1592
		d->b = 0;
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1593
		d++;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1594
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1595
		i ^= 0x40;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1596
		(v = 255, i < 0x3f) ||
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1597
		(v = 128, i < 0x4A || i >= 0x75) ||
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1598
		(v = 20);
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1599
		d->r = v;
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1600
		d->g = 0;
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1601
		d->b = 0;
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1602
		d++;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1603
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1604
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1605
	// Handle lighthouse and stadium animation
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1606
	s = ev->lighthouse;
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1607
	j = EXTR(256, 4);
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1608
	for (i = 0; i != 4; i++) {
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1609
		*d++ = s[j];
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1610
		j++;
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1611
		if (j == 4) j = 0;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1612
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1613
614
b96f987dbf80 (svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents: 543
diff changeset
  1614
	// Animate water for old DOS graphics
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1615
	if (_use_dos_palette) {
614
b96f987dbf80 (svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents: 543
diff changeset
  1616
		// Dark blue water DOS
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1617
		s = (_opt.landscape == LT_CANDY) ? ev->ac : ev->a;
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1618
		j = EXTR(320, 5);
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1619
		for (i = 0; i != 5; i++) {
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1620
			*d++ = s[j];
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1621
			j++;
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1622
			if (j == 5) j = 0;
614
b96f987dbf80 (svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents: 543
diff changeset
  1623
		}
915
d845fe7cf6f2 (svn r1402) Trim trailing whitespace
tron
parents: 798
diff changeset
  1624
614
b96f987dbf80 (svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents: 543
diff changeset
  1625
		// Glittery water DOS
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1626
		s = (_opt.landscape == LT_CANDY) ? ev->bc : ev->b;
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1627
		j = EXTR(128, 15);
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1628
		for (i = 0; i != 5; i++) {
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1629
			*d++ = s[j];
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1630
			j += 3;
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1631
			if (j >= 15) j -= 15;
614
b96f987dbf80 (svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents: 543
diff changeset
  1632
		}
b96f987dbf80 (svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents: 543
diff changeset
  1633
	}
b96f987dbf80 (svn r1038) Feature: OpenTTD runs with the grf files of the DOS version
dominik
parents: 543
diff changeset
  1634
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1635
	if (memcmp(old_val, &_cur_palette[217], c * sizeof(*old_val)) != 0) {
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1636
		if (_pal_first_dirty > 217) _pal_first_dirty = 217;
1991
4ce69ba880b4 (svn r2497) Use a struct array for palette entries instead of a flat byte array
tron
parents: 1914
diff changeset
  1637
		if (_pal_last_dirty < 217 + c) _pal_last_dirty = 217 + c;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1638
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1639
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1640
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1641
1093
4fdc46eaf423 (svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents: 1056
diff changeset
  1642
void LoadStringWidthTable(void)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1643
{
2005
2fe1516d45c5 (svn r2513) Small cleanup
tron
parents: 2004
diff changeset
  1644
	uint i;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1645
3797
db2306464bbe (svn r4793) - Replace list of magic numbers (characters that don't exist) with a call to SpriteExists(), when building the character width cache.
peter1138
parents: 3312
diff changeset
  1646
	/* Normal font */
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
  1647
	for (i = 0; i != 224; i++) {
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
  1648
		_stringwidth_table[FS_NORMAL][i] = GetGlyphWidth(FS_NORMAL, i + 32);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1649
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1650
3797
db2306464bbe (svn r4793) - Replace list of magic numbers (characters that don't exist) with a call to SpriteExists(), when building the character width cache.
peter1138
parents: 3312
diff changeset
  1651
	/* Small font */
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
  1652
	for (i = 0; i != 224; i++) {
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
  1653
		_stringwidth_table[FS_SMALL][i] = GetGlyphWidth(FS_SMALL, i + 32);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1654
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1655
3797
db2306464bbe (svn r4793) - Replace list of magic numbers (characters that don't exist) with a call to SpriteExists(), when building the character width cache.
peter1138
parents: 3312
diff changeset
  1656
	/* Large font */
3798
b1f5290b36b1 (svn r4802) - Codechange: replace _stringwidth_base and associated magic numbers with a FontSize enum, using the numbers (which are SpriteIDs) in only the places needed.
peter1138
parents: 3797
diff changeset
  1657
	for (i = 0; i != 224; i++) {
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
  1658
		_stringwidth_table[FS_LARGE][i] = GetGlyphWidth(FS_LARGE, i + 32);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1659
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1660
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1661
5108
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
  1662
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
  1663
byte GetCharacterWidth(FontSize size, WChar key)
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
  1664
{
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
  1665
	if (key >= 32 && key < 256) return _stringwidth_table[size][key - 32];
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
  1666
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
  1667
	return GetGlyphWidth(size, key);
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
  1668
}
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
  1669
aeaef6fe53b7 (svn r7182) -Feature: Merge utf8 branch. This brings us support for Unicode/UTF-8 and the option for fonts rendered by FreeType. Language changes to come.
peter1138
parents: 4958
diff changeset
  1670
1093
4fdc46eaf423 (svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents: 1056
diff changeset
  1671
void ScreenSizeChanged(void)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1672
{
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1673
	// check the dirty rect
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1674
	if (_invalid_rect.right >= _screen.width) _invalid_rect.right = _screen.width;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1675
	if (_invalid_rect.bottom >= _screen.height) _invalid_rect.bottom = _screen.height;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1676
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1677
	// screen size changed and the old bitmap is invalid now, so we don't want to undraw it
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1678
	_cursor.visible = false;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1679
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1680
1093
4fdc46eaf423 (svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents: 1056
diff changeset
  1681
void UndrawMouseCursor(void)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1682
{
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1683
	if (_cursor.visible) {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1684
		_cursor.visible = false;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1685
		memcpy_pitch(
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1686
			_screen.dst_ptr + _cursor.draw_pos.x + _cursor.draw_pos.y * _screen.pitch,
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1687
			_cursor_backup,
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1688
			_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
  1689
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1690
		_video_driver->make_dirty(_cursor.draw_pos.x, _cursor.draw_pos.y, _cursor.draw_size.x, _cursor.draw_size.y);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1691
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1692
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1693
1093
4fdc46eaf423 (svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents: 1056
diff changeset
  1694
void DrawMouseCursor(void)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1695
{
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1696
	int x;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1697
	int y;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1698
	int w;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1699
	int h;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1700
3312
d28f88dc5587 (svn r4075) - Feature: Undraw the mouse when it leaves the window and Draw it again when it enters. Added both for WIN32 and SDL. Since Win95 has troubles with TrackMouseEvent(), this function was just simply rewritten which was the easiest. Based on a patch by DmitryKo.
Darkvater
parents: 3252
diff changeset
  1701
	/* Redraw mouse cursor but only when it's inside the window */
d28f88dc5587 (svn r4075) - Feature: Undraw the mouse when it leaves the window and Draw it again when it enters. Added both for WIN32 and SDL. Since Win95 has troubles with TrackMouseEvent(), this function was just simply rewritten which was the easiest. Based on a patch by DmitryKo.
Darkvater
parents: 3252
diff changeset
  1702
	if (!_cursor.in_window) return;
d28f88dc5587 (svn r4075) - Feature: Undraw the mouse when it leaves the window and Draw it again when it enters. Added both for WIN32 and SDL. Since Win95 has troubles with TrackMouseEvent(), this function was just simply rewritten which was the easiest. Based on a patch by DmitryKo.
Darkvater
parents: 3252
diff changeset
  1703
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1704
	// Don't draw the mouse cursor if it's already drawn
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1705
	if (_cursor.visible) {
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1706
		if (!_cursor.dirty) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1707
		UndrawMouseCursor();
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1708
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1709
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1710
	w = _cursor.size.x;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1711
	x = _cursor.pos.x + _cursor.offs.x;
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1712
	if (x < 0) {
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1713
		w += x;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1714
		x = 0;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1715
	}
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1716
	if (w > _screen.width - x) w = _screen.width - x;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1717
	if (w <= 0) return;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1718
	_cursor.draw_pos.x = x;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1719
	_cursor.draw_size.x = w;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1720
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1721
	h = _cursor.size.y;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1722
	y = _cursor.pos.y + _cursor.offs.y;
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1723
	if (y < 0) {
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1724
		h += y;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1725
		y = 0;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1726
	}
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1727
	if (h > _screen.height - y) h = _screen.height - y;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1728
	if (h <= 0) return;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1729
	_cursor.draw_pos.y = y;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1730
	_cursor.draw_size.y = h;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1731
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1732
	assert(w * h < (int)sizeof(_cursor_backup));
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1733
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1734
	// Make backup of stuff below cursor
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1735
	memcpy_pitch(
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1736
		_cursor_backup,
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1737
		_screen.dst_ptr + _cursor.draw_pos.x + _cursor.draw_pos.y * _screen.pitch,
306
9ba288cacf0a (svn r312) -Fix: [926105] ctrl + d bug. Longest outstanding bug has been fixed \o/ 2004-03-30 (Tron)
darkvater
parents: 298
diff changeset
  1738
		_cursor.draw_size.x, _cursor.draw_size.y, _screen.pitch, _cursor.draw_size.x);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1739
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1740
	// Draw cursor on screen
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1741
	_cur_dpi = &_screen;
5668
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
  1742
	DrawSprite(_cursor.sprite, _cursor.pal, _cursor.pos.x, _cursor.pos.y);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1743
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1744
	_video_driver->make_dirty(_cursor.draw_pos.x, _cursor.draw_pos.y, _cursor.draw_size.x, _cursor.draw_size.y);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1745
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1746
	_cursor.visible = true;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1747
	_cursor.dirty = false;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1748
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1749
798
8331baea2dc9 (svn r1268) -Fix: some warnings in gfx.c fixed
darkvater
parents: 657
diff changeset
  1750
#if defined(_DEBUG)
410
0efd84450b01 (svn r607) -Patch: [ 985102 ] static cleanup
tron
parents: 375
diff changeset
  1751
static void DbgScreenRect(int left, int top, int right, int bottom)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1752
{
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1753
	DrawPixelInfo dp;
4171
5c6e60c392c3 (svn r5609) CodeChange : Apply coding style
belugas
parents: 3798
diff changeset
  1754
	DrawPixelInfo *old;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1755
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1756
	old = _cur_dpi;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1757
	_cur_dpi = &dp;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1758
	dp = _screen;
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1759
	GfxFillRect(left, top, right - 1, bottom - 1, rand() & 255);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1760
	_cur_dpi = old;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1761
}
798
8331baea2dc9 (svn r1268) -Fix: some warnings in gfx.c fixed
darkvater
parents: 657
diff changeset
  1762
#endif
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1763
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1764
void RedrawScreenRect(int left, int top, int right, int bottom)
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1765
{
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1766
	assert(right <= _screen.width && bottom <= _screen.height);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1767
	if (_cursor.visible) {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1768
		if (right > _cursor.draw_pos.x &&
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1769
				left < _cursor.draw_pos.x + _cursor.draw_size.x &&
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1770
				bottom > _cursor.draw_pos.y &&
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1771
				top < _cursor.draw_pos.y + _cursor.draw_size.y) {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1772
			UndrawMouseCursor();
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1773
		}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1774
	}
543
946badd71033 (svn r942) -Merged branch/network back into the trunk
truelight
parents: 510
diff changeset
  1775
	UndrawTextMessage();
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1776
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1777
#if defined(_DEBUG)
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1778
	if (_dbg_screen_rect)
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1779
		DbgScreenRect(left, top, right, bottom);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1780
	else
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1781
#endif
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1782
		DrawOverlappedWindowForAll(left, top, right, bottom);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1783
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1784
	_video_driver->make_dirty(left, top, right - left, bottom - top);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1785
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1786
1093
4fdc46eaf423 (svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents: 1056
diff changeset
  1787
void DrawDirtyBlocks(void)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1788
{
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1789
	byte *b = _dirty_blocks;
2398
912f16512ce2 (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
  1790
	const int w = ALIGN(_screen.width, 64);
912f16512ce2 (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
  1791
	const int h = ALIGN(_screen.height, 8);
2025
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1792
	int x;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1793
	int y;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1794
4300
c7e43c47a2b9 (svn r5946) -Add: merged the TGP branch to mainline. TGP adds:
truelight
parents: 4171
diff changeset
  1795
	if (IsGeneratingWorld() && !IsGeneratingWorldReadyForPaint()) return;
c7e43c47a2b9 (svn r5946) -Add: merged the TGP branch to mainline. TGP adds:
truelight
parents: 4171
diff changeset
  1796
2025
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1797
	y = 0;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1798
	do {
2025
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1799
		x = 0;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1800
		do {
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1801
			if (*b != 0) {
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1802
				int left;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1803
				int top;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1804
				int right = x + 64;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1805
				int bottom = y;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1806
				byte *p = b;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1807
				int h2;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1808
2025
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1809
				// First try coalescing downwards
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1810
				do {
2025
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1811
					*p = 0;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1812
					p += DIRTY_BYTES_PER_LINE;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1813
					bottom += 8;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1814
				} while (bottom != h && *p != 0);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1815
2025
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1816
				// Try coalescing to the right too.
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1817
				h2 = (bottom - y) >> 3;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1818
				assert(h2 > 0);
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1819
				p = b;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1820
2025
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1821
				while (right != w) {
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1822
					byte *p2 = ++p;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1823
					int h = h2;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1824
					// Check if a full line of dirty flags is set.
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1825
					do {
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1826
						if (!*p2) goto no_more_coalesc;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1827
						p2 += DIRTY_BYTES_PER_LINE;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1828
					} while (--h != 0);
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1829
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1830
					// Wohoo, can combine it one step to the right!
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1831
					// Do that, and clear the bits.
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1832
					right += 64;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1833
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1834
					h = h2;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1835
					p2 = p;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1836
					do {
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1837
						*p2 = 0;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1838
						p2 += DIRTY_BYTES_PER_LINE;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1839
					} while (--h != 0);
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1840
				}
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1841
				no_more_coalesc:
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1842
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1843
				left = x;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1844
				top = y;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1845
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1846
				if (left   < _invalid_rect.left  ) left   = _invalid_rect.left;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1847
				if (top    < _invalid_rect.top   ) top    = _invalid_rect.top;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1848
				if (right  > _invalid_rect.right ) right  = _invalid_rect.right;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1849
				if (bottom > _invalid_rect.bottom) bottom = _invalid_rect.bottom;
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1850
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1851
				if (left < right && top < bottom) {
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1852
					RedrawScreenRect(left, top, right, bottom);
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1853
				}
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1854
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1855
			}
2025
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1856
		} while (b++, (x += 64) != w);
6d1723144029 (svn r2534) Small cleanup
tron
parents: 2014
diff changeset
  1857
	} while (b += -(w >> 6) + DIRTY_BYTES_PER_LINE, (y += 8) != h);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1858
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1859
	_invalid_rect.left = w;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1860
	_invalid_rect.top = h;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1861
	_invalid_rect.right = 0;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1862
	_invalid_rect.bottom = 0;
4300
c7e43c47a2b9 (svn r5946) -Add: merged the TGP branch to mainline. TGP adds:
truelight
parents: 4171
diff changeset
  1863
c7e43c47a2b9 (svn r5946) -Add: merged the TGP branch to mainline. TGP adds:
truelight
parents: 4171
diff changeset
  1864
	/* If we are generating a world, and waiting for a paint run, mark it here
c7e43c47a2b9 (svn r5946) -Add: merged the TGP branch to mainline. TGP adds:
truelight
parents: 4171
diff changeset
  1865
	 *  as done painting, so we can continue generating. */
c7e43c47a2b9 (svn r5946) -Add: merged the TGP branch to mainline. TGP adds:
truelight
parents: 4171
diff changeset
  1866
	if (IsGeneratingWorld() && IsGeneratingWorldReadyForPaint()) {
c7e43c47a2b9 (svn r5946) -Add: merged the TGP branch to mainline. TGP adds:
truelight
parents: 4171
diff changeset
  1867
		SetGeneratingWorldPaintStatus(false);
c7e43c47a2b9 (svn r5946) -Add: merged the TGP branch to mainline. TGP adds:
truelight
parents: 4171
diff changeset
  1868
	}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1869
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1870
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1871
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1872
void SetDirtyBlocks(int left, int top, int right, int bottom)
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1873
{
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1874
	byte *b;
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1875
	int width;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1876
	int height;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1877
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1878
	if (left < 0) left = 0;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1879
	if (top < 0) top = 0;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1880
	if (right > _screen.width) right = _screen.width;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1881
	if (bottom > _screen.height) bottom = _screen.height;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1882
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1883
	if (left >= right || top >= bottom) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1884
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1885
	if (left   < _invalid_rect.left  ) _invalid_rect.left   = left;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1886
	if (top    < _invalid_rect.top   ) _invalid_rect.top    = top;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1887
	if (right  > _invalid_rect.right ) _invalid_rect.right  = right;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1888
	if (bottom > _invalid_rect.bottom) _invalid_rect.bottom = bottom;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1889
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1890
	left >>= 6;
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1891
	top  >>= 3;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1892
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1893
	b = _dirty_blocks + top * DIRTY_BYTES_PER_LINE + left;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1894
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1895
	width  = ((right  - 1) >> 6) - left + 1;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1896
	height = ((bottom - 1) >> 3) - top  + 1;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1897
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1898
	assert(width > 0 && height > 0);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1899
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1900
	do {
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1901
		int i = width;
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1902
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1903
		do b[--i] = 0xFF; while (i);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1904
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1905
		b += DIRTY_BYTES_PER_LINE;
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1906
	} while (--height != 0);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1907
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1908
1093
4fdc46eaf423 (svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents: 1056
diff changeset
  1909
void MarkWholeScreenDirty(void)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1910
{
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1911
	SetDirtyBlocks(0, 0, _screen.width, _screen.height);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1912
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1913
4958
5bf9f412940a (svn r6957) -Cleanup: comments, coding style
Darkvater
parents: 4954
diff changeset
  1914
/** Set up a clipping area for only drawing into a certain area. To do this,
5bf9f412940a (svn r6957) -Cleanup: comments, coding style
Darkvater
parents: 4954
diff changeset
  1915
 * Fill a DrawPixelInfo object with the supplied relative rectangle, backup
5bf9f412940a (svn r6957) -Cleanup: comments, coding style
Darkvater
parents: 4954
diff changeset
  1916
 * the original (calling) _cur_dpi and assign the just returned DrawPixelInfo
5bf9f412940a (svn r6957) -Cleanup: comments, coding style
Darkvater
parents: 4954
diff changeset
  1917
 * _cur_dpi. When you are done, give restore _cur_dpi's original value
5bf9f412940a (svn r6957) -Cleanup: comments, coding style
Darkvater
parents: 4954
diff changeset
  1918
 * @param *n the DrawPixelInfo that will be the clipping rectangle box allowed
5bf9f412940a (svn r6957) -Cleanup: comments, coding style
Darkvater
parents: 4954
diff changeset
  1919
 * for drawing
5bf9f412940a (svn r6957) -Cleanup: comments, coding style
Darkvater
parents: 4954
diff changeset
  1920
 * @param left,top,width,height the relative coordinates of the clipping
5bf9f412940a (svn r6957) -Cleanup: comments, coding style
Darkvater
parents: 4954
diff changeset
  1921
 * rectangle relative to the current _cur_dpi. This will most likely be the
5bf9f412940a (svn r6957) -Cleanup: comments, coding style
Darkvater
parents: 4954
diff changeset
  1922
 * offset from the calling window coordinates
5bf9f412940a (svn r6957) -Cleanup: comments, coding style
Darkvater
parents: 4954
diff changeset
  1923
 * @return return false if the requested rectangle is not possible with the
5bf9f412940a (svn r6957) -Cleanup: comments, coding style
Darkvater
parents: 4954
diff changeset
  1924
 * current dpi pointer. Only continue of the return value is true, or you'll
5bf9f412940a (svn r6957) -Cleanup: comments, coding style
Darkvater
parents: 4954
diff changeset
  1925
 * get some nasty results */
4429
b4eb6d97996f (svn r6184) Remove the unused (because it was NULL in all callers) second parameter of FillDrawPixelInfo() and simplify some expressions
tron
parents: 4428
diff changeset
  1926
bool FillDrawPixelInfo(DrawPixelInfo *n, int left, int top, int width, int height)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1927
{
4429
b4eb6d97996f (svn r6184) Remove the unused (because it was NULL in all callers) second parameter of FillDrawPixelInfo() and simplify some expressions
tron
parents: 4428
diff changeset
  1928
	const DrawPixelInfo *o = _cur_dpi;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1929
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1930
	n->zoom = 0;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1931
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1932
	assert(width > 0);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1933
	assert(height > 0);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1934
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1935
	if ((left -= o->left) < 0) {
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1936
		width += left;
4525
d12168a85134 (svn r6351) -Fix: Due to some off-by-one errors the width or height of a clipping rectangle could become 0, which isn't sensible. This should fix a very rare and hard to trigger assertion in GfxFillRect()
tron
parents: 4522
diff changeset
  1937
		if (width <= 0) return false;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1938
		n->left = -left;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1939
		left = 0;
4429
b4eb6d97996f (svn r6184) Remove the unused (because it was NULL in all callers) second parameter of FillDrawPixelInfo() and simplify some expressions
tron
parents: 4428
diff changeset
  1940
	} else {
b4eb6d97996f (svn r6184) Remove the unused (because it was NULL in all callers) second parameter of FillDrawPixelInfo() and simplify some expressions
tron
parents: 4428
diff changeset
  1941
		n->left = 0;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1942
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1943
4429
b4eb6d97996f (svn r6184) Remove the unused (because it was NULL in all callers) second parameter of FillDrawPixelInfo() and simplify some expressions
tron
parents: 4428
diff changeset
  1944
	if (width > o->width - left) {
b4eb6d97996f (svn r6184) Remove the unused (because it was NULL in all callers) second parameter of FillDrawPixelInfo() and simplify some expressions
tron
parents: 4428
diff changeset
  1945
		width = o->width - left;
4525
d12168a85134 (svn r6351) -Fix: Due to some off-by-one errors the width or height of a clipping rectangle could become 0, which isn't sensible. This should fix a very rare and hard to trigger assertion in GfxFillRect()
tron
parents: 4522
diff changeset
  1946
		if (width <= 0) return false;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1947
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1948
	n->width = width;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1949
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1950
	if ((top -= o->top) < 0) {
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1951
		height += top;
4525
d12168a85134 (svn r6351) -Fix: Due to some off-by-one errors the width or height of a clipping rectangle could become 0, which isn't sensible. This should fix a very rare and hard to trigger assertion in GfxFillRect()
tron
parents: 4522
diff changeset
  1952
		if (height <= 0) return false;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1953
		n->top = -top;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1954
		top = 0;
4429
b4eb6d97996f (svn r6184) Remove the unused (because it was NULL in all callers) second parameter of FillDrawPixelInfo() and simplify some expressions
tron
parents: 4428
diff changeset
  1955
	} else {
b4eb6d97996f (svn r6184) Remove the unused (because it was NULL in all callers) second parameter of FillDrawPixelInfo() and simplify some expressions
tron
parents: 4428
diff changeset
  1956
		n->top = 0;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1957
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1958
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1959
	n->dst_ptr = o->dst_ptr + left + top * (n->pitch = o->pitch);
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1960
4429
b4eb6d97996f (svn r6184) Remove the unused (because it was NULL in all callers) second parameter of FillDrawPixelInfo() and simplify some expressions
tron
parents: 4428
diff changeset
  1961
	if (height > o->height - top) {
b4eb6d97996f (svn r6184) Remove the unused (because it was NULL in all callers) second parameter of FillDrawPixelInfo() and simplify some expressions
tron
parents: 4428
diff changeset
  1962
		height = o->height - top;
4525
d12168a85134 (svn r6351) -Fix: Due to some off-by-one errors the width or height of a clipping rectangle could become 0, which isn't sensible. This should fix a very rare and hard to trigger assertion in GfxFillRect()
tron
parents: 4522
diff changeset
  1963
		if (height <= 0) return false;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1964
	}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1965
	n->height = height;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1966
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1967
	return true;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1968
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1969
5668
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
  1970
static void SetCursorSprite(SpriteID cursor, SpriteID pal)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1971
{
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1972
	CursorVars *cv = &_cursor;
1348
7b598080024c (svn r1852) Start cleaning up sprite handling:
tron
parents: 1336
diff changeset
  1973
	const Sprite *p;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1974
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  1975
	if (cv->sprite == cursor) return;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1976
5668
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
  1977
	p = GetSprite(GB(cursor, 0, SPRITE_WIDTH));
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1978
	cv->sprite = cursor;
5668
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
  1979
	cv->pal    = pal;
1348
7b598080024c (svn r1852) Start cleaning up sprite handling:
tron
parents: 1336
diff changeset
  1980
	cv->size.y = p->height;
1351
a08ab043dd08 (svn r1855) Handle endianness of sprite headers when loading a sprite, not everytime when accessing it
tron
parents: 1350
diff changeset
  1981
	cv->size.x = p->width;
a08ab043dd08 (svn r1855) Handle endianness of sprite headers when loading a sprite, not everytime when accessing it
tron
parents: 1350
diff changeset
  1982
	cv->offs.x = p->x_offs;
a08ab043dd08 (svn r1855) Handle endianness of sprite headers when loading a sprite, not everytime when accessing it
tron
parents: 1350
diff changeset
  1983
	cv->offs.y = p->y_offs;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1984
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1985
	cv->dirty = true;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1986
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1987
1093
4fdc46eaf423 (svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents: 1056
diff changeset
  1988
static void SwitchAnimatedCursor(void)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1989
{
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1990
	CursorVars *cv = &_cursor;
1914
2b4b3c3a95b4 (svn r2420) - Codechange: magic number elminitation of cursorsprites.
Darkvater
parents: 1891
diff changeset
  1991
	const CursorID *cur = cv->animate_cur;
2b4b3c3a95b4 (svn r2420) - Codechange: magic number elminitation of cursorsprites.
Darkvater
parents: 1891
diff changeset
  1992
	CursorID sprite;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1993
1914
2b4b3c3a95b4 (svn r2420) - Codechange: magic number elminitation of cursorsprites.
Darkvater
parents: 1891
diff changeset
  1994
	// ANIM_CURSOR_END is 0xFFFF in table/animcursors.h
2b4b3c3a95b4 (svn r2420) - Codechange: magic number elminitation of cursorsprites.
Darkvater
parents: 1891
diff changeset
  1995
	if (cur == NULL || *cur == 0xFFFF) cur = cv->animate_list;
2b4b3c3a95b4 (svn r2420) - Codechange: magic number elminitation of cursorsprites.
Darkvater
parents: 1891
diff changeset
  1996
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1997
	sprite = cur[0];
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1998
	cv->animate_timeout = cur[1];
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  1999
	cv->animate_cur = cur + 2;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2000
5668
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
  2001
	SetCursorSprite(sprite, cv->pal);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2002
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2003
1093
4fdc46eaf423 (svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents: 1056
diff changeset
  2004
void CursorTick(void)
4fdc46eaf423 (svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents: 1056
diff changeset
  2005
{
2010
5e0b6a1d2100 (svn r2518) Small cleanup
tron
parents: 2005
diff changeset
  2006
	if (_cursor.animate_timeout != 0 && --_cursor.animate_timeout == 0)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2007
		SwitchAnimatedCursor();
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2008
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2009
5668
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
  2010
void SetMouseCursor(SpriteID sprite, SpriteID pal)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2011
{
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2012
	// Turn off animation
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2013
	_cursor.animate_timeout = 0;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2014
	// Set cursor
5668
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
  2015
	SetCursorSprite(sprite, pal);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2016
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2017
1914
2b4b3c3a95b4 (svn r2420) - Codechange: magic number elminitation of cursorsprites.
Darkvater
parents: 1891
diff changeset
  2018
void SetAnimatedMouseCursor(const CursorID *table)
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2019
{
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2020
	_cursor.animate_list = table;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2021
	_cursor.animate_cur = NULL;
5668
36b39f4a9032 (svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents: 5636
diff changeset
  2022
	_cursor.pal = PAL_NONE;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2023
	SwitchAnimatedCursor();
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2024
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2025
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2026
bool ChangeResInGame(int w, int h)
193
0a7025304867 (svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents: 126
diff changeset
  2027
{
2645
841087328e0e (svn r3187) Simplify overly complicated ifs, especially if (foo) return false; else return true; is confusing
tron
parents: 2639
diff changeset
  2028
	return
841087328e0e (svn r3187) Simplify overly complicated ifs, especially if (foo) return false; else return true; is confusing
tron
parents: 2639
diff changeset
  2029
		(_screen.width == w && _screen.height == h) ||
841087328e0e (svn r3187) Simplify overly complicated ifs, especially if (foo) return false; else return true; is confusing
tron
parents: 2639
diff changeset
  2030
		_video_driver->change_resolution(w, h);
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
  2031
}
298
0123c0489940 (svn r304) -Fix: [967096] fullscreen. New button 'Fullscreen' in 'Game Options' menu which lets you set fullscreen ingame.
darkvater
parents: 193
diff changeset
  2032
5217
7a9e91919a93 (svn r7332) -Fix: segmentation fault, discovered by ln-, in the SDL video driver when one goes to fullscreen and there are no suitable resolutions.
rubidium
parents: 5156
diff changeset
  2033
void ToggleFullScreen(bool fs)
7a9e91919a93 (svn r7332) -Fix: segmentation fault, discovered by ln-, in the SDL video driver when one goes to fullscreen and there are no suitable resolutions.
rubidium
parents: 5156
diff changeset
  2034
{
7a9e91919a93 (svn r7332) -Fix: segmentation fault, discovered by ln-, in the SDL video driver when one goes to fullscreen and there are no suitable resolutions.
rubidium
parents: 5156
diff changeset
  2035
	_video_driver->toggle_fullscreen(fs);
7a9e91919a93 (svn r7332) -Fix: segmentation fault, discovered by ln-, in the SDL video driver when one goes to fullscreen and there are no suitable resolutions.
rubidium
parents: 5156
diff changeset
  2036
	if (_fullscreen != fs && _num_resolutions == 0) {
5380
8ea58542b6e0 (svn r7565) -Codechange: Rework DEBUG functionality. Look for appropiate debugging levels to
Darkvater
parents: 5217
diff changeset
  2037
		DEBUG(driver, 0, "Could not find a suitable fullscreen resolution");
5217
7a9e91919a93 (svn r7332) -Fix: segmentation fault, discovered by ln-, in the SDL video driver when one goes to fullscreen and there are no suitable resolutions.
rubidium
parents: 5156
diff changeset
  2038
	}
7a9e91919a93 (svn r7332) -Fix: segmentation fault, discovered by ln-, in the SDL video driver when one goes to fullscreen and there are no suitable resolutions.
rubidium
parents: 5156
diff changeset
  2039
}
1829
e90fe433fa7d (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
  2040
1806
5a55d508c23e (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
  2041
static int CDECL compare_res(const void *pa, const void *pb)
298
0123c0489940 (svn r304) -Fix: [967096] fullscreen. New button 'Fullscreen' in 'Game Options' menu which lets you set fullscreen ingame.
darkvater
parents: 193
diff changeset
  2042
{
1806
5a55d508c23e (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
  2043
	int x = ((const uint16*)pa)[0] - ((const uint16*)pb)[0];
5a55d508c23e (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
  2044
	if (x != 0) return x;
5a55d508c23e (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
  2045
	return ((const uint16*)pa)[1] - ((const uint16*)pb)[1];
5a55d508c23e (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
  2046
}
5a55d508c23e (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
  2047
5a55d508c23e (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
  2048
void SortResolutions(int count)
5a55d508c23e (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
  2049
{
5a55d508c23e (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
  2050
	qsort(_resolutions, count, sizeof(_resolutions[0]), compare_res);
298
0123c0489940 (svn r304) -Fix: [967096] fullscreen. New button 'Fullscreen' in 'Game Options' menu which lets you set fullscreen ingame.
darkvater
parents: 193
diff changeset
  2051
}