summaryrefslogtreecommitdiffstats
path: root/native
diff options
context:
space:
mode:
Diffstat (limited to 'native')
-rw-r--r--native/src/widget/button.rs9
-rw-r--r--native/src/widget/container.rs10
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(