Created SurfaceManager

This commit is contained in:
Kayne Ruse
2013-04-28 23:04:17 +10:00
parent 79304f24b8
commit 1226fa08ca
8 changed files with 189 additions and 5 deletions
+64
View File
@@ -0,0 +1,64 @@
#include "surface_manager.h"
#include "SDL/SDL.h"
#include <exception>
#include <iostream>
using namespace std;
int go(int, char**) {
SDL_Init(SDL_INIT_VIDEO);
SDL_Surface* screen = SDL_SetVideoMode(800, 600, 32, SDL_HWSURFACE|SDL_DOUBLEBUF);
SurfaceManager sMgr;
sMgr.Load("player", "rsc/graphics/sprites/elliot2.bmp");
sMgr.Load("tileset", "rsc/graphics/tilesets/MishMash.bmp");
bool running = true;
while (running) {
SDL_Event event;
while(SDL_PollEvent(&event)) {
switch(event.type) {
case SDL_QUIT:
running = false;
break;
case SDL_KEYDOWN:
switch(event.key.keysym.sym) {
case SDLK_ESCAPE:
running = false;
break;
case SDLK_1:
sMgr.Reload("tileset","rsc/graphics/tilesets/terrain.bmp");
break;
case SDLK_2:
sMgr.Reload("tileset","rsc/graphics/tilesets/MishMash.bmp");
break;
}
}
}
SDL_FillRect(screen, 0, 0);
SDL_BlitSurface(sMgr.Get("tileset"), NULL, screen, NULL);
SDL_BlitSurface(sMgr.Get("player"), NULL, screen, NULL);
SDL_Flip(screen);
}
SDL_Quit();
return 0;
}
int SDL_main(int argc, char* argv[]) {
try {
go(argc, argv);
}
catch(exception& e) {
cerr << "Error: " << e.what() << endl;
return 1;
}
return 0;
}