diff options
author | 2024-06-21 10:41:17 +0100 | |
---|---|---|
committer | 2024-09-10 23:44:04 +0200 | |
commit | ec39390c23cd46a115bb0528abdb2c5527f1272a (patch) | |
tree | 104c7209bc2c37cdd332b31d8308237461a22a63 /wgpu | |
parent | abd323181d613f1dc69b6cbe885dce556f427de2 (diff) | |
download | iced-ec39390c23cd46a115bb0528abdb2c5527f1272a.tar.gz iced-ec39390c23cd46a115bb0528abdb2c5527f1272a.tar.bz2 iced-ec39390c23cd46a115bb0528abdb2c5527f1272a.zip |
Add stroke_rectangle
This method should be able to leverage performance improvements in lyon's
`tessellate_rectangle` over `tessellate_path`.
Diffstat (limited to 'wgpu')
-rw-r--r-- | wgpu/src/geometry.rs | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/wgpu/src/geometry.rs b/wgpu/src/geometry.rs index be65ba36..8e6f77d7 100644 --- a/wgpu/src/geometry.rs +++ b/wgpu/src/geometry.rs @@ -253,6 +253,44 @@ impl geometry::frame::Backend for Frame { .expect("Stroke path"); } + fn stroke_rectangle<'a>( + &mut self, + top_left: Point, + size: Size, + stroke: impl Into<Stroke<'a>>, + ) { + let stroke = stroke.into(); + + let mut buffer = self + .buffers + .get_stroke(&self.transforms.current.transform_style(stroke.style)); + + let top_left = self + .transforms + .current + .0 + .transform_point(lyon::math::Point::new(top_left.x, top_left.y)); + + let size = + self.transforms.current.0.transform_vector( + lyon::math::Vector::new(size.width, size.height), + ); + + let mut options = tessellation::StrokeOptions::default(); + options.line_width = stroke.width; + options.start_cap = into_line_cap(stroke.line_cap); + options.end_cap = into_line_cap(stroke.line_cap); + options.line_join = into_line_join(stroke.line_join); + + self.stroke_tessellator + .tessellate_rectangle( + &lyon::math::Box2D::new(top_left, top_left + size), + &options, + buffer.as_mut(), + ) + .expect("Stroke rectangle"); + } + fn fill_text(&mut self, text: impl Into<geometry::Text>) { let text = text.into(); |