summaryrefslogtreecommitdiffstats
path: root/wgpu/src/renderer/widget/row.rs
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón <hector0193@gmail.com>2019-11-05 21:46:37 +0100
committerLibravatar GitHub <noreply@github.com>2019-11-05 21:46:37 +0100
commitae6156f779c24beaabf43ea6110d3ce38e34a998 (patch)
tree9545408530437eb780ac73c600f7d40968803786 /wgpu/src/renderer/widget/row.rs
parentda2717c74dbe3e1123ff41de345a409c1afc2f18 (diff)
parent0157121038987feb6c2ea3066a21ce25e689888e (diff)
downloadiced-ae6156f779c24beaabf43ea6110d3ce38e34a998.tar.gz
iced-ae6156f779c24beaabf43ea6110d3ce38e34a998.tar.bz2
iced-ae6156f779c24beaabf43ea6110d3ce38e34a998.zip
Merge pull request #38 from hecrj/feature/performance-metrics
Debug view
Diffstat (limited to 'wgpu/src/renderer/widget/row.rs')
-rw-r--r--wgpu/src/renderer/widget/row.rs34
1 files changed, 34 insertions, 0 deletions
diff --git a/wgpu/src/renderer/widget/row.rs b/wgpu/src/renderer/widget/row.rs
new file mode 100644
index 00000000..bbfef9a1
--- /dev/null
+++ b/wgpu/src/renderer/widget/row.rs
@@ -0,0 +1,34 @@
+use crate::{Primitive, Renderer};
+use iced_native::{row, Layout, MouseCursor, Point, Row};
+
+impl row::Renderer for Renderer {
+ fn draw<Message>(
+ &mut self,
+ row: &Row<'_, Message, Self>,
+ layout: Layout<'_>,
+ cursor_position: Point,
+ ) -> Self::Output {
+ let mut mouse_cursor = MouseCursor::OutOfBounds;
+
+ (
+ Primitive::Group {
+ primitives: row
+ .children
+ .iter()
+ .zip(layout.children())
+ .map(|(child, layout)| {
+ let (primitive, new_mouse_cursor) =
+ child.draw(self, layout, cursor_position);
+
+ if new_mouse_cursor > mouse_cursor {
+ mouse_cursor = new_mouse_cursor;
+ }
+
+ primitive
+ })
+ .collect(),
+ },
+ mouse_cursor,
+ )
+ }
+}