Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(703)

Side by Side Diff: ui/aura/monitor_manager.cc

Issue 9960042: Refactor screen/monitor so that gfx::Screen returns monitor object. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: cleanup Created 8 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "ui/aura/monitor_manager.h" 5 #include "ui/aura/monitor_manager.h"
6 6
7 #include <stdio.h> 7 #include <stdio.h>
8 8
9 #include "base/logging.h" 9 #include "base/logging.h"
10 #include "ui/aura/env.h" 10 #include "ui/aura/env.h"
11 #include "ui/aura/monitor.h" 11 #include "ui/aura/monitor_observer.h"
12 #include "ui/aura/root_window.h" 12 #include "ui/aura/root_window.h"
13 #include "ui/aura/root_window_host.h" 13 #include "ui/aura/root_window_host.h"
14 #include "ui/gfx/monitor.h"
14 #include "ui/gfx/rect.h" 15 #include "ui/gfx/rect.h"
15 16
16 namespace aura { 17 namespace aura {
17 namespace { 18 namespace {
18 // Default bounds for a monitor. 19 // Default bounds for a monitor.
19 static const int kDefaultHostWindowX = 200; 20 static const int kDefaultHostWindowX = 200;
20 static const int kDefaultHostWindowY = 200; 21 static const int kDefaultHostWindowY = 200;
21 static const int kDefaultHostWindowWidth = 1280; 22 static const int kDefaultHostWindowWidth = 1280;
22 static const int kDefaultHostWindowHeight = 1024; 23 static const int kDefaultHostWindowHeight = 1024;
23 } // namespace 24 } // namespace
24 25
25 // static 26 // static
26 bool MonitorManager::use_fullscreen_host_window_ = false; 27 bool MonitorManager::use_fullscreen_host_window_ = false;
27 28
28 // static 29 // static
29 Monitor* MonitorManager::CreateMonitorFromSpec(const std::string& spec) { 30 gfx::Monitor* MonitorManager::CreateMonitorFromSpec(const std::string& spec) {
30 gfx::Rect bounds(kDefaultHostWindowX, kDefaultHostWindowY, 31 gfx::Rect bounds(kDefaultHostWindowX, kDefaultHostWindowY,
31 kDefaultHostWindowWidth, kDefaultHostWindowHeight); 32 kDefaultHostWindowWidth, kDefaultHostWindowHeight);
32 int x = 0, y = 0, width, height; 33 int x = 0, y = 0, width, height;
33 float scale = 1.0f; 34 float scale = 1.0f;
34 if (sscanf(spec.c_str(), "%dx%d*%f", &width, &height, &scale) >= 2) { 35 if (sscanf(spec.c_str(), "%dx%d*%f", &width, &height, &scale) >= 2) {
35 bounds.set_size(gfx::Size(width, height)); 36 bounds.set_size(gfx::Size(width, height));
36 } else if (sscanf(spec.c_str(), "%d+%d-%dx%d*%f", &x, &y, &width, &height, 37 } else if (sscanf(spec.c_str(), "%d+%d-%dx%d*%f", &x, &y, &width, &height,
37 &scale) >= 4 ) { 38 &scale) >= 4 ) {
38 bounds = gfx::Rect(x, y, width, height); 39 bounds = gfx::Rect(x, y, width, height);
39 } else if (use_fullscreen_host_window_) { 40 } else if (use_fullscreen_host_window_) {
40 bounds = gfx::Rect(aura::RootWindowHost::GetNativeScreenSize()); 41 bounds = gfx::Rect(aura::RootWindowHost::GetNativeScreenSize());
41 } 42 }
42 Monitor* monitor = new Monitor(); 43 gfx::Monitor* monitor = new gfx::Monitor(bounds);
43 monitor->set_bounds(bounds);
44 monitor->set_device_scale_factor(scale); 44 monitor->set_device_scale_factor(scale);
45 DVLOG(1) << "Monitor bounds=" << bounds.ToString() << ", scale=" << scale; 45 DVLOG(1) << "Monitor bounds=" << bounds.ToString() << ", scale=" << scale;
46 return monitor; 46 return monitor;
47 } 47 }
48 48
49 // static 49 // static
50 RootWindow* MonitorManager::CreateRootWindowForPrimaryMonitor() { 50 RootWindow* MonitorManager::CreateRootWindowForPrimaryMonitor() {
51 MonitorManager* manager = aura::Env::GetInstance()->monitor_manager(); 51 MonitorManager* manager = aura::Env::GetInstance()->monitor_manager();
52 RootWindow* root = 52 RootWindow* root =
53 manager->CreateRootWindowForMonitor(manager->GetMonitorAt(0)); 53 manager->CreateRootWindowForMonitor(manager->GetMonitorAt(0));
54 if (use_fullscreen_host_window_) 54 if (use_fullscreen_host_window_)
55 root->ConfineCursorToWindow(); 55 root->ConfineCursorToWindow();
56 return root; 56 return root;
57 } 57 }
58 58
59 MonitorManager::MonitorManager() { 59 MonitorManager::MonitorManager() {
60 } 60 }
61 61
62 MonitorManager::~MonitorManager() { 62 MonitorManager::~MonitorManager() {
63 } 63 }
64 64
65 void MonitorManager::AddObserver(MonitorObserver* observer) { 65 void MonitorManager::AddObserver(MonitorObserver* observer) {
66 observers_.AddObserver(observer); 66 observers_.AddObserver(observer);
67 } 67 }
68 68
69 void MonitorManager::RemoveObserver(MonitorObserver* observer) { 69 void MonitorManager::RemoveObserver(MonitorObserver* observer) {
70 observers_.RemoveObserver(observer); 70 observers_.RemoveObserver(observer);
71 } 71 }
72 72
73 void MonitorManager::NotifyBoundsChanged(const Monitor* monitor) { 73 void MonitorManager::NotifyBoundsChanged(const gfx::Monitor* monitor) {
Ben Goodger (Google) 2012/04/24 21:17:08 const gfx::Monitor& monitor
oshima 2012/04/25 02:38:01 Done.
74 FOR_EACH_OBSERVER(MonitorObserver, observers_, 74 FOR_EACH_OBSERVER(MonitorObserver, observers_,
75 OnMonitorBoundsChanged(monitor)); 75 OnMonitorBoundsChanged(monitor));
76 } 76 }
77 77
78 void MonitorManager::NotifyMonitorAdded(Monitor* monitor) { 78 void MonitorManager::NotifyMonitorAdded(gfx::Monitor* monitor) {
Ben Goodger (Google) 2012/04/24 21:17:08 etc
oshima 2012/04/25 02:38:01 Done.
79 FOR_EACH_OBSERVER(MonitorObserver, observers_, 79 FOR_EACH_OBSERVER(MonitorObserver, observers_,
80 OnMonitorAdded(monitor)); 80 OnMonitorAdded(monitor));
81 } 81 }
82 82
83 void MonitorManager::NotifyMonitorRemoved(const Monitor* monitor) { 83 void MonitorManager::NotifyMonitorRemoved(const gfx::Monitor* monitor) {
Ben Goodger (Google) 2012/04/24 21:17:08 etc
oshima 2012/04/25 02:38:01 Done.
84 FOR_EACH_OBSERVER(MonitorObserver, observers_, 84 FOR_EACH_OBSERVER(MonitorObserver, observers_,
85 OnMonitorRemoved(monitor)); 85 OnMonitorRemoved(monitor));
86 } 86 }
87 87
88 } // namespace aura 88 } // namespace aura
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698