diff options
author | tomaka <pierre.krieger1708@gmail.com> | 2015-04-24 14:05:35 +0200 |
---|---|---|
committer | tomaka <pierre.krieger1708@gmail.com> | 2015-04-24 14:05:35 +0200 |
commit | b6252d9de2f487982193569212e301fb598593dd (patch) | |
tree | 3061216335701a5faa8bd3c5c9ec0499a357be5a /src/api/x11/window/monitor.rs | |
parent | c1af76550f311e3da7a08d393b4ea9805cb61a7b (diff) | |
parent | 3ad7f9a58429b02b11b18f6a70ac011f698b6f4b (diff) | |
download | glutin-b6252d9de2f487982193569212e301fb598593dd.tar.gz glutin-b6252d9de2f487982193569212e301fb598593dd.zip |
Merge pull request #393 from tomaka/reorganization
Create reorganization
Diffstat (limited to 'src/api/x11/window/monitor.rs')
-rw-r--r-- | src/api/x11/window/monitor.rs | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/src/api/x11/window/monitor.rs b/src/api/x11/window/monitor.rs new file mode 100644 index 0000000..46f2062 --- /dev/null +++ b/src/api/x11/window/monitor.rs @@ -0,0 +1,66 @@ +use std::ptr; +use std::collections::VecDeque; +use super::super::ffi; +use super::ensure_thread_init; +use native_monitor::NativeMonitorId; + +pub struct MonitorID(pub u32); + +pub fn get_available_monitors() -> VecDeque<MonitorID> { + ensure_thread_init(); + let nb_monitors = unsafe { + let display = ffi::XOpenDisplay(ptr::null()); + if display.is_null() { + panic!("get_available_monitors failed"); + } + let nb_monitors = ffi::XScreenCount(display); + ffi::XCloseDisplay(display); + nb_monitors + }; + + let mut monitors = VecDeque::new(); + monitors.extend((0..nb_monitors).map(|i| MonitorID(i as u32))); + monitors +} + +pub fn get_primary_monitor() -> MonitorID { + ensure_thread_init(); + let primary_monitor = unsafe { + let display = ffi::XOpenDisplay(ptr::null()); + if display.is_null() { + panic!("get_available_monitors failed"); + } + let primary_monitor = ffi::XDefaultScreen(display); + ffi::XCloseDisplay(display); + primary_monitor + }; + + MonitorID(primary_monitor as u32) +} + +impl MonitorID { + pub fn get_name(&self) -> Option<String> { + let MonitorID(screen_num) = *self; + Some(format!("Monitor #{}", screen_num)) + } + + pub fn get_native_identifier(&self) -> NativeMonitorId { + let MonitorID(screen_num) = *self; + NativeMonitorId::Numeric(screen_num) + } + + pub fn get_dimensions(&self) -> (u32, u32) { + let dimensions = unsafe { + let display = ffi::XOpenDisplay(ptr::null()); + let MonitorID(screen_num) = *self; + let screen = ffi::XScreenOfDisplay(display, screen_num as i32); + let width = ffi::XWidthOfScreen(screen); + let height = ffi::XHeightOfScreen(screen); + ffi::XCloseDisplay(display); + (width as u32, height as u32) + }; + + dimensions + } +} + |