| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "cc/animation/element_animations.h" | 5 #include "cc/animation/element_animations.h" |
| 6 | 6 |
| 7 #include <stddef.h> | 7 #include <stddef.h> |
| 8 | 8 |
| 9 #include <algorithm> | 9 #include <algorithm> |
| 10 | 10 |
| (...skipping 10 matching lines...) Expand all Loading... |
| 21 | 21 |
| 22 namespace cc { | 22 namespace cc { |
| 23 | 23 |
| 24 scoped_refptr<ElementAnimations> ElementAnimations::Create() { | 24 scoped_refptr<ElementAnimations> ElementAnimations::Create() { |
| 25 return make_scoped_refptr(new ElementAnimations()); | 25 return make_scoped_refptr(new ElementAnimations()); |
| 26 } | 26 } |
| 27 | 27 |
| 28 ElementAnimations::ElementAnimations() | 28 ElementAnimations::ElementAnimations() |
| 29 : players_list_(new PlayersList()), | 29 : players_list_(new PlayersList()), |
| 30 animation_host_(), | 30 animation_host_(), |
| 31 layer_id_(), | 31 element_id_(), |
| 32 is_active_(false), | 32 is_active_(false), |
| 33 has_element_in_active_list_(false), | 33 has_element_in_active_list_(false), |
| 34 has_element_in_pending_list_(false), | 34 has_element_in_pending_list_(false), |
| 35 needs_to_start_animations_(false), | 35 needs_to_start_animations_(false), |
| 36 scroll_offset_animation_was_interrupted_(false), | 36 scroll_offset_animation_was_interrupted_(false), |
| 37 potentially_animating_transform_for_active_elements_(false), | 37 potentially_animating_transform_for_active_elements_(false), |
| 38 potentially_animating_transform_for_pending_elements_(false) {} | 38 potentially_animating_transform_for_pending_elements_(false) {} |
| 39 | 39 |
| 40 ElementAnimations::~ElementAnimations() {} | 40 ElementAnimations::~ElementAnimations() {} |
| 41 | 41 |
| 42 void ElementAnimations::SetAnimationHost(AnimationHost* host) { | 42 void ElementAnimations::SetAnimationHost(AnimationHost* host) { |
| 43 animation_host_ = host; | 43 animation_host_ = host; |
| 44 } | 44 } |
| 45 | 45 |
| 46 void ElementAnimations::SetLayerId(int layer_id) { | 46 void ElementAnimations::SetElementId(ElementId element_id) { |
| 47 layer_id_ = layer_id; | 47 element_id_ = element_id; |
| 48 } | 48 } |
| 49 | 49 |
| 50 void ElementAnimations::InitAffectedElementTypes() { | 50 void ElementAnimations::InitAffectedElementTypes() { |
| 51 DCHECK(layer_id_); | 51 DCHECK(element_id_); |
| 52 DCHECK(animation_host_); | 52 DCHECK(animation_host_); |
| 53 | 53 |
| 54 UpdateActivation(FORCE_ACTIVATION); | 54 UpdateActivation(FORCE_ACTIVATION); |
| 55 | 55 |
| 56 DCHECK(animation_host_->mutator_host_client()); | 56 DCHECK(animation_host_->mutator_host_client()); |
| 57 if (animation_host_->mutator_host_client()->IsLayerInTree( | 57 if (animation_host_->mutator_host_client()->IsLayerInTree( |
| 58 layer_id_, LayerTreeType::ACTIVE)) { | 58 element_id_, LayerTreeType::ACTIVE)) { |
| 59 set_has_element_in_active_list(true); | 59 set_has_element_in_active_list(true); |
| 60 } | 60 } |
| 61 if (animation_host_->mutator_host_client()->IsLayerInTree( | 61 if (animation_host_->mutator_host_client()->IsLayerInTree( |
| 62 layer_id_, LayerTreeType::PENDING)) { | 62 element_id_, LayerTreeType::PENDING)) { |
| 63 set_has_element_in_pending_list(true); | 63 set_has_element_in_pending_list(true); |
| 64 } | 64 } |
| 65 } | 65 } |
| 66 | 66 |
| 67 void ElementAnimations::ClearAffectedElementTypes() { | 67 void ElementAnimations::ClearAffectedElementTypes() { |
| 68 DCHECK(animation_host_); | 68 DCHECK(animation_host_); |
| 69 | 69 |
| 70 if (has_element_in_active_list()) | 70 if (has_element_in_active_list()) |
| 71 OnTransformIsPotentiallyAnimatingChanged(LayerTreeType::ACTIVE, false); | 71 OnTransformIsPotentiallyAnimatingChanged(LayerTreeType::ACTIVE, false); |
| 72 set_has_element_in_active_list(false); | 72 set_has_element_in_active_list(false); |
| 73 | 73 |
| 74 if (has_element_in_pending_list()) | 74 if (has_element_in_pending_list()) |
| 75 OnTransformIsPotentiallyAnimatingChanged(LayerTreeType::PENDING, false); | 75 OnTransformIsPotentiallyAnimatingChanged(LayerTreeType::PENDING, false); |
| 76 set_has_element_in_pending_list(false); | 76 set_has_element_in_pending_list(false); |
| 77 | 77 |
| 78 animation_host_->DidDeactivateElementAnimations(this); | 78 animation_host_->DidDeactivateElementAnimations(this); |
| 79 UpdateActivation(FORCE_ACTIVATION); | 79 UpdateActivation(FORCE_ACTIVATION); |
| 80 } | 80 } |
| 81 | 81 |
| 82 void ElementAnimations::LayerRegistered(int layer_id, LayerTreeType tree_type) { | 82 void ElementAnimations::LayerRegistered(ElementId element_id, |
| 83 DCHECK_EQ(layer_id_, layer_id); | 83 LayerTreeType tree_type) { |
| 84 DCHECK_EQ(element_id_, element_id); |
| 84 | 85 |
| 85 if (tree_type == LayerTreeType::ACTIVE) | 86 if (tree_type == LayerTreeType::ACTIVE) |
| 86 set_has_element_in_active_list(true); | 87 set_has_element_in_active_list(true); |
| 87 else | 88 else |
| 88 set_has_element_in_pending_list(true); | 89 set_has_element_in_pending_list(true); |
| 89 } | 90 } |
| 90 | 91 |
| 91 void ElementAnimations::LayerUnregistered(int layer_id, | 92 void ElementAnimations::LayerUnregistered(ElementId element_id, |
| 92 LayerTreeType tree_type) { | 93 LayerTreeType tree_type) { |
| 93 DCHECK_EQ(this->layer_id(), layer_id); | 94 DCHECK_EQ(this->element_id(), element_id); |
| 94 if (tree_type == LayerTreeType::ACTIVE) | 95 if (tree_type == LayerTreeType::ACTIVE) |
| 95 set_has_element_in_active_list(false); | 96 set_has_element_in_active_list(false); |
| 96 else | 97 else |
| 97 set_has_element_in_pending_list(false); | 98 set_has_element_in_pending_list(false); |
| 98 } | 99 } |
| 99 | 100 |
| 100 void ElementAnimations::AddPlayer(AnimationPlayer* player) { | 101 void ElementAnimations::AddPlayer(AnimationPlayer* player) { |
| 101 players_list_->Append(player); | 102 players_list_->Append(player); |
| 102 } | 103 } |
| 103 | 104 |
| (...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 166 if (!animation->is_impl_only()) | 167 if (!animation->is_impl_only()) |
| 167 continue; | 168 continue; |
| 168 | 169 |
| 169 if (!animation->InEffect(monotonic_time)) | 170 if (!animation->InEffect(monotonic_time)) |
| 170 continue; | 171 continue; |
| 171 | 172 |
| 172 base::TimeDelta trimmed = | 173 base::TimeDelta trimmed = |
| 173 animation->TrimTimeToCurrentIteration(monotonic_time); | 174 animation->TrimTimeToCurrentIteration(monotonic_time); |
| 174 switch (animation->target_property()) { | 175 switch (animation->target_property()) { |
| 175 case TargetProperty::OPACITY: { | 176 case TargetProperty::OPACITY: { |
| 176 AnimationEvent event(AnimationEvent::PROPERTY_UPDATE, layer_id_, | 177 AnimationEvent event(AnimationEvent::PROPERTY_UPDATE, element_id_, |
| 177 animation->group(), TargetProperty::OPACITY, | 178 animation->group(), TargetProperty::OPACITY, |
| 178 monotonic_time); | 179 monotonic_time); |
| 179 const FloatAnimationCurve* float_animation_curve = | 180 const FloatAnimationCurve* float_animation_curve = |
| 180 animation->curve()->ToFloatAnimationCurve(); | 181 animation->curve()->ToFloatAnimationCurve(); |
| 181 event.opacity = float_animation_curve->GetValue(trimmed); | 182 event.opacity = float_animation_curve->GetValue(trimmed); |
| 182 event.is_impl_only = true; | 183 event.is_impl_only = true; |
| 183 events->events_.push_back(event); | 184 events->events_.push_back(event); |
| 184 break; | 185 break; |
| 185 } | 186 } |
| 186 | 187 |
| 187 case TargetProperty::TRANSFORM: { | 188 case TargetProperty::TRANSFORM: { |
| 188 AnimationEvent event(AnimationEvent::PROPERTY_UPDATE, layer_id_, | 189 AnimationEvent event(AnimationEvent::PROPERTY_UPDATE, element_id_, |
| 189 animation->group(), TargetProperty::TRANSFORM, | 190 animation->group(), TargetProperty::TRANSFORM, |
| 190 monotonic_time); | 191 monotonic_time); |
| 191 const TransformAnimationCurve* transform_animation_curve = | 192 const TransformAnimationCurve* transform_animation_curve = |
| 192 animation->curve()->ToTransformAnimationCurve(); | 193 animation->curve()->ToTransformAnimationCurve(); |
| 193 event.transform = transform_animation_curve->GetValue(trimmed); | 194 event.transform = transform_animation_curve->GetValue(trimmed); |
| 194 event.is_impl_only = true; | 195 event.is_impl_only = true; |
| 195 events->events_.push_back(event); | 196 events->events_.push_back(event); |
| 196 break; | 197 break; |
| 197 } | 198 } |
| 198 | 199 |
| 199 case TargetProperty::FILTER: { | 200 case TargetProperty::FILTER: { |
| 200 AnimationEvent event(AnimationEvent::PROPERTY_UPDATE, layer_id_, | 201 AnimationEvent event(AnimationEvent::PROPERTY_UPDATE, element_id_, |
| 201 animation->group(), TargetProperty::FILTER, | 202 animation->group(), TargetProperty::FILTER, |
| 202 monotonic_time); | 203 monotonic_time); |
| 203 const FilterAnimationCurve* filter_animation_curve = | 204 const FilterAnimationCurve* filter_animation_curve = |
| 204 animation->curve()->ToFilterAnimationCurve(); | 205 animation->curve()->ToFilterAnimationCurve(); |
| 205 event.filters = filter_animation_curve->GetValue(trimmed); | 206 event.filters = filter_animation_curve->GetValue(trimmed); |
| 206 event.is_impl_only = true; | 207 event.is_impl_only = true; |
| 207 events->events_.push_back(event); | 208 events->events_.push_back(event); |
| 208 break; | 209 break; |
| 209 } | 210 } |
| 210 | 211 |
| (...skipping 530 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 741 if (!animations_[i]->has_set_start_time() && | 742 if (!animations_[i]->has_set_start_time() && |
| 742 !animations_[i]->needs_synchronized_start_time()) | 743 !animations_[i]->needs_synchronized_start_time()) |
| 743 animations_[i]->set_start_time(monotonic_time); | 744 animations_[i]->set_start_time(monotonic_time); |
| 744 if (events) { | 745 if (events) { |
| 745 base::TimeTicks start_time; | 746 base::TimeTicks start_time; |
| 746 if (animations_[i]->has_set_start_time()) | 747 if (animations_[i]->has_set_start_time()) |
| 747 start_time = animations_[i]->start_time(); | 748 start_time = animations_[i]->start_time(); |
| 748 else | 749 else |
| 749 start_time = monotonic_time; | 750 start_time = monotonic_time; |
| 750 AnimationEvent started_event( | 751 AnimationEvent started_event( |
| 751 AnimationEvent::STARTED, layer_id_, animations_[i]->group(), | 752 AnimationEvent::STARTED, element_id_, animations_[i]->group(), |
| 752 animations_[i]->target_property(), start_time); | 753 animations_[i]->target_property(), start_time); |
| 753 started_event.is_impl_only = animations_[i]->is_impl_only(); | 754 started_event.is_impl_only = animations_[i]->is_impl_only(); |
| 754 if (started_event.is_impl_only) | 755 if (started_event.is_impl_only) |
| 755 NotifyAnimationStarted(started_event); | 756 NotifyAnimationStarted(started_event); |
| 756 else | 757 else |
| 757 events->events_.push_back(started_event); | 758 events->events_.push_back(started_event); |
| 758 } | 759 } |
| 759 } | 760 } |
| 760 } | 761 } |
| 761 } | 762 } |
| (...skipping 22 matching lines...) Expand all Loading... |
| 784 animations_with_same_group_id.reserve(animations_.size()); | 785 animations_with_same_group_id.reserve(animations_.size()); |
| 785 // Non-aborted animations are marked for deletion after a corresponding | 786 // Non-aborted animations are marked for deletion after a corresponding |
| 786 // AnimationEvent::FINISHED event is sent or received. This means that if | 787 // AnimationEvent::FINISHED event is sent or received. This means that if |
| 787 // we don't have an events vector, we must ensure that non-aborted animations | 788 // we don't have an events vector, we must ensure that non-aborted animations |
| 788 // have received a finished event before marking them for deletion. | 789 // have received a finished event before marking them for deletion. |
| 789 for (size_t i = 0; i < animations_.size(); i++) { | 790 for (size_t i = 0; i < animations_.size(); i++) { |
| 790 int group_id = animations_[i]->group(); | 791 int group_id = animations_[i]->group(); |
| 791 if (animations_[i]->run_state() == Animation::ABORTED) { | 792 if (animations_[i]->run_state() == Animation::ABORTED) { |
| 792 if (events && !animations_[i]->is_impl_only()) { | 793 if (events && !animations_[i]->is_impl_only()) { |
| 793 AnimationEvent aborted_event( | 794 AnimationEvent aborted_event( |
| 794 AnimationEvent::ABORTED, layer_id_, group_id, | 795 AnimationEvent::ABORTED, element_id_, group_id, |
| 795 animations_[i]->target_property(), monotonic_time); | 796 animations_[i]->target_property(), monotonic_time); |
| 796 events->events_.push_back(aborted_event); | 797 events->events_.push_back(aborted_event); |
| 797 } | 798 } |
| 798 // If on the compositor or on the main thread and received finish event, | 799 // If on the compositor or on the main thread and received finish event, |
| 799 // animation can be marked for deletion. | 800 // animation can be marked for deletion. |
| 800 if (events || animations_[i]->received_finished_event()) { | 801 if (events || animations_[i]->received_finished_event()) { |
| 801 animations_[i]->SetRunState(Animation::WAITING_FOR_DELETION, | 802 animations_[i]->SetRunState(Animation::WAITING_FOR_DELETION, |
| 802 monotonic_time); | 803 monotonic_time); |
| 803 marked_animations_for_deletions = true; | 804 marked_animations_for_deletions = true; |
| 804 } | 805 } |
| 805 continue; | 806 continue; |
| 806 } | 807 } |
| 807 | 808 |
| 808 // If running on the compositor and need to complete an aborted animation | 809 // If running on the compositor and need to complete an aborted animation |
| 809 // on the main thread. | 810 // on the main thread. |
| 810 if (events && | 811 if (events && |
| 811 animations_[i]->run_state() == | 812 animations_[i]->run_state() == |
| 812 Animation::ABORTED_BUT_NEEDS_COMPLETION) { | 813 Animation::ABORTED_BUT_NEEDS_COMPLETION) { |
| 813 AnimationEvent aborted_event(AnimationEvent::TAKEOVER, layer_id_, | 814 AnimationEvent aborted_event(AnimationEvent::TAKEOVER, element_id_, |
| 814 group_id, animations_[i]->target_property(), | 815 group_id, animations_[i]->target_property(), |
| 815 monotonic_time); | 816 monotonic_time); |
| 816 aborted_event.animation_start_time = | 817 aborted_event.animation_start_time = |
| 817 (animations_[i]->start_time() - base::TimeTicks()).InSecondsF(); | 818 (animations_[i]->start_time() - base::TimeTicks()).InSecondsF(); |
| 818 const ScrollOffsetAnimationCurve* scroll_offset_animation_curve = | 819 const ScrollOffsetAnimationCurve* scroll_offset_animation_curve = |
| 819 animations_[i]->curve()->ToScrollOffsetAnimationCurve(); | 820 animations_[i]->curve()->ToScrollOffsetAnimationCurve(); |
| 820 aborted_event.curve = scroll_offset_animation_curve->Clone(); | 821 aborted_event.curve = scroll_offset_animation_curve->Clone(); |
| 821 // Notify the compositor that the animation is finished. | 822 // Notify the compositor that the animation is finished. |
| 822 NotifyPlayersAnimationFinished(aborted_event.monotonic_time, | 823 NotifyPlayersAnimationFinished(aborted_event.monotonic_time, |
| 823 aborted_event.target_property, | 824 aborted_event.target_property, |
| (...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 874 } | 875 } |
| 875 } | 876 } |
| 876 if (all_anims_with_same_id_are_finished) { | 877 if (all_anims_with_same_id_are_finished) { |
| 877 // We now need to remove all animations with the same group id as | 878 // We now need to remove all animations with the same group id as |
| 878 // group_id (and send along animation finished notifications, if | 879 // group_id (and send along animation finished notifications, if |
| 879 // necessary). | 880 // necessary). |
| 880 for (size_t j = 0; j < animations_with_same_group_id.size(); j++) { | 881 for (size_t j = 0; j < animations_with_same_group_id.size(); j++) { |
| 881 size_t animation_index = animations_with_same_group_id[j]; | 882 size_t animation_index = animations_with_same_group_id[j]; |
| 882 if (events) { | 883 if (events) { |
| 883 AnimationEvent finished_event( | 884 AnimationEvent finished_event( |
| 884 AnimationEvent::FINISHED, layer_id_, | 885 AnimationEvent::FINISHED, element_id_, |
| 885 animations_[animation_index]->group(), | 886 animations_[animation_index]->group(), |
| 886 animations_[animation_index]->target_property(), monotonic_time); | 887 animations_[animation_index]->target_property(), monotonic_time); |
| 887 finished_event.is_impl_only = | 888 finished_event.is_impl_only = |
| 888 animations_[animation_index]->is_impl_only(); | 889 animations_[animation_index]->is_impl_only(); |
| 889 if (finished_event.is_impl_only) | 890 if (finished_event.is_impl_only) |
| 890 NotifyAnimationFinished(finished_event); | 891 NotifyAnimationFinished(finished_event); |
| 891 else | 892 else |
| 892 events->events_.push_back(finished_event); | 893 events->events_.push_back(finished_event); |
| 893 } | 894 } |
| 894 animations_[animation_index]->SetRunState( | 895 animations_[animation_index]->SetRunState( |
| (...skipping 341 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1236 | 1237 |
| 1237 Animation* ElementAnimations::GetAnimationById(int animation_id) const { | 1238 Animation* ElementAnimations::GetAnimationById(int animation_id) const { |
| 1238 for (size_t i = 0; i < animations_.size(); ++i) | 1239 for (size_t i = 0; i < animations_.size(); ++i) |
| 1239 if (animations_[i]->id() == animation_id) | 1240 if (animations_[i]->id() == animation_id) |
| 1240 return animations_[i].get(); | 1241 return animations_[i].get(); |
| 1241 return nullptr; | 1242 return nullptr; |
| 1242 } | 1243 } |
| 1243 | 1244 |
| 1244 void ElementAnimations::OnFilterAnimated(LayerTreeType tree_type, | 1245 void ElementAnimations::OnFilterAnimated(LayerTreeType tree_type, |
| 1245 const FilterOperations& filters) { | 1246 const FilterOperations& filters) { |
| 1246 DCHECK(layer_id()); | 1247 DCHECK(element_id()); |
| 1247 DCHECK(animation_host()); | 1248 DCHECK(animation_host()); |
| 1248 DCHECK(animation_host()->mutator_host_client()); | 1249 DCHECK(animation_host()->mutator_host_client()); |
| 1249 animation_host()->mutator_host_client()->SetLayerFilterMutated( | 1250 animation_host()->mutator_host_client()->SetLayerFilterMutated( |
| 1250 layer_id(), tree_type, filters); | 1251 element_id(), tree_type, filters); |
| 1251 } | 1252 } |
| 1252 | 1253 |
| 1253 void ElementAnimations::OnOpacityAnimated(LayerTreeType tree_type, | 1254 void ElementAnimations::OnOpacityAnimated(LayerTreeType tree_type, |
| 1254 float opacity) { | 1255 float opacity) { |
| 1255 DCHECK(layer_id()); | 1256 DCHECK(element_id()); |
| 1256 DCHECK(animation_host()); | 1257 DCHECK(animation_host()); |
| 1257 DCHECK(animation_host()->mutator_host_client()); | 1258 DCHECK(animation_host()->mutator_host_client()); |
| 1258 animation_host()->mutator_host_client()->SetLayerOpacityMutated( | 1259 animation_host()->mutator_host_client()->SetLayerOpacityMutated( |
| 1259 layer_id(), tree_type, opacity); | 1260 element_id(), tree_type, opacity); |
| 1260 } | 1261 } |
| 1261 | 1262 |
| 1262 void ElementAnimations::OnTransformAnimated(LayerTreeType tree_type, | 1263 void ElementAnimations::OnTransformAnimated(LayerTreeType tree_type, |
| 1263 const gfx::Transform& transform) { | 1264 const gfx::Transform& transform) { |
| 1264 DCHECK(layer_id()); | 1265 DCHECK(element_id()); |
| 1265 DCHECK(animation_host()); | 1266 DCHECK(animation_host()); |
| 1266 DCHECK(animation_host()->mutator_host_client()); | 1267 DCHECK(animation_host()->mutator_host_client()); |
| 1267 animation_host()->mutator_host_client()->SetLayerTransformMutated( | 1268 animation_host()->mutator_host_client()->SetLayerTransformMutated( |
| 1268 layer_id(), tree_type, transform); | 1269 element_id(), tree_type, transform); |
| 1269 } | 1270 } |
| 1270 | 1271 |
| 1271 void ElementAnimations::OnScrollOffsetAnimated( | 1272 void ElementAnimations::OnScrollOffsetAnimated( |
| 1272 LayerTreeType tree_type, | 1273 LayerTreeType tree_type, |
| 1273 const gfx::ScrollOffset& scroll_offset) { | 1274 const gfx::ScrollOffset& scroll_offset) { |
| 1274 DCHECK(layer_id()); | 1275 DCHECK(element_id()); |
| 1275 DCHECK(animation_host()); | 1276 DCHECK(animation_host()); |
| 1276 DCHECK(animation_host()->mutator_host_client()); | 1277 DCHECK(animation_host()->mutator_host_client()); |
| 1277 animation_host()->mutator_host_client()->SetLayerScrollOffsetMutated( | 1278 animation_host()->mutator_host_client()->SetLayerScrollOffsetMutated( |
| 1278 layer_id(), tree_type, scroll_offset); | 1279 element_id(), tree_type, scroll_offset); |
| 1279 } | 1280 } |
| 1280 | 1281 |
| 1281 void ElementAnimations::OnAnimationWaitingForDeletion() { | 1282 void ElementAnimations::OnAnimationWaitingForDeletion() { |
| 1282 // TODO(loyso): Invalidate AnimationHost::SetNeedsPushProperties here. | 1283 // TODO(loyso): Invalidate AnimationHost::SetNeedsPushProperties here. |
| 1283 // But we always do PushProperties in AnimationHost for now. crbug.com/604280 | 1284 // But we always do PushProperties in AnimationHost for now. crbug.com/604280 |
| 1284 DCHECK(animation_host()); | 1285 DCHECK(animation_host()); |
| 1285 animation_host()->OnAnimationWaitingForDeletion(); | 1286 animation_host()->OnAnimationWaitingForDeletion(); |
| 1286 } | 1287 } |
| 1287 | 1288 |
| 1288 void ElementAnimations::OnTransformIsPotentiallyAnimatingChanged( | 1289 void ElementAnimations::OnTransformIsPotentiallyAnimatingChanged( |
| 1289 LayerTreeType tree_type, | 1290 LayerTreeType tree_type, |
| 1290 bool is_animating) { | 1291 bool is_animating) { |
| 1291 DCHECK(layer_id()); | 1292 DCHECK(element_id()); |
| 1292 DCHECK(animation_host()); | 1293 DCHECK(animation_host()); |
| 1293 DCHECK(animation_host()->mutator_host_client()); | 1294 DCHECK(animation_host()->mutator_host_client()); |
| 1294 animation_host() | 1295 animation_host() |
| 1295 ->mutator_host_client() | 1296 ->mutator_host_client() |
| 1296 ->LayerTransformIsPotentiallyAnimatingChanged(layer_id(), tree_type, | 1297 ->LayerTransformIsPotentiallyAnimatingChanged(element_id(), tree_type, |
| 1297 is_animating); | 1298 is_animating); |
| 1298 } | 1299 } |
| 1299 | 1300 |
| 1300 void ElementAnimations::NotifyPlayersAnimationStarted( | 1301 void ElementAnimations::NotifyPlayersAnimationStarted( |
| 1301 base::TimeTicks monotonic_time, | 1302 base::TimeTicks monotonic_time, |
| 1302 TargetProperty::Type target_property, | 1303 TargetProperty::Type target_property, |
| 1303 int group) { | 1304 int group) { |
| 1304 for (PlayersListNode* node = players_list_->head(); | 1305 for (PlayersListNode* node = players_list_->head(); |
| 1305 node != players_list_->end(); node = node->next()) { | 1306 node != players_list_->end(); node = node->next()) { |
| 1306 AnimationPlayer* player = node->value(); | 1307 AnimationPlayer* player = node->value(); |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1343 player->NotifyAnimationTakeover(monotonic_time, target_property, | 1344 player->NotifyAnimationTakeover(monotonic_time, target_property, |
| 1344 animation_start_time, | 1345 animation_start_time, |
| 1345 std::move(animation_curve)); | 1346 std::move(animation_curve)); |
| 1346 } | 1347 } |
| 1347 } | 1348 } |
| 1348 | 1349 |
| 1349 gfx::ScrollOffset ElementAnimations::ScrollOffsetForAnimation() const { | 1350 gfx::ScrollOffset ElementAnimations::ScrollOffsetForAnimation() const { |
| 1350 if (animation_host()) { | 1351 if (animation_host()) { |
| 1351 DCHECK(animation_host()->mutator_host_client()); | 1352 DCHECK(animation_host()->mutator_host_client()); |
| 1352 return animation_host()->mutator_host_client()->GetScrollOffsetForAnimation( | 1353 return animation_host()->mutator_host_client()->GetScrollOffsetForAnimation( |
| 1353 layer_id()); | 1354 element_id()); |
| 1354 } | 1355 } |
| 1355 | 1356 |
| 1356 return gfx::ScrollOffset(); | 1357 return gfx::ScrollOffset(); |
| 1357 } | 1358 } |
| 1358 | 1359 |
| 1359 } // namespace cc | 1360 } // namespace cc |
| OLD | NEW |