Struct SegmentedCoord
pub struct SegmentedCoord<D>(/* private fields */)
where
D: DiscreteRanged;Expand description
A SegmentedCoord is a decorator on any discrete coordinate specification.
This decorator will convert the discrete coordinate in two ways:
- Add an extra dummy element after all the values in original discrete coordinate
- Logically each value
vfrom original coordinate system is mapped into an segment[v, v+1)wherev+1denotes the successor of thev - Introduce two types of values
SegmentValue::Exact(value)which denotes the left end of value’s segment andSegmentValue::CenterOf(value)which refers the center of the segment. This is used in histogram types, which uses a discrete coordinate as the buckets. The segmented coord always emitsCenterOf(value)key points, thus it allows all the label and tick marks of the coordinate rendered in the middle of each segment. The corresponding trait IntoSegmentedCoord is used to apply this decorator to coordinates.
Trait Implementations§
§impl<D> Clone for SegmentedCoord<D>where
D: Clone + DiscreteRanged,
impl<D> Clone for SegmentedCoord<D>where
D: Clone + DiscreteRanged,
§fn clone(&self) -> SegmentedCoord<D>
fn clone(&self) -> SegmentedCoord<D>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read more§impl<D> DiscreteRanged for SegmentedCoord<D>where
D: DiscreteRanged,
impl<D> DiscreteRanged for SegmentedCoord<D>where
D: DiscreteRanged,
§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
§fn index_of(
&self,
value: &<SegmentedCoord<D> as Ranged>::ValueType,
) -> Option<usize>
fn index_of( &self, value: &<SegmentedCoord<D> as Ranged>::ValueType, ) -> Option<usize>
Map a value to the index Read more
§fn from_index(
&self,
idx: usize,
) -> Option<<SegmentedCoord<D> as Ranged>::ValueType>
fn from_index( &self, idx: usize, ) -> Option<<SegmentedCoord<D> as Ranged>::ValueType>
Reverse map the index to the value Read more
§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
§impl<D> Ranged for SegmentedCoord<D>where
D: DiscreteRanged,
impl<D> Ranged for SegmentedCoord<D>where
D: DiscreteRanged,
§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
§type ValueType = SegmentValue<<D as Ranged>::ValueType>
type ValueType = SegmentValue<<D as Ranged>::ValueType>
The type of this value in this range specification
§fn map(
&self,
value: &<SegmentedCoord<D> as Ranged>::ValueType,
limit: (i32, i32),
) -> i32
fn map( &self, value: &<SegmentedCoord<D> as Ranged>::ValueType, limit: (i32, i32), ) -> i32
This function maps the value to i32, which is the drawing coordinate
§fn key_points<HintType>(
&self,
hint: HintType,
) -> Vec<<SegmentedCoord<D> as Ranged>::ValueType>where
HintType: KeyPointHint,
fn key_points<HintType>(
&self,
hint: HintType,
) -> Vec<<SegmentedCoord<D> as Ranged>::ValueType>where
HintType: KeyPointHint,
This function gives the key points that we can draw a grid based on this
§impl<T, D> ValueFormatter<SegmentValue<T>> for SegmentedCoord<D>
impl<T, D> ValueFormatter<SegmentValue<T>> for SegmentedCoord<D>
§fn format(value: &SegmentValue<T>) -> String
fn format(value: &SegmentValue<T>) -> String
Format the value
§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<D> Freeze for SegmentedCoord<D>where
D: Freeze,
impl<D> RefUnwindSafe for SegmentedCoord<D>where
D: RefUnwindSafe,
impl<D> Send for SegmentedCoord<D>where
D: Send,
impl<D> Sync for SegmentedCoord<D>where
D: Sync,
impl<D> Unpin for SegmentedCoord<D>where
D: Unpin,
impl<D> UnwindSafe for SegmentedCoord<D>where
D: UnwindSafe,
Blanket Implementations§
§impl<T> AsRangedCoord for Twhere
T: Ranged,
impl<T> AsRangedCoord for Twhere
T: Ranged,
§impl<T> BindKeyPointMethod for Twhere
T: AsRangedCoord,
impl<T> BindKeyPointMethod for Twhere
T: AsRangedCoord,
§fn with_key_point_func<F>(
self,
func: F,
) -> WithKeyPointMethod<Self::CoordDescType>
fn with_key_point_func<F>( 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
§impl<T> BindKeyPoints for Twhere
T: AsRangedCoord,
impl<T> BindKeyPoints for Twhere
T: AsRangedCoord,
§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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Convert
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Convert
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<T> IntoLinspace for Twhere
T: AsRangedCoord,
impl<T> IntoLinspace for Twhere
T: AsRangedCoord,
§impl<R> IntoPartialAxis for Rwhere
R: AsRangedCoord,
impl<R> IntoPartialAxis for Rwhere
R: AsRangedCoord,
§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