Struct Timer

Source
pub struct Timer { /* private fields */ }
Expand description

A timer that you can use to fix the time between actions, for example updates or draw calls.

See the article Fix Your Timestep for more on how to use timers to ensure framerate-independence.

Implementations§

Source§

impl Timer

Source

pub fn time_per_second(times: f32) -> Timer

Create a timer that ticks n many times per second

Source

pub fn with_duration(period: Duration) -> Timer

Create a timer with a given period (time between ticks)

Source

pub fn tick(&mut self) -> bool

Look if the time has elapsed and if so, starts the countdown for the next tick.

You can use a while loop instead of an if to catch up in the event that you were late. Each tick will only ‘consume’ one period worth of time.

Source

pub fn exhaust(&mut self) -> Option<NonZeroUsize>

Similar to Self::tick() but tells you how many ticks have passed, rather than just if a tick has passed.

This is useful in situations where catching up isn’t needed or possible, like rendering to the screen. If you’ve missed rendering three frames, there’s no point in drawing them now: just render the current state and move on.

Source

pub fn reset(&mut self)

Resets the timer to count from this moment.

This is the same as creating a new Timer with the same period

Source

pub fn period(&self) -> Duration

Gets the time in between ticks

Source

pub fn elapsed(&self) -> Duration

How much time has passed since the timer was last ticked

Source

pub fn remaining(&self) -> Option<Duration>

Look how much time is still left before its time for next tick.

Source

pub fn late_by(&self) -> Option<Duration>

Look how late you are with calling Timer::tick() if you would call it right now

Trait Implementations§

Source§

impl Clone for Timer

Source§

fn clone(&self) -> Timer

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Timer

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl Freeze for Timer

§

impl RefUnwindSafe for Timer

§

impl Send for Timer

§

impl Sync for Timer

§

impl Unpin for Timer

§

impl UnwindSafe for Timer

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.