X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?p=laserbrain_demo;a=blobdiff_plain;f=src%2Fmain.cc;h=c497dc1dff3d2249a67443a49c39c04266eef68c;hp=169dbd312d4906abca7620e1214c1e97914d6166;hb=512acaa2427ffa2ff19079f999bc2fcd7cd33925;hpb=22e03ce83ae740c09912cf8acd5307a67c59471d diff --git a/src/main.cc b/src/main.cc index 169dbd3..c497dc1 100644 --- a/src/main.cc +++ b/src/main.cc @@ -8,6 +8,7 @@ static bool init(int argc, char **argv); static void process_event(SDL_Event *ev); static void proc_modkeys(); +static int translate_keysym(SDL_Keycode sym); static SDL_Window *win; static SDL_GLContext ctx; @@ -48,6 +49,7 @@ int main(int argc, char **argv) int val; SDL_GL_GetAttribute(SDL_GL_FRAMEBUFFER_SRGB_CAPABLE, &val); printf("SDL says we %s an sRGB framebuffer\n", val ? "got" : "didn't get"); + fb_srgb = val; if(!(ctx = SDL_GL_CreateContext(win))) { fprintf(stderr, "failed to create OpenGL context\n"); @@ -164,6 +166,8 @@ static bool init(int argc, char **argv) static void process_event(SDL_Event *ev) { + int key; + switch(ev->type) { case SDL_QUIT: quit = true; @@ -172,7 +176,9 @@ static void process_event(SDL_Event *ev) case SDL_KEYDOWN: case SDL_KEYUP: proc_modkeys(); - app_keyboard(ev->key.keysym.sym, ev->key.state == SDL_PRESSED); + if((key = translate_keysym(ev->key.keysym.sym)) != -1) { + app_keyboard(key, ev->key.state == SDL_PRESSED); + } break; case SDL_MOUSEBUTTONDOWN: @@ -190,6 +196,10 @@ static void process_event(SDL_Event *ev) } break; + case SDL_MOUSEWHEEL: + app_mouse_wheel(ev->wheel.y); + break; + case SDL_WINDOWEVENT: if(ev->window.event == SDL_WINDOWEVENT_SIZE_CHANGED) { SDL_GL_GetDrawableSize(win, &win_width, &win_height); @@ -224,3 +234,39 @@ static void proc_modkeys() modkeys |= MOD_CTRL; } } + +static int translate_keysym(SDL_Keycode sym) +{ + switch(sym) { + case SDLK_RETURN: + return '\n'; + case SDLK_DELETE: + return KEY_DEL; + case SDLK_LEFT: + return KEY_LEFT; + case SDLK_RIGHT: + return KEY_RIGHT; + case SDLK_UP: + return KEY_UP; + case SDLK_DOWN: + return KEY_DOWN; + case SDLK_PAGEUP: + return KEY_PGUP; + case SDLK_PAGEDOWN: + return KEY_PGDOWN; + case SDLK_HOME: + return KEY_HOME; + case SDLK_END: + return KEY_END; + default: + break; + } + + if(sym < 127) { + return sym; + } + if(sym >= SDLK_F1 && sym <= SDLK_F12) { + return KEY_F1 + sym - SDLK_F1; + } + return -1; +}