summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatthias Schiffer <matthias@gamezock.de>2010-03-08 20:25:47 +0100
committerMatthias Schiffer <matthias@gamezock.de>2010-03-08 20:25:47 +0100
commit7edb7c0e060d509db83287c1cd8389e37dfc3a17 (patch)
tree8abcca934d465d8983f2b8deeb7a2cb4d3e07da0
parent996313bd8994d4536492ec8000f7a92fb015433e (diff)
downloadhtanks-7edb7c0e060d509db83287c1cd8389e37dfc3a17.tar
htanks-7edb7c0e060d509db83287c1cd8389e37dfc3a17.zip
Re-re-corrected coordinates ...
-rw-r--r--GLX.hs10
1 files changed, 9 insertions, 1 deletions
diff --git a/GLX.hs b/GLX.hs
index f98d367..3f3aec3 100644
--- a/GLX.hs
+++ b/GLX.hs
@@ -138,6 +138,10 @@ handleEvent glx xevent = do
| keysym == xK_Down -> return (glx, Just $ SomeEvent $ KeyPressEvent KeyDown)
| keysym == xK_Left -> return (glx, Just $ SomeEvent $ KeyPressEvent KeyLeft)
| keysym == xK_Right -> return (glx, Just $ SomeEvent $ KeyPressEvent KeyRight)
+ | keysym == xK_w -> return (glx, Just $ SomeEvent $ KeyPressEvent KeyUp)
+ | keysym == xK_s -> return (glx, Just $ SomeEvent $ KeyPressEvent KeyDown)
+ | keysym == xK_a -> return (glx, Just $ SomeEvent $ KeyPressEvent KeyLeft)
+ | keysym == xK_d -> return (glx, Just $ SomeEvent $ KeyPressEvent KeyRight)
| otherwise -> return (glx, Nothing)
| evtype == keyRelease -> do
keysym <- keycodeToKeysym (glxDisplay glx) (ev_keycode event) 0
@@ -146,6 +150,10 @@ handleEvent glx xevent = do
| keysym == xK_Down -> return (glx, Just $ SomeEvent $ KeyReleaseEvent KeyDown)
| keysym == xK_Left -> return (glx, Just $ SomeEvent $ KeyReleaseEvent KeyLeft)
| keysym == xK_Right -> return (glx, Just $ SomeEvent $ KeyReleaseEvent KeyRight)
+ | keysym == xK_w -> return (glx, Just $ SomeEvent $ KeyReleaseEvent KeyUp)
+ | keysym == xK_s -> return (glx, Just $ SomeEvent $ KeyReleaseEvent KeyDown)
+ | keysym == xK_a -> return (glx, Just $ SomeEvent $ KeyReleaseEvent KeyLeft)
+ | keysym == xK_d -> return (glx, Just $ SomeEvent $ KeyReleaseEvent KeyRight)
| otherwise -> return (glx, Nothing)
| evtype == clientMessage -> do
if ((glxDeleteWindow glx) == (fromIntegral . head . ev_data $ event))
@@ -162,7 +170,7 @@ handleEvent glx xevent = do
s = fromRational . glxScale $ glx
lw = fromIntegral . glxLevelWidth $ glx
lh = fromIntegral . glxLevelHeight $ glx
- return (glx, Just $ SomeEvent $ MouseMotionEvent ((w/2+x)/s - lw/2) ((h/2-y)/s + lh/2))
+ return (glx, Just $ SomeEvent $ MouseMotionEvent ((-w/2+x)/s + lw/2) ((h/2-y)/s + lh/2))
| otherwise -> return (glx, Nothing)