mirror of
https://github.com/TerryCavanagh/VVVVVV.git
synced 2025-01-10 19:09:45 +01:00
Refactor tower background to use a separate object instead
Previously, the tower background was controlled by a disparate set of attributes on Graphics and mapclass, and wasn't really encapsulated. (If that's what that word means, I don't particularly care about object-oriented lingo.) But now, all relevant things that a tower background has has been put into a TowerBG struct, so it will be easy to make multiple copies without having to duplicate the code that handles it.
This commit is contained in:
parent
20207e2098
commit
72c048d71e
12 changed files with 198 additions and 185 deletions
|
@ -1373,7 +1373,7 @@ void Game::updatestate()
|
||||||
gamestate = TITLEMODE;
|
gamestate = TITLEMODE;
|
||||||
graphics.fademode = 4;
|
graphics.fademode = 4;
|
||||||
graphics.backgrounddrawn = true;
|
graphics.backgrounddrawn = true;
|
||||||
map.tdrawback = true;
|
graphics.towerbg.tdrawback = true;
|
||||||
createmenu(Menu::timetrialcomplete);
|
createmenu(Menu::timetrialcomplete);
|
||||||
state = 0;
|
state = 0;
|
||||||
break;
|
break;
|
||||||
|
@ -2942,7 +2942,7 @@ void Game::updatestate()
|
||||||
gamestate = TITLEMODE;
|
gamestate = TITLEMODE;
|
||||||
graphics.fademode = 4;
|
graphics.fademode = 4;
|
||||||
graphics.backgrounddrawn = true;
|
graphics.backgrounddrawn = true;
|
||||||
map.tdrawback = true;
|
graphics.towerbg.tdrawback = true;
|
||||||
music.play(6);
|
music.play(6);
|
||||||
state = 0;
|
state = 0;
|
||||||
break;
|
break;
|
||||||
|
@ -3278,7 +3278,7 @@ void Game::updatestate()
|
||||||
gamestate = TITLEMODE;
|
gamestate = TITLEMODE;
|
||||||
graphics.fademode = 4;
|
graphics.fademode = 4;
|
||||||
graphics.backgrounddrawn = true;
|
graphics.backgrounddrawn = true;
|
||||||
map.tdrawback = true;
|
graphics.towerbg.tdrawback = true;
|
||||||
createmenu(Menu::nodeathmodecomplete);
|
createmenu(Menu::nodeathmodecomplete);
|
||||||
state = 0;
|
state = 0;
|
||||||
break;
|
break;
|
||||||
|
@ -7129,7 +7129,7 @@ void Game::quittomenu()
|
||||||
FILESYSTEM_unmountassets(); // should be before music.play(6)
|
FILESYSTEM_unmountassets(); // should be before music.play(6)
|
||||||
music.play(6);
|
music.play(6);
|
||||||
graphics.backgrounddrawn = false;
|
graphics.backgrounddrawn = false;
|
||||||
map.tdrawback = true;
|
graphics.towerbg.tdrawback = true;
|
||||||
graphics.flipmode = false;
|
graphics.flipmode = false;
|
||||||
//Don't be stuck on the summary screen,
|
//Don't be stuck on the summary screen,
|
||||||
//or "who do you want to play the level with?"
|
//or "who do you want to play the level with?"
|
||||||
|
@ -7223,7 +7223,7 @@ void Game::returntoeditor()
|
||||||
ed.level[i+(j*ed.maxwidth)].warpdir=ed.kludgewarpdir[i+(j*ed.maxwidth)];
|
ed.level[i+(j*ed.maxwidth)].warpdir=ed.kludgewarpdir[i+(j*ed.maxwidth)];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
map.scrolldir = 0;
|
graphics.towerbg.scrolldir = 0;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -7233,7 +7233,7 @@ void Game::returntopausemenu()
|
||||||
returntomenu(kludge_ingametemp);
|
returntomenu(kludge_ingametemp);
|
||||||
gamestate = MAPMODE;
|
gamestate = MAPMODE;
|
||||||
map.kludge_to_bg();
|
map.kludge_to_bg();
|
||||||
map.tdrawback = true;
|
graphics.towerbg.tdrawback = true;
|
||||||
graphics.backgrounddrawn = false;
|
graphics.backgrounddrawn = false;
|
||||||
mapheld = true;
|
mapheld = true;
|
||||||
graphics.flipmode = graphics.setflipmode;
|
graphics.flipmode = graphics.setflipmode;
|
||||||
|
|
|
@ -115,10 +115,9 @@ void Graphics::init()
|
||||||
menubuffer = NULL;
|
menubuffer = NULL;
|
||||||
screenbuffer = NULL;
|
screenbuffer = NULL;
|
||||||
tempBuffer = NULL;
|
tempBuffer = NULL;
|
||||||
towerbuffer = NULL;
|
|
||||||
towerbuffer_lerp = NULL;
|
|
||||||
footerbuffer = NULL;
|
footerbuffer = NULL;
|
||||||
ghostbuffer = NULL;
|
ghostbuffer = NULL;
|
||||||
|
towerbg = TowerBG();
|
||||||
trinketr = 0;
|
trinketr = 0;
|
||||||
trinketg = 0;
|
trinketg = 0;
|
||||||
trinketb = 0;
|
trinketb = 0;
|
||||||
|
@ -736,13 +735,13 @@ void Graphics::drawtowertile( int x, int y, int t )
|
||||||
x += 8;
|
x += 8;
|
||||||
y += 8;
|
y += 8;
|
||||||
SDL_Rect rect = { Sint16(x), Sint16(y), tiles_rect.w, tiles_rect.h };
|
SDL_Rect rect = { Sint16(x), Sint16(y), tiles_rect.w, tiles_rect.h };
|
||||||
BlitSurfaceStandard(tiles2[t], NULL, towerbuffer, &rect);
|
BlitSurfaceStandard(tiles2[t], NULL, towerbg.buffer, &rect);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Graphics::drawtowertile3( int x, int y, int t, int off )
|
void Graphics::drawtowertile3( int x, int y, int t, TowerBG& bg_obj )
|
||||||
{
|
{
|
||||||
t += off*30;
|
t += bg_obj.colstate*30;
|
||||||
if (!INBOUNDS_VEC(t, tiles3))
|
if (!INBOUNDS_VEC(t, tiles3))
|
||||||
{
|
{
|
||||||
WHINE_ONCE("drawtowertile3() out-of-bounds!")
|
WHINE_ONCE("drawtowertile3() out-of-bounds!")
|
||||||
|
@ -751,7 +750,7 @@ void Graphics::drawtowertile3( int x, int y, int t, int off )
|
||||||
x += 8;
|
x += 8;
|
||||||
y += 8;
|
y += 8;
|
||||||
SDL_Rect rect = { Sint16(x), Sint16(y), tiles_rect.w, tiles_rect.h };
|
SDL_Rect rect = { Sint16(x), Sint16(y), tiles_rect.w, tiles_rect.h };
|
||||||
BlitSurfaceStandard(tiles3[t], NULL, towerbuffer, &rect);
|
BlitSurfaceStandard(tiles3[t], NULL, bg_obj.buffer, &rect);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Graphics::drawgui()
|
void Graphics::drawgui()
|
||||||
|
@ -2116,15 +2115,15 @@ void Graphics::drawbackground( int t )
|
||||||
}
|
}
|
||||||
case 3: //Warp zone (horizontal)
|
case 3: //Warp zone (horizontal)
|
||||||
FillRect(backBuffer, 0x000000);
|
FillRect(backBuffer, 0x000000);
|
||||||
BlitSurfaceStandard(towerbuffer, NULL, towerbuffer_lerp, NULL);
|
BlitSurfaceStandard(towerbg.buffer, NULL, towerbg.buffer_lerp, NULL);
|
||||||
ScrollSurface(towerbuffer_lerp, lerp(0, -3), 0);
|
ScrollSurface(towerbg.buffer_lerp, lerp(0, -3), 0);
|
||||||
BlitSurfaceStandard(towerbuffer_lerp, &towerbuffer_rect, backBuffer, NULL);
|
BlitSurfaceStandard(towerbg.buffer_lerp, &towerbuffer_rect, backBuffer, NULL);
|
||||||
break;
|
break;
|
||||||
case 4: //Warp zone (vertical)
|
case 4: //Warp zone (vertical)
|
||||||
FillRect(backBuffer, 0x000000);
|
FillRect(backBuffer, 0x000000);
|
||||||
SDL_BlitSurface(towerbuffer, NULL, towerbuffer_lerp, NULL);
|
SDL_BlitSurface(towerbg.buffer, NULL, towerbg.buffer_lerp, NULL);
|
||||||
ScrollSurface(towerbuffer_lerp, 0, lerp(0, -3));
|
ScrollSurface(towerbg.buffer_lerp, 0, lerp(0, -3));
|
||||||
SDL_BlitSurface(towerbuffer_lerp, &towerbuffer_rect, backBuffer, NULL);
|
SDL_BlitSurface(towerbg.buffer_lerp, &towerbuffer_rect, backBuffer, NULL);
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
//Warp zone, central
|
//Warp zone, central
|
||||||
|
@ -2301,7 +2300,7 @@ void Graphics::updatebackground(int t)
|
||||||
|
|
||||||
if (backgrounddrawn)
|
if (backgrounddrawn)
|
||||||
{
|
{
|
||||||
ScrollSurface(towerbuffer, -3, 0 );
|
ScrollSurface(towerbg.buffer, -3, 0 );
|
||||||
for (int j = 0; j < 15; j++)
|
for (int j = 0; j < 15; j++)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < 2; i++)
|
for (int i = 0; i < 2; i++)
|
||||||
|
@ -2317,7 +2316,7 @@ void Graphics::updatebackground(int t)
|
||||||
{
|
{
|
||||||
//draw the whole thing for the first time!
|
//draw the whole thing for the first time!
|
||||||
backoffset = 0;
|
backoffset = 0;
|
||||||
FillRect(towerbuffer, 0x000000);
|
FillRect(towerbg.buffer, 0x000000);
|
||||||
for (int j = 0; j < 15; j++)
|
for (int j = 0; j < 15; j++)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < 21; i++)
|
for (int i = 0; i < 21; i++)
|
||||||
|
@ -2340,7 +2339,7 @@ void Graphics::updatebackground(int t)
|
||||||
|
|
||||||
if (backgrounddrawn)
|
if (backgrounddrawn)
|
||||||
{
|
{
|
||||||
ScrollSurface(towerbuffer,0,-3);
|
ScrollSurface(towerbg.buffer,0,-3);
|
||||||
for (int j = 0; j < 2; j++)
|
for (int j = 0; j < 2; j++)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < 21; i++)
|
for (int i = 0; i < 21; i++)
|
||||||
|
@ -2356,7 +2355,7 @@ void Graphics::updatebackground(int t)
|
||||||
{
|
{
|
||||||
//draw the whole thing for the first time!
|
//draw the whole thing for the first time!
|
||||||
backoffset = 0;
|
backoffset = 0;
|
||||||
FillRect(towerbuffer,0x000000 );
|
FillRect(towerbg.buffer,0x000000 );
|
||||||
for (int j = 0; j < 16; j++)
|
for (int j = 0; j < 16; j++)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < 21; i++)
|
for (int i = 0; i < 21; i++)
|
||||||
|
@ -2474,7 +2473,7 @@ void Graphics::drawtowermap()
|
||||||
for (int i = 0; i < 40; i++)
|
for (int i = 0; i < 40; i++)
|
||||||
{
|
{
|
||||||
temp = map.tower.at(i, j, yoff);
|
temp = map.tower.at(i, j, yoff);
|
||||||
if (temp > 0) drawtile3(i * 8, (j * 8) - (yoff % 8), temp, map.colstate);
|
if (temp > 0) drawtile3(i * 8, (j * 8) - (yoff % 8), temp, towerbg.colstate);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2485,66 +2484,66 @@ void Graphics::drawtowerspikes()
|
||||||
int spikelevelbottom = lerp(map.oldspikelevelbottom, map.spikelevelbottom);
|
int spikelevelbottom = lerp(map.oldspikelevelbottom, map.spikelevelbottom);
|
||||||
for (int i = 0; i < 40; i++)
|
for (int i = 0; i < 40; i++)
|
||||||
{
|
{
|
||||||
drawtile3(i * 8, -8+spikeleveltop, 9, map.colstate);
|
drawtile3(i * 8, -8+spikeleveltop, 9, towerbg.colstate);
|
||||||
drawtile3(i * 8, 230-spikelevelbottom, 8, map.colstate, 8 - spikelevelbottom);
|
drawtile3(i * 8, 230-spikelevelbottom, 8, towerbg.colstate, 8 - spikelevelbottom);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Graphics::drawtowerbackground()
|
void Graphics::drawtowerbackground(const TowerBG& bg_obj)
|
||||||
{
|
{
|
||||||
FillRect(backBuffer, 0x000000);
|
FillRect(backBuffer, 0x000000);
|
||||||
SDL_BlitSurface(towerbuffer, NULL, towerbuffer_lerp, NULL);
|
SDL_BlitSurface(bg_obj.buffer, NULL, bg_obj.buffer_lerp, NULL);
|
||||||
ScrollSurface(towerbuffer_lerp, 0, lerp(0, -map.bscroll));
|
ScrollSurface(bg_obj.buffer_lerp, 0, lerp(0, -bg_obj.bscroll));
|
||||||
SDL_BlitSurface(towerbuffer_lerp, &towerbuffer_rect, backBuffer, NULL);
|
SDL_BlitSurface(bg_obj.buffer_lerp, &towerbuffer_rect, backBuffer, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Graphics::updatetowerbackground()
|
void Graphics::updatetowerbackground(TowerBG& bg_obj)
|
||||||
{
|
{
|
||||||
int temp;
|
int temp;
|
||||||
|
|
||||||
if (map.bypos < 0) map.bypos += 120 * 8;
|
if (bg_obj.bypos < 0) bg_obj.bypos += 120 * 8;
|
||||||
|
|
||||||
if (map.tdrawback)
|
if (bg_obj.tdrawback)
|
||||||
{
|
{
|
||||||
int off = map.scrolldir == 0 ? 0 : map.bscroll;
|
int off = bg_obj.scrolldir == 0 ? 0 : bg_obj.bscroll;
|
||||||
//Draw the whole thing; needed for every colour cycle!
|
//Draw the whole thing; needed for every colour cycle!
|
||||||
for (int j = -1; j < 32; j++)
|
for (int j = -1; j < 32; j++)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < 40; i++)
|
for (int i = 0; i < 40; i++)
|
||||||
{
|
{
|
||||||
temp = map.tower.backat(i, j, map.bypos);
|
temp = map.tower.backat(i, j, bg_obj.bypos);
|
||||||
drawtowertile3(i * 8, (j * 8) - (map.bypos % 8) - off, temp, map.colstate);
|
drawtowertile3(i * 8, (j * 8) - (bg_obj.bypos % 8) - off, temp, bg_obj);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
map.tdrawback = false;
|
bg_obj.tdrawback = false;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
//just update the bottom
|
//just update the bottom
|
||||||
ScrollSurface(towerbuffer, 0, -map.bscroll);
|
ScrollSurface(bg_obj.buffer, 0, -bg_obj.bscroll);
|
||||||
if (map.scrolldir == 0)
|
if (bg_obj.scrolldir == 0)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < 40; i++)
|
for (int i = 0; i < 40; i++)
|
||||||
{
|
{
|
||||||
temp = map.tower.backat(i, -1, map.bypos);
|
temp = map.tower.backat(i, -1, bg_obj.bypos);
|
||||||
drawtowertile3(i * 8, -1*8 - (map.bypos % 8), temp, map.colstate);
|
drawtowertile3(i * 8, -1*8 - (bg_obj.bypos % 8), temp, bg_obj);
|
||||||
temp = map.tower.backat(i, 0, map.bypos);
|
temp = map.tower.backat(i, 0, bg_obj.bypos);
|
||||||
drawtowertile3(i * 8, -(map.bypos % 8), temp, map.colstate);
|
drawtowertile3(i * 8, -(bg_obj.bypos % 8), temp, bg_obj);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
for (int i = 0; i < 40; i++)
|
for (int i = 0; i < 40; i++)
|
||||||
{
|
{
|
||||||
temp = map.tower.backat(i, 29, map.bypos);
|
temp = map.tower.backat(i, 29, bg_obj.bypos);
|
||||||
drawtowertile3(i * 8, 29*8 - (map.bypos % 8) - map.bscroll, temp, map.colstate);
|
drawtowertile3(i * 8, 29*8 - (bg_obj.bypos % 8) - bg_obj.bscroll, temp, bg_obj);
|
||||||
temp = map.tower.backat(i, 30, map.bypos);
|
temp = map.tower.backat(i, 30, bg_obj.bypos);
|
||||||
drawtowertile3(i * 8, 30*8 - (map.bypos % 8) - map.bscroll, temp, map.colstate);
|
drawtowertile3(i * 8, 30*8 - (bg_obj.bypos % 8) - bg_obj.bscroll, temp, bg_obj);
|
||||||
temp = map.tower.backat(i, 31, map.bypos);
|
temp = map.tower.backat(i, 31, bg_obj.bypos);
|
||||||
drawtowertile3(i * 8, 31*8 - (map.bypos % 8) - map.bscroll, temp, map.colstate);
|
drawtowertile3(i * 8, 31*8 - (bg_obj.bypos % 8) - bg_obj.bscroll, temp, bg_obj);
|
||||||
temp = map.tower.backat(i, 32, map.bypos);
|
temp = map.tower.backat(i, 32, bg_obj.bypos);
|
||||||
drawtowertile3(i * 8, 32*8 - (map.bypos % 8) - map.bscroll, temp, map.colstate);
|
drawtowertile3(i * 8, 32*8 - (bg_obj.bypos % 8) - bg_obj.bscroll, temp, bg_obj);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,6 +11,7 @@
|
||||||
#include "Maths.h"
|
#include "Maths.h"
|
||||||
#include "Screen.h"
|
#include "Screen.h"
|
||||||
#include "Textbox.h"
|
#include "Textbox.h"
|
||||||
|
#include "TowerBG.h"
|
||||||
|
|
||||||
class Graphics
|
class Graphics
|
||||||
{
|
{
|
||||||
|
@ -168,7 +169,7 @@ public:
|
||||||
void drawtile2( int x, int y, int t );
|
void drawtile2( int x, int y, int t );
|
||||||
void drawtile( int x, int y, int t );
|
void drawtile( int x, int y, int t );
|
||||||
void drawtowertile( int x, int y, int t );
|
void drawtowertile( int x, int y, int t );
|
||||||
void drawtowertile3( int x, int y, int t, int off );
|
void drawtowertile3( int x, int y, int t, TowerBG& bg_obj );
|
||||||
|
|
||||||
void drawmap();
|
void drawmap();
|
||||||
|
|
||||||
|
@ -192,8 +193,8 @@ public:
|
||||||
|
|
||||||
void menuoffrender();
|
void menuoffrender();
|
||||||
|
|
||||||
void drawtowerbackground();
|
void drawtowerbackground(const TowerBG& bg_obj);
|
||||||
void updatetowerbackground();
|
void updatetowerbackground(TowerBG& bg_obj);
|
||||||
|
|
||||||
void setcol(int t);
|
void setcol(int t);
|
||||||
void drawfinalmap();
|
void drawfinalmap();
|
||||||
|
@ -225,11 +226,11 @@ public:
|
||||||
SDL_Surface* backBuffer;
|
SDL_Surface* backBuffer;
|
||||||
Screen* screenbuffer;
|
Screen* screenbuffer;
|
||||||
SDL_Surface* menubuffer;
|
SDL_Surface* menubuffer;
|
||||||
SDL_Surface* towerbuffer;
|
|
||||||
SDL_Surface* towerbuffer_lerp;
|
|
||||||
SDL_Surface* foregroundBuffer;
|
SDL_Surface* foregroundBuffer;
|
||||||
SDL_Surface* tempBuffer;
|
SDL_Surface* tempBuffer;
|
||||||
|
|
||||||
|
TowerBG towerbg;
|
||||||
|
|
||||||
SDL_Rect bfont_rect;
|
SDL_Rect bfont_rect;
|
||||||
SDL_Rect tiles_rect;
|
SDL_Rect tiles_rect;
|
||||||
SDL_Rect sprites_rect;
|
SDL_Rect sprites_rect;
|
||||||
|
|
|
@ -579,7 +579,7 @@ void menuactionpress()
|
||||||
//disable animated backgrounds
|
//disable animated backgrounds
|
||||||
game.colourblindmode = !game.colourblindmode;
|
game.colourblindmode = !game.colourblindmode;
|
||||||
game.savestats();
|
game.savestats();
|
||||||
map.tdrawback = true;
|
graphics.towerbg.tdrawback = true;
|
||||||
music.playef(11);
|
music.playef(11);
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
|
@ -1683,7 +1683,7 @@ void titleinput()
|
||||||
music.playef(18);
|
music.playef(18);
|
||||||
game.screenshake = 10;
|
game.screenshake = 10;
|
||||||
game.flashlight = 5;
|
game.flashlight = 5;
|
||||||
map.colstate = 10;
|
graphics.towerbg.colstate = 10;
|
||||||
map.nexttowercolour();
|
map.nexttowercolour();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -2381,13 +2381,13 @@ void mapmenuactionpress()
|
||||||
map.bg_to_kludge();
|
map.bg_to_kludge();
|
||||||
game.kludge_ingametemp = game.currentmenuname;
|
game.kludge_ingametemp = game.currentmenuname;
|
||||||
|
|
||||||
map.scrolldir = 0;
|
graphics.towerbg.scrolldir = 0;
|
||||||
map.colstate = ((int) (map.colstate / 5)) * 5;
|
graphics.towerbg.colstate = ((int) (graphics.towerbg.colstate / 5)) * 5;
|
||||||
map.bypos = 0;
|
graphics.towerbg.bypos = 0;
|
||||||
map.nexttowercolour();
|
map.nexttowercolour();
|
||||||
|
|
||||||
// Fix delta rendering glitch
|
// Fix delta rendering glitch
|
||||||
graphics.updatetowerbackground();
|
graphics.updatetowerbackground(graphics.towerbg);
|
||||||
titleupdatetextcol();
|
titleupdatetextcol();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -2536,11 +2536,11 @@ void gamecompleteinput()
|
||||||
//Do this before we update map.bypos
|
//Do this before we update map.bypos
|
||||||
if (!game.colourblindmode)
|
if (!game.colourblindmode)
|
||||||
{
|
{
|
||||||
graphics.updatetowerbackground();
|
graphics.updatetowerbackground(graphics.towerbg);
|
||||||
}
|
}
|
||||||
|
|
||||||
//Do these here because input comes first
|
//Do these here because input comes first
|
||||||
map.bypos += map.bscroll;
|
graphics.towerbg.bypos += graphics.towerbg.bscroll;
|
||||||
game.oldcreditposition = game.creditposition;
|
game.oldcreditposition = game.creditposition;
|
||||||
|
|
||||||
if (key.isDown(KEYBOARD_z) || key.isDown(KEYBOARD_SPACE) || key.isDown(KEYBOARD_v) || key.isDown(game.controllerButton_flip))
|
if (key.isDown(KEYBOARD_z) || key.isDown(KEYBOARD_SPACE) || key.isDown(KEYBOARD_v) || key.isDown(game.controllerButton_flip))
|
||||||
|
@ -2556,7 +2556,7 @@ void gamecompleteinput()
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
map.bscroll = +7;
|
graphics.towerbg.bscroll = +7;
|
||||||
}
|
}
|
||||||
game.press_action = true;
|
game.press_action = true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,15 +27,15 @@ void titleupdatetextcol()
|
||||||
void titlelogic()
|
void titlelogic()
|
||||||
{
|
{
|
||||||
//Misc
|
//Misc
|
||||||
//map.updatetowerglow();
|
//map.updatetowerglow(graphics.towerbg);
|
||||||
help.updateglow();
|
help.updateglow();
|
||||||
|
|
||||||
map.bypos -= 2;
|
graphics.towerbg.bypos -= 2;
|
||||||
map.bscroll = -2;
|
graphics.towerbg.bscroll = -2;
|
||||||
|
|
||||||
if (!game.colourblindmode)
|
if (!game.colourblindmode)
|
||||||
{
|
{
|
||||||
graphics.updatetowerbackground();
|
graphics.updatetowerbackground(graphics.towerbg);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!game.menustart)
|
if (!game.menustart)
|
||||||
|
@ -149,10 +149,10 @@ void maplogic()
|
||||||
void gamecompletelogic()
|
void gamecompletelogic()
|
||||||
{
|
{
|
||||||
//Misc
|
//Misc
|
||||||
map.updatetowerglow();
|
map.updatetowerglow(graphics.towerbg);
|
||||||
help.updateglow();
|
help.updateglow();
|
||||||
graphics.crewframe = 0;
|
graphics.crewframe = 0;
|
||||||
map.scrolldir = 1;
|
graphics.towerbg.scrolldir = 1;
|
||||||
graphics.updatetitlecolours();
|
graphics.updatetitlecolours();
|
||||||
|
|
||||||
graphics.col_tr = map.r - (help.glow / 4) - fRandom() * 4;
|
graphics.col_tr = map.r - (help.glow / 4) - fRandom() * 4;
|
||||||
|
@ -169,11 +169,11 @@ void gamecompletelogic()
|
||||||
if (game.creditposition <= -Credits::creditmaxposition)
|
if (game.creditposition <= -Credits::creditmaxposition)
|
||||||
{
|
{
|
||||||
game.creditposition = -Credits::creditmaxposition;
|
game.creditposition = -Credits::creditmaxposition;
|
||||||
map.bscroll = 0;
|
graphics.towerbg.bscroll = 0;
|
||||||
}
|
}
|
||||||
else if (!game.press_action)
|
else if (!game.press_action)
|
||||||
{
|
{
|
||||||
map.bscroll = +1;
|
graphics.towerbg.bscroll = +1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (graphics.fademode == 1)
|
if (graphics.fademode == 1)
|
||||||
|
@ -182,8 +182,8 @@ void gamecompletelogic()
|
||||||
graphics.showcutscenebars = false;
|
graphics.showcutscenebars = false;
|
||||||
graphics.cutscenebarspos = 0;
|
graphics.cutscenebarspos = 0;
|
||||||
graphics.oldcutscenebarspos = 0;
|
graphics.oldcutscenebarspos = 0;
|
||||||
map.scrolldir = 0;
|
graphics.towerbg.scrolldir = 0;
|
||||||
map.bypos = 0;
|
graphics.towerbg.bypos = 0;
|
||||||
//Return to game
|
//Return to game
|
||||||
game.gamestate = GAMECOMPLETE2;
|
game.gamestate = GAMECOMPLETE2;
|
||||||
graphics.fademode = 4;
|
graphics.fademode = 4;
|
||||||
|
@ -193,7 +193,7 @@ void gamecompletelogic()
|
||||||
void gamecompletelogic2()
|
void gamecompletelogic2()
|
||||||
{
|
{
|
||||||
//Misc
|
//Misc
|
||||||
map.updatetowerglow();
|
map.updatetowerglow(graphics.towerbg);
|
||||||
help.updateglow();
|
help.updateglow();
|
||||||
|
|
||||||
game.creditposdelay--;
|
game.creditposdelay--;
|
||||||
|
@ -222,7 +222,7 @@ void gamecompletelogic2()
|
||||||
game.savetele();
|
game.savetele();
|
||||||
music.currentsong=tmp;
|
music.currentsong=tmp;
|
||||||
//Return to game
|
//Return to game
|
||||||
map.colstate = 10;
|
graphics.towerbg.colstate = 10;
|
||||||
game.gamestate = TITLEMODE;
|
game.gamestate = TITLEMODE;
|
||||||
graphics.fademode = 4;
|
graphics.fademode = 4;
|
||||||
FILESYSTEM_unmountassets(); // should be before music.playef(18)
|
FILESYSTEM_unmountassets(); // should be before music.playef(18)
|
||||||
|
@ -267,7 +267,7 @@ void gamelogic()
|
||||||
//Misc
|
//Misc
|
||||||
if (map.towermode)
|
if (map.towermode)
|
||||||
{
|
{
|
||||||
map.updatetowerglow();
|
map.updatetowerglow(graphics.towerbg);
|
||||||
}
|
}
|
||||||
help.updateglow();
|
help.updateglow();
|
||||||
|
|
||||||
|
@ -331,28 +331,28 @@ void gamelogic()
|
||||||
//do nothing!
|
//do nothing!
|
||||||
//a trigger will set this off in the game
|
//a trigger will set this off in the game
|
||||||
map.cameramode = 1;
|
map.cameramode = 1;
|
||||||
map.bscroll = 0;
|
graphics.towerbg.bscroll = 0;
|
||||||
}
|
}
|
||||||
else if (map.cameramode == 1)
|
else if (map.cameramode == 1)
|
||||||
{
|
{
|
||||||
//move normally
|
//move normally
|
||||||
if(map.scrolldir==0)
|
if(graphics.towerbg.scrolldir==0)
|
||||||
{
|
{
|
||||||
map.ypos -= 2;
|
map.ypos -= 2;
|
||||||
map.bypos -= 1;
|
graphics.towerbg.bypos -= 1;
|
||||||
map.bscroll = -1;
|
graphics.towerbg.bscroll = -1;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
map.ypos += 2;
|
map.ypos += 2;
|
||||||
map.bypos += 1;
|
graphics.towerbg.bypos += 1;
|
||||||
map.bscroll = 1;
|
graphics.towerbg.bscroll = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (map.cameramode == 2)
|
else if (map.cameramode == 2)
|
||||||
{
|
{
|
||||||
//do nothing, but cycle colours (for taking damage)
|
//do nothing, but cycle colours (for taking damage)
|
||||||
map.bscroll = 0;
|
graphics.towerbg.bscroll = 0;
|
||||||
}
|
}
|
||||||
else if (map.cameramode == 4)
|
else if (map.cameramode == 4)
|
||||||
{
|
{
|
||||||
|
@ -367,7 +367,7 @@ void gamelogic()
|
||||||
|
|
||||||
map.cameramode = 5;
|
map.cameramode = 5;
|
||||||
|
|
||||||
map.bscroll = map.cameraseek/2;
|
graphics.towerbg.bscroll = map.cameraseek/2;
|
||||||
}
|
}
|
||||||
else if (map.cameramode == 5)
|
else if (map.cameramode == 5)
|
||||||
{
|
{
|
||||||
|
@ -393,7 +393,7 @@ void gamelogic()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
map.cameraseekframe--;
|
map.cameraseekframe--;
|
||||||
map.bypos = map.ypos / 2;
|
graphics.towerbg.bypos = map.ypos / 2;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -402,7 +402,7 @@ void gamelogic()
|
||||||
{
|
{
|
||||||
map.ypos = obj.entities[i].yp - 120;
|
map.ypos = obj.entities[i].yp - 120;
|
||||||
}
|
}
|
||||||
map.bypos = map.ypos / 2;
|
graphics.towerbg.bypos = map.ypos / 2;
|
||||||
map.cameramode = 0;
|
map.cameramode = 0;
|
||||||
map.colsuperstate = 0;
|
map.colsuperstate = 0;
|
||||||
}
|
}
|
||||||
|
@ -410,22 +410,22 @@ void gamelogic()
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
map.bscroll = 0;
|
graphics.towerbg.bscroll = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (map.ypos <= 0)
|
if (map.ypos <= 0)
|
||||||
{
|
{
|
||||||
map.ypos = 0;
|
map.ypos = 0;
|
||||||
map.bypos = 0;
|
graphics.towerbg.bypos = 0;
|
||||||
map.bscroll = 0;
|
graphics.towerbg.bscroll = 0;
|
||||||
}
|
}
|
||||||
if (map.towermode && map.minitowermode)
|
if (map.towermode && map.minitowermode)
|
||||||
{
|
{
|
||||||
if (map.ypos >= 568)
|
if (map.ypos >= 568)
|
||||||
{
|
{
|
||||||
map.ypos = 568;
|
map.ypos = 568;
|
||||||
map.bypos = map.ypos / 2;
|
graphics.towerbg.bypos = map.ypos / 2;
|
||||||
map.bscroll = 0;
|
graphics.towerbg.bscroll = 0;
|
||||||
} //100-29 * 8 = 568
|
} //100-29 * 8 = 568
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -433,7 +433,7 @@ void gamelogic()
|
||||||
if (map.ypos >= 5368)
|
if (map.ypos >= 5368)
|
||||||
{
|
{
|
||||||
map.ypos = 5368; //700-29 * 8 = 5368
|
map.ypos = 5368; //700-29 * 8 = 5368
|
||||||
map.bypos = map.ypos / 2.0;
|
graphics.towerbg.bypos = map.ypos / 2.0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -998,14 +998,14 @@ void gamelogic()
|
||||||
if (obj.entities[player].yp-map.ypos <= 0)
|
if (obj.entities[player].yp-map.ypos <= 0)
|
||||||
{
|
{
|
||||||
map.ypos-=10;
|
map.ypos-=10;
|
||||||
map.bypos = map.ypos / 2;
|
graphics.towerbg.bypos = map.ypos / 2;
|
||||||
map.bscroll = 0;
|
graphics.towerbg.bscroll = 0;
|
||||||
}
|
}
|
||||||
else if (obj.entities[player].yp-map.ypos >= 208)
|
else if (obj.entities[player].yp-map.ypos >= 208)
|
||||||
{
|
{
|
||||||
map.ypos+=2;
|
map.ypos+=2;
|
||||||
map.bypos = map.ypos / 2;
|
graphics.towerbg.bypos = map.ypos / 2;
|
||||||
map.bscroll = 0;
|
graphics.towerbg.bscroll = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1207,7 +1207,7 @@ void gamelogic()
|
||||||
//Right so! Screenwraping for tower:
|
//Right so! Screenwraping for tower:
|
||||||
if (map.towermode && map.minitowermode)
|
if (map.towermode && map.minitowermode)
|
||||||
{
|
{
|
||||||
if (map.scrolldir == 1)
|
if (graphics.towerbg.scrolldir == 1)
|
||||||
{
|
{
|
||||||
//This is minitower 1!
|
//This is minitower 1!
|
||||||
int player = obj.getplayer();
|
int player = obj.getplayer();
|
||||||
|
@ -1712,7 +1712,7 @@ void gamelogic()
|
||||||
{
|
{
|
||||||
if (map.towermode)
|
if (map.towermode)
|
||||||
{
|
{
|
||||||
graphics.updatetowerbackground();
|
graphics.updatetowerbackground(graphics.towerbg);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
|
@ -16,7 +16,6 @@ mapclass::mapclass()
|
||||||
r = 196;
|
r = 196;
|
||||||
g = 196;
|
g = 196;
|
||||||
b = 196;
|
b = 196;
|
||||||
colstate = 0;
|
|
||||||
colstatedelay = 0;
|
colstatedelay = 0;
|
||||||
colsuperstate = 0;
|
colsuperstate = 0;
|
||||||
spikeleveltop = 0;
|
spikeleveltop = 0;
|
||||||
|
@ -82,15 +81,11 @@ mapclass::mapclass()
|
||||||
|
|
||||||
ypos = 0;
|
ypos = 0;
|
||||||
oldypos = 0;
|
oldypos = 0;
|
||||||
bypos = 0;
|
|
||||||
|
|
||||||
background = 0;
|
background = 0;
|
||||||
cameramode = 0;
|
cameramode = 0;
|
||||||
cameraseek = 0;
|
cameraseek = 0;
|
||||||
minitowermode = false;
|
minitowermode = false;
|
||||||
scrolldir = 0;
|
|
||||||
tdrawback = false;
|
|
||||||
bscroll = 0;
|
|
||||||
roomtexton = false;
|
roomtexton = false;
|
||||||
kludge_bypos = 0;
|
kludge_bypos = 0;
|
||||||
kludge_colstate = 0;
|
kludge_colstate = 0;
|
||||||
|
@ -581,15 +576,15 @@ void mapclass::setcol(const int r1, const int g1, const int b1 , const int r2, c
|
||||||
b = intpol(b1, b2, c / 5);
|
b = intpol(b1, b2, c / 5);
|
||||||
}
|
}
|
||||||
|
|
||||||
void mapclass::updatetowerglow()
|
void mapclass::updatetowerglow(TowerBG& bg_obj)
|
||||||
{
|
{
|
||||||
if (colstatedelay <= 0 || colsuperstate > 0)
|
if (colstatedelay <= 0 || colsuperstate > 0)
|
||||||
{
|
{
|
||||||
if (colsuperstate > 0) colstate--;
|
if (colsuperstate > 0) bg_obj.colstate--;
|
||||||
colstate++;
|
bg_obj.colstate++;
|
||||||
if (colstate >= 30) colstate = 0;
|
if (bg_obj.colstate >= 30) bg_obj.colstate = 0;
|
||||||
int check = colstate % 5; //current state of phase
|
int check = bg_obj.colstate % 5; //current state of phase
|
||||||
int cmode = (colstate - check) / 5; // current colour transition
|
int cmode = (bg_obj.colstate - check) / 5; // current colour transition
|
||||||
|
|
||||||
switch(cmode)
|
switch(cmode)
|
||||||
{
|
{
|
||||||
|
@ -623,7 +618,7 @@ void mapclass::updatetowerglow()
|
||||||
}
|
}
|
||||||
if (colsuperstate > 0) colstatedelay = 0;
|
if (colsuperstate > 0) colstatedelay = 0;
|
||||||
|
|
||||||
tdrawback = true;
|
bg_obj.tdrawback = true;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -633,10 +628,10 @@ void mapclass::updatetowerglow()
|
||||||
|
|
||||||
void mapclass::nexttowercolour()
|
void mapclass::nexttowercolour()
|
||||||
{
|
{
|
||||||
colstate+=5;
|
graphics.towerbg.colstate+=5;
|
||||||
if (colstate >= 30) colstate = 0;
|
if (graphics.towerbg.colstate >= 30) graphics.towerbg.colstate = 0;
|
||||||
int check = colstate % 5; //current state of phase
|
int check = graphics.towerbg.colstate % 5; //current state of phase
|
||||||
int cmode = (colstate - check) / 5; // current colour transition
|
int cmode = (graphics.towerbg.colstate - check) / 5; // current colour transition
|
||||||
|
|
||||||
switch(cmode)
|
switch(cmode)
|
||||||
{
|
{
|
||||||
|
@ -660,15 +655,15 @@ void mapclass::nexttowercolour()
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
tdrawback = true;
|
graphics.towerbg.tdrawback = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void mapclass::settowercolour(int t)
|
void mapclass::settowercolour(int t)
|
||||||
{
|
{
|
||||||
colstate=t*5;
|
graphics.towerbg.colstate=t*5;
|
||||||
if (colstate >= 30) colstate = 0;
|
if (graphics.towerbg.colstate >= 30) graphics.towerbg.colstate = 0;
|
||||||
int check = colstate % 5; //current state of phase
|
int check = graphics.towerbg.colstate % 5; //current state of phase
|
||||||
int cmode = (colstate - check) / 5; // current colour transition
|
int cmode = (graphics.towerbg.colstate - check) / 5; // current colour transition
|
||||||
|
|
||||||
switch(cmode)
|
switch(cmode)
|
||||||
{
|
{
|
||||||
|
@ -692,7 +687,7 @@ void mapclass::settowercolour(int t)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
tdrawback = true;
|
graphics.towerbg.tdrawback = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool mapclass::spikecollide(int x, int y)
|
bool mapclass::spikecollide(int x, int y)
|
||||||
|
@ -849,7 +844,7 @@ void mapclass::resetplayer()
|
||||||
ypos = 0;
|
ypos = 0;
|
||||||
}
|
}
|
||||||
oldypos = ypos;
|
oldypos = ypos;
|
||||||
bypos = ypos / 2;
|
graphics.towerbg.bypos = ypos / 2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1261,9 +1256,9 @@ void mapclass::loadlevel(int rx, int ry)
|
||||||
|
|
||||||
ypos = (700-29) * 8;
|
ypos = (700-29) * 8;
|
||||||
oldypos = ypos;
|
oldypos = ypos;
|
||||||
bypos = ypos / 2;
|
graphics.towerbg.bypos = ypos / 2;
|
||||||
cameramode = 0;
|
cameramode = 0;
|
||||||
colstate = 0;
|
graphics.towerbg.colstate = 0;
|
||||||
colsuperstate = 0;
|
colsuperstate = 0;
|
||||||
}
|
}
|
||||||
else if (ry == 104)
|
else if (ry == 104)
|
||||||
|
@ -1271,9 +1266,9 @@ void mapclass::loadlevel(int rx, int ry)
|
||||||
//you've entered from the top floor
|
//you've entered from the top floor
|
||||||
ypos = 0;
|
ypos = 0;
|
||||||
oldypos = ypos;
|
oldypos = ypos;
|
||||||
bypos = 0;
|
graphics.towerbg.bypos = 0;
|
||||||
cameramode = 0;
|
cameramode = 0;
|
||||||
colstate = 0;
|
graphics.towerbg.colstate = 0;
|
||||||
colsuperstate = 0;
|
colsuperstate = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1351,17 +1346,17 @@ void mapclass::loadlevel(int rx, int ry)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 3: //The Tower
|
case 3: //The Tower
|
||||||
tdrawback = true;
|
graphics.towerbg.tdrawback = true;
|
||||||
minitowermode = false;
|
minitowermode = false;
|
||||||
tower.minitowermode = false;
|
tower.minitowermode = false;
|
||||||
bscroll = 0;
|
graphics.towerbg.bscroll = 0;
|
||||||
scrolldir = 0;
|
graphics.towerbg.scrolldir = 0;
|
||||||
|
|
||||||
roomname = "The Tower";
|
roomname = "The Tower";
|
||||||
tileset = 1;
|
tileset = 1;
|
||||||
background = 3;
|
background = 3;
|
||||||
towermode = true;
|
towermode = true;
|
||||||
//bypos = 0; ypos = 0; cameramode = 0;
|
//graphics.towerbg.bypos = 0; ypos = 0; cameramode = 0;
|
||||||
|
|
||||||
//All the entities for here are just loaded here; it's essentially one room after all
|
//All the entities for here are just loaded here; it's essentially one room after all
|
||||||
|
|
||||||
|
@ -1450,11 +1445,11 @@ void mapclass::loadlevel(int rx, int ry)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 7: //Final Level, Tower 1
|
case 7: //Final Level, Tower 1
|
||||||
tdrawback = true;
|
graphics.towerbg.tdrawback = true;
|
||||||
minitowermode = true;
|
minitowermode = true;
|
||||||
tower.minitowermode = true;
|
tower.minitowermode = true;
|
||||||
bscroll = 0;
|
graphics.towerbg.bscroll = 0;
|
||||||
scrolldir = 1;
|
graphics.towerbg.scrolldir = 1;
|
||||||
|
|
||||||
roomname = "Panic Room";
|
roomname = "Panic Room";
|
||||||
tileset = 1;
|
tileset = 1;
|
||||||
|
@ -1465,18 +1460,18 @@ void mapclass::loadlevel(int rx, int ry)
|
||||||
|
|
||||||
ypos = 0;
|
ypos = 0;
|
||||||
oldypos = 0;
|
oldypos = 0;
|
||||||
bypos = 0;
|
graphics.towerbg.bypos = 0;
|
||||||
cameramode = 0;
|
cameramode = 0;
|
||||||
colstate = 0;
|
graphics.towerbg.colstate = 0;
|
||||||
colsuperstate = 0;
|
colsuperstate = 0;
|
||||||
break;
|
break;
|
||||||
case 8: //Final Level, Tower 1 (reentered from below)
|
case 8: //Final Level, Tower 1 (reentered from below)
|
||||||
{
|
{
|
||||||
tdrawback = true;
|
graphics.towerbg.tdrawback = true;
|
||||||
minitowermode = true;
|
minitowermode = true;
|
||||||
tower.minitowermode = true;
|
tower.minitowermode = true;
|
||||||
bscroll = 0;
|
graphics.towerbg.bscroll = 0;
|
||||||
scrolldir = 1;
|
graphics.towerbg.scrolldir = 1;
|
||||||
|
|
||||||
roomname = "Panic Room";
|
roomname = "Panic Room";
|
||||||
tileset = 1;
|
tileset = 1;
|
||||||
|
@ -1495,18 +1490,18 @@ void mapclass::loadlevel(int rx, int ry)
|
||||||
|
|
||||||
ypos = (100-29) * 8;
|
ypos = (100-29) * 8;
|
||||||
oldypos = ypos;
|
oldypos = ypos;
|
||||||
bypos = ypos/2;
|
graphics.towerbg.bypos = ypos/2;
|
||||||
cameramode = 0;
|
cameramode = 0;
|
||||||
colstate = 0;
|
graphics.towerbg.colstate = 0;
|
||||||
colsuperstate = 0;}
|
colsuperstate = 0;}
|
||||||
break;
|
break;
|
||||||
case 9: //Final Level, Tower 2
|
case 9: //Final Level, Tower 2
|
||||||
{
|
{
|
||||||
tdrawback = true;
|
graphics.towerbg.tdrawback = true;
|
||||||
minitowermode = true;
|
minitowermode = true;
|
||||||
tower.minitowermode = true;
|
tower.minitowermode = true;
|
||||||
bscroll = 0;
|
graphics.towerbg.bscroll = 0;
|
||||||
scrolldir = 0;
|
graphics.towerbg.scrolldir = 0;
|
||||||
final_colorframe = 2;
|
final_colorframe = 2;
|
||||||
|
|
||||||
roomname = "The Final Challenge";
|
roomname = "The Final Challenge";
|
||||||
|
@ -1540,20 +1535,20 @@ void mapclass::loadlevel(int rx, int ry)
|
||||||
|
|
||||||
ypos = (100-29) * 8;
|
ypos = (100-29) * 8;
|
||||||
oldypos = ypos;
|
oldypos = ypos;
|
||||||
bypos = ypos/2;
|
graphics.towerbg.bypos = ypos/2;
|
||||||
cameramode = 0;
|
cameramode = 0;
|
||||||
colstate = 0;
|
graphics.towerbg.colstate = 0;
|
||||||
colsuperstate = 0;
|
colsuperstate = 0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 10: //Final Level, Tower 2
|
case 10: //Final Level, Tower 2
|
||||||
{
|
{
|
||||||
|
|
||||||
tdrawback = true;
|
graphics.towerbg.tdrawback = true;
|
||||||
minitowermode = true;
|
minitowermode = true;
|
||||||
tower.minitowermode = true;
|
tower.minitowermode = true;
|
||||||
bscroll = 0;
|
graphics.towerbg.bscroll = 0;
|
||||||
scrolldir = 0;
|
graphics.towerbg.scrolldir = 0;
|
||||||
final_colorframe = 2;
|
final_colorframe = 2;
|
||||||
|
|
||||||
roomname = "The Final Challenge";
|
roomname = "The Final Challenge";
|
||||||
|
@ -1579,9 +1574,9 @@ void mapclass::loadlevel(int rx, int ry)
|
||||||
|
|
||||||
ypos = 0;
|
ypos = 0;
|
||||||
oldypos = 0;
|
oldypos = 0;
|
||||||
bypos = 0;
|
graphics.towerbg.bypos = 0;
|
||||||
cameramode = 0;
|
cameramode = 0;
|
||||||
colstate = 0;
|
graphics.towerbg.colstate = 0;
|
||||||
colsuperstate = 0;
|
colsuperstate = 0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -2114,3 +2109,17 @@ void mapclass::twoframedelayfix()
|
||||||
script.dontrunnextframe = true;
|
script.dontrunnextframe = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void mapclass::bg_to_kludge()
|
||||||
|
{
|
||||||
|
kludge_bypos = graphics.towerbg.bypos;
|
||||||
|
kludge_colstate = graphics.towerbg.colstate;
|
||||||
|
kludge_scrolldir = graphics.towerbg.scrolldir;
|
||||||
|
}
|
||||||
|
|
||||||
|
void mapclass::kludge_to_bg()
|
||||||
|
{
|
||||||
|
graphics.towerbg.bypos = kludge_bypos;
|
||||||
|
graphics.towerbg.colstate = kludge_colstate;
|
||||||
|
graphics.towerbg.scrolldir = kludge_scrolldir;
|
||||||
|
}
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
#include "Otherlevel.h"
|
#include "Otherlevel.h"
|
||||||
#include "Spacestation2.h"
|
#include "Spacestation2.h"
|
||||||
#include "Tower.h"
|
#include "Tower.h"
|
||||||
|
#include "TowerBG.h"
|
||||||
#include "WarpClass.h"
|
#include "WarpClass.h"
|
||||||
|
|
||||||
struct Roomtext
|
struct Roomtext
|
||||||
|
@ -47,7 +48,7 @@ public:
|
||||||
|
|
||||||
void setcol(const int r1, const int g1, const int b1 , const int r2, const int g2, const int b2, const int c);
|
void setcol(const int r1, const int g1, const int b1 , const int r2, const int g2, const int b2, const int c);
|
||||||
|
|
||||||
void updatetowerglow();
|
void updatetowerglow(TowerBG& bg_obj);
|
||||||
|
|
||||||
void nexttowercolour();
|
void nexttowercolour();
|
||||||
|
|
||||||
|
@ -102,21 +103,17 @@ public:
|
||||||
bool towermode;
|
bool towermode;
|
||||||
float ypos;
|
float ypos;
|
||||||
float oldypos;
|
float oldypos;
|
||||||
int bypos;
|
|
||||||
int cameramode;
|
int cameramode;
|
||||||
int cameraseek, cameraseekframe;
|
int cameraseek, cameraseekframe;
|
||||||
int resumedelay;
|
int resumedelay;
|
||||||
bool minitowermode;
|
bool minitowermode;
|
||||||
int scrolldir;
|
|
||||||
|
|
||||||
//This is the old colour cycle
|
//This is the old colour cycle
|
||||||
int r, g,b;
|
int r, g,b;
|
||||||
int colstate, colstatedelay;
|
int colstatedelay;
|
||||||
int colsuperstate;
|
int colsuperstate;
|
||||||
int spikeleveltop, spikelevelbottom;
|
int spikeleveltop, spikelevelbottom;
|
||||||
int oldspikeleveltop, oldspikelevelbottom;
|
int oldspikeleveltop, oldspikelevelbottom;
|
||||||
bool tdrawback;
|
|
||||||
int bscroll;
|
|
||||||
//final level navigation
|
//final level navigation
|
||||||
int finalx;
|
int finalx;
|
||||||
int finaly;
|
int finaly;
|
||||||
|
@ -172,18 +169,8 @@ public:
|
||||||
int kludge_bypos;
|
int kludge_bypos;
|
||||||
int kludge_colstate;
|
int kludge_colstate;
|
||||||
int kludge_scrolldir;
|
int kludge_scrolldir;
|
||||||
void inline bg_to_kludge()
|
void bg_to_kludge();
|
||||||
{
|
void kludge_to_bg();
|
||||||
kludge_bypos = bypos;
|
|
||||||
kludge_colstate = colstate;
|
|
||||||
kludge_scrolldir = scrolldir;
|
|
||||||
}
|
|
||||||
void inline kludge_to_bg()
|
|
||||||
{
|
|
||||||
bypos = kludge_bypos;
|
|
||||||
colstate = kludge_colstate;
|
|
||||||
scrolldir = kludge_scrolldir;
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifndef MAP_DEFINITION
|
#ifndef MAP_DEFINITION
|
||||||
|
|
|
@ -1182,7 +1182,7 @@ void titlerender()
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if(!game.colourblindmode) graphics.drawtowerbackground();
|
if(!game.colourblindmode) graphics.drawtowerbackground(graphics.towerbg);
|
||||||
|
|
||||||
tr = graphics.col_tr;
|
tr = graphics.col_tr;
|
||||||
tg = graphics.col_tg;
|
tg = graphics.col_tg;
|
||||||
|
@ -1211,7 +1211,7 @@ void gamecompleterender()
|
||||||
{
|
{
|
||||||
FillRect(graphics.backBuffer, 0x000000);
|
FillRect(graphics.backBuffer, 0x000000);
|
||||||
|
|
||||||
if(!game.colourblindmode) graphics.drawtowerbackground();
|
if(!game.colourblindmode) graphics.drawtowerbackground(graphics.towerbg);
|
||||||
|
|
||||||
tr = graphics.col_tr;
|
tr = graphics.col_tr;
|
||||||
tg = graphics.col_tg;
|
tg = graphics.col_tg;
|
||||||
|
@ -1397,7 +1397,7 @@ void gamerender()
|
||||||
{
|
{
|
||||||
if (!game.colourblindmode)
|
if (!game.colourblindmode)
|
||||||
{
|
{
|
||||||
graphics.drawtowerbackground();
|
graphics.drawtowerbackground(graphics.towerbg);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
|
@ -1537,7 +1537,7 @@ void scriptclass::run()
|
||||||
map.resetnames();
|
map.resetnames();
|
||||||
map.resetmap();
|
map.resetmap();
|
||||||
map.resetplayer();
|
map.resetplayer();
|
||||||
map.tdrawback = true;
|
graphics.towerbg.tdrawback = true;
|
||||||
|
|
||||||
obj.resetallflags();
|
obj.resetallflags();
|
||||||
i = obj.getplayer();
|
i = obj.getplayer();
|
||||||
|
@ -2642,7 +2642,7 @@ void scriptclass::resetgametomenu()
|
||||||
graphics.flipmode = false;
|
graphics.flipmode = false;
|
||||||
obj.entities.clear();
|
obj.entities.clear();
|
||||||
graphics.fademode = 4;
|
graphics.fademode = 4;
|
||||||
map.tdrawback = true;
|
graphics.towerbg.tdrawback = true;
|
||||||
game.createmenu(Menu::gameover);
|
game.createmenu(Menu::gameover);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2732,7 +2732,7 @@ void scriptclass::startgamemode( int t )
|
||||||
{
|
{
|
||||||
map.ypos = obj.entities[i].yp - 120;
|
map.ypos = obj.entities[i].yp - 120;
|
||||||
}
|
}
|
||||||
map.bypos = map.ypos / 2;
|
graphics.towerbg.bypos = map.ypos / 2;
|
||||||
map.cameramode = 0;
|
map.cameramode = 0;
|
||||||
map.colsuperstate = 0;
|
map.colsuperstate = 0;
|
||||||
}
|
}
|
||||||
|
@ -3714,7 +3714,7 @@ void scriptclass::hardreset()
|
||||||
}
|
}
|
||||||
map.cameraseekframe = 0;
|
map.cameraseekframe = 0;
|
||||||
map.resumedelay = 0;
|
map.resumedelay = 0;
|
||||||
map.scrolldir = 0;
|
graphics.towerbg.scrolldir = 0;
|
||||||
map.customshowmm=true;
|
map.customshowmm=true;
|
||||||
|
|
||||||
SDL_memset(map.roomdeaths, 0, sizeof(map.roomdeaths));
|
SDL_memset(map.roomdeaths, 0, sizeof(map.roomdeaths));
|
||||||
|
|
17
desktop_version/src/TowerBG.h
Normal file
17
desktop_version/src/TowerBG.h
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
#ifndef TOWERBG_H
|
||||||
|
#define TOWERBG_H
|
||||||
|
|
||||||
|
#include <SDL.h>
|
||||||
|
|
||||||
|
struct TowerBG
|
||||||
|
{
|
||||||
|
SDL_Surface* buffer;
|
||||||
|
SDL_Surface* buffer_lerp;
|
||||||
|
bool tdrawback;
|
||||||
|
int bypos;
|
||||||
|
int bscroll;
|
||||||
|
int colstate;
|
||||||
|
int scrolldir;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif /* TOWERBG_H */
|
|
@ -3292,7 +3292,7 @@ void editorrender()
|
||||||
{
|
{
|
||||||
if(!game.colourblindmode)
|
if(!game.colourblindmode)
|
||||||
{
|
{
|
||||||
graphics.drawtowerbackground();
|
graphics.drawtowerbackground(graphics.towerbg);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -3679,8 +3679,8 @@ void editorlogic()
|
||||||
game.shouldreturntoeditor = false;
|
game.shouldreturntoeditor = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
map.bypos -= 2;
|
graphics.towerbg.bypos -= 2;
|
||||||
map.bscroll = -2;
|
graphics.towerbg.bscroll = -2;
|
||||||
|
|
||||||
ed.entframedelay--;
|
ed.entframedelay--;
|
||||||
if(ed.entframedelay<=0)
|
if(ed.entframedelay<=0)
|
||||||
|
@ -3740,14 +3740,14 @@ void editorlogic()
|
||||||
}
|
}
|
||||||
else if (!game.colourblindmode)
|
else if (!game.colourblindmode)
|
||||||
{
|
{
|
||||||
graphics.updatetowerbackground();
|
graphics.updatetowerbackground(graphics.towerbg);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (graphics.fademode == 1)
|
if (graphics.fademode == 1)
|
||||||
{
|
{
|
||||||
//Return to game
|
//Return to game
|
||||||
map.nexttowercolour();
|
map.nexttowercolour();
|
||||||
map.colstate = 10;
|
graphics.towerbg.colstate = 10;
|
||||||
game.gamestate = TITLEMODE;
|
game.gamestate = TITLEMODE;
|
||||||
script.hardreset();
|
script.hardreset();
|
||||||
graphics.fademode = 4;
|
graphics.fademode = 4;
|
||||||
|
|
|
@ -210,7 +210,7 @@ int main(int argc, char *argv[])
|
||||||
game.mainmenu = 0;
|
game.mainmenu = 0;
|
||||||
|
|
||||||
map.ypos = (700-29) * 8;
|
map.ypos = (700-29) * 8;
|
||||||
map.bypos = map.ypos / 2;
|
graphics.towerbg.bypos = map.ypos / 2;
|
||||||
|
|
||||||
//Moved screensetting init here from main menu V2.1
|
//Moved screensetting init here from main menu V2.1
|
||||||
int width = 320;
|
int width = 320;
|
||||||
|
@ -256,11 +256,11 @@ int main(int argc, char *argv[])
|
||||||
graphics.menubuffer = CREATE_SURFACE(320, 240);
|
graphics.menubuffer = CREATE_SURFACE(320, 240);
|
||||||
SDL_SetSurfaceBlendMode(graphics.menubuffer, SDL_BLENDMODE_NONE);
|
SDL_SetSurfaceBlendMode(graphics.menubuffer, SDL_BLENDMODE_NONE);
|
||||||
|
|
||||||
graphics.towerbuffer = CREATE_SURFACE(320 + 16, 240 + 16);
|
graphics.towerbg.buffer = CREATE_SURFACE(320 + 16, 240 + 16);
|
||||||
SDL_SetSurfaceBlendMode(graphics.towerbuffer, SDL_BLENDMODE_NONE);
|
SDL_SetSurfaceBlendMode(graphics.towerbg.buffer, SDL_BLENDMODE_NONE);
|
||||||
|
|
||||||
graphics.towerbuffer_lerp = CREATE_SURFACE(320 + 16, 240 + 16);
|
graphics.towerbg.buffer_lerp = CREATE_SURFACE(320 + 16, 240 + 16);
|
||||||
SDL_SetSurfaceBlendMode(graphics.towerbuffer_lerp, SDL_BLENDMODE_NONE);
|
SDL_SetSurfaceBlendMode(graphics.towerbg.buffer_lerp, SDL_BLENDMODE_NONE);
|
||||||
|
|
||||||
graphics.tempBuffer = CREATE_SURFACE(320, 240);
|
graphics.tempBuffer = CREATE_SURFACE(320, 240);
|
||||||
SDL_SetSurfaceBlendMode(graphics.tempBuffer, SDL_BLENDMODE_NONE);
|
SDL_SetSurfaceBlendMode(graphics.tempBuffer, SDL_BLENDMODE_NONE);
|
||||||
|
|
Loading…
Reference in a new issue