X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?a=blobdiff_plain;f=src%2Fmodern%2Fmain.c;h=ea1080552e88e2b2fd64e530d7c5adecc43259c4;hb=7ef52b31864696747396945b2ca8892d8796f96c;hp=e511b654e77d1439d9492a0ffa2287c837785dfe;hpb=60ca0807c066028fb144aea33da8e1f9cc94338e;p=retroray diff --git a/src/modern/main.c b/src/modern/main.c index e511b65..ea10805 100644 --- a/src/modern/main.c +++ b/src/modern/main.c @@ -20,7 +20,9 @@ along with this program. If not, see . #include #include "miniglut.h" #include "app.h" +#include "logger.h" +static void display(void); static void reshape(int x, int y); static void keydown(unsigned char key, int x, int y); static void keyup(unsigned char key, int x, int y); @@ -52,7 +54,7 @@ int main(int argc, char **argv) glutInitDisplayMode(GLUT_RGB | GLUT_DEPTH | GLUT_DOUBLE); glutCreateWindow("RetroRay"); - glutDisplayFunc(app_display); + glutDisplayFunc(display); glutReshapeFunc(reshape); glutKeyboardFunc(keydown); glutKeyboardUpFunc(keyup); @@ -77,7 +79,11 @@ int main(int argc, char **argv) wgl_swap_interval_ext = wglGetProcAddress("wglSwapIntervalEXT"); #endif - app_reshape(glutGet(GLUT_WINDOW_WIDTH), glutGet(GLUT_WINDOW_HEIGHT)); + win_width = glutGet(GLUT_WINDOW_WIDTH); + win_height = glutGet(GLUT_WINDOW_HEIGHT); + win_aspect = (float)win_width / win_height; + + init_logger(); if(app_init() == -1) { return 1; @@ -99,6 +105,23 @@ void app_redisplay(void) void app_swap_buffers(void) { + glMatrixMode(GL_PROJECTION); + glPushMatrix(); + glLoadIdentity(); + glMatrixMode(GL_MODELVIEW); + glLoadIdentity(); + + glRasterPos2i(-1, 1); + glPixelZoom(1, -1); + glEnable(GL_ALPHA_TEST); + glAlphaFunc(GL_GREATER, 0.5f); + glDrawPixels(win_width, win_height, GL_BGRA, GL_UNSIGNED_BYTE, framebuf); + glDisable(GL_ALPHA_TEST); + + glMatrixMode(GL_PROJECTION); + glPopMatrix(); + glMatrixMode(GL_MODELVIEW); + glutSwapBuffers(); assert(glGetError() == GL_NO_ERROR); } @@ -156,6 +179,11 @@ void app_vsync(int vsync) #endif +static void display(void) +{ + app_display(); + app_swap_buffers(); +} static void reshape(int x, int y) { @@ -215,7 +243,7 @@ static int translate_skey(int key) case GLUT_KEY_PAGE_UP: return KEY_PGUP; case GLUT_KEY_PAGE_DOWN: - return KEY_PGDOWN; + return KEY_PGDN; case GLUT_KEY_HOME: return KEY_HOME; case GLUT_KEY_END: