diff options
| author | 2020-03-13 07:51:41 +0100 | |
|---|---|---|
| committer | 2020-03-13 07:51:41 +0100 | |
| commit | 29bf51d25afdb07734700207dcc25b37357c04b1 (patch) | |
| tree | 0c7ba0ab89a0b6b2d72639a684f7eeb32e026567 /native/src/widget | |
| parent | c2ced4cd59fcc4cc46c2030897382bc443b9ccd8 (diff) | |
| download | iced-29bf51d25afdb07734700207dcc25b37357c04b1.tar.gz iced-29bf51d25afdb07734700207dcc25b37357c04b1.tar.bz2 iced-29bf51d25afdb07734700207dcc25b37357c04b1.zip | |
Implement `spacing` support for `PaneGrid`
Diffstat (limited to '')
| -rw-r--r-- | native/src/widget/pane_grid.rs | 43 | 
1 files changed, 32 insertions, 11 deletions
| diff --git a/native/src/widget/pane_grid.rs b/native/src/widget/pane_grid.rs index 7999998b..92ddc6e0 100644 --- a/native/src/widget/pane_grid.rs +++ b/native/src/widget/pane_grid.rs @@ -12,6 +12,7 @@ pub struct PaneGrid<'a, Message, Renderer> {      elements: Vec<(Pane, Element<'a, Message, Renderer>)>,      width: Length,      height: Length, +    spacing: u16,      on_drag: Option<Box<dyn Fn(DragEvent) -> Message>>,  } @@ -49,6 +50,7 @@ impl<'a, Message, Renderer> PaneGrid<'a, Message, Renderer> {              elements,              width: Length::Fill,              height: Length::Fill, +            spacing: 0,              on_drag: None,          }      } @@ -69,6 +71,14 @@ impl<'a, Message, Renderer> PaneGrid<'a, Message, Renderer> {          self      } +    /// Sets the spacing _between_ the panes of the [`PaneGrid`]. +    /// +    /// [`PaneGrid`]: struct.Column.html +    pub fn spacing(mut self, units: u16) -> Self { +        self.spacing = units; +        self +    } +      pub fn on_drag(          mut self,          f: impl Fn(DragEvent) -> Message + 'static, @@ -107,7 +117,7 @@ where          let limits = limits.width(self.width).height(self.height);          let size = limits.resolve(Size::ZERO); -        let regions = self.state.layout.regions(size); +        let regions = self.state.layout.regions(f32::from(self.spacing), size);          let children = self              .elements @@ -498,10 +508,15 @@ impl Node {          }      } -    pub fn regions(&self, size: Size) -> HashMap<Pane, Rectangle> { +    pub fn regions( +        &self, +        spacing: f32, +        size: Size, +    ) -> HashMap<Pane, Rectangle> {          let mut regions = HashMap::new();          self.compute_regions( +            spacing / 2.0,              &Rectangle {                  x: 0.0,                  y: 0.0, @@ -530,16 +545,18 @@ impl Node {      fn compute_regions(          &self, +        halved_spacing: f32,          current: &Rectangle,          regions: &mut HashMap<Pane, Rectangle>,      ) {          match self {              Node::Split { kind, ratio, a, b } => {                  let ratio = *ratio as f32 / 1_000_000.0; -                let (region_a, region_b) = kind.apply(current, ratio); +                let (region_a, region_b) = +                    kind.apply(current, ratio, halved_spacing); -                a.compute_regions(®ion_a, regions); -                b.compute_regions(®ion_b, regions); +                a.compute_regions(halved_spacing, ®ion_a, regions); +                b.compute_regions(halved_spacing, ®ion_b, regions);              }              Node::Pane(pane) => {                  let _ = regions.insert(*pane, *current); @@ -559,11 +576,13 @@ impl Split {          &self,          rectangle: &Rectangle,          ratio: f32, +        halved_spacing: f32,      ) -> (Rectangle, Rectangle) {          match self {              Split::Horizontal => { -                let width_left = (rectangle.width * ratio).round(); -                let width_right = rectangle.width - width_left; +                let width_left = +                    (rectangle.width * ratio).round() - halved_spacing; +                let width_right = rectangle.width - width_left - halved_spacing;                  (                      Rectangle { @@ -571,15 +590,17 @@ impl Split {                          ..*rectangle                      },                      Rectangle { -                        x: rectangle.x + width_left, +                        x: rectangle.x + width_left + halved_spacing,                          width: width_right,                          ..*rectangle                      },                  )              }              Split::Vertical => { -                let height_top = (rectangle.height * ratio).round(); -                let height_bottom = rectangle.height - height_top; +                let height_top = +                    (rectangle.height * ratio).round() - halved_spacing; +                let height_bottom = +                    rectangle.height - height_top - halved_spacing;                  (                      Rectangle { @@ -587,7 +608,7 @@ impl Split {                          ..*rectangle                      },                      Rectangle { -                        y: rectangle.y + height_top, +                        y: rectangle.y + height_top + halved_spacing,                          height: height_bottom,                          ..*rectangle                      }, | 
