diff options
| author | 2021-02-23 03:09:16 +0100 | |
|---|---|---|
| committer | 2021-02-23 03:09:16 +0100 | |
| commit | 81c75c15249b608dd8a6d47e25f96feb10ca68da (patch) | |
| tree | cd069025bcda644c2cc5d00750981c927f15950f /native/src/widget | |
| parent | a19f89d3a6af2804f2ac4e30f6d639b56a9bebfd (diff) | |
| download | iced-81c75c15249b608dd8a6d47e25f96feb10ca68da.tar.gz iced-81c75c15249b608dd8a6d47e25f96feb10ca68da.tar.bz2 iced-81c75c15249b608dd8a6d47e25f96feb10ca68da.zip | |
Change `Tooltip` to support `Text` only for now
Diffstat (limited to 'native/src/widget')
| -rw-r--r-- | native/src/widget/column.rs | 10 | ||||
| -rw-r--r-- | native/src/widget/container.rs | 8 | ||||
| -rw-r--r-- | native/src/widget/pane_grid.rs | 6 | ||||
| -rw-r--r-- | native/src/widget/pane_grid/content.rs | 7 | ||||
| -rw-r--r-- | native/src/widget/pick_list.rs | 2 | ||||
| -rw-r--r-- | native/src/widget/row.rs | 10 | ||||
| -rw-r--r-- | native/src/widget/scrollable.rs | 8 | ||||
| -rw-r--r-- | native/src/widget/tooltip.rs | 194 | 
8 files changed, 33 insertions, 212 deletions
| diff --git a/native/src/widget/column.rs b/native/src/widget/column.rs index 9ee60627..e0e88d31 100644 --- a/native/src/widget/column.rs +++ b/native/src/widget/column.rs @@ -198,19 +198,11 @@ where      fn overlay(          &mut self,          layout: Layout<'_>, -        overlay_content_bounds: Option<Rectangle>, -        cursor_position: Point,      ) -> Option<overlay::Element<'_, Message, Renderer>> {          self.children              .iter_mut()              .zip(layout.children()) -            .filter_map(|(child, layout)| { -                child.widget.overlay( -                    layout, -                    overlay_content_bounds, -                    cursor_position, -                ) -            }) +            .filter_map(|(child, layout)| child.widget.overlay(layout))              .next()      }  } diff --git a/native/src/widget/container.rs b/native/src/widget/container.rs index 2fc6707e..65764148 100644 --- a/native/src/widget/container.rs +++ b/native/src/widget/container.rs @@ -200,14 +200,8 @@ where      fn overlay(          &mut self,          layout: Layout<'_>, -        overlay_content_bounds: Option<Rectangle>, -        cursor_position: Point,      ) -> Option<overlay::Element<'_, Message, Renderer>> { -        self.content.overlay( -            layout.children().next().unwrap(), -            overlay_content_bounds, -            cursor_position, -        ) +        self.content.overlay(layout.children().next().unwrap())      }  } diff --git a/native/src/widget/pane_grid.rs b/native/src/widget/pane_grid.rs index 0a7d818d..c6fe4b60 100644 --- a/native/src/widget/pane_grid.rs +++ b/native/src/widget/pane_grid.rs @@ -558,15 +558,11 @@ where      fn overlay(          &mut self,          layout: Layout<'_>, -        overlay_content_bounds: Option<Rectangle>, -        cursor_position: Point,      ) -> Option<overlay::Element<'_, Message, Renderer>> {          self.elements              .iter_mut()              .zip(layout.children()) -            .filter_map(|((_, pane), layout)| { -                pane.overlay(layout, overlay_content_bounds, cursor_position) -            }) +            .filter_map(|((_, pane), layout)| pane.overlay(layout))              .next()      }  } diff --git a/native/src/widget/pane_grid/content.rs b/native/src/widget/pane_grid/content.rs index 28515624..913cfe96 100644 --- a/native/src/widget/pane_grid/content.rs +++ b/native/src/widget/pane_grid/content.rs @@ -1,5 +1,3 @@ -use iced_core::Rectangle; -  use crate::container;  use crate::event::{self, Event};  use crate::layout; @@ -191,8 +189,6 @@ where      pub(crate) fn overlay(          &mut self,          layout: Layout<'_>, -        overlay_content_bounds: Option<Rectangle>, -        cursor_position: Point,      ) -> Option<overlay::Element<'_, Message, Renderer>> {          let body_layout = if self.title_bar.is_some() {              let mut children = layout.children(); @@ -205,8 +201,7 @@ where              layout          }; -        self.body -            .overlay(body_layout, overlay_content_bounds, cursor_position) +        self.body.overlay(body_layout)      }  } diff --git a/native/src/widget/pick_list.rs b/native/src/widget/pick_list.rs index 6c424d28..74f4508e 100644 --- a/native/src/widget/pick_list.rs +++ b/native/src/widget/pick_list.rs @@ -274,8 +274,6 @@ where      fn overlay(          &mut self,          layout: Layout<'_>, -        _overlay_content_bounds: Option<Rectangle>, -        _cursor_position: Point,      ) -> Option<overlay::Element<'_, Message, Renderer>> {          if *self.is_open {              let bounds = layout.bounds(); diff --git a/native/src/widget/row.rs b/native/src/widget/row.rs index c542aedc..b71663bd 100644 --- a/native/src/widget/row.rs +++ b/native/src/widget/row.rs @@ -197,19 +197,11 @@ where      fn overlay(          &mut self,          layout: Layout<'_>, -        overlay_content_bounds: Option<Rectangle>, -        cursor_position: Point,      ) -> Option<overlay::Element<'_, Message, Renderer>> {          self.children              .iter_mut()              .zip(layout.children()) -            .filter_map(|(child, layout)| { -                child.widget.overlay( -                    layout, -                    overlay_content_bounds, -                    cursor_position, -                ) -            }) +            .filter_map(|(child, layout)| child.widget.overlay(layout))              .next()      }  } diff --git a/native/src/widget/scrollable.rs b/native/src/widget/scrollable.rs index 86a68f22..18cdf169 100644 --- a/native/src/widget/scrollable.rs +++ b/native/src/widget/scrollable.rs @@ -401,17 +401,11 @@ where      fn overlay(          &mut self,          layout: Layout<'_>, -        overlay_content_bounds: Option<Rectangle>, -        cursor_position: Point,      ) -> Option<overlay::Element<'_, Message, Renderer>> {          let Self { content, state, .. } = self;          content -            .overlay( -                layout.children().next().unwrap(), -                overlay_content_bounds, -                cursor_position, -            ) +            .overlay(layout.children().next().unwrap())              .map(|overlay| {                  let bounds = layout.bounds();                  let content_layout = layout.children().next().unwrap(); diff --git a/native/src/widget/tooltip.rs b/native/src/widget/tooltip.rs index cae38d46..72d03c1a 100644 --- a/native/src/widget/tooltip.rs +++ b/native/src/widget/tooltip.rs @@ -3,46 +3,43 @@ use std::hash::Hash;  use iced_core::Rectangle; +use crate::widget::text::{self, Text};  use crate::{ -    event, layout, overlay, Clipboard, Element, Event, Hasher, Layout, Length, -    Point, Size, Vector, Widget, +    event, layout, Clipboard, Element, Event, Hasher, Layout, Length, Point, +    Widget,  };  /// An element to display a widget over another.  #[allow(missing_debug_implementations)] -pub struct Tooltip<'a, Message, Renderer: self::Renderer> { +pub struct Tooltip<'a, Message, Renderer: self::Renderer + text::Renderer> {      content: Element<'a, Message, Renderer>, -    tooltip: Element<'a, Message, Renderer>, -    tooltip_position: TooltipPosition, +    tooltip: Text<Renderer>, +    position: Position,  }  impl<'a, Message, Renderer> Tooltip<'a, Message, Renderer>  where -    Renderer: self::Renderer, +    Renderer: self::Renderer + text::Renderer,  {      /// Creates an empty [`Tooltip`].      ///      /// [`Tooltip`]: struct.Tooltip.html -    pub fn new<T, H>( -        content: T, -        tooltip: H, -        tooltip_position: TooltipPosition, -    ) -> Self -    where -        T: Into<Element<'a, Message, Renderer>>, -        H: Into<Element<'a, Message, Renderer>>, -    { +    pub fn new( +        content: impl Into<Element<'a, Message, Renderer>>, +        tooltip: Text<Renderer>, +        position: Position, +    ) -> Self {          Tooltip {              content: content.into(), -            tooltip: tooltip.into(), -            tooltip_position, +            tooltip, +            position,          }      }  }  /// The position of the tooltip. Defaults to following the cursor. -#[derive(Debug, PartialEq)] -pub enum TooltipPosition { +#[derive(Debug, Clone, Copy, PartialEq, Eq)] +pub enum Position {      /// The tooltip will follow the cursor.      FollowCursor,      /// The tooltip will appear on the top of the widget. @@ -55,16 +52,10 @@ pub enum TooltipPosition {      Right,  } -impl Default for TooltipPosition { -    fn default() -> Self { -        TooltipPosition::FollowCursor -    } -} -  impl<'a, Message, Renderer> Widget<Message, Renderer>      for Tooltip<'a, Message, Renderer>  where -    Renderer: self::Renderer, +    Renderer: self::Renderer + text::Renderer,  {      fn width(&self) -> Length {          self.content.width() @@ -109,12 +100,15 @@ where          cursor_position: Point,          viewport: &Rectangle,      ) -> Renderer::Output { -        renderer.draw( +        self::Renderer::draw( +            renderer,              defaults,              cursor_position, -            &self.content,              layout,              viewport, +            &self.content, +            &self.tooltip, +            self.position,          )      } @@ -124,142 +118,6 @@ where          self.content.hash_layout(state);      } - -    fn overlay( -        &mut self, -        layout: Layout<'_>, -        overlay_content_bounds: Option<Rectangle>, -        cursor_position: Point, -    ) -> Option<overlay::Element<'_, Message, Renderer>> { -        let bounds = layout.bounds(); - -        if bounds.contains(cursor_position) { -            let mut position = cursor_position; - -            if let Some(content_bounds) = overlay_content_bounds { -                if TooltipPosition::FollowCursor != self.tooltip_position { -                    match self.tooltip_position { -                        TooltipPosition::Top | TooltipPosition::Bottom => { -                            let x = bounds.x + bounds.width * 0.5 -                                - content_bounds.width * 0.5; - -                            position = match self.tooltip_position { -                                TooltipPosition::Top => Point::new( -                                    x, -                                    bounds.y - content_bounds.height, -                                ), -                                TooltipPosition::Bottom => Point::new( -                                    x, -                                    bounds.y -                                        + bounds.height -                                        + content_bounds.height, -                                ), -                                _ => unreachable!(), -                            }; -                        } -                        TooltipPosition::Left | TooltipPosition::Right => { -                            let y = -                                bounds.center_y() + content_bounds.height * 0.5; - -                            position = match self.tooltip_position { -                                TooltipPosition::Left => Point::new( -                                    bounds.x - content_bounds.width, -                                    y, -                                ), -                                TooltipPosition::Right => { -                                    Point::new(bounds.x + bounds.width, y) -                                } -                                _ => unreachable!(), -                            }; -                        } -                        _ => {} -                    } -                } -            } - -            Some(overlay::Element::new( -                position, -                Box::new(Overlay::new(&self.tooltip)), -            )) -        } else { -            None -        } -    } -} - -struct Overlay<'a, Message, Renderer: self::Renderer> { -    content: &'a Element<'a, Message, Renderer>, -} - -impl<'a, Message, Renderer: self::Renderer> Overlay<'a, Message, Renderer> -where -    Message: 'a, -    Renderer: 'a, -{ -    pub fn new(content: &'a Element<'a, Message, Renderer>) -> Self { -        Self { content } -    } -} - -impl<'a, Message, Renderer> crate::Overlay<Message, Renderer> -    for Overlay<'a, Message, Renderer> -where -    Renderer: self::Renderer, -{ -    fn layout( -        &self, -        renderer: &Renderer, -        bounds: Size, -        position: Point, -    ) -> layout::Node { -        let space_below = bounds.height - position.y; -        let space_above = position.y; - -        let limits = layout::Limits::new( -            Size::ZERO, -            Size::new( -                bounds.width - position.x, -                if space_below > space_above { -                    space_below -                } else { -                    space_above -                }, -            ), -        ) -        .width(self.content.width()); - -        let mut node = self.content.layout(renderer, &limits); - -        node.move_to(position - Vector::new(0.0, node.size().height)); - -        node -    } - -    fn hash_layout(&self, state: &mut Hasher, position: Point) { -        struct Marker; -        std::any::TypeId::of::<Marker>().hash(state); - -        (position.x as u32).hash(state); -        (position.y as u32).hash(state); -        self.content.hash_layout(state); -    } - -    fn draw( -        &self, -        renderer: &mut Renderer, -        defaults: &Renderer::Defaults, -        layout: Layout<'_>, -        cursor_position: Point, -        viewport: &Rectangle, -    ) -> Renderer::Output { -        renderer.draw( -            defaults, -            cursor_position, -            &self.content, -            layout, -            viewport, -        ) -    }  }  /// The renderer of a [`Tooltip`]. @@ -269,7 +127,7 @@ where  ///  /// [`Tooltip`]: struct.Tooltip.html  /// [renderer]: ../../renderer/index.html -pub trait Renderer: crate::Renderer { +pub trait Renderer: crate::Renderer + text::Renderer {      /// The style supported by this renderer.      type Style: Default; @@ -280,16 +138,18 @@ pub trait Renderer: crate::Renderer {          &mut self,          defaults: &Self::Defaults,          cursor_position: Point, -        content: &Element<'_, Message, Self>,          content_layout: Layout<'_>,          viewport: &Rectangle, +        content: &Element<'_, Message, Self>, +        tooltip: &Text<Self>, +        position: Position,      ) -> Self::Output;  }  impl<'a, Message, Renderer> From<Tooltip<'a, Message, Renderer>>      for Element<'a, Message, Renderer>  where -    Renderer: 'a + self::Renderer, +    Renderer: 'a + self::Renderer + text::Renderer,      Message: 'a,  {      fn from( | 
