- Ifc: add heuristic to detect remaining, unwanted "crossing caps" and to drop them silently. Testing this on some larger files, it typically reduces artifacts due to z-fighting on lower window caps.

pull/16/merge
Alexander Gessler 2013-01-21 22:27:48 +01:00
parent d20126f7a1
commit fcf86f1e0a
1 changed files with 36 additions and 2 deletions

View File

@ -1573,7 +1573,7 @@ void FindBorderContours(ContourVector::iterator current)
last_proj_point = proj_point; last_proj_point = proj_point;
} }
// handle first segment // handle last segment
if (outer_border && start_on_outer_border) { if (outer_border && start_on_outer_border) {
const IfcVector2& proj_point = *cbegin; const IfcVector2& proj_point = *cbegin;
if (fabs((proj_point.x - last_proj_point.x) * (proj_point.y - last_proj_point.y)) < dot_point_epsilon) { if (fabs((proj_point.x - last_proj_point.x) * (proj_point.y - last_proj_point.y)) < dot_point_epsilon) {
@ -1582,6 +1582,40 @@ void FindBorderContours(ContourVector::iterator current)
} }
} }
// ------------------------------------------------------------------------------------------------
bool LikelyDiagonal(IfcVector2 vdelta)
{
vdelta.x = fabs(vdelta.x);
vdelta.y = fabs(vdelta.y);
return (fabs(vdelta.x-vdelta.y) < 0.8 * std::max(vdelta.x, vdelta.y));
}
// ------------------------------------------------------------------------------------------------
void FindLikelyCrossingLines(ContourVector::iterator current)
{
SkipList& skiplist = (*current).skiplist;
IfcVector2 last_proj_point;
const Contour::const_iterator cbegin = (*current).contour.begin(), cend = (*current).contour.end();
for (Contour::const_iterator cit = cbegin; cit != cend; ++cit) {
const IfcVector2& proj_point = *cit;
if (cit != cbegin) {
IfcVector2 vdelta = proj_point - last_proj_point;
if (LikelyDiagonal(vdelta)) {
skiplist[std::distance(cbegin, cit) - 1] = true;
}
}
last_proj_point = proj_point;
}
// handle last segment
if (LikelyDiagonal(*cbegin - last_proj_point)) {
skiplist[skiplist.size()-1] = true;
}
}
// ------------------------------------------------------------------------------------------------ // ------------------------------------------------------------------------------------------------
void CloseWindows(ContourVector& contours, void CloseWindows(ContourVector& contours,
const IfcMatrix4& minv, const IfcMatrix4& minv,
@ -1621,6 +1655,7 @@ void CloseWindows(ContourVector& contours,
FindAdjacentContours(it, contours); FindAdjacentContours(it, contours);
FindBorderContours(it); FindBorderContours(it);
FindLikelyCrossingLines(it);
ai_assert((*it).skiplist.size() == (*it).contour.size()); ai_assert((*it).skiplist.size() == (*it).contour.size());
@ -2003,7 +2038,6 @@ bool GenerateOpenings(std::vector<TempOpening>& openings,
if (poly.size() > 1) { if (poly.size() > 1) {
return TryAddOpenings_Poly2Tri(openings, nors, curmesh); return TryAddOpenings_Poly2Tri(openings, nors, curmesh);
break;
} }
else if (poly.size() == 0) { else if (poly.size() == 0) {
IFCImporter::LogWarn("ignoring duplicate opening"); IFCImporter::LogWarn("ignoring duplicate opening");