summaryrefslogtreecommitdiffstats
path: root/chrome/browser/ui/views/frame/browser_view_layout.cc
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/browser/ui/views/frame/browser_view_layout.cc')
-rw-r--r--chrome/browser/ui/views/frame/browser_view_layout.cc137
1 files changed, 122 insertions, 15 deletions
diff --git a/chrome/browser/ui/views/frame/browser_view_layout.cc b/chrome/browser/ui/views/frame/browser_view_layout.cc
index ff63aa9..1cde2ac 100644
--- a/chrome/browser/ui/views/frame/browser_view_layout.cc
+++ b/chrome/browser/ui/views/frame/browser_view_layout.cc
@@ -34,6 +34,29 @@ namespace {
const int kTabShadowSize = 2;
// The vertical overlap between the TabStrip and the Toolbar.
const int kToolbarTabStripVerticalOverlap = 3;
+// The vertical size of the space between the content area and the tabstrip that
+// is inserted in compact navigation mode. Note that we need to use a height
+// that includes the overlap to get the visible height we want, in order to
+// match how the toolbar overlaps the tabstrip.
+const int kCompactNavbarSpacerVisibleHeight = 4;
+const int kCompactNavbarSpacerHeight =
+ kCompactNavbarSpacerVisibleHeight + kToolbarTabStripVerticalOverlap;
+// The size of the padding between the compact navigation bar and the tab strip.
+const int kCompactNavbarHorizontalPadding = 2;
+// The number of pixels the bookmark bar should overlap the spacer by if the
+// spacer is visible.
+const int kSpacerBookmarkBarOverlap = 1;
+
+// Combines View::ConvertPointToView and View::HitTest for a given |point|.
+// Converts |point| from |src| to |dst| and hit tests it against |dst|. The
+// converted |point| can then be retrieved and used for additional tests.
+bool ConvertedHitTest(views::View* src, views::View* dst, gfx::Point* point) {
+ DCHECK(src);
+ DCHECK(dst);
+ DCHECK(point);
+ views::View::ConvertPointToView(src, dst, point);
+ return dst->HitTest(*point);
+}
} // namespace
@@ -46,6 +69,9 @@ BrowserViewLayout::BrowserViewLayout()
contents_split_(NULL),
contents_container_(NULL),
infobar_container_(NULL),
+ compact_navigation_bar_(NULL),
+ compact_options_bar_(NULL),
+ compact_spacer_(NULL),
download_shelf_(NULL),
active_bookmark_bar_(NULL),
browser_view_(NULL),
@@ -138,20 +164,29 @@ int BrowserViewLayout::NonClientHitTest(
gfx::Point point_in_browser_view_coords(point);
views::View::ConvertPointToView(
parent, browser_view_, &point_in_browser_view_coords);
+ gfx::Point test_point(point);
// Determine if the TabStrip exists and is capable of being clicked on. We
// might be a popup window without a TabStrip.
if (browser_view_->IsTabStripVisible()) {
// See if the mouse pointer is within the bounds of the TabStrip.
- gfx::Point point_in_tabstrip_coords(point);
- views::View::ConvertPointToView(parent, tabstrip_,
- &point_in_tabstrip_coords);
- if (tabstrip_->HitTest(point_in_tabstrip_coords)) {
- if (tabstrip_->IsPositionInWindowCaption(point_in_tabstrip_coords))
+ if (ConvertedHitTest(parent, tabstrip_, &test_point)) {
+ if (tabstrip_->IsPositionInWindowCaption(test_point))
return HTCAPTION;
return HTCLIENT;
}
+ // If the tabstrip is visible and we are in compact navigation mode, test
+ // against the compact navigation and option bars.
+ if (browser_view_->UseCompactNavigationBar()) {
+ test_point = point;
+ if (ConvertedHitTest(parent, compact_navigation_bar_, &test_point))
+ return HTCLIENT;
+ test_point = point;
+ if (ConvertedHitTest(parent, compact_options_bar_, &test_point))
+ return HTCLIENT;
+ }
+
// The top few pixels of the TabStrip are a drop-shadow - as we're pretty
// starved of dragable area, let's give it to window dragging (this also
// makes sense visually).
@@ -204,6 +239,9 @@ void BrowserViewLayout::Installed(views::View* host) {
download_shelf_ = NULL;
active_bookmark_bar_ = NULL;
tabstrip_ = NULL;
+ compact_navigation_bar_ = NULL;
+ compact_options_bar_ = NULL;
+ compact_spacer_ = NULL;
browser_view_ = static_cast<BrowserView*>(host);
}
@@ -234,6 +272,15 @@ void BrowserViewLayout::ViewAdded(views::View* host, views::View* view) {
case VIEW_ID_TAB_STRIP:
tabstrip_ = static_cast<AbstractTabStripView*>(view);
break;
+ case VIEW_ID_COMPACT_NAV_BAR_SPACER:
+ compact_spacer_ = view;
+ break;
+ case VIEW_ID_COMPACT_NAV_BAR:
+ compact_navigation_bar_ = view;
+ break;
+ case VIEW_ID_COMPACT_OPT_BAR:
+ compact_options_bar_ = view;
+ break;
}
}
@@ -247,7 +294,7 @@ void BrowserViewLayout::ViewRemoved(views::View* host, views::View* view) {
void BrowserViewLayout::Layout(views::View* host) {
vertical_layout_rect_ = browser_view_->GetLocalBounds();
- int top = LayoutTabStrip();
+ int top = LayoutTabStripRegion();
if (browser_view_->IsTabStripVisible() && !browser_view_->UseVerticalTabs()) {
tabstrip_->SetBackgroundOffset(gfx::Point(
tabstrip_->GetMirroredX() + browser_view_->GetMirroredX(),
@@ -268,6 +315,11 @@ void BrowserViewLayout::Layout(views::View* host) {
browser()->GetFindBarController()->find_bar()->MoveWindowIfNecessary(
gfx::Rect(), true);
}
+ if (browser()->UseCompactNavigationBar()) {
+ DCHECK(browser_view_->compact_location_bar_view_host());
+ browser_view_->compact_location_bar_view_host()->MoveWindowIfNecessary(
+ gfx::Rect(), true);
+ }
}
// Return the preferred size which is the size required to give each
@@ -287,13 +339,19 @@ const Browser* BrowserViewLayout::browser() const {
return browser_view_->browser();
}
-int BrowserViewLayout::LayoutTabStrip() {
+int BrowserViewLayout::LayoutTabStripRegion() {
if (!browser_view_->IsTabStripVisible()) {
+ if (compact_navigation_bar_ && compact_options_bar_) {
+ compact_navigation_bar_->SetVisible(false);
+ compact_options_bar_->SetVisible(false);
+ }
tabstrip_->SetVisible(false);
tabstrip_->SetBounds(0, 0, 0, 0);
return 0;
}
+ // This retrieves the bounds for the tab strip based on whether or not we show
+ // anything to the left of it, like the incognito avatar.
gfx::Rect tabstrip_bounds(
browser_view_->frame()->GetBoundsForTabStrip(tabstrip_));
gfx::Point tabstrip_origin(tabstrip_bounds.origin());
@@ -301,6 +359,41 @@ int BrowserViewLayout::LayoutTabStrip() {
&tabstrip_origin);
tabstrip_bounds.set_origin(tabstrip_origin);
+ // If we are in compact nav mode, we want to reduce the tab strip bounds from
+ // both ends enough to lay out the compact navigation and options bars. We
+ // check the pointers to see if the mode is available, and then check the pref
+ // to see if the mode is enabled (and therefore if the additional bars should
+ // be made visible).
+ if (compact_navigation_bar_ && compact_options_bar_) {
+ compact_navigation_bar_->SetVisible(
+ browser_view_->UseCompactNavigationBar());
+ compact_options_bar_->SetVisible(browser_view_->UseCompactNavigationBar());
+
+ if (compact_navigation_bar_->IsVisible()) {
+ gfx::Rect cnav_bar_bounds;
+ gfx::Size cnav_bar_size = compact_navigation_bar_->GetPreferredSize();
+ cnav_bar_bounds.set_origin(tabstrip_bounds.origin());
+ cnav_bar_bounds.set_size(cnav_bar_size);
+ compact_navigation_bar_->SetBoundsRect(cnav_bar_bounds);
+
+ // The options bar is flush right of the tab strip region.
+ gfx::Rect copt_bar_bounds;
+ gfx::Size copt_bar_size = compact_options_bar_->GetPreferredSize();
+ copt_bar_bounds.set_x(std::max(0, tabstrip_bounds.right() -
+ copt_bar_size.width()));
+ copt_bar_bounds.set_y(tabstrip_origin.y());
+ copt_bar_bounds.set_size(copt_bar_size);
+ compact_options_bar_->SetBoundsRect(copt_bar_bounds);
+
+ // Reduce the bounds of the tab strip accordingly.
+ tabstrip_bounds.set_x(tabstrip_bounds.x() + cnav_bar_size.width() +
+ kCompactNavbarHorizontalPadding);
+ tabstrip_bounds.set_width(std::max(0, tabstrip_bounds.width() -
+ cnav_bar_size.width() - copt_bar_size.width() -
+ kCompactNavbarHorizontalPadding * 2));
+ }
+ }
+
if (browser_view_->UseVerticalTabs())
vertical_layout_rect_.Inset(tabstrip_bounds.width(), 0, 0, 0);
@@ -312,16 +405,26 @@ int BrowserViewLayout::LayoutTabStrip() {
int BrowserViewLayout::LayoutToolbar(int top) {
int browser_view_width = vertical_layout_rect_.width();
- bool visible = browser_view_->IsToolbarVisible();
- toolbar_->location_bar()->SetFocusable(visible);
+ bool toolbar_visible = browser_view_->IsToolbarVisible();
+ toolbar_->location_bar()->SetFocusable(toolbar_visible);
int y = top;
if (!browser_view_->UseVerticalTabs()) {
- y -= ((visible && browser_view_->IsTabStripVisible()) ?
- kToolbarTabStripVerticalOverlap : 0);
+ y -= ((toolbar_visible || browser_view_->UseCompactNavigationBar()) &&
+ browser_view_->IsTabStripVisible()) ?
+ kToolbarTabStripVerticalOverlap : 0;
}
- int height = visible ? toolbar_->GetPreferredSize().height() : 0;
- toolbar_->SetVisible(visible);
+ int height = toolbar_visible ? toolbar_->GetPreferredSize().height() : 0;
+ toolbar_->SetVisible(toolbar_visible);
toolbar_->SetBounds(vertical_layout_rect_.x(), y, browser_view_width, height);
+
+ // The spacer essentially replaces the toolbar when in compact mode.
+ if (browser_view_->UseCompactNavigationBar()) {
+ compact_spacer_->SetVisible(!toolbar_visible);
+ compact_spacer_->SetBounds(vertical_layout_rect_.x(), y, browser_view_width,
+ toolbar_visible ? 0 : kCompactNavbarSpacerHeight);
+ height = kCompactNavbarSpacerHeight;
+ }
+
return y + height;
}
@@ -351,8 +454,12 @@ int BrowserViewLayout::LayoutBookmarkBar(int top) {
active_bookmark_bar_->set_infobar_visible(InfobarVisible());
int bookmark_bar_height = active_bookmark_bar_->GetPreferredSize().height();
- y -= views::NonClientFrameView::kClientEdgeThickness +
- active_bookmark_bar_->GetToolbarOverlap(false);
+ if (!browser_view_->UseCompactNavigationBar()) {
+ y -= views::NonClientFrameView::kClientEdgeThickness +
+ active_bookmark_bar_->GetToolbarOverlap(false);
+ } else {
+ y -= kSpacerBookmarkBarOverlap;
+ }
active_bookmark_bar_->SetVisible(true);
active_bookmark_bar_->SetBounds(vertical_layout_rect_.x(), y,
vertical_layout_rect_.width(),