diff options
| author | 2024-01-16 12:02:42 +0100 | |
|---|---|---|
| committer | 2024-01-16 12:02:42 +0100 | |
| commit | 534c7dd7b0bc515c31b6de87b4aa6a35b44c46a0 (patch) | |
| tree | 0ddc8f1b681cbade7e47293bd46a362896aa538a /widget/src/keyed | |
| parent | 17135cbd56316f31167eb62e026839450506573f (diff) | |
| parent | c4ba657de86d7606587dad5124f435141258f570 (diff) | |
| download | iced-534c7dd7b0bc515c31b6de87b4aa6a35b44c46a0.tar.gz iced-534c7dd7b0bc515c31b6de87b4aa6a35b44c46a0.tar.bz2 iced-534c7dd7b0bc515c31b6de87b4aa6a35b44c46a0.zip | |
Merge branch 'master' into update-winit
Diffstat (limited to '')
| -rw-r--r-- | widget/src/keyed/column.rs | 60 | 
1 files changed, 33 insertions, 27 deletions
| diff --git a/widget/src/keyed/column.rs b/widget/src/keyed/column.rs index 0ef82407..7f05a81e 100644 --- a/widget/src/keyed/column.rs +++ b/widget/src/keyed/column.rs @@ -8,7 +8,7 @@ use crate::core::widget::tree::{self, Tree};  use crate::core::widget::Operation;  use crate::core::{      Alignment, Clipboard, Element, Layout, Length, Padding, Pixels, Rectangle, -    Shell, Widget, +    Shell, Size, Widget,  };  /// A container that distributes its contents vertically. @@ -30,26 +30,10 @@ where  impl<'a, Key, Message, Renderer> Column<'a, Key, Message, Renderer>  where      Key: Copy + PartialEq, +    Renderer: crate::core::Renderer,  {      /// Creates an empty [`Column`].      pub fn new() -> Self { -        Self::with_children(Vec::new()) -    } - -    /// Creates a [`Column`] with the given elements. -    pub fn with_children( -        children: impl IntoIterator<Item = (Key, Element<'a, Message, Renderer>)>, -    ) -> Self { -        let (keys, children) = children.into_iter().fold( -            (Vec::new(), Vec::new()), -            |(mut keys, mut children), (key, child)| { -                keys.push(key); -                children.push(child); - -                (keys, children) -            }, -        ); -          Column {              spacing: 0.0,              padding: Padding::ZERO, @@ -57,11 +41,20 @@ where              height: Length::Shrink,              max_width: f32::INFINITY,              align_items: Alignment::Start, -            keys, -            children, +            keys: Vec::new(), +            children: Vec::new(),          }      } +    /// Creates a [`Column`] with the given elements. +    pub fn with_children( +        children: impl IntoIterator<Item = (Key, Element<'a, Message, Renderer>)>, +    ) -> Self { +        children +            .into_iter() +            .fold(Self::new(), |column, (key, child)| column.push(key, child)) +    } +      /// Sets the vertical spacing _between_ elements.      ///      /// Custom margins per element do not exist in iced. You should use this @@ -108,8 +101,19 @@ where          key: Key,          child: impl Into<Element<'a, Message, Renderer>>,      ) -> Self { +        let child = child.into(); +        let size = child.as_widget().size_hint(); + +        if size.width.is_fill() { +            self.width = Length::Fill; +        } + +        if size.height.is_fill() { +            self.height = Length::Fill; +        } +          self.keys.push(key); -        self.children.push(child.into()); +        self.children.push(child);          self      }  } @@ -117,6 +121,7 @@ where  impl<'a, Key, Message, Renderer> Default for Column<'a, Key, Message, Renderer>  where      Key: Copy + PartialEq, +    Renderer: crate::core::Renderer,  {      fn default() -> Self {          Self::new() @@ -173,12 +178,11 @@ where          }      } -    fn width(&self) -> Length { -        self.width -    } - -    fn height(&self) -> Length { -        self.height +    fn size(&self) -> Size<Length> { +        Size { +            width: self.width, +            height: self.height, +        }      }      fn layout( @@ -196,6 +200,8 @@ where              layout::flex::Axis::Vertical,              renderer,              &limits, +            self.width, +            self.height,              self.padding,              self.spacing,              self.align_items, | 
