X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?p=vrfileman;a=blobdiff_plain;f=src%2Fapp.cc;h=730302eb6a0400adda783056832bb34d93c11c24;hp=0dc88f01072b69c5a65b15310a9a820969f4b938;hb=818d6e49d86bc91748396a8c408cd84d17e10994;hpb=cb2703917746784c4ea3408a049ff4297dfc268e diff --git a/src/app.cc b/src/app.cc index 0dc88f0..730302e 100644 --- a/src/app.cc +++ b/src/app.cc @@ -7,15 +7,13 @@ #include "meshgen.h" #include "backdrop.h" #include "goatvr.h" - -static bool parse_args(int argc, char **argv); +#include "opt.h" int win_width, win_height; float win_aspect; long time_msec; Mat4 view_matrix; -static bool use_vr; static bool should_swap; static float cam_theta, cam_phi; @@ -27,9 +25,12 @@ static int prev_x, prev_y; bool app_init(int argc, char **argv) { - if(!parse_args(argc, argv)) { + if(!init_options(argc, argv, 0)) { return false; } + app_resize(opt.width, opt.height); + app_fullscreen(opt.fullscreen); + if(init_opengl() == -1) { return false; } @@ -44,14 +45,13 @@ bool app_init(int argc, char **argv) glEnable(GL_CULL_FACE); glEnable(GL_DEPTH_TEST); - //glEnable(GL_LIGHTING); - glEnable(GL_LIGHT0); - if(GLEW_ARB_framebuffer_sRGB) { + if(opt.srgb && GLEW_ARB_framebuffer_sRGB) { + printf("enabling sRGB framebuffer\n"); glEnable(GL_FRAMEBUFFER_SRGB); } - if(use_vr) { + if(opt.vr) { if(goatvr_init() == -1) { return false; } @@ -76,7 +76,7 @@ bool app_init(int argc, char **argv) void app_cleanup() { - if(use_vr) { + if(opt.vr) { goatvr_shutdown(); } delete mesh_torus; @@ -85,7 +85,7 @@ void app_cleanup() void app_draw() { - if(use_vr) { + if(opt.vr) { // VR mode goatvr_draw_start(); glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); @@ -152,7 +152,7 @@ void app_keyboard(int key, bool pressed) break; case ' ': - if(use_vr) { + if(opt.vr) { goatvr_recenter(); } break; @@ -179,7 +179,7 @@ void app_mouse_motion(int x, int y) if(bnstate[0]) { cam_theta += dx * 0.5; - if(!use_vr || !goatvr_have_headtracking()) { + if(!opt.vr || !goatvr_have_headtracking()) { cam_phi += dy * 0.5; if(cam_phi < -90) cam_phi = -90; @@ -188,30 +188,3 @@ void app_mouse_motion(int x, int y) } app_redraw(); } - -static bool parse_args(int argc, char **argv) -{ - for(int i=1; i