Trait lerp::LerpIter
[−]
[src]
pub trait LerpIter { fn lerp_iter(self, other: Self, steps: usize) -> LerpIterator<Self> where Self: Sized; fn lerp_iter_closed(self, other: Self, steps: usize) -> Skip<Chain<LerpIterator<Self>, Once<Self>>> where Self: Copy, LerpIterator<Self>: Iterator<Item=Self> { ... } }
Types which can construct a lerping iterator from one point to another over a set number of steps.
This is automatically implemented for all T: Lerp<f64> + Sized
.
Required Methods
fn lerp_iter(self, other: Self, steps: usize) -> LerpIterator<Self> where Self: Sized
Create an iterator which lerps from self
to other
.
The iterator is half-open: it includes self
, but not other
Example
use lerp::LerpIter; // lerp between 3 and 5, collecting two items let items: Vec<_> = 3.0_f64.lerp_iter(5.0, 4).collect(); assert_eq!(vec![3.0, 3.5, 4.0, 4.5], items);
Provided Methods
fn lerp_iter_closed(self, other: Self, steps: usize) -> Skip<Chain<LerpIterator<Self>, Once<Self>>> where Self: Copy, LerpIterator<Self>: Iterator<Item=Self>
Create an iterator which lerps from self
to other
.
The iterator is closed: it returns both self
and other
.
Note when steps == 1
, other
is returned instead of self
.
Example
use lerp::LerpIter; assert_eq!(vec![3.0, 5.0], 3.0_f64.lerp_iter_closed(5.0, 2).collect::<Vec<f64>>());