From 89968e6f9646f29446817f98e17df3923fe2feac Mon Sep 17 00:00:00 2001 From: Emil Ernerfeldt Date: Wed, 29 May 2024 22:37:55 +0200 Subject: [PATCH] Bug fix: ui opacity and gray-out not affecting strokes (#4581) Bug introduced in https://github.com/emilk/egui/pull/4353 --- crates/epaint/src/shape_transform.rs | 45 ++++++++++++++-------------- 1 file changed, 23 insertions(+), 22 deletions(-) diff --git a/crates/epaint/src/shape_transform.rs b/crates/epaint/src/shape_transform.rs index d0ab91536d1..3e976768d3f 100644 --- a/crates/epaint/src/shape_transform.rs +++ b/crates/epaint/src/shape_transform.rs @@ -10,22 +10,16 @@ pub fn adjust_colors( #![allow(clippy::match_same_arms)] match shape { Shape::Noop => {} + Shape::Vec(shapes) => { for shape in shapes { adjust_colors(shape, adjust_color); } } - Shape::LineSegment { stroke, points: _ } => match &stroke.color { - color::ColorMode::Solid(mut col) => adjust_color(&mut col), - color::ColorMode::UV(callback) => { - let callback = callback.clone(); - stroke.color = color::ColorMode::UV(Arc::new(Box::new(move |rect, pos| { - let mut col = callback(rect, pos); - adjust_color(&mut col); - col - }))); - } - }, + + Shape::LineSegment { stroke, points: _ } => { + adjust_color_mode(&mut stroke.color, adjust_color); + } Shape::Path(PathShape { points: _, @@ -46,17 +40,7 @@ pub fn adjust_colors( stroke, }) => { adjust_color(fill); - match &stroke.color { - color::ColorMode::Solid(mut col) => adjust_color(&mut col), - color::ColorMode::UV(callback) => { - let callback = callback.clone(); - stroke.color = color::ColorMode::UV(Arc::new(Box::new(move |rect, pos| { - let mut col = callback(rect, pos); - adjust_color(&mut col); - col - }))); - } - } + adjust_color_mode(&mut stroke.color, adjust_color); } Shape::Circle(CircleShape { @@ -124,3 +108,20 @@ pub fn adjust_colors( } } } + +fn adjust_color_mode( + color_mode: &mut ColorMode, + adjust_color: impl Fn(&mut Color32) + Send + Sync + Copy + 'static, +) { + match color_mode { + color::ColorMode::Solid(color) => adjust_color(color), + color::ColorMode::UV(callback) => { + let callback = callback.clone(); + *color_mode = color::ColorMode::UV(Arc::new(Box::new(move |rect, pos| { + let mut color = callback(rect, pos); + adjust_color(&mut color); + color + }))); + } + } +}