X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?a=blobdiff_plain;f=src%2Fgame.c;h=86170cb128b6c1d4104dff022a3749ac3ada3c4b;hb=713d33d0c193f880d665dc6f4e62eac9549b747e;hp=238ee0832569f450d206fa7f31a615c117ac7c89;hpb=79091ddde8d1e5f865502f1a3f0755cda57c34fb;p=eradicate diff --git a/src/game.c b/src/game.c index 238ee08..86170cb 100644 --- a/src/game.c +++ b/src/game.c @@ -1,5 +1,8 @@ +#include +#include #include "game.h" #include "screens.h" +#include "sprite.h" int fb_width, fb_height; long fb_size; @@ -10,9 +13,14 @@ 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; } @@ -30,15 +38,48 @@ void cleanup(void) menu_cleanup(); } -void cs_puts_font(cs_font_func csfont, int sz, void *fb, int x, int y, const char *str) +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) { - csfont(fb, x, y, c - ' '); + draw_sprite(dest, fb_width * 2, &dbgfont, c - ' '); } - x += sz; + 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); +}