1
0
Fork 0

Do not generate region points for hole areas in triangulation.

This commit is contained in:
Ralf Gerlich 2010-01-23 10:13:20 +01:00 committed by Ralf Gerlich - FlightGear
parent 1ad2b2e0e9
commit 95f595d730
2 changed files with 28 additions and 24 deletions

View file

@ -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;
}

View file

@ -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,6 +388,7 @@ int TGTriangle::run_triangulate( double angle, const int pass ) {
// region list
in.numberofregions = 0;
for ( i = 0; i < TG_MAX_AREA_TYPES; ++i ) {
if ( ! is_hole_area( i ) ) {
poly_list_iterator h_current, h_last;
h_current = polylist[i].begin();
h_last = polylist[i].end();
@ -400,10 +401,12 @@ 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 ) {
if ( ! is_hole_area( i ) ) {
poly_list_iterator h_current, h_last;
h_current = polylist[(int)i].begin();
h_last = polylist[(int)i].end();
@ -422,6 +425,7 @@ int TGTriangle::run_triangulate( double angle, const int pass ) {
}
}
}
}
// prep the output structures
out.pointlist = (REAL *) NULL; // Not needed if -N switch used.