From 1f0999e6a0470826ea5bbde2ba5e17758ef7751a Mon Sep 17 00:00:00 2001 From: Tomaka17 Date: Sun, 27 Jul 2014 22:46:30 +0200 Subject: Implement get_position for win32 and fix interface --- src/win32/mod.rs | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) (limited to 'src/win32/mod.rs') diff --git a/src/win32/mod.rs b/src/win32/mod.rs index 8f3ae91..74b046b 100644 --- a/src/win32/mod.rs +++ b/src/win32/mod.rs @@ -207,8 +207,18 @@ impl Window { } } - pub fn get_position(&self) -> (uint, uint) { - unimplemented!() + pub fn get_position(&self) -> (int, int) { + use std::{mem, os}; + + let mut placement: ffi::WINDOWPLACEMENT = unsafe { mem::zeroed() }; + placement.length = mem::size_of::() as ffi::UINT; + + if unsafe { ffi::GetWindowPlacement(self.window, &mut placement) } == 0 { + fail!("GetWindowPlacement failed: {}", os::error_string(os::errno() as uint)); + } + + let ref rect = placement.rcNormalPosition; + (rect.left as int, rect.top as int) } pub fn set_position(&self, x: uint, y: uint) { @@ -363,8 +373,8 @@ extern "stdcall" fn callback(window: ffi::HWND, msg: ffi::UINT, ffi::WM_MOVE => { use events::Moved; - let x = ffi::LOWORD(lparam as ffi::DWORD) as uint; - let y = ffi::HIWORD(lparam as ffi::DWORD) as uint; + let x = ffi::LOWORD(lparam as ffi::DWORD) as i16 as int; + let y = ffi::HIWORD(lparam as ffi::DWORD) as i16 as int; send_event(window, Moved(x, y)); 0 }, -- cgit v1.2.3