diff options
| author | 2020-06-11 20:41:11 +0200 | |
|---|---|---|
| committer | 2020-07-08 11:19:56 +0200 | |
| commit | 61f22b1db23f3495145a9a4f7255311fe8381998 (patch) | |
| tree | 925db905f29c3df13cf6e7480672d2a294ce10c7 /graphics/src/overlay | |
| parent | 0ff5a02550e5d5de8fb5fd0643ea424d9e508888 (diff) | |
| download | iced-61f22b1db23f3495145a9a4f7255311fe8381998.tar.gz iced-61f22b1db23f3495145a9a4f7255311fe8381998.tar.bz2 iced-61f22b1db23f3495145a9a4f7255311fe8381998.zip | |
Add styling support for `ComboBox` and `Menu`
Diffstat (limited to '')
| -rw-r--r-- | graphics/src/overlay.rs | 2 | ||||
| -rw-r--r-- | graphics/src/overlay/menu.rs | 24 | 
2 files changed, 15 insertions, 11 deletions
| diff --git a/graphics/src/overlay.rs b/graphics/src/overlay.rs index c57668d4..b9a0e3e0 100644 --- a/graphics/src/overlay.rs +++ b/graphics/src/overlay.rs @@ -1 +1 @@ -mod menu; +pub mod menu; diff --git a/graphics/src/overlay/menu.rs b/graphics/src/overlay/menu.rs index f4204f25..13065645 100644 --- a/graphics/src/overlay/menu.rs +++ b/graphics/src/overlay/menu.rs @@ -1,18 +1,23 @@  use crate::backend::Backend;  use crate::{Primitive, Renderer};  use iced_native::{ -    mouse, overlay, Background, Color, Font, HorizontalAlignment, Point, -    Rectangle, VerticalAlignment, +    mouse, overlay, Color, Font, HorizontalAlignment, Point, Rectangle, +    VerticalAlignment,  }; +pub use iced_style::menu::Style; +  impl<B> overlay::menu::Renderer for Renderer<B>  where      B: Backend,  { +    type Style = Style; +      fn decorate(          &mut self,          bounds: Rectangle,          _cursor_position: Point, +        style: &Style,          (primitives, mouse_cursor): Self::Output,      ) -> Self::Output {          ( @@ -20,11 +25,9 @@ where                  primitives: vec![                      Primitive::Quad {                          bounds, -                        background: Background::Color( -                            [0.87, 0.87, 0.87].into(), -                        ), -                        border_color: [0.7, 0.7, 0.7].into(), -                        border_width: 1, +                        background: style.background, +                        border_color: style.border_color, +                        border_width: style.border_width,                          border_radius: 0,                      },                      primitives, @@ -42,6 +45,7 @@ where          hovered_option: Option<usize>,          text_size: u16,          padding: u16, +        style: &Style,      ) -> Self::Output {          use std::f32; @@ -63,7 +67,7 @@ where              if is_selected {                  primitives.push(Primitive::Quad {                      bounds, -                    background: Background::Color([0.4, 0.4, 1.0].into()), +                    background: style.selected_background,                      border_color: Color::TRANSPARENT,                      border_width: 0,                      border_radius: 0, @@ -81,9 +85,9 @@ where                  size: f32::from(text_size),                  font: Font::Default,                  color: if is_selected { -                    Color::WHITE +                    style.selected_text_color                  } else { -                    Color::BLACK +                    style.text_color                  },                  horizontal_alignment: HorizontalAlignment::Left,                  vertical_alignment: VerticalAlignment::Center, | 
