X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?a=blobdiff_plain;f=src%2Fgame.c;h=86170cb128b6c1d4104dff022a3749ac3ada3c4b;hb=713d33d0c193f880d665dc6f4e62eac9549b747e;hp=88a7e3fc95586d8f5b270033597817a8b6d57748;hpb=1ee7845621c04020321fa8dfb6dcbf3d8c6c9b51;p=eradicate diff --git a/src/game.c b/src/game.c index 88a7e3f..86170cb 100644 --- a/src/game.c +++ b/src/game.c @@ -1,28 +1,85 @@ +#include +#include #include "game.h" -#include "menuscr.h" +#include "screens.h" +#include "sprite.h" int fb_width, fb_height; long fb_size; -void *fb_pixels, *vmem; +uint16_t *fb_pixels; long time_msec; void (*draw)(void); void (*key_event)(int key, int pressed); +static struct sprites dbgfont; + int init(int argc, char **argv) { + if(load_sprites(&dbgfont, "data/dbgfont.spr") == -1) { + return -1; + } + if(intro_init() == -1) { + return -1; + } if(menu_init() == -1) { return -1; } - draw = menu_draw; - key_event = menu_keyb; + intro_start(); return 0; } void cleanup(void) { + intro_cleanup(); menu_cleanup(); } + +void dbg_print(void *fb, int x, int y, const char *str) +{ + uint16_t *dest = (uint16_t*)fb + y * fb_width + x; + + while(*str) { + int c = *str++; + + if(c > ' ' && c < 128) { + draw_sprite(dest, fb_width * 2, &dbgfont, c - ' '); + } + dest += 8; + } +} + +void dbg_printf(void *fb, int x, int y, const char *fmt, ...) +{ + static char buf[2048]; + va_list ap; + + va_start(ap, fmt); + vsprintf(buf, fmt, ap); + va_end(ap); + + dbg_print(fb, x, y, buf); +} + +void dbg_fps(void *fb) +{ + static char fpsbuf[8]; + static long frame, prev_upd; + long msec = time_msec; + long delta; + + frame++; + + delta = msec - prev_upd; + if(delta >= 1024) { + frame *= 1000; + sprintf(fpsbuf, "%2ld.%1ld", frame >> 10, 10 * (frame & 0x3ff) >> 10); + frame = 0; + prev_upd = msec; + } + + dbg_print(fb, 2, 2, fpsbuf); +}