added back neighbor update

This commit is contained in:
zzzzrrr 2009-08-06 13:39:49 -04:00
parent 97ead85d3b
commit 05c71a20e8
3 changed files with 65 additions and 21 deletions

View File

@ -65,7 +65,7 @@ object CDT {
val deltaX = ALPHA * (xmax - xmin) val deltaX = ALPHA * (xmax - xmin)
val deltaY = ALPHA * (ymax - ymin) val deltaY = ALPHA * (ymax - ymin)
val p1 = Point(xmin - deltaX, ymin - deltaY) val p1 = Point(xmin - deltaX, ymin - deltaY)
val p2 = Point(xmax + deltaX, ymin - deltaY) val p2 = Point(xmax + deltaX, p1.y)
val segments = initSegments(points) val segments = initSegments(points)
val sortedPoints = pointSort(points) val sortedPoints = pointSort(points)
@ -125,13 +125,16 @@ class CDT(val points: List[Point], val segments: List[Segment], iTriangle: Trian
// Implement sweep-line // Implement sweep-line
private def sweep { private def sweep {
//var cTri: Triangle = null
for(i <- 1 until points.size) { for(i <- 1 until points.size) {
val point = points(i) val point = points(i)
// Process Point event // Process Point event
val triangle = pointEvent(point) val triangle = pointEvent(point)
// Process edge events // Process edge events
point.edges.foreach(e => edgeEvent(e, triangle)) point.edges.foreach(e => edgeEvent(e, triangle))
//if(i == 10) {cTri = triangle; mesh.debug += cTri}
} }
//mesh clean cTri
} }
// Point event // Point event
@ -156,6 +159,10 @@ class CDT(val points: List[Point], val segments: List[Segment], iTriangle: Trian
// No need for legalization here // No need for legalization here
// Update neighbors
node.triangle.updateNeighbors(rTriangle.points(1), rTriangle.points(2), rTriangle, mesh.debug)
node.prev.triangle.updateNeighbors(lTriangle.points(1), lTriangle.points(2), lTriangle, mesh.debug)
// Update advancing front // Update advancing front
val newNode = aFront.insert(point, rTriangle, node) val newNode = aFront.insert(point, rTriangle, node)
node.prev.next = newNode node.prev.next = newNode
@ -185,6 +192,8 @@ class CDT(val points: List[Point], val segments: List[Segment], iTriangle: Trian
// Update advancing front // Update advancing front
if(legal) { if(legal) {
newNode = aFront.insert(point, triangle, node) newNode = aFront.insert(point, triangle, node)
// Update neighbors
nTri.updateNeighbors(cwPoint, ccwPoint, triangle, mesh.debug)
} else { } else {
newNode = new Node(triangle.points(1), triangle) newNode = new Node(triangle.points(1), triangle)
val rNode = node.next val rNode = node.next
@ -210,19 +219,19 @@ class CDT(val points: List[Point], val segments: List[Segment], iTriangle: Trian
if(firstTriangle != null && !firstTriangle.contains(edge)) { if(firstTriangle != null && !firstTriangle.contains(edge)) {
// Collect intersected triangles // Collect intersected triangles
val triangles = new ArrayBuffer[Triangle] val tList = new ArrayBuffer[Triangle]
triangles += firstTriangle tList += firstTriangle
while(triangles.last != null && !triangles.last.contains(edge.p)) while(tList.last != null && !tList.last.contains(edge.p))
triangles += triangles.last.findNeighbor(edge.p - edge.q) tList += tList.last.findNeighbor(edge.p - edge.q)
// TODO: fix triangles.last == null bug! // TODO: fix tList.last == null bug!
// Not sure why this happens in bird & nazca monkey demo... // Not sure why this happens in bird & nazca monkey demo...
if(triangles.last == null) if(tList.last == null)
triangles -= triangles.last tList -= tList.last
// Remove old triangles // Remove old triangles
triangles.foreach(t => mesh.map -= t) tList.foreach(t => mesh.map -= t)
val lPoints = new ArrayBuffer[Point] val lPoints = new ArrayBuffer[Point]
val rPoints = new ArrayBuffer[Point] val rPoints = new ArrayBuffer[Point]
@ -232,7 +241,7 @@ class CDT(val points: List[Point], val segments: List[Segment], iTriangle: Trian
val point2 = if(ahead) edge.p else edge.q val point2 = if(ahead) edge.p else edge.q
// Collect points left and right of edge // Collect points left and right of edge
triangles.foreach(t => { tList.foreach(t => {
t.points.foreach(p => { t.points.foreach(p => {
if(p != edge.q && p != edge.p) { if(p != edge.q && p != edge.p) {
if(t.orient(point1, point2, p) >= 0 ) { if(t.orient(point1, point2, p) >= 0 ) {
@ -255,7 +264,10 @@ class CDT(val points: List[Point], val segments: List[Segment], iTriangle: Trian
val T2 = new ArrayBuffer[Triangle] val T2 = new ArrayBuffer[Triangle]
triangulate(rPoints.toArray, List(point1, point2), T2) triangulate(rPoints.toArray, List(point1, point2), T2)
// TODO: Update Delauney Edge Pointers // Mark constrained edges
val dEdge = new Segment(point1, point2)
T1.first markEdge dEdge
T2.first markEdge dEdge
} else if(firstTriangle == null) { } else if(firstTriangle == null) {
@ -284,10 +296,13 @@ class CDT(val points: List[Point], val segments: List[Segment], iTriangle: Trian
first.next = node first.next = node
node.prev = first node.prev = first
// TODO: Update Delauney Edge Pointers // Mark constrained edge
val dEdge = new Segment(point1, point2)
T.first markEdge dEdge
} else if(firstTriangle.contains(edge)) { } else if(firstTriangle.contains(edge)) {
// TODO: Update Delauney Edge Pointers // Mark constrained edge
firstTriangle markEdge edge
} }
} }
@ -354,6 +369,9 @@ class CDT(val points: List[Point], val segments: List[Segment], iTriangle: Trian
val points = Array(node.prev.point, node.point, node.next.point) val points = Array(node.prev.point, node.point, node.next.point)
val neighbors = Array(node.triangle, null, node.prev.triangle) val neighbors = Array(node.triangle, null, node.prev.triangle)
val triangle = new Triangle(points, neighbors) val triangle = new Triangle(points, neighbors)
// Update neighbor pointers
node.prev.triangle.updateNeighbors(triangle.points(0), triangle.points(1), triangle, mesh.debug)
node.triangle.updateNeighbors(triangle.points(1), triangle.points(2), triangle, mesh.debug)
mesh.map += triangle mesh.map += triangle
aFront -= (node.prev, node, triangle) aFront -= (node.prev, node, triangle)
} }

View File

@ -30,7 +30,7 @@
*/ */
package org.poly2tri.cdt package org.poly2tri.cdt
import scala.collection.mutable.HashSet import scala.collection.mutable.{HashSet, ArrayBuffer}
import shapes.{Point, Triangle} import shapes.{Point, Triangle}
@ -40,5 +40,20 @@ class Mesh(initialTriangle: Triangle) {
val map = HashSet(initialTriangle) val map = HashSet(initialTriangle)
// Debug triangles // Debug triangles
val debug = HashSet.empty[Triangle] val debug = HashSet.empty[Triangle]
val triangles = new ArrayBuffer[Triangle]
// Recursively collect triangles
def clean(triangle: Triangle) {
if(triangle != null && triangle.clean == false) {
triangle.clean = true
if(triangle.edges(0) == false)
clean(triangle.neighbors(0))
if(triangle.edges(1) == false)
clean(triangle.neighbors(1))
if(triangle.edges(2) == false)
clean(triangle.neighbors(2))
triangles += triangle
}
}
} }

View File

@ -39,7 +39,10 @@ import scala.collection.mutable.ArrayBuffer
class Triangle(val points: Array[Point], val neighbors: Array[Triangle]) { class Triangle(val points: Array[Point], val neighbors: Array[Triangle]) {
// Flags to determine if an edge is the final Delauney edge // Flags to determine if an edge is the final Delauney edge
val edges = new Array[Boolean](3) val edges = Array(false, false, false)
// Finalization flag
var clean = false
// Update neighbor pointers // Update neighbor pointers
def updateNeighbors(ccwPoint: Point, cwPoint: Point, triangle: Triangle, mesh: HashSet[Triangle]) { def updateNeighbors(ccwPoint: Point, cwPoint: Point, triangle: Triangle, mesh: HashSet[Triangle]) {
@ -47,14 +50,11 @@ class Triangle(val points: Array[Point], val neighbors: Array[Triangle]) {
neighbors(0) = triangle neighbors(0) = triangle
else if((ccwPoint == points(0) && cwPoint == points(2)) || (ccwPoint == points(2) && cwPoint == points(0))) else if((ccwPoint == points(0) && cwPoint == points(2)) || (ccwPoint == points(2) && cwPoint == points(0)))
neighbors(1) = triangle neighbors(1) = triangle
else if((ccwPoint == points(1) && cwPoint == points(0)) || (ccwPoint == points(0) && cwPoint == points(1))) else if((ccwPoint == points(0) && cwPoint == points(1)) || (ccwPoint == points(1) && cwPoint == points(0)))
neighbors(2) = triangle neighbors(2) = triangle
else { else {
mesh += this mesh += triangle
println("**********") //throw new Exception("Neighbor update error")
println(cwPoint + "," + ccwPoint)
printDebug
throw new Exception("neighbor error")
} }
} }
@ -223,4 +223,15 @@ class Triangle(val points: Array[Point], val neighbors: Array[Triangle]) {
ki = points(0) - points(2) ki = points(0) - points(2)
} }
// Mark edge as constrained
def markEdge(e: Segment) {
if((e.q == points(0) && e.p == points(1)) || (e.q == points(1) && e.p == points(0))) {
edges(2) = true
} else if ((e.q == points(0) && e.p == points(2)) || (e.q == points(2) && e.p == points(0))) {
edges(1) = true
} else {
edges(0) = true
}
}
} }