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()) |
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 |