geo/algorithm/contains/
line.rs1use super::{impl_contains_from_relate, impl_contains_geometry_for, Contains};
2use crate::algorithm::Intersects;
3use crate::geometry::*;
4use crate::{GeoFloat, GeoNum};
5
6impl<T> Contains<Coord<T>> for Line<T>
11where
12 T: GeoNum,
13{
14 fn contains(&self, coord: &Coord<T>) -> bool {
15 if self.start == self.end {
16 &self.start == coord
17 } else {
18 coord != &self.start && coord != &self.end && self.intersects(coord)
19 }
20 }
21}
22
23impl<T> Contains<Point<T>> for Line<T>
24where
25 T: GeoNum,
26{
27 fn contains(&self, p: &Point<T>) -> bool {
28 self.contains(&p.0)
29 }
30}
31
32impl<T> Contains<Line<T>> for Line<T>
33where
34 T: GeoNum,
35{
36 fn contains(&self, line: &Line<T>) -> bool {
37 if line.start == line.end {
38 self.contains(&line.start)
39 } else {
40 self.intersects(&line.start) && self.intersects(&line.end)
41 }
42 }
43}
44
45impl<T> Contains<LineString<T>> for Line<T>
46where
47 T: GeoNum,
48{
49 fn contains(&self, linestring: &LineString<T>) -> bool {
50 if linestring.0.is_empty() {
53 return false;
54 }
55
56 let first = linestring.0.first().unwrap();
69 let mut all_equal = true;
70
71 let all_intersects = linestring.0.iter().all(|c| {
76 if c != first {
77 all_equal = false;
78 }
79 self.intersects(c)
80 });
81
82 all_intersects && (!all_equal || self.contains(first))
83 }
84}
85
86impl_contains_from_relate!(Line<T>, [Polygon<T>, MultiPoint<T>, MultiLineString<T>, MultiPolygon<T>, GeometryCollection<T>, Rect<T>, Triangle<T>]);
87impl_contains_geometry_for!(Line<T>);