Chromium Code Reviews| 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 #include "chrome/browser/ui/views/frame/browser_non_client_frame_view.h" | 5 #include "chrome/browser/ui/views/frame/browser_non_client_frame_view.h" |
| 6 | 6 |
| 7 #include "build/build_config.h" | 7 #include "build/build_config.h" |
| 8 #include "chrome/app/vector_icons/vector_icons.h" | 8 #include "chrome/app/vector_icons/vector_icons.h" |
| 9 #include "chrome/browser/browser_process.h" | 9 #include "chrome/browser/browser_process.h" |
| 10 #include "chrome/browser/profiles/avatar_menu.h" | 10 #include "chrome/browser/profiles/avatar_menu.h" |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 64 : ThemeProperties::GetDefaultColor( | 64 : ThemeProperties::GetDefaultColor( |
| 65 color_id, browser_view_->IsIncognito()); | 65 color_id, browser_view_->IsIncognito()); |
| 66 } | 66 } |
| 67 | 67 |
| 68 views::View* BrowserNonClientFrameView::GetProfileSwitcherView() const { | 68 views::View* BrowserNonClientFrameView::GetProfileSwitcherView() const { |
| 69 return nullptr; | 69 return nullptr; |
| 70 } | 70 } |
| 71 | 71 |
| 72 void BrowserNonClientFrameView::UpdateClientArea() {} | 72 void BrowserNonClientFrameView::UpdateClientArea() {} |
| 73 | 73 |
| 74 void BrowserNonClientFrameView::ChildPreferredSizeChanged(views::View* child) { | |
| 75 if (child == GetProfileSwitcherView()) { | |
| 76 // Need to layout the root view here, too, as the avatar button may change | |
|
Peter Kasting
2017/05/22 18:44:14
Nit: Not clear what "here, too," means in this con
Evan Stade
2017/05/22 20:32:48
Done.
| |
| 77 // between the text and the icon when a profile is added or removed, which | |
| 78 // changes its width. This may cause it to start or stop overlapping the | |
| 79 // the tabstrip horizontally, which in turn causes it to change height, as | |
| 80 // calculated in LayoutProfileSwitcher(). Calling LayoutProfileSwitcher() | |
|
Peter Kasting
2017/05/22 18:44:15
Nit: LayoutProfileSwitcher() is not a member of th
Evan Stade
2017/05/22 20:32:48
I replaced this comment with the one we used to ha
| |
| 81 // is not enough here - it does not re-draw the line below the tabstrip | |
| 82 // properly when a profile is added or removed. Even adding | |
| 83 // browser_view()->tabstrip()->Layout() and SchedulePaint() is not enough. | |
| 84 // TODO(bsep): Figure out the most efficient way to do this. | |
| 85 frame()->GetRootView()->Layout(); | |
| 86 } | |
| 87 } | |
| 88 | |
| 74 void BrowserNonClientFrameView::VisibilityChanged(views::View* starting_from, | 89 void BrowserNonClientFrameView::VisibilityChanged(views::View* starting_from, |
| 75 bool is_visible) { | 90 bool is_visible) { |
| 76 // UpdateTaskbarDecoration() calls DrawTaskbarDecoration(), but that does | 91 // UpdateTaskbarDecoration() calls DrawTaskbarDecoration(), but that does |
| 77 // nothing if the window is not visible. So even if we've already gotten the | 92 // nothing if the window is not visible. So even if we've already gotten the |
| 78 // up-to-date decoration, we need to run the update procedure again here when | 93 // up-to-date decoration, we need to run the update procedure again here when |
| 79 // the window becomes visible. | 94 // the window becomes visible. |
| 80 if (is_visible) | 95 if (is_visible) |
| 81 OnProfileAvatarChanged(base::FilePath()); | 96 OnProfileAvatarChanged(base::FilePath()); |
| 82 } | 97 } |
| 83 | 98 |
| (...skipping 187 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 271 // safety. See crbug.com/313800. | 286 // safety. See crbug.com/313800. |
| 272 gfx::Image decoration; | 287 gfx::Image decoration; |
| 273 AvatarMenu::GetImageForMenuButton( | 288 AvatarMenu::GetImageForMenuButton( |
| 274 browser_view()->browser()->profile()->GetPath(), &decoration); | 289 browser_view()->browser()->profile()->GetPath(), &decoration); |
| 275 // This can happen if the user deletes the current profile. | 290 // This can happen if the user deletes the current profile. |
| 276 if (decoration.IsEmpty()) | 291 if (decoration.IsEmpty()) |
| 277 return; | 292 return; |
| 278 chrome::DrawTaskbarDecoration(frame_->GetNativeWindow(), &decoration); | 293 chrome::DrawTaskbarDecoration(frame_->GetNativeWindow(), &decoration); |
| 279 #endif | 294 #endif |
| 280 } | 295 } |
| OLD | NEW |