1
0
Fork 0
mirror of https://github.com/TerryCavanagh/VVVVVV.git synced 2025-01-08 18:09:45 +01:00

Use SDL_Color for colors instead of colourTransform

colourTransform is a struct with only one member, a Uint32. The issue
with `Uint32`s is that it requires a bunch of bit shifting logic to edit
the colors. The issue with bit shifting logic is that people have a
tendency to hardcode the shift amounts instead of using the shift amount
variables of the SDL_PixelFormat, which makes it annoying to change the
color masks of surfaces.

This commit fixes both issues by unhardcoding the bit shift amounts in
DrawPixel and ReadPixel, and by axing the `Uint32`s in favor of using
SDL_Color.

According to the SDL_PixelFormat documentation (
https://wiki.libsdl.org/SDL2/SDL_PixelFormat ), the logic to read and
draw to pixels from colors below 32-bit was just wrong. Specifically,
for 8-bit, there's a color palette used instead of some intrinsic color
information stored in the pixel itself. But we shouldn't need that logic
anyways because we don't use colors below 32-bit. So I axed that too.
This commit is contained in:
Misa 2023-01-01 16:36:43 -08:00
parent f24265f0fb
commit 351a022ebd
13 changed files with 309 additions and 327 deletions

View file

@ -1604,7 +1604,7 @@ void customlevelclass::generatecustomminimap(void)
// Return a graphics-ready color based off of the given tileset and tilecol // Return a graphics-ready color based off of the given tileset and tilecol
// Much kudos to Dav999 for saving me a lot of work, because I stole these colors from const.lua in Ved! -Info Teddy // Much kudos to Dav999 for saving me a lot of work, because I stole these colors from const.lua in Ved! -Info Teddy
Uint32 customlevelclass::getonewaycol(const int rx, const int ry) SDL_Color customlevelclass::getonewaycol(const int rx, const int ry)
{ {
const RoomProperty* const room = getroomprop(rx, ry); const RoomProperty* const room = getroomprop(rx, ry);
switch (room->tileset) { switch (room->tileset) {
@ -1763,7 +1763,7 @@ Uint32 customlevelclass::getonewaycol(const int rx, const int ry)
} }
// This version detects the room automatically // This version detects the room automatically
Uint32 customlevelclass::getonewaycol(void) SDL_Color customlevelclass::getonewaycol(void)
{ {
#ifndef NO_EDITOR #ifndef NO_EDITOR
if (game.gamestate == EDITORMODE) if (game.gamestate == EDITORMODE)

View file

@ -155,8 +155,8 @@ public:
int version; int version;
Uint32 getonewaycol(const int rx, const int ry); SDL_Color getonewaycol(int rx, int ry);
Uint32 getonewaycol(void); SDL_Color getonewaycol(void);
bool onewaycol_override; bool onewaycol_override;
}; };

View file

@ -279,20 +279,20 @@ static int edentat( int xp, int yp )
return -1; return -1;
} }
static void fillbox( int x, int y, int x2, int y2, int c ) static void fillbox(const int x, const int y, const int x2, const int y2, const SDL_Color color)
{ {
FillRect(graphics.backBuffer, x, y, x2-x, 1, c); FillRect(graphics.backBuffer, x, y, x2-x, 1, color);
FillRect(graphics.backBuffer, x, y2-1, x2-x, 1, c); FillRect(graphics.backBuffer, x, y2-1, x2-x, 1, color);
FillRect(graphics.backBuffer, x, y, 1, y2-y, c); FillRect(graphics.backBuffer, x, y, 1, y2-y, color);
FillRect(graphics.backBuffer, x2-1, y, 1, y2-y, c); FillRect(graphics.backBuffer, x2-1, y, 1, y2-y, color);
} }
static void fillboxabs( int x, int y, int x2, int y2, int c ) static void fillboxabs(const int x, const int y, const int x2, const int y2, const SDL_Color color)
{ {
FillRect(graphics.backBuffer, x, y, x2, 1, c); FillRect(graphics.backBuffer, x, y, x2, 1, color);
FillRect(graphics.backBuffer, x, y+y2-1, x2, 1, c); FillRect(graphics.backBuffer, x, y+y2-1, x2, 1, color);
FillRect(graphics.backBuffer, x, y, 1, y2, c); FillRect(graphics.backBuffer, x, y, 1, y2, color);
FillRect(graphics.backBuffer, x+x2-1, y, 1, y2, c); FillRect(graphics.backBuffer, x+x2-1, y, 1, y2, color);
} }
@ -595,8 +595,7 @@ void editorrender(void)
// Special case for drawing gray entities // Special case for drawing gray entities
bool custom_gray = room->tileset == 3 && room->tilecol == 6; bool custom_gray = room->tileset == 3 && room->tilecol == 6;
colourTransform gray_ct; const SDL_Color gray_ct = {255, 255, 255, 255};
gray_ct.colour = 0xFFFFFFFF;
// Draw entities backward to remain accurate with ingame // Draw entities backward to remain accurate with ingame
for (int i = customentities.size() - 1; i >= 0; i--) for (int i = customentities.size() - 1; i >= 0; i--)
@ -610,9 +609,10 @@ void editorrender(void)
switch(customentities[i].t) switch(customentities[i].t)
{ {
case 1: //Entities case 1: //Entities
if (custom_gray) { if (custom_gray)
{
graphics.setcol(18); graphics.setcol(18);
ed.entcolreal = graphics.ct.colour; ed.entcolreal = graphics.ct;
} }
graphics.drawsprite((customentities[i].x*8)- (ed.levx*40*8),(customentities[i].y*8)- (ed.levy*30*8),ed.getenemyframe(room->enemytype),ed.entcolreal); graphics.drawsprite((customentities[i].x*8)- (ed.levx*40*8),(customentities[i].y*8)- (ed.levy*30*8),ed.getenemyframe(room->enemytype),ed.entcolreal);
if(customentities[i].p1==0) graphics.Print((customentities[i].x*8)- (ed.levx*40*8)+4,(customentities[i].y*8)- (ed.levy*30*8)+4, "V", 255, 255, 255 - help.glow, false); if(customentities[i].p1==0) graphics.Print((customentities[i].x*8)- (ed.levx*40*8)+4,(customentities[i].y*8)- (ed.levy*30*8)+4, "V", 255, 255, 255 - help.glow, false);
@ -933,10 +933,8 @@ void editorrender(void)
tpoint.x = ed.ghosts[i].x; tpoint.x = ed.ghosts[i].x;
tpoint.y = ed.ghosts[i].y; tpoint.y = ed.ghosts[i].y;
graphics.setcolreal(ed.ghosts[i].realcol); graphics.setcolreal(ed.ghosts[i].realcol);
Uint32 alpha = graphics.ct.colour & graphics.backBuffer->format->Amask; const int alpha = 3 * graphics.ct.a / 4;
Uint32 therest = graphics.ct.colour & 0x00FFFFFF; graphics.ct.a = (Uint8) alpha;
alpha = (3 * (alpha >> 24) / 4) << 24;
graphics.ct.colour = therest | alpha;
SDL_Rect drawRect = graphics.sprites_rect; SDL_Rect drawRect = graphics.sprites_rect;
drawRect.x += tpoint.x; drawRect.x += tpoint.x;
drawRect.y += tpoint.y; drawRect.y += tpoint.y;
@ -1607,7 +1605,7 @@ void editorrenderfixed(void)
ed.entcol=cl.getenemycol(game.customcol); ed.entcol=cl.getenemycol(game.customcol);
graphics.setcol(ed.entcol); graphics.setcol(ed.entcol);
ed.entcolreal = graphics.ct.colour; ed.entcolreal = graphics.ct;
if (game.ghostsenabled) if (game.ghostsenabled)
{ {
@ -1621,7 +1619,7 @@ void editorrenderfixed(void)
} }
graphics.setcol(ghost.col); graphics.setcol(ghost.col);
ghost.realcol = graphics.ct.colour; ghost.realcol = graphics.ct;
} }
if (ed.currentghosts + 1 < (int)ed.ghosts.size()) { if (ed.currentghosts + 1 < (int)ed.ghosts.size()) {

View file

@ -42,7 +42,7 @@ struct GhostInfo
int x; // .xp int x; // .xp
int y; // .yp int y; // .yp
int col; // .colour int col; // .colour
Uint32 realcol; SDL_Color realcol;
int frame; // .drawframe int frame; // .drawframe
}; };
@ -93,7 +93,7 @@ public:
void switch_warpdir(const bool reversed); void switch_warpdir(const bool reversed);
int entcol; int entcol;
Uint32 entcolreal; SDL_Color entcolreal;
int kludgewarpdir[customlevelclass::numrooms]; int kludgewarpdir[customlevelclass::numrooms];

View file

@ -65,7 +65,7 @@ void entclass::clear(void)
dir = 0; dir = 0;
actionframe = 0; actionframe = 0;
realcol = 0; SDL_zero(realcol);
lerpoldxp = 0; lerpoldxp = 0;
lerpoldyp = 0; lerpoldyp = 0;
} }
@ -618,14 +618,14 @@ void entclass::updatecolour(void)
case 10: // 2x1 Sprite case 10: // 2x1 Sprite
case 13: // Special for epilogue: huge hero! case 13: // Special for epilogue: huge hero!
graphics.setcol(colour); graphics.setcol(colour);
realcol = graphics.ct.colour; realcol = graphics.ct;
break; break;
case 3: // Big chunky pixels! case 3: // Big chunky pixels!
realcol = graphics.bigchunkygetcol(colour); realcol = graphics.bigchunkygetcol(colour);
break; break;
case 4: // Small pickups case 4: // Small pickups
graphics.huetilesetcol(colour); graphics.huetilesetcol(colour);
realcol = graphics.ct.colour; realcol = graphics.ct;
break; break;
case 11: // The fucking elephant case 11: // The fucking elephant
if (game.noflashingmode) if (game.noflashingmode)
@ -636,7 +636,7 @@ void entclass::updatecolour(void)
{ {
graphics.setcol(colour); graphics.setcol(colour);
} }
realcol = graphics.ct.colour; realcol = graphics.ct;
break; break;
case 12: // Regular sprites that don't wrap case 12: // Regular sprites that don't wrap
// if we're outside the screen, we need to draw indicators // if we're outside the screen, we need to draw indicators
@ -648,7 +648,7 @@ void entclass::updatecolour(void)
{ {
graphics.setcol(colour); graphics.setcol(colour);
} }
realcol = graphics.ct.colour; realcol = graphics.ct;
break; break;
default: default:
break; break;

View file

@ -53,7 +53,7 @@ public:
int visualonground, visualonroof; int visualonground, visualonroof;
int yp;int xp; int yp;int xp;
Uint32 realcol; SDL_Color realcol;
int lerpoldxp, lerpoldyp; int lerpoldxp, lerpoldyp;
}; };

View file

@ -84,8 +84,8 @@ void Graphics::init(void)
backgrounddrawn = false; backgrounddrawn = false;
warpskip = 0; warpskip = 0;
warpfcol = 0x000000; SDL_zero(warpfcol);
warpbcol = 0x000000; SDL_zero(warpbcol);
spcol = 0; spcol = 0;
spcoldel = 0; spcoldel = 0;
@ -106,7 +106,7 @@ void Graphics::init(void)
// initialize everything else to zero // initialize everything else to zero
backBuffer = NULL; backBuffer = NULL;
ct = colourTransform(); SDL_zero(ct);
foregrounddrawn = false; foregrounddrawn = false;
foregroundBuffer = NULL; foregroundBuffer = NULL;
backgrounddrawn = false; backgrounddrawn = false;
@ -132,15 +132,15 @@ void Graphics::init(void)
screenshake_x = 0; screenshake_x = 0;
screenshake_y = 0; screenshake_y = 0;
col_crewred = 0x00000000; SDL_zero(col_crewred);
col_crewyellow = 0x00000000; SDL_zero(col_crewyellow);
col_crewgreen = 0x00000000; SDL_zero(col_crewgreen);
col_crewcyan = 0x00000000; SDL_zero(col_crewcyan);
col_crewblue = 0x00000000; SDL_zero(col_crewblue);
col_crewpurple = 0x00000000; SDL_zero(col_crewpurple);
col_crewinactive = 0x00000000; SDL_zero(col_crewinactive);
col_clock = 0x00000000; SDL_zero(col_clock);
col_trinket = 0x00000000; SDL_zero(col_trinket);
col_tr = 0; col_tr = 0;
col_tg = 0; col_tg = 0;
col_tb = 0; col_tb = 0;
@ -199,12 +199,12 @@ void Graphics::create_buffers(const SDL_PixelFormat* fmt)
footerbuffer = CREATE_SURFACE(320, 10); footerbuffer = CREATE_SURFACE(320, 10);
SDL_SetSurfaceBlendMode(footerbuffer, SDL_BLENDMODE_BLEND); SDL_SetSurfaceBlendMode(footerbuffer, SDL_BLENDMODE_BLEND);
SDL_SetSurfaceAlphaMod(footerbuffer, 127); SDL_SetSurfaceAlphaMod(footerbuffer, 127);
FillRect(footerbuffer, SDL_MapRGB(fmt, 0, 0, 0)); FillRect(footerbuffer, 0, 0, 0);
roomname_translator::dimbuffer = CREATE_SURFACE(320, 240); roomname_translator::dimbuffer = CREATE_SURFACE(320, 240);
SDL_SetSurfaceBlendMode(roomname_translator::dimbuffer, SDL_BLENDMODE_BLEND); SDL_SetSurfaceBlendMode(roomname_translator::dimbuffer, SDL_BLENDMODE_BLEND);
SDL_SetSurfaceAlphaMod(roomname_translator::dimbuffer, 96); SDL_SetSurfaceAlphaMod(roomname_translator::dimbuffer, 96);
FillRect(roomname_translator::dimbuffer, SDL_MapRGB(fmt, 0, 0, 0)); FillRect(roomname_translator::dimbuffer, 0, 0, 0);
ghostbuffer = CREATE_SURFACE(320, 240); ghostbuffer = CREATE_SURFACE(320, 240);
SDL_SetSurfaceBlendMode(ghostbuffer, SDL_BLENDMODE_BLEND); SDL_SetSurfaceBlendMode(ghostbuffer, SDL_BLENDMODE_BLEND);
@ -299,24 +299,24 @@ void Graphics::drawspritesetcol(int x, int y, int t, int c)
void Graphics::updatetitlecolours(void) void Graphics::updatetitlecolours(void)
{ {
setcol(15); setcol(15);
col_crewred = ct.colour; col_crewred = ct;
setcol(14); setcol(14);
col_crewyellow = ct.colour; col_crewyellow = ct;
setcol(13); setcol(13);
col_crewgreen = ct.colour; col_crewgreen = ct;
setcol(0); setcol(0);
col_crewcyan = ct.colour; col_crewcyan = ct;
setcol(16); setcol(16);
col_crewblue = ct.colour; col_crewblue = ct;
setcol(20); setcol(20);
col_crewpurple = ct.colour; col_crewpurple = ct;
setcol(19); setcol(19);
col_crewinactive = ct.colour; col_crewinactive = ct;
setcol(18); setcol(18);
col_clock = ct.colour; col_clock = ct;
setcol(18); setcol(18);
col_trinket = ct.colour; col_trinket = ct;
} }
#define PROCESS_TILESHEET_CHECK_ERROR(tilesheet, tile_square) \ #define PROCESS_TILESHEET_CHECK_ERROR(tilesheet, tile_square) \
@ -496,7 +496,7 @@ static void print_char(
const int x, const int x,
const int y, const int y,
const int scale, const int scale,
colourTransform& ct const SDL_Color color
) { ) {
SDL_Rect font_rect = {x, y, 8*scale, 8*scale}; SDL_Rect font_rect = {x, y, 8*scale, 8*scale};
SDL_Surface* surface; SDL_Surface* surface;
@ -514,7 +514,7 @@ static void print_char(
surface = font; surface = font;
} }
BlitSurfaceColoured(surface, NULL, buffer, &font_rect, ct); BlitSurfaceColoured(surface, NULL, buffer, &font_rect, color);
if (scale > 1) if (scale > 1)
{ {
@ -542,7 +542,7 @@ void Graphics::do_print(
b = SDL_clamp(b, 0, 255); b = SDL_clamp(b, 0, 255);
a = SDL_clamp(a, 0, 255); a = SDL_clamp(a, 0, 255);
ct.colour = getRGBA(r, g, b, a); ct = getRGBA(r, g, b, a);
while (iter != text.end()) while (iter != text.end())
{ {
@ -1033,7 +1033,7 @@ void Graphics::drawsprite( int x, int y, int t, int r, int g, int b )
BlitSurfaceColoured(sprites[t], NULL, backBuffer, &rect, ct); BlitSurfaceColoured(sprites[t], NULL, backBuffer, &rect, ct);
} }
void Graphics::drawsprite(int x, int y, int t, Uint32 c) void Graphics::drawsprite(int x, int y, int t, const SDL_Color color)
{ {
if (!INBOUNDS_VEC(t, sprites)) if (!INBOUNDS_VEC(t, sprites))
{ {
@ -1042,7 +1042,7 @@ void Graphics::drawsprite(int x, int y, int t, Uint32 c)
} }
SDL_Rect rect = {x, y, sprites_rect.w, sprites_rect.h}; SDL_Rect rect = {x, y, sprites_rect.w, sprites_rect.h};
setcolreal(c); setcolreal(color);
BlitSurfaceColoured(sprites[t], NULL, backBuffer, &rect, ct); BlitSurfaceColoured(sprites[t], NULL, backBuffer, &rect, ct);
} }
@ -1068,7 +1068,7 @@ void Graphics::drawtile( int x, int y, int t )
#if !defined(NO_CUSTOM_LEVELS) #if !defined(NO_CUSTOM_LEVELS)
if (shouldrecoloroneway(t, tiles1_mounted)) if (shouldrecoloroneway(t, tiles1_mounted))
{ {
colourTransform thect = {cl.getonewaycol()}; const SDL_Color thect = cl.getonewaycol();
BlitSurfaceTinted(tiles[t], NULL, backBuffer, &rect, thect); BlitSurfaceTinted(tiles[t], NULL, backBuffer, &rect, thect);
} }
else else
@ -1092,7 +1092,7 @@ void Graphics::drawtile2( int x, int y, int t )
#if !defined(NO_CUSTOM_LEVELS) #if !defined(NO_CUSTOM_LEVELS)
if (shouldrecoloroneway(t, tiles2_mounted)) if (shouldrecoloroneway(t, tiles2_mounted))
{ {
colourTransform thect = {cl.getonewaycol()}; const SDL_Color thect = cl.getonewaycol();
BlitSurfaceTinted(tiles2[t], NULL, backBuffer, &rect, thect); BlitSurfaceTinted(tiles2[t], NULL, backBuffer, &rect, thect);
} }
else else
@ -1431,14 +1431,14 @@ void Graphics::cutscenebars(void)
const int usethispos = lerp(oldcutscenebarspos, cutscenebarspos); const int usethispos = lerp(oldcutscenebarspos, cutscenebarspos);
if (showcutscenebars) if (showcutscenebars)
{ {
FillRect(backBuffer, 0, 0, usethispos, 16, 0x000000); FillRect(backBuffer, 0, 0, usethispos, 16, 0, 0, 0);
FillRect(backBuffer, 360-usethispos, 224, usethispos, 16, 0x000000); FillRect(backBuffer, 360-usethispos, 224, usethispos, 16, 0, 0, 0);
} }
else if (cutscenebarspos > 0) //disappearing else if (cutscenebarspos > 0) //disappearing
{ {
//draw //draw
FillRect(backBuffer, 0, 0, usethispos, 16, 0x000000); FillRect(backBuffer, 0, 0, usethispos, 16, 0, 0, 0);
FillRect(backBuffer, 360-usethispos, 224, usethispos, 16, 0x000000); FillRect(backBuffer, 360-usethispos, 224, usethispos, 16, 0, 0, 0);
} }
} }
@ -1702,13 +1702,13 @@ void Graphics::drawfade(void)
case FADE_FADING_OUT: case FADE_FADING_OUT:
for (size_t i = 0; i < SDL_arraysize(fadebars); i++) for (size_t i = 0; i < SDL_arraysize(fadebars); i++)
{ {
FillRect(backBuffer, fadebars[i], i * 16, usethisamount, 16, 0x000000 ); FillRect(backBuffer, fadebars[i], i * 16, usethisamount, 16, 0, 0, 0);
} }
break; break;
case FADE_FADING_IN: case FADE_FADING_IN:
for (size_t i = 0; i < SDL_arraysize(fadebars); i++) for (size_t i = 0; i < SDL_arraysize(fadebars); i++)
{ {
FillRect(backBuffer, fadebars[i]-usethisamount, i * 16, 500, 16, 0x000000 ); FillRect(backBuffer, fadebars[i]-usethisamount, i * 16, 500, 16, 0, 0, 0);
} }
break; break;
case FADE_NONE: case FADE_NONE:
@ -1924,13 +1924,12 @@ bool Graphics::Hitest(SDL_Surface* surface1, point p1, SDL_Surface* surface2, po
{ {
for(int y = r3_bottom; y < r3_top; y++) for(int y = r3_bottom; y < r3_top; y++)
{ {
Uint32 pixel1 = ReadPixel(surface1 , x - p1.x, y - p1.y); const SDL_Color pixel1 = ReadPixel(surface1, x - p1.x, y - p1.y);
Uint32 pixel2 = ReadPixel(surface2 , x - p2.x, y - p2.y); const SDL_Color pixel2 = ReadPixel(surface2, x - p2.x, y - p2.y);
/* INTENTIONAL BUG! In previous versions, the game mistakenly /* INTENTIONAL BUG! In previous versions, the game mistakenly
* checked the red channel, not the alpha channel. * checked the red channel, not the alpha channel.
* We preserve it here because some people abuse this. */ * We preserve it here because some people abuse this. */
if ((pixel1 & surface1->format->Rmask) if (pixel1.r != 0 && pixel2.r != 0)
&& (pixel2 & surface2->format->Rmask))
{ {
return true; return true;
} }
@ -2269,9 +2268,8 @@ void Graphics::drawentity(const int i, const int yoff)
drawRect.x += 8 * ii; drawRect.x += 8 * ii;
if (custom_gray) if (custom_gray)
{ {
colourTransform temp_ct; const SDL_Color temp_ct = {255, 255, 255, 255};
temp_ct.colour = 0xFFFFFFFF; BlitSurfaceTinted(tilesvec[obj.entities[i].drawframe], NULL, backBuffer, &drawRect, temp_ct);
BlitSurfaceTinted(tilesvec[obj.entities[i].drawframe],NULL, backBuffer, &drawRect, temp_ct);
} }
else else
{ {
@ -2501,7 +2499,10 @@ void Graphics::drawbackground( int t )
break; break;
case 2: case 2:
{ {
int bcol = 0, bcol2 = 0; SDL_Color bcol;
SDL_Color bcol2;
SDL_zero(bcol);
SDL_zero(bcol2);
//Lab //Lab
switch(rcol) switch(rcol)
@ -3096,15 +3097,15 @@ void Graphics::setcol( int t )
{ {
//Player Normal //Player Normal
case 0: case 0:
ct.colour = getRGB(160- help.glow/2 - (fRandom()*20), 200- help.glow/2, 220 - help.glow); ct = getRGB(160 - help.glow/2 - (fRandom() * 20), 200 - help.glow/2, 220 - help.glow);
break; break;
//Player Hurt //Player Hurt
case 1: case 1:
ct.colour = getRGB(196 - (fRandom() * 64), 10, 10); ct = getRGB(196 - (fRandom() * 64), 10, 10);
break; break;
//Enemies and stuff //Enemies and stuff
case 2: case 2:
ct.colour = getRGB(225-(help.glow/2), 75, 30); ct = getRGB(225 - (help.glow / 2), 75, 30);
break; break;
case 3: //Trinket case 3: //Trinket
if (!trinketcolset) if (!trinketcolset)
@ -3114,109 +3115,109 @@ void Graphics::setcol( int t )
trinketb = 164 + (fRandom() * 60); trinketb = 164 + (fRandom() * 60);
trinketcolset = true; trinketcolset = true;
} }
ct.colour = getRGB(trinketr, trinketg, trinketb); ct = getRGB(trinketr, trinketg, trinketb);
break; break;
case 4: //Inactive savepoint case 4: //Inactive savepoint
{ {
const int temp = (help.glow/2) + (fRandom() * 8); const int temp = (help.glow / 2) + (fRandom() * 8);
ct.colour = getRGB(80 + temp, 80 + temp, 80 + temp); ct = getRGB(80 + temp, 80 + temp, 80 + temp);
break; break;
} }
case 5: //Active savepoint case 5: //Active savepoint
ct.colour = getRGB(164+(fRandom()*64),164+(fRandom()*64), 255-(fRandom()*64)); ct = getRGB(164 + (fRandom() * 64), 164 + (fRandom() * 64), 255 - (fRandom() * 64));
break; break;
case 6: //Enemy : Red case 6: //Enemy : Red
ct.colour = getRGB(250 - help.glow/2, 60- help.glow/2, 60 - help.glow/2); ct = getRGB(250 - help.glow/2, 60- help.glow/2, 60 - help.glow/2);
break; break;
case 7: //Enemy : Green case 7: //Enemy : Green
ct.colour = getRGB(100 - help.glow/2 - (fRandom()*30), 250 - help.glow/2, 100 - help.glow/2 - (fRandom()*30)); ct = getRGB(100 - help.glow/2 - (fRandom() * 30), 250 - help.glow/2, 100 - help.glow/2 - (fRandom() * 30));
break; break;
case 8: //Enemy : Purple case 8: //Enemy : Purple
ct.colour = getRGB(250 - help.glow/2, 20, 128 - help.glow/2 + (fRandom()*30)); ct = getRGB(250 - help.glow/2, 20, 128 - help.glow/2 + (fRandom() * 30));
break; break;
case 9: //Enemy : Yellow case 9: //Enemy : Yellow
ct.colour = getRGB(250 - help.glow/2, 250 - help.glow/2, 20); ct = getRGB(250 - help.glow/2, 250 - help.glow/2, 20);
break; break;
case 10: //Warp point (white) case 10: //Warp point (white)
ct.colour = getRGB(255 - (fRandom() * 64), 255 - (fRandom() * 64), 255 - (fRandom() * 64)); ct = getRGB(255 - (fRandom() * 64), 255 - (fRandom() * 64), 255 - (fRandom() * 64));
break; break;
case 11: //Enemy : Cyan case 11: //Enemy : Cyan
ct.colour = getRGB(20, 250 - help.glow/2, 250 - help.glow/2); ct = getRGB(20, 250 - help.glow/2, 250 - help.glow/2);
break; break;
case 12: //Enemy : Blue case 12: //Enemy : Blue
ct.colour = getRGB(90- help.glow/2, 90 - help.glow/2, 250 - help.glow/2); ct = getRGB(90 - help.glow/2, 90 - help.glow/2, 250 - help.glow/2);
break; break;
//Crew Members //Crew Members
//green //green
case 13: case 13:
ct.colour = getRGB(120- help.glow/4 - (fRandom()*20), 220 - help.glow/4, 120- help.glow/4); ct = getRGB(120 - help.glow/4 - (fRandom() * 20), 220 - help.glow/4, 120 - help.glow/4);
break; break;
//Yellow //Yellow
case 14: case 14:
ct.colour = getRGB(220- help.glow/4 - (fRandom()*20), 210 - help.glow/4, 120- help.glow/4); ct = getRGB(220 - help.glow/4 - (fRandom() * 20), 210 - help.glow/4, 120 - help.glow/4);
break; break;
//pink //pink
case 15: case 15:
ct.colour = getRGB(255 - help.glow/8, 70 - help.glow/4, 70 - help.glow / 4); ct = getRGB(255 - help.glow/8, 70 - help.glow/4, 70 - help.glow / 4);
break; break;
//Blue //Blue
case 16: case 16:
ct.colour = getRGB(75, 75, 255- help.glow/4 - (fRandom()*20)); ct = getRGB(75, 75, 255 - help.glow/4 - (fRandom() * 20));
break; break;
case 17: //Enemy : Orange case 17: //Enemy : Orange
ct.colour = getRGB(250 - help.glow/2, 130 - help.glow/2, 20); ct = getRGB(250 - help.glow/2, 130 - help.glow/2, 20);
break; break;
case 18: //Enemy : Gray case 18: //Enemy : Gray
ct.colour = getRGB(130- help.glow/2, 130 - help.glow/2, 130 - help.glow/2); ct = getRGB(130 - help.glow/2, 130 - help.glow/2, 130 - help.glow/2);
break; break;
case 19: //Enemy : Dark gray case 19: //Enemy : Dark gray
ct.colour = getRGB(60- help.glow/8, 60 - help.glow/8, 60 - help.glow/8); ct = getRGB(60 - help.glow/8, 60 - help.glow/8, 60 - help.glow/8);
break; break;
//Purple //Purple
case 20: case 20:
ct.colour = getRGB(220 - help.glow / 4 - (fRandom() * 20), 120 - help.glow / 4, 210 - help.glow / 4); ct = getRGB(220 - help.glow/4 - (fRandom() * 20), 120 - help.glow/4, 210 - help.glow/4);
break; break;
case 21: //Enemy : Light Gray case 21: //Enemy : Light Gray
ct.colour = getRGB(180- help.glow/2, 180 - help.glow/2, 180 - help.glow/2); ct = getRGB(180 - help.glow/2, 180 - help.glow/2, 180 - help.glow/2);
break; break;
case 22: //Enemy : Indicator Gray case 22: //Enemy : Indicator Gray
ct.colour = getRGB(230- help.glow/2, 230- help.glow/2, 230- help.glow/2); ct = getRGB(230 - help.glow/2, 230- help.glow/2, 230 - help.glow/2);
break; break;
case 23: //Enemy : Indicator Gray case 23: //Enemy : Indicator Gray
ct.colour = getRGB(255- help.glow/2 - (fRandom() * 40) , 255- help.glow/2 - (fRandom() * 40), 255- help.glow/2 - (fRandom() * 40)); ct = getRGB(255 - help.glow/2 - (fRandom() * 40) , 255 - help.glow/2 - (fRandom() * 40), 255 - help.glow/2 - (fRandom() * 40));
break; break;
//Trophies //Trophies
//cyan //cyan
case 30: case 30:
ct.colour = RGBf(160, 200, 220); ct = RGBf(160, 200, 220);
break; break;
//Purple //Purple
case 31: case 31:
ct.colour = RGBf(220, 120, 210); ct = RGBf(220, 120, 210);
break; break;
//Yellow //Yellow
case 32: case 32:
ct.colour = RGBf(220, 210, 120); ct = RGBf(220, 210, 120);
break; break;
//red //red
case 33: case 33:
ct.colour = RGBf(255, 70, 70); ct = RGBf(255, 70, 70);
break; break;
//green //green
case 34: case 34:
ct.colour = RGBf(120, 220, 120); ct = RGBf(120, 220, 120);
break; break;
//Blue //Blue
case 35: case 35:
ct.colour = RGBf(75, 75, 255); ct = RGBf(75, 75, 255);
break; break;
//Gold //Gold
case 36: case 36:
ct.colour = getRGB(180, 120, 20); ct = getRGB(180, 120, 20);
break; break;
case 37: //Trinket case 37: //Trinket
if (!trinketcolset) if (!trinketcolset)
@ -3226,15 +3227,15 @@ void Graphics::setcol( int t )
trinketb = 164 + (fRandom() * 60); trinketb = 164 + (fRandom() * 60);
trinketcolset = true; trinketcolset = true;
} }
ct.colour = RGBf(trinketr, trinketg, trinketb); ct = RGBf(trinketr, trinketg, trinketb);
break; break;
//Silver //Silver
case 38: case 38:
ct.colour = RGBf(196, 196, 196); ct = RGBf(196, 196, 196);
break; break;
//Bronze //Bronze
case 39: case 39:
ct.colour = RGBf(128, 64, 10); ct = RGBf(128, 64, 10);
break; break;
//Awesome //Awesome
case 40: //Teleporter in action! case 40: //Teleporter in action!
@ -3242,56 +3243,56 @@ void Graphics::setcol( int t )
const int temp = fRandom() * 150; const int temp = fRandom() * 150;
if(temp<33) if(temp<33)
{ {
ct.colour = RGBf(255 - (fRandom() * 64), 64 + (fRandom() * 64), 64 + (fRandom() * 64)); ct = RGBf(255 - (fRandom() * 64), 64 + (fRandom() * 64), 64 + (fRandom() * 64));
} }
else if (temp < 66) else if (temp < 66)
{ {
ct.colour = RGBf(64 + (fRandom() * 64), 255 - (fRandom() * 64), 64 + (fRandom() * 64)); ct = RGBf(64 + (fRandom() * 64), 255 - (fRandom() * 64), 64 + (fRandom() * 64));
} }
else if (temp < 100) else if (temp < 100)
{ {
ct.colour = RGBf(64 + (fRandom() * 64), 64 + (fRandom() * 64), 255 - (fRandom() * 64)); ct = RGBf(64 + (fRandom() * 64), 64 + (fRandom() * 64), 255 - (fRandom() * 64));
} }
else else
{ {
ct.colour = RGBf(164+(fRandom()*64),164+(fRandom()*64), 255-(fRandom()*64)); ct = RGBf(164 + (fRandom() * 64), 164 + (fRandom() * 64), 255 - (fRandom() * 64));
} }
break; break;
} }
case 100: //Inactive Teleporter case 100: //Inactive Teleporter
{ {
const int temp = (help.glow/2) + (fRandom() * 8); const int temp = (help.glow / 2) + (fRandom() * 8);
ct.colour = getRGB(42 + temp, 42 + temp, 42 + temp); ct = getRGB(42 + temp, 42 + temp, 42 + temp);
break; break;
} }
case 101: //Active Teleporter case 101: //Active Teleporter
ct.colour = getRGB(164+(fRandom()*64),164+(fRandom()*64), 255-(fRandom()*64)); ct = getRGB(164 + (fRandom() * 64), 164 + (fRandom() * 64), 255 - (fRandom() * 64));
break; break;
case 102: //Teleporter in action! case 102: //Teleporter in action!
{ {
const int temp = fRandom() * 150; const int temp = fRandom() * 150;
if(temp<33) if (temp < 33)
{ {
ct.colour = getRGB(255 - (fRandom() * 64), 64 + (fRandom() * 64), 64 + (fRandom() * 64)); ct = getRGB(255 - (fRandom() * 64), 64 + (fRandom() * 64), 64 + (fRandom() * 64));
} }
else if (temp < 66) else if (temp < 66)
{ {
ct.colour = getRGB(64 + (fRandom() * 64), 255 - (fRandom() * 64), 64 + (fRandom() * 64)); ct = getRGB(64 + (fRandom() * 64), 255 - (fRandom() * 64), 64 + (fRandom() * 64));
} }
else if (temp < 100) else if (temp < 100)
{ {
ct.colour = getRGB(64 + (fRandom() * 64), 64 + (fRandom() * 64), 255 - (fRandom() * 64)); ct = getRGB(64 + (fRandom() * 64), 64 + (fRandom() * 64), 255 - (fRandom() * 64));
} }
else else
{ {
ct.colour = getRGB(164+(fRandom()*64),164+(fRandom()*64), 255-(fRandom()*64)); ct = getRGB(164 + (fRandom() * 64), 164 + (fRandom() * 64), 255 - (fRandom() * 64));
} }
break; break;
} }
default: default:
ct.colour = getRGB(255, 255, 255); ct = getRGB(255, 255, 255);
break; break;
} }
} }
@ -3341,7 +3342,7 @@ void Graphics::huetilesetcol(int t)
} }
} }
Uint32 Graphics::bigchunkygetcol(int t) SDL_Color Graphics::bigchunkygetcol(int t)
{ {
//A seperate index of colours, for simplicity //A seperate index of colours, for simplicity
switch (t) switch (t)
@ -3351,7 +3352,8 @@ Uint32 Graphics::bigchunkygetcol(int t)
case 2: case 2:
return getRGB(int(160- help.glow/2 - (fRandom()*20)), 200- help.glow/2, 220 - help.glow); return getRGB(int(160- help.glow/2 - (fRandom()*20)), 200- help.glow/2, 220 - help.glow);
} }
return 0x00000000; const SDL_Color color = {0, 0, 0, 0};
return color;
} }
void Graphics::setwarprect( int a, int b, int c, int d ) void Graphics::setwarprect( int a, int b, int c, int d )
@ -3498,7 +3500,7 @@ int Graphics::crewcolour(const int t)
void Graphics::flashlight(void) void Graphics::flashlight(void)
{ {
FillRect(backBuffer, 0xBBBBBBBB); FillRect(backBuffer, 0xBB, 0xBB, 0xBB, 0xBB);
} }
void Graphics::screenshake(void) void Graphics::screenshake(void)
@ -3608,7 +3610,7 @@ void Graphics::bigbrprint(int x, int y, const std::string& s, int r, int g, int
bigrprint(x, y, s, r, g, b, cen, sc); bigrprint(x, y, s, r, g, b, cen, sc);
} }
void Graphics::drawtele(int x, int y, int t, Uint32 c) void Graphics::drawtele(int x, int y, int t, const SDL_Color color)
{ {
setcolreal(getRGB(16,16,16)); setcolreal(getRGB(16,16,16));
@ -3619,7 +3621,7 @@ void Graphics::drawtele(int x, int y, int t, Uint32 c)
BlitSurfaceColoured(tele[0], NULL, backBuffer, &telerect, ct); BlitSurfaceColoured(tele[0], NULL, backBuffer, &telerect, ct);
} }
setcolreal(c); setcolreal(color);
if (t > 9) t = 8; if (t > 9) t = 8;
if (t < 1) t = 1; if (t < 1) t = 1;
@ -3630,32 +3632,30 @@ void Graphics::drawtele(int x, int y, int t, Uint32 c)
} }
} }
Uint32 Graphics::getRGBA(Uint8 r, Uint8 g, Uint8 b, Uint8 a) SDL_Color Graphics::getRGBA(const Uint8 r, const Uint8 g, const Uint8 b, const Uint8 a)
{ {
return SDL_MapRGBA(backBuffer->format, r, g, b, a); const SDL_Color color = {r, g, b, a};
return color;
} }
Uint32 Graphics::getRGB(Uint8 r, Uint8 g, Uint8 b) SDL_Color Graphics::getRGB(const Uint8 r, const Uint8 g, const Uint8 b)
{ {
return SDL_MapRGB(backBuffer->format, r, g, b); const SDL_Color color = {r, g, b, 255};
return color;
} }
Uint32 Graphics::getRGB(Uint32 _col) SDL_Color Graphics::RGBf(int r, int g, int b)
{ {
return ( _col); r = (r + 128) / 3;
g = (g + 128) / 3;
b = (b + 128) / 3;
const SDL_Color color = {(Uint8) r, (Uint8) g, (Uint8) b, 255};
return color;
} }
Uint32 Graphics::RGBf(int r, int g, int b) void Graphics::setcolreal(const SDL_Color color)
{ {
r = (r+128) / 3; ct = color;
g = (g+128) / 3;
b = (b+128) / 3;
return SDL_MapRGB(backBuffer->format, r, g, b);
}
void Graphics::setcolreal(Uint32 t)
{
ct.colour = t;
} }
void Graphics::drawforetile(int x, int y, int t) void Graphics::drawforetile(int x, int y, int t)
@ -3672,7 +3672,7 @@ void Graphics::drawforetile(int x, int y, int t)
#if !defined(NO_CUSTOM_LEVELS) #if !defined(NO_CUSTOM_LEVELS)
if (shouldrecoloroneway(t, tiles1_mounted)) if (shouldrecoloroneway(t, tiles1_mounted))
{ {
colourTransform thect = {cl.getonewaycol()}; const SDL_Color thect = cl.getonewaycol();
BlitSurfaceTinted(tiles[t], NULL, foregroundBuffer, &rect, thect); BlitSurfaceTinted(tiles[t], NULL, foregroundBuffer, &rect, thect);
} }
else else
@ -3696,7 +3696,7 @@ void Graphics::drawforetile2(int x, int y, int t)
#if !defined(NO_CUSTOM_LEVELS) #if !defined(NO_CUSTOM_LEVELS)
if (shouldrecoloroneway(t, tiles2_mounted)) if (shouldrecoloroneway(t, tiles2_mounted))
{ {
colourTransform thect = {cl.getonewaycol()}; const SDL_Color thect = cl.getonewaycol();
BlitSurfaceTinted(tiles2[t], NULL, foregroundBuffer, &rect, thect); BlitSurfaceTinted(tiles2[t], NULL, foregroundBuffer, &rect, thect);
} }
else else
@ -3800,7 +3800,7 @@ fail:
return false; return false;
} }
Uint32 Graphics::crewcolourreal(int t) SDL_Color Graphics::crewcolourreal(int t)
{ {
switch (t) switch (t)
{ {
@ -3830,7 +3830,7 @@ void Graphics::render_roomname(const char* roomname, int r, int g, int b)
} }
else else
{ {
FillRect(backBuffer, footerrect, 0); FillRect(backBuffer, footerrect, 0, 0, 0);
Print(5, 231, roomname, r, g, b, true); Print(5, 231, roomname, r, g, b, true);
} }
} }

View file

@ -7,7 +7,6 @@
#include "Game.h" #include "Game.h"
#include "GraphicsResources.h" #include "GraphicsResources.h"
#include "GraphicsUtil.h"
#include "Maths.h" #include "Maths.h"
#include "Textbox.h" #include "Textbox.h"
#include "TowerBG.h" #include "TowerBG.h"
@ -42,7 +41,7 @@ public:
void drawhuetile(int x, int y, int t); void drawhuetile(int x, int y, int t);
void huetilesetcol(int t); void huetilesetcol(int t);
Uint32 bigchunkygetcol(int t); SDL_Color bigchunkygetcol(int t);
void drawgravityline(int t); void drawgravityline(int t);
@ -141,7 +140,7 @@ public:
void drawgui(void); void drawgui(void);
void drawsprite(int x, int y, int t, int r, int g, int b); void drawsprite(int x, int y, int t, int r, int g, int b);
void drawsprite(int x, int y, int t, Uint32 c); void drawsprite(int x, int y, int t, SDL_Color color);
void printcrewname(int x, int y, int t); void printcrewname(int x, int y, int t);
void printcrewnamedark(int x, int y, int t); void printcrewnamedark(int x, int y, int t);
@ -202,18 +201,15 @@ public:
void bigbrprint(int x, int y, const std::string& t, int r, int g, int b, bool cen = false, float sc = 2); void bigbrprint(int x, int y, const std::string& t, int r, int g, int b, bool cen = false, float sc = 2);
void drawtele(int x, int y, int t, Uint32 c); void drawtele(int x, int y, int t, SDL_Color c);
Uint32 getRGBA(Uint8 r, Uint8 g, Uint8 b, Uint8 a); SDL_Color getRGBA(Uint8 r, Uint8 g, Uint8 b, Uint8 a);
Uint32 getRGB(Uint8 r, Uint8 g, Uint8 b); SDL_Color getRGB(Uint8 r, Uint8 g, Uint8 b);
Uint32 getRGB(Uint32 _col); SDL_Color RGBf(int r, int g, int b);
void setcolreal(SDL_Color color);
Uint32 RGBf(int r, int g, int b);
void setcolreal(Uint32 t);
void drawbackground(int t); void drawbackground(int t);
void updatebackground(int t); void updatebackground(int t);
@ -263,7 +259,7 @@ public:
void setcol(int t); void setcol(int t);
void drawfinalmap(void); void drawfinalmap(void);
colourTransform ct; SDL_Color ct;
int rcol; int rcol;
@ -346,7 +342,9 @@ public:
int backboxvy[numbackboxes]; int backboxvy[numbackboxes];
float backboxint[numbackboxes]; float backboxint[numbackboxes];
int warpskip, warpfcol, warpbcol; int warpskip;
SDL_Color warpfcol;
SDL_Color warpbcol;
bool translucentroomname; bool translucentroomname;
@ -366,15 +364,15 @@ public:
#endif #endif
float alpha; float alpha;
Uint32 col_crewred; SDL_Color col_crewred;
Uint32 col_crewyellow; SDL_Color col_crewyellow;
Uint32 col_crewgreen; SDL_Color col_crewgreen;
Uint32 col_crewcyan; SDL_Color col_crewcyan;
Uint32 col_crewblue; SDL_Color col_crewblue;
Uint32 col_crewpurple; //actually pink SDL_Color col_crewpurple; //actually pink
Uint32 col_crewinactive; SDL_Color col_crewinactive;
Uint32 col_clock; SDL_Color col_clock;
Uint32 col_trinket; SDL_Color col_trinket;
int col_tr; int col_tr;
int col_tg; int col_tg;
int col_tb; int col_tb;
@ -382,7 +380,7 @@ public:
bool kludgeswnlinewidth; bool kludgeswnlinewidth;
Uint32 crewcolourreal(int t); SDL_Color crewcolourreal(int t);
void render_roomname(const char* roomname, int r, int g, int b); void render_roomname(const char* roomname, int r, int g, int b);

View file

@ -1,5 +1,3 @@
#include "GraphicsUtil.h"
#include <SDL.h> #include <SDL.h>
#include <stddef.h> #include <stddef.h>
#include <stdlib.h> #include <stdlib.h>
@ -91,60 +89,63 @@ SDL_Surface* GetSubSurface( SDL_Surface* metaSurface, int x, int y, int width, i
return preSurface; return preSurface;
} }
static void DrawPixel( SDL_Surface *_surface, int x, int y, Uint32 pixel ) static void DrawPixel(SDL_Surface* surface, const int x, const int y, const SDL_Color color)
{ {
int bpp = _surface->format->BytesPerPixel; const SDL_PixelFormat* fmt = surface->format;
/* Here p is the address to the pixel we want to set */ const int bpp = fmt->BytesPerPixel;
Uint8 *p = (Uint8 *)_surface->pixels + y * _surface->pitch + x * bpp; Uint32* pixel = (Uint32*) ((Uint8*) surface->pixels + y * surface->pitch + x * bpp);
const Uint32 packed =
(color.r << fmt->Rshift) |
(color.g << fmt->Gshift) |
(color.b << fmt->Bshift) |
(color.a << fmt->Ashift);
switch(bpp) switch (bpp)
{ {
case 1: case 1:
*p = pixel;
break;
case 2: case 2:
*(Uint16 *)p = pixel;
break;
case 3: case 3:
p[0] = (pixel >> 16) & 0xff; SDL_assert(0 && "Non-32-bit colors not supported!");
p[1] = (pixel >> 8) & 0xff; return;
p[2] = pixel & 0xff;
break;
case 4: case 4:
*(Uint32 *)p = pixel; *pixel = packed;
break; break;
} }
} }
Uint32 ReadPixel( SDL_Surface *_surface, int x, int y ) SDL_Color ReadPixel(const SDL_Surface* surface, const int x, const int y)
{ {
int bpp = _surface->format->BytesPerPixel; const SDL_PixelFormat* fmt = surface->format;
/* Here p is the address to the pixel we want to retrieve */ const int bpp = surface->format->BytesPerPixel;
Uint8 *p = (Uint8 *)_surface->pixels + y * _surface->pitch + x * bpp; const Uint32* pixel = (Uint32*) ((Uint8*) surface->pixels + y * surface->pitch + x * bpp);
switch(bpp) switch (bpp)
{ {
case 1: case 1:
return *p;
break;
case 2: case 2:
return *(Uint16 *)p;
break;
case 3: case 3:
return p[0] | p[1] << 8 | p[2] << 16; {
SDL_assert(0 && "Non-32-bit colors not supported!");
const SDL_Color color = {0, 0, 0, 0};
return color;
}
case 4: case 4:
return *(Uint32 *)p; {
break; const SDL_Color color = {
(Uint8) ((*pixel & fmt->Rmask) >> fmt->Rshift),
default: (Uint8) ((*pixel & fmt->Gmask) >> fmt->Gshift),
return 0; /* shouldn't happen, but avoids warnings */ (Uint8) ((*pixel & fmt->Bmask) >> fmt->Bshift),
(Uint8) ((*pixel & fmt->Amask) >> fmt->Ashift)
};
return color;
} }
}
/* shouldn't happen, but avoids warnings */
const SDL_Color color = {0, 0, 0, 0};
return color;
} }
SDL_Surface * ScaleSurface( SDL_Surface *_surface, int Width, int Height, SDL_Surface * Dest ) SDL_Surface * ScaleSurface( SDL_Surface *_surface, int Width, int Height, SDL_Surface * Dest )
@ -199,95 +200,70 @@ void BlitSurfaceStandard( SDL_Surface* _src, SDL_Rect* _srcRect, SDL_Surface* _d
} }
void BlitSurfaceColoured( void BlitSurfaceColoured(
SDL_Surface* _src, SDL_Surface* src,
SDL_Rect* _srcRect, const SDL_Rect* src_rect,
SDL_Surface* _dest, SDL_Surface* dest,
SDL_Rect* _destRect, SDL_Rect* dest_rect,
colourTransform& ct const SDL_Color color
) { ) {
SDL_Rect *tempRect = _destRect; SDL_Surface* tempsurface = RecreateSurface(src);
const SDL_PixelFormat& fmt = *(_src->format); for (int x = 0; x < tempsurface->w; x++)
SDL_Surface* tempsurface = RecreateSurface(_src);
for(int x = 0; x < tempsurface->w; x++)
{ {
for(int y = 0; y < tempsurface->h; y++) for (int y = 0; y < tempsurface->h; y++)
{ {
Uint32 pixel = ReadPixel(_src, x, y); const SDL_Color pixel = ReadPixel(src, x, y);
Uint32 Alpha = pixel & fmt.Amask; const float div1 = pixel.a / 255.0f;
Uint32 result = ct.colour & 0x00FFFFFF; const float div2 = color.a / 255.0f;
Uint32 CTAlpha = ct.colour & fmt.Amask; const Uint8 alpha = (div1 * div2) * 255.0f;
float div1 = ((Alpha >> 24) / 255.0f); const SDL_Color result = {color.r, color.g, color.b, alpha};
float div2 = ((CTAlpha >> 24) / 255.0f); DrawPixel(tempsurface, x, y, result);
Uint32 UseAlpha = (div1 * div2) * 255.0f;
DrawPixel(tempsurface, x, y, result | (UseAlpha << 24));
} }
} }
SDL_BlitSurface(tempsurface, _srcRect, _dest, tempRect); SDL_BlitSurface(tempsurface, src_rect, dest, dest_rect);
VVV_freefunc(SDL_FreeSurface, tempsurface); VVV_freefunc(SDL_FreeSurface, tempsurface);
} }
void BlitSurfaceTinted( void BlitSurfaceTinted(
SDL_Surface* _src, SDL_Surface* src,
SDL_Rect* _srcRect, const SDL_Rect* src_rect,
SDL_Surface* _dest, SDL_Surface* dest,
SDL_Rect* _destRect, SDL_Rect* dest_rect,
colourTransform& ct const SDL_Color color
) { ) {
SDL_Rect *tempRect = _destRect; SDL_Surface* tempsurface = RecreateSurface(src);
const SDL_PixelFormat& fmt = *(_src->format); for (int x = 0; x < tempsurface->w; x++)
{
for (int y = 0; y < tempsurface->h; y++)
{
const SDL_Color pixel = ReadPixel(src, x, y);
SDL_Surface* tempsurface = RecreateSurface(_src); double red = pixel.r * 0.299;
double green = pixel.g * 0.587;
double blue = pixel.b * 0.114;
for (int x = 0; x < tempsurface->w; x++) { const double gray = SDL_floor(red + green + blue + 0.5);
for (int y = 0; y < tempsurface->h; y++) {
Uint32 pixel = ReadPixel(_src, x, y);
Uint8 pixred = (pixel & _src->format->Rmask) >> 16; red = gray * color.r / 255.0;
Uint8 pixgreen = (pixel & _src->format->Gmask) >> 8; green = gray * color.g / 255.0;
Uint8 pixblue = (pixel & _src->format->Bmask) >> 0; blue = gray * color.b / 255.0;
double temp_pixred = pixred * 0.299; red = SDL_clamp(red, 0, 255);
double temp_pixgreen = pixgreen * 0.587; green = SDL_clamp(green, 0, 255);
double temp_pixblue = pixblue * 0.114; blue = SDL_clamp(blue, 0, 255);
double gray = SDL_floor((temp_pixred + temp_pixgreen + temp_pixblue + 0.5)); const float div1 = pixel.a / 255.0f;
const float div2 = color.a / 255.0f;
const Uint8 alpha = (div1 * div2) * 255.0f;
Uint8 ctred = (ct.colour & graphics.backBuffer->format->Rmask) >> 16; const SDL_Color result = {(Uint8) red, (Uint8) green, (Uint8) blue, alpha};
Uint8 ctgreen = (ct.colour & graphics.backBuffer->format->Gmask) >> 8; DrawPixel(tempsurface, x, y, result);
Uint8 ctblue = (ct.colour & graphics.backBuffer->format->Bmask) >> 0;
temp_pixred = gray * ctred / 255.0;
temp_pixgreen = gray * ctgreen / 255.0;
temp_pixblue = gray * ctblue / 255.0;
if (temp_pixred > 255)
temp_pixred = 255;
if (temp_pixgreen > 255)
temp_pixgreen = 255;
if (temp_pixblue > 255)
temp_pixblue = 255;
pixred = temp_pixred;
pixgreen = temp_pixgreen;
pixblue = temp_pixblue;
Uint32 Alpha = pixel & fmt.Amask;
Uint32 result = (pixred << 16) + (pixgreen << 8) + (pixblue << 0);
Uint32 CTAlpha = ct.colour & fmt.Amask;
float div1 = ((Alpha >> 24) / 255.0f);
float div2 = ((CTAlpha >> 24) / 255.0f);
Uint32 UseAlpha = (div1 * div2) * 255.0f;
DrawPixel(tempsurface, x, y, result | (UseAlpha << 24));
} }
} }
SDL_BlitSurface(tempsurface, _srcRect, _dest, tempRect); SDL_BlitSurface(tempsurface, src_rect, dest, dest_rect);
VVV_freefunc(SDL_FreeSurface, tempsurface); VVV_freefunc(SDL_FreeSurface, tempsurface);
} }
@ -316,29 +292,29 @@ void UpdateFilter(void)
} }
} }
SDL_Surface* ApplyFilter( SDL_Surface* _src ) SDL_Surface* ApplyFilter(SDL_Surface* src)
{ {
SDL_Surface* _ret = RecreateSurface(_src); SDL_Surface* ret = RecreateSurface(src);
int redOffset = rand() % 4; const int red_offset = rand() % 4;
for(int x = 0; x < _src->w; x++) for (int x = 0; x < ret->w; x++)
{ {
for(int y = 0; y < _src->h; y++) for (int y = 0; y < ret->h; y++)
{ {
int sampley = (y + (int) graphics.lerp(oldscrollamount, scrollamount) )% 240; const int sampley = (y + (int) graphics.lerp(oldscrollamount, scrollamount)) % 240;
Uint32 pixel = ReadPixel(_src, x,sampley); const SDL_Color pixel = ReadPixel(src, x, sampley);
Uint8 green = (pixel & _src->format->Gmask) >> 8; Uint8 green = pixel.g;
Uint8 blue = (pixel & _src->format->Bmask) >> 0; Uint8 blue = pixel.b;
Uint32 pixelOffset = ReadPixel(_src, SDL_min(x+redOffset, 319), sampley) ; const SDL_Color pixel_offset = ReadPixel(src, SDL_min(x + red_offset, 319), sampley);
Uint8 red = (pixelOffset & _src->format->Rmask) >> 16 ; Uint8 red = pixel_offset.r;
double mult; double mult;
int tmp; /* needed to avoid char overflow */ int tmp; /* needed to avoid char overflow */
if(isscrolling && sampley > 220 && ((rand() %10) < 4)) if (isscrolling && sampley > 220 && ((rand() % 10) < 4))
{ {
mult = 0.6; mult = 0.6;
} }
@ -354,26 +330,26 @@ SDL_Surface* ApplyFilter( SDL_Surface* _src )
tmp = blue + fRandom() * mult * 254; tmp = blue + fRandom() * mult * 254;
blue = SDL_min(tmp, 255); blue = SDL_min(tmp, 255);
if(y % 2 == 0) if (y % 2 == 0)
{ {
red = static_cast<Uint8>(red / 1.2f); red = (Uint8) (red / 1.2f);
green = static_cast<Uint8>(green / 1.2f); green = (Uint8) (green / 1.2f);
blue = static_cast<Uint8>(blue / 1.2f); blue = (Uint8) (blue / 1.2f);
} }
int distX = static_cast<int>((SDL_abs (160.0f -x ) / 160.0f) *16); int distX = (int) ((SDL_abs(160.0f - x) / 160.0f) * 16);
int distY = static_cast<int>((SDL_abs (120.0f -y ) / 120.0f)*32); int distY = (int) ((SDL_abs(120.0f - y) / 120.0f) * 32);
red = SDL_max(red - ( distX +distY), 0); red = SDL_max(red - (distX + distY), 0);
green = SDL_max(green - ( distX +distY), 0); green = SDL_max(green - (distX + distY), 0);
blue = SDL_max(blue - ( distX +distY), 0); blue = SDL_max(blue - (distX + distY), 0);
Uint32 finalPixel = ((red<<16) + (green<<8) + (blue<<0)) | (pixel &_src->format->Amask);
DrawPixel(_ret,x,y, finalPixel);
const SDL_Color color = {red, green, blue, pixel.a};
DrawPixel(ret, x, y, color);
} }
} }
return _ret;
return ret;
} }
void FillRect( SDL_Surface* _surface, const int _x, const int _y, const int _w, const int _h, const int r, int g, int b ) void FillRect( SDL_Surface* _surface, const int _x, const int _y, const int _w, const int _h, const int r, int g, int b )
@ -389,26 +365,35 @@ void FillRect( SDL_Surface* _surface, const int r, int g, int b )
SDL_FillRect(_surface, NULL, color); SDL_FillRect(_surface, NULL, color);
} }
void FillRect( SDL_Surface* _surface, const int color )
{
SDL_FillRect(_surface, NULL, color);
}
void FillRect( SDL_Surface* _surface, const int x, const int y, const int w, const int h, int rgba )
{
SDL_Rect rect = {x, y, w, h};
SDL_FillRect(_surface, &rect, rgba);
}
void FillRect( SDL_Surface* _surface, SDL_Rect& _rect, const int r, int g, int b ) void FillRect( SDL_Surface* _surface, SDL_Rect& _rect, const int r, int g, int b )
{ {
Uint32 color = SDL_MapRGB(_surface->format, r, g, b); Uint32 color = SDL_MapRGB(_surface->format, r, g, b);
SDL_FillRect(_surface, &_rect, color); SDL_FillRect(_surface, &_rect, color);
} }
void FillRect( SDL_Surface* _surface, SDL_Rect rect, int rgba ) void FillRect(SDL_Surface* surface, const SDL_Rect rect, const SDL_Color color)
{ {
SDL_FillRect(_surface, &rect, rgba); const Uint32 mapped = SDL_MapRGBA(surface->format, color.r, color.g, color.b, color.a);
SDL_FillRect(surface, &rect, mapped);
}
void FillRect(SDL_Surface* surface, const SDL_Color color)
{
const Uint32 mapped = SDL_MapRGBA(surface->format, color.r, color.g, color.b, color.a);
SDL_FillRect(surface, NULL, mapped);
}
void FillRect(SDL_Surface* surface, const int x, const int y, const int w, const int h, const SDL_Color color)
{
const SDL_Rect rect = {x, y, w, h};
const Uint32 mapped = SDL_MapRGBA(surface->format, color.r, color.g, color.b, color.a);
SDL_FillRect(surface, &rect, mapped);
}
void FillRect(SDL_Surface* surface, const int r, const int g, const int b, const int a)
{
const Uint32 mapped = SDL_MapRGBA(surface->format, r, g, b, a);
SDL_FillRect(surface, NULL, mapped);
} }
void ClearSurface(SDL_Surface* surface) void ClearSurface(SDL_Surface* surface)

View file

@ -3,37 +3,33 @@
#include <SDL.h> #include <SDL.h>
struct colourTransform
{
Uint32 colour;
};
void setRect(SDL_Rect& _r, int x, int y, int w, int h); void setRect(SDL_Rect& _r, int x, int y, int w, int h);
SDL_Surface* GetSubSurface( SDL_Surface* metaSurface, int x, int y, int width, int height ); SDL_Surface* GetSubSurface( SDL_Surface* metaSurface, int x, int y, int width, int height );
Uint32 ReadPixel( SDL_Surface *surface, int x, int y ); SDL_Color ReadPixel(const SDL_Surface* surface, int x, int y);
SDL_Surface * ScaleSurface( SDL_Surface *Surface, int Width, int Height, SDL_Surface * Dest = NULL ); SDL_Surface * ScaleSurface( SDL_Surface *Surface, int Width, int Height, SDL_Surface * Dest = NULL );
void BlitSurfaceStandard( SDL_Surface* _src, SDL_Rect* _srcRect, SDL_Surface* _dest, SDL_Rect* _destRect ); void BlitSurfaceStandard( SDL_Surface* _src, SDL_Rect* _srcRect, SDL_Surface* _dest, SDL_Rect* _destRect );
void BlitSurfaceColoured( SDL_Surface* _src, SDL_Rect* _srcRect, SDL_Surface* _dest, SDL_Rect* _destRect, colourTransform& ct ); void BlitSurfaceColoured(SDL_Surface* src, const SDL_Rect* src_rect, SDL_Surface* dest, SDL_Rect* dest_rect, SDL_Color color);
void BlitSurfaceTinted( SDL_Surface* _src, SDL_Rect* _srcRect, SDL_Surface* _dest, SDL_Rect* _destRect, colourTransform& ct ); void BlitSurfaceTinted(SDL_Surface* src, const SDL_Rect* src_rect, SDL_Surface* dest, SDL_Rect* dest_rect, SDL_Color color);
void FillRect( SDL_Surface* surface, const int x, const int y, const int w, const int h, const int r, int g, int b ); void FillRect( SDL_Surface* surface, const int x, const int y, const int w, const int h, const int r, int g, int b );
void FillRect( SDL_Surface* surface, const int r, int g, int b ); void FillRect( SDL_Surface* surface, const int r, int g, int b );
void FillRect( SDL_Surface* surface, const int color );
void FillRect( SDL_Surface* surface, const int x, const int y, const int w, const int h, int rgba );
void FillRect( SDL_Surface* surface, SDL_Rect& rect, const int r, int g, int b ); void FillRect( SDL_Surface* surface, SDL_Rect& rect, const int r, int g, int b );
void FillRect( SDL_Surface* surface, SDL_Rect rect, int rgba ); void FillRect(SDL_Surface* surface, SDL_Rect rect, SDL_Color color);
void FillRect(SDL_Surface* surface, SDL_Color color);
void FillRect(SDL_Surface* surface, int x, int y, int w, int h, SDL_Color color);
void FillRect(SDL_Surface* surface, int r, int g, int b, int a);
void ClearSurface(SDL_Surface* surface); void ClearSurface(SDL_Surface* surface);

View file

@ -9,6 +9,7 @@
#include "Game.h" #include "Game.h"
#include "GlitchrunnerMode.h" #include "GlitchrunnerMode.h"
#include "Graphics.h" #include "Graphics.h"
#include "GraphicsUtil.h"
#include "KeyPoll.h" #include "KeyPoll.h"
#include "Localization.h" #include "Localization.h"
#include "LocalizationMaint.h" #include "LocalizationMaint.h"

View file

@ -13,6 +13,7 @@
#include "FileSystemUtils.h" #include "FileSystemUtils.h"
#include "Game.h" #include "Game.h"
#include "Graphics.h" #include "Graphics.h"
#include "GraphicsUtil.h"
#include "Input.h" #include "Input.h"
#include "InterimVersion.h" #include "InterimVersion.h"
#include "KeyPoll.h" #include "KeyPoll.h"

View file

@ -2,6 +2,7 @@
#include "Enums.h" #include "Enums.h"
#include "Game.h" #include "Game.h"
#include "Graphics.h" #include "Graphics.h"
#include "GraphicsUtil.h"
#include "Localization.h" #include "Localization.h"
#include "KeyPoll.h" #include "KeyPoll.h"
#include "UtilityClass.h" #include "UtilityClass.h"
@ -9,7 +10,9 @@
static int pre_fakepercent=0, pre_transition=30; static int pre_fakepercent=0, pre_transition=30;
static bool pre_startgame=false; static bool pre_startgame=false;
static int pre_darkcol=0, pre_lightcol=0, pre_curcol=0, pre_coltimer=0, pre_offset=0; static SDL_Color pre_darkcol = {0, 0, 0, 0};
static SDL_Color pre_lightcol = {0, 0, 0, 0};
static int pre_curcol = 0, pre_coltimer = 0, pre_offset = 0;
static int pre_frontrectx=30, pre_frontrecty=20, pre_frontrectw=260, pre_frontrecth=200; static int pre_frontrectx=30, pre_frontrecty=20, pre_frontrectw=260, pre_frontrecth=200;
static int pre_temprectx=0, pre_temprecty=0, pre_temprectw=320, pre_temprecth=240; static int pre_temprectx=0, pre_temprecty=0, pre_temprectw=320, pre_temprecth=240;