Struct geo::geometry::MultiPolygon
source · pub struct MultiPolygon<T = f64>(pub Vec<Polygon<T>>)
where
T: CoordNum;
Expand description
A collection of Polygon
s. Can
be created from a Vec
of Polygon
s, or from an
Iterator which yields Polygon
s. Iterating over this
object yields the component Polygon
s.
§Semantics
The interior and the boundary are the union of the interior and the boundary of the constituent polygons.
§Validity
-
The interiors of no two constituent polygons may intersect.
-
The boundaries of two (distinct) constituent polygons may only intersect at finitely many points.
Refer to section 6.1.14 of the OGC-SFA for a formal definition of validity. Note that the validity is not enforced, but expected by the operations and predicates that operate on it.
Tuple Fields§
§0: Vec<Polygon<T>>
Implementations§
Trait Implementations§
source§impl<T> AbsDiffEq for MultiPolygon<T>
impl<T> AbsDiffEq for MultiPolygon<T>
source§fn abs_diff_eq(
&self,
other: &MultiPolygon<T>,
epsilon: <MultiPolygon<T> as AbsDiffEq>::Epsilon
) -> bool
fn abs_diff_eq( &self, other: &MultiPolygon<T>, epsilon: <MultiPolygon<T> as AbsDiffEq>::Epsilon ) -> bool
Equality assertion with an absolute limit.
§Examples
use geo_types::{polygon, Polygon, MultiPolygon};
let a_el: Polygon<f32> = polygon![(x: 0., y: 0.), (x: 5., y: 0.), (x: 7., y: 9.), (x: 0., y: 0.)];
let a = MultiPolygon::new(vec![a_el]);
let b_el: Polygon<f32> = polygon![(x: 0., y: 0.), (x: 5., y: 0.), (x: 7.01, y: 9.), (x: 0., y: 0.)];
let b = MultiPolygon::new(vec![b_el]);
approx::abs_diff_eq!(a, b, epsilon=0.1);
approx::abs_diff_ne!(a, b, epsilon=0.001);
source§fn default_epsilon() -> <MultiPolygon<T> as AbsDiffEq>::Epsilon
fn default_epsilon() -> <MultiPolygon<T> as AbsDiffEq>::Epsilon
§fn abs_diff_ne(&self, other: &Rhs, epsilon: Self::Epsilon) -> bool
fn abs_diff_ne(&self, other: &Rhs, epsilon: Self::Epsilon) -> bool
AbsDiffEq::abs_diff_eq
].source§impl<T> Area<T> for MultiPolygon<T>where
T: CoordFloat,
impl<T> Area<T> for MultiPolygon<T>where
T: CoordFloat,
Note. The implementation is a straight-forward
summation of the signed areas of the individual
polygons. In particular, unsigned_area
is not
necessarily the sum of the unsigned_area
of the
constituent polygons unless they are all oriented the
same.
fn signed_area(&self) -> T
fn unsigned_area(&self) -> T
source§impl<T: GeoFloat> BooleanOps for MultiPolygon<T>
impl<T: GeoFloat> BooleanOps for MultiPolygon<T>
type Scalar = T
fn boolean_op(&self, other: &Self, op: OpType) -> MultiPolygon<Self::Scalar>
source§fn clip(
&self,
ls: &MultiLineString<Self::Scalar>,
invert: bool
) -> MultiLineString<Self::Scalar>
fn clip( &self, ls: &MultiLineString<Self::Scalar>, invert: bool ) -> MultiLineString<Self::Scalar>
fn intersection(&self, other: &Self) -> MultiPolygon<Self::Scalar>
fn union(&self, other: &Self) -> MultiPolygon<Self::Scalar>
fn xor(&self, other: &Self) -> MultiPolygon<Self::Scalar>
fn difference(&self, other: &Self) -> MultiPolygon<Self::Scalar>
source§impl<T> BoundingRect<T> for MultiPolygon<T>where
T: CoordNum,
impl<T> BoundingRect<T> for MultiPolygon<T>where
T: CoordNum,
source§impl<T> Centroid for MultiPolygon<T>where
T: GeoFloat,
impl<T> Centroid for MultiPolygon<T>where
T: GeoFloat,
source§fn centroid(&self) -> Self::Output
fn centroid(&self) -> Self::Output
The Centroid of a MultiPolygon
is the mean of the centroids of its polygons, weighted
by the area of the polygons
§Examples
use geo::Centroid;
use geo::{MultiPolygon, polygon, point};
let multi_polygon = MultiPolygon::new(vec![
// centroid (1.0, 0.5)
polygon![
(x: 0.0f32, y: 0.0),
(x: 2.0, y: 0.0),
(x: 2.0, y: 1.0),
(x: 0.0, y: 1.0),
],
// centroid (-0.5, 0.0)
polygon![
(x: 1.0, y: 1.0),
(x: -2.0, y: 1.0),
(x: -2.0, y: -1.0),
(x: 1.0, y: -1.0),
]
]);
assert_eq!(
// ( 2.0 * (1.0, 0.5) + 6.0 * (-0.5, 0.0) ) / 8.0
Some(point!(x: -0.125, y: 0.125)),
multi_polygon.centroid(),
);
type Output = Option<Point<T>>
source§impl<T> ChaikinSmoothing<T> for MultiPolygon<T>where
T: CoordFloat + FromPrimitive,
impl<T> ChaikinSmoothing<T> for MultiPolygon<T>where
T: CoordFloat + FromPrimitive,
source§fn chaikin_smoothing(&self, n_iterations: usize) -> Self
fn chaikin_smoothing(&self, n_iterations: usize) -> Self
n_iterations
times.source§impl<T> ChamberlainDuquetteArea<T> for MultiPolygon<T>where
T: CoordFloat,
impl<T> ChamberlainDuquetteArea<T> for MultiPolygon<T>where
T: CoordFloat,
fn chamberlain_duquette_signed_area(&self) -> T
fn chamberlain_duquette_unsigned_area(&self) -> T
source§impl<T> Clone for MultiPolygon<T>
impl<T> Clone for MultiPolygon<T>
source§fn clone(&self) -> MultiPolygon<T>
fn clone(&self) -> MultiPolygon<T>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl<F: GeoFloat> ClosestPoint<F> for MultiPolygon<F>
impl<F: GeoFloat> ClosestPoint<F> for MultiPolygon<F>
source§fn closest_point(&self, p: &Point<F>) -> Closest<F>
fn closest_point(&self, p: &Point<F>) -> Closest<F>
self
and p
.source§impl<T> ConcaveHull for MultiPolygon<T>
impl<T> ConcaveHull for MultiPolygon<T>
source§impl<F> Contains<GeometryCollection<F>> for MultiPolygon<F>where
F: GeoFloat,
impl<F> Contains<GeometryCollection<F>> for MultiPolygon<F>where
F: GeoFloat,
fn contains(&self, rhs: &GeometryCollection<F>) -> bool
source§impl<F> Contains<LineString<F>> for MultiPolygon<F>where
F: GeoFloat,
impl<F> Contains<LineString<F>> for MultiPolygon<F>where
F: GeoFloat,
fn contains(&self, rhs: &LineString<F>) -> bool
source§impl<F> Contains<MultiLineString<F>> for MultiPolygon<F>where
F: GeoFloat,
impl<F> Contains<MultiLineString<F>> for MultiPolygon<F>where
F: GeoFloat,
fn contains(&self, rhs: &MultiLineString<F>) -> bool
source§impl<T: GeoNum> Contains<MultiPoint<T>> for MultiPolygon<T>
impl<T: GeoNum> Contains<MultiPoint<T>> for MultiPolygon<T>
fn contains(&self, rhs: &MultiPoint<T>) -> bool
source§impl<T> Contains<MultiPolygon<T>> for Geometry<T>where
T: GeoFloat,
impl<T> Contains<MultiPolygon<T>> for Geometry<T>where
T: GeoFloat,
fn contains(&self, multi_line_string: &MultiPolygon<T>) -> bool
source§impl<T> Contains<MultiPolygon<T>> for GeometryCollection<T>where
T: GeoFloat,
impl<T> Contains<MultiPolygon<T>> for GeometryCollection<T>where
T: GeoFloat,
fn contains(&self, target: &MultiPolygon<T>) -> bool
source§impl<T> Contains<MultiPolygon<T>> for Line<T>where
T: GeoFloat,
impl<T> Contains<MultiPolygon<T>> for Line<T>where
T: GeoFloat,
fn contains(&self, target: &MultiPolygon<T>) -> bool
source§impl<T> Contains<MultiPolygon<T>> for LineString<T>where
T: GeoFloat,
impl<T> Contains<MultiPolygon<T>> for LineString<T>where
T: GeoFloat,
fn contains(&self, target: &MultiPolygon<T>) -> bool
source§impl<T> Contains<MultiPolygon<T>> for MultiLineString<T>where
T: GeoFloat,
impl<T> Contains<MultiPolygon<T>> for MultiLineString<T>where
T: GeoFloat,
fn contains(&self, target: &MultiPolygon<T>) -> bool
source§impl<T> Contains<MultiPolygon<T>> for MultiPoint<T>where
T: GeoFloat,
impl<T> Contains<MultiPolygon<T>> for MultiPoint<T>where
T: GeoFloat,
fn contains(&self, target: &MultiPolygon<T>) -> bool
source§impl<T> Contains<MultiPolygon<T>> for Point<T>where
T: CoordNum,
impl<T> Contains<MultiPolygon<T>> for Point<T>where
T: CoordNum,
fn contains(&self, multi_polygon: &MultiPolygon<T>) -> bool
source§impl<T> Contains<MultiPolygon<T>> for Polygon<T>where
T: GeoFloat,
impl<T> Contains<MultiPolygon<T>> for Polygon<T>where
T: GeoFloat,
fn contains(&self, target: &MultiPolygon<T>) -> bool
source§impl<T> Contains<MultiPolygon<T>> for Rect<T>where
T: GeoFloat,
impl<T> Contains<MultiPolygon<T>> for Rect<T>where
T: GeoFloat,
fn contains(&self, target: &MultiPolygon<T>) -> bool
source§impl<T> Contains<MultiPolygon<T>> for Triangle<T>where
T: GeoFloat,
impl<T> Contains<MultiPolygon<T>> for Triangle<T>where
T: GeoFloat,
fn contains(&self, target: &MultiPolygon<T>) -> bool
source§impl<F> Contains for MultiPolygon<F>where
F: GeoFloat,
impl<F> Contains for MultiPolygon<F>where
F: GeoFloat,
fn contains(&self, rhs: &MultiPolygon<F>) -> bool
source§impl<T> CoordinatePosition for MultiPolygon<T>where
T: GeoNum,
impl<T> CoordinatePosition for MultiPolygon<T>where
T: GeoNum,
source§impl<T: CoordNum> CoordsIter for MultiPolygon<T>
impl<T: CoordNum> CoordsIter for MultiPolygon<T>
source§fn coords_count(&self) -> usize
fn coords_count(&self) -> usize
Return the number of coordinates in the MultiPolygon
.
type Iter<'a> = Flatten<MapCoordsIter<'a, T, Iter<'a, Polygon<T>>, Polygon<T>>> where T: 'a
type ExteriorIter<'a> = Flatten<MapExteriorCoordsIter<'a, T, Iter<'a, Polygon<T>>, Polygon<T>>> where T: 'a
type Scalar = T
source§fn coords_iter(&self) -> Self::Iter<'_>
fn coords_iter(&self) -> Self::Iter<'_>
source§fn exterior_coords_iter(&self) -> Self::ExteriorIter<'_>
fn exterior_coords_iter(&self) -> Self::ExteriorIter<'_>
source§impl<T> Debug for MultiPolygon<T>
impl<T> Debug for MultiPolygon<T>
source§impl<T> Densify<T> for MultiPolygon<T>
impl<T> Densify<T> for MultiPolygon<T>
source§impl<T> DensifyHaversine<T> for MultiPolygon<T>where
T: CoordFloat + FromPrimitive,
Line<T>: HaversineLength<T>,
LineString<T>: HaversineLength<T>,
impl<T> DensifyHaversine<T> for MultiPolygon<T>where
T: CoordFloat + FromPrimitive,
Line<T>: HaversineLength<T>,
LineString<T>: HaversineLength<T>,
type Output = MultiPolygon<T>
fn densify_haversine(&self, max_distance: T) -> Self::Output
source§impl<T> EuclideanDistance<T> for MultiPolygon<T>
impl<T> EuclideanDistance<T> for MultiPolygon<T>
source§fn euclidean_distance(&self, target: &MultiPolygon<T>) -> T
fn euclidean_distance(&self, target: &MultiPolygon<T>) -> T
source§impl<T> EuclideanDistance<T, Geometry<T>> for MultiPolygon<T>
impl<T> EuclideanDistance<T, Geometry<T>> for MultiPolygon<T>
source§fn euclidean_distance(&self, geom: &Geometry<T>) -> T
fn euclidean_distance(&self, geom: &Geometry<T>) -> T
source§impl<T> EuclideanDistance<T, GeometryCollection<T>> for MultiPolygon<T>
impl<T> EuclideanDistance<T, GeometryCollection<T>> for MultiPolygon<T>
source§fn euclidean_distance(&self, target: &GeometryCollection<T>) -> T
fn euclidean_distance(&self, target: &GeometryCollection<T>) -> T
source§impl<T> EuclideanDistance<T, Line<T>> for MultiPolygon<T>
impl<T> EuclideanDistance<T, Line<T>> for MultiPolygon<T>
source§fn euclidean_distance(&self, target: &Line<T>) -> T
fn euclidean_distance(&self, target: &Line<T>) -> T
source§impl<T> EuclideanDistance<T, LineString<T>> for MultiPolygon<T>
impl<T> EuclideanDistance<T, LineString<T>> for MultiPolygon<T>
source§fn euclidean_distance(&self, target: &LineString<T>) -> T
fn euclidean_distance(&self, target: &LineString<T>) -> T
source§impl<T> EuclideanDistance<T, MultiLineString<T>> for MultiPolygon<T>
impl<T> EuclideanDistance<T, MultiLineString<T>> for MultiPolygon<T>
source§fn euclidean_distance(&self, target: &MultiLineString<T>) -> T
fn euclidean_distance(&self, target: &MultiLineString<T>) -> T
source§impl<T> EuclideanDistance<T, MultiPoint<T>> for MultiPolygon<T>
impl<T> EuclideanDistance<T, MultiPoint<T>> for MultiPolygon<T>
source§fn euclidean_distance(&self, target: &MultiPoint<T>) -> T
fn euclidean_distance(&self, target: &MultiPoint<T>) -> T
source§impl<T> EuclideanDistance<T, MultiPolygon<T>> for Geometry<T>
impl<T> EuclideanDistance<T, MultiPolygon<T>> for Geometry<T>
source§fn euclidean_distance(&self, other: &MultiPolygon<T>) -> T
fn euclidean_distance(&self, other: &MultiPolygon<T>) -> T
source§impl<T> EuclideanDistance<T, MultiPolygon<T>> for GeometryCollection<T>
impl<T> EuclideanDistance<T, MultiPolygon<T>> for GeometryCollection<T>
source§fn euclidean_distance(&self, target: &MultiPolygon<T>) -> T
fn euclidean_distance(&self, target: &MultiPolygon<T>) -> T
source§impl<T> EuclideanDistance<T, MultiPolygon<T>> for Line<T>
impl<T> EuclideanDistance<T, MultiPolygon<T>> for Line<T>
source§fn euclidean_distance(&self, target: &MultiPolygon<T>) -> T
fn euclidean_distance(&self, target: &MultiPolygon<T>) -> T
source§impl<T> EuclideanDistance<T, MultiPolygon<T>> for LineString<T>
impl<T> EuclideanDistance<T, MultiPolygon<T>> for LineString<T>
source§fn euclidean_distance(&self, target: &MultiPolygon<T>) -> T
fn euclidean_distance(&self, target: &MultiPolygon<T>) -> T
source§impl<T> EuclideanDistance<T, MultiPolygon<T>> for MultiLineString<T>
impl<T> EuclideanDistance<T, MultiPolygon<T>> for MultiLineString<T>
source§fn euclidean_distance(&self, target: &MultiPolygon<T>) -> T
fn euclidean_distance(&self, target: &MultiPolygon<T>) -> T
source§impl<T> EuclideanDistance<T, MultiPolygon<T>> for MultiPoint<T>
impl<T> EuclideanDistance<T, MultiPolygon<T>> for MultiPoint<T>
source§fn euclidean_distance(&self, target: &MultiPolygon<T>) -> T
fn euclidean_distance(&self, target: &MultiPolygon<T>) -> T
source§impl<T> EuclideanDistance<T, MultiPolygon<T>> for Point<T>
impl<T> EuclideanDistance<T, MultiPolygon<T>> for Point<T>
source§fn euclidean_distance(&self, target: &MultiPolygon<T>) -> T
fn euclidean_distance(&self, target: &MultiPolygon<T>) -> T
source§impl<T> EuclideanDistance<T, MultiPolygon<T>> for Polygon<T>
impl<T> EuclideanDistance<T, MultiPolygon<T>> for Polygon<T>
source§fn euclidean_distance(&self, target: &MultiPolygon<T>) -> T
fn euclidean_distance(&self, target: &MultiPolygon<T>) -> T
source§impl<T> EuclideanDistance<T, MultiPolygon<T>> for Rect<T>
impl<T> EuclideanDistance<T, MultiPolygon<T>> for Rect<T>
source§fn euclidean_distance(&self, other: &MultiPolygon<T>) -> T
fn euclidean_distance(&self, other: &MultiPolygon<T>) -> T
source§impl<T> EuclideanDistance<T, MultiPolygon<T>> for Triangle<T>
impl<T> EuclideanDistance<T, MultiPolygon<T>> for Triangle<T>
source§fn euclidean_distance(&self, other: &MultiPolygon<T>) -> T
fn euclidean_distance(&self, other: &MultiPolygon<T>) -> T
source§impl<T> EuclideanDistance<T, Point<T>> for MultiPolygon<T>
impl<T> EuclideanDistance<T, Point<T>> for MultiPolygon<T>
source§fn euclidean_distance(&self, target: &Point<T>) -> T
fn euclidean_distance(&self, target: &Point<T>) -> T
source§impl<T> EuclideanDistance<T, Polygon<T>> for MultiPolygon<T>
impl<T> EuclideanDistance<T, Polygon<T>> for MultiPolygon<T>
source§fn euclidean_distance(&self, target: &Polygon<T>) -> T
fn euclidean_distance(&self, target: &Polygon<T>) -> T
source§impl<T> EuclideanDistance<T, Rect<T>> for MultiPolygon<T>
impl<T> EuclideanDistance<T, Rect<T>> for MultiPolygon<T>
source§fn euclidean_distance(&self, other: &Rect<T>) -> T
fn euclidean_distance(&self, other: &Rect<T>) -> T
source§impl<T> EuclideanDistance<T, Triangle<T>> for MultiPolygon<T>
impl<T> EuclideanDistance<T, Triangle<T>> for MultiPolygon<T>
source§fn euclidean_distance(&self, other: &Triangle<T>) -> T
fn euclidean_distance(&self, other: &Triangle<T>) -> T
source§impl<T, IP> From<IP> for MultiPolygon<T>
impl<T, IP> From<IP> for MultiPolygon<T>
source§fn from(x: IP) -> MultiPolygon<T>
fn from(x: IP) -> MultiPolygon<T>
source§impl<T> From<MultiPolygon<T>> for Geometry<T>where
T: CoordNum,
impl<T> From<MultiPolygon<T>> for Geometry<T>where
T: CoordNum,
source§fn from(x: MultiPolygon<T>) -> Geometry<T>
fn from(x: MultiPolygon<T>) -> Geometry<T>
source§impl<T: GeoNum> From<MultiPolygon<T>> for MonotonicPolygons<T>
impl<T: GeoNum> From<MultiPolygon<T>> for MonotonicPolygons<T>
source§fn from(mp: MultiPolygon<T>) -> Self
fn from(mp: MultiPolygon<T>) -> Self
source§impl<T, IP> From<Vec<IP>> for MultiPolygon<T>
impl<T, IP> From<Vec<IP>> for MultiPolygon<T>
source§fn from(x: Vec<IP>) -> MultiPolygon<T>
fn from(x: Vec<IP>) -> MultiPolygon<T>
source§impl<T, IP> FromIterator<IP> for MultiPolygon<T>
impl<T, IP> FromIterator<IP> for MultiPolygon<T>
source§fn from_iter<I>(iter: I) -> MultiPolygon<T>where
I: IntoIterator<Item = IP>,
fn from_iter<I>(iter: I) -> MultiPolygon<T>where
I: IntoIterator<Item = IP>,
source§impl GeodesicArea<f64> for MultiPolygon
impl GeodesicArea<f64> for MultiPolygon
source§fn geodesic_perimeter(&self) -> f64
fn geodesic_perimeter(&self) -> f64
source§fn geodesic_area_signed(&self) -> f64
fn geodesic_area_signed(&self) -> f64
source§fn geodesic_area_unsigned(&self) -> f64
fn geodesic_area_unsigned(&self) -> f64
source§impl<C: CoordNum> HasDimensions for MultiPolygon<C>
impl<C: CoordNum> HasDimensions for MultiPolygon<C>
source§fn dimensions(&self) -> Dimensions
fn dimensions(&self) -> Dimensions
Rect
s are 2-dimensional, but it’s possible to create degenerate Rect
s which
have either 1 or 0 dimensions. Read moresource§fn boundary_dimensions(&self) -> Dimensions
fn boundary_dimensions(&self) -> Dimensions
Geometry
’s boundary, as used by OGC-SFA. Read moresource§impl<T> Hash for MultiPolygon<T>
impl<T> Hash for MultiPolygon<T>
source§impl<T> HaversineClosestPoint<T> for MultiPolygon<T>where
T: GeoFloat + FromPrimitive,
impl<T> HaversineClosestPoint<T> for MultiPolygon<T>where
T: GeoFloat + FromPrimitive,
fn haversine_closest_point(&self, from: &Point<T>) -> Closest<T>
source§impl<T> InteriorPoint for MultiPolygon<T>where
T: GeoFloat,
impl<T> InteriorPoint for MultiPolygon<T>where
T: GeoFloat,
source§impl<G, T> Intersects<G> for MultiPolygon<T>
impl<G, T> Intersects<G> for MultiPolygon<T>
fn intersects(&self, rhs: &G) -> bool
source§impl<T> Intersects<MultiPolygon<T>> for Line<T>
impl<T> Intersects<MultiPolygon<T>> for Line<T>
fn intersects(&self, rhs: &MultiPolygon<T>) -> bool
source§impl<T> Intersects<MultiPolygon<T>> for Point<T>
impl<T> Intersects<MultiPolygon<T>> for Point<T>
fn intersects(&self, rhs: &MultiPolygon<T>) -> bool
source§impl<T> Intersects<MultiPolygon<T>> for Polygon<T>
impl<T> Intersects<MultiPolygon<T>> for Polygon<T>
fn intersects(&self, rhs: &MultiPolygon<T>) -> bool
source§impl<T> Intersects<MultiPolygon<T>> for Rect<T>
impl<T> Intersects<MultiPolygon<T>> for Rect<T>
fn intersects(&self, rhs: &MultiPolygon<T>) -> bool
source§impl<T> Intersects<MultiPolygon<T>> for Triangle<T>
impl<T> Intersects<MultiPolygon<T>> for Triangle<T>
fn intersects(&self, rhs: &MultiPolygon<T>) -> bool
source§impl<'a, T> IntoIterator for &'a MultiPolygon<T>where
T: CoordNum,
impl<'a, T> IntoIterator for &'a MultiPolygon<T>where
T: CoordNum,
source§impl<'a, T> IntoIterator for &'a mut MultiPolygon<T>where
T: CoordNum,
impl<'a, T> IntoIterator for &'a mut MultiPolygon<T>where
T: CoordNum,
source§impl<T> IntoIterator for MultiPolygon<T>where
T: CoordNum,
impl<T> IntoIterator for MultiPolygon<T>where
T: CoordNum,
source§impl<'a, T: CoordNum + 'a> LinesIter<'a> for MultiPolygon<T>
impl<'a, T: CoordNum + 'a> LinesIter<'a> for MultiPolygon<T>
type Scalar = T
type Iter = Flatten<MapLinesIter<'a, Iter<'a, Polygon<<MultiPolygon<T> as LinesIter<'a>>::Scalar>>, Polygon<<MultiPolygon<T> as LinesIter<'a>>::Scalar>>>
source§fn lines_iter(&'a self) -> Self::Iter
fn lines_iter(&'a self) -> Self::Iter
source§impl<T: CoordNum, NT: CoordNum> MapCoords<T, NT> for MultiPolygon<T>
impl<T: CoordNum, NT: CoordNum> MapCoords<T, NT> for MultiPolygon<T>
source§impl<T: CoordNum> MapCoordsInPlace<T> for MultiPolygon<T>
impl<T: CoordNum> MapCoordsInPlace<T> for MultiPolygon<T>
source§impl<T> Orient for MultiPolygon<T>where
T: GeoNum,
impl<T> Orient for MultiPolygon<T>where
T: GeoNum,
source§impl<T> PartialEq for MultiPolygon<T>
impl<T> PartialEq for MultiPolygon<T>
source§fn eq(&self, other: &MultiPolygon<T>) -> bool
fn eq(&self, other: &MultiPolygon<T>) -> bool
self
and other
values to be equal, and is used
by ==
.source§impl<F: GeoFloat> Relate<F, GeometryCollection<F>> for MultiPolygon<F>
impl<F: GeoFloat> Relate<F, GeometryCollection<F>> for MultiPolygon<F>
fn relate(&self, other: &GeometryCollection<F>) -> IntersectionMatrix
source§impl<F: GeoFloat> Relate<F, Line<F>> for MultiPolygon<F>
impl<F: GeoFloat> Relate<F, Line<F>> for MultiPolygon<F>
fn relate(&self, other: &Line<F>) -> IntersectionMatrix
source§impl<F: GeoFloat> Relate<F, LineString<F>> for MultiPolygon<F>
impl<F: GeoFloat> Relate<F, LineString<F>> for MultiPolygon<F>
fn relate(&self, other: &LineString<F>) -> IntersectionMatrix
source§impl<F: GeoFloat> Relate<F, MultiLineString<F>> for MultiPolygon<F>
impl<F: GeoFloat> Relate<F, MultiLineString<F>> for MultiPolygon<F>
fn relate(&self, other: &MultiLineString<F>) -> IntersectionMatrix
source§impl<F: GeoFloat> Relate<F, MultiPoint<F>> for MultiPolygon<F>
impl<F: GeoFloat> Relate<F, MultiPoint<F>> for MultiPolygon<F>
fn relate(&self, other: &MultiPoint<F>) -> IntersectionMatrix
source§impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for GeometryCollection<F>
impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for GeometryCollection<F>
fn relate(&self, other: &MultiPolygon<F>) -> IntersectionMatrix
source§impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for Line<F>
impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for Line<F>
fn relate(&self, other: &MultiPolygon<F>) -> IntersectionMatrix
source§impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for LineString<F>
impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for LineString<F>
fn relate(&self, other: &MultiPolygon<F>) -> IntersectionMatrix
source§impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for MultiLineString<F>
impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for MultiLineString<F>
fn relate(&self, other: &MultiPolygon<F>) -> IntersectionMatrix
source§impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for MultiPoint<F>
impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for MultiPoint<F>
fn relate(&self, other: &MultiPolygon<F>) -> IntersectionMatrix
source§impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for MultiPolygon<F>
impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for MultiPolygon<F>
fn relate(&self, other: &MultiPolygon<F>) -> IntersectionMatrix
source§impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for Point<F>
impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for Point<F>
fn relate(&self, other: &MultiPolygon<F>) -> IntersectionMatrix
source§impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for Polygon<F>
impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for Polygon<F>
fn relate(&self, other: &MultiPolygon<F>) -> IntersectionMatrix
source§impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for Rect<F>
impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for Rect<F>
fn relate(&self, other: &MultiPolygon<F>) -> IntersectionMatrix
source§impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for Triangle<F>
impl<F: GeoFloat> Relate<F, MultiPolygon<F>> for Triangle<F>
fn relate(&self, other: &MultiPolygon<F>) -> IntersectionMatrix
source§impl<F: GeoFloat> Relate<F, Point<F>> for MultiPolygon<F>
impl<F: GeoFloat> Relate<F, Point<F>> for MultiPolygon<F>
fn relate(&self, other: &Point<F>) -> IntersectionMatrix
source§impl<F: GeoFloat> Relate<F, Polygon<F>> for MultiPolygon<F>
impl<F: GeoFloat> Relate<F, Polygon<F>> for MultiPolygon<F>
fn relate(&self, other: &Polygon<F>) -> IntersectionMatrix
source§impl<F: GeoFloat> Relate<F, Rect<F>> for MultiPolygon<F>
impl<F: GeoFloat> Relate<F, Rect<F>> for MultiPolygon<F>
fn relate(&self, other: &Rect<F>) -> IntersectionMatrix
source§impl<F: GeoFloat> Relate<F, Triangle<F>> for MultiPolygon<F>
impl<F: GeoFloat> Relate<F, Triangle<F>> for MultiPolygon<F>
fn relate(&self, other: &Triangle<F>) -> IntersectionMatrix
source§impl<T> RelativeEq for MultiPolygon<T>where
T: AbsDiffEq<Epsilon = T> + CoordNum + RelativeEq,
impl<T> RelativeEq for MultiPolygon<T>where
T: AbsDiffEq<Epsilon = T> + CoordNum + RelativeEq,
source§fn relative_eq(
&self,
other: &MultiPolygon<T>,
epsilon: <MultiPolygon<T> as AbsDiffEq>::Epsilon,
max_relative: <MultiPolygon<T> as AbsDiffEq>::Epsilon
) -> bool
fn relative_eq( &self, other: &MultiPolygon<T>, epsilon: <MultiPolygon<T> as AbsDiffEq>::Epsilon, max_relative: <MultiPolygon<T> as AbsDiffEq>::Epsilon ) -> bool
Equality assertion within a relative limit.
§Examples
use geo_types::{polygon, Polygon, MultiPolygon};
let a_el: Polygon<f32> = polygon![(x: 0., y: 0.), (x: 5., y: 0.), (x: 7., y: 9.), (x: 0., y: 0.)];
let a = MultiPolygon::new(vec![a_el]);
let b_el: Polygon<f32> = polygon![(x: 0., y: 0.), (x: 5., y: 0.), (x: 7.01, y: 9.), (x: 0., y: 0.)];
let b = MultiPolygon::new(vec![b_el]);
approx::assert_relative_eq!(a, b, max_relative=0.1);
approx::assert_relative_ne!(a, b, max_relative=0.001);
source§fn default_max_relative() -> <MultiPolygon<T> as AbsDiffEq>::Epsilon
fn default_max_relative() -> <MultiPolygon<T> as AbsDiffEq>::Epsilon
§fn relative_ne(
&self,
other: &Rhs,
epsilon: Self::Epsilon,
max_relative: Self::Epsilon
) -> bool
fn relative_ne( &self, other: &Rhs, epsilon: Self::Epsilon, max_relative: Self::Epsilon ) -> bool
RelativeEq::relative_eq
].source§impl<T> RemoveRepeatedPoints<T> for MultiPolygon<T>where
T: CoordNum + FromPrimitive,
impl<T> RemoveRepeatedPoints<T> for MultiPolygon<T>where
T: CoordNum + FromPrimitive,
source§fn remove_repeated_points(&self) -> Self
fn remove_repeated_points(&self) -> Self
Create a MultiPolygon with consecutive repeated points removed.
source§fn remove_repeated_points_mut(&mut self)
fn remove_repeated_points_mut(&mut self)
Remove consecutive repeated points from a MultiPolygon inplace.
source§impl<T> Simplify<T> for MultiPolygon<T>where
T: GeoFloat,
impl<T> Simplify<T> for MultiPolygon<T>where
T: GeoFloat,
source§impl<T> SimplifyVw<T> for MultiPolygon<T>where
T: CoordFloat,
impl<T> SimplifyVw<T> for MultiPolygon<T>where
T: CoordFloat,
source§fn simplify_vw(&self, epsilon: &T) -> MultiPolygon<T>
fn simplify_vw(&self, epsilon: &T) -> MultiPolygon<T>
source§impl<T> SimplifyVwPreserve<T> for MultiPolygon<T>
impl<T> SimplifyVwPreserve<T> for MultiPolygon<T>
source§fn simplify_vw_preserve(&self, epsilon: &T) -> MultiPolygon<T>
fn simplify_vw_preserve(&self, epsilon: &T) -> MultiPolygon<T>
source§impl<T> TryFrom<Geometry<T>> for MultiPolygon<T>where
T: CoordNum,
impl<T> TryFrom<Geometry<T>> for MultiPolygon<T>where
T: CoordNum,
Convert a Geometry enum into its inner type.
Fails if the enum case does not match the type you are trying to convert it to.
impl<T> Eq for MultiPolygon<T>
impl<T> StructuralPartialEq for MultiPolygon<T>where
T: CoordNum,
Auto Trait Implementations§
impl<T> RefUnwindSafe for MultiPolygon<T>where
T: RefUnwindSafe,
impl<T> Send for MultiPolygon<T>where
T: Send,
impl<T> Sync for MultiPolygon<T>where
T: Sync,
impl<T> Unpin for MultiPolygon<T>where
T: Unpin,
impl<T> UnwindSafe for MultiPolygon<T>where
T: UnwindSafe,
Blanket Implementations§
source§impl<T, M> AffineOps<T> for M
impl<T, M> AffineOps<T> for M
source§fn affine_transform(&self, transform: &AffineTransform<T>) -> M
fn affine_transform(&self, transform: &AffineTransform<T>) -> M
transform
immutably, outputting a new geometry.source§fn affine_transform_mut(&mut self, transform: &AffineTransform<T>)
fn affine_transform_mut(&mut self, transform: &AffineTransform<T>)
transform
to mutate self
.source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<'a, T, G> ConvexHull<'a, T> for Gwhere
T: GeoNum,
G: CoordsIter<Scalar = T>,
impl<'a, T, G> ConvexHull<'a, T> for Gwhere
T: GeoNum,
G: CoordsIter<Scalar = T>,
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
source§impl<'a, T, G> Extremes<'a, T> for Gwhere
G: CoordsIter<Scalar = T>,
T: CoordNum,
impl<'a, T, G> Extremes<'a, T> for Gwhere
G: CoordsIter<Scalar = T>,
T: CoordNum,
source§impl<T, G> HausdorffDistance<T> for Gwhere
T: GeoFloat,
G: CoordsIter<Scalar = T>,
impl<T, G> HausdorffDistance<T> for Gwhere
T: GeoFloat,
G: CoordsIter<Scalar = T>,
fn hausdorff_distance<Rhs>(&self, rhs: &Rhs) -> Twhere
Rhs: CoordsIter<Scalar = T>,
source§impl<T, G> MinimumRotatedRect<T> for G
impl<T, G> MinimumRotatedRect<T> for G
type Scalar = T
fn minimum_rotated_rect( &self ) -> Option<Polygon<<G as MinimumRotatedRect<T>>::Scalar>>
source§impl<G, IP, IR, T> Rotate<T> for G
impl<G, IP, IR, T> Rotate<T> for G
source§fn rotate_around_centroid(&self, degrees: T) -> G
fn rotate_around_centroid(&self, degrees: T) -> G
source§fn rotate_around_centroid_mut(&mut self, degrees: T)
fn rotate_around_centroid_mut(&mut self, degrees: T)
Self::rotate_around_centroid
source§fn rotate_around_center(&self, degrees: T) -> G
fn rotate_around_center(&self, degrees: T) -> G
source§fn rotate_around_center_mut(&mut self, degrees: T)
fn rotate_around_center_mut(&mut self, degrees: T)
Self::rotate_around_center
source§fn rotate_around_point(&self, degrees: T, point: Point<T>) -> G
fn rotate_around_point(&self, degrees: T, point: Point<T>) -> G
source§fn rotate_around_point_mut(&mut self, degrees: T, point: Point<T>)
fn rotate_around_point_mut(&mut self, degrees: T, point: Point<T>)
Self::rotate_around_point
source§impl<T, IR, G> Scale<T> for Gwhere
T: CoordFloat,
IR: Into<Option<Rect<T>>>,
G: Clone + AffineOps<T> + BoundingRect<T, Output = IR>,
impl<T, IR, G> Scale<T> for Gwhere
T: CoordFloat,
IR: Into<Option<Rect<T>>>,
G: Clone + AffineOps<T> + BoundingRect<T, Output = IR>,
source§fn scale(&self, scale_factor: T) -> G
fn scale(&self, scale_factor: T) -> G
source§fn scale_xy(&self, x_factor: T, y_factor: T) -> G
fn scale_xy(&self, x_factor: T, y_factor: T) -> G
x_factor
and
y_factor
to distort the geometry’s aspect ratio. Read moresource§fn scale_xy_mut(&mut self, x_factor: T, y_factor: T)
fn scale_xy_mut(&mut self, x_factor: T, y_factor: T)
scale_xy
.source§fn scale_around_point(
&self,
x_factor: T,
y_factor: T,
origin: impl Into<Coord<T>>
) -> G
fn scale_around_point( &self, x_factor: T, y_factor: T, origin: impl Into<Coord<T>> ) -> G
origin
. Read moresource§fn scale_around_point_mut(
&mut self,
x_factor: T,
y_factor: T,
origin: impl Into<Coord<T>>
)
fn scale_around_point_mut( &mut self, x_factor: T, y_factor: T, origin: impl Into<Coord<T>> )
scale_around_point
.source§impl<T, IR, G> Skew<T> for Gwhere
T: CoordFloat,
IR: Into<Option<Rect<T>>>,
G: Clone + AffineOps<T> + BoundingRect<T, Output = IR>,
impl<T, IR, G> Skew<T> for Gwhere
T: CoordFloat,
IR: Into<Option<Rect<T>>>,
G: Clone + AffineOps<T> + BoundingRect<T, Output = IR>,
source§fn skew(&self, degrees: T) -> G
fn skew(&self, degrees: T) -> G
source§fn skew_xy(&self, degrees_x: T, degrees_y: T) -> G
fn skew_xy(&self, degrees_x: T, degrees_y: T) -> G
source§fn skew_xy_mut(&mut self, degrees_x: T, degrees_y: T)
fn skew_xy_mut(&mut self, degrees_x: T, degrees_y: T)
skew_xy
.source§fn skew_around_point(&self, xs: T, ys: T, origin: impl Into<Coord<T>>) -> G
fn skew_around_point(&self, xs: T, ys: T, origin: impl Into<Coord<T>>) -> G
origin
, sheared by an
angle along the x and y dimensions. Read moresource§fn skew_around_point_mut(&mut self, xs: T, ys: T, origin: impl Into<Coord<T>>)
fn skew_around_point_mut(&mut self, xs: T, ys: T, origin: impl Into<Coord<T>>)
skew_around_point
.