| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2013 Google Inc. All rights reserved. | 2 * Copyright (C) 2013 Google Inc. All rights reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
| 6 * met: | 6 * met: |
| 7 * | 7 * |
| 8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
| 9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
| 10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
| (...skipping 218 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 229 void AnimationTimeline::setOutdatedAnimationPlayer(AnimationPlayer* player) | 229 void AnimationTimeline::setOutdatedAnimationPlayer(AnimationPlayer* player) |
| 230 { | 230 { |
| 231 ASSERT(player->outdated()); | 231 ASSERT(player->outdated()); |
| 232 m_playersNeedingUpdate.add(player); | 232 m_playersNeedingUpdate.add(player); |
| 233 if (m_document && m_document->page() && !m_document->page()->animator().isSe
rvicingAnimations()) | 233 if (m_document && m_document->page() && !m_document->page()->animator().isSe
rvicingAnimations()) |
| 234 m_timing->serviceOnNextFrame(); | 234 m_timing->serviceOnNextFrame(); |
| 235 } | 235 } |
| 236 | 236 |
| 237 void AnimationTimeline::setPlaybackRate(double playbackRate) | 237 void AnimationTimeline::setPlaybackRate(double playbackRate) |
| 238 { | 238 { |
| 239 // FIXME: need to invalidate compositor animations |
| 239 m_currentTimeSnapshot = currentTimeInternal(); | 240 m_currentTimeSnapshot = currentTimeInternal(); |
| 240 m_rawCurrentTimeSnapshot = m_document->animationClock().currentTime() - zero
Time(); | 241 m_rawCurrentTimeSnapshot = m_document->animationClock().currentTime() - zero
Time(); |
| 241 m_playbackRate = playbackRate; | 242 m_playbackRate = playbackRate; |
| 242 for (auto& player : m_players) { | |
| 243 player->setCompositorPending(true); | |
| 244 } | |
| 245 } | 243 } |
| 246 | 244 |
| 247 double AnimationTimeline::playbackRate() const | 245 double AnimationTimeline::playbackRate() const |
| 248 { | 246 { |
| 249 return m_playbackRate; | 247 return m_playbackRate; |
| 250 } | 248 } |
| 251 | 249 |
| 252 #if !ENABLE(OILPAN) | 250 #if !ENABLE(OILPAN) |
| 253 void AnimationTimeline::detachFromDocument() | 251 void AnimationTimeline::detachFromDocument() |
| 254 { | 252 { |
| 255 // FIXME: AnimationTimeline should keep Document alive. | 253 // FIXME: AnimationTimeline should keep Document alive. |
| 256 m_document = nullptr; | 254 m_document = nullptr; |
| 257 } | 255 } |
| 258 #endif | 256 #endif |
| 259 | 257 |
| 260 void AnimationTimeline::trace(Visitor* visitor) | 258 void AnimationTimeline::trace(Visitor* visitor) |
| 261 { | 259 { |
| 262 #if ENABLE(OILPAN) | 260 #if ENABLE(OILPAN) |
| 263 visitor->trace(m_document); | 261 visitor->trace(m_document); |
| 264 visitor->trace(m_timing); | 262 visitor->trace(m_timing); |
| 265 visitor->trace(m_playersNeedingUpdate); | 263 visitor->trace(m_playersNeedingUpdate); |
| 266 visitor->trace(m_players); | 264 visitor->trace(m_players); |
| 267 #endif | 265 #endif |
| 268 } | 266 } |
| 269 | 267 |
| 270 } // namespace | 268 } // namespace |
| OLD | NEW |