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

Side by Side Diff: chrome/browser/extensions/display_info_provider_chromeos.cc

Issue 1289043002: Hookup device dpi for ChromeOS (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: review Created 5 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 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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/display_info_provider_chromeos.h" 5 #include "chrome/browser/extensions/display_info_provider_chromeos.h"
6 6
7 #include "ash/display/display_manager.h" 7 #include "ash/display/display_manager.h"
8 #include "ash/display/window_tree_host_manager.h" 8 #include "ash/display/window_tree_host_manager.h"
9 #include "ash/shell.h" 9 #include "ash/shell.h"
10 #include "base/strings/string_number_conversions.h" 10 #include "base/strings/string_number_conversions.h"
(...skipping 348 matching lines...) Expand 10 before | Expand all | Expand 10 after
359 const gfx::Display& display, 359 const gfx::Display& display,
360 extensions::api::system_display::DisplayUnitInfo* unit) { 360 extensions::api::system_display::DisplayUnitInfo* unit) {
361 ash::DisplayManager* display_manager = 361 ash::DisplayManager* display_manager =
362 ash::Shell::GetInstance()->display_manager(); 362 ash::Shell::GetInstance()->display_manager();
363 unit->name = display_manager->GetDisplayNameForId(display.id()); 363 unit->name = display_manager->GetDisplayNameForId(display.id());
364 if (display_manager->IsInMirrorMode()) { 364 if (display_manager->IsInMirrorMode()) {
365 unit->mirroring_source_id = 365 unit->mirroring_source_id =
366 base::Int64ToString(display_manager->mirroring_display_id()); 366 base::Int64ToString(display_manager->mirroring_display_id());
367 } 367 }
368 368
369 // TODO(hshi): determine the DPI of the screen. 369 const ash::DisplayInfo& display_info =
370 const float kDpi96 = 96.0; 370 display_manager->GetDisplayInfo(display.id());
371 371 const float device_dpi = display_info.device_dpi();
372 const float dpi = display.device_scale_factor() * kDpi96; 372 unit->dpi_x = device_dpi * display.size().width() /
373 unit->dpi_x = dpi; 373 display_info.bounds_in_native().width();
374 unit->dpi_y = dpi; 374 unit->dpi_y = device_dpi * display.size().height() /
375 display_info.bounds_in_native().height();
375 376
376 const gfx::Insets overscan_insets = 377 const gfx::Insets overscan_insets =
377 display_manager->GetOverscanInsets(display.id()); 378 display_manager->GetOverscanInsets(display.id());
378 unit->overscan.left = overscan_insets.left(); 379 unit->overscan.left = overscan_insets.left();
379 unit->overscan.top = overscan_insets.top(); 380 unit->overscan.top = overscan_insets.top();
380 unit->overscan.right = overscan_insets.right(); 381 unit->overscan.right = overscan_insets.right();
381 unit->overscan.bottom = overscan_insets.bottom(); 382 unit->overscan.bottom = overscan_insets.bottom();
382 } 383 }
383 384
384 gfx::Screen* DisplayInfoProviderChromeOS::GetActiveScreen() { 385 gfx::Screen* DisplayInfoProviderChromeOS::GetActiveScreen() {
385 return ash::Shell::GetScreen(); 386 return ash::Shell::GetScreen();
386 } 387 }
387 388
388 void DisplayInfoProviderChromeOS::EnableUnifiedDesktop(bool enable) { 389 void DisplayInfoProviderChromeOS::EnableUnifiedDesktop(bool enable) {
389 ash::Shell::GetInstance()->display_manager()->SetUnifiedDesktopEnabled( 390 ash::Shell::GetInstance()->display_manager()->SetUnifiedDesktopEnabled(
390 enable); 391 enable);
391 } 392 }
392 393
393 // static 394 // static
394 DisplayInfoProvider* DisplayInfoProvider::Create() { 395 DisplayInfoProvider* DisplayInfoProvider::Create() {
395 return new DisplayInfoProviderChromeOS(); 396 return new DisplayInfoProviderChromeOS();
396 } 397 }
397 398
398 } // namespace extensions 399 } // namespace extensions
OLDNEW
« no previous file with comments | « ash/display/display_info.cc ('k') | chrome/browser/extensions/display_info_provider_chromeos_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698