| /* This Source Code Form is subject to the terms of the Mozilla Public |
| * License, v. 2.0. If a copy of the MPL was not distributed with this |
| * file, You can obtain one at https://mozilla.org/MPL/2.0/. */ |
| |
| #![deny(missing_docs)] |
| |
| //! A timeline module, used to specify an `AnimationTimeline` which determines |
| //! the time used for synchronizing animations in the script thread. |
| |
| use std::time::{SystemTime, UNIX_EPOCH}; |
| |
| use jstraceable_derive::JSTraceable; |
| |
| /// A `AnimationTimeline` which is used to synchronize animations during the script |
| /// event loop. |
| #[derive(Clone, Copy, Debug, JSTraceable, MallocSizeOf)] |
| pub(crate) struct AnimationTimeline { |
| current_value: f64, |
| } |
| |
| impl AnimationTimeline { |
| /// Creates a new "normal" timeline, i.e., a "Current" mode timer. |
| #[inline] |
| pub(crate) fn new() -> Self { |
| Self { |
| current_value: SystemTime::now() |
| .duration_since(UNIX_EPOCH) |
| .unwrap_or_default() |
| .as_secs_f64(), |
| } |
| } |
| |
| /// Creates a new "test mode" timeline, with initial time 0. |
| #[inline] |
| pub(crate) fn new_for_testing() -> Self { |
| Self { current_value: 0. } |
| } |
| |
| /// Returns the current value of the timeline in seconds. |
| pub(crate) fn current_value(&self) -> f64 { |
| self.current_value |
| } |
| |
| /// Updates the value of the `AnimationTimeline` to the current clock time. |
| pub(crate) fn update(&mut self) { |
| self.current_value = SystemTime::now() |
| .duration_since(UNIX_EPOCH) |
| .unwrap_or_default() |
| .as_secs_f64(); |
| } |
| |
| /// Increments the current value of the timeline by a specific number of seconds. |
| /// This is used for testing. |
| pub(crate) fn advance_specific(&mut self, by: f64) { |
| self.current_value += by; |
| } |
| } |