diff options
| author | 2020-02-23 09:20:21 +0100 | |
|---|---|---|
| committer | 2020-02-23 09:20:21 +0100 | |
| commit | e680fd27e754aead4003cae72f401090662851b2 (patch) | |
| tree | 8f36aaf39111606573369a3629b1661d8a198144 /core/src | |
| parent | d6c2b1121c9592826e1cc25eeecbf3fa8d982ee8 (diff) | |
| parent | 126133ead775fda064a6c23503e9a552a10dc2c5 (diff) | |
| download | iced-e680fd27e754aead4003cae72f401090662851b2.tar.gz iced-e680fd27e754aead4003cae72f401090662851b2.tar.bz2 iced-e680fd27e754aead4003cae72f401090662851b2.zip | |
Merge pull request #201 from hecrj/fix/clip-primitive-intersection
Fix `Clip` primitive intersection in `iced_wgpu`
Diffstat (limited to 'core/src')
| -rw-r--r-- | core/src/rectangle.rs | 50 | 
1 files changed, 50 insertions, 0 deletions
| diff --git a/core/src/rectangle.rs b/core/src/rectangle.rs index ee1e3807..7ed3d2df 100644 --- a/core/src/rectangle.rs +++ b/core/src/rectangle.rs @@ -27,6 +27,34 @@ impl Rectangle<f32> {              && self.y <= point.y              && point.y <= self.y + self.height      } + +    /// Computes the intersection with the given [`Rectangle`]. +    /// +    /// [`Rectangle`]: struct.Rectangle.html +    pub fn intersection( +        &self, +        other: &Rectangle<f32>, +    ) -> Option<Rectangle<f32>> { +        let x = self.x.max(other.x); +        let y = self.y.max(other.y); + +        let lower_right_x = (self.x + self.width).min(other.x + other.width); +        let lower_right_y = (self.y + self.height).min(other.y + other.height); + +        let width = lower_right_x - x; +        let height = lower_right_y - y; + +        if width > 0.0 && height > 0.0 { +            Some(Rectangle { +                x, +                y, +                width, +                height, +            }) +        } else { +            None +        } +    }  }  impl std::ops::Mul<f32> for Rectangle<u32> { @@ -41,3 +69,25 @@ impl std::ops::Mul<f32> for Rectangle<u32> {          }      }  } + +impl From<Rectangle<u32>> for Rectangle<f32> { +    fn from(rectangle: Rectangle<u32>) -> Rectangle<f32> { +        Rectangle { +            x: rectangle.x as f32, +            y: rectangle.y as f32, +            width: rectangle.width as f32, +            height: rectangle.height as f32, +        } +    } +} + +impl From<Rectangle<f32>> for Rectangle<u32> { +    fn from(rectangle: Rectangle<f32>) -> Rectangle<u32> { +        Rectangle { +            x: rectangle.x as u32, +            y: rectangle.y as u32, +            width: rectangle.width.ceil() as u32, +            height: rectangle.height.ceil() as u32, +        } +    } +} | 
