abstreet/geom/src/lib.rs

54 lines
1.3 KiB
Rust
Raw Normal View History

2018-06-29 05:48:11 +03:00
extern crate dimensioned;
extern crate graphics;
extern crate ordered_float;
extern crate rand;
extern crate serde;
#[macro_use]
extern crate serde_derive;
mod angle;
mod bounds;
mod gps;
mod line;
mod polygon;
2018-06-29 05:48:11 +03:00
mod polyline;
mod pt;
pub use angle::Angle;
pub use bounds::Bounds;
2018-08-07 23:22:24 +03:00
use dimensioned::si;
2018-06-29 05:48:11 +03:00
pub use gps::LonLat;
pub use line::Line;
pub use polygon::{Polygon, Triangle};
2018-06-29 05:48:11 +03:00
pub use polyline::PolyLine;
pub use pt::{HashablePt2D, Pt2D};
2018-08-07 23:22:24 +03:00
use std::marker;
pub const EPSILON_DIST: si::Meter<f64> = si::Meter {
2018-08-07 23:22:24 +03:00
value_unsafe: 0.00001,
_marker: marker::PhantomData,
};
// NOT segment. Fails for parallel lines.
// https://en.wikipedia.org/wiki/Line%E2%80%93line_intersection#Given_two_points_on_each_line
pub(crate) fn line_intersection(l1: &Line, l2: &Line) -> Option<Pt2D> {
let x1 = l1.pt1().x();
let y1 = l1.pt1().y();
let x2 = l1.pt2().x();
let y2 = l1.pt2().y();
let x3 = l2.pt1().x();
let y3 = l2.pt1().y();
let x4 = l2.pt2().x();
let y4 = l2.pt2().y();
let numer_x = (x1 * y2 - y1 * x2) * (x3 - x4) - (x1 - x2) * (x3 * y4 - y3 * x4);
let numer_y = (x1 * y2 - y1 * x2) * (y3 - y4) - (y1 - y2) * (x3 * y4 - y3 * x4);
let denom = (x1 - x2) * (y3 - y4) - (y1 - y2) * (x3 - x4);
if denom == 0.0 {
None
} else {
Some(Pt2D::new(numer_x / denom, numer_y / denom))
}
}