Struct UniformNestedRange

Source
pub struct UniformNestedRange<Primary: DiscreteRanged, Secondary: Ranged> { /* private fields */ }
Expand description

Like plotters::coord::combinators::NestedRange, except the nested coordinate system is the same for every item in the outer coordinate system.

That is, each value in the discrete ranged coordinate system has an associated secondary coordinate system. The value type is UniformNestedValue - most of the time, you just want UniformNestedValue::Value - and a From implementation for tuples is provided as such.

Because of this uniformity, this can be used very efficiently, even recursively, and even with large Primary coordinate systems - including both as a primary coordinate system itself, or as a secondary coordinate system. This is because it lacks the need to scan all the potentially-variadic coordinate systems when doing discrete value indexing.

Important to note here - The coordinate ranges produced by coordinate systems are typically [inclusive, exclusive) style - they include the lower value and exclude the upper value. This remains true for this coordinate system. However, when working with both UniformNestedRange and plotters::coord::combinators::NestedRange, typically the final value of the primary coordinate system is actually included, and it’s only the last value of the secondary coordinate systems that is excluded. This means that it may extend one-further within the primary coordinate system than is expected.

Trait Implementations§

Source§

impl<Primary: DiscreteRanged, Secondary: DiscreteRanged> DiscreteRanged for UniformNestedRange<Primary, Secondary>

Efficient implementation of uniformly-nested DiscreteRanged. Even in uses which require very large amounts of indexing operations, this should be significantly more efficient than plotters::coord::combinators::NestedRange, because of the lack of a need to traverse linearly through dynamic secondary coordinate systems.

Source§

fn size(&self) -> usize

Get the number of element in the range Note: we assume that all the ranged discrete coordinate has finite value Read more
Source§

fn index_of(&self, value: &Self::ValueType) -> Option<usize>

Map a value to the index Read more
Source§

fn from_index(&self, index: usize) -> Option<Self::ValueType>

Reverse map the index to the value Read more
Source§

fn values(&self) -> DiscreteValueIter<'_, Self>
where Self: Sized,

Return a iterator that iterates over the all possible values Read more
Source§

fn previous(&self, value: &Self::ValueType) -> Option<Self::ValueType>

Returns the previous value in this range Read more
Source§

fn next(&self, value: &Self::ValueType) -> Option<Self::ValueType>

Returns the next value in this range Read more
Source§

impl<P: DiscreteRanged, S: Ranged> Ranged for UniformNestedRange<P, S>

Source§

type FormatOption = NoDefaultFormatting

This marker decides if Plotters default ValueFormatter implementation should be used. This associated type can be one of the following two types: Read more
Source§

type ValueType = UniformNestedValue<<P as Ranged>::ValueType, <S as Ranged>::ValueType>

The type of this value in this range specification
Source§

fn map(&self, value: &Self::ValueType, limit: (i32, i32)) -> i32

This function maps the value to i32, which is the drawing coordinate
Source§

fn key_points<Hint: KeyPointHint>(&self, hint: Hint) -> Vec<Self::ValueType>

This function gives the key points that we can draw a grid based on this
Source§

fn range(&self) -> Range<Self::ValueType>

Get the range of this value
Source§

fn axis_pixel_range(&self, limit: (i32, i32)) -> Range<i32>

This function provides the on-axis part of its range
Source§

impl<PCoordType, SCoordType, P, S> ValueFormatter<NestedValue<PCoordType, SCoordType>> for UniformNestedRange<P, S>
where P: Ranged<ValueType = PCoordType> + DiscreteRanged + ValueFormatter<PCoordType>, S: Ranged<ValueType = SCoordType> + ValueFormatter<SCoordType>,

Source§

fn format(value: &NestedValue<PCoordType, SCoordType>) -> String

Format the value
Source§

fn format_ext(&self, value: &V) -> String

Determine how we can format a value in a coordinate system by default

Auto Trait Implementations§

§

impl<Primary, Secondary> Freeze for UniformNestedRange<Primary, Secondary>
where Primary: Freeze, Secondary: Freeze,

§

impl<Primary, Secondary> RefUnwindSafe for UniformNestedRange<Primary, Secondary>
where Primary: RefUnwindSafe, Secondary: RefUnwindSafe,

§

impl<Primary, Secondary> Send for UniformNestedRange<Primary, Secondary>
where Primary: Send, Secondary: Send,

§

impl<Primary, Secondary> Sync for UniformNestedRange<Primary, Secondary>
where Primary: Sync, Secondary: Sync,

§

impl<Primary, Secondary> Unpin for UniformNestedRange<Primary, Secondary>
where Primary: Unpin, Secondary: Unpin,

§

impl<Primary, Secondary> UnwindSafe for UniformNestedRange<Primary, Secondary>
where Primary: UnwindSafe, Secondary: UnwindSafe,

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> AsRangedCoord for T
where T: Ranged,

Source§

type CoordDescType = T

Type to describe a coordinate system
Source§

type Value = <T as Ranged>::ValueType

Type for values in the given coordinate system
Source§

impl<T> BindKeyPointMethod for T
where T: AsRangedCoord,

Source§

fn with_key_point_func<F>( self, func: F, ) -> WithKeyPointMethod<Self::CoordDescType>
where F: Fn(usize) -> Vec<Self::Value> + 'static,

Bind a existing coordinate spec with a given key points algorithm. See WithKeyPointMethod for more details. Example: Read more
Source§

impl<T> BindKeyPoints for T
where T: AsRangedCoord,

Source§

fn with_key_points( self, points: Vec<Self::Value>, ) -> WithKeyPoints<Self::CoordDescType>

Bind a existing coordinate spec with a given key points vector. See WithKeyPoints for more details. Example: 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> 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> IntoLinspace for T
where T: AsRangedCoord,

Source§

fn step<S>(self, val: S) -> Linspace<Self::CoordDescType, S, Exact<Self::Value>>
where S: Clone, Self::Value: Add<S, Output = Self::Value> + PartialOrd + Clone,

Set the step value, make a linspace coordinate from the given range. By default the matching method use the exact match Read more
Source§

impl<R> IntoPartialAxis for R
where R: AsRangedCoord,

Source§

fn partial_axis( self, axis_range: Range<<Self::CoordDescType as Ranged>::ValueType>, ) -> PartialAxis<Self::CoordDescType>

Make the partial axis Read more
Source§

impl<DC> ReversibleRanged for DC
where DC: DiscreteRanged,

Source§

fn unmap( &self, input: i32, limit: (i32, i32), ) -> Option<<DC as Ranged>::ValueType>

Perform the reverse mapping
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.