diff options
| author | 2022-11-08 04:39:55 +0100 | |
|---|---|---|
| committer | 2022-11-08 04:39:55 +0100 | |
| commit | ac737cb6e905f7a8a85e9f26a27deb7907e80114 (patch) | |
| tree | 161f47b500ace9668c06d01889604bbc60c55727 /core/src | |
| parent | acb520a4a8001ed9db885d128ddd1f0ccbd71db2 (diff) | |
| parent | 04087b2a867520cfc43a648fa9e93cee2a6daf3c (diff) | |
| download | iced-ac737cb6e905f7a8a85e9f26a27deb7907e80114.tar.gz iced-ac737cb6e905f7a8a85e9f26a27deb7907e80114.tar.bz2 iced-ac737cb6e905f7a8a85e9f26a27deb7907e80114.zip | |
Merge pull request #1494 from tarkah/fix/padding
Constrain padding to resolved inner / outer widget sizes
Diffstat (limited to 'core/src')
| -rw-r--r-- | core/src/padding.rs | 20 | ||||
| -rw-r--r-- | core/src/size.rs | 27 | 
2 files changed, 44 insertions, 3 deletions
| diff --git a/core/src/padding.rs b/core/src/padding.rs index 22467d6b..140ad8ee 100644 --- a/core/src/padding.rs +++ b/core/src/padding.rs @@ -1,3 +1,5 @@ +use crate::Size; +  /// An amount of space to pad for each side of a box  ///  /// You can leverage the `From` trait to build [`Padding`] conveniently: @@ -71,9 +73,21 @@ impl Padding {      pub fn horizontal(self) -> u16 {          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 {          Padding {              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 {          Padding {              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 {          Padding {              top: p[0], diff --git a/core/src/size.rs b/core/src/size.rs index 2db33a88..31f3171b 100644 --- a/core/src/size.rs +++ b/core/src/size.rs @@ -34,6 +34,22 @@ impl Size {              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 { @@ -68,3 +84,14 @@ impl From<Size> for Vector<f32> {          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, +        } +    } +} | 
