aboutsummaryrefslogtreecommitdiffstats
path: root/src/win32/callback.rs
diff options
context:
space:
mode:
authortomaka <pierre.krieger1708@gmail.com>2015-03-30 13:32:28 +0200
committertomaka <pierre.krieger1708@gmail.com>2015-03-30 13:32:28 +0200
commita1b504d16c6734dd064aff84059f45c803d97eb3 (patch)
treeaa3d6c4ea6d9903a7e7953b808401f1d8cd8c5d8 /src/win32/callback.rs
parentc3470abc8e818c3ba1247df243055f5d1f854f2c (diff)
parent2089e9c476691b8d81b9bbe8eb83f4c878614774 (diff)
downloadglutin-a1b504d16c6734dd064aff84059f45c803d97eb3.tar.gz
glutin-a1b504d16c6734dd064aff84059f45c803d97eb3.zip
Merge pull request #328 from tomaka/grab
Cursor grabbing
Diffstat (limited to 'src/win32/callback.rs')
-rw-r--r--src/win32/callback.rs21
1 files changed, 21 insertions, 0 deletions
diff --git a/src/win32/callback.rs b/src/win32/callback.rs
index bbf5b55..1cfb640 100644
--- a/src/win32/callback.rs
+++ b/src/win32/callback.rs
@@ -1,3 +1,4 @@
+use std::mem;
use std::rc::Rc;
use std::cell::RefCell;
use std::sync::mpsc::Sender;
@@ -176,6 +177,26 @@ pub unsafe extern "system" fn callback(window: winapi::HWND, msg: winapi::UINT,
0
},
+ winapi::WM_INPUT => {
+ let mut data: winapi::RAWINPUT = mem::uninitialized();
+ let mut data_size = mem::size_of::<winapi::RAWINPUT>() as winapi::UINT;
+ user32::GetRawInputData(mem::transmute(lparam), winapi::RID_INPUT,
+ mem::transmute(&mut data), &mut data_size,
+ mem::size_of::<winapi::RAWINPUTHEADER>() as winapi::UINT);
+
+ if data.header.dwType == winapi::RIM_TYPEMOUSE {
+ let _x = data.mouse.lLastX; // FIXME: this is not always the relative movement
+ let _y = data.mouse.lLastY;
+ // TODO:
+ //send_event(window, Event::MouseRawMovement { x: x, y: y });
+
+ 0
+
+ } else {
+ user32::DefWindowProcW(window, msg, wparam, lparam)
+ }
+ },
+
winapi::WM_SETFOCUS => {
use events::Event::Focused;
send_event(window, Focused(true));