diff options
Diffstat (limited to 'native/src')
| -rw-r--r-- | native/src/element.rs | 2 | ||||
| -rw-r--r-- | native/src/overlay/menu.rs | 4 | ||||
| -rw-r--r-- | native/src/renderer.rs | 25 | ||||
| -rw-r--r-- | native/src/widget/button.rs | 4 | ||||
| -rw-r--r-- | native/src/widget/checkbox.rs | 2 | ||||
| -rw-r--r-- | native/src/widget/container.rs | 2 | ||||
| -rw-r--r-- | native/src/widget/pane_grid.rs | 2 | ||||
| -rw-r--r-- | native/src/widget/pick_list.rs | 2 | ||||
| -rw-r--r-- | native/src/widget/progress_bar.rs | 4 | ||||
| -rw-r--r-- | native/src/widget/radio.rs | 4 | ||||
| -rw-r--r-- | native/src/widget/rule.rs | 2 | ||||
| -rw-r--r-- | native/src/widget/scrollable.rs | 4 | ||||
| -rw-r--r-- | native/src/widget/slider.rs | 6 | ||||
| -rw-r--r-- | native/src/widget/text_input.rs | 6 | ||||
| -rw-r--r-- | native/src/widget/toggler.rs | 4 | 
15 files changed, 48 insertions, 25 deletions
| diff --git a/native/src/element.rs b/native/src/element.rs index 4cca3870..2f1adeff 100644 --- a/native/src/element.rs +++ b/native/src/element.rs @@ -519,7 +519,7 @@ where                      bounds: layout.bounds(),                      border_color: color,                      border_width: 1.0, -                    border_radius: 0.0, +                    border_radius: 0.0.into(),                  },                  Color::TRANSPARENT,              ); diff --git a/native/src/overlay/menu.rs b/native/src/overlay/menu.rs index 2e4f70b5..099b1a97 100644 --- a/native/src/overlay/menu.rs +++ b/native/src/overlay/menu.rs @@ -287,7 +287,7 @@ where                  },                  border_color: appearance.border_color,                  border_width: appearance.border_width, -                border_radius: appearance.border_radius, +                border_radius: appearance.border_radius.into(),              },              appearance.background,          ); @@ -479,7 +479,7 @@ where                          bounds,                          border_color: Color::TRANSPARENT,                          border_width: 0.0, -                        border_radius: appearance.border_radius, +                        border_radius: appearance.border_radius.into(),                      },                      appearance.selected_background,                  ); diff --git a/native/src/renderer.rs b/native/src/renderer.rs index ef64ac36..5e776be6 100644 --- a/native/src/renderer.rs +++ b/native/src/renderer.rs @@ -50,7 +50,7 @@ pub struct Quad {      pub bounds: Rectangle,      /// The border radius of the [`Quad`]. -    pub border_radius: f32, +    pub border_radius: BorderRadius,      /// The border width of the [`Quad`].      pub border_width: f32, @@ -59,6 +59,29 @@ pub struct Quad {      pub border_color: Color,  } +/// The border radi for the corners of a graphics primitive in the order: +/// top-left, top-right, bottom-right, bottom-left. +#[derive(Debug, Clone, Copy, PartialEq, Default)] +pub struct BorderRadius([f32; 4]); + +impl From<f32> for BorderRadius { +    fn from(w: f32) -> Self { +        Self([w; 4]) +    } +} + +impl From<[f32; 4]> for BorderRadius { +    fn from(radi: [f32; 4]) -> Self { +        Self(radi) +    } +} + +impl From<BorderRadius> for [f32; 4] { +    fn from(radi: BorderRadius) -> Self { +        radi.0 +    } +} +  /// The styling attributes of a [`Renderer`].  #[derive(Debug, Clone, Copy, PartialEq)]  pub struct Style { diff --git a/native/src/widget/button.rs b/native/src/widget/button.rs index d68e01c7..bbd9451c 100644 --- a/native/src/widget/button.rs +++ b/native/src/widget/button.rs @@ -393,7 +393,7 @@ where                          y: bounds.y + styling.shadow_offset.y,                          ..bounds                      }, -                    border_radius: styling.border_radius, +                    border_radius: styling.border_radius.into(),                      border_width: 0.0,                      border_color: Color::TRANSPARENT,                  }, @@ -404,7 +404,7 @@ where          renderer.fill_quad(              renderer::Quad {                  bounds, -                border_radius: styling.border_radius, +                border_radius: styling.border_radius.into(),                  border_width: styling.border_width,                  border_color: styling.border_color,              }, diff --git a/native/src/widget/checkbox.rs b/native/src/widget/checkbox.rs index 77d639a9..bec5c448 100644 --- a/native/src/widget/checkbox.rs +++ b/native/src/widget/checkbox.rs @@ -236,7 +236,7 @@ where              renderer.fill_quad(                  renderer::Quad {                      bounds, -                    border_radius: custom_style.border_radius, +                    border_radius: custom_style.border_radius.into(),                      border_width: custom_style.border_width,                      border_color: custom_style.border_color,                  }, diff --git a/native/src/widget/container.rs b/native/src/widget/container.rs index 1c681091..16d0cb61 100644 --- a/native/src/widget/container.rs +++ b/native/src/widget/container.rs @@ -321,7 +321,7 @@ pub fn draw_background<Renderer>(          renderer.fill_quad(              renderer::Quad {                  bounds, -                border_radius: appearance.border_radius, +                border_radius: appearance.border_radius.into(),                  border_width: appearance.border_width,                  border_color: appearance.border_color,              }, diff --git a/native/src/widget/pane_grid.rs b/native/src/widget/pane_grid.rs index c3ac6de6..edad993e 100644 --- a/native/src/widget/pane_grid.rs +++ b/native/src/widget/pane_grid.rs @@ -877,7 +877,7 @@ pub fn draw<Renderer, T>(                              height: split_region.height,                          },                      }, -                    border_radius: 0.0, +                    border_radius: 0.0.into(),                      border_width: 0.0,                      border_color: Color::TRANSPARENT,                  }, diff --git a/native/src/widget/pick_list.rs b/native/src/widget/pick_list.rs index 8f799a2a..52cb1ad1 100644 --- a/native/src/widget/pick_list.rs +++ b/native/src/widget/pick_list.rs @@ -536,7 +536,7 @@ pub fn draw<T, Renderer>(              bounds,              border_color: style.border_color,              border_width: style.border_width, -            border_radius: style.border_radius, +            border_radius: style.border_radius.into(),          },          style.background,      ); diff --git a/native/src/widget/progress_bar.rs b/native/src/widget/progress_bar.rs index b053d959..f059026f 100644 --- a/native/src/widget/progress_bar.rs +++ b/native/src/widget/progress_bar.rs @@ -129,7 +129,7 @@ where          renderer.fill_quad(              renderer::Quad {                  bounds: Rectangle { ..bounds }, -                border_radius: style.border_radius, +                border_radius: style.border_radius.into(),                  border_width: 0.0,                  border_color: Color::TRANSPARENT,              }, @@ -143,7 +143,7 @@ where                          width: active_progress_width,                          ..bounds                      }, -                    border_radius: style.border_radius, +                    border_radius: style.border_radius.into(),                      border_width: 0.0,                      border_color: Color::TRANSPARENT,                  }, diff --git a/native/src/widget/radio.rs b/native/src/widget/radio.rs index 743689c7..b95ccc5b 100644 --- a/native/src/widget/radio.rs +++ b/native/src/widget/radio.rs @@ -245,7 +245,7 @@ where              renderer.fill_quad(                  renderer::Quad {                      bounds, -                    border_radius: size / 2.0, +                    border_radius: (size / 2.0).into(),                      border_width: custom_style.border_width,                      border_color: custom_style.border_color,                  }, @@ -261,7 +261,7 @@ where                              width: bounds.width - dot_size,                              height: bounds.height - dot_size,                          }, -                        border_radius: dot_size / 2.0, +                        border_radius: (dot_size / 2.0).into(),                          border_width: 0.0,                          border_color: Color::TRANSPARENT,                      }, diff --git a/native/src/widget/rule.rs b/native/src/widget/rule.rs index e44d8d99..2dc7b6f0 100644 --- a/native/src/widget/rule.rs +++ b/native/src/widget/rule.rs @@ -123,7 +123,7 @@ where          renderer.fill_quad(              renderer::Quad {                  bounds, -                border_radius: style.radius, +                border_radius: style.radius.into(),                  border_width: 0.0,                  border_color: Color::TRANSPARENT,              }, diff --git a/native/src/widget/scrollable.rs b/native/src/widget/scrollable.rs index 495b7af1..a5e97aa7 100644 --- a/native/src/widget/scrollable.rs +++ b/native/src/widget/scrollable.rs @@ -704,7 +704,7 @@ pub fn draw<Renderer>(                      renderer.fill_quad(                          renderer::Quad {                              bounds: scrollbar.bounds, -                            border_radius: style.border_radius, +                            border_radius: style.border_radius.into(),                              border_width: style.border_width,                              border_color: style.border_color,                          }, @@ -721,7 +721,7 @@ pub fn draw<Renderer>(                      renderer.fill_quad(                          renderer::Quad {                              bounds: scrollbar.scroller.bounds, -                            border_radius: style.scroller.border_radius, +                            border_radius: style.scroller.border_radius.into(),                              border_width: style.scroller.border_width,                              border_color: style.scroller.border_color,                          }, diff --git a/native/src/widget/slider.rs b/native/src/widget/slider.rs index fd9160a4..87030a4d 100644 --- a/native/src/widget/slider.rs +++ b/native/src/widget/slider.rs @@ -380,7 +380,7 @@ pub fn draw<T, R>(                  width: bounds.width,                  height: 2.0,              }, -            border_radius: 0.0, +            border_radius: 0.0.into(),              border_width: 0.0,              border_color: Color::TRANSPARENT,          }, @@ -395,7 +395,7 @@ pub fn draw<T, R>(                  width: bounds.width,                  height: 2.0,              }, -            border_radius: 0.0, +            border_radius: 0.0.into(),              border_width: 0.0,              border_color: Color::TRANSPARENT,          }, @@ -435,7 +435,7 @@ pub fn draw<T, R>(                  width: handle_width,                  height: handle_height,              }, -            border_radius: handle_border_radius, +            border_radius: handle_border_radius.into(),              border_width: style.handle.border_width,              border_color: style.handle.border_color,          }, diff --git a/native/src/widget/text_input.rs b/native/src/widget/text_input.rs index 14e7e1b7..9391d1dd 100644 --- a/native/src/widget/text_input.rs +++ b/native/src/widget/text_input.rs @@ -801,7 +801,7 @@ pub fn draw<Renderer>(      renderer.fill_quad(          renderer::Quad {              bounds, -            border_radius: appearance.border_radius, +            border_radius: appearance.border_radius.into(),              border_width: appearance.border_width,              border_color: appearance.border_color,          }, @@ -833,7 +833,7 @@ pub fn draw<Renderer>(                                  width: 1.0,                                  height: text_bounds.height,                              }, -                            border_radius: 0.0, +                            border_radius: 0.0.into(),                              border_width: 0.0,                              border_color: Color::TRANSPARENT,                          }, @@ -877,7 +877,7 @@ pub fn draw<Renderer>(                                  width,                                  height: text_bounds.height,                              }, -                            border_radius: 0.0, +                            border_radius: 0.0.into(),                              border_width: 0.0,                              border_color: Color::TRANSPARENT,                          }, diff --git a/native/src/widget/toggler.rs b/native/src/widget/toggler.rs index 99a56ea8..37cafd92 100644 --- a/native/src/widget/toggler.rs +++ b/native/src/widget/toggler.rs @@ -278,7 +278,7 @@ where          renderer.fill_quad(              renderer::Quad {                  bounds: toggler_background_bounds, -                border_radius, +                border_radius: border_radius.into(),                  border_width: 1.0,                  border_color: style                      .background_border @@ -302,7 +302,7 @@ where          renderer.fill_quad(              renderer::Quad {                  bounds: toggler_foreground_bounds, -                border_radius, +                border_radius: border_radius.into(),                  border_width: 1.0,                  border_color: style                      .foreground_border | 
