Index: chrome/browser/ui/views/frame/minimize_button_metrics_win.cc |
diff --git a/chrome/browser/ui/views/frame/minimize_button_metrics_win.cc b/chrome/browser/ui/views/frame/minimize_button_metrics_win.cc |
index 986f5e2d855a68e6145e1371767869d93b1a99c3..63c7f8fafb287f6ef6a1f423f0e13051ad585c47 100644 |
--- a/chrome/browser/ui/views/frame/minimize_button_metrics_win.cc |
+++ b/chrome/browser/ui/views/frame/minimize_button_metrics_win.cc |
@@ -2,37 +2,64 @@ |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
-#include "chrome/browser/ui/views/frame/minimize_button_metrics_win.h" |
- |
#include "base/logging.h" |
#include "base/i18n/rtl.h" |
+#include "chrome/browser/ui/views/frame/minimize_button_metrics_win.h" |
+#include "dwmapi.h" |
#include "ui/base/win/shell.h" |
#include "ui/display/win/dpi.h" |
+#include "ui/display/win/screen_win.h" |
kylix_rd
2016/05/03 22:13:12
Pre-submit checks complained about the include ord
|
namespace { |
-int GetMinimizeButtonOffsetForWindow(HWND hwnd) { |
+using display::win::ScreenWin; |
+ |
+int GetMinimizeButtonOffsetForWindow(HWND hwnd, bool was_activated = true) { |
kylix_rd
2016/05/03 22:13:11
TODO: remove default parameter.
|
+ bool dwm_button_pos = false; |
+ POINT minimize_button_corner = { 0 }; |
+ RECT button_bounds = { 0 }; |
+ if (SUCCEEDED(DwmGetWindowAttribute(hwnd, DWMWA_CAPTION_BUTTON_BOUNDS, |
+ reinterpret_cast<PVOID>(&button_bounds), sizeof(button_bounds)))) { |
+ if (button_bounds.left != button_bounds.right) { |
kylix_rd
2016/05/03 22:13:12
If these values are the same (typically 0), then D
|
+ // This converts the button coordinate into screen coordinates |
+ // thus, ensuring that the identity switcher is placed in the |
+ // same location as before. |
+ RECT window_bounds = { 0 }; |
+ if (GetWindowRect(hwnd, reinterpret_cast<LPRECT>(&window_bounds))) |
+ { |
+ minimize_button_corner = |
+ { button_bounds.left + window_bounds.left, 0 }; |
+ dwm_button_pos = true; |
+ } |
+ } |
+ } |
+ if (!dwm_button_pos) { |
kylix_rd
2016/05/03 22:13:11
If for whatever reason, any of the above fails, fa
|
// The WM_GETTITLEBARINFOEX message can fail if we are not active/visible. By |
// fail we get a location of 0; the return status code is always the same and |
// similarly the state never seems to change (titlebar_info.rgstate). |
- TITLEBARINFOEX titlebar_info = {0}; |
- titlebar_info.cbSize = sizeof(TITLEBARINFOEX); |
- SendMessage(hwnd, WM_GETTITLEBARINFOEX, 0, |
- reinterpret_cast<WPARAM>(&titlebar_info)); |
+ TITLEBARINFOEX titlebar_info = { 0 }; |
+ titlebar_info.cbSize = sizeof(TITLEBARINFOEX); |
+ SendMessage(hwnd, WM_GETTITLEBARINFOEX, 0, |
+ reinterpret_cast<WPARAM>(&titlebar_info)); |
- if (titlebar_info.rgrect[2].left == titlebar_info.rgrect[2].right || |
+ if (!was_activated || |
+ titlebar_info.rgrect[2].left == titlebar_info.rgrect[2].right || |
(titlebar_info.rgstate[2] & (STATE_SYSTEM_INVISIBLE | |
- STATE_SYSTEM_OFFSCREEN | |
- STATE_SYSTEM_UNAVAILABLE))) { |
- return 0; |
+ STATE_SYSTEM_OFFSCREEN | |
+ STATE_SYSTEM_UNAVAILABLE))) { |
+ return 0; |
+ } |
+ minimize_button_corner = { titlebar_info.rgrect[2].left, 0 }; |
} |
// WM_GETTITLEBARINFOEX returns rects in screen coordinates in pixels. |
- // We need to convert the minimize button corner offset to DIP before |
- // returning it. |
- POINT minimize_button_corner = { titlebar_info.rgrect[2].left, 0 }; |
+ // DWMNA_CAPTION_BUTTON_BOUNDS is in window (not client) coordinates, |
+ // but it has been converted to screen coordinates above. We need to |
+ // convert the minimize button corner offset to DIP before returning it. |
MapWindowPoints(HWND_DESKTOP, hwnd, &minimize_button_corner, 1); |
- return minimize_button_corner.x / display::win::GetDPIScale(); |
+ gfx::Point pixel_point = { minimize_button_corner.x, 0 }; |
+ gfx::Point dip_point = ScreenWin::ClientToDIPPoint(hwnd, pixel_point); |
+ return dip_point.x(); |
kylix_rd
2016/05/03 22:13:12
From inspecting the code in display::win::ScreenWi
|
} |
} // namespace |
@@ -56,16 +83,16 @@ void MinimizeButtonMetrics::Init(HWND hwnd) { |
void MinimizeButtonMetrics::OnHWNDActivated() { |
was_activated_ = true; |
- // NOTE: we don't cache here as it seems only after the activate is the value |
- // correct. |
+ // NOTE: we don't cache here as it seems only after the activate is the |
+ // value correct. |
} |
int MinimizeButtonMetrics::GetMinimizeButtonOffsetX() const { |
// Under DWM WM_GETTITLEBARINFOEX won't return the right thing until after |
- // WM_NCACTIVATE (maybe it returns classic values?). In an attempt to return a |
- // consistant value we cache the last value across instances and use it until |
- // we get the activate. |
- if (was_activated_ || !ui::win::IsAeroGlassEnabled() || |
+ // WM_NCACTIVATE (maybe it returns classic values?). In an attempt to return |
+ // a consistant value we cache the last value across instances and use it |
+ // until we get the activate. |
kylix_rd
2016/05/03 22:13:12
TODO: update comment
|
+ if (/*was_activated_ || */!ui::win::IsAeroGlassEnabled() || |
kylix_rd
2016/05/03 22:13:12
TODO: cleanup
Always attempt to get the button of
|
cached_minimize_button_x_delta_ == 0) { |
const int minimize_button_offset = GetAndCacheMinimizeButtonOffsetX(); |
if (minimize_button_offset > 0) |
@@ -87,7 +114,8 @@ int MinimizeButtonMetrics::GetMinimizeButtonOffsetX() const { |
} |
int MinimizeButtonMetrics::GetAndCacheMinimizeButtonOffsetX() const { |
- const int minimize_button_offset = GetMinimizeButtonOffsetForWindow(hwnd_); |
+ const int minimize_button_offset = |
+ GetMinimizeButtonOffsetForWindow(hwnd_, was_activated_); |
kylix_rd
2016/05/03 22:13:12
TODO: cleaner way to handle this?
|
if (minimize_button_offset <= 0) |
return 0; |