diff options
| -rw-r--r-- | graphics/src/renderer.rs | 4 | ||||
| -rw-r--r-- | native/src/renderer/null.rs | 4 | ||||
| -rw-r--r-- | native/src/renderer/text.rs | 13 | ||||
| -rw-r--r-- | native/src/widget/checkbox.rs | 81 | 
4 files changed, 79 insertions, 23 deletions
| diff --git a/graphics/src/renderer.rs b/graphics/src/renderer.rs index f8c67047..5e74019f 100644 --- a/graphics/src/renderer.rs +++ b/graphics/src/renderer.rs @@ -91,6 +91,10 @@ where  {      type Font = Font; +    const ICON_FONT: Font = B::ICON_FONT; +    const CHECKMARK_ICON: char = B::CHECKMARK_ICON; +    const ARROW_DOWN_ICON: char = B::ARROW_DOWN_ICON; +      fn default_size(&self) -> u16 {          self.backend().default_size()      } diff --git a/native/src/renderer/null.rs b/native/src/renderer/null.rs index 010305a2..351f6233 100644 --- a/native/src/renderer/null.rs +++ b/native/src/renderer/null.rs @@ -35,6 +35,10 @@ impl Renderer for Null {  impl renderer::Text for Null {      type Font = Font; +    const ICON_FONT: Font = Font::Default; +    const CHECKMARK_ICON: char = '0'; +    const ARROW_DOWN_ICON: char = '0'; +      fn default_size(&self) -> u16 {          20      } diff --git a/native/src/renderer/text.rs b/native/src/renderer/text.rs index 80769b62..fbf116a1 100644 --- a/native/src/renderer/text.rs +++ b/native/src/renderer/text.rs @@ -7,6 +7,19 @@ pub trait Text: Renderer {      /// The font type used.      type Font: Default + Copy; +    /// The icon font of the backend. +    const ICON_FONT: Self::Font; + +    /// The `char` representing a ✔ icon in the [`ICON_FONT`]. +    /// +    /// [`ICON_FONT`]: Self::ICON_FONT +    const CHECKMARK_ICON: char; + +    /// The `char` representing a ▼ icon in the built-in [`ICON_FONT`]. +    /// +    /// [`ICON_FONT`]: Self::ICON_FONT +    const ARROW_DOWN_ICON: char; +      /// Returns the default size of [`Text`].      fn default_size(&self) -> u16; diff --git a/native/src/widget/checkbox.rs b/native/src/widget/checkbox.rs index c1408d73..babd74a5 100644 --- a/native/src/widget/checkbox.rs +++ b/native/src/widget/checkbox.rs @@ -1,10 +1,12 @@  //! Show toggle controls using checkboxes.  use std::hash::Hash; +use crate::alignment;  use crate::event::{self, Event};  use crate::layout;  use crate::mouse;  use crate::renderer; +use crate::text;  use crate::touch;  use crate::{      Alignment, Clipboard, Color, Element, Hasher, Layout, Length, Point, @@ -18,7 +20,7 @@ pub use iced_style::checkbox::{Style, StyleSheet};  /// # Example  ///  /// ``` -/// # type Checkbox<Message> = iced_native::Checkbox<Message, iced_native::renderer::Null>; +/// # type Checkbox<'a, Message> = iced_native::Checkbox<'a, Message, iced_native::renderer::Null>;  /// #  /// pub enum Message {  ///     CheckboxToggled(bool), @@ -192,28 +194,61 @@ where          cursor_position: Point,          _viewport: &Rectangle,      ) { -        // let bounds = layout.bounds(); -        // let mut children = layout.children(); - -        // let checkbox_layout = children.next().unwrap(); -        // let label_layout = children.next().unwrap(); -        // let checkbox_bounds = checkbox_layout.bounds(); - -        // let label = text::Renderer::draw( -        //     renderer, -        //     defaults, -        //     label_layout.bounds(), -        //     &self.label, -        //     self.text_size.unwrap_or(renderer.default_size()), -        //     self.font, -        //     self.text_color, -        //     alignment::Horizontal::Left, -        //     alignment::Vertical::Center, -        // ); - -        // let is_mouse_over = bounds.contains(cursor_position); - -        // TODO +        let bounds = layout.bounds(); +        let is_mouse_over = bounds.contains(cursor_position); + +        let mut children = layout.children(); + +        { +            let layout = children.next().unwrap(); +            let bounds = layout.bounds(); + +            let style = if is_mouse_over { +                self.style_sheet.hovered(self.is_checked) +            } else { +                self.style_sheet.active(self.is_checked) +            }; + +            renderer.fill_rectangle(renderer::Quad { +                bounds, +                background: style.background, +                border_radius: style.border_radius, +                border_width: style.border_width, +                border_color: style.border_color, +            }); + +            if self.is_checked { +                renderer.fill_text(renderer::text::Section { +                    content: &Renderer::CHECKMARK_ICON.to_string(), +                    font: Renderer::ICON_FONT, +                    size: bounds.height * 0.7, +                    bounds: Rectangle { +                        x: bounds.center_x(), +                        y: bounds.center_y(), +                        ..bounds +                    }, +                    color: style.checkmark_color, +                    horizontal_alignment: alignment::Horizontal::Center, +                    vertical_alignment: alignment::Vertical::Center, +                }); +            } +        } + +        { +            let label_layout = children.next().unwrap(); + +            text::draw( +                renderer, +                style, +                label_layout, +                &self.label, +                self.font, +                self.text_size, +                self.text_color, +                alignment::Horizontal::Left, +                alignment::Vertical::Center, +            ); +        }      }      fn hash_layout(&self, state: &mut Hasher) { | 
