X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?p=vrfileman;a=blobdiff_plain;f=src%2Fapp.cc;h=c3f6b3928c57400a9f04490d01cf4f2c0f4b3b0f;hp=d8aa1448865becbf0e29b6a231a4cd3df19a2dcb;hb=8afeabf06c79c755e5aaffa224e06c4abc92d833;hpb=b4582685152d23c4c3b6c7ead4d651c4df06eb01 diff --git a/src/app.cc b/src/app.cc index d8aa144..c3f6b39 100644 --- a/src/app.cc +++ b/src/app.cc @@ -7,14 +7,14 @@ #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; +double time_sec; +Mat4 view_matrix; -static bool use_vr; static bool should_swap; static float cam_theta, cam_phi; @@ -26,9 +26,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; } @@ -39,16 +42,17 @@ bool app_init(int argc, char **argv) glGetIntegerv(GL_SAMPLES, &aasamples); printf("got %d samples per pixel\n", aasamples); + printf("Max anisotropy: %d\n", glcaps.max_aniso); + 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; } @@ -73,7 +77,7 @@ bool app_init(int argc, char **argv) void app_cleanup() { - if(use_vr) { + if(opt.vr) { goatvr_shutdown(); } delete mesh_torus; @@ -82,7 +86,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); @@ -93,13 +97,13 @@ void app_draw() glMatrixMode(GL_PROJECTION); glLoadMatrixf(goatvr_projection_matrix(i, 0.5, 1000.0)); - Mat4 view_mat = goatvr_view_matrix(i); - view_mat.pre_rotate_x(deg_to_rad(cam_phi)); - view_mat.pre_rotate_y(deg_to_rad(cam_theta)); - view_mat.pre_translate(0, -cam_height, 0); + view_matrix = goatvr_view_matrix(i); + view_matrix.pre_rotate_x(deg_to_rad(cam_phi)); + view_matrix.pre_rotate_y(deg_to_rad(cam_theta)); + view_matrix.pre_translate(0, -cam_height, 0); glMatrixMode(GL_MODELVIEW); - glLoadMatrixf(view_mat[0]); + glLoadMatrixf(view_matrix[0]); draw_backdrop(); } @@ -114,17 +118,18 @@ void app_draw() // regular monoscopic mode glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - Mat4 view_mat; - view_mat.pre_rotate_x(deg_to_rad(cam_phi)); - view_mat.pre_rotate_y(deg_to_rad(cam_theta)); - view_mat.pre_translate(0, -cam_height, 0); + view_matrix = Mat4::identity; + view_matrix.pre_rotate_x(deg_to_rad(cam_phi)); + view_matrix.pre_rotate_y(deg_to_rad(cam_theta)); + view_matrix.pre_translate(0, -cam_height, 0); glMatrixMode(GL_MODELVIEW); - glLoadMatrixf(view_mat[0]); + glLoadMatrixf(view_matrix[0]); draw_backdrop(); app_swap_buffers(); + app_redraw(); // since we added animation we need to redisplay even in non-VR mode } assert(glGetError() == GL_NO_ERROR); } @@ -138,6 +143,10 @@ void app_reshape(int x, int y) glMatrixMode(GL_PROJECTION); glLoadMatrixf(mat[0]); + + if(opt.vr) { + goatvr_set_fb_size(x, y, 1.0); + } } void app_keyboard(int key, bool pressed) @@ -148,8 +157,19 @@ void app_keyboard(int key, bool pressed) app_quit(); break; + case 'f': + if(!opt.vr || should_swap) { + /* we take the need to swap as a signal that our window is not managed + * by some VR compositor, and therefore it's safe to fullscreen without + * upsetting the VR rendering output + */ + opt.fullscreen = !opt.fullscreen; + app_fullscreen(opt.fullscreen); + } + break; + case ' ': - if(use_vr) { + if(opt.vr) { goatvr_recenter(); } break; @@ -176,7 +196,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; @@ -185,30 +205,3 @@ void app_mouse_motion(int x, int y) } app_redraw(); } - -static bool parse_args(int argc, char **argv) -{ - for(int i=1; i