summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón Jiménez <hector0193@gmail.com>2023-03-03 04:00:44 +0100
committerLibravatar Héctor Ramón Jiménez <hector0193@gmail.com>2023-03-03 04:00:44 +0100
commitd13d19ba3569560edd67f20b48f37548d10ceee9 (patch)
treeb5dcc662534f0475bc385dd5595c2854ba66fc88
parentbbeaf10c04a922af5c1c3b898f0c4301d23feab0 (diff)
downloadiced-d13d19ba3569560edd67f20b48f37548d10ceee9.tar.gz
iced-d13d19ba3569560edd67f20b48f37548d10ceee9.tar.bz2
iced-d13d19ba3569560edd67f20b48f37548d10ceee9.zip
Rename `canvas::frame` to `canvas` in `iced_wgpu`
-rw-r--r--graphics/src/primitive.rs4
-rw-r--r--renderer/src/widget/canvas.rs6
-rw-r--r--tiny_skia/src/backend.rs3
-rw-r--r--wgpu/src/canvas.rs (renamed from wgpu/src/widget/canvas/frame.rs)7
-rw-r--r--wgpu/src/lib.rs5
-rw-r--r--wgpu/src/widget.rs9
-rw-r--r--wgpu/src/widget/canvas.rs16
-rw-r--r--wgpu/src/widget/canvas/cache.rs93
-rw-r--r--wgpu/src/widget/canvas/geometry.rs24
9 files changed, 14 insertions, 153 deletions
diff --git a/graphics/src/primitive.rs b/graphics/src/primitive.rs
index 5a48639d..f900b3fd 100644
--- a/graphics/src/primitive.rs
+++ b/graphics/src/primitive.rs
@@ -86,14 +86,14 @@ pub enum Primitive {
/// The [`Gradient`] to apply to the mesh.
gradient: Gradient,
},
- #[cfg(feature = "tiny_skia")]
+ #[cfg(feature = "tiny-skia")]
Fill {
path: tiny_skia::Path,
paint: tiny_skia::Paint<'static>,
rule: tiny_skia::FillRule,
transform: tiny_skia::Transform,
},
- #[cfg(feature = "tiny_skia")]
+ #[cfg(feature = "tiny-skia")]
Stroke {
path: tiny_skia::Path,
paint: tiny_skia::Paint<'static>,
diff --git a/renderer/src/widget/canvas.rs b/renderer/src/widget/canvas.rs
index f40a1097..35c8fff9 100644
--- a/renderer/src/widget/canvas.rs
+++ b/renderer/src/widget/canvas.rs
@@ -16,7 +16,7 @@ use crate::{Backend, Point, Rectangle, Size, Vector};
pub use crate::Geometry;
pub enum Frame {
- Wgpu(iced_wgpu::widget::canvas::Frame),
+ Wgpu(iced_wgpu::canvas::Frame),
TinySkia(iced_tiny_skia::canvas::Frame),
}
@@ -33,7 +33,7 @@ impl Frame {
pub fn new<Theme>(renderer: &crate::Renderer<Theme>, size: Size) -> Self {
match renderer.backend() {
Backend::Wgpu(_) => {
- Frame::Wgpu(iced_wgpu::widget::canvas::Frame::new(size))
+ Frame::Wgpu(iced_wgpu::canvas::Frame::new(size))
}
Backend::TinySkia(_) => {
Frame::TinySkia(iced_tiny_skia::canvas::Frame::new(size))
@@ -131,7 +131,7 @@ impl Frame {
pub fn with_clip(&mut self, region: Rectangle, f: impl FnOnce(&mut Frame)) {
let mut frame = match self {
Self::Wgpu(_) => {
- Self::Wgpu(iced_wgpu::widget::canvas::Frame::new(region.size()))
+ Self::Wgpu(iced_wgpu::canvas::Frame::new(region.size()))
}
Self::TinySkia(_) => Self::TinySkia(
iced_tiny_skia::canvas::Frame::new(region.size()),
diff --git a/tiny_skia/src/backend.rs b/tiny_skia/src/backend.rs
index 2e4663ea..6883a953 100644
--- a/tiny_skia/src/backend.rs
+++ b/tiny_skia/src/backend.rs
@@ -256,6 +256,9 @@ impl Backend {
// Not supported!
// TODO: Draw a placeholder (?) / Log it (?)
}
+ _ => {
+ // Not supported!
+ }
}
}
}
diff --git a/wgpu/src/widget/canvas/frame.rs b/wgpu/src/canvas.rs
index 987570ec..e8d540c3 100644
--- a/wgpu/src/widget/canvas/frame.rs
+++ b/wgpu/src/canvas.rs
@@ -1,9 +1,8 @@
-use crate::primitive::{self, Primitive};
-use crate::widget::canvas::fill::{self, Fill};
-use crate::widget::canvas::{
+use iced_graphics::primitive::{self, Primitive};
+use iced_native::widget::canvas::fill::{self, Fill};
+use iced_native::widget::canvas::{
LineCap, LineDash, LineJoin, Path, Stroke, Style, Text,
};
-
use iced_native::{Gradient, Point, Rectangle, Size, Vector};
use lyon::geom::euclid;
diff --git a/wgpu/src/lib.rs b/wgpu/src/lib.rs
index 8be12602..31db16a8 100644
--- a/wgpu/src/lib.rs
+++ b/wgpu/src/lib.rs
@@ -37,12 +37,13 @@
#![forbid(rust_2018_idioms)]
#![allow(clippy::inherent_to_string, clippy::type_complexity)]
#![cfg_attr(docsrs, feature(doc_cfg))]
-
pub mod layer;
pub mod settings;
-pub mod widget;
pub mod window;
+#[cfg(feature = "canvas")]
+pub mod canvas;
+
mod backend;
mod buffer;
mod quad;
diff --git a/wgpu/src/widget.rs b/wgpu/src/widget.rs
deleted file mode 100644
index 8d05041e..00000000
--- a/wgpu/src/widget.rs
+++ /dev/null
@@ -1,9 +0,0 @@
-//! Use the graphical widgets supported out-of-the-box.
-
-#[cfg(feature = "canvas")]
-#[cfg_attr(docsrs, doc(cfg(feature = "canvas")))]
-pub mod canvas;
-
-#[cfg(feature = "canvas")]
-#[doc(no_inline)]
-pub use canvas::Canvas;
diff --git a/wgpu/src/widget/canvas.rs b/wgpu/src/widget/canvas.rs
deleted file mode 100644
index 41444fcf..00000000
--- a/wgpu/src/widget/canvas.rs
+++ /dev/null
@@ -1,16 +0,0 @@
-mod cache;
-mod frame;
-mod geometry;
-
-pub use cache::Cache;
-pub use frame::Frame;
-pub use geometry::Geometry;
-
-pub use iced_native::widget::canvas::event::{self, Event};
-pub use iced_native::widget::canvas::fill::{self, Fill};
-pub use iced_native::widget::canvas::gradient::{self, Gradient};
-pub use iced_native::widget::canvas::path::{self, Path};
-pub use iced_native::widget::canvas::stroke::{self, Stroke};
-pub use iced_native::widget::canvas::{
- Canvas, Cursor, LineCap, LineDash, LineJoin, Program, Renderer, Style, Text,
-};
diff --git a/wgpu/src/widget/canvas/cache.rs b/wgpu/src/widget/canvas/cache.rs
deleted file mode 100644
index 09b26b90..00000000
--- a/wgpu/src/widget/canvas/cache.rs
+++ /dev/null
@@ -1,93 +0,0 @@
-use crate::widget::canvas::{Frame, Geometry};
-use crate::Primitive;
-
-use iced_native::Size;
-use std::{cell::RefCell, sync::Arc};
-
-#[derive(Default)]
-enum State {
- #[default]
- Empty,
- Filled {
- bounds: Size,
- primitive: Arc<Primitive>,
- },
-}
-
-/// A simple cache that stores generated [`Geometry`] to avoid recomputation.
-///
-/// A [`Cache`] will not redraw its geometry unless the dimensions of its layer
-/// change or it is explicitly cleared.
-#[derive(Debug, Default)]
-pub struct Cache {
- state: RefCell<State>,
-}
-
-impl Cache {
- /// Creates a new empty [`Cache`].
- pub fn new() -> Self {
- Cache {
- state: Default::default(),
- }
- }
-
- /// Clears the [`Cache`], forcing a redraw the next time it is used.
- pub fn clear(&self) {
- *self.state.borrow_mut() = State::Empty;
- }
-
- /// Draws [`Geometry`] using the provided closure and stores it in the
- /// [`Cache`].
- ///
- /// The closure will only be called when
- /// - the bounds have changed since the previous draw call.
- /// - the [`Cache`] is empty or has been explicitly cleared.
- ///
- /// Otherwise, the previously stored [`Geometry`] will be returned. The
- /// [`Cache`] is not cleared in this case. In other words, it will keep
- /// returning the stored [`Geometry`] if needed.
- pub fn draw(
- &self,
- bounds: Size,
- draw_fn: impl FnOnce(&mut Frame),
- ) -> Geometry {
- use std::ops::Deref;
-
- if let State::Filled {
- bounds: cached_bounds,
- primitive,
- } = self.state.borrow().deref()
- {
- if *cached_bounds == bounds {
- return Geometry::from_primitive(Primitive::Cache {
- content: primitive.clone(),
- });
- }
- }
-
- let mut frame = Frame::new(bounds);
- draw_fn(&mut frame);
-
- let primitive = Arc::new(frame.into_primitive());
-
- *self.state.borrow_mut() = State::Filled {
- bounds,
- primitive: primitive.clone(),
- };
-
- Geometry::from_primitive(Primitive::Cache { content: primitive })
- }
-}
-
-impl std::fmt::Debug for State {
- fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
- match self {
- State::Empty => write!(f, "Empty"),
- State::Filled { primitive, bounds } => f
- .debug_struct("Filled")
- .field("primitive", primitive)
- .field("bounds", bounds)
- .finish(),
- }
- }
-}
diff --git a/wgpu/src/widget/canvas/geometry.rs b/wgpu/src/widget/canvas/geometry.rs
deleted file mode 100644
index e8ac621d..00000000
--- a/wgpu/src/widget/canvas/geometry.rs
+++ /dev/null
@@ -1,24 +0,0 @@
-use crate::Primitive;
-
-/// A bunch of shapes that can be drawn.
-///
-/// [`Geometry`] can be easily generated with a [`Frame`] or stored in a
-/// [`Cache`].
-///
-/// [`Frame`]: crate::widget::canvas::Frame
-/// [`Cache`]: crate::widget::canvas::Cache
-#[derive(Debug, Clone)]
-pub struct Geometry(Primitive);
-
-impl Geometry {
- pub(crate) fn from_primitive(primitive: Primitive) -> Self {
- Self(primitive)
- }
-
- /// Turns the [`Geometry`] into a [`Primitive`].
- ///
- /// This can be useful if you are building a custom widget.
- pub fn into_primitive(self) -> Primitive {
- self.0
- }
-}