X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?a=blobdiff_plain;f=src%2Fdemo.c;h=a27d86c4f91b64f68821dc39268ad22634ffa7fc;hb=8e783a58d1e21ace04fd6d7ed00158e65bd78040;hp=a4bb0c70fd8f7462638b11c90f6343ddcaeb2942;hpb=5eefe7b94c8d6c6caa2c10e3835ab0831a3c42a1;p=demo_prior diff --git a/src/demo.c b/src/demo.c index a4bb0c7..a27d86c 100644 --- a/src/demo.c +++ b/src/demo.c @@ -5,6 +5,9 @@ #include "post.h" #include "sdr.h" #include "opt.h" +#include "drawtext.h" +#include "imtk.h" +#include "osd.h" void reg_whitted(void); @@ -12,6 +15,11 @@ int win_width, win_height; float win_aspect; long time_msec; +struct dtx_font *fnt_ui; +int fnt_ui_size; + +int dbgui; + static int reshape_pending; static unsigned int sdr_gamma; @@ -32,6 +40,19 @@ int demo_init(void) glEnable(GL_MULTISAMPLE); } + if(opt.vsync) { + gl_swap_interval(1); + } else { + gl_swap_interval(0); + } + + if(!(fnt_ui = dtx_open_font_glyphmap("data/ui.glyphmap"))) { + fprintf(stderr, "failed to open ui font\n"); + return -1; + } + fnt_ui_size = dtx_get_glyphmap_ptsize(dtx_get_glyphmap(fnt_ui, 0)); + dtx_prepare_range(fnt_ui, fnt_ui_size, 32, 127); + post_init(); if(!(sdr_gamma = create_program_load("sdr/post.v.glsl", "sdr/gamma.p.glsl"))) { @@ -63,6 +84,8 @@ void demo_cleanup(void) for(i=0; idestroy(); } + + dtx_close_font(fnt_ui); } void demo_display(void) @@ -109,6 +132,24 @@ void demo_display(void) glUseProgram(sdr_gamma); overlay_tex(post_fbtex, 1.0); } + + { + static long frames, prev_upd, fps; + long dt; + + frames++; + + dt = time_msec - prev_upd; + if(dt >= 750) { + fps = ((frames * 1000 << 8) + 128) / dt; + frames = 0; + prev_upd = time_msec; + } + + print_text(win_width - 80, 20, 1.0, 0.8, 0.1, "fps: %ld.%ld", fps >> 8, ((fps & 0xff) * 10) >> 8); + } + + draw_osd(); } void demo_reshape(int x, int y) @@ -124,13 +165,22 @@ void demo_reshape(int x, int y) glMatrixMode(GL_PROJECTION); glLoadIdentity(); gluPerspective(50.0, win_aspect, 0.5, 500.0); + + imtk_set_viewport(x, y); } void demo_keyboard(int key, int st) { - if(st && key == 27) { - demo_quit(); - return; + if(st) { + switch(key) { + case 27: + demo_quit(); + return; + + case '`': + dbgui ^= 1; + break; + } } if(cur_part && cur_part->keyboard) {