diff options
author | 2019-11-05 21:46:37 +0100 | |
---|---|---|
committer | 2019-11-05 21:46:37 +0100 | |
commit | ae6156f779c24beaabf43ea6110d3ce38e34a998 (patch) | |
tree | 9545408530437eb780ac73c600f7d40968803786 /wgpu/src/renderer/widget/row.rs | |
parent | da2717c74dbe3e1123ff41de345a409c1afc2f18 (diff) | |
parent | 0157121038987feb6c2ea3066a21ce25e689888e (diff) | |
download | iced-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.rs | 34 |
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, + ) + } +} |