mirror of
https://github.com/jhasse/poly2tri.git
synced 2024-12-02 10:13:29 +01:00
bug hunting
This commit is contained in:
parent
413275d415
commit
8f8e8144bf
@ -210,10 +210,12 @@ class Poly2TriDemo extends BasicGame("Poly2Tri") {
|
|||||||
g.draw(triangle)
|
g.draw(triangle)
|
||||||
})
|
})
|
||||||
|
|
||||||
slCDT.cList.foreach(c => {
|
//slCDT.cList.foreach(c => {
|
||||||
val circ = new Circle(c.x, c.y, 0.5f)
|
for(i <- 0 until 9) {
|
||||||
|
val circ = new Circle(slCDT.cList(i).x, slCDT.cList(i).y, 0.5f)
|
||||||
g.setColor(blue); g.draw(circ); g.fill(circ)
|
g.setColor(blue); g.draw(circ); g.fill(circ)
|
||||||
})
|
}
|
||||||
|
//})
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -437,9 +439,9 @@ class Poly2TriDemo extends BasicGame("Poly2Tri") {
|
|||||||
if(slCDT.cList.size > 1) {
|
if(slCDT.cList.size > 1) {
|
||||||
//slCDT.addPoint(slCDT.cList(0))
|
//slCDT.addPoint(slCDT.cList(0))
|
||||||
//slCDT.addPoint(slCDT.cList(1))
|
//slCDT.addPoint(slCDT.cList(1))
|
||||||
for(i <- 0 until slCDT.cList.size)
|
for(i <- 0 until 9 /*slCDT.cList.size*/)
|
||||||
slCDT.addPoint(slCDT.cList(i))
|
slCDT.addPoint(slCDT.cList(i))
|
||||||
//slCDT.triangulate
|
slCDT.triangulate
|
||||||
}
|
}
|
||||||
|
|
||||||
println("CDT average (ms) = " + runTime*1e-6)
|
println("CDT average (ms) = " + runTime*1e-6)
|
||||||
|
@ -152,8 +152,8 @@ class CDT(polyLine: Array[Point], clearPoint: Point) {
|
|||||||
|
|
||||||
// Implement sweep-line
|
// Implement sweep-line
|
||||||
private def sweep {
|
private def sweep {
|
||||||
// 48 67
|
// 49 69
|
||||||
val size = if(refine) 47 else points.size
|
val size = if(refine) 50 else points.size
|
||||||
|
|
||||||
for(i <- 1 until size) {
|
for(i <- 1 until size) {
|
||||||
|
|
||||||
@ -187,7 +187,7 @@ class CDT(polyLine: Array[Point], clearPoint: Point) {
|
|||||||
if(t.thin) {
|
if(t.thin) {
|
||||||
val center = Util.circumcenter(t.points(0), t.points(1), t.points(2))
|
val center = Util.circumcenter(t.points(0), t.points(1), t.points(2))
|
||||||
cList += center
|
cList += center
|
||||||
//refine = true
|
refine = true
|
||||||
//addPoint(center)
|
//addPoint(center)
|
||||||
//mesh.debug += t
|
//mesh.debug += t
|
||||||
}
|
}
|
||||||
@ -218,7 +218,10 @@ class CDT(polyLine: Array[Point], clearPoint: Point) {
|
|||||||
private def edgeEvent(edge: Segment, node: Node) {
|
private def edgeEvent(edge: Segment, node: Node) {
|
||||||
|
|
||||||
// Locate the first intersected triangle
|
// Locate the first intersected triangle
|
||||||
val firstTriangle = node.triangle.locateFirst(edge)
|
val firstTriangle = if(!node.triangle.contains(edge.q))
|
||||||
|
node.triangle
|
||||||
|
else
|
||||||
|
node.triangle.locateFirst(edge)
|
||||||
|
|
||||||
if(firstTriangle != null && !firstTriangle.contains(edge)) {
|
if(firstTriangle != null && !firstTriangle.contains(edge)) {
|
||||||
|
|
||||||
@ -306,57 +309,70 @@ class CDT(polyLine: Array[Point], clearPoint: Point) {
|
|||||||
nTriangles += pNode.triangle
|
nTriangles += pNode.triangle
|
||||||
|
|
||||||
val ahead = (edge.p.x > edge.q.x)
|
val ahead = (edge.p.x > edge.q.x)
|
||||||
|
var aboveEdge = false
|
||||||
|
|
||||||
if(ahead) {
|
if(ahead) {
|
||||||
|
// Scan right
|
||||||
pNode = pNode.next
|
pNode = pNode.next
|
||||||
while(pNode.point != edge.p) {
|
while(pNode.point != edge.p && !aboveEdge) {
|
||||||
points += pNode.point
|
points += pNode.point
|
||||||
nTriangles += pNode.triangle
|
nTriangles += pNode.triangle
|
||||||
pNode = pNode.next
|
pNode = pNode.next
|
||||||
|
aboveEdge = edge < pNode.point
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
// Scal left
|
||||||
pNode = pNode.prev
|
pNode = pNode.prev
|
||||||
while(pNode.point != edge.p) {
|
while(pNode.point != edge.p && !aboveEdge) {
|
||||||
points += pNode.point
|
points += pNode.point
|
||||||
nTriangles += pNode.triangle
|
nTriangles += pNode.triangle
|
||||||
pNode = pNode.prev
|
pNode = pNode.prev
|
||||||
|
aboveEdge = edge < pNode.point
|
||||||
}
|
}
|
||||||
|
nTriangles += pNode.triangle
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
val point2 = if(aboveEdge) {
|
||||||
val s = new Segment(first.point, first.next.point)
|
val p1 = pNode.point
|
||||||
if(s > point1) {
|
val p2 = if(ahead) pNode.prev.point else pNode.next.point
|
||||||
mesh.map -= first.triangle
|
edge.intersect(p1, p2)
|
||||||
first.triangle = first.triangle.neighborCW(first.point)
|
} else {
|
||||||
val t = first.triangle.neighborAcross(first.point)
|
edge.p
|
||||||
val n = new Node(point1, t)
|
|
||||||
first.next = n
|
|
||||||
n.prev = first
|
|
||||||
n.next = first.next.next
|
|
||||||
n.next.prev = n
|
|
||||||
}
|
}
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
// Triangulate empty areas.
|
// Triangulate empty areas.
|
||||||
val T = new ArrayBuffer[Triangle]
|
val T = new ArrayBuffer[Triangle]
|
||||||
triangulate(points.toArray, List(edge.q, edge.p), T)
|
triangulate(points.toArray, List(edge.q, point2), T)
|
||||||
|
|
||||||
// Update neighbors
|
// Update neighbors
|
||||||
edgeNeighbors(nTriangles, T)
|
edgeNeighbors(nTriangles, T)
|
||||||
|
|
||||||
// Update advancing front
|
// Update advancing front
|
||||||
if(ahead)
|
if(ahead && !aboveEdge)
|
||||||
aFront link (first, pNode, T.last)
|
aFront link (first, pNode, T.last)
|
||||||
else
|
else if(!ahead && !aboveEdge)
|
||||||
aFront link (pNode, first, T.last)
|
aFront link (pNode, first, T.last)
|
||||||
|
|
||||||
// Mark constrained edge
|
// Mark constrained edge
|
||||||
T.last markEdge(edge.q, edge.p)
|
T.last markEdge(edge.q, point2)
|
||||||
|
|
||||||
if(pNode.point != edge.p) {
|
if(aboveEdge) {
|
||||||
println("span")
|
val iNode = if(ahead) {
|
||||||
//edgeEvent(edge, pNode)
|
val n = new Node(point2, pNode.prev.triangle)
|
||||||
|
aFront link (first, n, T.last)
|
||||||
|
n.next = pNode
|
||||||
|
pNode.prev = n
|
||||||
|
n
|
||||||
|
} else {
|
||||||
|
val n = new Node(point2, pNode.next.triangle)
|
||||||
|
aFront link (n, first, T.last)
|
||||||
|
pNode.next = n
|
||||||
|
n.prev = pNode
|
||||||
|
n
|
||||||
|
}
|
||||||
|
val above = point2.y > edge.p.y
|
||||||
|
val e = if(above) new Segment(edge.p, point2) else { println("wtf"); new Segment(point2, edge.p)}
|
||||||
|
edgeEvent(e, iNode)
|
||||||
}
|
}
|
||||||
|
|
||||||
} else if(firstTriangle.contains(edge.q, edge.p)) {
|
} else if(firstTriangle.contains(edge.q, edge.p)) {
|
||||||
|
@ -51,4 +51,28 @@ class Segment(var p: Point, var q: Point) {
|
|||||||
// Determines if this segment lies below the given point
|
// Determines if this segment lies below the given point
|
||||||
def < (point: Point) = (Math.floor(point.y) > Math.floor(slope * point.x + b))
|
def < (point: Point) = (Math.floor(point.y) > Math.floor(slope * point.x + b))
|
||||||
|
|
||||||
|
private def signedArea(a: Point, b: Point, c: Point): Float =
|
||||||
|
(a.x - c.x) * (b.y - c.y) - (a.y - c.y) * (b.x - c.x)
|
||||||
|
|
||||||
|
def intersect(c: Point, d: Point): Point = {
|
||||||
|
|
||||||
|
val a = p
|
||||||
|
val b = q
|
||||||
|
|
||||||
|
val a1 = signedArea(a, b, d)
|
||||||
|
val a2 = signedArea(a, b, c)
|
||||||
|
|
||||||
|
if (a1 != 0.0f && a2 != 0.0f && a1*a2 < 0.0f) {
|
||||||
|
val a3 = signedArea(c, d, a)
|
||||||
|
val a4 = a3 + a2 - a1
|
||||||
|
if (a3 * a4 < 0.0f) {
|
||||||
|
val t = a3 / (a3 - a4)
|
||||||
|
return a + ((b - a) * t)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
throw new Exception("Error")
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -125,7 +125,8 @@ class Triangle(val points: Array[Point]) {
|
|||||||
// Locate first triangle crossed by constrained edge
|
// Locate first triangle crossed by constrained edge
|
||||||
def locateFirst(edge: Segment): Triangle = {
|
def locateFirst(edge: Segment): Triangle = {
|
||||||
|
|
||||||
if(contains(edge)) this
|
if(contains(edge)) return this
|
||||||
|
|
||||||
if(edge.q == points(0))
|
if(edge.q == points(0))
|
||||||
search(points(1), points(2), edge, neighbors(2))
|
search(points(1), points(2), edge, neighbors(2))
|
||||||
else if(edge.q == points(1))
|
else if(edge.q == points(1))
|
||||||
|
@ -285,6 +285,21 @@ object Util {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def closestPtSegment(c: Point, a: Point, b: Point): Point = {
|
||||||
|
val ab = b - a
|
||||||
|
var t = (c - a) dot ab
|
||||||
|
if (t <= 0.0f)
|
||||||
|
return a
|
||||||
|
else {
|
||||||
|
val denom = ab dot ab
|
||||||
|
if (t >= denom)
|
||||||
|
return b
|
||||||
|
else {
|
||||||
|
t = t / denom
|
||||||
|
}
|
||||||
|
}
|
||||||
|
a + (ab * t)
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user