pub struct EmptyElement<Coord, DB: DrawingBackend> { /* private fields */ }
Expand description
An empty composable element. This is the starting point of a composed element.
§Example
use plotters::prelude::*;
let data = [(1.0, 3.3), (2., 2.1), (3., 1.5), (4., 1.9), (5., 1.0)];
let drawing_area = SVGBackend::new("composable.svg", (300, 200)).into_drawing_area();
drawing_area.fill(&WHITE).unwrap();
let mut chart_builder = ChartBuilder::on(&drawing_area);
chart_builder.margin(7).set_left_and_bottom_label_area_size(20);
let mut chart_context = chart_builder.build_cartesian_2d(0.0..5.5, 0.0..5.5).unwrap();
chart_context.configure_mesh().draw().unwrap();
chart_context.draw_series(data.map(|(x, y)| {
EmptyElement::at((x, y)) // Use the guest coordinate system with EmptyElement
+ Circle::new((0, 0), 10, BLUE) // Use backend coordinates with the rest
+ Cross::new((4, 4), 3, RED)
+ Pixel::new((4, -4), RED)
+ TriangleMarker::new((-4, -4), 4, RED)
})).unwrap();
The result is a data series where each point consists of a circle, a cross, a pixel, and a triangle:
Implementations§
Source§impl<Coord, DB: DrawingBackend> EmptyElement<Coord, DB>
impl<Coord, DB: DrawingBackend> EmptyElement<Coord, DB>
Sourcepub fn at(coord: Coord) -> Self
pub fn at(coord: Coord) -> Self
An empty composable element. This is the starting point of a composed element.
See EmptyElement
for more information and examples.
Trait Implementations§
Source§impl<Coord, Other, DB: DrawingBackend> Add<Other> for EmptyElement<Coord, DB>
impl<Coord, Other, DB: DrawingBackend> Add<Other> for EmptyElement<Coord, DB>
Source§impl<Coord, DB: DrawingBackend> Drawable<DB> for EmptyElement<Coord, DB>
impl<Coord, DB: DrawingBackend> Drawable<DB> for EmptyElement<Coord, DB>
Source§impl<'a, Coord, DB: DrawingBackend> PointCollection<'a, Coord> for &'a EmptyElement<Coord, DB>
impl<'a, Coord, DB: DrawingBackend> PointCollection<'a, Coord> for &'a EmptyElement<Coord, DB>
Auto Trait Implementations§
impl<Coord, DB> Freeze for EmptyElement<Coord, DB>where
Coord: Freeze,
impl<Coord, DB> RefUnwindSafe for EmptyElement<Coord, DB>where
Coord: RefUnwindSafe,
DB: RefUnwindSafe,
impl<Coord, DB> Send for EmptyElement<Coord, DB>
impl<Coord, DB> Sync for EmptyElement<Coord, DB>
impl<Coord, DB> Unpin for EmptyElement<Coord, DB>
impl<Coord, DB> UnwindSafe for EmptyElement<Coord, DB>where
Coord: UnwindSafe,
DB: UnwindSafe,
Blanket Implementations§
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<'b, T, DB, Coord> IntoDynElement<'b, DB, Coord> for Twhere
T: Drawable<DB> + 'b,
&'a T: for<'a> PointCollection<'a, Coord>,
Coord: Clone,
DB: DrawingBackend,
impl<'b, T, DB, Coord> IntoDynElement<'b, DB, Coord> for Twhere
T: Drawable<DB> + 'b,
&'a T: for<'a> PointCollection<'a, Coord>,
Coord: Clone,
DB: DrawingBackend,
Source§fn into_dyn(self) -> DynElement<'b, DB, Coord>
fn into_dyn(self) -> DynElement<'b, DB, Coord>
Make the conversion
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.