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/constrained_window_frame_simple.h" | 5 #include "chrome/browser/ui/views/constrained_window_frame_simple.h" |
6 | 6 |
7 #include "chrome/browser/ui/constrained_window.h" | 7 #include "chrome/browser/ui/constrained_window.h" |
8 #include "chrome/browser/ui/constrained_window_constants.h" | 8 #include "chrome/browser/ui/constrained_window_constants.h" |
9 #include "chrome/browser/ui/views/constrained_window_views.h" | 9 #include "chrome/browser/ui/views/constrained_window_views.h" |
10 #include "grit/ui_resources.h" | 10 #include "grit/ui_resources.h" |
(...skipping 11 matching lines...) Expand all Loading... | |
22 #include "ui/views/controls/label.h" | 22 #include "ui/views/controls/label.h" |
23 #include "ui/views/controls/button/image_button.h" | 23 #include "ui/views/controls/button/image_button.h" |
24 #include "ui/views/layout/grid_layout.h" | 24 #include "ui/views/layout/grid_layout.h" |
25 #include "ui/views/layout/layout_manager.h" | 25 #include "ui/views/layout/layout_manager.h" |
26 #include "ui/views/layout/layout_constants.h" | 26 #include "ui/views/layout/layout_constants.h" |
27 #include "ui/views/widget/widget.h" | 27 #include "ui/views/widget/widget.h" |
28 #include "ui/views/widget/widget_delegate.h" | 28 #include "ui/views/widget/widget_delegate.h" |
29 | 29 |
30 namespace { | 30 namespace { |
31 | 31 |
32 typedef ConstrainedWindowFrameSimple::HeaderViews HeaderViews; | 32 views::Label* CreateTitleLabel(const string16& title) { |
33 | 33 const int kTitleTopPadding = ConstrainedWindowConstants::kTitleTopPadding - |
34 // A layout manager that lays out the header view with proper padding, | 34 ConstrainedWindowConstants::kCloseButtonPadding; |
Peter Kasting
2012/10/15 21:46:54
Nit: Add a comment about why we subtract kCloseBut
please use gerrit instead
2012/10/16 00:12:23
Inlined the whole thing and added a comment for su
| |
35 // and sized to the widget's client view. | 35 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); |
36 class HeaderLayout : public views::LayoutManager { | 36 views::Label* title_label = new views::Label(title); |
37 public: | 37 title_label->SetHorizontalAlignment(views::Label::ALIGN_LEFT); |
38 explicit HeaderLayout() {} | 38 title_label->SetFont(rb.GetFont(ConstrainedWindowConstants::kTitleFontStyle)); |
39 virtual ~HeaderLayout() {} | 39 title_label->SetEnabledColor(ConstrainedWindow::GetTextColor()); |
40 | 40 title_label->set_border(views::Border::CreateEmptyBorder( |
41 // Overridden from LayoutManager | 41 kTitleTopPadding, 0, 0, 0)); |
42 virtual void Layout(views::View* host); | 42 return title_label; |
43 virtual gfx::Size GetPreferredSize(views::View* host); | |
44 | |
45 DISALLOW_COPY_AND_ASSIGN(HeaderLayout); | |
46 }; | |
47 | |
48 void HeaderLayout::Layout(views::View* host) { | |
49 if (!host->has_children()) | |
50 return; | |
51 | |
52 int top_padding = ConstrainedWindowConstants::kCloseButtonPadding; | |
53 int left_padding = ConstrainedWindowConstants::kHorizontalPadding; | |
54 int right_padding = ConstrainedWindowConstants::kCloseButtonPadding; | |
55 | |
56 views::View* header = host->child_at(0); | |
57 gfx::Size preferred_size = GetPreferredSize(host); | |
58 int width = preferred_size.width() - left_padding - right_padding; | |
59 int height = preferred_size.height() - top_padding; | |
60 | |
61 header->SetBounds(left_padding, top_padding, width, height); | |
62 } | 43 } |
63 | 44 |
64 gfx::Size HeaderLayout::GetPreferredSize(views::View* host) { | 45 views::ImageButton* CreateCloseButton(views::ButtonListener* listener) { |
65 int top_padding = ConstrainedWindowConstants::kCloseButtonPadding; | 46 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); |
66 int left_padding = ConstrainedWindowConstants::kHorizontalPadding; | 47 views::ImageButton* close_button = new views::ImageButton(listener); |
67 int right_padding = ConstrainedWindowConstants::kCloseButtonPadding; | 48 close_button->SetImage(views::CustomButton::BS_NORMAL, |
49 rb.GetImageSkiaNamed(IDR_SHARED_IMAGES_X)); | |
50 close_button->SetImage(views::CustomButton::BS_HOT, | |
51 rb.GetImageSkiaNamed(IDR_SHARED_IMAGES_X_HOVER)); | |
52 close_button->SetImage(views::CustomButton::BS_PUSHED, | |
53 rb.GetImageSkiaNamed(IDR_SHARED_IMAGES_X_PRESSED)); | |
54 return close_button; | |
55 } | |
68 | 56 |
69 views::View* header = host->child_at(0); | 57 views::View* CreateHeader( |
70 gfx::Size header_size = header ? header->GetPreferredSize() : gfx::Size(); | 58 views::View* header_child, |
Peter Kasting
2012/10/15 21:46:54
Nit: Place on previous line, indent next line even
please use gerrit instead
2012/10/16 00:12:23
Not applicable after inlining that you requested.
| |
71 int width = std::max(host->GetPreferredSize().width(), | 59 views::ImageButton* close_button) { |
72 left_padding + header_size.width() + right_padding); | 60 const int kHeaderBottomPadding = 0; |
Peter Kasting
2012/10/15 21:46:54
Nit: I'd just write 0 in the SetInsets() call
please use gerrit instead
2012/10/16 00:12:23
Done.
| |
73 int height = header_size.height() + top_padding; | 61 views::View* header = new views::View(); |
74 | 62 views::GridLayout* header_layout = new views::GridLayout(header); |
75 return gfx::Size(width, height); | 63 header_layout->SetInsets(ConstrainedWindowConstants::kCloseButtonPadding, |
64 ConstrainedWindowConstants::kHorizontalPadding, | |
65 kHeaderBottomPadding, | |
66 ConstrainedWindowConstants::kCloseButtonPadding); | |
67 header->SetLayoutManager(header_layout); | |
68 views::ColumnSet* cs = header_layout->AddColumnSet(0); | |
69 cs->AddColumn(views::GridLayout::FILL, views::GridLayout::CENTER, 1, | |
70 views::GridLayout::USE_PREF, 0, 0); // Title. | |
71 cs->AddPaddingColumn(0, ConstrainedWindowConstants::kCloseButtonPadding); | |
72 cs->AddColumn(views::GridLayout::TRAILING, views::GridLayout::LEADING, 0, | |
73 views::GridLayout::USE_PREF, 0, 0); // Close Button. | |
74 header_layout->StartRow(0, 0); | |
75 header_layout->AddView(header_child); | |
76 header_layout->AddView(close_button); | |
77 header->Layout(); | |
Peter Kasting
2012/10/15 21:46:54
Is this call necessary? Shouldn't this happen aut
please use gerrit instead
2012/10/16 00:12:23
Removed and the UI still works as expected. You're
| |
78 return header; | |
76 } | 79 } |
77 | 80 |
78 } // namespace | 81 } // namespace |
79 | 82 |
80 ConstrainedWindowFrameSimple::HeaderViews::HeaderViews( | |
81 views::View* header, | |
82 views::Label* title_label, | |
83 views::Button* close_button) | |
84 : header(header), | |
85 title_label(title_label), | |
86 close_button(close_button) { | |
87 DCHECK(header); | |
88 } | |
89 | |
90 ConstrainedWindowFrameSimple::ConstrainedWindowFrameSimple( | 83 ConstrainedWindowFrameSimple::ConstrainedWindowFrameSimple( |
91 ConstrainedWindowViews* container) | 84 ConstrainedWindowViews* container) |
92 : container_(container) { | 85 : container_(container), |
86 header_(NULL), | |
87 title_label_(CreateTitleLabel( | |
88 container->widget_delegate()->GetWindowTitle())), | |
89 ALLOW_THIS_IN_INITIALIZER_LIST(close_button_(CreateCloseButton(this))) { | |
93 container_->set_frame_type(views::Widget::FRAME_TYPE_FORCE_CUSTOM); | 90 container_->set_frame_type(views::Widget::FRAME_TYPE_FORCE_CUSTOM); |
94 | 91 |
95 layout_ = new HeaderLayout(); | 92 header_ = CreateHeader(title_label_, close_button_); |
96 SetLayoutManager(layout_); | |
97 | 93 |
98 SetHeaderView(CreateDefaultHeaderView()); | 94 views::GridLayout* layout = new views::GridLayout(this); |
95 SetLayoutManager(layout); | |
96 layout->AddColumnSet(0)->AddColumn( | |
97 views::GridLayout::FILL, views::GridLayout::LEADING, 1, | |
98 views::GridLayout::USE_PREF, 0, 0); | |
99 layout->StartRow(0, 0); | |
100 layout->AddView(header_); | |
101 Layout(); | |
99 | 102 |
100 set_background(views::Background::CreateSolidBackground( | 103 set_background(views::Background::CreateSolidBackground( |
101 ConstrainedWindow::GetBackgroundColor())); | 104 ConstrainedWindow::GetBackgroundColor())); |
102 | |
103 set_border(views::Border::CreateEmptyBorder( | |
104 ConstrainedWindowConstants::kClientTopPadding, | |
105 ConstrainedWindowConstants::kHorizontalPadding, | |
106 ConstrainedWindowConstants::kClientBottomPadding, | |
107 ConstrainedWindowConstants::kHorizontalPadding)); | |
108 } | 105 } |
109 | 106 |
110 ConstrainedWindowFrameSimple::~ConstrainedWindowFrameSimple() { | 107 ConstrainedWindowFrameSimple::~ConstrainedWindowFrameSimple() { |
111 } | 108 } |
112 | 109 |
113 void ConstrainedWindowFrameSimple::SetHeaderView(HeaderViews* header_views) | |
114 { | |
115 RemoveAllChildViews(true); | |
116 | |
117 header_views_.reset(header_views); | |
118 | |
119 AddChildView(header_views_->header); | |
120 } | |
121 | |
122 HeaderViews* ConstrainedWindowFrameSimple::CreateDefaultHeaderView() { | |
123 const int kTitleTopPadding = ConstrainedWindowConstants::kTitleTopPadding - | |
124 ConstrainedWindowConstants::kCloseButtonPadding; | |
125 const int kTitleLeftPadding = 0; | |
126 const int kTitleBottomPadding = 0; | |
127 const int kTitleRightPadding = 0; | |
128 | |
129 views::View* header_view = new views::View; | |
130 | |
131 views::GridLayout* grid_layout = new views::GridLayout(header_view); | |
132 header_view->SetLayoutManager(grid_layout); | |
133 | |
134 views::ColumnSet* header_cs = grid_layout->AddColumnSet(0); | |
135 header_cs->AddColumn(views::GridLayout::CENTER, views::GridLayout::CENTER, 0, | |
136 views::GridLayout::USE_PREF, 0, 0); // Title. | |
137 header_cs->AddPaddingColumn(1, views::kUnrelatedControlHorizontalSpacing); | |
138 header_cs->AddColumn(views::GridLayout::TRAILING, views::GridLayout::LEADING, | |
139 0, views::GridLayout::USE_PREF, 0, 0); // Close Button. | |
140 | |
141 // Header row. | |
142 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); | |
143 grid_layout->StartRow(0, 0); | |
144 | |
145 views::Label* title_label = new views::Label(); | |
146 title_label->SetHorizontalAlignment(views::Label::ALIGN_LEFT); | |
147 title_label->SetFont(rb.GetFont(ConstrainedWindowConstants::kTitleFontStyle)); | |
148 title_label->SetEnabledColor(ConstrainedWindow::GetTextColor()); | |
149 title_label->SetText(container_->widget_delegate()->GetWindowTitle()); | |
150 title_label->set_border(views::Border::CreateEmptyBorder(kTitleTopPadding, | |
151 kTitleLeftPadding, kTitleBottomPadding, kTitleRightPadding)); | |
152 grid_layout->AddView(title_label); | |
153 | |
154 views::Button* close_button = CreateCloseButton(); | |
155 grid_layout->AddView(close_button); | |
156 | |
157 return new HeaderViews(header_view, title_label, close_button); | |
158 } | |
159 | |
160 gfx::Rect ConstrainedWindowFrameSimple::GetBoundsForClientView() const { | 110 gfx::Rect ConstrainedWindowFrameSimple::GetBoundsForClientView() const { |
161 gfx::Rect bounds(GetContentsBounds()); | 111 gfx::Rect bounds(GetContentsBounds()); |
162 if (header_views_->header) | |
163 bounds.Inset(0, header_views_->header->GetPreferredSize().height(), 0, 0); | |
164 return bounds; | 112 return bounds; |
165 } | 113 } |
166 | 114 |
167 gfx::Rect ConstrainedWindowFrameSimple::GetWindowBoundsForClientBounds( | 115 gfx::Rect ConstrainedWindowFrameSimple::GetWindowBoundsForClientBounds( |
168 const gfx::Rect& client_bounds) const { | 116 const gfx::Rect& client_bounds) const { |
169 gfx::Rect bounds(client_bounds); | 117 gfx::Rect bounds(client_bounds); |
170 bounds.Inset(-GetInsets()); | 118 bounds.Inset(-GetInsets()); |
171 if (header_views_->header) | 119 gfx::Size header_size = header_->GetPreferredSize(); |
Peter Kasting
2012/10/15 21:46:54
Nit: Or just inline into next line
please use gerrit instead
2012/10/16 00:12:23
Done.
| |
172 bounds.Inset(0, -header_views_->header->GetPreferredSize().height(), 0, 0); | 120 bounds.set_width(std::max(bounds.width(), header_size.width())); |
173 return bounds; | 121 return bounds; |
174 } | 122 } |
175 | 123 |
176 int ConstrainedWindowFrameSimple::NonClientHitTest(const gfx::Point& point) { | 124 int ConstrainedWindowFrameSimple::NonClientHitTest(const gfx::Point& point) { |
177 if (!bounds().Contains(point)) | 125 if (!bounds().Contains(point)) |
178 return HTNOWHERE; | 126 return HTNOWHERE; |
179 return HTCLIENT; | 127 return HTCLIENT; |
180 } | 128 } |
181 | 129 |
182 void ConstrainedWindowFrameSimple::GetWindowMask(const gfx::Size& size, | 130 void ConstrainedWindowFrameSimple::GetWindowMask(const gfx::Size& size, |
(...skipping 14 matching lines...) Expand all Loading... | |
197 window_mask->addRoundRect(rect, radii); | 145 window_mask->addRoundRect(rect, radii); |
198 } | 146 } |
199 | 147 |
200 void ConstrainedWindowFrameSimple::ResetWindowControls() { | 148 void ConstrainedWindowFrameSimple::ResetWindowControls() { |
201 } | 149 } |
202 | 150 |
203 void ConstrainedWindowFrameSimple::UpdateWindowIcon() { | 151 void ConstrainedWindowFrameSimple::UpdateWindowIcon() { |
204 } | 152 } |
205 | 153 |
206 void ConstrainedWindowFrameSimple::UpdateWindowTitle() { | 154 void ConstrainedWindowFrameSimple::UpdateWindowTitle() { |
207 if (!header_views_->title_label) | 155 if (!title_label_) |
208 return; | 156 return; |
209 | 157 |
210 string16 text = container_->widget_delegate()->GetWindowTitle(); | 158 string16 text = container_->widget_delegate()->GetWindowTitle(); |
211 header_views_->title_label->SetText(text); | 159 title_label_->SetText(text); |
160 } | |
161 | |
162 void ConstrainedWindowFrameSimple::OnBoundsChanged( | |
163 const gfx::Rect& previous_bounds) { | |
164 gfx::Rect header_bounds(header_->bounds()); | |
165 header_bounds.set_width(std::max(header_->width(), bounds().width())); | |
Peter Kasting
2012/10/15 21:46:54
Is it right to use header_->width() instead of hea
please use gerrit instead
2012/10/16 00:12:23
Great catch! I've been looking for a way to resolv
| |
166 header_->SetBounds(header_bounds.x(), header_bounds.y(), | |
167 header_bounds.width(), header_bounds.height()); | |
168 views::NonClientFrameView::OnBoundsChanged(previous_bounds); | |
212 } | 169 } |
213 | 170 |
214 gfx::Size ConstrainedWindowFrameSimple::GetPreferredSize() { | 171 gfx::Size ConstrainedWindowFrameSimple::GetPreferredSize() { |
215 return container_->non_client_view()->GetWindowBoundsForClientBounds( | 172 return GetWindowBoundsForClientBounds( |
216 gfx::Rect(container_->client_view()->GetPreferredSize())).size(); | 173 gfx::Rect(container_->client_view()->GetPreferredSize())).size(); |
217 } | 174 } |
218 | 175 |
219 void ConstrainedWindowFrameSimple::ButtonPressed(views::Button* sender, | 176 void ConstrainedWindowFrameSimple::ButtonPressed( |
Peter Kasting
2012/10/15 21:46:54
Nit: Original wrapping here was fine
please use gerrit instead
2012/10/16 00:12:23
Returned to original wrapping as you requested.
| |
220 const ui::Event& event) { | 177 views::Button* sender, |
221 if (header_views_->close_button && sender == header_views_->close_button) | 178 const ui::Event& event) { |
222 sender->GetWidget()->Close(); | 179 if (close_button_ && sender == close_button_) |
Peter Kasting
2012/10/15 21:46:54
Nit: NULL-checking |close_button_| is presumably n
please use gerrit instead
2012/10/16 00:12:23
Right. Also, |close_button_| should always be non-
| |
180 sender->GetWidget()->Close(); | |
Peter Kasting
2012/10/15 21:46:54
Nit: Indent 2
please use gerrit instead
2012/10/16 00:12:23
Done.
| |
223 } | 181 } |
224 | |
225 views::ImageButton* ConstrainedWindowFrameSimple::CreateCloseButton() { | |
226 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); | |
227 views::ImageButton* close_button = new views::ImageButton(this); | |
228 close_button->SetImage(views::CustomButton::BS_NORMAL, | |
229 rb.GetImageSkiaNamed(IDR_SHARED_IMAGES_X)); | |
230 close_button->SetImage(views::CustomButton::BS_HOT, | |
231 rb.GetImageSkiaNamed(IDR_SHARED_IMAGES_X_HOVER)); | |
232 close_button->SetImage(views::CustomButton::BS_PUSHED, | |
233 rb.GetImageSkiaNamed(IDR_SHARED_IMAGES_X_PRESSED)); | |
234 return close_button; | |
235 } | |
OLD | NEW |