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

Unified Diff: chrome/browser/ui/search/toolbar_search_animator.cc

Issue 10816027: alternate ntp: toolbar background and separator animation (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fix android build break Created 8 years, 4 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
Index: chrome/browser/ui/search/toolbar_search_animator.cc
diff --git a/chrome/browser/ui/search/toolbar_search_animator.cc b/chrome/browser/ui/search/toolbar_search_animator.cc
index c8160fb047e1318caf60f21b74858725baffa66d..919c6438817ab80bccefbc301945640c585672fd 100644
--- a/chrome/browser/ui/search/toolbar_search_animator.cc
+++ b/chrome/browser/ui/search/toolbar_search_animator.cc
@@ -9,7 +9,7 @@
#include "chrome/browser/ui/search/toolbar_search_animator_observer.h"
#include "chrome/browser/ui/tab_contents/tab_contents.h"
#include "chrome/browser/ui/webui/instant_ui.h"
-#include "ui/base/animation/slide_animation.h"
+#include "ui/base/animation/multi_animation.h"
namespace {
@@ -26,33 +26,21 @@ namespace search {
ToolbarSearchAnimator::ToolbarSearchAnimator(SearchModel* search_model)
: search_model_(search_model),
- animate_state_(ANIMATE_STATE_NONE) {
+ background_change_delay_ms_(kBackgroundChangeDelayMs),
+ background_change_duration_ms_(kBackgroundChangeDurationMs) {
search_model_->AddObserver(this);
}
ToolbarSearchAnimator::~ToolbarSearchAnimator() {
+ if (background_animation_.get())
+ background_animation_->Stop();
search_model_->RemoveObserver(this);
}
-void ToolbarSearchAnimator::GetCurrentBackgroundState(
- BackgroundState* background_state,
- double* search_background_opacity) const {
- // Should only be called for SEARCH mode.
- DCHECK(search_model_->mode().is_search());
- *background_state = BACKGROUND_STATE_DEFAULT;
- *search_background_opacity = -1.0f;
- switch (animate_state_) {
- case ANIMATE_STATE_WAITING:
- *background_state = BACKGROUND_STATE_NTP;
- break;
- case ANIMATE_STATE_RUNNING:
- *background_state = BACKGROUND_STATE_NTP_SEARCH;
- *search_background_opacity = background_animation_->CurrentValueBetween(
- kMinOpacity, kMaxOpacity);
- break;
- case ANIMATE_STATE_NONE:
- break;
- }
+double ToolbarSearchAnimator::GetGradientOpacity() const {
+ if (background_animation_.get() && background_animation_->is_animating())
+ return background_animation_->CurrentValueBetween(kMinOpacity, kMaxOpacity);
+ return search_model_->mode().is_ntp() ? kMinOpacity : kMaxOpacity;
}
void ToolbarSearchAnimator::FinishAnimation(TabContents* tab_contents) {
@@ -69,68 +57,72 @@ void ToolbarSearchAnimator::RemoveObserver(
observers_.RemoveObserver(observer);
}
-void ToolbarSearchAnimator::ModeChanged(const Mode& mode) {
- int delay_ms = kBackgroundChangeDelayMs *
- InstantUI::GetSlowAnimationScaleFactor();
- if (mode.is_search() && mode.animate &&
- animate_state_ == ANIMATE_STATE_NONE) {
- background_change_timer_.Start(
- FROM_HERE,
- base::TimeDelta::FromMilliseconds(delay_ms),
- this,
- &ToolbarSearchAnimator::StartBackgroundChange);
- animate_state_ = ANIMATE_STATE_WAITING;
+void ToolbarSearchAnimator::ModeChanged(const Mode& old_mode,
+ const Mode& new_mode) {
+ // If the mode transitions from |NTP| to |SEARCH| and we're not animating
+ // background, start fading in gradient background.
+ // TODO(kuan): check with UX folks if we need to animate from gradient to flat
+ // when mode transitions from |SEARCH| or |DEFAULT| to |NTP|.
+ if (new_mode.animate && old_mode.is_ntp() && new_mode.is_search() &&
+ !(background_animation_.get() && background_animation_->is_animating())) {
+ StartBackgroundChange();
return;
}
- // For all other cases, reset |animate_state_| and stop timer or animation.
+
+ // If the mode transitions from |SEARCH| to |DEFAULT| and we're already
+ // animating background, let animation continue.
+ if (new_mode.animate && old_mode.is_search() && new_mode.is_default() &&
+ background_animation_.get() && background_animation_->is_animating()) {
+ return;
+ }
+
+ // For all other cases, reset animation.
// Stopping animation will jump to the end of it.
Reset(NULL);
}
void ToolbarSearchAnimator::AnimationProgressed(
const ui::Animation* animation) {
- DCHECK_EQ(animation, background_animation_.get());
- animate_state_ = ANIMATE_STATE_RUNNING;
+ DCHECK_EQ(background_animation_.get(), animation);
FOR_EACH_OBSERVER(ToolbarSearchAnimatorObserver, observers_,
OnToolbarBackgroundAnimatorProgressed());
}
void ToolbarSearchAnimator::AnimationEnded(const ui::Animation* animation) {
- DCHECK_EQ(animation, background_animation_.get());
- // Only notify observers via OnToolbarBackgroundAnimatorProgressed if the
- // animation has runs its full course i.e |animate_state_| is still
- // ANIMATE_STATE_RUNNING.
- // Animation that is canceled, i.e. |animate_state_| has been set to
- // ANIMATE_STATE_NONE in Reset, should notify observers via
- // OnToolbarBackgroundAnimatorCanceled.
- if (animate_state_ == ANIMATE_STATE_RUNNING) {
- animate_state_ = ANIMATE_STATE_NONE;
- FOR_EACH_OBSERVER(ToolbarSearchAnimatorObserver, observers_,
- OnToolbarBackgroundAnimatorProgressed());
- }
+ // We only get this callback when |animation| has run its full course.
+ // If animation was canceled (in Reset()), we won't get an AnimationEnded()
+ // callback because we had cleared the animation's delegate in Reset().
+ DCHECK_EQ(background_animation_.get(), animation);
+ FOR_EACH_OBSERVER(ToolbarSearchAnimatorObserver, observers_,
+ OnToolbarBackgroundAnimatorProgressed());
+}
+
+void ToolbarSearchAnimator::InitBackgroundAnimation() {
+ ui::MultiAnimation::Parts parts;
+ parts.push_back(ui::MultiAnimation::Part(
+ background_change_delay_ms_ * InstantUI::GetSlowAnimationScaleFactor(),
+ ui::Tween::ZERO));
+ parts.push_back(ui::MultiAnimation::Part(
+ background_change_duration_ms_ * InstantUI::GetSlowAnimationScaleFactor(),
+ ui::Tween::LINEAR));
+ background_animation_.reset(new ui::MultiAnimation(parts));
+ background_animation_->set_continuous(false);
+ background_animation_->set_delegate(this);
}
void ToolbarSearchAnimator::StartBackgroundChange() {
- if (!background_animation_.get()) {
- background_animation_.reset(new ui::SlideAnimation(this));
- background_animation_->SetTweenType(ui::Tween::LINEAR);
- background_animation_->SetSlideDuration(
- kBackgroundChangeDurationMs * InstantUI::GetSlowAnimationScaleFactor());
- }
- background_animation_->Reset(0.0);
- background_animation_->Show();
+ InitBackgroundAnimation();
+ background_animation_->Start();
}
void ToolbarSearchAnimator::Reset(TabContents* tab_contents) {
- bool notify_observers = animate_state_ != ANIMATE_STATE_NONE;
- animate_state_ = ANIMATE_STATE_NONE;
- background_change_timer_.Stop();
- // If animation is still running, stopping it will trigger AnimationEnded
- // where we've prevented from notifying observers via BackgroundChanged;
- // see comments in AnimationEnded.
- if (background_animation_.get())
- background_animation_->Stop();
- if (notify_observers) {
+ bool notify_background_observers =
+ background_animation_.get() && background_animation_->is_animating();
+
+ background_animation_.reset();
+
+ // Notify observers of animation cancelation.
+ if (notify_background_observers) {
FOR_EACH_OBSERVER(ToolbarSearchAnimatorObserver, observers_,
OnToolbarBackgroundAnimatorCanceled(tab_contents));
}
« no previous file with comments | « chrome/browser/ui/search/toolbar_search_animator.h ('k') | chrome/browser/ui/search/toolbar_search_animator_observer.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698