Merge pull request #1390 from iced-rs/fix/container-layout
Fix `max_width` and `max_height` for `Container`
This commit is contained in:
commit
785385d889
4 changed files with 17 additions and 2 deletions
|
|
@ -127,12 +127,20 @@ pub fn layout<Renderer>(
|
||||||
limits: &layout::Limits,
|
limits: &layout::Limits,
|
||||||
width: Length,
|
width: Length,
|
||||||
height: Length,
|
height: Length,
|
||||||
|
max_width: u32,
|
||||||
|
max_height: u32,
|
||||||
padding: Padding,
|
padding: Padding,
|
||||||
horizontal_alignment: alignment::Horizontal,
|
horizontal_alignment: alignment::Horizontal,
|
||||||
vertical_alignment: alignment::Vertical,
|
vertical_alignment: alignment::Vertical,
|
||||||
layout_content: impl FnOnce(&Renderer, &layout::Limits) -> layout::Node,
|
layout_content: impl FnOnce(&Renderer, &layout::Limits) -> layout::Node,
|
||||||
) -> layout::Node {
|
) -> layout::Node {
|
||||||
let limits = limits.loose().width(width).height(height).pad(padding);
|
let limits = limits
|
||||||
|
.loose()
|
||||||
|
.max_width(max_width)
|
||||||
|
.max_height(max_height)
|
||||||
|
.width(width)
|
||||||
|
.height(height)
|
||||||
|
.pad(padding);
|
||||||
|
|
||||||
let mut content = layout_content(renderer, &limits.loose());
|
let mut content = layout_content(renderer, &limits.loose());
|
||||||
let size = limits.resolve(content.size());
|
let size = limits.resolve(content.size());
|
||||||
|
|
@ -171,6 +179,8 @@ where
|
||||||
limits,
|
limits,
|
||||||
self.width,
|
self.width,
|
||||||
self.height,
|
self.height,
|
||||||
|
self.max_width,
|
||||||
|
self.max_height,
|
||||||
self.padding,
|
self.padding,
|
||||||
self.horizontal_alignment,
|
self.horizontal_alignment,
|
||||||
self.vertical_alignment,
|
self.vertical_alignment,
|
||||||
|
|
|
||||||
|
|
@ -162,9 +162,10 @@ pub fn layout<Renderer>(
|
||||||
limits: &layout::Limits,
|
limits: &layout::Limits,
|
||||||
width: Length,
|
width: Length,
|
||||||
height: Length,
|
height: Length,
|
||||||
|
max_height: u32,
|
||||||
layout_content: impl FnOnce(&Renderer, &layout::Limits) -> layout::Node,
|
layout_content: impl FnOnce(&Renderer, &layout::Limits) -> layout::Node,
|
||||||
) -> layout::Node {
|
) -> layout::Node {
|
||||||
let limits = limits.width(width).height(height);
|
let limits = limits.max_height(max_height).width(width).height(height);
|
||||||
|
|
||||||
let child_limits = layout::Limits::new(
|
let child_limits = layout::Limits::new(
|
||||||
Size::new(limits.min().width, 0.0),
|
Size::new(limits.min().width, 0.0),
|
||||||
|
|
@ -648,6 +649,7 @@ where
|
||||||
limits,
|
limits,
|
||||||
Widget::<Message, Renderer>::width(self),
|
Widget::<Message, Renderer>::width(self),
|
||||||
self.height,
|
self.height,
|
||||||
|
self.max_height,
|
||||||
|renderer, limits| self.content.layout(renderer, limits),
|
|renderer, limits| self.content.layout(renderer, limits),
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -156,6 +156,8 @@ where
|
||||||
limits,
|
limits,
|
||||||
self.width,
|
self.width,
|
||||||
self.height,
|
self.height,
|
||||||
|
self.max_width,
|
||||||
|
self.max_height,
|
||||||
self.padding,
|
self.padding,
|
||||||
self.horizontal_alignment,
|
self.horizontal_alignment,
|
||||||
self.vertical_alignment,
|
self.vertical_alignment,
|
||||||
|
|
|
||||||
|
|
@ -133,6 +133,7 @@ where
|
||||||
limits,
|
limits,
|
||||||
Widget::<Message, Renderer>::width(self),
|
Widget::<Message, Renderer>::width(self),
|
||||||
self.height,
|
self.height,
|
||||||
|
u32::MAX,
|
||||||
|renderer, limits| {
|
|renderer, limits| {
|
||||||
self.content.as_widget().layout(renderer, limits)
|
self.content.as_widget().layout(renderer, limits)
|
||||||
},
|
},
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue