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

Unified Diff: cc/animation/animation_player.cc

Issue 947033002: CC Animations: Establish AnimationHost, AnimationTimeline and AnimationPlayer (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Remove kEnableNewCompositorAnimations. Created 5 years, 9 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: cc/animation/animation_player.cc
diff --git a/cc/animation/animation_player.cc b/cc/animation/animation_player.cc
new file mode 100644
index 0000000000000000000000000000000000000000..5be039544f2a46f138a3ca1e4200763d7f0dfa3b
--- /dev/null
+++ b/cc/animation/animation_player.cc
@@ -0,0 +1,245 @@
+// Copyright 2015 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "cc/animation/animation_player.h"
+
+#include "cc/animation/animation_timeline.h"
+#include "cc/layers/layer.h"
+#include "cc/trees/layer_tree_mutators_client.h"
+
+namespace cc {
+
+class AnimationPlayer::ValueObserver : public LayerAnimationValueObserver {
+ public:
+ ValueObserver(AnimationPlayer* player, bool is_active)
+ : player_(player), is_active_(is_active) {
+ DCHECK(player_);
+ }
+
+ // LayerAnimationValueObserver implementation.
+ void OnFilterAnimated(const FilterOperations& filters) override {
+ player_->SetFilterMutated(is_active_, filters);
+ }
+
+ void OnOpacityAnimated(float opacity) override {
+ player_->SetOpacityMutated(is_active_, opacity);
+ }
+
+ void OnTransformAnimated(const gfx::Transform& transform) override {
+ player_->SetTransformMutated(is_active_, transform);
+ }
+
+ void OnScrollOffsetAnimated(const gfx::ScrollOffset& scroll_offset) override {
+ // TODO(loyso): implement it.
+ }
+
+ void OnAnimationWaitingForDeletion() override {
+ // TODO(loyso): implement it.
+ }
+
+ bool IsActive() const override { return is_active_; }
+
+ private:
+ AnimationPlayer* player_;
+ bool is_active_;
+
+ DISALLOW_COPY_AND_ASSIGN(ValueObserver);
+};
+
+scoped_refptr<AnimationPlayer> AnimationPlayer::Create(int id) {
+ return make_scoped_refptr(new AnimationPlayer(id));
+}
+
+AnimationPlayer::AnimationPlayer(int id)
+ : animation_timeline_(),
+ layer_animation_delegate_(),
+ id_(id),
+ layer_id_(0) {
+ DCHECK(id_);
+}
+
+AnimationPlayer::~AnimationPlayer() {
+ DCHECK(!animation_timeline_);
+ DCHECK(!layer_animation_controller_);
+}
+
+scoped_refptr<AnimationPlayer> AnimationPlayer::CreateImplInstance() const {
+ scoped_refptr<AnimationPlayer> to_return = AnimationPlayer::Create(id());
+ return to_return;
+}
+
+void AnimationPlayer::SetAnimationTimeline(AnimationTimeline* timeline) {
+ animation_timeline_ = timeline;
+ if (layer_animation_controller_)
+ layer_animation_controller_->SetAnimationRegistrar(
+ animation_timeline_
+ ? animation_timeline_->layer_tree_mutators_client()
+ ->GetAnimationRegistrar()
+ : nullptr);
+}
+
+void AnimationPlayer::set_layer_animation_delegate(
+ AnimationDelegate* delegate) {
+ layer_animation_delegate_ = delegate;
+ if (layer_animation_controller_)
+ layer_animation_controller_->set_layer_animation_delegate(delegate);
+}
+
+void AnimationPlayer::AttachLayer(int layer_id) {
+ DCHECK_EQ(layer_id_, 0);
+ DCHECK_NE(layer_id, 0);
+ DCHECK(animation_timeline_);
+ layer_id_ = layer_id;
+
+ layer_animation_controller_ = LayerAnimationController::Create(layer_id_);
+ layer_animation_controller_->SetAnimationRegistrar(
+ animation_timeline_->layer_tree_mutators_client()
+ ->GetAnimationRegistrar());
+
+ if (animation_timeline_->layer_tree_mutators_client()->IsLayerInActiveTree(
+ layer_id_))
+ CreateActiveValueObserver();
+ if (animation_timeline_->layer_tree_mutators_client()->IsLayerInPendingTree(
+ layer_id_))
+ CreatePendingValueObserver();
+
+ animation_timeline_->RegisterPlayerForLayer(layer_id_, this);
+}
+
+void AnimationPlayer::DetachLayer() {
+ DCHECK_NE(layer_id_, 0);
+ DCHECK(layer_animation_controller_);
+
+ if (animation_timeline_)
+ animation_timeline_->UnregisterPlayerForLayer(layer_id_, this);
+
+ DestroyPendingValueObserver();
+ DestroyActiveValueObserver();
+
+ layer_animation_controller_ = nullptr;
+ layer_id_ = 0;
+}
+
+void AnimationPlayer::LayerImplRegistered(int layer_id, bool is_active_tree) {
+ is_active_tree ? CreateActiveValueObserver() : CreatePendingValueObserver();
+}
+
+void AnimationPlayer::LayerImplUnregistered(int layer_id, bool is_active_tree) {
+ is_active_tree ? DestroyActiveValueObserver() : DestroyPendingValueObserver();
+}
+
+void AnimationPlayer::AddAnimation(scoped_ptr<Animation> animation) {
+ DCHECK(layer_animation_controller_);
+ layer_animation_controller_->AddAnimation(animation.Pass());
+ SetNeedsCommit();
+}
+
+void AnimationPlayer::PauseAnimation(int animation_id, double time_offset) {
+ DCHECK(layer_animation_controller_);
+ layer_animation_controller_->PauseAnimation(
+ animation_id, base::TimeDelta::FromSecondsD(time_offset));
+ SetNeedsCommit();
+}
+
+void AnimationPlayer::RemoveAnimation(int animation_id) {
+ DCHECK(layer_animation_controller_);
+ layer_animation_controller_->RemoveAnimation(animation_id);
+ SetNeedsCommit();
+}
+
+void AnimationPlayer::PushPropertiesTo(AnimationPlayer* player_impl) {
+ if (!layer_animation_controller()) {
+ if (player_impl->layer_animation_controller())
+ player_impl->DetachLayer();
+ return;
+ }
+
+ DCHECK_NE(layer_id_, 0);
+ if (!player_impl->layer_animation_controller())
+ player_impl->AttachLayer(layer_id_);
+
+ DCHECK(player_impl->layer_animation_controller());
+ layer_animation_controller_->PushAnimationUpdatesTo(
+ player_impl->layer_animation_controller());
+}
+
+void AnimationPlayer::SetNeedsCommit() {
+ DCHECK(animation_timeline_);
+ animation_timeline_->layer_tree_mutators_client()->SetMutatorsNeedCommit();
+}
+
+void AnimationPlayer::SetFilterMutated(bool active_tree,
+ const FilterOperations& filters) {
+ DCHECK(layer_id_);
+ if (animation_timeline()) {
+ DCHECK(animation_timeline()->layer_tree_mutators_client());
+ animation_timeline()->layer_tree_mutators_client()->SetLayerFilterMutated(
+ layer_id_, active_tree, filters);
+ }
+}
+
+void AnimationPlayer::SetOpacityMutated(bool active_tree, float opacity) {
+ DCHECK(layer_id_);
+ if (animation_timeline()) {
+ DCHECK(animation_timeline()->layer_tree_mutators_client());
+ animation_timeline()->layer_tree_mutators_client()->SetLayerOpacityMutated(
+ layer_id_, active_tree, opacity);
+ }
+}
+
+void AnimationPlayer::SetTransformMutated(bool active_tree,
+ const gfx::Transform& transform) {
+ DCHECK(layer_id_);
+ if (animation_timeline()) {
+ DCHECK(animation_timeline()->layer_tree_mutators_client());
+ animation_timeline()
+ ->layer_tree_mutators_client()
+ ->SetLayerTransformMutated(layer_id_, active_tree, transform);
+ }
+}
+
+void AnimationPlayer::CreateActiveValueObserver() {
+ DCHECK(layer_animation_controller_);
+ DCHECK(!active_value_observer_);
+ active_value_observer_ = make_scoped_ptr(new ValueObserver(this, true));
+ layer_animation_controller_->AddValueObserver(active_value_observer_.get());
+
+ layer_animation_controller_->set_value_provider(this);
+ layer_animation_controller_->set_layer_animation_delegate(
+ layer_animation_delegate_);
+}
+
+void AnimationPlayer::DestroyActiveValueObserver() {
+ DCHECK(layer_animation_controller_);
+ if (active_value_observer_)
+ layer_animation_controller_->RemoveValueObserver(
+ active_value_observer_.get());
+ active_value_observer_ = nullptr;
+
+ layer_animation_controller_->remove_value_provider(this);
+ layer_animation_controller_->remove_layer_animation_delegate(
+ layer_animation_delegate_);
+}
+
+void AnimationPlayer::CreatePendingValueObserver() {
+ DCHECK(layer_animation_controller_);
+ DCHECK(!pending_value_observer_);
+ pending_value_observer_ = make_scoped_ptr(new ValueObserver(this, false));
+ layer_animation_controller_->AddValueObserver(pending_value_observer_.get());
+}
+
+void AnimationPlayer::DestroyPendingValueObserver() {
+ DCHECK(layer_animation_controller_);
+ if (pending_value_observer_)
+ layer_animation_controller_->RemoveValueObserver(
+ pending_value_observer_.get());
+ pending_value_observer_ = nullptr;
+}
+
+gfx::ScrollOffset AnimationPlayer::ScrollOffsetForAnimation() const {
+ // TODO(loyso): implement it.
+ return gfx::ScrollOffset();
+}
+
+} // namespace cc

Powered by Google App Engine
This is Rietveld 408576698