summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ash/launcher/launcher.cc14
-rw-r--r--ash/launcher/launcher_alignment_menu.cc20
-rw-r--r--ash/launcher/launcher_button.cc68
-rw-r--r--ash/launcher/launcher_button.h10
-rw-r--r--ash/launcher/launcher_button_host.h3
-rw-r--r--ash/launcher/launcher_tooltip_manager.cc30
-rw-r--r--ash/launcher/launcher_tooltip_manager.h10
-rw-r--r--ash/launcher/launcher_tooltip_manager_unittest.cc1
-rw-r--r--ash/launcher/launcher_view.cc90
-rw-r--r--ash/launcher/launcher_view.h16
-rw-r--r--ash/launcher/launcher_view_unittest.cc5
-rw-r--r--ash/launcher/overflow_bubble.cc52
-rw-r--r--ash/launcher/overflow_bubble.h2
-rw-r--r--ash/launcher/overflow_button.cc20
-rw-r--r--ash/launcher/overflow_button.h3
-rw-r--r--ash/launcher/tabbed_launcher_button.cc15
-rw-r--r--ash/launcher/tabbed_launcher_button.h2
-rw-r--r--ash/root_window_controller.cc2
-rw-r--r--ash/wm/app_list_controller.cc18
-rw-r--r--ash/wm/shelf_layout_manager.cc45
-rw-r--r--ash/wm/shelf_layout_manager.h37
21 files changed, 246 insertions, 217 deletions
diff --git a/ash/launcher/launcher.cc b/ash/launcher/launcher.cc
index f38b567..69de8e1 100644
--- a/ash/launcher/launcher.cc
+++ b/ash/launcher/launcher.cc
@@ -167,12 +167,13 @@ void Launcher::DelegateView::Layout() {
void Launcher::DelegateView::OnPaintBackground(gfx::Canvas* canvas) {
if (launcher_->alignment_ == SHELF_ALIGNMENT_BOTTOM) {
SkPaint paint;
- static const gfx::ImageSkia* launcher_background = NULL;
- if (!launcher_background) {
- ResourceBundle& rb = ResourceBundle::GetSharedInstance();
- launcher_background =
- rb.GetImageNamed(IDR_AURA_LAUNCHER_BACKGROUND_BOTTOM).ToImageSkia();
- }
+ ResourceBundle& rb = ResourceBundle::GetSharedInstance();
+ const gfx::ImageSkia* launcher_background = rb.GetImageSkiaNamed(
+ internal::ShelfLayoutManager::ForLauncher(
+ launcher_->widget()->GetNativeView())->
+ SelectValueForShelfAlignment(IDR_AURA_LAUNCHER_BACKGROUND_BOTTOM,
+ IDR_AURA_LAUNCHER_BACKGROUND_LEFT,
+ IDR_AURA_LAUNCHER_BACKGROUND_RIGHT));
paint.setAlpha(alpha_);
canvas->DrawImageInt(
*launcher_background,
@@ -230,6 +231,7 @@ Launcher::Launcher(aura::Window* window_container,
widget_->GetNativeView()->SetName("LauncherView");
widget_->GetNativeView()->SetProperty(internal::kStayInSameRootWindowKey,
true);
+
// SetBounds() has to be called after kStayInSameRootWindowKey is set.
gfx::Size pref =
static_cast<views::View*>(launcher_view_)->GetPreferredSize();
diff --git a/ash/launcher/launcher_alignment_menu.cc b/ash/launcher/launcher_alignment_menu.cc
index cfa242c..1136baa 100644
--- a/ash/launcher/launcher_alignment_menu.cc
+++ b/ash/launcher/launcher_alignment_menu.cc
@@ -6,7 +6,9 @@
#include "ash/shelf_types.h"
#include "ash/shell.h"
+#include "ash/wm/shelf_layout_manager.h"
#include "grit/ash_strings.h"
+#include "ui/aura/root_window.h"
#include "ui/base/l10n/l10n_util.h"
namespace ash {
@@ -33,19 +35,11 @@ LauncherAlignmentMenu::~LauncherAlignmentMenu() {
}
bool LauncherAlignmentMenu::IsCommandIdChecked(int command_id) const {
- switch (command_id) {
- case MENU_ALIGN_LEFT:
- return Shell::GetInstance()->GetShelfAlignment(root_window_) ==
- SHELF_ALIGNMENT_LEFT;
- case MENU_ALIGN_BOTTOM:
- return Shell::GetInstance()->GetShelfAlignment(root_window_) ==
- SHELF_ALIGNMENT_BOTTOM;
- case MENU_ALIGN_RIGHT:
- return Shell::GetInstance()->GetShelfAlignment(root_window_) ==
- SHELF_ALIGNMENT_RIGHT;
- default:
- return false;
- }
+ return internal::ShelfLayoutManager::ForLauncher(root_window_)->
+ SelectValueForShelfAlignment(
+ MENU_ALIGN_BOTTOM == command_id,
+ MENU_ALIGN_LEFT == command_id,
+ MENU_ALIGN_RIGHT == command_id);
}
bool LauncherAlignmentMenu::IsCommandIdEnabled(int command_id) const {
diff --git a/ash/launcher/launcher_button.cc b/ash/launcher/launcher_button.cc
index be5e381..77546f8 100644
--- a/ash/launcher/launcher_button.cc
+++ b/ash/launcher/launcher_button.cc
@@ -7,6 +7,7 @@
#include <algorithm>
#include "ash/launcher/launcher_button_host.h"
+#include "ash/wm/shelf_layout_manager.h"
#include "grit/ash_resources.h"
#include "skia/ext/image_operations.h"
#include "ui/base/accessibility/accessible_view_state.h"
@@ -112,20 +113,25 @@ bool LauncherButton::IconView::HitTestRect(const gfx::Rect& rect) const {
////////////////////////////////////////////////////////////////////////////////
// LauncherButton
-LauncherButton* LauncherButton::Create(views::ButtonListener* listener,
- LauncherButtonHost* host) {
- LauncherButton* button = new LauncherButton(listener, host);
+LauncherButton* LauncherButton::Create(
+ views::ButtonListener* listener,
+ LauncherButtonHost* host,
+ ShelfLayoutManager* shelf_layout_manager) {
+ LauncherButton* button =
+ new LauncherButton(listener, host, shelf_layout_manager);
button->Init();
return button;
}
LauncherButton::LauncherButton(views::ButtonListener* listener,
- LauncherButtonHost* host)
+ LauncherButtonHost* host,
+ ShelfLayoutManager* shelf_layout_manager)
: CustomButton(listener),
host_(host),
icon_view_(NULL),
bar_(new BarView),
- state_(STATE_NORMAL) {
+ state_(STATE_NORMAL),
+ shelf_layout_manager_(shelf_layout_manager) {
set_accessibility_focusable(true);
const gfx::ShadowValue kShadows[] = {
@@ -269,7 +275,7 @@ void LauncherButton::Layout() {
int x_offset = 0, y_offset = 0;
gfx::Rect icon_bounds;
- if (host_->GetShelfAlignment() == SHELF_ALIGNMENT_BOTTOM) {
+ if (shelf_layout_manager_->GetAlignment() == SHELF_ALIGNMENT_BOTTOM) {
icon_bounds.SetRect(
button_bounds.x(), button_bounds.y() + kIconPad,
button_bounds.width(), kIconSize);
@@ -283,7 +289,7 @@ void LauncherButton::Layout() {
x_offset += kHopSpacing;
}
- if (host_->GetShelfAlignment() == SHELF_ALIGNMENT_LEFT)
+ if (shelf_layout_manager_->GetAlignment() == SHELF_ALIGNMENT_LEFT)
x_offset = -x_offset;
icon_bounds.Offset(x_offset, y_offset);
icon_view_->SetBoundsRect(icon_bounds);
@@ -347,7 +353,7 @@ LauncherButton::IconView* LauncherButton::CreateIconView() {
}
bool LauncherButton::IsShelfHorizontal() const {
- return host_->GetShelfAlignment() == SHELF_ALIGNMENT_BOTTOM;
+ return shelf_layout_manager_->IsHorizontalAlignment();
}
void LauncherButton::UpdateState() {
@@ -355,28 +361,39 @@ void LauncherButton::UpdateState() {
bar_->SetVisible(false);
} else {
int bar_id;
- if (IsShelfHorizontal()) {
- if (state_ & STATE_ACTIVE)
- bar_id = IDR_AURA_LAUNCHER_UNDERLINE_BOTTOM_ACTIVE;
- else if (state_ & (STATE_HOVERED | STATE_FOCUSED | STATE_ATTENTION))
- bar_id = IDR_AURA_LAUNCHER_UNDERLINE_BOTTOM_HOVER;
- else
- bar_id = IDR_AURA_LAUNCHER_UNDERLINE_BOTTOM_RUNNING;
+ if (state_ & STATE_ACTIVE) {
+ bar_id = shelf_layout_manager_->SelectValueForShelfAlignment(
+ IDR_AURA_LAUNCHER_UNDERLINE_BOTTOM_ACTIVE,
+ IDR_AURA_LAUNCHER_UNDERLINE_LEFT_ACTIVE,
+ IDR_AURA_LAUNCHER_UNDERLINE_RIGHT_ACTIVE);
+ } else if (state_ & (STATE_HOVERED | STATE_FOCUSED | STATE_ATTENTION)) {
+ bar_id = shelf_layout_manager_->SelectValueForShelfAlignment(
+ IDR_AURA_LAUNCHER_UNDERLINE_BOTTOM_HOVER,
+ IDR_AURA_LAUNCHER_UNDERLINE_LEFT_HOVER,
+ IDR_AURA_LAUNCHER_UNDERLINE_RIGHT_HOVER);
} else {
- if (state_ & STATE_ACTIVE)
- bar_id = IDR_AURA_LAUNCHER_UNDERLINE_LEFT_ACTIVE;
- else if (state_ & (STATE_HOVERED | STATE_FOCUSED | STATE_ATTENTION))
- bar_id = IDR_AURA_LAUNCHER_UNDERLINE_LEFT_HOVER;
- else
- bar_id = IDR_AURA_LAUNCHER_UNDERLINE_LEFT_RUNNING;
+ bar_id = shelf_layout_manager_->SelectValueForShelfAlignment(
+ IDR_AURA_LAUNCHER_UNDERLINE_BOTTOM_RUNNING,
+ IDR_AURA_LAUNCHER_UNDERLINE_LEFT_RUNNING,
+ IDR_AURA_LAUNCHER_UNDERLINE_RIGHT_RUNNING);
}
-
ResourceBundle& rb = ResourceBundle::GetSharedInstance();
bar_->SetImage(rb.GetImageNamed(bar_id).ToImageSkia());
bar_->SetVisible(true);
}
-
- switch (host_->GetShelfAlignment()) {
+ bool rtl = base::i18n::IsRTL();
+ bar_->SetHorizontalAlignment(
+ shelf_layout_manager_->SelectValueForShelfAlignment(
+ views::ImageView::CENTER,
+ rtl ? views::ImageView::TRAILING : views::ImageView::LEADING,
+ rtl ? views::ImageView::LEADING : views::ImageView::TRAILING));
+ bar_->SetVerticalAlignment(
+ shelf_layout_manager_->SelectValueForShelfAlignment(
+ views::ImageView::TRAILING,
+ views::ImageView::CENTER,
+ views::ImageView::CENTER));
+
+ switch (shelf_layout_manager_->GetAlignment()) {
case SHELF_ALIGNMENT_BOTTOM:
bar_->SetHorizontalAlignment(views::ImageView::CENTER);
bar_->SetVerticalAlignment(views::ImageView::TRAILING);
@@ -395,7 +412,10 @@ void LauncherButton::UpdateState() {
break;
}
+ // Force bar to layout as alignment may have changed but not bounds.
+ bar_->Layout();
Layout();
+ bar_->SchedulePaint();
SchedulePaint();
}
diff --git a/ash/launcher/launcher_button.h b/ash/launcher/launcher_button.h
index c46b209..934fc9a 100644
--- a/ash/launcher/launcher_button.h
+++ b/ash/launcher/launcher_button.h
@@ -13,6 +13,7 @@ namespace ash {
namespace internal {
class LauncherButtonHost;
+class ShelfLayoutManager;
// Button used for items on the launcher, except for the AppList.
class LauncherButton : public views::CustomButton {
@@ -38,7 +39,8 @@ class LauncherButton : public views::CustomButton {
// Called to create an instance of a LauncherButton.
static LauncherButton* Create(views::ButtonListener* listener,
- LauncherButtonHost* host);
+ LauncherButtonHost* host,
+ ShelfLayoutManager* shelf_layout_manager);
// Sets the image to display for this entry.
void SetImage(const gfx::ImageSkia& image);
@@ -52,7 +54,9 @@ class LauncherButton : public views::CustomButton {
gfx::Rect GetIconBounds() const;
protected:
- LauncherButton(views::ButtonListener* listener, LauncherButtonHost* host);
+ LauncherButton(views::ButtonListener* listener,
+ LauncherButtonHost* host,
+ ShelfLayoutManager* shelf_layout_manager);
// Class that draws the icon part of a button, so it can be animated
// independently of the rest. This can be subclassed to provide a custom
@@ -121,6 +125,8 @@ class LauncherButton : public views::CustomButton {
// together.
int state_;
+ ShelfLayoutManager* shelf_layout_manager_;
+
gfx::ShadowValues icon_shadows_;
DISALLOW_COPY_AND_ASSIGN(LauncherButton);
diff --git a/ash/launcher/launcher_button_host.h b/ash/launcher/launcher_button_host.h
index c088533..37ed07a 100644
--- a/ash/launcher/launcher_button_host.h
+++ b/ash/launcher/launcher_button_host.h
@@ -6,7 +6,6 @@
#define ASH_LAUNCHER_LAUNCHER_BUTTON_HOST_H_
#include "ash/ash_export.h"
-#include "ash/shelf_types.h"
#include "base/string16.h"
namespace ui {
@@ -54,8 +53,6 @@ class ASH_EXPORT LauncherButtonHost {
// Invoked when the mouse exits the item.
virtual void MouseExitedButton(views::View* view) = 0;
- virtual ShelfAlignment GetShelfAlignment() const = 0;
-
// Invoked to get the accessible name of the item.
virtual string16 GetAccessibleName(const views::View* view) = 0;
diff --git a/ash/launcher/launcher_tooltip_manager.cc b/ash/launcher/launcher_tooltip_manager.cc
index aa48c5c..f99e552 100644
--- a/ash/launcher/launcher_tooltip_manager.cc
+++ b/ash/launcher/launcher_tooltip_manager.cc
@@ -9,6 +9,7 @@
#include "ash/shell_window_ids.h"
#include "ash/wm/session_state_controller.h"
#include "ash/wm/session_state_observer.h"
+#include "ash/wm/shelf_layout_manager.h"
#include "ash/wm/window_animations.h"
#include "base/bind.h"
#include "base/message_loop.h"
@@ -41,18 +42,6 @@ const int kTooltipMaxWidth = 250;
// The distance between the arrow tip and edge of the anchor view.
const int kArrowOffset = 10;
-views::BubbleBorder::ArrowLocation GetArrowLocation(ShelfAlignment alignment) {
- switch (alignment) {
- case SHELF_ALIGNMENT_LEFT:
- return views::BubbleBorder::LEFT_CENTER;
- case SHELF_ALIGNMENT_RIGHT:
- return views::BubbleBorder::RIGHT_CENTER;
- case SHELF_ALIGNMENT_BOTTOM:
- return views::BubbleBorder::BOTTOM_CENTER;
- }
-
- return views::BubbleBorder::NONE;
-}
} // namespace
// The implementation of tooltip of the launcher.
@@ -139,13 +128,11 @@ gfx::Size LauncherTooltipManager::LauncherTooltipBubble::GetPreferredSize() {
}
LauncherTooltipManager::LauncherTooltipManager(
- ShelfAlignment alignment,
ShelfLayoutManager* shelf_layout_manager,
LauncherView* launcher_view)
: view_(NULL),
widget_(NULL),
anchor_(NULL),
- alignment_(alignment),
shelf_layout_manager_(shelf_layout_manager),
launcher_view_(launcher_view) {
if (shelf_layout_manager)
@@ -217,11 +204,7 @@ void LauncherTooltipManager::OnBubbleClosed(views::BubbleDelegateView* view) {
}
}
-void LauncherTooltipManager::SetArrowLocation(ShelfAlignment alignment) {
- if (alignment_ == alignment)
- return;
-
- alignment_ = alignment;
+void LauncherTooltipManager::UpdateArrowLocation() {
if (view_) {
CancelHidingAnimation();
Close();
@@ -368,8 +351,13 @@ void LauncherTooltipManager::CreateBubble(views::View* anchor,
anchor_ = anchor;
text_ = text;
- view_ = new LauncherTooltipBubble(
- anchor, GetArrowLocation(alignment_), this);
+ views::BubbleBorder::ArrowLocation arrow_location =
+ shelf_layout_manager_->SelectValueForShelfAlignment(
+ views::BubbleBorder::BOTTOM_CENTER,
+ views::BubbleBorder::LEFT_CENTER,
+ views::BubbleBorder::RIGHT_CENTER);
+
+ view_ = new LauncherTooltipBubble(anchor, arrow_location, this);
widget_ = view_->GetWidget();
view_->SetText(text_);
diff --git a/ash/launcher/launcher_tooltip_manager.h b/ash/launcher/launcher_tooltip_manager.h
index 0e2c660..8bb764f 100644
--- a/ash/launcher/launcher_tooltip_manager.h
+++ b/ash/launcher/launcher_tooltip_manager.h
@@ -40,11 +40,14 @@ class ASH_EXPORT LauncherTooltipManager : public ui::EventHandler,
public ShelfLayoutManager::Observer,
public SessionStateObserver {
public:
- LauncherTooltipManager(ShelfAlignment alignment,
- ShelfLayoutManager* shelf_layout_manager,
+ LauncherTooltipManager(ShelfLayoutManager* shelf_layout_manager,
LauncherView* launcher_view);
virtual ~LauncherTooltipManager();
+ ShelfLayoutManager* shelf_layout_manager() {
+ return shelf_layout_manager_;
+ }
+
// Called when the bubble is closed.
void OnBubbleClosed(views::BubbleDelegateView* view);
@@ -59,7 +62,7 @@ class ASH_EXPORT LauncherTooltipManager : public ui::EventHandler,
// Changes the arrow location of the tooltip in case that the launcher
// arrangement has changed.
- void SetArrowLocation(ShelfAlignment alignment);
+ void UpdateArrowLocation();
// Resets the timer for the delayed showing |view_|. If the timer isn't
// running, it starts a new timer.
@@ -101,7 +104,6 @@ protected:
views::Widget* widget_;
views::View* anchor_;
string16 text_;
- ShelfAlignment alignment_;
scoped_ptr<base::Timer> timer_;
ShelfLayoutManager* shelf_layout_manager_;
diff --git a/ash/launcher/launcher_tooltip_manager_unittest.cc b/ash/launcher/launcher_tooltip_manager_unittest.cc
index 0d0617a..c6d81dd 100644
--- a/ash/launcher/launcher_tooltip_manager_unittest.cc
+++ b/ash/launcher/launcher_tooltip_manager_unittest.cc
@@ -41,7 +41,6 @@ class LauncherTooltipManagerTest : public AshTestBase {
internal::RootWindowController* controller =
Shell::GetPrimaryRootWindowController();
tooltip_manager_.reset(new internal::LauncherTooltipManager(
- SHELF_ALIGNMENT_BOTTOM,
controller->shelf(),
controller->launcher()->GetLauncherViewForTest()));
}
diff --git a/ash/launcher/launcher_view.cc b/ash/launcher/launcher_view.cc
index 4148c87..18c9e9d 100644
--- a/ash/launcher/launcher_view.cc
+++ b/ash/launcher/launcher_view.cc
@@ -16,8 +16,8 @@
#include "ash/launcher/overflow_bubble.h"
#include "ash/launcher/overflow_button.h"
#include "ash/launcher/tabbed_launcher_button.h"
-#include "ash/shell.h"
#include "ash/shell_delegate.h"
+#include "ash/wm/shelf_layout_manager.h"
#include "base/auto_reset.h"
#include "base/memory/scoped_ptr.h"
#include "grit/ash_strings.h"
@@ -282,7 +282,6 @@ LauncherView::LauncherView(LauncherModel* model,
drag_offset_(0),
start_drag_index_(-1),
context_menu_id_(0),
- alignment_(SHELF_ALIGNMENT_BOTTOM),
leading_inset_(kDefaultLeadingInset) {
DCHECK(model_);
bounds_animator_.reset(new views::BoundsAnimator(this));
@@ -290,7 +289,7 @@ LauncherView::LauncherView(LauncherModel* model,
set_context_menu_controller(this);
focus_search_.reset(new LauncherFocusSearch(view_model_.get()));
tooltip_.reset(new LauncherTooltipManager(
- alignment_, shelf_layout_manager, this));
+ shelf_layout_manager, this));
}
LauncherView::~LauncherView() {
@@ -324,9 +323,9 @@ void LauncherView::SetAlignment(ShelfAlignment alignment) {
return;
alignment_ = alignment;
UpdateFirstButtonPadding();
- overflow_button_->SetShelfAlignment(alignment_);
+ overflow_button_->OnShelfAlignmentChanged();
LayoutToIdealBounds();
- tooltip_->SetArrowLocation(alignment_);
+ tooltip_->UpdateArrowLocation();
if (overflow_bubble_.get())
overflow_bubble_->Hide();
}
@@ -395,29 +394,32 @@ void LauncherView::LayoutToIdealBounds() {
}
void LauncherView::CalculateIdealBounds(IdealBounds* bounds) {
- int available_size = primary_axis_coordinate(width(), height());
+ ShelfLayoutManager* shelf = tooltip_->shelf_layout_manager();
+
+ int available_size = shelf->PrimaryAxisValue(width(), height());
if (!available_size)
return;
// Initial x,y values account both leading_inset in primary
// coordinate and secondary coordinate based on the dynamic edge of the
// launcher (eg top edge on bottom-aligned launcher).
- int x = alignment_based_value(leading_inset(),
+ int x = shelf->SelectValueForShelfAlignment(
+ leading_inset(),
width() - kLauncherPreferredSize,
std::max(width() - kLauncherPreferredSize,
- ShelfLayoutManager::kAutoHideSize + 1));
- int y = primary_axis_coordinate(0, leading_inset());
+ ShelfLayoutManager::kAutoHideSize + 1));
+ int y = shelf->PrimaryAxisValue(0, leading_inset());
for (int i = 0; i < view_model_->view_size(); ++i) {
if (i < first_visible_index_) {
view_model_->set_ideal_bounds(i, gfx::Rect(x, y, 0, 0));
continue;
}
- int w = primary_axis_coordinate(kLauncherPreferredSize, width());
- int h = primary_axis_coordinate(height(), kLauncherPreferredSize);
+ int w = shelf->PrimaryAxisValue(kLauncherPreferredSize, width());
+ int h = shelf->PrimaryAxisValue(height(), kLauncherPreferredSize);
view_model_->set_ideal_bounds(i, gfx::Rect(x, y, w, h));
- x = primary_axis_coordinate(x + w + kButtonSpacing, x);
- y = primary_axis_coordinate(y, y + h + kButtonSpacing);
+ x = shelf->PrimaryAxisValue(x + w + kButtonSpacing, x);
+ y = shelf->PrimaryAxisValue(y, y + h + kButtonSpacing);
}
int app_list_index = view_model_->view_size() - 1;
@@ -431,8 +433,8 @@ void LauncherView::CalculateIdealBounds(IdealBounds* bounds) {
}
bounds->overflow_bounds.set_size(gfx::Size(
- primary_axis_coordinate(kLauncherPreferredSize, width()),
- primary_axis_coordinate(height(), kLauncherPreferredSize)));
+ shelf->PrimaryAxisValue(kLauncherPreferredSize, width()),
+ shelf->PrimaryAxisValue(height(), kLauncherPreferredSize)));
last_visible_index_ = DetermineLastVisibleIndex(
available_size - leading_inset() - kLauncherPreferredSize -
kButtonSpacing - kLauncherPreferredSize);
@@ -447,24 +449,25 @@ void LauncherView::CalculateIdealBounds(IdealBounds* bounds) {
if (show_overflow) {
DCHECK_NE(0, view_model_->view_size());
if (last_visible_index_ == -1) {
- x = alignment_based_value(leading_inset(),
- width() - kLauncherPreferredSize,
- std::max(width() - kLauncherPreferredSize,
- ShelfLayoutManager::kAutoHideSize + 1));
- y = primary_axis_coordinate(0, leading_inset());
+ x = shelf->SelectValueForShelfAlignment(
+ leading_inset(),
+ width() - kLauncherPreferredSize,
+ std::max(width() - kLauncherPreferredSize,
+ ShelfLayoutManager::kAutoHideSize + 1));
+ y = shelf->PrimaryAxisValue(0, leading_inset());
} else {
- x = primary_axis_coordinate(
+ x = shelf->PrimaryAxisValue(
view_model_->ideal_bounds(last_visible_index_).right(),
view_model_->ideal_bounds(last_visible_index_).x());
- y = primary_axis_coordinate(
+ y = shelf->PrimaryAxisValue(
view_model_->ideal_bounds(last_visible_index_).y(),
view_model_->ideal_bounds(last_visible_index_).bottom());
}
gfx::Rect app_list_bounds = view_model_->ideal_bounds(app_list_index);
bounds->overflow_bounds.set_x(x);
bounds->overflow_bounds.set_y(y);
- x = primary_axis_coordinate(x + kLauncherPreferredSize + kButtonSpacing, x);
- y = primary_axis_coordinate(y, y + kLauncherPreferredSize + kButtonSpacing);
+ x = shelf->PrimaryAxisValue(x + kLauncherPreferredSize + kButtonSpacing, x);
+ y = shelf->PrimaryAxisValue(y, y + kLauncherPreferredSize + kButtonSpacing);
app_list_bounds.set_x(x);
app_list_bounds.set_y(y);
view_model_->set_ideal_bounds(app_list_index, app_list_bounds);
@@ -475,9 +478,11 @@ void LauncherView::CalculateIdealBounds(IdealBounds* bounds) {
}
int LauncherView::DetermineLastVisibleIndex(int max_value) {
+ ShelfLayoutManager* shelf = tooltip_->shelf_layout_manager();
+
int index = view_model_->view_size() - 1;
while (index >= 0 &&
- primary_axis_coordinate(
+ shelf->PrimaryAxisValue(
view_model_->ideal_bounds(index).right(),
view_model_->ideal_bounds(index).bottom()) > max_value) {
index--;
@@ -511,6 +516,7 @@ views::View* LauncherView::CreateViewForItem(const LauncherItem& item) {
TabbedLauncherButton::Create(
this,
this,
+ tooltip_->shelf_layout_manager(),
item.is_incognito ?
TabbedLauncherButton::STATE_INCOGNITO :
TabbedLauncherButton::STATE_NOT_INCOGNITO);
@@ -523,7 +529,8 @@ views::View* LauncherView::CreateViewForItem(const LauncherItem& item) {
case TYPE_APP_SHORTCUT:
case TYPE_PLATFORM_APP:
case TYPE_APP_PANEL: {
- LauncherButton* button = LauncherButton::Create(this, this);
+ LauncherButton* button = LauncherButton::Create(
+ this, this, tooltip_->shelf_layout_manager());
button->SetImage(item.image);
ReflectItemStatus(item, button);
view = button;
@@ -539,7 +546,8 @@ views::View* LauncherView::CreateViewForItem(const LauncherItem& item) {
case TYPE_BROWSER_SHORTCUT: {
ResourceBundle& rb = ResourceBundle::GetSharedInstance();
- LauncherButton* button = LauncherButton::Create(this, this);
+ LauncherButton* button = LauncherButton::Create(
+ this, this, tooltip_->shelf_layout_manager());
int image_id = delegate_ ?
delegate_->GetBrowserShortcutResourceId() :
IDR_AURA_LAUNCHER_BROWSER_SHORTCUT;
@@ -587,6 +595,8 @@ void LauncherView::PrepareForDrag(Pointer pointer,
}
void LauncherView::ContinueDrag(const ui::LocatedEvent& event) {
+ ShelfLayoutManager* shelf = tooltip_->shelf_layout_manager();
+
// TODO: I don't think this works correctly with RTL.
gfx::Point drag_point(event.location());
views::View::ConvertPointToTarget(drag_view_, this, &drag_point);
@@ -608,7 +618,7 @@ void LauncherView::ContinueDrag(const ui::LocatedEvent& event) {
if (last_drag_index > last_visible_index_)
last_drag_index = last_visible_index_;
int x = 0, y = 0;
- if (is_horizontal_alignment()) {
+ if (shelf->IsHorizontalAlignment()) {
x = std::max(view_model_->ideal_bounds(indices.first).x(),
drag_point.x() - drag_offset_);
x = std::min(view_model_->ideal_bounds(last_drag_index).right() -
@@ -631,7 +641,7 @@ void LauncherView::ContinueDrag(const ui::LocatedEvent& event) {
int target_index =
views::ViewModelUtils::DetermineMoveIndex(
*view_model_, drag_view_,
- is_horizontal_alignment() ?
+ shelf->IsHorizontalAlignment() ?
views::ViewModelUtils::HORIZONTAL :
views::ViewModelUtils::VERTICAL,
x, y);
@@ -693,20 +703,21 @@ void LauncherView::ShowOverflowBubble() {
overflow_bubble_->Show(delegate_,
model_,
overflow_button_,
- alignment_,
first_overflow_index);
Shell::GetInstance()->UpdateShelfVisibility();
}
void LauncherView::UpdateFirstButtonPadding() {
+ ShelfLayoutManager* shelf = tooltip_->shelf_layout_manager();
+
// Creates an empty border for first launcher button to make included leading
// inset act as the button's padding. This is only needed on button creation
// and when shelf alignment changes.
if (view_model_->view_size() > 0) {
view_model_->view_at(0)->set_border(views::Border::CreateEmptyBorder(
- primary_axis_coordinate(0, leading_inset()),
- primary_axis_coordinate(leading_inset(), 0),
+ shelf->PrimaryAxisValue(0, leading_inset()),
+ shelf->PrimaryAxisValue(leading_inset(), 0),
0,
0));
}
@@ -766,7 +777,9 @@ gfx::Size LauncherView::GetPreferredSize() {
gfx::Rect(gfx::Size(kLauncherPreferredSize,
kLauncherPreferredSize));
- if (is_horizontal_alignment()) {
+ ShelfLayoutManager* shelf = tooltip_->shelf_layout_manager();
+
+ if (shelf->IsHorizontalAlignment()) {
return gfx::Size(last_button_bounds.right() + leading_inset(),
kLauncherPreferredSize);
}
@@ -911,15 +924,18 @@ void LauncherView::PointerPressedOnButton(views::View* view,
!delegate_->IsDraggable(model_->items()[index]))
return; // View is being deleted or not draggable, ignore request.
+ ShelfLayoutManager* shelf = tooltip_->shelf_layout_manager();
+
drag_view_ = view;
- drag_offset_ = primary_axis_coordinate(event.x(), event.y());
+ drag_offset_ = shelf->PrimaryAxisValue(event.x(), event.y());
}
void LauncherView::PointerDraggedOnButton(views::View* view,
Pointer pointer,
const ui::LocatedEvent& event) {
+ ShelfLayoutManager* shelf = tooltip_->shelf_layout_manager();
if (!dragging() && drag_view_ &&
- primary_axis_coordinate(abs(event.x() - drag_offset_),
+ shelf->PrimaryAxisValue(abs(event.x() - drag_offset_),
abs(event.y() - drag_offset_)) >=
kMinimumDragDistance) {
PrepareForDrag(pointer, event);
@@ -970,10 +986,6 @@ void LauncherView::MouseExitedButton(views::View* view) {
tooltip_->StopTimer();
}
-ShelfAlignment LauncherView::GetShelfAlignment() const {
- return alignment_;
-}
-
string16 LauncherView::GetAccessibleName(const views::View* view) {
int view_index = view_model_->GetIndexOfView(view);
// May be -1 while in the process of animating closed.
diff --git a/ash/launcher/launcher_view.h b/ash/launcher/launcher_view.h
index f52bb8d..563577f 100644
--- a/ash/launcher/launcher_view.h
+++ b/ash/launcher/launcher_view.h
@@ -106,21 +106,6 @@ class ASH_EXPORT LauncherView : public views::View,
gfx::Rect overflow_bounds;
};
- // Used in calculating ideal bounds.
- int primary_axis_coordinate(int x, int y) const {
- return is_horizontal_alignment() ? x : y;
- }
-
- bool is_horizontal_alignment() const {
- return alignment_ == SHELF_ALIGNMENT_BOTTOM;
- }
-
- // Used in calculating ideal bounds.
- int alignment_based_value(int bottom, int left, int right) const {
- return (SHELF_ALIGNMENT_BOTTOM == alignment_ ? bottom :
- (SHELF_ALIGNMENT_LEFT == alignment_ ? left : right));
- }
-
bool is_overflow_mode() const {
return first_visible_index_ > 0;
}
@@ -209,7 +194,6 @@ class ASH_EXPORT LauncherView : public views::View,
virtual void MouseMovedOverButton(views::View* view) OVERRIDE;
virtual void MouseEnteredButton(views::View* view) OVERRIDE;
virtual void MouseExitedButton(views::View* view) OVERRIDE;
- virtual ShelfAlignment GetShelfAlignment() const OVERRIDE;
virtual string16 GetAccessibleName(const views::View* view) OVERRIDE;
// Overridden from views::ButtonListener:
diff --git a/ash/launcher/launcher_view_unittest.cc b/ash/launcher/launcher_view_unittest.cc
index 468e8f9..727d0ff 100644
--- a/ash/launcher/launcher_view_unittest.cc
+++ b/ash/launcher/launcher_view_unittest.cc
@@ -12,6 +12,7 @@
#include "ash/launcher/launcher_icon_observer.h"
#include "ash/launcher/launcher_model.h"
#include "ash/launcher/launcher_tooltip_manager.h"
+#include "ash/root_window_controller.h"
#include "ash/shell.h"
#include "ash/test/ash_test_base.h"
#include "ash/test/launcher_view_test_api.h"
@@ -178,7 +179,9 @@ class LauncherViewTest : public AshTestBase {
model_.reset(new LauncherModel);
launcher_view_.reset(new internal::LauncherView(
- model_.get(), &delegate_, NULL));
+ model_.get(),
+ &delegate_,
+ Shell::GetPrimaryRootWindowController()->shelf()));
launcher_view_->Init();
// The bounds should be big enough for 4 buttons + overflow chevron.
launcher_view_->SetBounds(0, 0, 500, 50);
diff --git a/ash/launcher/overflow_bubble.cc b/ash/launcher/overflow_bubble.cc
index b5a1be5e..75d28af 100644
--- a/ash/launcher/overflow_bubble.cc
+++ b/ash/launcher/overflow_bubble.cc
@@ -10,6 +10,7 @@
#include "ash/launcher/launcher_view.h"
#include "ash/system/tray/system_tray.h"
#include "ash/shell.h"
+#include "ash/wm/shelf_layout_manager.h"
#include "ui/gfx/insets.h"
#include "ui/gfx/screen.h"
#include "ui/views/bubble/bubble_delegate.h"
@@ -30,22 +31,6 @@ const int kPadding = 2;
// Padding space in pixels between LauncherView's left/top edge to its contents.
const int kLauncherViewLeadingInset = 8;
-// Gets arrow location based on shelf alignment.
-views::BubbleBorder::ArrowLocation GetBubbleArrowLocation(
- ShelfAlignment shelf_alignment) {
- switch (shelf_alignment) {
- case ash::SHELF_ALIGNMENT_BOTTOM:
- return views::BubbleBorder::BOTTOM_LEFT;
- case ash::SHELF_ALIGNMENT_LEFT:
- return views::BubbleBorder::LEFT_TOP;
- case ash::SHELF_ALIGNMENT_RIGHT:
- return views::BubbleBorder::RIGHT_TOP;
- default:
- NOTREACHED() << "Unknown shelf alignment " << shelf_alignment;
- return views::BubbleBorder::BOTTOM_LEFT;
- }
-}
-
////////////////////////////////////////////////////////////////////////////////
// OverflowBubbleView
// OverflowBubbleView hosts a LauncherView to display overflown items.
@@ -58,18 +43,25 @@ class OverflowBubbleView : public views::BubbleDelegateView {
void InitOverflowBubble(LauncherDelegate* delegate,
LauncherModel* model,
views::View* anchor,
- ShelfAlignment shelf_alignment,
int overflow_start_index);
private:
- bool is_horizontal_alignment() const {
- return shelf_alignment_ == SHELF_ALIGNMENT_BOTTOM;
+ bool IsHorizontalAlignment() const {
+ return GetShelfLayoutManagerForLauncher()->IsHorizontalAlignment();
}
const gfx::Size GetContentsSize() const {
return static_cast<views::View*>(launcher_view_)->GetPreferredSize();
}
+ // Gets arrow location based on shelf alignment.
+ views::BubbleBorder::ArrowLocation GetBubbleArrowLocation() const {
+ return GetShelfLayoutManagerForLauncher()->SelectValueForShelfAlignment(
+ views::BubbleBorder::BOTTOM_LEFT,
+ views::BubbleBorder::LEFT_TOP,
+ views::BubbleBorder::RIGHT_TOP);
+ }
+
void ScrollByXOffset(int x_offset);
void ScrollByYOffset(int y_offset);
@@ -85,7 +77,11 @@ class OverflowBubbleView : public views::BubbleDelegateView {
// views::BubbleDelegate overrides:
virtual gfx::Rect GetBubbleBounds() OVERRIDE;
- ShelfAlignment shelf_alignment_;
+ ShelfLayoutManager* GetShelfLayoutManagerForLauncher() const {
+ return ShelfLayoutManager::ForLauncher(
+ anchor_view()->GetWidget()->GetNativeView());
+ }
+
LauncherView* launcher_view_; // Owned by views hierarchy.
gfx::Vector2d scroll_offset_;
@@ -93,8 +89,7 @@ class OverflowBubbleView : public views::BubbleDelegateView {
};
OverflowBubbleView::OverflowBubbleView()
- : shelf_alignment_(SHELF_ALIGNMENT_BOTTOM),
- launcher_view_(NULL) {
+ : launcher_view_(NULL) {
}
OverflowBubbleView::~OverflowBubbleView() {
@@ -103,14 +98,13 @@ OverflowBubbleView::~OverflowBubbleView() {
void OverflowBubbleView::InitOverflowBubble(LauncherDelegate* delegate,
LauncherModel* model,
views::View* anchor,
- ShelfAlignment shelf_alignment,
int overflow_start_index) {
- shelf_alignment_ = shelf_alignment;
-
// Makes bubble view has a layer and clip its children layers.
SetPaintToLayer(true);
SetFillsBoundsOpaquely(false);
layer()->SetMasksToBounds(true);
+ ShelfAlignment shelf_alignment = GetShelfLayoutManagerForLauncher()->
+ GetAlignment();
launcher_view_ = new LauncherView(model, delegate, NULL);
launcher_view_->set_first_visible_index(overflow_start_index);
@@ -120,7 +114,7 @@ void OverflowBubbleView::InitOverflowBubble(LauncherDelegate* delegate,
AddChildView(launcher_view_);
set_anchor_view(anchor);
- set_arrow_location(GetBubbleArrowLocation(shelf_alignment));
+ set_arrow_location(GetBubbleArrowLocation());
set_background(NULL);
set_color(SkColorSetARGB(kLauncherBackgroundAlpha, 0, 0, 0));
set_margins(gfx::Insets(kPadding, kPadding, kPadding, kPadding));
@@ -152,7 +146,7 @@ gfx::Size OverflowBubbleView::GetPreferredSize() {
const gfx::Rect monitor_rect = Shell::GetScreen()->GetDisplayNearestPoint(
GetAnchorRect().CenterPoint()).work_area();
if (!monitor_rect.IsEmpty()) {
- if (is_horizontal_alignment()) {
+ if (IsHorizontalAlignment()) {
preferred_size.set_width(std::min(
preferred_size.width(),
static_cast<int>(monitor_rect.width() *
@@ -183,7 +177,7 @@ void OverflowBubbleView::ChildPreferredSizeChanged(views::View* child) {
}
bool OverflowBubbleView::OnMouseWheel(const ui::MouseWheelEvent& event) {
- if (is_horizontal_alignment())
+ if (IsHorizontalAlignment())
ScrollByXOffset(-event.offset());
else
ScrollByYOffset(-event.offset());
@@ -257,7 +251,6 @@ OverflowBubble::~OverflowBubble() {
void OverflowBubble::Show(LauncherDelegate* delegate,
LauncherModel* model,
views::View* anchor,
- ShelfAlignment shelf_alignment,
int overflow_start_index) {
Hide();
@@ -265,7 +258,6 @@ void OverflowBubble::Show(LauncherDelegate* delegate,
bubble_view->InitOverflowBubble(delegate,
model,
anchor,
- shelf_alignment,
overflow_start_index);
bubble_ = bubble_view;
diff --git a/ash/launcher/overflow_bubble.h b/ash/launcher/overflow_bubble.h
index 5d5e747..b1ea42e 100644
--- a/ash/launcher/overflow_bubble.h
+++ b/ash/launcher/overflow_bubble.h
@@ -5,7 +5,6 @@
#ifndef ASH_LAUNCHER_OVERFLOW_BUBBLE_H_
#define ASH_LAUNCHER_OVERFLOW_BUBBLE_H_
-#include "ash/shelf_types.h"
#include "base/basictypes.h"
#include "base/compiler_specific.h"
#include "ui/views/widget/widget_observer.h"
@@ -32,7 +31,6 @@ class OverflowBubble : public views::WidgetObserver {
void Show(LauncherDelegate* delegate,
LauncherModel* model,
views::View* anchor,
- ShelfAlignment shelf_alignment,
int overflow_start_index);
void Hide();
diff --git a/ash/launcher/overflow_button.cc b/ash/launcher/overflow_button.cc
index 0a853bb..6f007bf 100644
--- a/ash/launcher/overflow_button.cc
+++ b/ash/launcher/overflow_button.cc
@@ -4,6 +4,7 @@
#include "ash/launcher/overflow_button.h"
+#include "ash/wm/shelf_layout_manager.h"
#include "grit/ash_resources.h"
#include "grit/ash_strings.h"
#include "third_party/skia/include/core/SkPaint.h"
@@ -14,6 +15,7 @@
#include "ui/gfx/canvas.h"
#include "ui/gfx/skia_util.h"
#include "ui/gfx/transform.h"
+#include "ui/views/widget/widget.h"
namespace ash {
namespace internal {
@@ -48,7 +50,6 @@ void RotateClockwise(gfx::Transform* transform) {
OverflowButton::OverflowButton(views::ButtonListener* listener)
: CustomButton(listener),
- alignment_(SHELF_ALIGNMENT_BOTTOM),
image_(NULL) {
ResourceBundle& rb = ResourceBundle::GetSharedInstance();
image_ = rb.GetImageNamed(IDR_AURA_LAUNCHER_OVERFLOW).ToImageSkia();
@@ -62,20 +63,18 @@ OverflowButton::OverflowButton(views::ButtonListener* listener)
OverflowButton::~OverflowButton() {
}
-void OverflowButton::SetShelfAlignment(ShelfAlignment alignment) {
- if (alignment_ == alignment)
- return;
-
- alignment_ = alignment;
+void OverflowButton::OnShelfAlignmentChanged() {
SchedulePaint();
}
void OverflowButton::PaintBackground(gfx::Canvas* canvas, int alpha) {
gfx::Rect bounds(GetContentsBounds());
gfx::Rect rect(0, 0, kButtonHoverSize, kButtonHoverSize);
+ ShelfLayoutManager* shelf =
+ ShelfLayoutManager::ForLauncher(GetWidget()->GetNativeView());
// Nudge the background a little to line up right.
- if (alignment_ == SHELF_ALIGNMENT_BOTTOM) {
+ if (shelf->GetAlignment() == SHELF_ALIGNMENT_BOTTOM) {
rect.set_origin(gfx::Point(
bounds.x() + ((bounds.width() - kButtonHoverSize) / 2) - 1,
bounds.y() + kBackgroundOffset - 1));
@@ -100,6 +99,9 @@ void OverflowButton::PaintBackground(gfx::Canvas* canvas, int alpha) {
}
void OverflowButton::OnPaint(gfx::Canvas* canvas) {
+ ShelfAlignment alignment = ShelfLayoutManager::ForLauncher(
+ GetWidget()->GetNativeView())->GetAlignment();
+
if (hover_animation_->is_animating()) {
PaintBackground(
canvas,
@@ -113,7 +115,7 @@ void OverflowButton::OnPaint(gfx::Canvas* canvas) {
gfx::Transform transform;
- switch (alignment_) {
+ switch (alignment) {
case SHELF_ALIGNMENT_BOTTOM:
// Shift 1 pixel left to align with overflow bubble tip.
transform.Translate(-1, kBackgroundOffset);
@@ -132,7 +134,7 @@ void OverflowButton::OnPaint(gfx::Canvas* canvas) {
canvas->Transform(transform);
gfx::Rect rect(GetContentsBounds());
- if (alignment_ == SHELF_ALIGNMENT_BOTTOM) {
+ if (alignment == SHELF_ALIGNMENT_BOTTOM) {
canvas->DrawImageInt(*image_,
rect.x() + (rect.width() - image_->width()) / 2,
kButtonHoverSize - image_->height());
diff --git a/ash/launcher/overflow_button.h b/ash/launcher/overflow_button.h
index be24ba6..69cc795 100644
--- a/ash/launcher/overflow_button.h
+++ b/ash/launcher/overflow_button.h
@@ -23,7 +23,7 @@ class OverflowButton : public views::CustomButton {
explicit OverflowButton(views::ButtonListener* listener);
virtual ~OverflowButton();
- void SetShelfAlignment(ShelfAlignment alignment);
+ void OnShelfAlignmentChanged();
private:
void PaintBackground(gfx::Canvas* canvas, int alpha);
@@ -31,7 +31,6 @@ class OverflowButton : public views::CustomButton {
// views::View overrides:
virtual void OnPaint(gfx::Canvas* canvas) OVERRIDE;
- ShelfAlignment alignment_;
const gfx::ImageSkia* image_;
DISALLOW_COPY_AND_ASSIGN(OverflowButton);
diff --git a/ash/launcher/tabbed_launcher_button.cc b/ash/launcher/tabbed_launcher_button.cc
index 7bd5682..517607c 100644
--- a/ash/launcher/tabbed_launcher_button.cc
+++ b/ash/launcher/tabbed_launcher_button.cc
@@ -115,17 +115,20 @@ const gfx::ImageSkia*
TabbedLauncherButton* TabbedLauncherButton::Create(
views::ButtonListener* listener,
LauncherButtonHost* host,
+ ShelfLayoutManager* shelf_layout_manager,
IncognitoState is_incognito) {
- TabbedLauncherButton* button =
- new TabbedLauncherButton(listener, host, is_incognito);
+ TabbedLauncherButton* button = new TabbedLauncherButton(
+ listener, host, shelf_layout_manager, is_incognito);
button->Init();
return button;
}
-TabbedLauncherButton::TabbedLauncherButton(views::ButtonListener* listener,
- LauncherButtonHost* host,
- IncognitoState is_incognito)
- : LauncherButton(listener, host),
+TabbedLauncherButton::TabbedLauncherButton(
+ views::ButtonListener* listener,
+ LauncherButtonHost* host,
+ ShelfLayoutManager* shelf_layout_manager,
+ IncognitoState is_incognito)
+ : LauncherButton(listener, host, shelf_layout_manager),
is_incognito_(is_incognito) {
set_accessibility_focusable(true);
}
diff --git a/ash/launcher/tabbed_launcher_button.h b/ash/launcher/tabbed_launcher_button.h
index f78ec07..6eb0b9e 100644
--- a/ash/launcher/tabbed_launcher_button.h
+++ b/ash/launcher/tabbed_launcher_button.h
@@ -37,6 +37,7 @@ class TabbedLauncherButton : public LauncherButton {
static TabbedLauncherButton* Create(views::ButtonListener* listener,
LauncherButtonHost* host,
+ ShelfLayoutManager* shelf_layout_manager,
IncognitoState is_incognito);
virtual ~TabbedLauncherButton();
@@ -49,6 +50,7 @@ class TabbedLauncherButton : public LauncherButton {
protected:
TabbedLauncherButton(views::ButtonListener* listener,
LauncherButtonHost* host,
+ ShelfLayoutManager* shelf_layout_manager,
IncognitoState is_incognito);
// View override.
virtual void GetAccessibleState(ui::AccessibleViewState* state) OVERRIDE;
diff --git a/ash/root_window_controller.cc b/ash/root_window_controller.cc
index 7911f89..14b2006 100644
--- a/ash/root_window_controller.cc
+++ b/ash/root_window_controller.cc
@@ -483,7 +483,7 @@ bool RootWindowController::SetShelfAlignment(ShelfAlignment alignment) {
}
ShelfAlignment RootWindowController::GetShelfAlignment() {
- return shelf_->alignment();
+ return shelf_->GetAlignment();
}
////////////////////////////////////////////////////////////////////////////////
diff --git a/ash/wm/app_list_controller.cc b/ash/wm/app_list_controller.cc
index e0785c8..bf02979 100644
--- a/ash/wm/app_list_controller.cc
+++ b/ash/wm/app_list_controller.cc
@@ -45,19 +45,11 @@ ui::Layer* GetLayer(views::Widget* widget) {
views::BubbleBorder::ArrowLocation GetBubbleArrowLocation(
aura::Window* window) {
DCHECK(Shell::HasInstance());
- ShelfAlignment shelf_alignment = Shell::GetInstance()->GetShelfAlignment(
- window->GetRootWindow());
- switch (shelf_alignment) {
- case ash::SHELF_ALIGNMENT_BOTTOM:
- return views::BubbleBorder::BOTTOM_CENTER;
- case ash::SHELF_ALIGNMENT_LEFT:
- return views::BubbleBorder::LEFT_CENTER;
- case ash::SHELF_ALIGNMENT_RIGHT:
- return views::BubbleBorder::RIGHT_CENTER;
- default:
- NOTREACHED() << "Unknown shelf alignment " << shelf_alignment;
- return views::BubbleBorder::BOTTOM_CENTER;
- }
+ return ShelfLayoutManager::ForLauncher(window)->
+ SelectValueForShelfAlignment(
+ views::BubbleBorder::BOTTOM_CENTER,
+ views::BubbleBorder::LEFT_CENTER,
+ views::BubbleBorder::RIGHT_CENTER);
}
// Offset given |rect| towards shelf.
diff --git a/ash/wm/shelf_layout_manager.cc b/ash/wm/shelf_layout_manager.cc
index eec85b4..1937a7e 100644
--- a/ash/wm/shelf_layout_manager.cc
+++ b/ash/wm/shelf_layout_manager.cc
@@ -124,8 +124,7 @@ class ShelfLayoutManager::UpdateShelfObserver
virtual void OnImplicitAnimationsCompleted() OVERRIDE {
if (shelf_) {
- shelf_->UpdateShelfBackground(
- internal::BackgroundAnimator::CHANGE_ANIMATE);
+ shelf_->UpdateShelfBackground(BackgroundAnimator::CHANGE_ANIMATE);
}
delete this;
}
@@ -309,7 +308,7 @@ void ShelfLayoutManager::UpdateAutoHideState() {
void ShelfLayoutManager::SetWindowOverlapsShelf(bool value) {
window_overlaps_shelf_ = value;
- UpdateShelfBackground(internal::BackgroundAnimator::CHANGE_ANIMATE);
+ UpdateShelfBackground(BackgroundAnimator::CHANGE_ANIMATE);
}
void ShelfLayoutManager::AddObserver(Observer* observer) {
@@ -328,12 +327,12 @@ void ShelfLayoutManager::StartGestureDrag(const ui::GestureEvent& gesture) {
gesture_drag_amount_ = 0.f;
gesture_drag_auto_hide_state_ = visibility_state() == SHELF_AUTO_HIDE ?
auto_hide_state() : SHELF_AUTO_HIDE_SHOWN;
- UpdateShelfBackground(internal::BackgroundAnimator::CHANGE_ANIMATE);
+ UpdateShelfBackground(BackgroundAnimator::CHANGE_ANIMATE);
}
ShelfLayoutManager::DragState ShelfLayoutManager::UpdateGestureDrag(
const ui::GestureEvent& gesture) {
- bool horizontal = alignment() == SHELF_ALIGNMENT_BOTTOM;
+ bool horizontal = alignment_ == SHELF_ALIGNMENT_BOTTOM;
gesture_drag_amount_ += horizontal ? gesture.details().scroll_y() :
gesture.details().scroll_x();
LayoutShelf();
@@ -359,7 +358,7 @@ ShelfLayoutManager::DragState ShelfLayoutManager::UpdateGestureDrag(
}
void ShelfLayoutManager::CompleteGestureDrag(const ui::GestureEvent& gesture) {
- bool horizontal = alignment() == SHELF_ALIGNMENT_BOTTOM;
+ bool horizontal = alignment_ == SHELF_ALIGNMENT_BOTTOM;
bool should_change = false;
if (gesture.type() == ui::ET_GESTURE_SCROLL_END) {
// The visibility of the shelf changes only if the shelf was dragged X%
@@ -373,7 +372,7 @@ void ShelfLayoutManager::CompleteGestureDrag(const ui::GestureEvent& gesture) {
should_change = drag_ratio > kDragHideThreshold;
} else {
bool correct_direction = false;
- switch (alignment()) {
+ switch (alignment_) {
case SHELF_ALIGNMENT_BOTTOM:
case SHELF_ALIGNMENT_RIGHT:
correct_direction = gesture_drag_amount_ < 0;
@@ -391,7 +390,7 @@ void ShelfLayoutManager::CompleteGestureDrag(const ui::GestureEvent& gesture) {
} else {
if (horizontal)
should_change = gesture.details().velocity_y() < 0;
- else if (alignment() == SHELF_ALIGNMENT_LEFT)
+ else if (alignment_ == SHELF_ALIGNMENT_LEFT)
should_change = gesture.details().velocity_x() > 0;
else
should_change = gesture.details().velocity_x() < 0;
@@ -433,7 +432,7 @@ void ShelfLayoutManager::CancelGestureDrag() {
status_settings(GetLayer(status_area_widget_)->GetAnimator());
LayoutShelf();
UpdateVisibilityState();
- UpdateShelfBackground(internal::BackgroundAnimator::CHANGE_ANIMATE);
+ UpdateShelfBackground(BackgroundAnimator::CHANGE_ANIMATE);
}
////////////////////////////////////////////////////////////////////////////////
@@ -477,6 +476,15 @@ void ShelfLayoutManager::OnWindowActivated(aura::Window* active,
UpdateAutoHideStateNow();
}
+bool ShelfLayoutManager::IsHorizontalAlignment() const {
+ return alignment_ == SHELF_ALIGNMENT_BOTTOM;
+}
+
+// static
+ShelfLayoutManager* ShelfLayoutManager::ForLauncher(aura::Window* window) {
+ return RootWindowController::ForLauncher(window)->shelf();
+}
+
////////////////////////////////////////////////////////////////////////////////
// ShelfLayoutManager, private:
@@ -517,12 +525,11 @@ void ShelfLayoutManager::SetState(ShelfVisibilityState visibility_state) {
// Animating the background when transitioning from auto-hide & hidden to
// visible is janky. Update the background immediately in this case.
- internal::BackgroundAnimator::ChangeType change_type =
+ BackgroundAnimator::ChangeType change_type =
(state_.visibility_state == SHELF_AUTO_HIDE &&
state_.auto_hide_state == SHELF_AUTO_HIDE_HIDDEN &&
state.visibility_state == SHELF_VISIBLE) ?
- internal::BackgroundAnimator::CHANGE_IMMEDIATE :
- internal::BackgroundAnimator::CHANGE_ANIMATE;
+ BackgroundAnimator::CHANGE_IMMEDIATE : BackgroundAnimator::CHANGE_ANIMATE;
StopAnimating();
State old_state = state_;
@@ -694,7 +701,7 @@ void ShelfLayoutManager::CalculateTargetBounds(
void ShelfLayoutManager::UpdateTargetBoundsForGesture(
TargetBounds* target_bounds) const {
CHECK_EQ(GESTURE_DRAG_IN_PROGRESS, gesture_drag_status_);
- bool horizontal = alignment() == SHELF_ALIGNMENT_BOTTOM;
+ bool horizontal = alignment_ == SHELF_ALIGNMENT_BOTTOM;
int resistance_free_region = 0;
if (gesture_drag_auto_hide_state_ == SHELF_AUTO_HIDE_HIDDEN &&
@@ -713,7 +720,7 @@ void ShelfLayoutManager::UpdateTargetBoundsForGesture(
bool resist = false;
if (horizontal)
resist = gesture_drag_amount_ < -resistance_free_region;
- else if (alignment() == SHELF_ALIGNMENT_LEFT)
+ else if (alignment_ == SHELF_ALIGNMENT_LEFT)
resist = gesture_drag_amount_ > resistance_free_region;
else
resist = gesture_drag_amount_ < -resistance_free_region;
@@ -752,20 +759,20 @@ void ShelfLayoutManager::UpdateTargetBoundsForGesture(
}
} else {
// Move the launcher with the gesture.
- if (alignment() == SHELF_ALIGNMENT_RIGHT)
+ if (alignment_ == SHELF_ALIGNMENT_RIGHT)
target_bounds->launcher_bounds_in_root.Offset(translate, 0);
- if ((translate > 0 && alignment() == SHELF_ALIGNMENT_RIGHT) ||
- (translate < 0 && alignment() == SHELF_ALIGNMENT_LEFT)) {
+ if ((translate > 0 && alignment_ == SHELF_ALIGNMENT_RIGHT) ||
+ (translate < 0 && alignment_ == SHELF_ALIGNMENT_LEFT)) {
// When dragging towards the edge, the statusbar should move.
target_bounds->status_bounds_in_root.Offset(translate, 0);
} else {
// When dragging away from the edge, the launcher width should increase.
- float move = alignment() == SHELF_ALIGNMENT_RIGHT ?
+ float move = alignment_ == SHELF_ALIGNMENT_RIGHT ?
std::max(translate, -static_cast<float>(resistance_free_region)) :
std::min(translate, static_cast<float>(resistance_free_region));
- if (alignment() == SHELF_ALIGNMENT_RIGHT) {
+ if (alignment_ == SHELF_ALIGNMENT_RIGHT) {
target_bounds->launcher_bounds_in_root.set_width(
target_bounds->launcher_bounds_in_root.width() + move - translate);
} else {
diff --git a/ash/wm/shelf_layout_manager.h b/ash/wm/shelf_layout_manager.h
index 2666e8c..0a4a018 100644
--- a/ash/wm/shelf_layout_manager.h
+++ b/ash/wm/shelf_layout_manager.h
@@ -11,6 +11,7 @@
#include "ash/shell_observer.h"
#include "base/basictypes.h"
#include "base/compiler_specific.h"
+#include "base/logging.h"
#include "base/observer_list.h"
#include "base/timer.h"
#include "ui/aura/layout_manager.h"
@@ -76,7 +77,7 @@ class ASH_EXPORT ShelfLayoutManager :
// Sets the alignment. Returns true if the alignment is changed. Otherwise,
// returns false.
bool SetAlignment(ShelfAlignment alignment);
- ShelfAlignment alignment() const { return alignment_; }
+ ShelfAlignment GetAlignment() const { return alignment_; }
void set_workspace_controller(WorkspaceController* controller) {
workspace_controller_ = controller;
@@ -156,6 +157,36 @@ class ASH_EXPORT ShelfLayoutManager :
virtual void OnWindowActivated(aura::Window* active,
aura::Window* old_active) OVERRIDE;
+ // TODO(harrym|oshima): These templates will be moved to
+ // new Shelf class.
+ // A helper function that provides a shortcut for choosing
+ // values specific to a shelf alignment.
+ template<typename T>
+ T SelectValueForShelfAlignment(T bottom, T left, T right) const {
+ switch (alignment_) {
+ case SHELF_ALIGNMENT_BOTTOM:
+ return bottom;
+ case SHELF_ALIGNMENT_LEFT:
+ return left;
+ case SHELF_ALIGNMENT_RIGHT:
+ return right;
+ }
+ NOTREACHED();
+ return right;
+ }
+
+ template<typename T>
+ T PrimaryAxisValue(T horizontal, T vertical) const {
+ return IsHorizontalAlignment() ? horizontal : vertical;
+ }
+
+ // Is the shelf's alignment horizontal?
+ bool IsHorizontalAlignment() const;
+
+ // Returns a ShelfLayoutManager on the display which has a launcher for
+ // given |window|. See RootWindowController::ForLauncher for more info.
+ static ShelfLayoutManager* ForLauncher(aura::Window* window);
+
private:
class AutoHideEventFilter;
class UpdateShelfObserver;
@@ -234,10 +265,6 @@ class ASH_EXPORT ShelfLayoutManager :
int GetWorkAreaSize(const State& state, int size) const;
- int axis_position(int x, int y) const {
- return alignment_ == SHELF_ALIGNMENT_BOTTOM ? y : x;
- }
-
// The RootWindow is cached so that we don't invoke Shell::GetInstance() from
// our destructor. We avoid that as at the time we're deleted Shell is being
// deleted too.