SliderPath

Struct SliderPath 

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

The path of a HitObjectSlider.

Implementations§

Source§

impl SliderPath

Source

pub const fn new( mode: GameMode, control_points: Vec<PathControlPoint>, expected_dist: Option<f64>, ) -> Self

Creates a new SliderPath.

The contained Curve will not necessarily be calculated yet, only when accessing it with methods such as SliderPath::curve.

Source

pub fn control_points(&self) -> &[PathControlPoint]

Returns an immutable reference to the control points.

Source

pub const fn expected_dist(&self) -> Option<f64>

Returns the expected distance.

Source

pub fn curve(&mut self) -> &Curve

Returns a reference to the Curve.

If the curve has not yet been accessed, it needs to be calculated first.

In case curves of multiple slider paths are being calculated, it is recommended to initialize CurveBuffers and pass a mutable reference of it to SliderPath::curve_with_bufs so the buffers are re-used for all sliders.

Alternatively, to avoid storing the curve altogether because it will be accessed only once, using SliderPath::borrowed_curve should be preferred.

Source

pub fn curve_with_bufs(&mut self, bufs: &mut CurveBuffers) -> &Curve

Returns a reference to the Curve.

If the curve has not yet been accessed, it needs to be calculated first.

In case the curve will be accessed only once, using SliderPath::borrowed_curve should be preferred.

Source

pub fn borrowed_curve<'a, 'b: 'a>( &'a self, bufs: &'b mut CurveBuffers, ) -> BorrowedCurve<'a>

Returns a BorrowedCurve.

If the curve has been calculated before, the returned curve will borrow from it. Otherwise, it will be calculated and returned without storing it by borrowing from the given CurveBuffers.

This should be preferred over SliderPath::curve_with_bufs if the curve will be accessed only once.

Source

pub fn control_points_mut(&mut self) -> &mut Vec<PathControlPoint>

Returns a mutable reference to the control points.

Note that calling this method will invalidate the stored curve so it must be recalculated on its next access.

Source

pub fn expected_dist_mut(&mut self) -> &mut Option<f64>

Returns a mutable reference to the expected distance.

Note that calling this method will invalidate the stored curve so it must be recalculated on its next access.

Source

pub fn clear_curve(&mut self)

Remove the stored curve so that it has to be re-calculated when accessing it the next time.

Trait Implementations§

Source§

impl Clone for SliderPath

Source§

fn clone(&self) -> SliderPath

Returns a duplicate 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 SliderPath

Source§

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

Formats the value using the given formatter. Read more
Source§

impl PartialEq for SliderPath

Source§

fn eq(&self, other: &Self) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.

Auto Trait Implementations§

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.