pub struct NestedRange<Primary: DiscreteRanged, Secondary: Ranged> { /* private fields */ }
Expand description
A nested coordinate spec which is a discrete coordinate on the top level and for each value in discrete value, there is a secondary coordinate system. And the value is defined as a tuple of primary coordinate value and secondary coordinate value
Trait Implementations§
Source§impl<P: DiscreteRanged, S: DiscreteRanged> DiscreteRanged for NestedRange<P, S>
impl<P: DiscreteRanged, S: DiscreteRanged> DiscreteRanged for NestedRange<P, S>
Source§fn size(&self) -> usize
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>
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>
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,
fn values(&self) -> DiscreteValueIter<'_, Self>where
Self: Sized,
Return a iterator that iterates over the all possible values Read more
Source§impl<P: DiscreteRanged, S: Ranged> Ranged for NestedRange<P, S>
impl<P: DiscreteRanged, S: Ranged> Ranged for NestedRange<P, S>
Source§type FormatOption = NoDefaultFormatting
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 = NestedValue<<P as Ranged>::ValueType, <S as Ranged>::ValueType>
type ValueType = NestedValue<<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
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>
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§impl<PT, ST, P, S> ValueFormatter<NestedValue<PT, ST>> for NestedRange<P, S>where
P: Ranged<ValueType = PT> + DiscreteRanged + ValueFormatter<PT>,
S: Ranged<ValueType = ST> + ValueFormatter<ST>,
impl<PT, ST, P, S> ValueFormatter<NestedValue<PT, ST>> for NestedRange<P, S>where
P: Ranged<ValueType = PT> + DiscreteRanged + ValueFormatter<PT>,
S: Ranged<ValueType = ST> + ValueFormatter<ST>,
Source§fn format(value: &NestedValue<PT, ST>) -> String
fn format(value: &NestedValue<PT, ST>) -> String
Format the value
Source§fn format_ext(&self, value: &V) -> String
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 NestedRange<Primary, Secondary>where
Primary: Freeze,
impl<Primary, Secondary> RefUnwindSafe for NestedRange<Primary, Secondary>where
Primary: RefUnwindSafe,
Secondary: RefUnwindSafe,
impl<Primary, Secondary> Send for NestedRange<Primary, Secondary>
impl<Primary, Secondary> Sync for NestedRange<Primary, Secondary>
impl<Primary, Secondary> Unpin for NestedRange<Primary, Secondary>
impl<Primary, Secondary> UnwindSafe for NestedRange<Primary, Secondary>where
Primary: UnwindSafe,
Secondary: UnwindSafe,
Blanket Implementations§
Source§impl<T> AsRangedCoord for Twhere
T: Ranged,
impl<T> AsRangedCoord for Twhere
T: Ranged,
Source§impl<T> BindKeyPointMethod for Twhere
T: AsRangedCoord,
impl<T> BindKeyPointMethod for Twhere
T: AsRangedCoord,
Source§fn with_key_point_func<F: Fn(usize) -> Vec<Self::Value> + 'static>(
self,
func: F,
) -> WithKeyPointMethod<Self::CoordDescType>
fn with_key_point_func<F: Fn(usize) -> Vec<Self::Value> + 'static>( self, func: F, ) -> WithKeyPointMethod<Self::CoordDescType>
Bind a existing coordinate spec with a given key points algorithm. See WithKeyPointMethod for more details.
Example: Read more
Source§impl<T> BindKeyPoints for Twhere
T: AsRangedCoord,
impl<T> BindKeyPoints for Twhere
T: AsRangedCoord,
Source§fn with_key_points(
self,
points: Vec<Self::Value>,
) -> WithKeyPoints<Self::CoordDescType>
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> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> IntoLinspace for Twhere
T: AsRangedCoord,
impl<T> IntoLinspace for Twhere
T: AsRangedCoord,
Source§impl<R> IntoPartialAxis for Rwhere
R: AsRangedCoord,
impl<R> IntoPartialAxis for Rwhere
R: AsRangedCoord,
Source§fn partial_axis(
self,
axis_range: Range<<Self::CoordDescType as Ranged>::ValueType>,
) -> PartialAxis<Self::CoordDescType>
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 DCwhere
DC: DiscreteRanged,
impl<DC> ReversibleRanged for DCwhere
DC: DiscreteRanged,
Layout§
Note: Unable to compute type layout, possibly due to this type having generic parameters. Layout can only be computed for concrete, fully-instantiated types.