mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2024-12-27 09:50:34 +05:00
1151 lines
30 KiB
C++
1151 lines
30 KiB
C++
// Copyright (C) 2007-2013 CEA/DEN, EDF R&D, OPEN CASCADE
|
|
//
|
|
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
|
|
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
|
|
//
|
|
// This library is free software; you can redistribute it and/or
|
|
// modify it under the terms of the GNU Lesser General Public
|
|
// License as published by the Free Software Foundation; either
|
|
// version 2.1 of the License.
|
|
//
|
|
// This library is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
// Lesser General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Lesser General Public
|
|
// License along with this library; if not, write to the Free Software
|
|
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
//
|
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
|
//
|
|
// File: GEOMAlgo_GetInPlace.cxx
|
|
// Created:
|
|
// Author: Peter KURNEV
|
|
|
|
#include <GEOMAlgo_GetInPlace.hxx>
|
|
|
|
|
|
#include <NCollection_UBTreeFiller.hxx>
|
|
|
|
#include <Bnd_Box.hxx>
|
|
#include <gp_Pnt.hxx>
|
|
|
|
#include <TColStd_ListOfInteger.hxx>
|
|
#include <TColStd_ListIteratorOfListOfInteger.hxx>
|
|
|
|
#include <TopAbs_ShapeEnum.hxx>
|
|
|
|
#include <TopoDS_Iterator.hxx>
|
|
#include <TopoDS_Shape.hxx>
|
|
#include <TopoDS_Vertex.hxx>
|
|
#include <TopoDS_Edge.hxx>
|
|
#include <TopoDS_Face.hxx>
|
|
#include <TopoDS_Compound.hxx>
|
|
|
|
#include <BRep_Tool.hxx>
|
|
#include <BRep_Builder.hxx>
|
|
|
|
#include <BRepBndLib.hxx>
|
|
|
|
#include <TopExp.hxx>
|
|
|
|
#include <TopTools_IndexedMapOfShape.hxx>
|
|
#include <TopTools_ListOfShape.hxx>
|
|
#include <TopTools_DataMapOfShapeListOfShape.hxx>
|
|
#include <TopTools_DataMapIteratorOfDataMapOfShapeListOfShape.hxx>
|
|
#include <TopTools_ListIteratorOfListOfShape.hxx>
|
|
#include <TopTools_MapOfShape.hxx>
|
|
#include <TopTools_MapIteratorOfMapOfShape.hxx>
|
|
|
|
#include <GEOMAlgo_BoxBndTree.hxx>
|
|
#include <GEOMAlgo_CoupleOfShapes.hxx>
|
|
|
|
|
|
static
|
|
void MapBRepShapes(const TopoDS_Shape& aS,
|
|
TopTools_IndexedMapOfShape& aM);
|
|
|
|
|
|
//=======================================================================
|
|
//function : GEOMAlgo_GetInPlace
|
|
//purpose :
|
|
//=======================================================================
|
|
GEOMAlgo_GetInPlace::GEOMAlgo_GetInPlace()
|
|
:
|
|
GEOMAlgo_GluerAlgo(),
|
|
GEOMAlgo_Algo()
|
|
{
|
|
myTolerance=0.0001;
|
|
myTolMass=0.0001;
|
|
myTolCG=0.0001;
|
|
myFound=Standard_False;
|
|
myCheckGeometry=Standard_True;
|
|
}
|
|
//=======================================================================
|
|
//function : ~
|
|
//purpose :
|
|
//=======================================================================
|
|
GEOMAlgo_GetInPlace::~GEOMAlgo_GetInPlace()
|
|
{
|
|
}
|
|
//=======================================================================
|
|
//function : SetTolMass
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::SetTolMass(const Standard_Real theTol)
|
|
{
|
|
myTolMass=theTol;
|
|
}
|
|
//=======================================================================
|
|
//function : TolMass
|
|
//purpose :
|
|
//=======================================================================
|
|
Standard_Real GEOMAlgo_GetInPlace::TolMass()const
|
|
{
|
|
return myTolMass;
|
|
}
|
|
//=======================================================================
|
|
//function : SetTolCG
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::SetTolCG(const Standard_Real theTol)
|
|
{
|
|
myTolCG=theTol;
|
|
}
|
|
//=======================================================================
|
|
//function : TolCG
|
|
//purpose :
|
|
//=======================================================================
|
|
Standard_Real GEOMAlgo_GetInPlace::TolCG()const
|
|
{
|
|
return myTolCG;
|
|
}
|
|
//=======================================================================
|
|
//function : IsFound
|
|
//purpose :
|
|
//=======================================================================
|
|
Standard_Boolean GEOMAlgo_GetInPlace::IsFound()const
|
|
{
|
|
return myFound;
|
|
}
|
|
//=======================================================================
|
|
//function : SetShapeWhere
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::SetShapeWhere(const TopoDS_Shape& theShape)
|
|
{
|
|
myShapeWhere=theShape;
|
|
}
|
|
//=======================================================================
|
|
//function : ShapeWhere
|
|
//purpose :
|
|
//=======================================================================
|
|
const TopoDS_Shape& GEOMAlgo_GetInPlace::ShapeWhere()const
|
|
{
|
|
return myShapeWhere;
|
|
}
|
|
//=======================================================================
|
|
//function : ShapesIn
|
|
//purpose :
|
|
//=======================================================================
|
|
const GEOMAlgo_DataMapOfShapeMapOfShape& GEOMAlgo_GetInPlace::ShapesIn()const
|
|
{
|
|
return myShapesIn;
|
|
}
|
|
//=======================================================================
|
|
//function : ShapesOn
|
|
//purpose :
|
|
//=======================================================================
|
|
const GEOMAlgo_DataMapOfShapeMapOfShape& GEOMAlgo_GetInPlace::ShapesOn()const
|
|
{
|
|
return myShapesOn;
|
|
}
|
|
//=======================================================================
|
|
//function : Clear
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::Clear()
|
|
{
|
|
myErrorStatus=0;
|
|
myWarningStatus=0;
|
|
//
|
|
GEOMAlgo_GluerAlgo::Clear();
|
|
myIterator.Clear();
|
|
myShapesIn.Clear();
|
|
myShapesOn.Clear();
|
|
myMapShapePnt.Clear();
|
|
}
|
|
//=======================================================================
|
|
//function : Perform
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::Perform()
|
|
{
|
|
myFound=Standard_False;
|
|
myErrorStatus=0;
|
|
myWarningStatus=0;
|
|
//
|
|
Clear();
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
//
|
|
CheckData();
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
//
|
|
// Initialize the context
|
|
GEOMAlgo_GluerAlgo::Perform();
|
|
//
|
|
Intersect();
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
//
|
|
PerformVV();
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
//
|
|
FillEdgesOn();
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
//
|
|
PerformVE();
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
//
|
|
PerformEE();
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
//
|
|
PerformVF();
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
//
|
|
FillFacesOn();
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
//
|
|
PerformEF();
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
//
|
|
PerformFF();
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
//
|
|
FillSolidsOn();
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
//
|
|
PerformZF();
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
//
|
|
PerformZZ();
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
//
|
|
FillImages();
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
//
|
|
CheckGProps();
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
}
|
|
//=======================================================================
|
|
//function : CheckData
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::CheckData()
|
|
{
|
|
myErrorStatus=0;
|
|
myWarningStatus=0;
|
|
//
|
|
if (myArgument.IsNull()) {
|
|
myErrorStatus=2;
|
|
return;
|
|
}
|
|
//
|
|
if (myShapeWhere.IsNull()) {
|
|
myErrorStatus=3;
|
|
return;
|
|
}
|
|
}
|
|
//=======================================================================
|
|
//function : Intersect
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::Intersect()
|
|
{
|
|
Standard_Integer i, j, aNbS1, aNbS2, aNbSD;
|
|
TColStd_ListIteratorOfListOfInteger aItLI;
|
|
TopTools_IndexedMapOfShape aMS1, aMS2;
|
|
TopTools_DataMapOfShapeListOfShape aDMSLS;
|
|
TopTools_DataMapIteratorOfDataMapOfShapeListOfShape aItDMSLS;
|
|
TopTools_ListIteratorOfListOfShape aItLS;
|
|
GEOMAlgo_CoupleOfShapes aCS;
|
|
//
|
|
GEOMAlgo_BoxBndTreeSelector aSelector;
|
|
GEOMAlgo_BoxBndTree aBBTree;
|
|
NCollection_UBTreeFiller <Standard_Integer, Bnd_Box> aTreeFiller(aBBTree);
|
|
//
|
|
myErrorStatus=0;
|
|
myWarningStatus=0;
|
|
//
|
|
myIterator.Clear();
|
|
//
|
|
MapBRepShapes(myArgument, aMS1);
|
|
aNbS1=aMS1.Extent();
|
|
for (i=1; i<=aNbS1; ++i) {
|
|
Bnd_Box aBox1;
|
|
//
|
|
const TopoDS_Shape& aS1=aMS1(i);
|
|
BRepBndLib::Add(aS1, aBox1);
|
|
//modified by NIZNHY-PKV Fri Jun 10 08:20:03 2011f
|
|
//aBox1.SetGap(myTolerance);
|
|
aBox1.Enlarge(myTolerance);
|
|
//modified by NIZNHY-PKV Fri Jun 10 08:20:06 2011t
|
|
//
|
|
aTreeFiller.Add(i, aBox1);
|
|
}
|
|
//
|
|
aTreeFiller.Fill();
|
|
//
|
|
MapBRepShapes(myShapeWhere, aMS2);
|
|
aNbS2=aMS2.Extent();
|
|
for (j=1; j<=aNbS2; ++j) {
|
|
Bnd_Box aBox2;
|
|
//
|
|
const TopoDS_Shape& aS2=aMS2(j);
|
|
BRepBndLib::Add(aS2, aBox2);
|
|
//modified by NIZNHY-PKV Fri Jun 10 08:20:23 2011f
|
|
//aBox2.SetGap(myTolerance);
|
|
aBox2.Enlarge(myTolerance);
|
|
//modified by NIZNHY-PKV Fri Jun 10 08:20:25 2011t
|
|
//
|
|
aSelector.Clear();
|
|
aSelector.SetBox(aBox2);
|
|
aNbSD=aBBTree.Select(aSelector);
|
|
if (!aNbSD) {
|
|
continue; // it should not be
|
|
}
|
|
//
|
|
const TColStd_ListOfInteger& aLI=aSelector.Indices();
|
|
aItLI.Initialize(aLI);
|
|
for (; aItLI.More(); aItLI.Next()) {
|
|
i=aItLI.Value();
|
|
const TopoDS_Shape& aS1=aMS1(i);
|
|
//
|
|
if (aDMSLS.IsBound(aS1)) {
|
|
TopTools_ListOfShape& aLS=aDMSLS.ChangeFind(aS1);
|
|
aLS.Append(aS2);
|
|
}
|
|
else {
|
|
TopTools_ListOfShape aLS;
|
|
//
|
|
aLS.Append(aS2);
|
|
aDMSLS.Bind(aS1, aLS);
|
|
}
|
|
}
|
|
}// for (j=1; j<=aNbS2; ++j) {
|
|
//
|
|
aItDMSLS.Initialize(aDMSLS);
|
|
for (; aItDMSLS.More(); aItDMSLS.Next()) {
|
|
const TopoDS_Shape& aS1=aItDMSLS.Key();
|
|
const TopTools_ListOfShape& aLS2=aItDMSLS.Value();
|
|
aCS.SetShape1(aS1);
|
|
aItLS.Initialize(aLS2);
|
|
for (; aItLS.More(); aItLS.Next()) {
|
|
const TopoDS_Shape& aS2=aItLS.Value();
|
|
aCS.SetShape2(aS2);
|
|
myIterator.AppendPair(aCS);
|
|
}
|
|
}
|
|
}
|
|
//=======================================================================
|
|
//function : PerformVV
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::PerformVV()
|
|
{
|
|
myErrorStatus=0;
|
|
myWarningStatus=0;
|
|
//
|
|
myIterator.Initialize(TopAbs_VERTEX, TopAbs_VERTEX);
|
|
for (; myIterator.More(); myIterator.Next()) {
|
|
const GEOMAlgo_CoupleOfShapes& aCS=myIterator.Value();
|
|
const TopoDS_Shape& aV1=aCS.Shape1();
|
|
const TopoDS_Shape& aV2=aCS.Shape2();
|
|
//
|
|
FillShapesOn(aV1, aV2);
|
|
}
|
|
}
|
|
//=======================================================================
|
|
//function : FillEdgesOn
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::FillEdgesOn()
|
|
{
|
|
Standard_Integer i, aNbE;
|
|
TopoDS_Iterator aIt;
|
|
TopTools_IndexedMapOfShape aME;
|
|
TopTools_MapIteratorOfMapOfShape aItMS;
|
|
//
|
|
TopExp::MapShapes(myArgument, TopAbs_EDGE, aME);
|
|
aNbE=aME.Extent();
|
|
for (i=1; i<=aNbE; ++i) {
|
|
const TopoDS_Edge& aE1=*((TopoDS_Edge*)&aME(i));
|
|
if (BRep_Tool::Degenerated(aE1)) {
|
|
continue;
|
|
}
|
|
//
|
|
aIt.Initialize(aE1);
|
|
for (; aIt.More(); aIt.Next()) {
|
|
const TopoDS_Shape& aV1=aIt.Value();
|
|
if (myShapesOn.IsBound(aV1)) {
|
|
const TopTools_MapOfShape& aMSOn=myShapesOn.Find(aV1);
|
|
//aNbSOn=aMSOn.Extent();
|
|
aItMS.Initialize(aMSOn);
|
|
for (; aItMS.More(); aItMS.Next()) {
|
|
const TopoDS_Shape& aV2=aItMS.Key();
|
|
FillShapesOn(aE1, aV2);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
//=======================================================================
|
|
//function : PerformVE
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::PerformVE()
|
|
{
|
|
Standard_Boolean bFound;
|
|
//
|
|
myErrorStatus=0;
|
|
myWarningStatus=0;
|
|
//
|
|
// 2. Fill Shapes In
|
|
myIterator.Initialize(TopAbs_EDGE, TopAbs_VERTEX);
|
|
for (; myIterator.More(); myIterator.Next()) {
|
|
const GEOMAlgo_CoupleOfShapes& aCS=myIterator.Value();
|
|
const TopoDS_Shape& aE1=aCS.Shape1();
|
|
const TopoDS_Shape& aV2=aCS.Shape2();
|
|
//
|
|
if (myShapesOn.IsBound(aE1)) {
|
|
const TopTools_MapOfShape& aMSOn=myShapesOn.Find(aE1);
|
|
if (aMSOn.Contains(aV2)) {
|
|
continue;
|
|
}
|
|
}
|
|
//
|
|
bFound=CheckCoincidence(aE1, aV2);
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
if (bFound) {
|
|
FillShapesIn(aE1, aV2);
|
|
}
|
|
}
|
|
}
|
|
//=======================================================================
|
|
//function : PerformEE
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::PerformEE()
|
|
{
|
|
Standard_Boolean bHasOn, bHasIn, bFound;
|
|
TopoDS_Iterator aIt;
|
|
TopTools_MapOfShape aMSX;
|
|
//
|
|
myErrorStatus=0;
|
|
myWarningStatus=0;
|
|
//
|
|
myIterator.Initialize(TopAbs_EDGE, TopAbs_EDGE);
|
|
for (; myIterator.More(); myIterator.Next()) {
|
|
const GEOMAlgo_CoupleOfShapes& aCS=myIterator.Value();
|
|
const TopoDS_Shape& aE1=aCS.Shape1();
|
|
const TopoDS_Shape& aE2=aCS.Shape2();
|
|
//
|
|
bHasOn=myShapesOn.IsBound(aE1);
|
|
bHasIn=myShapesIn.IsBound(aE1);
|
|
const TopTools_MapOfShape& aMSOn=(bHasOn) ? myShapesOn.Find(aE1) : aMSX;
|
|
const TopTools_MapOfShape& aMSIn=(bHasIn) ? myShapesIn.Find(aE1) : aMSX;
|
|
//
|
|
bFound=Standard_True;
|
|
aIt.Initialize(aE2);
|
|
for (; aIt.More(); aIt.Next()) {
|
|
const TopoDS_Shape& aV2=aIt.Value();
|
|
if (!(aMSOn.Contains(aV2) || aMSIn.Contains(aV2))) {
|
|
bFound=!bFound;
|
|
break;
|
|
}
|
|
}
|
|
if (!bFound) {
|
|
continue;
|
|
}
|
|
//
|
|
bFound=CheckCoincidence(aE1, aE2);
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
if (bFound) {
|
|
FillShapesIn(aE1, aE2);
|
|
}
|
|
}
|
|
}
|
|
//=======================================================================
|
|
//function : PerformVF
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::PerformVF()
|
|
{
|
|
Standard_Boolean bHasOn, bHasIn, bFound;
|
|
Standard_Integer i, aNbE;
|
|
TopTools_MapOfShape aMSX;
|
|
TopTools_IndexedMapOfShape aME;
|
|
//
|
|
myErrorStatus=0;
|
|
myWarningStatus=0;
|
|
//
|
|
myIterator.Initialize(TopAbs_FACE, TopAbs_VERTEX);
|
|
for (; myIterator.More(); myIterator.Next()) {
|
|
const GEOMAlgo_CoupleOfShapes& aCS=myIterator.Value();
|
|
const TopoDS_Shape& aF1=aCS.Shape1();
|
|
const TopoDS_Shape& aV2=aCS.Shape2();
|
|
//
|
|
aME.Clear();
|
|
TopExp::MapShapes(aF1, TopAbs_EDGE, aME);
|
|
//
|
|
bFound=Standard_False;
|
|
aNbE=aME.Extent();
|
|
for (i=1; i<=aNbE; ++i) {
|
|
const TopoDS_Edge& aE1=*((TopoDS_Edge*)&aME(i));
|
|
if (BRep_Tool::Degenerated(aE1)) {
|
|
continue;
|
|
}
|
|
//
|
|
bHasOn=myShapesOn.IsBound(aE1);
|
|
bHasIn=myShapesIn.IsBound(aE1);
|
|
const TopTools_MapOfShape& aMSOn=(bHasOn) ? myShapesOn.Find(aE1) : aMSX;
|
|
const TopTools_MapOfShape& aMSIn=(bHasIn) ? myShapesIn.Find(aE1) : aMSX;
|
|
bFound= (aMSOn.Contains(aV2) || aMSIn.Contains(aV2));
|
|
if (bFound) {
|
|
break;
|
|
}
|
|
}
|
|
//
|
|
if (bFound) {
|
|
continue;
|
|
}
|
|
//
|
|
bFound=CheckCoincidence(aF1, aV2);
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
if (bFound) {
|
|
FillShapesIn(aF1, aV2);
|
|
}
|
|
}
|
|
}
|
|
//=======================================================================
|
|
//function : FillFacesOn
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::FillFacesOn()
|
|
{
|
|
Standard_Integer i, j, aNbF, aNbE;
|
|
TopoDS_Iterator aIt;
|
|
TopTools_IndexedMapOfShape aMF, aME;
|
|
TopTools_MapIteratorOfMapOfShape aItMS;
|
|
//
|
|
TopExp::MapShapes(myArgument, TopAbs_FACE, aMF);
|
|
aNbF=aMF.Extent();
|
|
for (i=1; i<=aNbF; ++i) {
|
|
const TopoDS_Face& aF1=*((TopoDS_Face*)&aMF(i));
|
|
//
|
|
aME.Clear();
|
|
TopExp::MapShapes(aF1, TopAbs_EDGE, aME);
|
|
aNbE=aME.Extent();
|
|
for (j=1; j<=aNbE; ++j) {
|
|
const TopoDS_Edge& aE1=*((TopoDS_Edge*)&aME(j));
|
|
if (BRep_Tool::Degenerated(aE1)) {
|
|
continue;
|
|
}
|
|
//
|
|
if (myShapesOn.IsBound(aE1)) {
|
|
const TopTools_MapOfShape& aMSOn=myShapesOn.Find(aE1);
|
|
aItMS.Initialize(aMSOn);
|
|
for (; aItMS.More(); aItMS.Next()) {
|
|
const TopoDS_Shape& aS2=aItMS.Key();
|
|
FillShapesOn(aF1, aS2);
|
|
}
|
|
}
|
|
//
|
|
if (myShapesIn.IsBound(aE1)) {
|
|
const TopTools_MapOfShape& aMSIn=myShapesIn.Find(aE1);
|
|
aItMS.Initialize(aMSIn);
|
|
for (; aItMS.More(); aItMS.Next()) {
|
|
const TopoDS_Shape& aS2=aItMS.Key();
|
|
FillShapesOn(aF1, aS2);
|
|
}
|
|
}
|
|
}//for (j=1; j<=aNbE; ++j) {
|
|
}//for (i=1; i<=aNbF; ++i) {
|
|
}
|
|
//=======================================================================
|
|
//function : PerformEF
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::PerformEF()
|
|
{
|
|
Standard_Boolean bFound, bHasOnF, bHasInF;
|
|
TopoDS_Iterator aIt;
|
|
TopTools_MapOfShape aMSX;
|
|
//
|
|
myErrorStatus=0;
|
|
myWarningStatus=0;
|
|
//
|
|
myIterator.Initialize(TopAbs_FACE, TopAbs_EDGE);
|
|
for (; myIterator.More(); myIterator.Next()) {
|
|
const GEOMAlgo_CoupleOfShapes& aCS=myIterator.Value();
|
|
const TopoDS_Shape& aF1=aCS.Shape1();
|
|
const TopoDS_Shape& aE2=aCS.Shape2();
|
|
//
|
|
// 1.
|
|
bHasOnF=myShapesOn.IsBound(aF1);
|
|
const TopTools_MapOfShape& aMSOnF=(bHasOnF) ? myShapesOn.Find(aF1) : aMSX;
|
|
bFound=aMSOnF.Contains(aE2);
|
|
if (bFound) {
|
|
continue;
|
|
}
|
|
//
|
|
// 2.
|
|
bHasInF=myShapesIn.IsBound(aF1);
|
|
const TopTools_MapOfShape& aMSInF=(bHasInF) ? myShapesIn.Find(aF1) : aMSX;
|
|
//
|
|
aIt.Initialize(aE2);
|
|
for (; aIt.More(); aIt.Next()) {
|
|
const TopoDS_Shape& aV2=aIt.Value();
|
|
bFound=(aMSOnF.Contains(aV2) || aMSInF.Contains(aV2));
|
|
if (!bFound) {
|
|
break;
|
|
}
|
|
}
|
|
if (!bFound) {
|
|
continue;
|
|
}
|
|
//------------------------------
|
|
bFound=CheckCoincidence(aF1, aE2);
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
if (bFound) {
|
|
FillShapesIn(aF1, aE2);
|
|
}
|
|
}
|
|
}
|
|
//=======================================================================
|
|
//function : PerformFF
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::PerformFF()
|
|
{
|
|
Standard_Boolean bFound, bHasOnF, bHasInF;
|
|
Standard_Integer i, aNbS2;
|
|
TopTools_MapOfShape aMSX;
|
|
TopTools_IndexedMapOfShape aMS2;
|
|
//
|
|
myErrorStatus=0;
|
|
myWarningStatus=0;
|
|
//
|
|
myIterator.Initialize(TopAbs_FACE, TopAbs_FACE);
|
|
for (; myIterator.More(); myIterator.Next()) {
|
|
const GEOMAlgo_CoupleOfShapes& aCS=myIterator.Value();
|
|
const TopoDS_Shape& aF1=aCS.Shape1();
|
|
const TopoDS_Shape& aF2=aCS.Shape2();
|
|
//
|
|
bHasOnF=myShapesOn.IsBound(aF1);
|
|
const TopTools_MapOfShape& aMSOnF=(bHasOnF) ? myShapesOn.Find(aF1) : aMSX;
|
|
//
|
|
bHasInF=myShapesIn.IsBound(aF1);
|
|
const TopTools_MapOfShape& aMSInF=(bHasInF) ? myShapesIn.Find(aF1) : aMSX;
|
|
//
|
|
aMS2.Clear();
|
|
MapBRepShapes(aF2, aMS2);
|
|
//
|
|
bFound=Standard_False;
|
|
aNbS2=aMS2.Extent();
|
|
for (i=1; i<=aNbS2; ++i) {
|
|
const TopoDS_Shape& aS2=aMS2(i);
|
|
if (aS2.IsSame(aF2)) {
|
|
continue;
|
|
}
|
|
bFound=(aMSOnF.Contains(aS2) || aMSInF.Contains(aS2));
|
|
if (!bFound) {
|
|
break;
|
|
}
|
|
}
|
|
if (!bFound) {
|
|
continue;
|
|
}
|
|
//
|
|
bFound=CheckCoincidence(aF1, aF2);
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
if (bFound) {
|
|
FillShapesIn(aF1, aF2);
|
|
}
|
|
}
|
|
}
|
|
//=======================================================================
|
|
//function : FillSolidsOn
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::FillSolidsOn()
|
|
{
|
|
Standard_Integer i, j, aNbS, aNbF;
|
|
TopTools_IndexedMapOfShape aMS, aMF;
|
|
TopTools_MapIteratorOfMapOfShape aItMS;
|
|
//
|
|
TopExp::MapShapes(myArgument, TopAbs_SOLID, aMS);
|
|
//
|
|
aNbS=aMS.Extent();
|
|
for (i=1; i<=aNbS; ++i) {
|
|
const TopoDS_Shape& aSD1=aMS(i);
|
|
//
|
|
aMF.Clear();
|
|
TopExp::MapShapes(aSD1, TopAbs_FACE, aMF);
|
|
aNbF=aMF.Extent();
|
|
for (j=1; j<=aNbF; ++j) {
|
|
const TopoDS_Shape& aF1=aMF(j);
|
|
//
|
|
if (myShapesOn.IsBound(aF1)) {
|
|
const TopTools_MapOfShape& aMSOn=myShapesOn.Find(aF1);
|
|
aItMS.Initialize(aMSOn);
|
|
for (; aItMS.More(); aItMS.Next()) {
|
|
const TopoDS_Shape& aS2=aItMS.Key();
|
|
FillShapesOn(aSD1, aS2);
|
|
}
|
|
}
|
|
//
|
|
if (myShapesIn.IsBound(aF1)) {
|
|
const TopTools_MapOfShape& aMSIn=myShapesIn.Find(aF1);
|
|
aItMS.Initialize(aMSIn);
|
|
for (; aItMS.More(); aItMS.Next()) {
|
|
const TopoDS_Shape& aS2=aItMS.Key();
|
|
FillShapesOn(aSD1, aS2);
|
|
}
|
|
}
|
|
}//for (j=1; j<=aNbF; ++j) {
|
|
}//for (i=1; i<=aNbS; ++i) {
|
|
}
|
|
//=======================================================================
|
|
//function : PerformZF
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::PerformZF()
|
|
{
|
|
Standard_Boolean bFound, bHasOnF;
|
|
TopTools_MapOfShape aMSX;
|
|
//
|
|
myErrorStatus=0;
|
|
myWarningStatus=0;
|
|
//
|
|
myIterator.Initialize(TopAbs_SOLID, TopAbs_FACE);
|
|
for (; myIterator.More(); myIterator.Next()) {
|
|
const GEOMAlgo_CoupleOfShapes& aCS=myIterator.Value();
|
|
const TopoDS_Shape& aSo1=aCS.Shape1();
|
|
const TopoDS_Shape& aF2=aCS.Shape2();
|
|
//
|
|
bHasOnF=myShapesOn.IsBound(aSo1);
|
|
const TopTools_MapOfShape& aMSOnF=(bHasOnF) ? myShapesOn.Find(aSo1) : aMSX;
|
|
bFound=aMSOnF.Contains(aF2);
|
|
if (bFound) {
|
|
continue;
|
|
}
|
|
//------------------------------
|
|
bFound=CheckCoincidence(aSo1, aF2);
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
if (bFound) {
|
|
FillShapesIn(aSo1, aF2);
|
|
}
|
|
}
|
|
}
|
|
//=======================================================================
|
|
//function : PerformZZ
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::PerformZZ()
|
|
{
|
|
Standard_Boolean bFound, bHasOn, bHasIn;
|
|
Standard_Integer i, aNbS2, iCntOn, iCntIn, iCntOut;
|
|
TopTools_MapOfShape aMSX;
|
|
TopTools_IndexedMapOfShape aMS2;
|
|
//
|
|
myErrorStatus=0;
|
|
myWarningStatus=0;
|
|
//
|
|
myIterator.Initialize(TopAbs_SOLID, TopAbs_SOLID);
|
|
for (; myIterator.More(); myIterator.Next()) {
|
|
const GEOMAlgo_CoupleOfShapes& aCS=myIterator.Value();
|
|
const TopoDS_Shape& aSo1=aCS.Shape1();
|
|
const TopoDS_Shape& aSo2=aCS.Shape2();
|
|
//
|
|
bHasOn=myShapesOn.IsBound(aSo1);
|
|
const TopTools_MapOfShape& aMSOn=(bHasOn) ? myShapesOn.Find(aSo1) : aMSX;
|
|
//
|
|
bHasIn=myShapesIn.IsBound(aSo1);
|
|
const TopTools_MapOfShape& aMSIn=(bHasIn) ? myShapesIn.Find(aSo1) : aMSX;
|
|
//
|
|
aMS2.Clear();
|
|
TopExp::MapShapes(aSo2, TopAbs_FACE, aMS2);
|
|
//
|
|
iCntIn=0;
|
|
iCntOn=0;
|
|
iCntOut=0;
|
|
bFound=Standard_False;
|
|
aNbS2=aMS2.Extent();
|
|
for (i=1; i<=aNbS2; ++i) {
|
|
const TopoDS_Shape& aF2=aMS2(i);
|
|
//
|
|
if (aMSIn.Contains(aF2)) {
|
|
++iCntIn;
|
|
bFound=Standard_True;
|
|
break;
|
|
}
|
|
else if (!aMSOn.Contains(aF2)) {
|
|
++iCntOut;
|
|
bFound=Standard_False;// out
|
|
break;
|
|
}
|
|
else {
|
|
++iCntOn; //on
|
|
}
|
|
}
|
|
//
|
|
if (!bFound && iCntOut) {
|
|
continue;
|
|
}
|
|
//
|
|
if (!iCntIn) {
|
|
bFound=CheckCoincidence(aSo1, aSo2);
|
|
if (myErrorStatus) {
|
|
return;
|
|
}
|
|
}
|
|
if (bFound) {
|
|
FillShapesIn(aSo1, aSo2);
|
|
}
|
|
}// for (; myIterator.More(); myIterator.Next()) {
|
|
}
|
|
//=======================================================================
|
|
//function : FillImages
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::FillImages()
|
|
{
|
|
Standard_Integer i, aNbS, aNbSx, aNbSi;
|
|
TopAbs_ShapeEnum aType;
|
|
TopoDS_Iterator aIt;
|
|
TopTools_ListOfShape aLSx;
|
|
TopTools_ListIteratorOfListOfShape aItLS;
|
|
TopTools_IndexedMapOfShape aMS;
|
|
TopTools_MapIteratorOfMapOfShape aItMS;
|
|
//
|
|
myErrorStatus=0;
|
|
myWarningStatus=0;
|
|
//
|
|
myImages.Clear();
|
|
//
|
|
// 1. Vertices
|
|
aMS.Clear();
|
|
TopExp::MapShapes(myArgument, TopAbs_VERTEX, aMS);
|
|
aNbS=aMS.Extent();
|
|
for (i=1; i<=aNbS; ++i) {
|
|
const TopoDS_Shape& aV=aMS(i);
|
|
if (myShapesOn.IsBound(aV)) {
|
|
const TopTools_MapOfShape& aMSx=myShapesOn.Find(aV);
|
|
aNbSx=aMSx.Extent();
|
|
//
|
|
aLSx.Clear();
|
|
aItMS.Initialize(aMSx);
|
|
for (; aItMS.More(); aItMS.Next()) {
|
|
const TopoDS_Shape& aVx=aItMS.Key();
|
|
aLSx.Append(aVx);
|
|
}
|
|
//
|
|
myImages.Bind(aV, aLSx);
|
|
}
|
|
}
|
|
//
|
|
// 2. Edges
|
|
aMS.Clear();
|
|
TopExp::MapShapes(myArgument, TopAbs_EDGE, aMS);
|
|
aNbS=aMS.Extent();
|
|
for (i=1; i<=aNbS; ++i) {
|
|
const TopoDS_Shape& aE=aMS(i);
|
|
if (myShapesIn.IsBound(aE)) {
|
|
const TopTools_MapOfShape& aMSx=myShapesIn.Find(aE);
|
|
aNbSx=aMSx.Extent();
|
|
//
|
|
aLSx.Clear();
|
|
aItMS.Initialize(aMSx);
|
|
for (; aItMS.More(); aItMS.Next()) {
|
|
const TopoDS_Shape& aEx=aItMS.Key();
|
|
aType=aEx.ShapeType();
|
|
if (aType==TopAbs_EDGE){
|
|
aLSx.Append(aEx);
|
|
}
|
|
}
|
|
//
|
|
myImages.Bind(aE, aLSx);
|
|
}
|
|
}
|
|
//
|
|
// 3. Wires
|
|
aMS.Clear();
|
|
TopExp::MapShapes(myArgument, TopAbs_WIRE, aMS);
|
|
aNbS=aMS.Extent();
|
|
for (i=1; i<=aNbS; ++i) {
|
|
const TopoDS_Shape& aW=aMS(i);
|
|
aLSx.Clear();
|
|
aIt.Initialize(aW);
|
|
for(; aIt.More(); aIt.Next()) {
|
|
const TopoDS_Shape& aE=aIt.Value();
|
|
if (myImages.IsBound(aE)) {
|
|
const TopTools_ListOfShape& aLSi=myImages.Find(aE);
|
|
aNbSi=aLSi.Extent();
|
|
//
|
|
aItLS.Initialize(aLSi);
|
|
for (; aItLS.More(); aItLS.Next()) {
|
|
const TopoDS_Shape& aEi=aItLS.Value();
|
|
aLSx.Append(aEi);
|
|
}
|
|
}
|
|
}
|
|
myImages.Bind(aW, aLSx);
|
|
}
|
|
//
|
|
// 4. Faces
|
|
aMS.Clear();
|
|
TopExp::MapShapes(myArgument, TopAbs_FACE, aMS);
|
|
aNbS=aMS.Extent();
|
|
for (i=1; i<=aNbS; ++i) {
|
|
const TopoDS_Shape& aF=aMS(i);
|
|
if (myShapesIn.IsBound(aF)) {
|
|
const TopTools_MapOfShape& aMSx=myShapesIn.Find(aF);
|
|
aNbSx=aMSx.Extent();
|
|
//
|
|
aLSx.Clear();
|
|
aItMS.Initialize(aMSx);
|
|
for (; aItMS.More(); aItMS.Next()) {
|
|
const TopoDS_Shape& aFx=aItMS.Key();
|
|
aType=aFx.ShapeType();
|
|
if (aType==TopAbs_FACE){
|
|
aLSx.Append(aFx);
|
|
}
|
|
}
|
|
//
|
|
myImages.Bind(aF, aLSx);
|
|
}
|
|
}
|
|
//
|
|
// 5. Shells
|
|
aMS.Clear();
|
|
TopExp::MapShapes(myArgument, TopAbs_SHELL, aMS);
|
|
aNbS=aMS.Extent();
|
|
for (i=1; i<=aNbS; ++i) {
|
|
const TopoDS_Shape& aSh=aMS(i);
|
|
aLSx.Clear();
|
|
aIt.Initialize(aSh);
|
|
for(; aIt.More(); aIt.Next()) {
|
|
const TopoDS_Shape& aF=aIt.Value();
|
|
if (myImages.IsBound(aF)) {
|
|
const TopTools_ListOfShape& aLSi=myImages.Find(aF);
|
|
aNbSi=aLSi.Extent();
|
|
//
|
|
aItLS.Initialize(aLSi);
|
|
for (; aItLS.More(); aItLS.Next()) {
|
|
const TopoDS_Shape& aFi=aItLS.Value();
|
|
aLSx.Append(aFi);
|
|
}
|
|
}
|
|
}
|
|
myImages.Bind(aSh, aLSx);
|
|
}
|
|
//
|
|
// 6. Solids
|
|
aMS.Clear();
|
|
TopExp::MapShapes(myArgument, TopAbs_SOLID, aMS);
|
|
aNbS=aMS.Extent();
|
|
for (i=1; i<=aNbS; ++i) {
|
|
const TopoDS_Shape& aZ=aMS(i);
|
|
if (myShapesIn.IsBound(aZ)) {
|
|
const TopTools_MapOfShape& aMSx=myShapesIn.Find(aZ);
|
|
aNbSx=aMSx.Extent();
|
|
//
|
|
aLSx.Clear();
|
|
aItMS.Initialize(aMSx);
|
|
for (; aItMS.More(); aItMS.Next()) {
|
|
const TopoDS_Shape& aZx=aItMS.Key();
|
|
aType=aZx.ShapeType();
|
|
if (aType==TopAbs_SOLID){
|
|
aLSx.Append(aZx);
|
|
}
|
|
}
|
|
//
|
|
myImages.Bind(aZ, aLSx);
|
|
}
|
|
}
|
|
//
|
|
// 7. CompSolids
|
|
aMS.Clear();
|
|
TopExp::MapShapes(myArgument, TopAbs_COMPSOLID, aMS);
|
|
aNbS=aMS.Extent();
|
|
for (i=1; i<=aNbS; ++i) {
|
|
const TopoDS_Shape& aCs=aMS(i);
|
|
aLSx.Clear();
|
|
aIt.Initialize(aCs);
|
|
for(; aIt.More(); aIt.Next()) {
|
|
const TopoDS_Shape& aZ=aIt.Value();
|
|
if (myImages.IsBound(aZ)) {
|
|
const TopTools_ListOfShape& aLSi=myImages.Find(aZ);
|
|
aNbSi=aLSi.Extent();
|
|
//
|
|
aItLS.Initialize(aLSi);
|
|
for (; aItLS.More(); aItLS.Next()) {
|
|
const TopoDS_Shape& aZi=aItLS.Value();
|
|
aLSx.Append(aZi);
|
|
}
|
|
}
|
|
}
|
|
myImages.Bind(aCs, aLSx);
|
|
}
|
|
//
|
|
// 8. Compounds
|
|
aType=myArgument.ShapeType();
|
|
if (aType==TopAbs_COMPOUND) {
|
|
FillImagesCompound(myArgument);
|
|
}
|
|
}
|
|
//=======================================================================
|
|
//function : FillImagesCompound
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::FillImagesCompound(const TopoDS_Shape& aS)
|
|
{
|
|
TopAbs_ShapeEnum aType;
|
|
TopoDS_Iterator aIt;
|
|
TopTools_ListOfShape aLSx;
|
|
TopTools_ListIteratorOfListOfShape aItLS;
|
|
//
|
|
aIt.Initialize(aS);
|
|
for(; aIt.More(); aIt.Next()) {
|
|
const TopoDS_Shape& aSx=aIt.Value();
|
|
aType=aSx.ShapeType();
|
|
//
|
|
if (aType==TopAbs_COMPOUND) {
|
|
FillImagesCompound(aSx);
|
|
}
|
|
//
|
|
if (myImages.IsBound(aSx)) {
|
|
const TopTools_ListOfShape& aLSi=myImages.Find(aSx);
|
|
aItLS.Initialize(aLSi);
|
|
for (; aItLS.More(); aItLS.Next()) {
|
|
const TopoDS_Shape& aSi=aItLS.Value();
|
|
aLSx.Append(aSi);
|
|
}
|
|
}
|
|
}
|
|
myImages.Bind(aS, aLSx);
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : FillShapesIn
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::FillShapesIn(const TopoDS_Shape& aS1,
|
|
const TopoDS_Shape& aS2)
|
|
{
|
|
if (myShapesIn.IsBound(aS1)) {
|
|
TopTools_MapOfShape& aMS=myShapesIn.ChangeFind(aS1);
|
|
aMS.Add(aS2);
|
|
}
|
|
else {
|
|
TopTools_MapOfShape aMS;
|
|
//
|
|
aMS.Add(aS2);
|
|
myShapesIn.Bind(aS1, aMS);
|
|
}
|
|
}
|
|
//=======================================================================
|
|
//function : FillShapesOn
|
|
//purpose :
|
|
//=======================================================================
|
|
void GEOMAlgo_GetInPlace::FillShapesOn(const TopoDS_Shape& aS1,
|
|
const TopoDS_Shape& aS2)
|
|
{
|
|
if (myShapesOn.IsBound(aS1)) {
|
|
TopTools_MapOfShape& aMS=myShapesOn.ChangeFind(aS1);
|
|
aMS.Add(aS2);
|
|
}
|
|
else {
|
|
TopTools_MapOfShape aMS;
|
|
//
|
|
aMS.Add(aS2);
|
|
myShapesOn.Bind(aS1, aMS);
|
|
}
|
|
}
|
|
//=======================================================================
|
|
//function : MapBRepShapes
|
|
//purpose :
|
|
//=======================================================================
|
|
void MapBRepShapes(const TopoDS_Shape& aS,
|
|
TopTools_IndexedMapOfShape& aM)
|
|
{
|
|
Standard_Boolean bDegenerated;
|
|
TopAbs_ShapeEnum aType;
|
|
TopoDS_Iterator aIt;
|
|
//
|
|
aType=aS.ShapeType();
|
|
if (aType==TopAbs_VERTEX || aType==TopAbs_EDGE ||
|
|
aType==TopAbs_FACE || aType==TopAbs_SOLID) {
|
|
bDegenerated=Standard_False;
|
|
if (aType==TopAbs_EDGE) {
|
|
TopoDS_Edge *pE=(TopoDS_Edge*)&aS;
|
|
bDegenerated=BRep_Tool::Degenerated(*pE);
|
|
}
|
|
if (!bDegenerated) {
|
|
aM.Add(aS);
|
|
}
|
|
}
|
|
//
|
|
aIt.Initialize(aS);
|
|
for(; aIt.More(); aIt.Next()) {
|
|
const TopoDS_Shape& aSx=aIt.Value();
|
|
aType=aSx.ShapeType();
|
|
MapBRepShapes(aSx, aM);
|
|
}
|
|
}
|