X-Git-Url: http://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Fgame%2Fg_window.pas;h=17aa0479563d2239f9a3db5305b5b44a07fad5f9;hb=b3b3def6089809491a38cc03717683c011298032;hp=8b8919633da10cb3f2908cf0730e0ad809c45deb;hpb=966e88968e6a2ba968187fe82144874aae35d02a;p=d2df-sdl.git diff --git a/src/game/g_window.pas b/src/game/g_window.pas index 8b89196..17aa047 100644 --- a/src/game/g_window.pas +++ b/src/game/g_window.pas @@ -250,6 +250,7 @@ begin begin curMsButState := 0; curKbState := 0; + e_UnpressAllKeys(); if not wMinimized then begin e_ResizeWindow(0, 0); @@ -336,6 +337,7 @@ begin curMsButState := 0; curKbState := 0; wDeactivate := True; + e_UnpressAllKeys(); //e_WriteLog('window lost focus!', MSG_NOTIFY); g_Holmes_WindowBlured(); end; @@ -440,8 +442,7 @@ begin Result := True; end; - SDL_KEYDOWN, - SDL_KEYUP: + SDL_KEYDOWN, SDL_KEYUP: begin key := ev.key.keysym.scancode; if (g_holmes_enabled) then @@ -451,9 +452,14 @@ begin kbev.sym := ev.key.keysym.sym; kbev.bstate := curMsButState; kbev.kstate := curKbState; - if g_Holmes_keyEvent(kbev) then exit; + if g_Holmes_keyEvent(kbev) then + begin + if (ev.type_ <> SDL_KEYDOWN) then e_KeyUpDown(ev.key.keysym.scancode, false); + exit; + end; end; if (ev.type_ = SDL_KEYDOWN) then KeyPress(key); + e_KeyUpDown(ev.key.keysym.scancode, (ev.type_ = SDL_KEYDOWN)); end; SDL_MOUSEBUTTONDOWN, SDL_MOUSEBUTTONUP: @@ -815,10 +821,6 @@ begin if ParamStr(idx) = '--opengl-dump-exts' then gwin_dump_extensions := true; if ParamStr(idx) = '--twinkletwinkle' then gwin_k8_enable_light_experiments := true; if ParamStr(idx) = '--jah' then g_profile_history_size := 100; - //if ParamStr(idx) = '--tree-draw' then gdbg_map_use_tree_draw := true; - //if ParamStr(idx) = '--grid-draw' then gdbg_map_use_tree_draw := false; - //if ParamStr(idx) = '--tree-coldet' then gdbg_map_use_tree_coldet := true; - //if ParamStr(idx) = '--grid-coldet' then gdbg_map_use_tree_coldet := false; if ParamStr(idx) = '--no-particles' then gpart_dbg_enabled := false; if ParamStr(idx) = '--no-los' then gmon_dbg_los_enabled := false; @@ -833,15 +835,9 @@ begin if ParamStr(idx) = '--no-particle-phys' then gpart_dbg_phys_enabled := false; if ParamStr(idx) = '--no-particle-physics' then gpart_dbg_phys_enabled := false; - if ParamStr(idx) = '--holmes' then g_holmes_enabled := false; + if ParamStr(idx) = '--holmes' then begin g_holmes_enabled := true; g_Game_SetDebugMode(); end; end; - //if gdbg_map_use_tree_draw then e_WriteLog('using TREE renderer', MSG_NOTIFY); - //if not gdbg_map_use_tree_draw then e_WriteLog('using GRID renderer', MSG_NOTIFY); - - //if gdbg_map_use_tree_coldet then e_WriteLog('using TREE coldet', MSG_NOTIFY); - //if not gdbg_map_use_tree_coldet then e_WriteLog('using GRID coldet', MSG_NOTIFY); - e_WriteLog('Initializing OpenGL', MSG_NOTIFY); InitOpenGL(gVSync);