Replace lossy conversions with methods

This commit is contained in:
Chad Brokaw 2022-05-19 18:04:00 -04:00
parent 938d6fc052
commit 39b773c611

View file

@ -28,9 +28,10 @@ mod kurbo_conv {
use super::geometry::{Affine, Point, Rect}; use super::geometry::{Affine, Point, Rect};
use super::path::Element; use super::path::Element;
impl From<kurbo::Point> for Point { impl Point {
fn from(p: kurbo::Point) -> Self { /// Creates a new point from the equivalent kurbo type.
Self::new(p.x as f32, p.y as f32) pub fn from_kurbo(point: kurbo::Point) -> Self {
Self::new(point.x as f32, point.y as f32)
} }
} }
@ -40,9 +41,10 @@ mod kurbo_conv {
} }
} }
impl From<kurbo::Affine> for Affine { impl Affine {
fn from(a: kurbo::Affine) -> Self { /// Creates a new affine transformation from the equivalent kurbo type.
let c = a.as_coeffs(); pub fn from_kurbo(affine: kurbo::Affine) -> Self {
let c = affine.as_coeffs();
Self { Self {
xx: c[0] as f32, xx: c[0] as f32,
yx: c[1] as f32, yx: c[1] as f32,
@ -67,11 +69,12 @@ mod kurbo_conv {
} }
} }
impl From<kurbo::Rect> for Rect { impl Rect {
fn from(r: kurbo::Rect) -> Self { /// Creates a new rectangle from the equivalent kurbo type.
pub fn from_kurbo(rect: kurbo::Rect) -> Self {
Self { Self {
min: Point::new(r.x0 as f32, r.y0 as f32), min: Point::new(rect.x0 as f32, rect.y0 as f32),
max: Point::new(r.x1 as f32, r.y1 as f32), max: Point::new(rect.x1 as f32, rect.y1 as f32),
} }
} }
} }
@ -100,6 +103,23 @@ mod kurbo_conv {
} }
} }
impl Element {
/// Creates a new path element from the equivalent kurbo type.
pub fn from_kurbo(el: kurbo::PathEl) -> Self {
use kurbo::PathEl::*;
use Point::from_kurbo;
match e {
MoveTo(p0) => Self::MoveTo(from_kurbo(p0)),
LineTo(p0) => Self::LineTo(from_kurbo(p0)),
QuadTo(p0, p1) => Self::QuadTo(from_kurbo(p0), from_kurbo(p1)),
CurveTo(p0, p1, p2) => {
Self::CurveTo(from_kurbo(p0), from_kurbo(p1), from_kurbo(p2))
}
ClosePath => Self::Close,
}
}
}
impl From<Element> for kurbo::PathEl { impl From<Element> for kurbo::PathEl {
fn from(e: Element) -> Self { fn from(e: Element) -> Self {
use Element::*; use Element::*;