aboutsummaryrefslogtreecommitdiffstats
path: root/src/cocoa/monitor.rs
diff options
context:
space:
mode:
authortomaka <pierre.krieger1708@gmail.com>2015-01-26 10:55:35 +0100
committertomaka <pierre.krieger1708@gmail.com>2015-01-26 10:55:35 +0100
commit1a9cf9bc5c6e9251c8035e8412edafe4bfa8869d (patch)
tree735466f6586a7f9a686e769487b55a1991bc87dc /src/cocoa/monitor.rs
parent9705606a20cb68187829b6767cf880ff6b4fda0c (diff)
parent73078e0569a9cadc51d64e98f4653e66e2985b8d (diff)
downloadglutin-1a9cf9bc5c6e9251c8035e8412edafe4bfa8869d.tar.gz
glutin-1a9cf9bc5c6e9251c8035e8412edafe4bfa8869d.zip
Merge pull request #231 from bjz/osx-window
Implement some more Cocoa stuff
Diffstat (limited to 'src/cocoa/monitor.rs')
-rw-r--r--src/cocoa/monitor.rs47
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
+ }
+}