2014-02-18 12:44:41 +06:00
|
|
|
// Copyright (C) 2007-2014 CEA/DEN, EDF R&D, OPEN CASCADE
|
2012-08-09 13:58:02 +06:00
|
|
|
//
|
|
|
|
// 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
|
2014-02-18 12:44:41 +06:00
|
|
|
// version 2.1 of the License, or (at your option) any later version.
|
2012-08-09 13:58:02 +06:00
|
|
|
//
|
|
|
|
// 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_Gluer2_3.cxx
|
|
|
|
// Author: Peter KURNEV
|
|
|
|
|
|
|
|
#include <GEOMAlgo_Gluer2.hxx>
|
|
|
|
|
|
|
|
#include <TopAbs_ShapeEnum.hxx>
|
|
|
|
|
|
|
|
#include <TopoDS_Shape.hxx>
|
|
|
|
#include <TopoDS_Edge.hxx>
|
|
|
|
|
|
|
|
#include <BRep_Tool.hxx>
|
|
|
|
|
|
|
|
#include <TopExp.hxx>
|
|
|
|
#include <TopExp_Explorer.hxx>
|
|
|
|
|
|
|
|
#include <TopTools_DataMapIteratorOfDataMapOfShapeListOfShape.hxx>
|
|
|
|
#include <TopTools_DataMapOfShapeListOfShape.hxx>
|
|
|
|
#include <TopTools_ListOfShape.hxx>
|
|
|
|
#include <TopTools_MapOfShape.hxx>
|
|
|
|
#include <TopTools_MapIteratorOfMapOfShape.hxx>
|
|
|
|
#include <TopTools_DataMapIteratorOfDataMapOfShapeListOfShape.hxx>
|
|
|
|
#include <TopTools_ListIteratorOfListOfShape.hxx>
|
|
|
|
#include <TopTools_IndexedMapOfShape.hxx>
|
|
|
|
|
2013-09-16 19:59:50 +06:00
|
|
|
#include <GEOMAlgo_CoupleOfShapes.hxx>
|
|
|
|
#include <GEOMAlgo_ListOfCoupleOfShapes.hxx>
|
|
|
|
#include <GEOMAlgo_ListIteratorOfListOfCoupleOfShapes.hxx>
|
2012-08-09 13:58:02 +06:00
|
|
|
|
2013-09-16 19:59:50 +06:00
|
|
|
#include <GEOMAlgo_AlgoTools.hxx>
|
2012-08-09 13:58:02 +06:00
|
|
|
#include <GEOMAlgo_GlueDetector.hxx>
|
2013-09-16 19:59:50 +06:00
|
|
|
#include <GEOMAlgo_IndexedDataMapOfShapeIndexedMapOfShape.hxx>
|
2012-08-09 13:58:02 +06:00
|
|
|
|
|
|
|
|
|
|
|
static
|
|
|
|
void MapShapes1(const TopoDS_Shape& aS,
|
|
|
|
const TopAbs_ShapeEnum aType,
|
|
|
|
TopTools_IndexedMapOfShape& aM);
|
|
|
|
|
|
|
|
//=======================================================================
|
|
|
|
//function : Detect
|
|
|
|
//purpose :
|
|
|
|
//=======================================================================
|
|
|
|
void GEOMAlgo_Gluer2::Detect()
|
|
|
|
{
|
|
|
|
Standard_Boolean bCheckGeometry;
|
|
|
|
Standard_Integer iErr, aNbSD;
|
|
|
|
TopTools_ListIteratorOfListOfShape aItLS;
|
|
|
|
TopTools_DataMapIteratorOfDataMapOfShapeListOfShape aItDMSLS;
|
|
|
|
//GEOMAlgo_GlueDetector aDetector;
|
|
|
|
//
|
|
|
|
myErrorStatus=0;
|
|
|
|
myWarningStatus=0;
|
|
|
|
//
|
|
|
|
myImagesDetected.Clear();
|
|
|
|
myOriginsDetected.Clear();
|
|
|
|
//
|
|
|
|
bCheckGeometry=Standard_True;
|
|
|
|
//
|
|
|
|
//modified by NIZNHY-PKV Tue Mar 13 13:33:35 2012f
|
|
|
|
myDetector.Clear();
|
|
|
|
myDetector.SetContext(myContext);
|
|
|
|
//modified by NIZNHY-PKV Tue Mar 13 13:33:38 2012t
|
|
|
|
myDetector.SetArgument(myArgument);
|
|
|
|
myDetector.SetTolerance(myTolerance);
|
|
|
|
myDetector.SetCheckGeometry(bCheckGeometry);
|
|
|
|
//
|
|
|
|
myDetector.Perform();
|
|
|
|
iErr=myDetector.ErrorStatus();
|
|
|
|
if (iErr) {
|
|
|
|
// Detector is failed
|
|
|
|
myErrorStatus=11;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
//modified by NIZNHY-PKV Tue Mar 13 13:40:36 2012f
|
|
|
|
iErr=myDetector.WarningStatus();
|
|
|
|
if (iErr) {
|
|
|
|
// Sticked shapes are detected
|
|
|
|
myWarningStatus=2;
|
|
|
|
}
|
|
|
|
//modified by NIZNHY-PKV Tue Mar 13 13:40:39 2012t
|
|
|
|
//
|
|
|
|
const TopTools_DataMapOfShapeListOfShape& aImages=myDetector.Images();
|
|
|
|
aItDMSLS.Initialize(aImages);
|
|
|
|
for (; aItDMSLS.More(); aItDMSLS.Next()) {
|
|
|
|
const TopoDS_Shape& aSkey=aItDMSLS.Key();
|
|
|
|
const TopTools_ListOfShape& aLSD=aItDMSLS.Value();
|
|
|
|
aNbSD=aLSD.Extent();
|
|
|
|
myImagesDetected.Bind(aSkey, aLSD);
|
|
|
|
}
|
|
|
|
//
|
|
|
|
aItDMSLS.Initialize(myImagesDetected);
|
|
|
|
for (; aItDMSLS.More(); aItDMSLS.Next()) {
|
|
|
|
const TopoDS_Shape& aSkey=aItDMSLS.Key();
|
|
|
|
const TopTools_ListOfShape& aLSD=aItDMSLS.Value();
|
|
|
|
aItLS.Initialize(aLSD);
|
|
|
|
for (; aItLS.More(); aItLS.Next()) {
|
|
|
|
const TopoDS_Shape& aSx=aItLS.Value();
|
|
|
|
myOriginsDetected.Bind(aSx, aSkey);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//=======================================================================
|
|
|
|
//function : PerformShapesToWork
|
|
|
|
//purpose :
|
|
|
|
//=======================================================================
|
|
|
|
void GEOMAlgo_Gluer2::PerformShapesToWork()
|
|
|
|
{
|
|
|
|
Standard_Integer aNbSG, i, j, k, aNbC, aNb, aNbSD;
|
|
|
|
TopTools_ListIteratorOfListOfShape aItLS1, aItLS2;
|
|
|
|
TopTools_DataMapIteratorOfDataMapOfShapeListOfShape aItDMSLS;
|
2013-09-16 19:59:50 +06:00
|
|
|
GEOMAlgo_CoupleOfShapes aCS;
|
|
|
|
GEOMAlgo_ListOfCoupleOfShapes aLCS;
|
|
|
|
GEOMAlgo_ListIteratorOfListOfCoupleOfShapes aItCS;
|
2012-08-09 13:58:02 +06:00
|
|
|
//
|
|
|
|
myErrorStatus=0;
|
|
|
|
myWarningStatus=0;
|
|
|
|
//
|
|
|
|
myImagesToWork.Clear();
|
|
|
|
myOriginsToWork.Clear();
|
|
|
|
//
|
|
|
|
aNbSD=myImagesDetected.Extent();
|
|
|
|
if (!aNbSD) {// no shapes to glue detected
|
|
|
|
myWarningStatus=1;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
aNbSG=myShapesToGlue.Extent();
|
|
|
|
if (!aNbSG) {
|
|
|
|
// glue all possible
|
|
|
|
myImagesToWork=myImagesDetected;
|
|
|
|
//
|
|
|
|
aItDMSLS.Initialize(myImagesToWork);
|
|
|
|
for (; aItDMSLS.More(); aItDMSLS.Next()) {
|
|
|
|
const TopoDS_Shape& aSkey=aItDMSLS.Key();
|
|
|
|
const TopTools_ListOfShape& aLSD=aItDMSLS.Value();
|
|
|
|
aItLS1.Initialize(aLSD);
|
|
|
|
for (; aItLS1.More(); aItLS1.Next()) {
|
|
|
|
const TopoDS_Shape& aSx=aItLS1.Value();
|
|
|
|
myOriginsToWork.Bind(aSx, aSkey);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}// if (!aNbSG) {
|
|
|
|
//
|
|
|
|
// 1. Make pairs
|
|
|
|
aItDMSLS.Initialize(myShapesToGlue);
|
|
|
|
for (k=0; aItDMSLS.More(); aItDMSLS.Next(), ++k) {
|
|
|
|
//const TopoDS_Shape& aSkey=aItDMSLS.Key();
|
|
|
|
const TopTools_ListOfShape& aLSG=aItDMSLS.Value();
|
|
|
|
aItLS1.Initialize(aLSG);
|
|
|
|
for (i=0; aItLS1.More(); aItLS1.Next(), ++i) {
|
|
|
|
aItLS2.Initialize(aLSG);
|
|
|
|
for (j=0; aItLS2.More(); aItLS2.Next(), ++j) {
|
|
|
|
if (j>i) {
|
|
|
|
const TopoDS_Shape& aSG1=aItLS1.Value();
|
|
|
|
const TopoDS_Shape& aSG2=aItLS2.Value();
|
|
|
|
aCS.SetShape1(aSG1);
|
|
|
|
aCS.SetShape2(aSG2);
|
|
|
|
TreatPair(aCS, aLCS);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//
|
|
|
|
// 2. Find Chains
|
|
|
|
TopTools_ListOfShape aLSX;
|
2013-09-16 19:59:50 +06:00
|
|
|
GEOMAlgo_IndexedDataMapOfShapeIndexedMapOfShape aMC;
|
2012-08-09 13:58:02 +06:00
|
|
|
//
|
2013-09-16 19:59:50 +06:00
|
|
|
GEOMAlgo_AlgoTools::FindChains(aLCS, aMC);
|
2012-08-09 13:58:02 +06:00
|
|
|
//
|
|
|
|
// 3. myImagesToWork, myOriginsToWork
|
|
|
|
aNbC=aMC.Extent();
|
|
|
|
for (i=1; i<=aNbC; ++i) {
|
|
|
|
const TopoDS_Shape& aSkey=aMC.FindKey(i);
|
|
|
|
const TopTools_IndexedMapOfShape& aM=aMC(i);
|
|
|
|
aLSX.Clear();
|
|
|
|
aNb=aM.Extent();
|
|
|
|
for (j=1; j<=aNb; ++j) {
|
|
|
|
const TopoDS_Shape& aS=aM(j);
|
|
|
|
aLSX.Append(aS);
|
|
|
|
myOriginsToWork.Bind(aS, aSkey);
|
|
|
|
}
|
|
|
|
myImagesToWork.Bind(aSkey, aLSX);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//=======================================================================
|
|
|
|
//function : TreatPair
|
|
|
|
//purpose :
|
|
|
|
//=======================================================================
|
2013-09-16 19:59:50 +06:00
|
|
|
void GEOMAlgo_Gluer2::TreatPair(const GEOMAlgo_CoupleOfShapes& aCS,
|
|
|
|
GEOMAlgo_ListOfCoupleOfShapes& aLCS)
|
2012-08-09 13:58:02 +06:00
|
|
|
{
|
|
|
|
if (myErrorStatus) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
Standard_Integer i, aNbS1, aNbS2, aNbS;
|
|
|
|
TopAbs_ShapeEnum aType, aTypeS;
|
|
|
|
TopTools_ListIteratorOfListOfShape aItLS;
|
|
|
|
TopTools_IndexedMapOfShape aMS1, aMS2;
|
|
|
|
TopTools_DataMapOfShapeListOfShape aDMSLS;
|
|
|
|
TopTools_DataMapIteratorOfDataMapOfShapeListOfShape aItDMSLS;
|
2013-09-16 19:59:50 +06:00
|
|
|
GEOMAlgo_CoupleOfShapes aCSS;
|
2012-08-09 13:58:02 +06:00
|
|
|
//
|
|
|
|
// 1. Checking the pair on whether it can be glued at all
|
|
|
|
// 1.1
|
|
|
|
const TopoDS_Shape& aS1=aCS.Shape1();
|
|
|
|
if (!myOriginsDetected.IsBound(aS1)) {
|
|
|
|
myErrorStatus=30;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
const TopoDS_Shape& aSkey1=myOriginsDetected.Find(aS1);
|
|
|
|
// 1.2
|
|
|
|
const TopoDS_Shape& aS2=aCS.Shape2();
|
|
|
|
if (!myOriginsDetected.IsBound(aS2)) {
|
|
|
|
myErrorStatus=30;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
const TopoDS_Shape& aSkey2=myOriginsDetected.Find(aS2);
|
|
|
|
// 1.3
|
|
|
|
if (!aSkey1.IsSame(aSkey2)) {
|
|
|
|
myErrorStatus=33;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
// 2. Append the pair to the aLCS
|
|
|
|
aLCS.Append(aCS);
|
|
|
|
//
|
|
|
|
// 3. Treatment the sub-shapes of the pair
|
|
|
|
aType=aS1.ShapeType();
|
|
|
|
if (aType==TopAbs_VERTEX) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
aTypeS=TopAbs_EDGE;
|
|
|
|
if (aType==aTypeS) {
|
|
|
|
aTypeS=TopAbs_VERTEX;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
MapShapes1(aS1, aTypeS, aMS1);
|
|
|
|
MapShapes1(aS2, aTypeS, aMS2);
|
|
|
|
//
|
|
|
|
aNbS1=aMS1.Extent();
|
|
|
|
aNbS2=aMS2.Extent();
|
|
|
|
if (aNbS1!=aNbS2) {
|
|
|
|
myErrorStatus=31;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
// 1.
|
|
|
|
for (i=1; i<=aNbS1; ++i) {
|
|
|
|
const TopoDS_Shape& aSS1=aMS1(i);
|
|
|
|
if (aMS2.Contains(aSS1)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
if (!myOriginsDetected.IsBound(aSS1)) {
|
|
|
|
myErrorStatus=30;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
const TopoDS_Shape& aSkey=myOriginsDetected.Find(aSS1);
|
|
|
|
if (aDMSLS.IsBound(aSkey)) {
|
|
|
|
TopTools_ListOfShape& aLS=aDMSLS.ChangeFind(aSkey);
|
|
|
|
aLS.Append(aSS1);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
TopTools_ListOfShape aLS;
|
|
|
|
//
|
|
|
|
aLS.Append(aSS1);
|
|
|
|
aDMSLS.Bind(aSkey, aLS);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//
|
|
|
|
// 2.
|
|
|
|
for (i=1; i<=aNbS2; ++i) {
|
|
|
|
const TopoDS_Shape& aSS2=aMS2(i);
|
|
|
|
if (aMS1.Contains(aSS2)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
if (!myOriginsDetected.IsBound(aSS2)) {
|
|
|
|
myErrorStatus=30;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
const TopoDS_Shape& aSkey=myOriginsDetected.Find(aSS2);
|
|
|
|
if (aDMSLS.IsBound(aSkey)) {
|
|
|
|
TopTools_ListOfShape& aLS=aDMSLS.ChangeFind(aSkey);
|
|
|
|
aLS.Append(aSS2);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
TopTools_ListOfShape aLS;
|
|
|
|
//
|
|
|
|
aLS.Append(aSS2);
|
|
|
|
aDMSLS.Bind(aSkey, aLS);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//
|
|
|
|
// 3.
|
|
|
|
aItDMSLS.Initialize(aDMSLS);
|
|
|
|
for (; aItDMSLS.More(); aItDMSLS.Next()) {
|
|
|
|
//const TopoDS_Shape& aSkey=aItDMSLS.Key();
|
|
|
|
const TopTools_ListOfShape& aLS=aItDMSLS.Value();
|
|
|
|
aNbS=aLS.Extent();
|
|
|
|
if (aNbS!=2) {
|
|
|
|
myErrorStatus=32;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
//
|
|
|
|
const TopoDS_Shape& aSS1=aLS.First();
|
|
|
|
const TopoDS_Shape& aSS2=aLS.Last();
|
|
|
|
aCSS.SetShape1(aSS1);
|
|
|
|
aCSS.SetShape2(aSS2);
|
|
|
|
TreatPair(aCSS, aLCS);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//=======================================================================
|
|
|
|
//function : MapShapes1
|
|
|
|
//purpose :
|
|
|
|
//=======================================================================
|
|
|
|
void MapShapes1(const TopoDS_Shape& aS,
|
|
|
|
const TopAbs_ShapeEnum aType,
|
|
|
|
TopTools_IndexedMapOfShape& aM)
|
|
|
|
{
|
|
|
|
TopExp_Explorer aExp;
|
|
|
|
|
|
|
|
aExp.Init (aS, aType);
|
|
|
|
for ( ;aExp.More(); aExp.Next()) {
|
|
|
|
const TopoDS_Shape aSx=aExp.Current();
|
|
|
|
if (aType==TopAbs_EDGE) {
|
|
|
|
const TopoDS_Edge& aEx=*((TopoDS_Edge*)&aSx);
|
|
|
|
if (BRep_Tool::Degenerated(aEx)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
aM.Add(aSx);
|
|
|
|
}
|
|
|
|
}
|