summaryrefslogtreecommitdiffstats
path: root/wgpu/src/renderer
diff options
context:
space:
mode:
Diffstat (limited to 'wgpu/src/renderer')
-rw-r--r--wgpu/src/renderer/widget.rs2
-rw-r--r--wgpu/src/renderer/widget/image_pane.rs36
2 files changed, 38 insertions, 0 deletions
diff --git a/wgpu/src/renderer/widget.rs b/wgpu/src/renderer/widget.rs
index 37421fbe..6e1b7fe9 100644
--- a/wgpu/src/renderer/widget.rs
+++ b/wgpu/src/renderer/widget.rs
@@ -17,3 +17,5 @@ mod svg;
#[cfg(feature = "image")]
mod image;
+#[cfg(feature = "image")]
+mod image_pane;
diff --git a/wgpu/src/renderer/widget/image_pane.rs b/wgpu/src/renderer/widget/image_pane.rs
new file mode 100644
index 00000000..8b032250
--- /dev/null
+++ b/wgpu/src/renderer/widget/image_pane.rs
@@ -0,0 +1,36 @@
+use crate::{Primitive, Renderer};
+use iced_native::{image, image_pane, MouseCursor, Rectangle, Vector};
+
+impl image_pane::Renderer for Renderer {
+ fn draw(
+ &mut self,
+ state: &image_pane::State,
+ bounds: Rectangle,
+ image_bounds: Rectangle,
+ offset: (u32, u32),
+ handle: image::Handle,
+ is_mouse_over: bool,
+ ) -> Self::Output {
+ (
+ {
+ Primitive::Clip {
+ bounds,
+ offset: Vector::new(offset.0, offset.1),
+ content: Box::new(Primitive::Image {
+ handle,
+ bounds: image_bounds,
+ }),
+ }
+ },
+ {
+ if state.is_cursor_clicked() {
+ MouseCursor::Grabbing
+ } else if is_mouse_over {
+ MouseCursor::Grab
+ } else {
+ MouseCursor::OutOfBounds
+ }
+ },
+ )
+ }
+}