Struct WithKeyPoints
pub struct WithKeyPoints<Inner>where
Inner: Ranged,{ /* private fields */ }Expand description
The coordinate decorator that binds a key point vector. Normally, all the ranged coordinate implements its own keypoint algorithm to determine how to render the tick mark and mesh grid. This decorator allows customized tick mark specifiied by vector. See BindKeyPoints::with_key_points for details. Note: For any coordinate spec wrapped by this decorator, the maximum number of labels configured by MeshStyle will be ignored and the key point function will always returns the entire vector
Implementations§
§impl<I> WithKeyPoints<I>where
I: Ranged,
impl<I> WithKeyPoints<I>where
I: Ranged,
pub fn with_light_points<T>(self, iter: T) -> WithKeyPoints<I>
pub fn with_light_points<T>(self, iter: T) -> WithKeyPoints<I>
Specify the light key points, which is used to render the light mesh line
pub fn bold_points(&self) -> &[<I as Ranged>::ValueType]
pub fn bold_points(&self) -> &[<I as Ranged>::ValueType]
Get a reference to the bold points
pub fn bold_points_mut(&mut self) -> &mut [<I as Ranged>::ValueType]
pub fn bold_points_mut(&mut self) -> &mut [<I as Ranged>::ValueType]
Get a mut reference to the bold points
pub fn light_points(&self) -> &[<I as Ranged>::ValueType]
pub fn light_points(&self) -> &[<I as Ranged>::ValueType]
Get a reference to light key points
pub fn light_points_mut(&mut self) -> &mut [<I as Ranged>::ValueType]
pub fn light_points_mut(&mut self) -> &mut [<I as Ranged>::ValueType]
Get a mut reference to the light key points
Trait Implementations§
§impl<R> DiscreteRanged for WithKeyPoints<R>
impl<R> DiscreteRanged for WithKeyPoints<R>
§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: &<WithKeyPoints<R> as Ranged>::ValueType,
) -> Option<usize>
fn index_of( &self, value: &<WithKeyPoints<R> as Ranged>::ValueType, ) -> Option<usize>
Map a value to the index Read more
§fn from_index(
&self,
index: usize,
) -> Option<<WithKeyPoints<R> as Ranged>::ValueType>
fn from_index( &self, index: usize, ) -> Option<<WithKeyPoints<R> 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<R> Ranged for WithKeyPoints<R>
impl<R> Ranged for WithKeyPoints<R>
§type FormatOption = <R as Ranged>::FormatOption
type FormatOption = <R as Ranged>::FormatOption
This marker decides if Plotters default ValueFormatter implementation should be used.
This associated type can be one of the following two types: Read more
§fn map(
&self,
value: &<WithKeyPoints<R> as Ranged>::ValueType,
limit: (i32, i32),
) -> i32
fn map( &self, value: &<WithKeyPoints<R> as Ranged>::ValueType, limit: (i32, i32), ) -> i32
This function maps the value to i32, which is the drawing coordinate
§fn key_points<Hint>(
&self,
hint: Hint,
) -> Vec<<WithKeyPoints<R> as Ranged>::ValueType>where
Hint: KeyPointHint,
fn key_points<Hint>(
&self,
hint: Hint,
) -> Vec<<WithKeyPoints<R> as Ranged>::ValueType>where
Hint: KeyPointHint,
This function gives the key points that we can draw a grid based on this
Auto Trait Implementations§
impl<Inner> Freeze for WithKeyPoints<Inner>where
Inner: Freeze,
impl<Inner> RefUnwindSafe for WithKeyPoints<Inner>
impl<Inner> Send for WithKeyPoints<Inner>
impl<Inner> Sync for WithKeyPoints<Inner>
impl<Inner> Unpin for WithKeyPoints<Inner>
impl<Inner> UnwindSafe for WithKeyPoints<Inner>
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
§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