diff options
Diffstat (limited to '')
| -rw-r--r-- | native/src/widget/button.rs | 9 | ||||
| -rw-r--r-- | native/src/widget/container.rs | 10 | 
2 files changed, 12 insertions, 7 deletions
diff --git a/native/src/widget/button.rs b/native/src/widget/button.rs index 6c0b8f6e..e927998c 100644 --- a/native/src/widget/button.rs +++ b/native/src/widget/button.rs @@ -426,12 +426,15 @@ pub fn layout<Renderer>(      padding: Padding,      layout_content: impl FnOnce(&Renderer, &layout::Limits) -> layout::Node,  ) -> layout::Node { -    let limits = limits.width(width).height(height).pad(padding); +    let limits = limits.width(width).height(height); + +    let mut content = layout_content(renderer, &limits.pad(padding)); + +    let padding = padding.constrain(content.size(), limits.max()); -    let mut content = layout_content(renderer, &limits);      content.move_to(Point::new(padding.left.into(), padding.top.into())); -    let size = limits.resolve(content.size()).pad(padding); +    let size = limits.pad(padding).resolve(content.size()).pad(padding);      layout::Node::with_children(size, vec![content])  } diff --git a/native/src/widget/container.rs b/native/src/widget/container.rs index 2afad3f2..cc886dcb 100644 --- a/native/src/widget/container.rs +++ b/native/src/widget/container.rs @@ -293,11 +293,13 @@ pub fn layout<Renderer>(          .max_width(max_width)          .max_height(max_height)          .width(width) -        .height(height) -        .pad(padding); +        .height(height); -    let mut content = layout_content(renderer, &limits.loose()); -    let size = limits.resolve(content.size()); +    let mut content = layout_content(renderer, &limits.pad(padding).loose()); + +    let padding = padding.constrain(content.size(), limits.max()); + +    let size = limits.pad(padding).resolve(content.size());      content.move_to(Point::new(padding.left.into(), padding.top.into()));      content.align(  | 
