diff options
author | David Partouche <david@manateedev.com> | 2014-10-23 17:18:47 +0200 |
---|---|---|
committer | David Partouche <david@manateedev.com> | 2014-10-23 17:30:17 +0200 |
commit | 6f46c0c2dd9eedd350dd2ea1a426c96ef6284357 (patch) | |
tree | e0eb52ba847e9c11a9cc5333968588ccea9c2556 /src/osx | |
parent | 271b68891002b324be04d04475a4207ce5918590 (diff) | |
download | glutin-6f46c0c2dd9eedd350dd2ea1a426c96ef6284357.tar.gz glutin-6f46c0c2dd9eedd350dd2ea1a426c96ef6284357.zip |
Added the modifiers key as input
Diffstat (limited to 'src/osx')
-rw-r--r-- | src/osx/mod.rs | 41 |
1 files changed, 38 insertions, 3 deletions
diff --git a/src/osx/mod.rs b/src/osx/mod.rs index f165650..abe233d 100644 --- a/src/osx/mod.rs +++ b/src/osx/mod.rs @@ -8,6 +8,7 @@ use WindowBuilder; use HeadlessRendererBuilder; use cocoa::base::{id, NSUInteger, nil}; +use cocoa::appkit; use cocoa::appkit::*; use core_foundation::base::TCFType; @@ -16,10 +17,16 @@ use core_foundation::bundle::{CFBundleGetBundleWithIdentifier, CFBundleGetFuncti use std::c_str::CString; use {MouseInput, Pressed, Released, LeftMouseButton, RightMouseButton, MouseMoved, ReceivedCharacter, - KeyboardInput}; + KeyboardInput, KeyModifiers}; + +use events; mod event; +static mut shift_pressed: bool = false; +static mut ctrl_pressed: bool = false; +static mut win_pressed: bool = false; + pub struct Window { view: id, context: id, @@ -250,8 +257,21 @@ impl Window { events.push(KeyboardInput(Released, event.keycode() as u8, vkey, modifiers)); }, NSFlagsChanged => { - println!("Modifiers: {}", event.modifierFlags()); - // Need to keep an array of the modified flags + let shift_modifier = Window::modifier_event(event, appkit::NSShiftKeyMask as u64, events::LShift, shift_pressed); + if shift_modifier.is_some() { + shift_pressed = !shift_pressed; + events.push(shift_modifier.unwrap()); + } + let ctrl_modifier = Window::modifier_event(event, appkit::NSControlKeyMask as u64, events::LControl, ctrl_pressed); + if ctrl_modifier.is_some() { + ctrl_pressed = !ctrl_pressed; + events.push(ctrl_modifier.unwrap()); + } + let win_modifier = Window::modifier_event(event, appkit::NSCommandKeyMask as u64, events::LWin, win_pressed); + if win_modifier.is_some() { + win_pressed = !win_pressed; + events.push(win_modifier.unwrap()); + } }, NSScrollWheel => { }, NSOtherMouseDown => { }, @@ -264,6 +284,21 @@ impl Window { events } + unsafe fn modifier_event(event: id, keymask: u64, key: events::VirtualKeyCode, key_pressed: bool) -> Option<Event> { + if !key_pressed && Window::modifier_key_pressed(event, keymask) { + return Some(KeyboardInput(Pressed, event.keycode() as u8, Some(key), KeyModifiers::empty())); + } + else if key_pressed && !Window::modifier_key_pressed(event, keymask) { + return Some(KeyboardInput(Released, event.keycode() as u8, Some(key), KeyModifiers::empty())); + } + + return None; + } + + unsafe fn modifier_key_pressed(event: id, modifier: u64) -> bool { + event.modifierFlags() & modifier != 0 + } + pub fn wait_events(&self) -> Vec<Event> { unsafe { let event = NSApp().nextEventMatchingMask_untilDate_inMode_dequeue_( |