use geo_types::CoordFloat;
use super::{Contains, impl_contains_from_relate, impl_contains_geometry_for};
use crate::{Area, CoordsIter, HasDimensions, Intersects, geometry::*};
use crate::{CoordNum, GeoFloat};
impl<T> Contains<Coord<T>> for Rect<T>
where
T: CoordNum,
{
fn contains(&self, coord: &Coord<T>) -> bool {
coord.x > self.min().x
&& coord.x < self.max().x
&& coord.y > self.min().y
&& coord.y < self.max().y
}
}
impl<T> Contains<Point<T>> for Rect<T>
where
T: CoordNum,
{
fn contains(&self, p: &Point<T>) -> bool {
self.contains(&p.0)
}
}
impl<T> Contains<Rect<T>> for Rect<T>
where
T: CoordNum,
{
fn contains(&self, other: &Rect<T>) -> bool {
self.min().x <= other.min().x
&& self.max().x >= other.max().x
&& self.min().y <= other.min().y
&& self.max().y >= other.max().y
}
}
impl<T> Contains<Polygon<T>> for Rect<T>
where
T: CoordFloat,
{
fn contains(&self, rhs: &Polygon<T>) -> bool {
if rhs.is_empty() {
return false;
}
let mut points_inside = 0;
for c in rhs.exterior_coords_iter() {
if !self.intersects(&c) {
return false;
}
if self.contains(&c) {
points_inside += 1;
}
}
if points_inside == 0 && rhs.signed_area().is_zero() {
return false;
}
true
}
}
impl_contains_from_relate!(Rect<T>, [Line<T>, LineString<T>, MultiPoint<T>, MultiLineString<T>, MultiPolygon<T>, GeometryCollection<T>, Triangle<T>]);
impl_contains_geometry_for!(Rect<T>);