diff options
author | tomaka <pierre.krieger1708@gmail.com> | 2014-09-19 20:36:50 +0200 |
---|---|---|
committer | tomaka <pierre.krieger1708@gmail.com> | 2014-09-19 20:36:50 +0200 |
commit | 3ac5f6d115afa3907047a8a55b58c698b47d3b28 (patch) | |
tree | 6f5a29b567d863c7e8d42ce46498c575ffdb6151 /src/x11/monitor.rs | |
parent | d8171a0c73921a28b2005030df741ef11a262900 (diff) | |
parent | 9b06c973a2569c43ed0c95d72423fe5c3146efdb (diff) | |
download | glutin-3ac5f6d115afa3907047a8a55b58c698b47d3b28.tar.gz glutin-3ac5f6d115afa3907047a8a55b58c698b47d3b28.zip |
Merge pull request #38 from tomaka/x11_fullscreen
X11 fullscreen
Diffstat (limited to 'src/x11/monitor.rs')
-rw-r--r-- | src/x11/monitor.rs | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/src/x11/monitor.rs b/src/x11/monitor.rs new file mode 100644 index 0000000..f1b861b --- /dev/null +++ b/src/x11/monitor.rs @@ -0,0 +1,55 @@ +use std::{ptr}; +use super::ffi; + +pub struct MonitorID(uint); + +pub fn get_available_monitors() -> Vec<MonitorID> { + let nb_monitors = unsafe { + let display = ffi::XOpenDisplay(ptr::null()); + if display.is_null() { + fail!("get_available_monitors failed"); + } + let nb_monitors = ffi::XScreenCount(display); + ffi::XCloseDisplay(display); + nb_monitors + }; + + let mut vec = Vec::new(); + vec.grow_fn(nb_monitors as uint, |i| MonitorID(i)); + vec +} + +pub fn get_primary_monitor() -> MonitorID { + let primary_monitor = unsafe { + let display = ffi::XOpenDisplay(ptr::null()); + if display.is_null() { + fail!("get_available_monitors failed"); + } + let primary_monitor = ffi::XDefaultScreen(display); + ffi::XCloseDisplay(display); + primary_monitor + }; + + MonitorID(primary_monitor as uint) +} + +impl MonitorID { + pub fn get_name(&self) -> Option<String> { + let MonitorID(screen_num) = *self; + Some(format!("Monitor #{}", screen_num)) + } + + pub fn get_dimensions(&self) -> (uint, uint) { + 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); + (width as uint, height as uint) + }; + + dimensions + } +} + |