Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(8470)

Unified Diff: ash/launcher/launcher_button.cc

Issue 10386212: Add new attention state to launcher (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « ash/launcher/launcher_button.h ('k') | ash/launcher/launcher_types.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ash/launcher/launcher_button.cc
diff --git a/ash/launcher/launcher_button.cc b/ash/launcher/launcher_button.cc
index 8701f30dfe279189efb1289484a94522589b9b68..d6558307e7cc9e72db3514e6f4fc5b8da8ed03c1 100644
--- a/ash/launcher/launcher_button.cc
+++ b/ash/launcher/launcher_button.cc
@@ -9,6 +9,8 @@
#include "ash/launcher/launcher_button_host.h"
#include "grit/ui_resources.h"
#include "ui/base/accessibility/accessible_view_state.h"
+#include "ui/base/animation/animation_delegate.h"
+#include "ui/base/animation/throb_animation.h"
#include "ui/base/resource/resource_bundle.h"
#include "ui/compositor/layer.h"
#include "ui/compositor/scoped_layer_animation_settings.h"
@@ -27,14 +29,7 @@ const int kActiveBarColor = 0xe6ffffff;
const int kInactiveBarColor = 0x80ffffff;
const int kHopUpMS = 200;
const int kHopDownMS = 200;
-
-// Used to allow Mouse...() messages to go to the parent view.
-class MouseIgnoredImageView : public views::ImageView {
- public:
- bool HitTest(const gfx::Point& l) const OVERRIDE {
- return false;
- }
-};
+const int kAttentionThrobDurationMS = 2000;
bool ShouldHop(int state) {
return state & ash::internal::LauncherButton::STATE_HOVERED ||
@@ -47,6 +42,47 @@ namespace ash {
namespace internal {
+class LauncherButton::BarView : public views::ImageView,
+ public ui::AnimationDelegate {
+ public:
+ BarView() : animation_(new ui::ThrobAnimation(this)) {
sky 2012/05/18 16:38:30 ALLOW_THIS_IN_INITIALIAZER_LIST
+ animation_->SetThrobDuration(kAttentionThrobDurationMS);
+ animation_->SetTweenType(ui::Tween::SMOOTH_IN_OUT);
+ }
+
+ // View overrides.
+ bool HitTest(const gfx::Point& l) const OVERRIDE {
+ // Allow Mouse...() messages to go to the parent view.
+ return false;
+ }
+
+ void OnPaint(gfx::Canvas* canvas) {
sky 2012/05/18 16:38:30 virtual OVERRIDE
+ if (animation_->is_animating()) {
+ int alpha = animation_->CurrentValueBetween(0, 255);
+ canvas->SaveLayerAlpha(alpha);
+ views::ImageView::OnPaint(canvas);
+ canvas->Restore();
+ } else {
+ views::ImageView::OnPaint(canvas);
+ }
+ }
+
+ // ui::AnimationDelegate overrides.
+ void AnimationProgressed(const ui::Animation* animation) {
sky 2012/05/18 16:38:30 virtual OVERRIDE
+ SchedulePaint();
+ }
+
+ void ShowAttention(bool show) {
+ if (show)
+ animation_->StartThrobbing(-1);
+ else
+ animation_->Reset();
+ }
+
+ private:
+ scoped_ptr<ui::ThrobAnimation> animation_;
sky 2012/05/18 16:38:30 Since you create this in the constructor, no need
+};
sky 2012/05/18 16:38:30 DISALLOW_...
+
LauncherButton::IconView::IconView() : icon_size_(kIconHeight) {
}
@@ -69,7 +105,7 @@ LauncherButton::LauncherButton(views::ButtonListener* listener,
: CustomButton(listener),
host_(host),
icon_view_(NULL),
- bar_(new MouseIgnoredImageView),
+ bar_(new BarView),
state_(STATE_NORMAL) {
set_accessibility_focusable(true);
bar_->SetHorizontalAlignment(views::ImageView::CENTER);
@@ -152,6 +188,8 @@ void LauncherButton::AddState(State state) {
state_ |= state;
UpdateState();
}
+ if (state & STATE_ATTENTION)
+ bar_->ShowAttention(true);
}
}
@@ -169,6 +207,8 @@ void LauncherButton::ClearState(State state) {
state_ &= ~state;
UpdateState();
}
+ if (state & STATE_ATTENTION)
+ bar_->ShowAttention(false);
}
}
@@ -257,10 +297,10 @@ void LauncherButton::UpdateState() {
int bar_id;
bar_->SetVisible(true);
- if (state_ & STATE_HOVERED)
- bar_id = IDR_AURA_LAUNCHER_UNDERLINE_HOVER;
- else if (state_ & STATE_ACTIVE)
+ if (state_ & STATE_ACTIVE || state_ & STATE_ATTENTION)
bar_id = IDR_AURA_LAUNCHER_UNDERLINE_ACTIVE;
+ else if (state_ & STATE_HOVERED)
+ bar_id = IDR_AURA_LAUNCHER_UNDERLINE_HOVER;
else
bar_id = IDR_AURA_LAUNCHER_UNDERLINE_RUNNING;
« no previous file with comments | « ash/launcher/launcher_button.h ('k') | ash/launcher/launcher_types.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698