diff options
Diffstat (limited to 'wgpu/src')
| -rw-r--r-- | wgpu/src/lib.rs | 3 | ||||
| -rw-r--r-- | wgpu/src/widget/canvas.rs | 54 | ||||
| -rw-r--r-- | wgpu/src/widget/canvas/layer/cache.rs | 2 | ||||
| -rw-r--r-- | wgpu/src/widget/canvas/path.rs | 1 | ||||
| -rw-r--r-- | wgpu/src/widget/pane_grid.rs | 7 | 
5 files changed, 63 insertions, 4 deletions
| diff --git a/wgpu/src/lib.rs b/wgpu/src/lib.rs index 4e0cbc60..f00c7d2c 100644 --- a/wgpu/src/lib.rs +++ b/wgpu/src/lib.rs @@ -11,8 +11,9 @@  //! Currently, `iced_wgpu` supports the following primitives:  //! - Text, which is rendered using [`wgpu_glyph`]. No shaping at all.  //! - Quads or rectangles, with rounded borders and a solid background color. -//! - Images, lazily loaded from the filesystem.  //! - Clip areas, useful to implement scrollables or hide overflowing content. +//! - Images and SVG, loaded from memory or the file system. +//! - Meshes of triangles, useful to draw geometry freely.  //!  //! [Iced]: https://github.com/hecrj/iced  //! [`iced_native`]: https://github.com/hecrj/iced/tree/master/native diff --git a/wgpu/src/widget/canvas.rs b/wgpu/src/widget/canvas.rs index 3a9605c9..325f90ce 100644 --- a/wgpu/src/widget/canvas.rs +++ b/wgpu/src/widget/canvas.rs @@ -33,11 +33,61 @@ pub use text::Text;  /// A widget capable of drawing 2D graphics.  ///  /// A [`Canvas`] may contain multiple layers. A [`Layer`] is drawn using the -/// painter's algorithm. In other words, layers will be drawn on top of each in -/// the same order they are pushed into the [`Canvas`]. +/// painter's algorithm. In other words, layers will be drawn on top of each +/// other in the same order they are pushed into the [`Canvas`].  ///  /// [`Canvas`]: struct.Canvas.html  /// [`Layer`]: layer/trait.Layer.html +/// +/// # Examples +/// The repository has a couple of [examples] showcasing how to use a +/// [`Canvas`]: +/// +/// - [`clock`], an application that uses the [`Canvas`] widget to draw a clock +/// and its hands to display the current time. +/// - [`solar_system`], an animated solar system drawn using the [`Canvas`] widget +/// and showcasing how to compose different transforms. +/// +/// [examples]: https://github.com/hecrj/iced/tree/0.1/examples +/// [`clock`]: https://github.com/hecrj/iced/tree/0.1/examples/clock +/// [`solar_system`]: https://github.com/hecrj/iced/tree/0.1/examples/solar_system +/// +/// ## Drawing a simple circle +/// If you want to get a quick overview, here's how we can draw a simple circle: +/// +/// ```no_run +/// # mod iced { +/// #     pub use iced_wgpu::canvas; +/// #     pub use iced_native::Color; +/// # } +/// use iced::canvas::{self, layer, Canvas, Drawable, Fill, Frame, Path}; +/// use iced::Color; +/// +/// // First, we define the data we need for drawing +/// #[derive(Debug)] +/// struct Circle { +///     radius: f32, +/// } +/// +/// // Then, we implement the `Drawable` trait +/// impl Drawable for Circle { +///     fn draw(&self, frame: &mut Frame) { +///         // We create a `Path` representing a simple circle +///         let circle = Path::new(|p| p.circle(frame.center(), self.radius)); +/// +///         // And fill it with some color +///         frame.fill(&circle, Fill::Color(Color::BLACK)); +///     } +/// } +/// +/// // We can use a `Cache` to avoid unnecessary re-tessellation +/// let cache: layer::Cache<Circle> = layer::Cache::new(); +/// +/// // Finally, we simply provide the data to our `Cache` and push the resulting +/// // layer into a `Canvas` +/// let canvas = Canvas::new() +///     .push(cache.with(&Circle { radius: 50.0 })); +/// ```  #[derive(Debug)]  pub struct Canvas<'a> {      width: Length, diff --git a/wgpu/src/widget/canvas/layer/cache.rs b/wgpu/src/widget/canvas/layer/cache.rs index f7002459..20a095bd 100644 --- a/wgpu/src/widget/canvas/layer/cache.rs +++ b/wgpu/src/widget/canvas/layer/cache.rs @@ -12,7 +12,7 @@ use std::{cell::RefCell, marker::PhantomData, sync::Arc};  /// change or it is explicitly cleared.  ///  /// [`Layer`]: ../trait.Layer.html -/// [`Cached`]: struct.Cached.html +/// [`Cache`]: struct.Cache.html  #[derive(Debug)]  pub struct Cache<T: Drawable> {      input: PhantomData<T>, diff --git a/wgpu/src/widget/canvas/path.rs b/wgpu/src/widget/canvas/path.rs index 15c2e853..e7ff47f3 100644 --- a/wgpu/src/widget/canvas/path.rs +++ b/wgpu/src/widget/canvas/path.rs @@ -3,6 +3,7 @@ pub mod arc;  mod builder; +#[doc(no_inline)]  pub use arc::Arc;  pub use builder::Builder; diff --git a/wgpu/src/widget/pane_grid.rs b/wgpu/src/widget/pane_grid.rs index 7bc2f7c5..578e8960 100644 --- a/wgpu/src/widget/pane_grid.rs +++ b/wgpu/src/widget/pane_grid.rs @@ -1,6 +1,13 @@  //! Let your users split regions of your application and organize layout dynamically.  //!  //! [](https://gfycat.com/mixedflatjellyfish) +//! +//! # Example +//! The [`pane_grid` example] showcases how to use a [`PaneGrid`] with resizing, +//! drag and drop, and hotkey support. +//! +//! [`pane_grid` example]: https://github.com/hecrj/iced/tree/0.1/examples/pane_grid +//! [`PaneGrid`]: type.PaneGrid.html  use crate::Renderer;  pub use iced_native::pane_grid::{ | 
