From 95f595d730f891bc3f5c88070c9d8d24b9d8d55b Mon Sep 17 00:00:00 2001 From: Ralf Gerlich Date: Sat, 23 Jan 2010 10:13:20 +0100 Subject: [PATCH] Do not generate region points for hole areas in triangulation. --- src/BuildTiles/Clipper/priorities.cxx | 2 +- src/BuildTiles/Triangulate/triangle.cxx | 50 +++++++++++++------------ 2 files changed, 28 insertions(+), 24 deletions(-) diff --git a/src/BuildTiles/Clipper/priorities.cxx b/src/BuildTiles/Clipper/priorities.cxx index f3189ef9..63b42b19 100644 --- a/src/BuildTiles/Clipper/priorities.cxx +++ b/src/BuildTiles/Clipper/priorities.cxx @@ -101,7 +101,7 @@ int load_area_types( const std::string& filename ) { AreaType index = (AreaType)area_types.size(); area_types.push_back(descriptor); area_names[descriptor.name]=index; - SG_LOG(SG_GENERAL, SG_INFO, " " << descriptor.name << " " << descriptor.kind); + SG_LOG(SG_GENERAL, SG_INFO, " " << index << " " << descriptor.name << " " << descriptor.kind); in >> skipcomment; } diff --git a/src/BuildTiles/Triangulate/triangle.cxx b/src/BuildTiles/Triangulate/triangle.cxx index fa20d87d..eb397d85 100644 --- a/src/BuildTiles/Triangulate/triangle.cxx +++ b/src/BuildTiles/Triangulate/triangle.cxx @@ -369,11 +369,11 @@ int TGTriangle::run_triangulate( double angle, const int pass ) { in.holelist = (REAL *) malloc(in.numberofholes * 2 * sizeof(REAL)); + counter = 0; for ( i = 0; i < TG_MAX_AREA_TYPES; i++) { if ( is_hole_area( i ) ) { h_current = polylist[i].begin(); h_last = polylist[i].end(); - counter = 0; for ( ; h_current != h_last; ++h_current ) { poly = *h_current; for ( j = 0; j < poly.contours(); ++j ) { @@ -388,14 +388,16 @@ int TGTriangle::run_triangulate( double angle, const int pass ) { // region list in.numberofregions = 0; for ( i = 0; i < TG_MAX_AREA_TYPES; ++i ) { - poly_list_iterator h_current, h_last; - h_current = polylist[i].begin(); - h_last = polylist[i].end(); - for ( ; h_current != h_last; ++h_current ) { - poly = *h_current; - for ( j = 0; j < poly.contours(); ++j ) { - if ( ! poly.get_hole_flag( j ) ) { - ++in.numberofregions; + if ( ! is_hole_area( i ) ) { + poly_list_iterator h_current, h_last; + h_current = polylist[i].begin(); + h_last = polylist[i].end(); + for ( ; h_current != h_last; ++h_current ) { + poly = *h_current; + for ( j = 0; j < poly.contours(); ++j ) { + if ( ! poly.get_hole_flag( j ) ) { + ++in.numberofregions; + } } } } @@ -404,20 +406,22 @@ int TGTriangle::run_triangulate( double angle, const int pass ) { in.regionlist = (REAL *) malloc(in.numberofregions * 4 * sizeof(REAL)); counter = 0; for ( i = 0; i < TG_MAX_AREA_TYPES; ++i ) { - poly_list_iterator h_current, h_last; - h_current = polylist[(int)i].begin(); - h_last = polylist[(int)i].end(); - for ( ; h_current != h_last; ++h_current ) { - poly = *h_current; - for ( j = 0; j < poly.contours(); ++j ) { - if ( ! poly.get_hole_flag( j ) ) { - p = poly.get_point_inside( j ); - cout << "Region point = " << p << endl; - in.regionlist[counter++] = p.x(); // x coord - in.regionlist[counter++] = p.y(); // y coord - in.regionlist[counter++] = i; // region attribute - in.regionlist[counter++] = -1.0; // area constraint - // (unused) + if ( ! is_hole_area( i ) ) { + poly_list_iterator h_current, h_last; + h_current = polylist[(int)i].begin(); + h_last = polylist[(int)i].end(); + for ( ; h_current != h_last; ++h_current ) { + poly = *h_current; + for ( j = 0; j < poly.contours(); ++j ) { + if ( ! poly.get_hole_flag( j ) ) { + p = poly.get_point_inside( j ); + cout << "Region point = " << p << endl; + in.regionlist[counter++] = p.x(); // x coord + in.regionlist[counter++] = p.y(); // y coord + in.regionlist[counter++] = i; // region attribute + in.regionlist[counter++] = -1.0; // area constraint + // (unused) + } } } }