plotters::coord::combinators

Struct GroupBy

Source
pub struct GroupBy<T: DiscreteRanged>(/* private fields */);
Expand description

Grouping the value in the coordinate specification.

This combinator doesn’t change the coordinate mapping behavior. But it changes how the key point is generated, this coordinate specification will enforce that only the first value in each group can be emitted as the bold key points.

This is useful, for example, when we have an X axis is a integer and denotes days. And we are expecting the tick mark denotes weeks, in this way we can make the range spec grouping by 7 elements. With the help of the GroupBy decorator, this can be archived quite easily:

use plotters::prelude::*;
let mut buf = vec![0;1024*768*3];
let area = BitMapBackend::with_buffer(buf.as_mut(), (1024, 768)).into_drawing_area();
let chart = ChartBuilder::on(&area)
    .build_cartesian_2d((0..100).group_by(7), 0..100)
    .unwrap();

To apply this combinator, call ToGroupByRange::group_by method on any discrete coordinate spec.

Trait Implementations§

Source§

impl<T: Clone + DiscreteRanged> Clone for GroupBy<T>

Source§

fn clone(&self) -> GroupBy<T>

Returns a copy 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<T: DiscreteRanged> DiscreteRanged for GroupBy<T>

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<T: DiscreteRanged> Ranged for GroupBy<T>

Source§

type FormatOption = NoDefaultFormatting

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

type ValueType = <T as Ranged>::ValueType

The type of this value in this range specification
Source§

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

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

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

Get the range of this value
Source§

fn key_points<HintType: KeyPointHint>( &self, hint: HintType, ) -> Vec<T::ValueType>

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

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

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

impl<T, R: DiscreteRanged<ValueType = T> + ValueFormatter<T>> ValueFormatter<T> for GroupBy<R>

Source§

fn format(value: &T) -> String

Format the value

Auto Trait Implementations§

§

impl<T> Freeze for GroupBy<T>
where T: Freeze,

§

impl<T> RefUnwindSafe for GroupBy<T>
where T: RefUnwindSafe,

§

impl<T> Send for GroupBy<T>
where T: Send,

§

impl<T> Sync for GroupBy<T>
where T: Sync,

§

impl<T> Unpin for GroupBy<T>
where T: Unpin,

§

impl<T> UnwindSafe for GroupBy<T>
where T: 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§

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

Source§

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 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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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: Clone>( self, val: S, ) -> Linspace<Self::CoordDescType, S, Exact<Self::Value>>
where 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>

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.