1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-04 18:06:22 +03:00

0024530: TKMesh - remove unused package IntPoly

Deletion of package IntPoly.
This commit is contained in:
aml 2014-02-13 09:39:50 +04:00 committed by apn
parent 7075ef95b6
commit 9bd37e127c
14 changed files with 0 additions and 2187 deletions

View File

@ -156,7 +156,6 @@ p IntCurvesFace
p IntImp
p IntImpParGen
p IntPatch
p IntPoly
p IntPolyh
p IntRes2d
p IntStart

View File

@ -1,68 +0,0 @@
-- Created on: 1995-07-17
-- Created by: Stagiaire Alain JOURDAIN
-- Copyright (c) 1995-1999 Matra Datavision
-- Copyright (c) 1999-2014 OPEN CASCADE SAS
--
-- This file is part of Open CASCADE Technology software library.
--
-- This library is free software; you can redistribute it and / or modify it
-- under the terms of the GNU Lesser General Public version 2.1 as published
-- by the Free Software Foundation, with special exception defined in the file
-- OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
-- distribution for complete text of the license and disclaimer of any warranty.
--
-- Alternatively, this file may be used under the terms of Open CASCADE
-- commercial license or contractual agreement.
package IntPoly
---Purpose:
uses Standard,
TCollection,
gp,
TColStd,
TColgp,
TopoDS,
TopAbs,
TopExp,
TopLoc,
Poly
is class SequenceOfSequenceOfPnt2d
instantiates Sequence from TCollection (SequenceOfPnt2d from TColgp);
class Pnt2dHasher;
class IndexedMapOfPnt2d
instantiates IndexedMap from TCollection (Pnt2d from gp,
Pnt2dHasher from IntPoly);
class PlaneSection;
class SequenceOfSequenceOfPnt
instantiates Sequence from TCollection (SequenceOfPnt from TColgp);
class PntHasher;
class IndexedMapOfPnt
instantiates IndexedMap from TCollection (Pnt from gp,
PntHasher from IntPoly);
class ShapeSection;
end IntPoly;

View File

@ -1,114 +0,0 @@
-- Created on: 1995-07-17
-- Created by: Stagiaire Alain JOURDAIN
-- Copyright (c) 1995-1999 Matra Datavision
-- Copyright (c) 1999-2014 OPEN CASCADE SAS
--
-- This file is part of Open CASCADE Technology software library.
--
-- This library is free software; you can redistribute it and / or modify it
-- under the terms of the GNU Lesser General Public version 2.1 as published
-- by the Free Software Foundation, with special exception defined in the file
-- OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
-- distribution for complete text of the license and disclaimer of any warranty.
--
-- Alternatively, this file may be used under the terms of Open CASCADE
-- commercial license or contractual agreement.
class PlaneSection from IntPoly
---Purpose: determines the section of a triangulated shape by a plane.
-- The section is a set of edges.
uses Real from Standard,
Integer from Standard,
Boolean from Standard,
Shape from TopoDS,
Edge from TopoDS,
Trsf from gp,
Pln from gp,
Pnt from gp,
Pnt2d from gp,
SequenceOfPnt2d from TColgp,
SequenceOfSequenceOfPnt2d from IntPoly,
IndexedMapOfPnt2d from IntPoly,
Pnt2dHasher from IntPoly
is Create
returns PlaneSection from IntPoly;
Create (S : Shape from TopoDS;
P : Pln from gp)
returns PlaneSection from IntPoly;
Section (me : in out)
is static;
Intersect (me : in out; Point1 : Pnt from gp;
Point2 : Pnt from gp;
Point3 : Pnt from gp;
OutPoint1 : out Pnt2d from gp;
OutPoint2 : out Pnt2d from gp)
---Purpose: determines the 2 2D-points resulting of the intersection
-- of the triangle (Point1,Point2,Point3) by the plane
returns Boolean from Standard;
Insert (me : in out; OldPnt : Pnt2d from gp;
ComPnt : Pnt2d from gp;
NewPnt : Pnt2d from gp)
---Purpose: sees whether OldPnt and NewPnt begins or ends a section
-- created before and adds the 2 others points.
-- If not, creates a section
is static;
Concat (me : in out; BegPnt : Pnt2d from gp;
EndPnt : Pnt2d from gp;
OutPnt : out Pnt2d from gp)
---Purpose: sees whether BegPnt or EndPnt begins or ends a section
-- created before, and returns the other point to continue
-- the construction
-- Returns 2 if the construction is 'Forward'
-- Returns 1 if the construction is 'Previous'
-- Returns 0 if not and creates a section
returns Integer from Standard;
ConcatSection (me : in out; Section : in out SequenceOfPnt2d from TColgp;
NbSection : Integer from Standard;
Index : Integer from Standard)
---Purpose: sees whether Section begins or ends another one in mySection,
-- from the rank 'Index' to the last one 'NbSection'
is static;
ForwConstruction (me : in out; Point : Pnt2d from gp)
---Purpose: builds a section from Point in this way
-- ___ ___ ___ ___
-- Point--/__/--/__/--/__/--/__/--->
is static;
PrevConstruction (me : in out; Point : Pnt2d from gp)
---Purpose: builds a section from Point in this way
-- ___ ___ ___ ___
-- <---/__/--/__/--/__/--/__/--Point
is static;
NbEdges (me : in out)
returns Integer from Standard;
Edge (me : in out; Index : Integer from Standard)
---Purpose: builds an edge from a sequence of Pnt2d
-- this is a part of the section
returns Edge from TopoDS;
fields
myShape : Shape from TopoDS;
myTransform : Trsf from gp;
myBackTransform : Trsf from gp;
mySection : SequenceOfSequenceOfPnt2d from IntPoly;
myMapBegPoints : IndexedMapOfPnt2d from IntPoly;
myMapEndPoints : IndexedMapOfPnt2d from IntPoly;
myCpt : Integer from Standard;
myIndex : Integer from Standard;
myNbEdges : Integer from Standard;
end PlaneSection;

View File

@ -1,623 +0,0 @@
// Created on: 1995-07-17
// Created by: Stagiaire Alain JOURDAIN
// Copyright (c) 1995-1999 Matra Datavision
// Copyright (c) 1999-2014 OPEN CASCADE SAS
//
// This file is part of Open CASCADE Technology software library.
//
// This library is free software; you can redistribute it and / or modify it
// under the terms of the GNU Lesser General Public version 2.1 as published
// by the Free Software Foundation, with special exception defined in the file
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
// distribution for complete text of the license and disclaimer of any warranty.
//
// Alternatively, this file may be used under the terms of Open CASCADE
// commercial license or contractual agreement.
#include <IntPoly_PlaneSection.ixx>
#include <IntPoly_SequenceOfSequenceOfPnt2d.hxx>
#include <IntPoly_IndexedMapOfPnt2d.hxx>
#include <IntPoly_Pnt2dHasher.hxx>
#include <Precision.hxx>
#include <TopExp_Explorer.hxx>
#include <TopoDS_Shape.hxx>
#include <TopoDS_Edge.hxx>
#include <BRep_Tool.hxx>
#include <BRep_Builder.hxx>
#include <TopoDS.hxx>
#include <Poly_Triangulation.hxx>
#include <Poly_Polygon3D.hxx>
#include <OSD_Chronometer.hxx>
//=======================================================================
//function : IntPoly_PlaneSection
//purpose :
//=======================================================================
IntPoly_PlaneSection::IntPoly_PlaneSection()
{}
//=======================================================================
//function : IntPoly_PlaneSection
//purpose :
//=======================================================================
IntPoly_PlaneSection::IntPoly_PlaneSection(const TopoDS_Shape& S,
const gp_Pln& P)
{
myShape = S;
myTransform.SetTransformation(P.Position());
gp_Ax3 Ax0(gp_Pnt(0,0,0),gp_Dir(0,0,1));
myBackTransform.SetTransformation(P.Position(),Ax0);
Section();
}
//=======================================================================
//function : Section
//purpose :
//=======================================================================
void IntPoly_PlaneSection::Section()
{
TopExp_Explorer ex;
Standard_Integer NbTrian,i,i1,i2,i3,Result;
Standard_Real Big = Precision::Infinite();
Standard_Boolean Inter;
//gp_Pnt Nod1,Nod2,Nod3;
gp_Pnt2d BegPoint,EndPoint,OutPoint;
TopLoc_Location Loc;
Handle(Poly_Triangulation) Tr;
myCpt = 0;
for (ex.Init(myShape,TopAbs_FACE);ex.More();ex.Next()) {
Tr = (BRep_Tool::Triangulation(TopoDS::Face(ex.Current()),Loc));
if (!Tr.IsNull()) {
NbTrian = Tr->NbTriangles();
const Poly_Array1OfTriangle& TabTrian = Tr->Triangles();
const TColgp_Array1OfPnt& TabNodes = Tr->Nodes();
TColgp_Array1OfPnt TabTransfNodes(1,Tr->NbNodes());
for (i = 1;i <= Tr->NbNodes();i++) {
if (!Loc.IsIdentity())
TabTransfNodes(i) =
(TabNodes(i).Transformed(Loc.Transformation()))
.Transformed(myTransform);
else
TabTransfNodes(i) = TabNodes(i).Transformed(myTransform);
}
for (i = 1;i <= NbTrian;i++) {
TabTrian(i).Get(i1,i2,i3);
Inter = Intersect(TabTransfNodes(i1),
TabTransfNodes(i2),
TabTransfNodes(i3),
BegPoint,EndPoint);
if (Inter) {
if (myMapBegPoints.Contains(BegPoint)) {
Standard_Integer Index = myMapBegPoints.FindIndex(BegPoint);
Insert(myMapEndPoints.FindKey(Index),BegPoint,EndPoint);
myCpt++;
myMapBegPoints.Substitute(Index,gp_Pnt2d(Big,myCpt));
myMapEndPoints.Substitute(Index,gp_Pnt2d(Big,myCpt));
}
else if (myMapEndPoints.Contains(EndPoint)) {
Standard_Integer Index = myMapEndPoints.FindIndex(EndPoint);
Insert(myMapBegPoints.FindKey(Index),EndPoint,BegPoint);
myCpt++;
myMapBegPoints.Substitute(Index,gp_Pnt2d(Big,myCpt));
myMapEndPoints.Substitute(Index,gp_Pnt2d(Big,myCpt));
}
else {
myMapBegPoints.Add(BegPoint);
myMapEndPoints.Add(EndPoint);
}
}
}
}
}
Standard_Integer NbLinks = myMapBegPoints.Extent();
i = 1;
while (i <= NbLinks) {
if (!(Precision::IsInfinite((myMapBegPoints.FindKey(i)).X()))) {
BegPoint = myMapBegPoints.FindKey(i);
EndPoint = myMapEndPoints.FindKey(i);
myCpt++;
myMapBegPoints.Substitute(i,gp_Pnt2d(Big,myCpt));
myMapEndPoints.Substitute(i,gp_Pnt2d(Big,myCpt));
Result = Concat(BegPoint,EndPoint,OutPoint);
if (Result == 2)
ForwConstruction(OutPoint);
else
if (Result == 1)
PrevConstruction(OutPoint);
else {
ForwConstruction(EndPoint);
PrevConstruction(BegPoint);
}
}
i++;
}
i = 1;
while (i < mySection.Length()) {
ConcatSection(mySection.ChangeValue(i),mySection.Length(),i+1);
i++;
}
myNbEdges = mySection.Length();
}
//=======================================================================
//function : Intersect
//purpose : Determines the 2 2D-points resulting of the intersection
// of the triangle (Point1,Point2,Point3) by the plane
//=======================================================================
Standard_Boolean IntPoly_PlaneSection::Intersect(const gp_Pnt& Point1,
const gp_Pnt& Point2,
const gp_Pnt& Point3,
gp_Pnt2d& OutPoint1,
gp_Pnt2d& OutPoint2)
{
gp_Pnt Pt1 = Point1;
gp_Pnt Pt2 = Point2;
gp_Pnt Pt3 = Point3;
Standard_Real z1 = Pt1.Z();
Standard_Real z2 = Pt2.Z();
Standard_Real z3 = Pt3.Z();
Standard_Boolean intersection = Standard_False;
if ((z1 == 0) && (z2 == 0) && (z3 == 0))
return intersection;
if ((z1 == 0) && (z2 == 0)) {
intersection = Standard_True;
OutPoint1.SetCoord(Pt1.X(),Pt1.Y());
OutPoint2.SetCoord(Pt2.X(),Pt2.Y());
return intersection;
}
if ((z2 == 0) && (z3 == 0)) {
intersection = Standard_True;
OutPoint1.SetCoord(Pt2.X(),Pt2.Y());
OutPoint2.SetCoord(Pt3.X(),Pt3.Y());
return intersection;
}
if ((z3 == 0) && (z1 == 0)) {
intersection = Standard_True;
OutPoint1.SetCoord(Pt3.X(),Pt3.Y());
OutPoint2.SetCoord(Pt1.X(),Pt1.Y());
return intersection;
}
if (z1 == 0) {
if ((z2 < 0) && (z3 > 0))
intersection = Standard_True;
if ((z2 > 0) && (z3 < 0)) {
intersection = Standard_True;
gp_Pnt Pt = Pt2;
Pt2 = Pt3;
Pt3 = Pt;
}
if (intersection) {
Standard_Real u1 = Pt2.X();
Standard_Real v1 = Pt2.Y();
z1 = Pt2.Z();
Standard_Real u2 = Pt3.X();
Standard_Real v2 = Pt3.Y();
z2 = Pt3.Z();
Standard_Real U = u1 - z1 * (u2 - u1)/(z2 - z1);
Standard_Real V = v1 - z1 * (v2 - v1)/(z2 - z1);
OutPoint1.SetCoord(Pt1.X(),Pt1.Y());
OutPoint2.SetCoord(U,V);
return intersection;
}
}
else
if (z2 == 0) {
if ((z1 < 0) && (z3 > 0))
intersection = Standard_True;
if ((z1 > 0) && (z3 < 0)) {
intersection = Standard_True;
gp_Pnt Pt = Pt1;
Pt1 = Pt3;
Pt3 = Pt;
}
if (intersection) {
Standard_Real u1 = Pt1.X();
Standard_Real v1 = Pt1.Y();
z1 = Pt1.Z();
Standard_Real u2 = Pt3.X();
Standard_Real v2 = Pt3.Y();
z2 = Pt3.Z();
Standard_Real U = u1 - z1 * (u2 - u1)/(z2 - z1);
Standard_Real V = v1 - z1 * (v2 - v1)/(z2 - z1);
OutPoint1.SetCoord(Pt2.X(),Pt2.Y());
OutPoint2.SetCoord(U,V);
return intersection;
}
}
else
if (z3 == 0) {
if ((z2 < 0) && (z1 > 0))
intersection = Standard_True;
if ((z2 > 0) && (z1 < 0)) {
intersection = Standard_True;
gp_Pnt Pt = Pt2;
Pt2 = Pt1;
Pt1 = Pt;
}
if (intersection) {
Standard_Real u1 = Pt2.X();
Standard_Real v1 = Pt2.Y();
z1 = Pt2.Z();
Standard_Real u2 = Pt1.X();
Standard_Real v2 = Pt1.Y();
z2 = Pt1.Z();
Standard_Real U = u1 - z1 * (u2 - u1)/(z2 - z1);
Standard_Real V = v1 - z1 * (v2 - v1)/(z2 - z1);
OutPoint1.SetCoord(Pt3.X(),Pt3.Y());
OutPoint2.SetCoord(U,V);
return intersection;
}
}
if ((z1 < 0) && (z2 > 0))
intersection = Standard_True;
if ((z1 > 0) && (z2 < 0)) {
intersection = Standard_True;
gp_Pnt Pt = Pt1;
Pt1 = Pt2;
Pt2 = Pt;
}
if (intersection) {
Standard_Real u1 = Pt1.X();
Standard_Real v1 = Pt1.Y();
z1 = Pt1.Z();
Standard_Real u2 = Pt2.X();
Standard_Real v2 = Pt2.Y();
z2 = Pt2.Z();
Standard_Real U = u1 - z1 * (u2 - u1)/(z2 - z1);
Standard_Real V = v1 - z1 * (v2 - v1)/(z2 - z1);
OutPoint1.SetCoord(U,V);
intersection = Standard_False;
Pt1 = Point1;
Pt2 = Point2;
z1 = Pt1.Z();
z2 = Pt2.Z();
if ((z2 < 0) && (z3 > 0))
intersection = Standard_True;
if ((z2 > 0) && (z3 < 0)) {
intersection = Standard_True;
gp_Pnt Pt = Pt2;
Pt2 = Pt3;
Pt3 = Pt;
}
if (intersection) {
u1 = Pt2.X();
v1 = Pt2.Y();
z1 = Pt2.Z();
u2 = Pt3.X();
v2 = Pt3.Y();
z2 = Pt3.Z();
U = u1 - z1 * (u2 - u1)/(z2 - z1);
V = v1 - z1 * (v2 - v1)/(z2 - z1);
OutPoint2.SetCoord(U,V);
return intersection;
}
else {
intersection = Standard_True;
Pt3 = Point3;
z3 = Pt3.Z();
if ((z3 > 0) && (z1 < 0)) {
gp_Pnt Pt = Pt3;
Pt3 = Pt1;
Pt1 = Pt;
}
u1 = Pt3.X();
v1 = Pt3.Y();
z1 = Pt3.Z();
u2 = Pt1.X();
v2 = Pt1.Y();
z2 = Pt1.Z();
U = u1 - z1 * (u2 - u1)/(z2 - z1);
V = v1 - z1 * (v2 - v1)/(z2 - z1);
OutPoint2.SetCoord(U,V);
return intersection;
}
}
else {
if ((z2 < 0) && (z3 > 0))
intersection = Standard_True;
if ((z2 > 0) && (z3 < 0)) {
intersection = Standard_True;
gp_Pnt Pt = Pt2;
Pt2 = Pt3;
Pt3 = Pt;
}
if (intersection) {
Standard_Real u1 = Pt2.X();
Standard_Real v1 = Pt2.Y();
z1 = Pt2.Z();
Standard_Real u2 = Pt3.X();
Standard_Real v2 = Pt3.Y();
z2 = Pt3.Z();
Standard_Real U = u1 - z1 * (u2 - u1)/(z2 - z1);
Standard_Real V = v1 - z1 * (v2 - v1)/(z2 - z1);
OutPoint1.SetCoord(U,V);
Pt3 = Point3;
z3 = Pt3.Z();
if ((z3 > 0) && (z1 < 0)) {
gp_Pnt Pt = Pt3;
Pt3 = Pt1;
Pt1 = Pt;
}
u1 = Pt3.X();
v1 = Pt3.Y();
z1 = Pt3.Z();
u2 = Pt1.X();
v2 = Pt1.Y();
z2 = Pt1.Z();
U = u1 - z1 * (u2 - u1)/(z2 - z1);
V = v1 - z1 * (v2 - v1)/(z2 - z1);
OutPoint2.SetCoord(U,V);
return intersection;
}
}
return intersection;
}
//=======================================================================
//function : Insert
//purpose : Sees whether OldPnt and NewPnt begins or ends a section
// created before and adds the 2 others points.
// If not, creates a section
//=======================================================================
void IntPoly_PlaneSection::Insert(const gp_Pnt2d& OldPnt,
const gp_Pnt2d& ComPnt,
const gp_Pnt2d& NewPnt)
{
Standard_Integer i = 0;
Standard_Integer NbSection = mySection.Length();
Standard_Boolean IsInSection = Standard_False;
while (i < NbSection) {
i++;
TColgp_SequenceOfPnt2d& CurSection = mySection.ChangeValue(i);
if (IntPoly_Pnt2dHasher::IsEqual(OldPnt,CurSection.First())) {
IsInSection = Standard_True;
CurSection.Prepend(ComPnt);
CurSection.Prepend(NewPnt);
break;
}
if (IntPoly_Pnt2dHasher::IsEqual(OldPnt,CurSection.Last())) {
IsInSection = Standard_True;
CurSection.Append(ComPnt);
CurSection.Append(NewPnt);
break;
}
if (IntPoly_Pnt2dHasher::IsEqual(NewPnt,CurSection.First())) {
IsInSection = Standard_True;
CurSection.Prepend(ComPnt);
CurSection.Prepend(OldPnt);
break;
}
if (IntPoly_Pnt2dHasher::IsEqual(NewPnt,CurSection.Last())) {
IsInSection = Standard_True;
CurSection.Append(ComPnt);
CurSection.Append(OldPnt);
break;
}
}
if (!(IsInSection)) {
TColgp_SequenceOfPnt2d EmptySec;
EmptySec.Append(OldPnt);
EmptySec.Append(ComPnt);
EmptySec.Append(NewPnt);
mySection.Append(EmptySec);
}
}
//=======================================================================
//function : Concat
//purpose : sees whether BegPnt or EndPnt begins or ends a section
// created before, and returns the other point to continue
// the construction
// Returns 2 if the construction is 'Forward'
// Returns 1 if the construction is 'Previous'
// Returns 0 if not and creates a section
//=======================================================================
Standard_Integer IntPoly_PlaneSection::Concat(const gp_Pnt2d& BegPnt,
const gp_Pnt2d& EndPnt,
gp_Pnt2d& OutPnt)
{
Standard_Integer i = 0;
Standard_Integer NbSection = mySection.Length();
Standard_Integer ConcatIdx = 0;
while (i < NbSection) {
i++;
TColgp_SequenceOfPnt2d& CurSection = mySection.ChangeValue(i);
if (IntPoly_Pnt2dHasher::IsEqual(BegPnt,CurSection.First())) {
ConcatIdx = 1;
myIndex = i;
CurSection.Prepend(EndPnt);
OutPnt = EndPnt;
break;
}
if (IntPoly_Pnt2dHasher::IsEqual(BegPnt,CurSection.Last())) {
ConcatIdx = 2;
myIndex = i;
CurSection.Append(EndPnt);
OutPnt = EndPnt;
break;
}
if (IntPoly_Pnt2dHasher::IsEqual(EndPnt,CurSection.First())) {
ConcatIdx = 1;
myIndex = i;
CurSection.Prepend(BegPnt);
OutPnt = BegPnt;
break;
}
if (IntPoly_Pnt2dHasher::IsEqual(EndPnt,CurSection.Last())) {
ConcatIdx = 2;
myIndex = i;
CurSection.Append(BegPnt);
OutPnt = BegPnt;
break;
}
}
if (ConcatIdx == 0) {
TColgp_SequenceOfPnt2d EmptySec;
EmptySec.Append(BegPnt);
EmptySec.Append(EndPnt);
mySection.Append(EmptySec);
NbSection++;
myIndex = NbSection;
}
return ConcatIdx;
}
//=======================================================================
//function : ConcatSection
//purpose : Sees whether Section begins or ends another one in mySection,
// from the rank 'Index' to the last one 'NbSection'
//=======================================================================
void IntPoly_PlaneSection::ConcatSection(TColgp_SequenceOfPnt2d& Section,
const Standard_Integer NbSection,
const Standard_Integer Index)
{
Standard_Integer j;
Standard_Integer i = Index;
gp_Pnt2d BegPnt = Section.First();
gp_Pnt2d EndPnt = Section.Last();
while (i <= NbSection) {
TColgp_SequenceOfPnt2d& CurSection = mySection.ChangeValue(i);
Standard_Integer CurSection_Length = CurSection.Length();
if (IntPoly_Pnt2dHasher::IsEqual(BegPnt,CurSection.First())) {
for (j = 2;j <= CurSection_Length;j++)
Section.Prepend(CurSection.Value(j));
mySection.Remove(i);
ConcatSection(Section,NbSection-1,Index);
break;
}
else
if (IntPoly_Pnt2dHasher::IsEqual(BegPnt,CurSection.Last())) {
for (j = CurSection_Length-1;j >= 1;j--)
Section.Prepend(CurSection.Value(j));
mySection.Remove(i);
ConcatSection(Section,NbSection-1,Index);
break;
}
else
if (IntPoly_Pnt2dHasher::IsEqual(EndPnt,CurSection.First())) {
for (j = 2;j <= CurSection_Length;j++)
Section.Append(CurSection.Value(j));
mySection.Remove(i);
ConcatSection(Section,NbSection-1,Index);
break;
}
else
if (IntPoly_Pnt2dHasher::IsEqual(EndPnt,CurSection.Last())) {
for (j = CurSection_Length-1;j >= 1;j--)
Section.Append(CurSection.Value(j));
mySection.Remove(i);
ConcatSection(Section,NbSection-1,Index);
break;
}
i++;
}
}
//=======================================================================
//function : ForwContruction
//purpose : Builds a section from Point in this way
// ___ ___ ___ ___
// <---/__/--/__/--/__/--/__/--Point
//=======================================================================
void IntPoly_PlaneSection::ForwConstruction(const gp_Pnt2d& Point)
{
if (myMapBegPoints.Contains(Point)) {
Standard_Integer Index = myMapBegPoints.FindIndex(Point);
gp_Pnt2d Pnt = myMapEndPoints.FindKey(Index);
(mySection.ChangeValue(myIndex)).Append(Pnt);
Standard_Real Big = Precision::Infinite();
myCpt++;
myMapBegPoints.Substitute(Index,gp_Pnt2d(Big,myCpt));
myMapEndPoints.Substitute(Index,gp_Pnt2d(Big,myCpt));
ForwConstruction(Pnt);
}
}
//=======================================================================
//function : PrevContruction
//purpose : Builds a section from Point in this way
// ___ ___ ___ ___
// Point--/__/--/__/--/__/--/__/--->
//=======================================================================
void IntPoly_PlaneSection::PrevConstruction(const gp_Pnt2d& Point)
{
if (myMapEndPoints.Contains(Point)) {
Standard_Integer Index = myMapEndPoints.FindIndex(Point);
gp_Pnt2d Pnt = myMapBegPoints.FindKey(Index);
(mySection.ChangeValue(myIndex)).Prepend(Pnt);
Standard_Real Big = Precision::Infinite();
myCpt++;
myMapBegPoints.Substitute(Index,gp_Pnt2d(Big,myCpt));
myMapEndPoints.Substitute(Index,gp_Pnt2d(Big,myCpt));
PrevConstruction(Pnt);
}
}
//=======================================================================
//function : NbEdges
//purpose : Returns the final number of edges in the section
//=======================================================================
Standard_Integer IntPoly_PlaneSection::NbEdges()
{ return myNbEdges; }
//=======================================================================
//function : Edge
//purpose : Builds the edges of the section
//=======================================================================
TopoDS_Edge IntPoly_PlaneSection::Edge(const Standard_Integer Index)
{
const TColgp_SequenceOfPnt2d& CurSection = mySection.ChangeValue(Index);
Standard_Integer NbPoints = CurSection.Length();
TColgp_Array1OfPnt TabPnt(1,NbPoints);
gp_Pnt CurPoint;
for (Standard_Integer i = 1 ; i <= NbPoints ; i++) {
CurPoint.SetX((CurSection.Value(i)).X());
CurPoint.SetY((CurSection.Value(i)).Y());
CurPoint.SetZ(0);
TabPnt.SetValue(i,CurPoint.Transformed(myBackTransform));
}
Handle(Poly_Polygon3D) Pol = new Poly_Polygon3D(TabPnt);
TopoDS_Edge Edge;
BRep_Builder B;
B.MakeEdge(Edge,Pol);
return Edge;
}

View File

@ -1,35 +0,0 @@
-- Created on: 1995-07-20
-- Created by: Stagiaire Alain JOURDAIN
-- Copyright (c) 1995-1999 Matra Datavision
-- Copyright (c) 1999-2014 OPEN CASCADE SAS
--
-- This file is part of Open CASCADE Technology software library.
--
-- This library is free software; you can redistribute it and / or modify it
-- under the terms of the GNU Lesser General Public version 2.1 as published
-- by the Free Software Foundation, with special exception defined in the file
-- OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
-- distribution for complete text of the license and disclaimer of any warranty.
--
-- Alternatively, this file may be used under the terms of Open CASCADE
-- commercial license or contractual agreement.
class Pnt2dHasher from IntPoly
uses Pnt2d from gp
is HashCode(myclass; Point : Pnt2d from gp;
Upper : Integer)
returns Integer;
---Purpose: Returns a HasCode value for the Key <K> in the
-- range 0..Upper.
---C++: inline
IsEqual(myclass; Point1,Point2 : Pnt2d from gp)
returns Boolean;
---Purpose: Returns True when the two keys are the same. Two
-- same keys must have the same hashcode, the
-- contrary is not necessary.
---C++: inline
end Pnt2dHasher;

View File

@ -1,17 +0,0 @@
// Created on: 1995-07-20
// Created by: Stagiaire Alain JOURDAIN
// Copyright (c) 1995-1999 Matra Datavision
// Copyright (c) 1999-2014 OPEN CASCADE SAS
//
// This file is part of Open CASCADE Technology software library.
//
// This library is free software; you can redistribute it and / or modify it
// under the terms of the GNU Lesser General Public version 2.1 as published
// by the Free Software Foundation, with special exception defined in the file
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
// distribution for complete text of the license and disclaimer of any warranty.
//
// Alternatively, this file may be used under the terms of Open CASCADE
// commercial license or contractual agreement.
#include <IntPoly_Pnt2dHasher.ixx>

View File

@ -1,43 +0,0 @@
// Created on: 1995-07-20
// Created by: Stagiaire Alain JOURDAIN
// Copyright (c) 1995-1999 Matra Datavision
// Copyright (c) 1999-2014 OPEN CASCADE SAS
//
// This file is part of Open CASCADE Technology software library.
//
// This library is free software; you can redistribute it and / or modify it
// under the terms of the GNU Lesser General Public version 2.1 as published
// by the Free Software Foundation, with special exception defined in the file
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
// distribution for complete text of the license and disclaimer of any warranty.
//
// Alternatively, this file may be used under the terms of Open CASCADE
// commercial license or contractual agreement.
#include <IntPoly_IndexedMapOfPnt2d.hxx>
#include <gp_Pnt2d.hxx>
#include <TColStd_MapRealHasher.hxx>
#include <Precision.hxx>
//=======================================================================
//function : HashCode
//purpose :
//=======================================================================
inline Standard_Integer IntPoly_Pnt2dHasher::HashCode(const gp_Pnt2d& Point,
const Standard_Integer upper)
{
return TColStd_MapRealHasher::HashCode(Point.X()+Point.Y(),upper);
}
//=======================================================================
//function : IsEqual
//purpose :
//=======================================================================
inline Standard_Boolean IntPoly_Pnt2dHasher::IsEqual(const gp_Pnt2d& Point1,
const gp_Pnt2d& Point2)
{
return ((Point1.X() == Point2.X()) && (Point1.Y() == Point2.Y()));
}

View File

@ -1,35 +0,0 @@
-- Created on: 1995-08-08
-- Created by: Stagiaire Alain JOURDAIN
-- Copyright (c) 1995-1999 Matra Datavision
-- Copyright (c) 1999-2014 OPEN CASCADE SAS
--
-- This file is part of Open CASCADE Technology software library.
--
-- This library is free software; you can redistribute it and / or modify it
-- under the terms of the GNU Lesser General Public version 2.1 as published
-- by the Free Software Foundation, with special exception defined in the file
-- OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
-- distribution for complete text of the license and disclaimer of any warranty.
--
-- Alternatively, this file may be used under the terms of Open CASCADE
-- commercial license or contractual agreement.
class PntHasher from IntPoly
uses Pnt from gp
is HashCode(myclass; Point : Pnt from gp;
Upper : Integer)
returns Integer;
---Purpose: Returns a HasCode value for the Key <K> in the
-- range 0..Upper.
---C++: inline
IsEqual(myclass; Point1,Point2 : Pnt from gp)
returns Boolean;
---Purpose: Returns True when the two keys are the same. Two
-- same keys must have the same hashcode, the
-- contrary is not necessary.
---C++: inline
end PntHasher;

View File

@ -1,17 +0,0 @@
// Created on: 1995-08-08
// Created by: Stagiaire Alain JOURDAIN
// Copyright (c) 1995-1999 Matra Datavision
// Copyright (c) 1999-2014 OPEN CASCADE SAS
//
// This file is part of Open CASCADE Technology software library.
//
// This library is free software; you can redistribute it and / or modify it
// under the terms of the GNU Lesser General Public version 2.1 as published
// by the Free Software Foundation, with special exception defined in the file
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
// distribution for complete text of the license and disclaimer of any warranty.
//
// Alternatively, this file may be used under the terms of Open CASCADE
// commercial license or contractual agreement.
#include <IntPoly_PntHasher.ixx>

View File

@ -1,45 +0,0 @@
// Created on: 1995-08-08
// Created by: Stagiaire Alain JOURDAIN
// Copyright (c) 1995-1999 Matra Datavision
// Copyright (c) 1999-2014 OPEN CASCADE SAS
//
// This file is part of Open CASCADE Technology software library.
//
// This library is free software; you can redistribute it and / or modify it
// under the terms of the GNU Lesser General Public version 2.1 as published
// by the Free Software Foundation, with special exception defined in the file
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
// distribution for complete text of the license and disclaimer of any warranty.
//
// Alternatively, this file may be used under the terms of Open CASCADE
// commercial license or contractual agreement.
#include <IntPoly_IndexedMapOfPnt.hxx>
#include <gp_Pnt.hxx>
#include <TColStd_MapRealHasher.hxx>
#include <Precision.hxx>
//=======================================================================
//function : HashCode
//purpose :
//=======================================================================
inline Standard_Integer IntPoly_PntHasher::HashCode(const gp_Pnt& Point,
const Standard_Integer upper)
{
return TColStd_MapRealHasher::HashCode(Point.X()+Point.Y()+Point.Z(),upper);
}
//=======================================================================
//function : IsEqual
//purpose :
//=======================================================================
inline Standard_Boolean IntPoly_PntHasher::IsEqual(const gp_Pnt& Point1,
const gp_Pnt& Point2)
{
return ((Point1.X() == Point2.X()) &&
(Point1.Y() == Point2.Y()) &&
(Point1.Z() == Point2.Z()));
}

View File

@ -1,130 +0,0 @@
-- Created on: 1995-08-01
-- Created by: Stagiaire Alain JOURDAIN
-- Copyright (c) 1995-1999 Matra Datavision
-- Copyright (c) 1999-2014 OPEN CASCADE SAS
--
-- This file is part of Open CASCADE Technology software library.
--
-- This library is free software; you can redistribute it and / or modify it
-- under the terms of the GNU Lesser General Public version 2.1 as published
-- by the Free Software Foundation, with special exception defined in the file
-- OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
-- distribution for complete text of the license and disclaimer of any warranty.
--
-- Alternatively, this file may be used under the terms of Open CASCADE
-- commercial license or contractual agreement.
class ShapeSection from IntPoly
---Purpose: determines the section between 2 triangulated shapes.
-- The section is a set of edges.
uses Real from Standard,
Integer from Standard,
Boolean from Standard,
Shape from TopoDS,
Edge from TopoDS,
Vec from gp,
Pnt from gp,
SequenceOfPnt from TColgp,
SequenceOfSequenceOfPnt from IntPoly,
IndexedMapOfPnt from IntPoly,
PntHasher from IntPoly
is Create
returns ShapeSection from IntPoly;
Create (S1 : Shape from TopoDS;
S2 : Shape from TopoDS)
returns ShapeSection from IntPoly;
Section (me : in out)
is static;
Explore (me : in out)
is static;
Intersect (me : in out; S1,S2,S3 : Pnt from gp;
OS1,VS0,V1,V2 : Vec from gp;
h1,h2,ah1,ah2 : in out Real from Standard)
---Purpose: determines if it exists, the intersection point between
-- the (S1,S2,S3) triangle and the edge pointed by V1 and V2.
-- Returns True if the triangle-triangle section is found.
returns Boolean from Standard;
IsEqual (me : in out; Pt1,Pt2 : Pnt from gp)
returns Boolean from Standard;
IsInside (me : in out; P,P1,P2,P3 : Pnt from gp;
N0 : Vec from gp)
---Purpose: returns True if P is inside the (P1,P2,P3) triangle
-- N0 = P1P2 ^ P1P3
returns Boolean from Standard;
InsertInMap (me : in out)
---Purpose: adds if necessary, myBegPoint in myMapBegPoint
-- and myEndPoint in myMapEndPoint.
is static;
Insert (me : in out; OldPnt : Pnt from gp;
ComPnt : Pnt from gp;
NewPnt : Pnt from gp)
---Purpose: sees whether OldPnt and NewPnt begins or ends a section
-- created before and adds the 2 others points.
-- If not, creates a section
is static;
Concat (me : in out; BegPnt : Pnt from gp;
EndPnt : Pnt from gp;
OutPnt : out Pnt from gp)
---Purpose: sees whether BegPnt or EndPnt begins or ends a section
-- created before, and returns the other point to continue
-- the construction
-- Returns 2 if the construction is 'Forward'
-- Returns 1 if the construction is 'Previous'
-- Returns 0 if not and creates a section
returns Integer from Standard;
ConcatSection (me : in out; Section : in out SequenceOfPnt from TColgp;
NbSection : Integer from Standard;
Index : Integer from Standard)
---Purpose: sees whether Section begins or ends another one in mySection,
-- from the rank 'Index' to the last one 'NbSection'
is static;
ForwConstruction (me : in out; Point : Pnt from gp)
---Purpose: builds a section from Point in this way
-- ___ ___ ___ ___
-- Point--/__/--/__/--/__/--/__/--->
is static;
PrevConstruction (me : in out; Point : Pnt from gp)
---Purpose: builds a section from Point in this way
-- ___ ___ ___ ___
-- <---/__/--/__/--/__/--/__/--Point
is static;
NbEdges (me : in out)
returns Integer from Standard;
Edge (me : in out; Index : Integer from Standard)
---Purpose: builds an edge from a sequence of Pnt
-- this is a part of the whole section
returns Edge from TopoDS;
fields
myShape1 : Shape from TopoDS;
myShape2 : Shape from TopoDS;
mySection : SequenceOfSequenceOfPnt from IntPoly;
myMapBegPoints : IndexedMapOfPnt from IntPoly;
myMapEndPoints : IndexedMapOfPnt from IntPoly;
myBegPoint : Pnt from gp;
myEndPoint : Pnt from gp;
myFirstTime : Boolean from Standard;
myCpt : Integer from Standard;
myIndex : Integer from Standard;
myNbEdges : Integer from Standard;
end ShapeSection;

View File

@ -1,994 +0,0 @@
// Created on: 1995-08-01
// Created by: Stagiaire Alain JOURDAIN
// Copyright (c) 1995-1999 Matra Datavision
// Copyright (c) 1999-2014 OPEN CASCADE SAS
//
// This file is part of Open CASCADE Technology software library.
//
// This library is free software; you can redistribute it and / or modify it
// under the terms of the GNU Lesser General Public version 2.1 as published
// by the Free Software Foundation, with special exception defined in the file
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
// distribution for complete text of the license and disclaimer of any warranty.
//
// Alternatively, this file may be used under the terms of Open CASCADE
// commercial license or contractual agreement.
#include <IntPoly_ShapeSection.ixx>
#include <IntPoly_SequenceOfSequenceOfPnt.hxx>
#include <IntPoly_IndexedMapOfPnt.hxx>
#include <IntPoly_PntHasher.hxx>
#include <Precision.hxx>
#include <TopExp_Explorer.hxx>
#include <TopoDS_Shape.hxx>
#include <TopoDS_Edge.hxx>
#include <TColStd_Array1OfReal.hxx>
#include <TColStd_Array1OfInteger.hxx>
#include <BRep_Tool.hxx>
#include <BRep_Builder.hxx>
#include <TopoDS.hxx>
#include <gp_Pnt.hxx>
#include <gp_Dir.hxx>
#include <gp_XYZ.hxx>
#include <Poly_Triangulation.hxx>
#include <Poly_Polygon3D.hxx>
//=======================================================================
//function : IntPoly_ShapeSection
//purpose :
//=======================================================================
IntPoly_ShapeSection::IntPoly_ShapeSection()
{}
//=======================================================================
//function : IntPoly_ShapeSection
//purpose :
//=======================================================================
IntPoly_ShapeSection::IntPoly_ShapeSection(const TopoDS_Shape& S1,
const TopoDS_Shape& S2)
{
myShape1 = S1;
myShape2 = S2;
Section();
}
//=======================================================================
//function : Section
//purpose :
//=======================================================================
void IntPoly_ShapeSection::Section()
{
Explore();
Standard_Integer NbLinks = myMapBegPoints.Extent();
Standard_Integer Result,i = 1;
Standard_Real Big = Precision::Infinite();
gp_Pnt BegPoint,EndPoint,OutPoint;
while (i <= NbLinks) {
if (!(Precision::IsInfinite((myMapBegPoints.FindKey(i)).X()))) {
BegPoint = myMapBegPoints.FindKey(i);
EndPoint = myMapEndPoints.FindKey(i);
myCpt++;
myMapBegPoints.Substitute(i,gp_Pnt(Big,myCpt,myCpt));
myMapEndPoints.Substitute(i,gp_Pnt(Big,myCpt,myCpt));
Result = Concat(BegPoint,EndPoint,OutPoint);
if (Result == 2)
ForwConstruction(OutPoint);
else
if (Result == 1)
PrevConstruction(OutPoint);
else {
ForwConstruction(EndPoint);
PrevConstruction(BegPoint);
}
}
i++;
}
i = 1;
while (i < mySection.Length()) {
ConcatSection(mySection.ChangeValue(i),mySection.Length(),i+1);
i++;
}
myNbEdges = mySection.Length();
}
//=======================================================================
//function : Explore
//purpose :
//=======================================================================
inline Standard_Boolean SAMESIGN(Standard_Real a,
Standard_Real b,
Standard_Real c)
{
return ((a > 0.0 && b > 0.0 && c > 0.0) ||
(a < 0.0 && b < 0.0 && c < 0.0) ||
(a == 0.0 && b == 0.0 && c == 0.0));
}
inline void MINMAX(Standard_Real a,Standard_Real b,Standard_Real c,
Standard_Real &m,Standard_Real &M)
{
m = M = a;
if (b < c) {
if (b < m) m = b;
if (c > M) M = c;
}
else {
if (c < m) m = c;
if (b > M) M = b;
}
}
void IntPoly_ShapeSection::Explore()
{
TopExp_Explorer ex1,ex2;
Standard_Integer i,i1,i2,i3,j,j1,j2,j3;
Standard_Integer NbTrian1,NbFaces1,NbTriATotal;
Standard_Integer NbTrian2,NbFaces2,NbTriBTotal;
Standard_Real Big = Precision::Infinite();
Standard_Real min,minfx,minfy,minfz,max,maxfx,maxfy,maxfz;
TopLoc_Location Loc1,Loc2;
Handle(Poly_Triangulation) Tr1,Tr2;
myCpt = 0;
//-----------------------------------------------------------------
//-- Traitement pour recuperer le nombre de faces et le nombre
//-- de triangles des shapes 1 et 2
//-----------------------------------------------------------------
NbFaces1 = NbTriATotal = 0;
for (ex1.Init(myShape1,TopAbs_FACE);ex1.More();ex1.Next()) {
Tr1 = (BRep_Tool::Triangulation(TopoDS::Face(ex1.Current()),Loc1));
if (!Tr1.IsNull()) {
NbTriATotal += Tr1->NbTriangles();
NbFaces1++;
}
}
NbFaces2 = NbTriBTotal = 0;
for (ex2.Init(myShape2,TopAbs_FACE);ex2.More();ex2.Next()) {
Tr2 = (BRep_Tool::Triangulation(TopoDS::Face(ex2.Current()),Loc2));
if (!Tr2.IsNull()) {
NbTriBTotal += Tr2->NbTriangles();
NbFaces2++;
}
}
if (NbTriATotal < NbTriBTotal) {
TopoDS_Shape S = myShape2;
myShape2 = myShape1;
myShape1 = S;
Standard_Integer Nb = NbTriBTotal;
NbTriBTotal = NbTriATotal;
NbTriATotal = Nb;
Nb = NbFaces2;
NbFaces2 = NbFaces1;
NbFaces1 = Nb;
}
//-----------------------------------------------------------------
//-- Tableaux des sommets des NbTriATotal triangles du shape 1
//-----------------------------------------------------------------
TColgp_Array1OfPnt TA1(1,NbTriATotal);
TColgp_Array1OfPnt TA2(1,NbTriATotal);
TColgp_Array1OfPnt TA3(1,NbTriATotal);
//-----------------------------------------------------------------
//-- Tableaux des MinMax des NbTriATotal triangles du shape 1
//-----------------------------------------------------------------
TColStd_Array1OfReal MinAx(1,NbTriATotal);
TColStd_Array1OfReal MinAy(1,NbTriATotal);
TColStd_Array1OfReal MinAz(1,NbTriATotal);
TColStd_Array1OfReal MaxAx(1,NbTriATotal);
TColStd_Array1OfReal MaxAy(1,NbTriATotal);
TColStd_Array1OfReal MaxAz(1,NbTriATotal);
//-----------------------------------------------------------------
//-- Tableaux des MinMax des NbFaces1 faces du shape 1
//-----------------------------------------------------------------
TColStd_Array1OfReal MinFAx(1,NbFaces1);
TColStd_Array1OfReal MinFAy(1,NbFaces1);
TColStd_Array1OfReal MinFAz(1,NbFaces1);
TColStd_Array1OfReal MaxFAx(1,NbFaces1);
TColStd_Array1OfReal MaxFAy(1,NbFaces1);
TColStd_Array1OfReal MaxFAz(1,NbFaces1);
//-----------------------------------------------------------------
//-- Tableau contenant le nombre de triangles des faces du shape 1
//-----------------------------------------------------------------
TColStd_Array1OfInteger TNbTr1(1,NbFaces1);
//-----------------------------------------------------------------
//-- Preparation : Mise a jour des tableaux et calcul des MinMax
//-----------------------------------------------------------------
NbTriATotal = NbFaces1 = 0;
for (ex1.Init(myShape1,TopAbs_FACE);ex1.More();ex1.Next()) {
Tr1 = (BRep_Tool::Triangulation(TopoDS::Face(ex1.Current()),Loc1));
if (!Tr1.IsNull()) {
NbTrian1 = Tr1->NbTriangles();
NbFaces1++;
TNbTr1.SetValue(NbFaces1,NbTrian1);
const Poly_Array1OfTriangle& TabTrian1 = Tr1->Triangles();
const TColgp_Array1OfPnt& TabNodes1 = Tr1->Nodes();
minfx = minfy = minfz = -Big;
maxfx = maxfy = maxfz = Big;
for (i = 1;i <= NbTrian1;i++) {
TabTrian1(i).Get(i1,i2,i3);
NbTriATotal++;
TA1.SetValue(NbTriATotal,TabNodes1(i1).Transformed(Loc1.Transformation()));
TA2.SetValue(NbTriATotal,TabNodes1(i2).Transformed(Loc1.Transformation()));
TA3.SetValue(NbTriATotal,TabNodes1(i3).Transformed(Loc1.Transformation()));
MINMAX(TA1.Value(NbTriATotal).X(),
TA2.Value(NbTriATotal).X(),
TA3.Value(NbTriATotal).X(),min,max);
MinAx.SetValue(NbTriATotal,min);
MaxAx.SetValue(NbTriATotal,max);
if (min < minfx) minfx = min;
if (max > maxfx) maxfx = max;
MINMAX(TA1.Value(NbTriATotal).Y(),
TA2.Value(NbTriATotal).Y(),
TA3.Value(NbTriATotal).Y(),min,max);
MinAy.SetValue(NbTriATotal,min);
MaxAy.SetValue(NbTriATotal,max);
if (min < minfy) minfy = min;
if (max > maxfy) maxfy = max;
MINMAX(TA1.Value(NbTriATotal).Z(),
TA2.Value(NbTriATotal).Z(),
TA3.Value(NbTriATotal).Z(),min,max);
MinAz.SetValue(NbTriATotal,min);
MaxAz.SetValue(NbTriATotal,max);
if (min < minfz) minfz = min;
if (max > maxfz) maxfz = max;
}
MinFAx.SetValue(NbFaces1,minfx);
MaxFAx.SetValue(NbFaces1,maxfx);
MinFAy.SetValue(NbFaces1,minfy);
MaxFAy.SetValue(NbFaces1,maxfy);
MinFAz.SetValue(NbFaces1,minfz);
MaxFAz.SetValue(NbFaces1,maxfz);
}
}
//-----------------------------------------------------------------
//-- Tableaux des sommets des NbTriBTotal triangles du shape 2
//-----------------------------------------------------------------
TColgp_Array1OfPnt TB1(1,NbTriBTotal);
TColgp_Array1OfPnt TB2(1,NbTriBTotal);
TColgp_Array1OfPnt TB3(1,NbTriBTotal);
//-----------------------------------------------------------------
//-- Tableaux des MinMax des NbTriBTotal triangles du shape 2
//-----------------------------------------------------------------
TColStd_Array1OfReal MinBx(1,NbTriBTotal);
TColStd_Array1OfReal MinBy(1,NbTriBTotal);
TColStd_Array1OfReal MinBz(1,NbTriBTotal);
TColStd_Array1OfReal MaxBx(1,NbTriBTotal);
TColStd_Array1OfReal MaxBy(1,NbTriBTotal);
TColStd_Array1OfReal MaxBz(1,NbTriBTotal);
//-----------------------------------------------------------------
//-- Tableaux des MinMax des NbFaces2 faces du shape 2
//-----------------------------------------------------------------
TColStd_Array1OfReal MinFBx(1,NbFaces2);
TColStd_Array1OfReal MinFBy(1,NbFaces2);
TColStd_Array1OfReal MinFBz(1,NbFaces2);
TColStd_Array1OfReal MaxFBx(1,NbFaces2);
TColStd_Array1OfReal MaxFBy(1,NbFaces2);
TColStd_Array1OfReal MaxFBz(1,NbFaces2);
//-----------------------------------------------------------------
//-- Tableau contenant le nombre de triangles des faces du shape 2
//-----------------------------------------------------------------
TColStd_Array1OfInteger TNbTr2(1,NbFaces2);
//-----------------------------------------------------------------
//-- Preparation : Mise a jour des tableaux et calcul des MinMax
//-----------------------------------------------------------------
NbTriBTotal = NbFaces2 = 0;
for (ex2.Init(myShape2,TopAbs_FACE);ex2.More();ex2.Next()) {
Tr2 = (BRep_Tool::Triangulation(TopoDS::Face(ex2.Current()),Loc2));
if (!Tr2.IsNull()) {
NbTrian2 = Tr2->NbTriangles();
NbFaces2++;
TNbTr2.SetValue(NbFaces2,NbTrian2);
const Poly_Array1OfTriangle& TabTrian2 = Tr2->Triangles();
const TColgp_Array1OfPnt& TabNodes2 = Tr2->Nodes();
minfx = minfy = minfz = -Big;
maxfx = maxfy = maxfz = Big;
for (j = 1;j <= NbTrian2;j++) {
TabTrian2(j).Get(j1,j2,j3);
NbTriBTotal++;
TB1.SetValue(NbTriBTotal,TabNodes2(j1).Transformed(Loc2.Transformation()));
TB2.SetValue(NbTriBTotal,TabNodes2(j2).Transformed(Loc2.Transformation()));
TB3.SetValue(NbTriBTotal,TabNodes2(j3).Transformed(Loc2.Transformation()));
MINMAX(TB1.Value(NbTriBTotal).X(),
TB2.Value(NbTriBTotal).X(),
TB3.Value(NbTriBTotal).X(),min,max);
MinBx.SetValue(NbTriBTotal,min);
MaxBx.SetValue(NbTriBTotal,max);
if (min < minfx) minfx = min;
if (max > maxfx) maxfx = max;
MINMAX(TB1.Value(NbTriBTotal).Y(),
TB2.Value(NbTriBTotal).Y(),
TB3.Value(NbTriBTotal).Y(),min,max);
MinBy.SetValue(NbTriBTotal,min);
MaxBy.SetValue(NbTriBTotal,max);
if (min < minfy) minfy = min;
if (max > maxfy) maxfy = max;
MINMAX(TB1.Value(NbTriBTotal).Z(),
TB2.Value(NbTriBTotal).Z(),
TB3.Value(NbTriBTotal).Z(),min,max);
MinBz.SetValue(NbTriBTotal,min);
MaxBz.SetValue(NbTriBTotal,max);
if (min < minfz) minfz = min;
if (max > maxfz) maxfz = max;
}
MinFBx.SetValue(NbFaces2,minfx);
MaxFBx.SetValue(NbFaces2,maxfx);
MinFBy.SetValue(NbFaces2,minfy);
MaxFBy.SetValue(NbFaces2,maxfy);
MinFBz.SetValue(NbFaces2,minfz);
MaxFBz.SetValue(NbFaces2,maxfz);
}
}
Standard_Integer ii,jj,fi,fj;
i = j = 0;
for (fi = 1;fi <= NbFaces1;fi++) {
NbTrian1 = TNbTr1.Value(fi);
i += NbTrian1;
j = 0;
for (fj = 1;fj <= NbFaces2;fj++) {
NbTrian2 = TNbTr2.Value(fj);
if (MinFAx.Value(fi) > MaxFBx.Value(fj) ||
MinFBx.Value(fj) > MaxFAx.Value(fi)) {
j += NbTrian2;
continue;
}
else {
if (MinFAy.Value(fi) > MaxFBy.Value(fj) ||
MinFBy.Value(fj) > MaxFAy.Value(fi)) {
j += NbTrian2;
continue;
}
else if (MinFAz.Value(fi) > MaxFBz.Value(fj) ||
MinFBz.Value(fj) > MaxFAz.Value(fi)) {
j += NbTrian2;
continue;
}
}
i -= NbTrian1;
j += NbTrian2;
for (ii = 1;ii <= NbTrian1;ii++) {
i++;
j -= NbTrian2;
const gp_Pnt& A1 = TA1.Value(i);
const gp_Pnt& A2 = TA2.Value(i);
const gp_Pnt& A3 = TA3.Value(i);
gp_Vec OA1(A1.X(), A1.Y(), A1.Z());
gp_Vec VA0 = gp_Vec(A1,A2);
gp_Vec VA = gp_Vec(A1,A3);
VA0.Cross(VA);
VA0.Normalize();
for (jj = 1;jj <= NbTrian2;jj++) {
j++;
if(MinAx.Value(i) > MaxBx.Value(j) ||
MinBx.Value(j) > MaxAx.Value(i)) {
continue;
}
else {
if (MinAy.Value(i) > MaxBy.Value(j) ||
MinBy.Value(j) > MaxAy.Value(i)) {
continue;
}
else if (MinAz.Value(i) > MaxBz.Value(j) ||
MinBz.Value(j) > MaxAz.Value(i)) {
continue;
}
}
const gp_Pnt& B1 = TB1.Value(j);
const gp_Pnt& B2 = TB2.Value(j);
const gp_Pnt& B3 = TB3.Value(j);
gp_Vec VB0(B1,B2);
gp_Vec VB(B1,B3);
VB0.Cross(VB);
VB0.Normalize();
gp_Vec OB1(B1.XYZ());
gp_Vec V1(B1,A1);
gp_Vec V2(B1,A2);
gp_Vec V3(B1,A3);
Standard_Real h1 = VB0.Dot(V1);
Standard_Real h2 = VB0.Dot(V2);
Standard_Real h3 = VB0.Dot(V3);
Standard_Real ah1 = Abs(h1);
Standard_Real ah2 = Abs(h2);
Standard_Real ah3 = Abs(h3);
if(!SAMESIGN(h1,h2,h3)) {
myFirstTime = Standard_True;
if (h1 == 0.0) {
if (IsInside(A1,B1,B2,B3,VB0)) {
myFirstTime = Standard_False;
myBegPoint = A1;
if (h2 == 0.0) {
if (IsInside(A2,B1,B2,B3,VB0)) {
if (!IsEqual(A2,myBegPoint)) {
myEndPoint = A2;
InsertInMap();
continue;
}
}
}
if (h3 == 0.0) {
if (IsInside(A3,B1,B2,B3,VB0)) {
if (!IsEqual(A3,myBegPoint)) {
myEndPoint = A3;
InsertInMap();
continue;
}
}
}
}
}
if (h2 == 0.0) { // h1 <> 0
if (IsInside(A2,B1,B2,B3,VB0)) {
myFirstTime = Standard_False;
myBegPoint = A2;
if (h3 == 0.0) {
if (IsInside(A3,B1,B2,B3,VB0)) {
if (!IsEqual(A3,myBegPoint)) {
myEndPoint = A3;
InsertInMap();
continue;
}
}
}
}
}
if (h3 == 0.0) { // h1 <> 0 and h2 <> 0
if (IsInside(A3,B1,B2,B3,VB0)) {
myFirstTime = Standard_False;
myBegPoint = A3;
}
}
if (Intersect(B1,B2,B3,OB1,VB0,V1,V2,h1,h2,ah1,ah2))
continue;
if (Intersect(B1,B2,B3,OB1,VB0,V2,V3,h2,h3,ah2,ah3))
continue;
if (Intersect(B1,B2,B3,OB1,VB0,V3,V1,h3,h1,ah3,ah1))
continue;
V1 = gp_Vec(A1,B1);
V2 = gp_Vec(A1,B2);
V3 = gp_Vec(A1,B3);
h1 = VA0.Dot(V1);
h2 = VA0.Dot(V2);
h3 = VA0.Dot(V3);
ah1 = Abs(h1);
ah2 = Abs(h2);
ah3 = Abs(h3);
if(!SAMESIGN(h1,h2,h3)) {
if (h1 == 0.0) {
if (IsInside(B1,A1,A2,A3,VA0)) {
if (myFirstTime) {
myFirstTime = Standard_False;
myBegPoint = B1;
}
else {
if (!IsEqual(B1,myBegPoint)) {
myEndPoint = B1;
InsertInMap();
continue;
}
}
if (h2 == 0.0) {
if (IsInside(B2,A1,A2,A3,VA0)) {
if (!IsEqual(B2,myBegPoint)) {
myEndPoint = B2;
InsertInMap();
continue;
}
}
}
if (h3 == 0.0) {
if (IsInside(B3,A1,A2,A3,VA0)) {
if (!IsEqual(B3,myBegPoint)) {
myEndPoint = B3;
InsertInMap();
continue;
}
}
}
}
}
if (h2 == 0.0) { // h1 <> 0
if (IsInside(B2,A1,A2,A3,VA0)) {
if (myFirstTime) {
myFirstTime = Standard_False;
myBegPoint = B2;
}
else {
if (!IsEqual(B2,myBegPoint)) {
myEndPoint = B2;
InsertInMap();
continue;
}
}
if (h3 == 0.0) {
if (IsInside(B3,A1,A2,A3,VA0)) {
if (!IsEqual(B3,myBegPoint)) {
myEndPoint = B3;
InsertInMap();
continue;
}
}
}
}
}
if (h3 == 0.0) { // h1 <> 0 and h2 <> 0
if (IsInside(B3,A1,A2,A3,VA0)) {
if (myFirstTime) {
myBegPoint = B3;
myFirstTime = Standard_False;
}
else {
if (!IsEqual(B3,myBegPoint)) {
myEndPoint = B3;
InsertInMap();
continue;
}
}
}
}
if (Intersect(A1,A2,A3,OA1,VA0,V1,V2,h1,h2,ah1,ah2))
continue;
if (Intersect(A1,A2,A3,OA1,VA0,V2,V3,h2,h3,ah2,ah3))
continue;
if (Intersect(A1,A2,A3,OA1,VA0,V3,V1,h3,h1,ah3,ah1))
continue;
}
}
}
}
}
}
}
//=======================================================================
//function : Intersect
//purpose :
//=======================================================================
#define DIFFSIGN(a,b) (((a)>0.0 && (b)<0.0) || ((a)<0.0 && (b)>0.0))
Standard_Boolean IntPoly_ShapeSection::Intersect(const gp_Pnt& S1,
const gp_Pnt& S2,
const gp_Pnt& S3,
const gp_Vec& OS1,
const gp_Vec& VS0,
const gp_Vec& V1,
const gp_Vec& V2,
Standard_Real& h1,
Standard_Real& h2,
Standard_Real& ah1,
Standard_Real& ah2)
{
if (DIFFSIGN(h1,h2)) {
gp_XYZ OP;
OP.SetLinearForm(ah2/(ah1+ah2),V1.XYZ(),
ah1/(ah1+ah2),V2.XYZ(),
OS1.XYZ());
gp_Pnt P(OP.X(),OP.Y(),OP.Z());
if (IsInside(P,S1,S2,S3,VS0)) {
if (myFirstTime) {
myFirstTime = Standard_False;
myBegPoint = P;
}
else {
if (!IsEqual(P,myBegPoint)) {
myEndPoint = P;
InsertInMap();
return (Standard_True);
}
}
}
}
return (Standard_False);
}
//=======================================================================
//function : IsEqual
//purpose :
//=======================================================================
#define epsilon 0.000000000001
Standard_Boolean IntPoly_ShapeSection::IsEqual(const gp_Pnt& Pt1, const gp_Pnt& Pt2)
{
return (((Pt1.X() <= Pt2.X() && Pt2.X() < Pt1.X()+epsilon) ||
(Pt2.X() <= Pt1.X() && Pt1.X() < Pt2.X()+epsilon)) &&
((Pt1.Y() <= Pt2.Y() && Pt2.Y() < Pt1.Y()+epsilon) ||
(Pt2.Y() <= Pt1.Y() && Pt1.Y() < Pt2.Y()+epsilon)) &&
((Pt1.Z() <= Pt2.Z() && Pt2.Z() < Pt1.Z()+epsilon) ||
(Pt2.Z() <= Pt1.Z() && Pt1.Z() < Pt2.Z()+epsilon)));
}
//=======================================================================
//function : IsInside
//purpose :
//=======================================================================
static Standard_Boolean IsInside1(Standard_Real PU,
Standard_Real PV,
Standard_Real *Pu,
Standard_Real *Pv)
{
Standard_Real u = Pu[0] - PU;
Standard_Real v = Pv[0] - PV;
Standard_Real nu,nv;
Standard_Integer SH = (v < 0.0)? -1 : 1;
Standard_Integer NH,i,ip1 = 1;
Standard_Integer NbCrossing = 0;
for (i = 0;i < 3;i++,ip1++) {
nu = Pu[ip1] - PU;
nv = Pv[ip1] - PV;
NH = (nv < 0.0)? -1 : 1;
if (NH != SH) {
if (u > 0.0 && nu > 0.0) NbCrossing++;
else if (u > 0.0 || nu > 0.0)
if ((u - v * (nu - u) / (nv - v)) > 0.0) NbCrossing++;
SH = NH;
}
u = nu;
v = nv;
}
return (NbCrossing & 1);
}
#define TOLBRUIT 0.00000000000001
Standard_Boolean IntPoly_ShapeSection::IsInside(const gp_Pnt& P,
const gp_Pnt& P1,
const gp_Pnt& P2,
const gp_Pnt& P3,
const gp_Vec& N0)
{
if (IsEqual(P,P1) || IsEqual(P,P2) || IsEqual(P,P3))
return(Standard_True);
Standard_Real Nx = Abs(N0.X());
Standard_Real Ny = Abs(N0.Y());
Standard_Real Nz = Abs(N0.Z());
Standard_Real PU,PV,Pu[4],Pv[4];
Standard_Integer Ind = 1; //-- 1:x 2:y 3:z
if (Nx > Ny) { //-- x or z
if (Nx > Nz) Ind = 1;
else Ind = 3;
}
else { //-- y or z
if (Ny > Nz) Ind = 2;
else Ind = 3;
}
if (Ind == 1) {
PU = P.Y();
PV = P.Z();
Pu[0] = Pu[3] = P1.Y();
Pv[0] = Pv[3] = P1.Z();
Pu[1] = P2.Y();
Pv[1] = P2.Z();
Pu[2] = P3.Y();
Pv[2] = P3.Z();
}
else if (Ind == 2) {
PU = P.Z();
PV = P.X();
Pu[0] = Pu[3] = P1.Z();
Pv[0] = Pv[3] = P1.X();
Pu[1] = P2.Z();
Pv[1] = P2.X();
Pu[2] = P3.Z();
Pv[2] = P3.X();
}
else {
PU = P.X();
PV = P.Y();
Pu[0] = Pu[3] = P1.X();
Pv[0] = Pv[3] = P1.Y();
Pu[1] = P2.X();
Pv[1] = P2.Y();
Pu[2] = P3.X();
Pv[2] = P3.Y();
}
if (IsInside1(PU,PV,Pu,Pv))
return(Standard_True);
if (IsInside1(PU+TOLBRUIT,PV,Pu,Pv))
return(Standard_True);
if (IsInside1(PU-TOLBRUIT,PV,Pu,Pv))
return(Standard_True);
if (IsInside1(PU,PV+TOLBRUIT,Pu,Pv))
return(Standard_True);
if (IsInside1(PU,PV-TOLBRUIT,Pu,Pv))
return(Standard_True);
return(Standard_False);
}
//=======================================================================
//function : InsertInMap
//purpose :
//=======================================================================
void IntPoly_ShapeSection::InsertInMap()
{
Standard_Integer Index;
Standard_Real Big = Precision::Infinite();
if (myMapBegPoints.Contains(myBegPoint)) {
Index = myMapBegPoints.FindIndex(myBegPoint);
Insert(myMapEndPoints.FindKey(Index),myBegPoint,myEndPoint);
myCpt++;
myMapBegPoints.Substitute(Index,gp_Pnt(Big,myCpt,myCpt));
myMapEndPoints.Substitute(Index,gp_Pnt(Big,myCpt,myCpt));
}
else if (myMapEndPoints.Contains(myEndPoint)) {
Index = myMapEndPoints.FindIndex(myEndPoint);
Insert(myMapBegPoints.FindKey(Index),myEndPoint,myBegPoint);
myCpt++;
myMapBegPoints.Substitute(Index,gp_Pnt(Big,myCpt,myCpt));
myMapEndPoints.Substitute(Index,gp_Pnt(Big,myCpt,myCpt));
}
else {
myMapBegPoints.Add(myBegPoint);
myMapEndPoints.Add(myEndPoint);
}
}
//=======================================================================
//function : Insert
//purpose :
//=======================================================================
void IntPoly_ShapeSection::Insert(const gp_Pnt& OldPnt,
const gp_Pnt& ComPnt,
const gp_Pnt& NewPnt)
{
Standard_Integer i = 0;
Standard_Integer NbSection = mySection.Length();
Standard_Boolean IsInSection = Standard_False;
while (i < NbSection) {
i++;
TColgp_SequenceOfPnt& CurSection = mySection.ChangeValue(i);
if (IsEqual(OldPnt,CurSection.First())) {
IsInSection = Standard_True;
CurSection.Prepend(ComPnt);
CurSection.Prepend(NewPnt);
break;
}
if (IsEqual(OldPnt,CurSection.Last())) {
IsInSection = Standard_True;
CurSection.Append(ComPnt);
CurSection.Append(NewPnt);
break;
}
if (IsEqual(NewPnt,CurSection.First())) {
IsInSection = Standard_True;
CurSection.Prepend(ComPnt);
CurSection.Prepend(OldPnt);
break;
}
if (IsEqual(NewPnt,CurSection.Last())) {
IsInSection = Standard_True;
CurSection.Append(ComPnt);
CurSection.Append(OldPnt);
break;
}
}
if (!(IsInSection)) {
TColgp_SequenceOfPnt EmptySec;
EmptySec.Append(OldPnt);
EmptySec.Append(ComPnt);
EmptySec.Append(NewPnt);
mySection.Append(EmptySec);
}
}
//=======================================================================
//function : Concat
//purpose :
//=======================================================================
Standard_Integer IntPoly_ShapeSection::Concat(const gp_Pnt& BegPnt,
const gp_Pnt& EndPnt,
gp_Pnt& OutPnt)
{
Standard_Integer i = 0;
Standard_Integer NbSection = mySection.Length();
Standard_Integer ConcatIdx = 0;
while (i < NbSection) {
i++;
TColgp_SequenceOfPnt& CurSection = mySection.ChangeValue(i);
if (IsEqual(BegPnt,CurSection.First())) {
ConcatIdx = 1;
myIndex = i;
CurSection.Prepend(EndPnt);
OutPnt = EndPnt;
break;
}
if (IsEqual(BegPnt,CurSection.Last())) {
ConcatIdx = 2;
myIndex = i;
CurSection.Append(EndPnt);
OutPnt = EndPnt;
break;
}
if (IsEqual(EndPnt,CurSection.First())) {
ConcatIdx = 1;
myIndex = i;
CurSection.Prepend(BegPnt);
OutPnt = BegPnt;
break;
}
if (IsEqual(EndPnt,CurSection.Last())) {
ConcatIdx = 2;
myIndex = i;
CurSection.Append(BegPnt);
OutPnt = BegPnt;
break;
}
}
if (ConcatIdx == 0) {
TColgp_SequenceOfPnt EmptySec;
EmptySec.Append(BegPnt);
EmptySec.Append(EndPnt);
mySection.Append(EmptySec);
NbSection++;
myIndex = NbSection;
}
return ConcatIdx;
}
//=======================================================================
//function : ConcatSection
//purpose :
//=======================================================================
void IntPoly_ShapeSection::ConcatSection(TColgp_SequenceOfPnt& Section,
const Standard_Integer NbSection,
const Standard_Integer Index)
{
Standard_Integer j;
Standard_Integer i = Index;
gp_Pnt BegPnt = Section.First();
gp_Pnt EndPnt = Section.Last();
while (i <= NbSection) {
TColgp_SequenceOfPnt& CurSection = mySection.ChangeValue(i);
Standard_Integer CurSection_Length = CurSection.Length();
if (IsEqual(BegPnt,CurSection.First())) {
for (j = 2;j <= CurSection_Length;j++)
Section.Prepend(CurSection.Value(j));
mySection.Remove(i);
ConcatSection(Section,NbSection-1,Index);
break;
}
else
if (IsEqual(BegPnt,CurSection.Last())) {
for (j = CurSection_Length-1;j >= 1;j--)
Section.Prepend(CurSection.Value(j));
mySection.Remove(i);
ConcatSection(Section,NbSection-1,Index);
break;
}
else
if (IsEqual(EndPnt,CurSection.First())) {
for (j = 2;j <= CurSection_Length;j++)
Section.Append(CurSection.Value(j));
mySection.Remove(i);
ConcatSection(Section,NbSection-1,Index);
break;
}
else
if (IsEqual(EndPnt,CurSection.Last())) {
for (j = CurSection_Length-1;j >= 1;j--)
Section.Append(CurSection.Value(j));
mySection.Remove(i);
ConcatSection(Section,NbSection-1,Index);
break;
}
i++;
}
}
//=======================================================================
//function : ForwContruction
//purpose :
//=======================================================================
void IntPoly_ShapeSection::ForwConstruction(const gp_Pnt& Point)
{
if (myMapBegPoints.Contains(Point)) {
Standard_Integer Index = myMapBegPoints.FindIndex(Point);
gp_Pnt Pnt = myMapEndPoints.FindKey(Index);
(mySection.ChangeValue(myIndex)).Append(Pnt);
Standard_Real Big = Precision::Infinite();
myCpt++;
myMapBegPoints.Substitute(Index,gp_Pnt(Big,myCpt,myCpt));
myMapEndPoints.Substitute(Index,gp_Pnt(Big,myCpt,myCpt));
ForwConstruction(Pnt);
}
}
//=======================================================================
//function : PrevContruction
//purpose :
//=======================================================================
void IntPoly_ShapeSection::PrevConstruction(const gp_Pnt& Point)
{
if (myMapEndPoints.Contains(Point)) {
Standard_Integer Index = myMapEndPoints.FindIndex(Point);
gp_Pnt Pnt = myMapBegPoints.FindKey(Index);
(mySection.ChangeValue(myIndex)).Prepend(Pnt);
Standard_Real Big = Precision::Infinite();
myCpt++;
myMapBegPoints.Substitute(Index,gp_Pnt(Big,myCpt,myCpt));
myMapEndPoints.Substitute(Index,gp_Pnt(Big,myCpt,myCpt));
PrevConstruction(Pnt);
}
}
//=======================================================================
//function : NbEdges
//purpose :
//=======================================================================
Standard_Integer IntPoly_ShapeSection::NbEdges()
{ return myNbEdges; }
//=======================================================================
//function : Edge
//purpose :
//=======================================================================
TopoDS_Edge IntPoly_ShapeSection::Edge(const Standard_Integer Index)
{
const TColgp_SequenceOfPnt& CurSection = mySection.ChangeValue(Index);
Standard_Integer NbPoints = CurSection.Length();
TColgp_Array1OfPnt TabPnt(1,NbPoints);
//gp_Pnt CurPoint;
for (Standard_Integer i = 1 ; i <= NbPoints ; i++) {
TabPnt.SetValue(i,CurSection.Value(i));
}
Handle(Poly_Polygon3D) Pol = new Poly_Polygon3D(TabPnt);
TopoDS_Edge Edge;
BRep_Builder B;
B.MakeEdge(Edge,Pol);
return Edge;
}

View File

@ -51,8 +51,6 @@
#include <Bnd_Box.hxx>
#include <Precision.hxx>
#include <Draw_Interpretor.hxx>
#include <IntPoly_PlaneSection.hxx>
#include <IntPoly_ShapeSection.hxx>
#include <Geom_Plane.hxx>
#include <Geom_Surface.hxx>
#include <Draw_Marker3D.hxx>
@ -117,66 +115,6 @@ OSD_Chronometer chAdd11, chAdd12, chAdd2, chUpdate, chPointValid;
OSD_Chronometer chIsos, chPointsOnIsos;
#endif
//=======================================================================
//function : shapesection
//purpose :
//=======================================================================
static Standard_Integer shapesection(Draw_Interpretor&, Standard_Integer nbarg, const char** argv)
{
if (nbarg < 4) return 1;
TopoDS_Shape S1 = DBRep::Get(argv[2]);
TopoDS_Shape S2 = DBRep::Get(argv[3]);
if (S1.IsNull() || S2.IsNull()) return 1;
IntPoly_ShapeSection SECTION(S1,S2);
// char name[100];
BRep_Builder B;
TopoDS_Compound C;
B.MakeCompound(C);
for (Standard_Integer i = 1 ; i <= SECTION.NbEdges() ; i++) {
TopoDS_Shape E = SECTION.Edge(i);
if (!E.IsNull()) B.Add(C,E);
}
DBRep::Set(argv[1],C);
return 0;
}
//=======================================================================
//function : planesection
//purpose :
//=======================================================================
static Standard_Integer planesection(Draw_Interpretor&, Standard_Integer nbarg, const char** argv)
{
if (nbarg < 4) return 1;
TopoDS_Shape S = DBRep::Get(argv[2]);
if (S.IsNull()) return 1;
Handle(Geom_Surface) Surf = DrawTrSurf::GetSurface(argv[3]);
Handle(Geom_Plane) pl = Handle(Geom_Plane)::DownCast(Surf);
if (!pl.IsNull()) {
IntPoly_PlaneSection SECTION(S,pl->Pln());
// char name[100];
BRep_Builder B;
TopoDS_Compound C;
B.MakeCompound(C);
for (Standard_Integer i = 1 ; i <= SECTION.NbEdges() ; i++) {
TopoDS_Shape E = SECTION.Edge(i);
if (!E.IsNull()) B.Add(C,E);
}
DBRep::Set(argv[1],C);
return 0;
}
else return 1;
}
//=======================================================================
//function : incrementalmesh
//purpose :
@ -1564,8 +1502,6 @@ void MeshTest::Commands(Draw_Interpretor& theCommands)
g = "Mesh Commands";
theCommands.Add("shpsec","shpsec result shape shape",__FILE__, shapesection, g);
theCommands.Add("plnsec","plnsec result shape plane",__FILE__, planesection, g);
theCommands.Add("incmesh","incmesh shape deflection [inParallel (0/1) : 0 by default]",__FILE__, incrementalmesh, g);
theCommands.Add("MemLeakTest","MemLeakTest",__FILE__, MemLeakTest, g);
theCommands.Add("fastdiscret","fastdiscret shape deflection [shared [nbiter]]",__FILE__, fastdiscret, g);

View File

@ -1,2 +1 @@
BRepMesh
IntPoly