1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "ui/gfx/screen.h"
#include "base/logging.h"
#include "ui/gfx/native_widget_types.h"
namespace gfx {
// gfx can't depend upon ash, otherwise we have circular dependencies. So,
// gfx::Screen is pluggable and Desktop plugs in the real implementation.
// static
Screen* Screen::instance_ = NULL;
// static
void Screen::SetInstance(Screen* screen) {
delete instance_;
instance_ = screen;
}
// static
gfx::Point Screen::GetCursorScreenPoint() {
// TODO(erg): Figure out what to do about the Screen class. For now, I've
// added default values for when a Screen instance class isn't passed in, but
// this is the wrong thing.
if (!instance_)
return gfx::Point();
return instance_->GetCursorScreenPointImpl();
}
// static
gfx::Rect Screen::GetMonitorWorkAreaNearestWindow(gfx::NativeWindow window) {
if (!instance_)
return gfx::Rect(0, 0, 800, 800);
return instance_->GetMonitorWorkAreaNearestWindowImpl(window);
}
// static
gfx::Rect Screen::GetMonitorAreaNearestWindow(gfx::NativeWindow window) {
if (!instance_)
return gfx::Rect(0, 0, 800, 800);
return instance_->GetMonitorAreaNearestWindowImpl(window);
}
// static
gfx::Rect Screen::GetMonitorWorkAreaNearestPoint(const gfx::Point& point) {
if (!instance_)
return gfx::Rect(0, 0, 800, 800);
return instance_->GetMonitorWorkAreaNearestPointImpl(point);
}
// static
gfx::Rect Screen::GetMonitorAreaNearestPoint(const gfx::Point& point) {
if (!instance_)
return gfx::Rect(0, 0, 800, 800);
return instance_->GetMonitorAreaNearestPointImpl(point);
}
// static
gfx::Rect Screen::GetPrimaryMonitorWorkArea() {
if (!instance_)
return gfx::Rect(0, 0, 800, 800);
return instance_->GetMonitorWorkAreaNearestPoint(gfx::Point());
}
// static
gfx::Rect Screen::GetPrimaryMonitorBounds() {
if (!instance_)
return gfx::Rect(0, 0, 800, 800);
return instance_->GetMonitorAreaNearestPoint(gfx::Point());
}
// static
gfx::Rect Screen::GetMonitorWorkAreaMatching(const gfx::Rect& match_rect) {
if (!instance_)
return gfx::Rect(0, 0, 800, 800);
return instance_->GetMonitorWorkAreaNearestPoint(gfx::Point());
}
// static
gfx::NativeWindow Screen::GetWindowAtCursorScreenPoint() {
if (!instance_)
return NULL;
return instance_->GetWindowAtCursorScreenPointImpl();
}
// static
gfx::Size Screen::GetPrimaryMonitorSize() {
if (!instance_)
return gfx::Size(800, 800);
return instance_->GetPrimaryMonitorSizeImpl();
}
// static
int Screen::GetNumMonitors() {
if (!instance_)
return 1;
return instance_->GetNumMonitorsImpl();
}
} // namespace gfx
|