diff options
Diffstat (limited to 'src/cocoa/monitor.rs')
-rw-r--r-- | src/cocoa/monitor.rs | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/src/cocoa/monitor.rs b/src/cocoa/monitor.rs new file mode 100644 index 0000000..912c02d --- /dev/null +++ b/src/cocoa/monitor.rs @@ -0,0 +1,47 @@ +use core_graphics::display; +use std::collections::RingBuf; + +pub struct MonitorID(u32); + +pub fn get_available_monitors() -> RingBuf<MonitorID> { + let mut monitors = RingBuf::new(); + unsafe { + let max_displays = 10u32; + let mut active_displays = [0u32; 10]; + let mut display_count = 0; + display::CGGetActiveDisplayList(max_displays, + &mut active_displays[0], + &mut display_count); + for i in range(0us, display_count as usize) { + monitors.push_back(MonitorID(active_displays[i])); + } + } + monitors +} + +pub fn get_primary_monitor() -> MonitorID { + let id = unsafe { + MonitorID(display::CGMainDisplayID()) + }; + id +} + +impl MonitorID { + pub fn get_name(&self) -> Option<String> { + let MonitorID(display_id) = *self; + let screen_num = unsafe { + display::CGDisplayModelNumber(display_id) + }; + Some(format!("Monitor #{}", screen_num)) + } + + pub fn get_dimensions(&self) -> (u32, u32) { + let MonitorID(display_id) = *self; + let dimension = unsafe { + let height = display::CGDisplayPixelsHigh(display_id); + let width = display::CGDisplayPixelsWide(display_id); + (width as u32, height as u32) + }; + dimension + } +} |