Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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_mus.h" | 5 #include "chrome/browser/ui/views/frame/browser_non_client_frame_view_mus.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 | 8 |
| 9 #include "chrome/browser/profiles/profiles_state.h" | 9 #include "chrome/browser/profiles/profiles_state.h" |
| 10 #include "chrome/browser/themes/theme_properties.h" | 10 #include "chrome/browser/themes/theme_properties.h" |
| 11 #include "chrome/browser/ui/browser.h" | 11 #include "chrome/browser/ui/browser.h" |
| 12 #include "chrome/browser/ui/layout_constants.h" | 12 #include "chrome/browser/ui/layout_constants.h" |
| 13 #include "chrome/browser/ui/views/frame/browser_frame.h" | 13 #include "chrome/browser/ui/views/frame/browser_frame.h" |
| 14 #include "chrome/browser/ui/views/frame/browser_frame_mus.h" | 14 #include "chrome/browser/ui/views/frame/browser_frame_mus.h" |
| 15 #include "chrome/browser/ui/views/frame/browser_header_painter_ash.h" | 15 #include "chrome/browser/ui/views/frame/browser_header_painter_ash.h" |
| 16 #include "chrome/browser/ui/views/frame/browser_view.h" | 16 #include "chrome/browser/ui/views/frame/browser_view.h" |
| 17 #include "chrome/browser/ui/views/frame/immersive_mode_controller.h" | 17 #include "chrome/browser/ui/views/frame/immersive_mode_controller.h" |
| 18 #include "chrome/browser/ui/views/frame/web_app_left_header_view_ash.h" | 18 #include "chrome/browser/ui/views/frame/web_app_left_header_view_ash.h" |
| 19 #include "chrome/browser/ui/views/profiles/profile_indicator_icon.h" | 19 #include "chrome/browser/ui/views/profiles/profile_indicator_icon.h" |
| 20 #include "chrome/browser/ui/views/tab_icon_view.h" | 20 #include "chrome/browser/ui/views/tab_icon_view.h" |
| 21 #include "chrome/browser/ui/views/tabs/tab_strip.h" | 21 #include "chrome/browser/ui/views/tabs/tab_strip.h" |
| 22 #include "chrome/browser/web_applications/web_app.h" | 22 #include "chrome/browser/web_applications/web_app.h" |
| 23 #include "chrome/grit/theme_resources.h" | 23 #include "chrome/grit/theme_resources.h" |
| 24 #include "content/public/browser/web_contents.h" | 24 #include "content/public/browser/web_contents.h" |
| 25 #include "services/ui/public/cpp/window.h" | |
| 26 #include "ui/accessibility/ax_node_data.h" | 25 #include "ui/accessibility/ax_node_data.h" |
| 27 #include "ui/aura/client/aura_constants.h" | 26 #include "ui/aura/client/aura_constants.h" |
| 28 #include "ui/aura/window.h" | 27 #include "ui/aura/window.h" |
| 29 #include "ui/base/hit_test.h" | 28 #include "ui/base/hit_test.h" |
| 30 #include "ui/base/layout.h" | 29 #include "ui/base/layout.h" |
| 31 #include "ui/base/theme_provider.h" | 30 #include "ui/base/theme_provider.h" |
| 32 #include "ui/compositor/layer_animator.h" | 31 #include "ui/compositor/layer_animator.h" |
| 33 #include "ui/gfx/canvas.h" | 32 #include "ui/gfx/canvas.h" |
| 34 #include "ui/gfx/geometry/rect_conversions.h" | 33 #include "ui/gfx/geometry/rect_conversions.h" |
| 35 #include "ui/gfx/image/image_skia.h" | 34 #include "ui/gfx/image/image_skia.h" |
| 36 #include "ui/gfx/scoped_canvas.h" | 35 #include "ui/gfx/scoped_canvas.h" |
| 37 #include "ui/views/controls/label.h" | 36 #include "ui/views/controls/label.h" |
| 38 #include "ui/views/layout/layout_constants.h" | 37 #include "ui/views/layout/layout_constants.h" |
| 38 #include "ui/views/mus/desktop_window_tree_host_mus.h" | |
| 39 #include "ui/views/mus/window_manager_frame_values.h" | 39 #include "ui/views/mus/window_manager_frame_values.h" |
| 40 #include "ui/views/widget/widget.h" | 40 #include "ui/views/widget/widget.h" |
| 41 #include "ui/views/widget/widget_delegate.h" | 41 #include "ui/views/widget/widget_delegate.h" |
| 42 | 42 |
| 43 #if !defined(OS_CHROMEOS) | 43 #if !defined(OS_CHROMEOS) |
| 44 #define FRAME_AVATAR_BUTTON | 44 #define FRAME_AVATAR_BUTTON |
| 45 #endif | 45 #endif |
| 46 | 46 |
| 47 namespace { | 47 namespace { |
| 48 | 48 |
| (...skipping 277 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 326 if (!delegate) | 326 if (!delegate) |
| 327 return gfx::ImageSkia(); | 327 return gfx::ImageSkia(); |
| 328 return delegate->GetWindowIcon(); | 328 return delegate->GetWindowIcon(); |
| 329 } | 329 } |
| 330 /////////////////////////////////////////////////////////////////////////////// | 330 /////////////////////////////////////////////////////////////////////////////// |
| 331 // BrowserNonClientFrameViewMus, protected: | 331 // BrowserNonClientFrameViewMus, protected: |
| 332 | 332 |
| 333 // BrowserNonClientFrameView: | 333 // BrowserNonClientFrameView: |
| 334 void BrowserNonClientFrameViewMus::UpdateProfileIcons() { | 334 void BrowserNonClientFrameViewMus::UpdateProfileIcons() { |
| 335 #if defined(FRAME_AVATAR_BUTTON) | 335 #if defined(FRAME_AVATAR_BUTTON) |
| 336 if (browser_view()->IsRegularOrGuestSession()) | 336 if (browser_view()->IsRegularOrGuestSession()) { |
| 337 profile_switcher_.Update(AvatarButtonStyle::NATIVE); | 337 profile_switcher_.Update(AvatarButtonStyle::NATIVE); |
| 338 else | 338 return; |
| 339 } | |
| 339 #endif | 340 #endif |
| 340 UpdateProfileIndicatorIcon(); | 341 UpdateProfileIndicatorIcon(); |
| 341 } | 342 } |
| 342 | 343 |
| 343 /////////////////////////////////////////////////////////////////////////////// | 344 /////////////////////////////////////////////////////////////////////////////// |
| 344 // BrowserNonClientFrameViewMus, private: | 345 // BrowserNonClientFrameViewMus, private: |
| 345 | 346 |
| 346 ui::Window* BrowserNonClientFrameViewMus::mus_window() { | |
| 347 return static_cast<BrowserFrameMus*>(frame()->native_widget())->window(); | |
| 348 } | |
| 349 | |
| 350 void BrowserNonClientFrameViewMus::UpdateClientArea() { | 347 void BrowserNonClientFrameViewMus::UpdateClientArea() { |
| 351 std::vector<gfx::Rect> additional_client_area; | 348 std::vector<gfx::Rect> additional_client_area; |
| 352 if (tab_strip_) { | 349 if (tab_strip_) { |
| 353 gfx::Rect tab_strip_bounds(GetBoundsForTabStrip(tab_strip_)); | 350 gfx::Rect tab_strip_bounds(GetBoundsForTabStrip(tab_strip_)); |
| 354 if (!tab_strip_bounds.IsEmpty() && tab_strip_->max_x()) { | 351 if (!tab_strip_bounds.IsEmpty() && tab_strip_->max_x()) { |
| 355 tab_strip_bounds.set_width(tab_strip_->max_x()); | 352 tab_strip_bounds.set_width(tab_strip_->max_x()); |
| 356 additional_client_area.push_back(tab_strip_bounds); | 353 additional_client_area.push_back(tab_strip_bounds); |
| 357 } | 354 } |
| 358 } | 355 } |
| 359 mus_window()->SetClientArea( | 356 static_cast<aura::WindowTreeHostMus*>( |
| 360 views::WindowManagerFrameValues::instance().normal_insets, | 357 GetWidget()->GetNativeWindow()->GetHost()) |
|
sadrul
2016/12/16 02:17:48
We are using this static-cast in a few places. May
sky
2016/12/16 03:51:50
I'm hesitant to do that because it's generally not
| |
| 361 additional_client_area); | 358 ->SetClientArea(views::WindowManagerFrameValues::instance().normal_insets, |
| 359 additional_client_area); | |
| 362 } | 360 } |
| 363 | 361 |
| 364 void BrowserNonClientFrameViewMus::TabStripMaxXChanged(TabStrip* tab_strip) { | 362 void BrowserNonClientFrameViewMus::TabStripMaxXChanged(TabStrip* tab_strip) { |
| 365 UpdateClientArea(); | 363 UpdateClientArea(); |
| 366 } | 364 } |
| 367 | 365 |
| 368 void BrowserNonClientFrameViewMus::TabStripDeleted(TabStrip* tab_strip) { | 366 void BrowserNonClientFrameViewMus::TabStripDeleted(TabStrip* tab_strip) { |
| 369 tab_strip_->RemoveObserver(this); | 367 tab_strip_->RemoveObserver(this); |
| 370 tab_strip_ = nullptr; | 368 tab_strip_ = nullptr; |
| 371 } | 369 } |
| (...skipping 136 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 508 } | 506 } |
| 509 | 507 |
| 510 void BrowserNonClientFrameViewMus::PaintContentEdge(gfx::Canvas* canvas) { | 508 void BrowserNonClientFrameViewMus::PaintContentEdge(gfx::Canvas* canvas) { |
| 511 DCHECK(!UsePackagedAppHeaderStyle() && !UseWebAppHeaderStyle()); | 509 DCHECK(!UsePackagedAppHeaderStyle() && !UseWebAppHeaderStyle()); |
| 512 const int bottom = frame_values().normal_insets.bottom(); | 510 const int bottom = frame_values().normal_insets.bottom(); |
| 513 canvas->FillRect( | 511 canvas->FillRect( |
| 514 gfx::Rect(0, bottom, width(), kClientEdgeThickness), | 512 gfx::Rect(0, bottom, width(), kClientEdgeThickness), |
| 515 GetThemeProvider()->GetColor( | 513 GetThemeProvider()->GetColor( |
| 516 ThemeProperties::COLOR_TOOLBAR_BOTTOM_SEPARATOR)); | 514 ThemeProperties::COLOR_TOOLBAR_BOTTOM_SEPARATOR)); |
| 517 } | 515 } |
| OLD | NEW |