Merge pull request #1494 from tarkah/fix/padding
Constrain padding to resolved inner / outer widget sizes
This commit is contained in:
commit
ac737cb6e9
5 changed files with 60 additions and 14 deletions
|
|
@ -1,3 +1,5 @@
|
||||||
|
use crate::Size;
|
||||||
|
|
||||||
/// An amount of space to pad for each side of a box
|
/// An amount of space to pad for each side of a box
|
||||||
///
|
///
|
||||||
/// You can leverage the `From` trait to build [`Padding`] conveniently:
|
/// You can leverage the `From` trait to build [`Padding`] conveniently:
|
||||||
|
|
@ -71,9 +73,21 @@ impl Padding {
|
||||||
pub fn horizontal(self) -> u16 {
|
pub fn horizontal(self) -> u16 {
|
||||||
self.left + self.right
|
self.left + self.right
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Fits the [`Padding`] between the provided `inner` and `outer` [`Size`].
|
||||||
|
pub fn fit(self, inner: Size, outer: Size) -> Self {
|
||||||
|
let available = (outer - inner).max(Size::ZERO);
|
||||||
|
|
||||||
|
Padding {
|
||||||
|
top: self.top.min((available.height as u16) / 2),
|
||||||
|
right: self.right.min((available.width as u16) / 2),
|
||||||
|
bottom: self.bottom.min((available.height as u16) / 2),
|
||||||
|
left: self.left.min((available.width as u16) / 2),
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl std::convert::From<u16> for Padding {
|
impl From<u16> for Padding {
|
||||||
fn from(p: u16) -> Self {
|
fn from(p: u16) -> Self {
|
||||||
Padding {
|
Padding {
|
||||||
top: p,
|
top: p,
|
||||||
|
|
@ -84,7 +98,7 @@ impl std::convert::From<u16> for Padding {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl std::convert::From<[u16; 2]> for Padding {
|
impl From<[u16; 2]> for Padding {
|
||||||
fn from(p: [u16; 2]) -> Self {
|
fn from(p: [u16; 2]) -> Self {
|
||||||
Padding {
|
Padding {
|
||||||
top: p[0],
|
top: p[0],
|
||||||
|
|
@ -95,7 +109,7 @@ impl std::convert::From<[u16; 2]> for Padding {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl std::convert::From<[u16; 4]> for Padding {
|
impl From<[u16; 4]> for Padding {
|
||||||
fn from(p: [u16; 4]) -> Self {
|
fn from(p: [u16; 4]) -> Self {
|
||||||
Padding {
|
Padding {
|
||||||
top: p[0],
|
top: p[0],
|
||||||
|
|
|
||||||
|
|
@ -34,6 +34,22 @@ impl Size {
|
||||||
height: self.height + padding.vertical() as f32,
|
height: self.height + padding.vertical() as f32,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Returns the minimum of each component of this size and another
|
||||||
|
pub fn min(self, other: Self) -> Self {
|
||||||
|
Size {
|
||||||
|
width: self.width.min(other.width),
|
||||||
|
height: self.height.min(other.height),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Returns the maximum of each component of this size and another
|
||||||
|
pub fn max(self, other: Self) -> Self {
|
||||||
|
Size {
|
||||||
|
width: self.width.max(other.width),
|
||||||
|
height: self.height.max(other.height),
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl From<[f32; 2]> for Size {
|
impl From<[f32; 2]> for Size {
|
||||||
|
|
@ -68,3 +84,14 @@ impl From<Size> for Vector<f32> {
|
||||||
Vector::new(size.width, size.height)
|
Vector::new(size.width, size.height)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl std::ops::Sub for Size {
|
||||||
|
type Output = Size;
|
||||||
|
|
||||||
|
fn sub(self, rhs: Self) -> Self::Output {
|
||||||
|
Size {
|
||||||
|
width: self.width - rhs.width,
|
||||||
|
height: self.height - rhs.height,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
||||||
|
|
@ -426,13 +426,14 @@ pub fn layout<Renderer>(
|
||||||
padding: Padding,
|
padding: Padding,
|
||||||
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).pad(padding);
|
let limits = limits.width(width).height(height);
|
||||||
|
|
||||||
|
let mut content = layout_content(renderer, &limits.pad(padding));
|
||||||
|
let padding = padding.fit(content.size(), limits.max());
|
||||||
|
let size = limits.pad(padding).resolve(content.size()).pad(padding);
|
||||||
|
|
||||||
let mut content = layout_content(renderer, &limits);
|
|
||||||
content.move_to(Point::new(padding.left.into(), padding.top.into()));
|
content.move_to(Point::new(padding.left.into(), padding.top.into()));
|
||||||
|
|
||||||
let size = limits.resolve(content.size()).pad(padding);
|
|
||||||
|
|
||||||
layout::Node::with_children(size, vec![content])
|
layout::Node::with_children(size, vec![content])
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -293,11 +293,11 @@ pub fn layout<Renderer>(
|
||||||
.max_width(max_width)
|
.max_width(max_width)
|
||||||
.max_height(max_height)
|
.max_height(max_height)
|
||||||
.width(width)
|
.width(width)
|
||||||
.height(height)
|
.height(height);
|
||||||
.pad(padding);
|
|
||||||
|
|
||||||
let mut content = layout_content(renderer, &limits.loose());
|
let mut content = layout_content(renderer, &limits.pad(padding).loose());
|
||||||
let size = limits.resolve(content.size());
|
let padding = padding.fit(content.size(), limits.max());
|
||||||
|
let size = limits.pad(padding).resolve(content.size());
|
||||||
|
|
||||||
content.move_to(Point::new(padding.left.into(), padding.top.into()));
|
content.move_to(Point::new(padding.left.into(), padding.top.into()));
|
||||||
content.align(
|
content.align(
|
||||||
|
|
|
||||||
|
|
@ -350,15 +350,19 @@ where
|
||||||
{
|
{
|
||||||
let text_size = size.unwrap_or_else(|| renderer.default_size());
|
let text_size = size.unwrap_or_else(|| renderer.default_size());
|
||||||
|
|
||||||
let limits = limits
|
let text_limits = limits
|
||||||
.pad(padding)
|
.pad(padding)
|
||||||
.width(width)
|
.width(width)
|
||||||
.height(Length::Units(text_size));
|
.height(Length::Units(text_size));
|
||||||
|
let limits = limits.width(width).height(Length::Shrink);
|
||||||
|
|
||||||
|
let mut text = layout::Node::new(text_limits.resolve(Size::ZERO));
|
||||||
|
let padding = padding.fit(text.size(), limits.max());
|
||||||
|
let size = limits.pad(padding).resolve(text.size()).pad(padding);
|
||||||
|
|
||||||
let mut text = layout::Node::new(limits.resolve(Size::ZERO));
|
|
||||||
text.move_to(Point::new(padding.left.into(), padding.top.into()));
|
text.move_to(Point::new(padding.left.into(), padding.top.into()));
|
||||||
|
|
||||||
layout::Node::with_children(text.size().pad(padding), vec![text])
|
layout::Node::with_children(size, vec![text])
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Processes an [`Event`] and updates the [`State`] of a [`TextInput`]
|
/// Processes an [`Event`] and updates the [`State`] of a [`TextInput`]
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue