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 #ifndef UI_VIEWS_WINDOW_CUSTOM_FRAME_VIEW_H_ | 5 #ifndef UI_VIEWS_WINDOW_CUSTOM_FRAME_VIEW_H_ |
| 6 #define UI_VIEWS_WINDOW_CUSTOM_FRAME_VIEW_H_ | 6 #define UI_VIEWS_WINDOW_CUSTOM_FRAME_VIEW_H_ |
| 7 | 7 |
| 8 #include "base/basictypes.h" | 8 #include "base/basictypes.h" |
| 9 #include "base/compiler_specific.h" | 9 #include "base/compiler_specific.h" |
| 10 #include "base/memory/scoped_ptr.h" | 10 #include "base/memory/scoped_ptr.h" |
| 11 #include "ui/views/controls/button/button.h" | 11 #include "ui/views/controls/button/button.h" |
| 12 #include "ui/views/window/frame_buttons.h" | |
| 12 #include "ui/views/window/non_client_view.h" | 13 #include "ui/views/window/non_client_view.h" |
| 13 | 14 |
| 14 namespace gfx { | 15 namespace gfx { |
| 15 class ImageSkia; | 16 class ImageSkia; |
| 16 } | 17 } |
| 17 | 18 |
| 18 namespace views { | 19 namespace views { |
| 19 | 20 |
| 20 class FrameBackground; | 21 class FrameBackground; |
| 21 class ImageButton; | 22 class ImageButton; |
| 22 class Widget; | 23 class Widget; |
| 23 | 24 |
| 24 /////////////////////////////////////////////////////////////////////////////// | 25 /////////////////////////////////////////////////////////////////////////////// |
| 25 // | 26 // |
| 26 // CustomFrameView | 27 // CustomFrameView |
| 27 // | 28 // |
| 28 // A view that provides the non client frame for Windows. This means | 29 // A view that provides the non client frame for Windows. This means |
| 29 // rendering the non-standard window caption, border, and controls. | 30 // rendering the non-standard window caption, border, and controls. |
| 30 // | 31 // |
| 31 //////////////////////////////////////////////////////////////////////////////// | 32 //////////////////////////////////////////////////////////////////////////////// |
| 32 class CustomFrameView : public NonClientFrameView, | 33 class VIEWS_EXPORT CustomFrameView : public NonClientFrameView, |
| 33 public ButtonListener { | 34 public ButtonListener { |
| 34 public: | 35 public: |
| 35 CustomFrameView(); | 36 CustomFrameView(); |
| 36 virtual ~CustomFrameView(); | 37 virtual ~CustomFrameView(); |
| 37 | 38 |
| 38 void Init(Widget* frame); | 39 void Init(Widget* frame); |
| 39 | 40 |
| 40 // Overridden from NonClientFrameView: | 41 // Overridden from NonClientFrameView: |
| 41 virtual gfx::Rect GetBoundsForClientView() const OVERRIDE; | 42 virtual gfx::Rect GetBoundsForClientView() const OVERRIDE; |
| 42 virtual gfx::Rect GetWindowBoundsForClientBounds( | 43 virtual gfx::Rect GetWindowBoundsForClientBounds( |
| 43 const gfx::Rect& client_bounds) const OVERRIDE; | 44 const gfx::Rect& client_bounds) const OVERRIDE; |
| 44 virtual int NonClientHitTest(const gfx::Point& point) OVERRIDE; | 45 virtual int NonClientHitTest(const gfx::Point& point) OVERRIDE; |
| 45 virtual void GetWindowMask(const gfx::Size& size, | 46 virtual void GetWindowMask(const gfx::Size& size, |
| 46 gfx::Path* window_mask) OVERRIDE; | 47 gfx::Path* window_mask) OVERRIDE; |
| 47 virtual void ResetWindowControls() OVERRIDE; | 48 virtual void ResetWindowControls() OVERRIDE; |
| 48 virtual void UpdateWindowIcon() OVERRIDE; | 49 virtual void UpdateWindowIcon() OVERRIDE; |
| 49 virtual void UpdateWindowTitle() OVERRIDE; | 50 virtual void UpdateWindowTitle() OVERRIDE; |
| 50 | 51 |
| 51 // Overridden from View: | 52 // Overridden from View: |
| 52 virtual void OnPaint(gfx::Canvas* canvas) OVERRIDE; | 53 virtual void OnPaint(gfx::Canvas* canvas) OVERRIDE; |
| 53 virtual void Layout() OVERRIDE; | 54 virtual void Layout() OVERRIDE; |
| 54 virtual gfx::Size GetPreferredSize() OVERRIDE; | 55 virtual gfx::Size GetPreferredSize() OVERRIDE; |
| 55 virtual gfx::Size GetMinimumSize() OVERRIDE; | 56 virtual gfx::Size GetMinimumSize() OVERRIDE; |
| 56 virtual gfx::Size GetMaximumSize() OVERRIDE; | 57 virtual gfx::Size GetMaximumSize() OVERRIDE; |
| 57 | 58 |
| 58 // Overridden from ButtonListener: | 59 // Overridden from ButtonListener: |
| 59 virtual void ButtonPressed(Button* sender, const ui::Event& event) OVERRIDE; | 60 virtual void ButtonPressed(Button* sender, const ui::Event& event) OVERRIDE; |
| 60 | 61 |
| 61 private: | 62 private: |
| 63 friend class CustomFrameViewTest; | |
| 64 | |
| 62 // Returns the thickness of the border that makes up the window frame edges. | 65 // Returns the thickness of the border that makes up the window frame edges. |
| 63 // This does not include any client edge. | 66 // This does not include any client edge. |
| 64 int FrameBorderThickness() const; | 67 int FrameBorderThickness() const; |
| 65 | 68 |
| 66 // Returns the thickness of the entire nonclient left, right, and bottom | 69 // Returns the thickness of the entire nonclient left, right, and bottom |
| 67 // borders, including both the window frame and any client edge. | 70 // borders, including both the window frame and any client edge. |
| 68 int NonClientBorderThickness() const; | 71 int NonClientBorderThickness() const; |
| 69 | 72 |
| 70 // Returns the height of the entire nonclient top border, including the window | 73 // Returns the height of the entire nonclient top border, including the window |
| 71 // frame, any title area, and any connected client edge. | 74 // frame, any title area, and any connected client edge. |
| (...skipping 25 matching lines...) Expand all Loading... | |
| 97 // Paint various sub-components of this view. | 100 // Paint various sub-components of this view. |
| 98 void PaintRestoredFrameBorder(gfx::Canvas* canvas); | 101 void PaintRestoredFrameBorder(gfx::Canvas* canvas); |
| 99 void PaintMaximizedFrameBorder(gfx::Canvas* canvas); | 102 void PaintMaximizedFrameBorder(gfx::Canvas* canvas); |
| 100 void PaintTitleBar(gfx::Canvas* canvas); | 103 void PaintTitleBar(gfx::Canvas* canvas); |
| 101 void PaintRestoredClientEdge(gfx::Canvas* canvas); | 104 void PaintRestoredClientEdge(gfx::Canvas* canvas); |
| 102 | 105 |
| 103 // Compute aspects of the frame needed to paint the frame background. | 106 // Compute aspects of the frame needed to paint the frame background. |
| 104 SkColor GetFrameColor() const; | 107 SkColor GetFrameColor() const; |
| 105 const gfx::ImageSkia* GetFrameImage() const; | 108 const gfx::ImageSkia* GetFrameImage() const; |
| 106 | 109 |
| 107 // Layout various sub-components of this view. | 110 // Performs the layout for the window control buttons based on the |
| 111 // configuration specified in |leading_buttons_| and |trailing_buttons_|. | |
| 112 // The sizing and positions of the buttons affects LayoutTitleBar, call | |
| 113 // this beforehand. | |
|
varkha
2014/05/15 23:33:18
|leading_buttons_| and |trailing_buttons_| are not
jonross
2014/05/16 18:59:48
Done.
| |
| 108 void LayoutWindowControls(); | 114 void LayoutWindowControls(); |
| 115 | |
| 116 // Calculations depend on the positions of the window controls. Always call | |
| 117 // LayoutWindowControls beforehand. | |
| 109 void LayoutTitleBar(); | 118 void LayoutTitleBar(); |
| 110 void LayoutClientView(); | 119 void LayoutClientView(); |
| 111 | 120 |
| 112 // Creates, adds and returns a new window caption button (e.g, minimize, | 121 // Creates, adds and returns a new window caption button (e.g, minimize, |
| 113 // maximize, restore). | 122 // maximize, restore). |
| 114 ImageButton* InitWindowCaptionButton(int accessibility_string_id, | 123 ImageButton* InitWindowCaptionButton(int accessibility_string_id, |
| 115 int normal_image_id, | 124 int normal_image_id, |
| 116 int hot_image_id, | 125 int hot_image_id, |
| 117 int pushed_image_id); | 126 int pushed_image_id); |
| 118 | 127 |
| 128 // Returns the window caption button for the given FrameButton type, if it | |
| 129 // should be visible. Otherwise NULL. | |
| 130 ImageButton* GetImageButton(views::FrameButton button); | |
| 131 | |
| 119 // The bounds of the client view, in this view's coordinates. | 132 // The bounds of the client view, in this view's coordinates. |
| 120 gfx::Rect client_view_bounds_; | 133 gfx::Rect client_view_bounds_; |
| 121 | 134 |
| 122 // The layout rect of the title, if visible. | 135 // The layout rect of the title, if visible. |
| 123 gfx::Rect title_bounds_; | 136 gfx::Rect title_bounds_; |
| 124 | 137 |
| 125 // Not owned. | 138 // Not owned. |
| 126 Widget* frame_; | 139 Widget* frame_; |
| 127 | 140 |
| 128 // The icon of this window. May be NULL. | 141 // The icon of this window. May be NULL. |
| 129 ImageButton* window_icon_; | 142 ImageButton* window_icon_; |
| 130 | 143 |
| 131 // Window caption buttons. | 144 // Window caption buttons. |
| 132 ImageButton* minimize_button_; | 145 ImageButton* minimize_button_; |
| 133 ImageButton* maximize_button_; | 146 ImageButton* maximize_button_; |
| 134 ImageButton* restore_button_; | 147 ImageButton* restore_button_; |
| 135 ImageButton* close_button_; | 148 ImageButton* close_button_; |
| 136 | 149 |
| 137 // Should maximize button be shown? | 150 // Should maximize button be shown? |
| 138 bool should_show_maximize_button_; | 151 bool should_show_maximize_button_; |
| 139 | 152 |
| 140 // Background painter for the window frame. | 153 // Background painter for the window frame. |
| 141 scoped_ptr<FrameBackground> frame_background_; | 154 scoped_ptr<FrameBackground> frame_background_; |
| 142 | 155 |
| 156 // The horizontal boundaries for the title bar to layout within. Restricted | |
| 157 // by the space used by the leading and trailing buttons. | |
| 158 int minimum_title_bar_x_; | |
| 159 int maximum_title_bar_x_; | |
| 160 | |
| 143 DISALLOW_COPY_AND_ASSIGN(CustomFrameView); | 161 DISALLOW_COPY_AND_ASSIGN(CustomFrameView); |
| 144 }; | 162 }; |
| 145 | 163 |
| 146 } // namespace views | 164 } // namespace views |
| 147 | 165 |
| 148 #endif // UI_VIEWS_WINDOW_CUSTOM_FRAME_VIEW_H_ | 166 #endif // UI_VIEWS_WINDOW_CUSTOM_FRAME_VIEW_H_ |
| OLD | NEW |