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

Side by Side Diff: cc/animation/scroll_offset_animations.cc

Issue 1950243005: Communicate MT changes to impl-only scroll offset animations (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: review comments Created 4 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 unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2016 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "cc/animation/scroll_offset_animations.h"
6
7 #include "cc/animation/animation_host.h"
8
9 namespace cc {
10
11 ScrollOffsetAnimationUpdate::ScrollOffsetAnimationUpdate(Type type,
12 ElementId element_id)
13 : type_(type), element_id_(element_id) {}
14
15 ScrollOffsetAnimations::ScrollOffsetAnimations(AnimationHost* animation_host)
16 : animation_host_(animation_host) {}
17
18 ScrollOffsetAnimations::~ScrollOffsetAnimations() {}
19
20 void ScrollOffsetAnimations::AddUpdate(ScrollOffsetAnimationUpdate update) {
21 queue_.push_back(update);
22 animation_host_->SetNeedsCommit();
23 }
24
25 bool ScrollOffsetAnimations::HasUpdatesForTesting() const {
26 return !queue_.empty();
27 }
28
29 void ScrollOffsetAnimations::PushPropertiesTo(
30 ScrollOffsetAnimationsImpl* animations,
31 base::TimeTicks frame_monotonic_time) {
32 if (!animations)
loyso (OOO) 2016/05/11 06:25:45 DCHECK maybe?
ymalik 2016/05/12 22:31:25 Done.
33 return;
34 if (queue_.empty())
35 return;
36
37 for (auto& update : queue_) {
38 switch (update.type_) {
39 case ScrollOffsetAnimationUpdate::Type::SCROLL_OFFSET_CHANGED:
40 animations->ScrollAnimationApplyAdjustment(
41 update.element_id_, update.adjustment_, frame_monotonic_time);
42 }
43 }
44 queue_.clear();
45 }
46
47 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698