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

Side by Side Diff: ash/test/display_manager_test_api.cc

Issue 2445583002: Relocate display_manager from ash to ui (Closed)
Patch Set: fix windows build Created 4 years, 1 month 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
« no previous file with comments | « ash/test/display_manager_test_api.h ('k') | ash/touch/touch_hud_debug.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "ash/test/display_manager_test_api.h"
6
7 #include <cstdarg>
8 #include <vector>
9
10 #include "ash/display/display_manager.h"
11 #include "base/command_line.h"
12 #include "base/strings/string_split.h"
13 #include "ui/display/display.h"
14 #include "ui/display/manager/display_layout_builder.h"
15 #include "ui/display/manager/display_manager_utilities.h"
16 #include "ui/display/manager/managed_display_info.h"
17 #include "ui/display/screen.h"
18 #include "ui/events/test/event_generator.h"
19
20 namespace ash {
21 namespace test {
22 namespace {
23
24 DisplayInfoList CreateDisplayInfoListFromString(
25 const std::string specs,
26 DisplayManager* display_manager) {
27 DisplayInfoList display_info_list;
28 std::vector<std::string> parts = base::SplitString(
29 specs, ",", base::TRIM_WHITESPACE, base::SPLIT_WANT_ALL);
30 size_t index = 0;
31
32 display::Displays list =
33 display_manager->IsInUnifiedMode()
34 ? display_manager->software_mirroring_display_list()
35 : display_manager->active_display_list();
36
37 for (std::vector<std::string>::const_iterator iter = parts.begin();
38 iter != parts.end(); ++iter, ++index) {
39 int64_t id = (index < list.size()) ? list[index].id()
40 : display::Display::kInvalidDisplayID;
41 display_info_list.push_back(
42 display::ManagedDisplayInfo::CreateFromSpecWithID(*iter, id));
43 }
44 return display_info_list;
45 }
46
47 scoped_refptr<display::ManagedDisplayMode> GetDisplayModeForUIScale(
48 const display::ManagedDisplayInfo& info,
49 float ui_scale) {
50 const display::ManagedDisplayInfo::ManagedDisplayModeList& modes =
51 info.display_modes();
52 auto iter = std::find_if(
53 modes.begin(), modes.end(),
54 [ui_scale](const scoped_refptr<display::ManagedDisplayMode>& mode) {
55 return mode->ui_scale() == ui_scale;
56 });
57 if (iter == modes.end())
58 return scoped_refptr<display::ManagedDisplayMode>();
59 return *iter;
60 }
61
62 } // namespace
63
64 DisplayManagerTestApi::DisplayManagerTestApi(DisplayManager* display_manager)
65 : display_manager_(display_manager) {}
66
67 DisplayManagerTestApi::~DisplayManagerTestApi() {}
68
69 void DisplayManagerTestApi::UpdateDisplay(const std::string& display_specs) {
70 DisplayInfoList display_info_list =
71 CreateDisplayInfoListFromString(display_specs, display_manager_);
72 bool is_host_origin_set = false;
73 for (size_t i = 0; i < display_info_list.size(); ++i) {
74 const display::ManagedDisplayInfo& display_info = display_info_list[i];
75 if (display_info.bounds_in_native().origin() != gfx::Point(0, 0)) {
76 is_host_origin_set = true;
77 break;
78 }
79 }
80
81 // On non-testing environment, when a secondary display is connected, a new
82 // native (i.e. X) window for the display is always created below the
83 // previous one for GPU performance reasons. Try to emulate the behavior
84 // unless host origins are explicitly set.
85 if (!is_host_origin_set) {
86 // Start from (1,1) so that windows won't overlap with native mouse cursor.
87 // See |AshTestBase::SetUp()|.
88 int next_y = 1;
89 for (DisplayInfoList::iterator iter = display_info_list.begin();
90 iter != display_info_list.end(); ++iter) {
91 gfx::Rect bounds(iter->bounds_in_native().size());
92 bounds.set_x(1);
93 bounds.set_y(next_y);
94 next_y += bounds.height();
95 iter->SetBounds(bounds);
96 }
97 }
98
99 display_manager_->OnNativeDisplaysChanged(display_info_list);
100 display_manager_->UpdateInternalManagedDisplayModeListForTest();
101 display_manager_->RunPendingTasksForTest();
102 }
103
104 int64_t DisplayManagerTestApi::SetFirstDisplayAsInternalDisplay() {
105 const display::Display& internal = display_manager_->active_display_list_[0];
106 SetInternalDisplayId(internal.id());
107 return display::Display::InternalDisplayId();
108 }
109
110 void DisplayManagerTestApi::SetInternalDisplayId(int64_t id) {
111 display::Display::SetInternalDisplayId(id);
112 display_manager_->UpdateInternalManagedDisplayModeListForTest();
113 }
114
115 void DisplayManagerTestApi::DisableChangeDisplayUponHostResize() {
116 display_manager_->set_change_display_upon_host_resize(false);
117 }
118
119 void DisplayManagerTestApi::SetAvailableColorProfiles(
120 int64_t display_id,
121 const std::vector<ui::ColorCalibrationProfile>& profiles) {
122 display_manager_->display_info_[display_id].set_available_color_profiles(
123 profiles);
124 }
125
126 const display::ManagedDisplayInfo&
127 DisplayManagerTestApi::GetInternalManagedDisplayInfo(int64_t display_id) {
128 return display_manager_->display_info_[display_id];
129 }
130
131 bool DisplayManagerTestApi::SetDisplayUIScale(int64_t id, float ui_scale) {
132 if (!display_manager_->IsActiveDisplayId(id) ||
133 !display::Display::IsInternalDisplayId(id)) {
134 return false;
135 }
136 const display::ManagedDisplayInfo& info =
137 display_manager_->GetDisplayInfo(id);
138
139 scoped_refptr<display::ManagedDisplayMode> mode =
140 GetDisplayModeForUIScale(info, ui_scale);
141 if (!mode)
142 return false;
143 return display_manager_->SetDisplayMode(id, mode);
144 }
145
146 ScopedDisable125DSFForUIScaling::ScopedDisable125DSFForUIScaling() {
147 display::ManagedDisplayInfo::SetUse125DSFForUIScalingForTest(false);
148 }
149
150 ScopedDisable125DSFForUIScaling::~ScopedDisable125DSFForUIScaling() {
151 display::ManagedDisplayInfo::SetUse125DSFForUIScalingForTest(true);
152 }
153
154 ScopedSetInternalDisplayId::ScopedSetInternalDisplayId(
155 DisplayManager* display_manager,
156 int64_t id) {
157 DisplayManagerTestApi(display_manager).SetInternalDisplayId(id);
158 }
159
160 ScopedSetInternalDisplayId::~ScopedSetInternalDisplayId() {
161 display::Display::SetInternalDisplayId(display::Display::kInvalidDisplayID);
162 }
163
164 bool SetDisplayResolution(DisplayManager* display_manager,
165 int64_t display_id,
166 const gfx::Size& resolution) {
167 const display::ManagedDisplayInfo& info =
168 display_manager->GetDisplayInfo(display_id);
169 scoped_refptr<display::ManagedDisplayMode> mode =
170 GetDisplayModeForResolution(info, resolution);
171 if (!mode)
172 return false;
173 return display_manager->SetDisplayMode(display_id, mode);
174 }
175
176 std::unique_ptr<display::DisplayLayout> CreateDisplayLayout(
177 DisplayManager* display_manager,
178 display::DisplayPlacement::Position position,
179 int offset) {
180 display::DisplayLayoutBuilder builder(
181 display::Screen::GetScreen()->GetPrimaryDisplay().id());
182 builder.SetSecondaryPlacement(display_manager->GetSecondaryDisplay().id(),
183 position, offset);
184 return builder.Build();
185 }
186
187 display::DisplayIdList CreateDisplayIdList2(int64_t id1, int64_t id2) {
188 display::DisplayIdList list;
189 list.push_back(id1);
190 list.push_back(id2);
191 display::SortDisplayIdList(&list);
192 return list;
193 }
194
195 display::DisplayIdList CreateDisplayIdListN(size_t count, ...) {
196 display::DisplayIdList list;
197 va_list args;
198 va_start(args, count);
199 for (size_t i = 0; i < count; i++) {
200 int64_t id = va_arg(args, int64_t);
201 list.push_back(id);
202 }
203 display::SortDisplayIdList(&list);
204 return list;
205 }
206
207 } // namespace test
208 } // namespace ash
OLDNEW
« no previous file with comments | « ash/test/display_manager_test_api.h ('k') | ash/touch/touch_hud_debug.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698