summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--chrome/browser/views/bookmark_manager_view.cc1
-rw-r--r--views/controls/single_split_view.cc17
-rw-r--r--views/controls/single_split_view.h12
3 files changed, 29 insertions, 1 deletions
diff --git a/chrome/browser/views/bookmark_manager_view.cc b/chrome/browser/views/bookmark_manager_view.cc
index f21c350..2bb6f5e 100644
--- a/chrome/browser/views/bookmark_manager_view.cc
+++ b/chrome/browser/views/bookmark_manager_view.cc
@@ -184,6 +184,7 @@ BookmarkManagerView::BookmarkManagerView(Profile* profile)
split_view_ = new views::SingleSplitView(tree_view_, table_view_,
views::SingleSplitView::HORIZONTAL_SPLIT);
+ split_view_->set_resize_leading_on_bounds_change(false);
split_view_->set_background(
views::Background::CreateSolidBackground(kBackgroundColorBottom));
diff --git a/views/controls/single_split_view.cc b/views/controls/single_split_view.cc
index dadf4b2..7915171 100644
--- a/views/controls/single_split_view.cc
+++ b/views/controls/single_split_view.cc
@@ -21,7 +21,8 @@ SingleSplitView::SingleSplitView(View* leading,
View* trailing,
Orientation orientation)
: is_horizontal_(orientation == HORIZONTAL_SPLIT),
- divider_offset_(-1) {
+ divider_offset_(-1),
+ resize_leading_on_bounds_change_(true) {
AddChildView(leading);
AddChildView(trailing);
#if defined(OS_WIN)
@@ -31,6 +32,20 @@ SingleSplitView::SingleSplitView(View* leading,
#endif
}
+void SingleSplitView::DidChangeBounds(const gfx::Rect& previous,
+ const gfx::Rect& current) {
+ if (resize_leading_on_bounds_change_) {
+ if (is_horizontal_)
+ divider_offset_ += current.width() - previous.width();
+ else
+ divider_offset_ += current.height() - previous.height();
+
+ if (divider_offset_ < 0)
+ divider_offset_ = kDividerSize;
+ }
+ View::DidChangeBounds(previous, current);
+}
+
void SingleSplitView::Layout() {
if (GetChildViewCount() != 2)
return;
diff --git a/views/controls/single_split_view.h b/views/controls/single_split_view.h
index 74377df..af982e4 100644
--- a/views/controls/single_split_view.h
+++ b/views/controls/single_split_view.h
@@ -20,6 +20,9 @@ class SingleSplitView : public views::View {
SingleSplitView(View* leading, View* trailing, Orientation orientation);
+ virtual void DidChangeBounds(const gfx::Rect& previous,
+ const gfx::Rect& current);
+
virtual void Layout();
// SingleSplitView's preferred size is the sum of the preferred widths
@@ -36,6 +39,13 @@ class SingleSplitView : public views::View {
}
int divider_offset() { return divider_offset_; }
+ // Sets whether the leading component is resized when the split views size
+ // changes. The default is true. A value of false results in the trailing
+ // component resizing on a bounds change.
+ void set_resize_leading_on_bounds_change(bool resize) {
+ resize_leading_on_bounds_change_ = resize;
+ }
+
protected:
virtual bool OnMousePressed(const MouseEvent& event);
virtual bool OnMouseDragged(const MouseEvent& event);
@@ -70,6 +80,8 @@ class SingleSplitView : public views::View {
// Position of the divider.
int divider_offset_;
+ bool resize_leading_on_bounds_change_;
+
DISALLOW_COPY_AND_ASSIGN(SingleSplitView);
};