You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I'd like to use this algorithm in my breadx project, as a way of breaking shapes into triangles before sending them to the X11 server. As a test, I ran the algorithm on this shape:
I implemented tesselate_shape using the following:
/// From the given set of points, return an iterator over the triangles.
#[inline]
pub fn tesselate_shape<'a>(points: &'a [Pointfix]) -> impl Iterator<Item = Triangle> + 'a {
let floating_points: Vec<Point> = points
.iter()
.copied()
.map(|Pointfix { x, y }| Point {
x: fixed_to_double(x),
y: fixed_to_double(y),
})
.collect();
let vector = match triangulate(&floating_points) {
Some(t) => t.triangles ,
None => vec![],
};
vector
.into_iter()
.map(move |index| &points[index])
.copied()
.scan(ArrayVec::<[Pointfix; 3]>::new(), |av, point| {
av.push(point);
if av.len() == 3 {
let [p1, p2, p3] = mem::take(av).into_inner();
Some(Some(Triangle { p1, p2, p3 }))
} else {
Some(None)
}
})
.flatten()
}
Note: XRender does things in fixed-point 32-bit numbers by default, so I have to convert them to and from floating point notation.
When I run this, it produces radically different results than expected. Here's what I should see; this is what I get when I manually triangulated the shape:
However, this happens when I use delaunator:
I feel like this is probably a result of me misunderstanding how the crate is supposed to work; is there something I'm missing?
The text was updated successfully, but these errors were encountered:
I'd like to use this algorithm in my breadx project, as a way of breaking shapes into triangles before sending them to the X11 server. As a test, I ran the algorithm on this shape:
I implemented
tesselate_shape
using the following:Note: XRender does things in fixed-point 32-bit numbers by default, so I have to convert them to and from floating point notation.
When I run this, it produces radically different results than expected. Here's what I should see; this is what I get when I manually triangulated the shape:
However, this happens when I use
delaunator
:I feel like this is probably a result of me misunderstanding how the crate is supposed to work; is there something I'm missing?
The text was updated successfully, but these errors were encountered: