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

Side by Side Diff: extensions/browser/api/system_display/display_info_provider.cc

Issue 389633002: Move system.* family of APIs to extensions/ (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebased Created 6 years, 3 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
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 "chrome/browser/extensions/api/system_display/display_info_provider.h" 5 #include "extensions/browser/api/system_display/display_info_provider.h"
6 6
7 #include "base/strings/string_number_conversions.h" 7 #include "base/strings/string_number_conversions.h"
8 #include "chrome/common/extensions/api/system_display.h" 8 #include "extensions/common/api/system_display.h"
9 #include "ui/gfx/display.h" 9 #include "ui/gfx/display.h"
10 #include "ui/gfx/screen.h" 10 #include "ui/gfx/screen.h"
11 11
12 namespace extensions { 12 namespace extensions {
13 13
14 namespace { 14 namespace {
15 15
16 // Created on demand and will leak when the process exits. 16 // Created on demand and will leak when the process exits.
17 DisplayInfoProvider* g_display_info_provider = NULL; 17 DisplayInfoProvider* g_display_info_provider = NULL;
18 18
19 // Converts Rotation enum to integer. 19 // Converts Rotation enum to integer.
20 int RotationToDegrees(gfx::Display::Rotation rotation) { 20 int RotationToDegrees(gfx::Display::Rotation rotation) {
21 switch (rotation) { 21 switch (rotation) {
22 case gfx::Display::ROTATE_0: 22 case gfx::Display::ROTATE_0:
23 return 0; 23 return 0;
24 case gfx::Display::ROTATE_90: 24 case gfx::Display::ROTATE_90:
25 return 90; 25 return 90;
26 case gfx::Display::ROTATE_180: 26 case gfx::Display::ROTATE_180:
27 return 180; 27 return 180;
28 case gfx::Display::ROTATE_270: 28 case gfx::Display::ROTATE_270:
29 return 270; 29 return 270;
30 } 30 }
31 return 0; 31 return 0;
32 } 32 }
33 33
34 // Creates new DisplayUnitInfo struct for |display|. 34 // Creates new DisplayUnitInfo struct for |display|.
35 extensions::api::system_display::DisplayUnitInfo* 35 core_api::system_display::DisplayUnitInfo* CreateDisplayUnitInfo(
36 CreateDisplayUnitInfo(const gfx::Display& display, int64 primary_display_id) { 36 const gfx::Display& display,
37 extensions::api::system_display::DisplayUnitInfo* unit = 37 int64 primary_display_id) {
38 new extensions::api::system_display::DisplayUnitInfo(); 38 core_api::system_display::DisplayUnitInfo* unit =
39 new core_api::system_display::DisplayUnitInfo();
39 const gfx::Rect& bounds = display.bounds(); 40 const gfx::Rect& bounds = display.bounds();
40 const gfx::Rect& work_area = display.work_area(); 41 const gfx::Rect& work_area = display.work_area();
41 unit->id = base::Int64ToString(display.id()); 42 unit->id = base::Int64ToString(display.id());
42 unit->is_primary = (display.id() == primary_display_id); 43 unit->is_primary = (display.id() == primary_display_id);
43 unit->is_internal = display.IsInternal(); 44 unit->is_internal = display.IsInternal();
44 unit->is_enabled = true; 45 unit->is_enabled = true;
45 unit->rotation = RotationToDegrees(display.rotation()); 46 unit->rotation = RotationToDegrees(display.rotation());
46 unit->bounds.left = bounds.x(); 47 unit->bounds.left = bounds.x();
47 unit->bounds.top = bounds.y(); 48 unit->bounds.top = bounds.y();
48 unit->bounds.width = bounds.width(); 49 unit->bounds.width = bounds.width();
(...skipping 24 matching lines...) Expand all
73 g_display_info_provider = display_info_provider; 74 g_display_info_provider = display_info_provider;
74 } 75 }
75 76
76 DisplayInfo DisplayInfoProvider::GetAllDisplaysInfo() { 77 DisplayInfo DisplayInfoProvider::GetAllDisplaysInfo() {
77 // TODO(scottmg): Native is wrong http://crbug.com/133312 78 // TODO(scottmg): Native is wrong http://crbug.com/133312
78 gfx::Screen* screen = gfx::Screen::GetNativeScreen(); 79 gfx::Screen* screen = gfx::Screen::GetNativeScreen();
79 int64 primary_id = screen->GetPrimaryDisplay().id(); 80 int64 primary_id = screen->GetPrimaryDisplay().id();
80 std::vector<gfx::Display> displays = screen->GetAllDisplays(); 81 std::vector<gfx::Display> displays = screen->GetAllDisplays();
81 DisplayInfo all_displays; 82 DisplayInfo all_displays;
82 for (int i = 0; i < screen->GetNumDisplays(); ++i) { 83 for (int i = 0; i < screen->GetNumDisplays(); ++i) {
83 linked_ptr<extensions::api::system_display::DisplayUnitInfo> unit( 84 linked_ptr<core_api::system_display::DisplayUnitInfo> unit(
84 CreateDisplayUnitInfo(displays[i], primary_id)); 85 CreateDisplayUnitInfo(displays[i], primary_id));
85 UpdateDisplayUnitInfoForPlatform(displays[i], unit.get()); 86 UpdateDisplayUnitInfoForPlatform(displays[i], unit.get());
86 all_displays.push_back(unit); 87 all_displays.push_back(unit);
87 } 88 }
88 return all_displays; 89 return all_displays;
89 } 90 }
90 91
91 DisplayInfoProvider::DisplayInfoProvider() { 92 DisplayInfoProvider::DisplayInfoProvider() {
92 } 93 }
93 94
94 } // namespace extensions 95 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698