OLD | NEW |
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 #ifndef UI_GFX_DPI_WIN_H_ | 5 #ifndef UI_GFX_DPI_WIN_H_ |
6 #define UI_GFX_DPI_WIN_H_ | 6 #define UI_GFX_DPI_WIN_H_ |
7 | 7 |
8 #include "ui/gfx/geometry/point.h" | 8 #include "ui/gfx/geometry/point.h" |
9 #include "ui/gfx/geometry/rect.h" | 9 #include "ui/gfx/geometry/rect.h" |
10 #include "ui/gfx/geometry/size.h" | 10 #include "ui/gfx/geometry/size.h" |
11 #include "ui/gfx/gfx_export.h" | 11 #include "ui/gfx/gfx_export.h" |
12 | 12 |
13 namespace gfx { | 13 namespace gfx { |
14 | 14 |
15 // Sets the device scale factor that will be used unless overridden on the | 15 // Sets the device scale factor that will be used unless overridden on the |
16 // command line by --force-device-scale-factor. If this is not called, and that | 16 // command line by --force-device-scale-factor. If this is not called, and that |
17 // flag is not used, the scale factor used by the DIP conversion functions below | 17 // flag is not used, the scale factor used by the DIP conversion functions below |
18 // will be that returned by GetDPIScale(). | 18 // will be that returned by GetDPIScale(). |
19 GFX_EXPORT void SetDefaultDeviceScaleFactor(float scale); | 19 GFX_EXPORT void SetDefaultDeviceScaleFactor(float scale); |
20 | 20 |
21 GFX_EXPORT Size GetDPI(); | 21 GFX_EXPORT int GetDPIFromScalingFactor(float device_scaling_factor); |
22 | 22 |
23 // Gets the scale factor of the display. For example, if the display DPI is | 23 // Gets the scale factor of the display. For example, if the display DPI is |
24 // 96 then the scale factor is 1.0. This clamps scale factors <= 1.25 to 1.0 to | 24 // 96 then the scale factor is 1.0. This clamps scale factors <= 1.25 to 1.0 to |
25 // maintain previous (non-DPI-aware) behavior where only the font size was | 25 // maintain previous (non-DPI-aware) behavior where only the font size was |
26 // boosted. | 26 // boosted. |
27 GFX_EXPORT float GetDPIScale(); | 27 GFX_EXPORT float GetDPIScale(); |
28 | 28 |
29 namespace win { | 29 namespace win { |
30 | 30 |
31 GFX_EXPORT Point ScreenToDIPPoint(const Point& pixel_point); | |
32 | |
33 GFX_EXPORT Point DIPToScreenPoint(const Point& dip_point); | |
34 | |
35 // WARNING: there is no right way to scale sizes and rects. The implementation | |
36 // of these strives to maintain a constant size by scaling the size independent | |
37 // of the origin. An alternative is to get the enclosing rect, which is the | |
38 // right way for some situations. Understand which you need before blindly | |
39 // assuming this is the right way. | |
40 GFX_EXPORT Rect ScreenToDIPRect(const Rect& pixel_bounds); | |
41 GFX_EXPORT Rect DIPToScreenRect(const Rect& dip_bounds); | |
42 GFX_EXPORT Size ScreenToDIPSize(const Size& size_in_pixels); | |
43 GFX_EXPORT Size DIPToScreenSize(const Size& dip_size); | |
44 | |
45 // Win32's GetSystemMetrics uses pixel measures. This function calls | 31 // Win32's GetSystemMetrics uses pixel measures. This function calls |
46 // GetSystemMetrics for the given |metric|, then converts the result to DIP. | 32 // GetSystemMetrics for the given |metric|, then converts the result to DIP. |
47 GFX_EXPORT int GetSystemMetricsInDIP(int metric); | 33 GFX_EXPORT int GetSystemMetricsInDIP(int metric); |
48 | 34 |
49 } // namespace win | 35 } // namespace win |
50 } // namespace gfx | 36 } // namespace gfx |
51 | 37 |
52 #endif // UI_GFX_DPI_WIN_H_ | 38 #endif // UI_GFX_DPI_WIN_H_ |
OLD | NEW |