9个不稳定版本 (3个破坏性)
0.3.0 | 2022年4月24日 |
---|---|
0.2.5 | 2022年3月28日 |
0.1.0 | 2022年3月28日 |
0.0.0 | 2022年3月28日 |
#1752 in 数学
每月103次下载
在 15 个crates中(2个直接) 使用
13KB
176 行
射影变换
use projective::Projective;
#[derive(Debug, Copy, Clone, PartialEq)]
pub struct Point(f64, f64);
#[rustfmt::skip]
impl Projective<f64> for Point {
fn transform(&self, matrix: &[&f64; 9]) -> Self {
Point(
matrix[0] * self.0 + matrix[1] * self.1 + matrix[2],
matrix[3] * self.0 + matrix[4] * self.1 + matrix[5],
)
}
}
#[test]
fn test_transform() {
let p0 = Point(1.0, 2.0);
assert_eq!(p0.translate(&2.0, &1.0), Point(3.0, 3.0));
assert_eq!(p0.scale(&2.0, &3.0), Point(2.0, 6.0));
// floating precision error, implement rotate manually to reduce errors
assert_eq!(p0.rotate(&std::f64::consts::PI), Point(-0.9999999999999998, -2.0));
}
依赖关系
~150KB