| Index: chrome/browser/ui/views/constrained_window_frame_simple.cc
|
| diff --git a/chrome/browser/ui/views/constrained_window_frame_simple.cc b/chrome/browser/ui/views/constrained_window_frame_simple.cc
|
| index e17297de7c379e249b5bcba787b05a35c3060276..cd8cce684b485da8a5a11408988269b4c35fe58b 100644
|
| --- a/chrome/browser/ui/views/constrained_window_frame_simple.cc
|
| +++ b/chrome/browser/ui/views/constrained_window_frame_simple.cc
|
| @@ -4,24 +4,181 @@
|
|
|
| #include "chrome/browser/ui/views/constrained_window_frame_simple.h"
|
|
|
| +#include "chrome/browser/ui/constrained_window.h"
|
| #include "chrome/browser/ui/views/constrained_window_views.h"
|
| +#include "grit/ui_resources.h"
|
| +#include "grit/chromium_strings.h"
|
| +#include "grit/generated_resources.h"
|
| +#include "grit/google_chrome_strings.h"
|
| +#include "grit/shared_resources.h"
|
| +#include "grit/theme_resources.h"
|
| #include "ui/base/hit_test.h"
|
| +#include "ui/base/resource/resource_bundle.h"
|
| +#include "ui/gfx/canvas.h"
|
| #include "ui/gfx/rect.h"
|
| +#include "ui/gfx/path.h"
|
| +#include "ui/views/background.h"
|
| +#include "ui/views/controls/label.h"
|
| +#include "ui/views/controls/button/image_button.h"
|
| +#include "ui/views/layout/grid_layout.h"
|
| +#include "ui/views/layout/layout_manager.h"
|
| +#include "ui/views/layout/layout_constants.h"
|
| #include "ui/views/widget/widget.h"
|
| +#include "ui/views/widget/widget_delegate.h"
|
| +
|
| +namespace {
|
| +
|
| +typedef ConstrainedWindowFrameSimple::HeaderViews HeaderViews;
|
| +
|
| +// A layout manager that lays out the header view with proper padding,
|
| +// and sized to the widget's client view.
|
| +class HeaderLayout : public views::LayoutManager {
|
| + public:
|
| + explicit HeaderLayout(views::Widget* container) : container_(container) {}
|
| + virtual ~HeaderLayout() {}
|
| +
|
| + // Overridden from LayoutManager
|
| + virtual void Layout(views::View* host);
|
| + virtual gfx::Size GetPreferredSize(views::View* host);
|
| +
|
| + private:
|
| + views::Widget* container_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(HeaderLayout);
|
| +};
|
| +
|
| +void HeaderLayout::Layout(views::View* host) {
|
| + if (!host->has_children())
|
| + return;
|
| +
|
| + int horizontal_padding = ConstrainedWindow::kHorizontalPadding;
|
| + int vertical_padding = ConstrainedWindow::kVerticalPadding;
|
| + int row_padding = ConstrainedWindow::kRowPadding;
|
| +
|
| + views::View* header = host->child_at(0);
|
| + gfx::Size preferred_size = GetPreferredSize(host);
|
| + int width = preferred_size.width() - 2 * horizontal_padding;
|
| + int height = preferred_size.height() - vertical_padding - row_padding;
|
| +
|
| + header->SetBounds(horizontal_padding, vertical_padding, width, height);
|
| +}
|
| +
|
| +gfx::Size HeaderLayout::GetPreferredSize(views::View* host) {
|
| + int horizontal_padding = ConstrainedWindow::kHorizontalPadding;
|
| + int vertical_padding = ConstrainedWindow::kVerticalPadding;
|
| + int row_padding = ConstrainedWindow::kRowPadding;
|
| +
|
| + views::View* header = host->child_at(0);
|
| + views::View* client_view = container_->client_view();
|
| +
|
| + gfx::Size header_size = header ? header->GetPreferredSize() : gfx::Size();
|
| + gfx::Size client_size =
|
| + client_view ? client_view->GetPreferredSize() : gfx::Size();
|
| + int width = std::max(client_size.width(), header_size.width()) +
|
| + 2 * horizontal_padding;
|
| + int height = vertical_padding + header_size.height() + row_padding;
|
| + return gfx::Size(width, height);
|
| +}
|
| +
|
| +} // namespace
|
| +
|
| +ConstrainedWindowFrameSimple::HeaderViews::HeaderViews(
|
| + views::View* header,
|
| + views::Label* title_label,
|
| + views::Button* close_button)
|
| + : header(header),
|
| + title_label(title_label),
|
| + close_button(close_button) {
|
| + DCHECK(header);
|
| +}
|
|
|
| ConstrainedWindowFrameSimple::ConstrainedWindowFrameSimple(
|
| - ConstrainedWindowViews* container) {
|
| - // Draw a custom frame, ie NO frame.
|
| - container->set_frame_type(views::Widget::FRAME_TYPE_FORCE_CUSTOM);
|
| + ConstrainedWindowViews* container)
|
| + : container_(container) {
|
| + container_->set_frame_type(views::Widget::FRAME_TYPE_FORCE_CUSTOM);
|
| +
|
| + layout_ = new HeaderLayout(container_);
|
| + SetLayoutManager(layout_);
|
| +
|
| + SetHeaderView(CreateDefaultHeaderView());
|
| +
|
| + set_background(views::Background::CreateSolidBackground(
|
| + ConstrainedWindow::GetBackgroundColor()));
|
| +}
|
| +
|
| +ConstrainedWindowFrameSimple::~ConstrainedWindowFrameSimple() {
|
| +}
|
| +
|
| +void ConstrainedWindowFrameSimple::SetHeaderView(HeaderViews* header_views)
|
| +{
|
| + RemoveAllChildViews(true);
|
| +
|
| + header_views_.reset(header_views);
|
| +
|
| + AddChildView(header_views_->header);
|
| +}
|
| +
|
| +HeaderViews* ConstrainedWindowFrameSimple::CreateDefaultHeaderView() {
|
| + views::View* header_view = new views::View;
|
| +
|
| + views::GridLayout* grid_layout = new views::GridLayout(header_view);
|
| + header_view->SetLayoutManager(grid_layout);
|
| +
|
| + views::ColumnSet* header_cs = grid_layout->AddColumnSet(0);
|
| + header_cs->AddColumn(views::GridLayout::CENTER, views::GridLayout::CENTER, 0,
|
| + views::GridLayout::USE_PREF, 0, 0); // Title.
|
| + header_cs->AddPaddingColumn(1, views::kUnrelatedControlHorizontalSpacing);
|
| + header_cs->AddColumn(views::GridLayout::CENTER, views::GridLayout::CENTER, 0,
|
| + views::GridLayout::USE_PREF, 0, 0); // Close Button.
|
| +
|
| + // Header row.
|
| + ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance();
|
| + grid_layout->StartRow(0, 0);
|
| + views::Label* title_label = new views::Label();
|
| + title_label->SetHorizontalAlignment(views::Label::ALIGN_LEFT);
|
| + title_label->SetFont(rb.GetFont(ConstrainedWindow::kTitleFontStyle));
|
| + title_label->SetEnabledColor(ConstrainedWindow::GetTextColor());
|
| + title_label->SetText(container_->widget_delegate()->GetWindowTitle());
|
| + grid_layout->AddView(title_label);
|
| +
|
| + views::Button* close_button = CreateCloseButton();
|
| + grid_layout->AddView(close_button);
|
| +
|
| + return new HeaderViews(header_view, title_label, close_button);
|
| }
|
|
|
| gfx::Rect ConstrainedWindowFrameSimple::GetBoundsForClientView() const {
|
| - return bounds();
|
| + int horizontal_padding = ConstrainedWindow::kHorizontalPadding;
|
| + int vertical_padding = ConstrainedWindow::kVerticalPadding;
|
| + int row_padding = ConstrainedWindow::kRowPadding;
|
| + gfx::Size header_size =
|
| + header_views_->header ?
|
| + header_views_->header->GetPreferredSize() : gfx::Size();
|
| +
|
| + return gfx::Rect(horizontal_padding,
|
| + vertical_padding + header_size.height() + row_padding,
|
| + std::max(0, width() - 2 * horizontal_padding),
|
| + std::max(0, (height() - 2 * vertical_padding -
|
| + header_size.height() - row_padding)));
|
| }
|
|
|
| gfx::Rect ConstrainedWindowFrameSimple::GetWindowBoundsForClientBounds(
|
| const gfx::Rect& client_bounds) const {
|
| - return client_bounds;
|
| + int horizontal_padding = ConstrainedWindow::kHorizontalPadding;
|
| + int vertical_padding = ConstrainedWindow::kVerticalPadding;
|
| + int row_padding = ConstrainedWindow::kRowPadding;
|
| + gfx::Size header_size =
|
| + header_views_->header ?
|
| + header_views_->header->GetPreferredSize() : gfx::Size();
|
| +
|
| + int x = client_bounds.x() - horizontal_padding;
|
| + int y = client_bounds.y() - vertical_padding - header_size.height() -
|
| + row_padding;
|
| + int width = client_bounds.width() + 2 * horizontal_padding;
|
| + int height = client_bounds.height() + 2 * vertical_padding +
|
| + header_size.height() + row_padding;
|
| +
|
| + return gfx::Rect(x, y, width, height);
|
| }
|
|
|
| int ConstrainedWindowFrameSimple::NonClientHitTest(const gfx::Point& point) {
|
| @@ -30,3 +187,51 @@ int ConstrainedWindowFrameSimple::NonClientHitTest(const gfx::Point& point) {
|
| return HTCLIENT;
|
| }
|
|
|
| +void ConstrainedWindowFrameSimple::GetWindowMask(const gfx::Size& size,
|
| + gfx::Path* window_mask) {
|
| + SkRect rect = {0, 0, size.width() - 1, size.height() - 1};
|
| + SkScalar radius = SkIntToScalar(ConstrainedWindow::kBorderRadius);
|
| + SkScalar radii[8] = {radius, radius, radius, radius,
|
| + radius, radius, radius, radius};
|
| +
|
| + // NB: We're not using the addRoundRect uniform radius overload as it
|
| + // mishandles the bottom corners on Windows
|
| + window_mask->addRoundRect(rect, radii);
|
| +}
|
| +
|
| +void ConstrainedWindowFrameSimple::ResetWindowControls() {
|
| +}
|
| +
|
| +void ConstrainedWindowFrameSimple::UpdateWindowIcon() {
|
| +}
|
| +
|
| +void ConstrainedWindowFrameSimple::UpdateWindowTitle() {
|
| + if (!header_views_->title_label)
|
| + return;
|
| +
|
| + string16 text = container_->widget_delegate()->GetWindowTitle();
|
| + header_views_->title_label->SetText(text);
|
| +}
|
| +
|
| +gfx::Size ConstrainedWindowFrameSimple::GetPreferredSize() {
|
| + return container_->non_client_view()->GetWindowBoundsForClientBounds(
|
| + gfx::Rect(container_->client_view()->GetPreferredSize())).size();
|
| +}
|
| +
|
| +void ConstrainedWindowFrameSimple::ButtonPressed(views::Button* sender,
|
| + const ui::Event& event) {
|
| + if (header_views_->close_button && sender == header_views_->close_button)
|
| + sender->GetWidget()->Close();
|
| +}
|
| +
|
| +views::ImageButton* ConstrainedWindowFrameSimple::CreateCloseButton() {
|
| + ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance();
|
| + views::ImageButton* close_button = new views::ImageButton(this);
|
| + close_button->SetImage(views::CustomButton::BS_NORMAL,
|
| + rb.GetImageSkiaNamed(IDR_SHARED_IMAGES_X));
|
| + close_button->SetImage(views::CustomButton::BS_HOT,
|
| + rb.GetImageSkiaNamed(IDR_SHARED_IMAGES_X_HOVER));
|
| + close_button->SetImage(views::CustomButton::BS_PUSHED,
|
| + rb.GetImageSkiaNamed(IDR_SHARED_IMAGES_X_HOVER));
|
| + return close_button;
|
| +}
|
|
|