// Created on: 1994-06-17 // Created by: Modeling // Copyright (c) 1994-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 License 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 #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include //======================================================================= //function : BRepFilletAPI_MakeFillet //purpose : //======================================================================= BRepFilletAPI_MakeFillet::BRepFilletAPI_MakeFillet(const TopoDS_Shape& S, const ChFi3d_FilletShape FShape): myBuilder(S,FShape) { } //======================================================================= //function : SetParams //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::SetParams(const Standard_Real Tang, const Standard_Real Tesp, const Standard_Real T2d, const Standard_Real TApp3d, const Standard_Real TolApp2d, const Standard_Real Fleche) { myBuilder.SetParams(Tang,Tesp, T2d, TApp3d, TolApp2d, Fleche); } //======================================================================= //function : SetContinuity //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::SetContinuity( const GeomAbs_Shape InternalContinuity, const Standard_Real AngleTol) { myBuilder.SetContinuity(InternalContinuity, AngleTol ); } //======================================================================= //function : Add //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::Add(const TopoDS_Edge& E) { myBuilder.Add(E); } //======================================================================= //function : Add //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::Add(const Standard_Real Radius, const TopoDS_Edge& E) { //myBuilder.Add(Radius,E); myBuilder.Add(E); Standard_Integer IinC; Standard_Integer IC = myBuilder.Contains(E, IinC); if (IC) SetRadius( Radius, IC, IinC ); } //======================================================================= //function : Add //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::Add(const Standard_Real R1, const Standard_Real R2, const TopoDS_Edge& E) { myBuilder.Add(E); Standard_Integer IinC; Standard_Integer IC = myBuilder.Contains(E, IinC); if (IC) SetRadius(R1,R2,IC,IinC); } //======================================================================= //function : Add //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::Add(const Handle(Law_Function)& L, const TopoDS_Edge& E) { //myBuilder.Add(L,E); myBuilder.Add(E); Standard_Integer IinC; Standard_Integer IC = myBuilder.Contains(E, IinC); if (IC) SetRadius(L,IC,IinC); } //======================================================================= //function : Add //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::Add(const TColgp_Array1OfPnt2d& UandR, const TopoDS_Edge& E) { myBuilder.Add(E); Standard_Integer IinC; Standard_Integer IC = myBuilder.Contains(E, IinC); if (IC) SetRadius( UandR, IC, IinC ); } //======================================================================= //function : SetRadius //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::SetRadius(const Standard_Real Radius, const Standard_Integer IC, const Standard_Integer IinC) { gp_XY FirstUandR( 0., Radius ), LastUandR( 1., Radius ); myBuilder.SetRadius( FirstUandR, IC, IinC ); myBuilder.SetRadius( LastUandR, IC, IinC ); } //======================================================================= //function : SetRadius //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::SetRadius(const Standard_Real R1, const Standard_Real R2, const Standard_Integer IC, const Standard_Integer IinC) { Standard_Real r1, r2; if(Abs(R1-R2) < Precision::Confusion()) r1 = r2 = (R1+R2)*0.5; else { r1 = R1; r2 = R2; } gp_XY FirstUandR( 0., r1 ), LastUandR( 1., r2 ); myBuilder.SetRadius( FirstUandR, IC, IinC ); myBuilder.SetRadius( LastUandR, IC, IinC ); } //======================================================================= //function : SetRadius //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::SetRadius(const Handle(Law_Function)& L, const Standard_Integer IC, const Standard_Integer IinC) { myBuilder.SetRadius(L,IC,IinC); } //======================================================================= //function : SetRadius //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::SetRadius(const TColgp_Array1OfPnt2d& UandR, const Standard_Integer IC, const Standard_Integer IinC) { if(UandR.Length() == 1) SetRadius( UandR(UandR.Lower()).Y(), IC, IinC ); else if(UandR.Length() == 2) SetRadius( UandR(UandR.Lower()).Y(), UandR(UandR.Upper()).Y(), IC, IinC ); else{ Standard_Real Uf = UandR(UandR.Lower()).X(); Standard_Real Ul = UandR(UandR.Upper()).X(); for(Standard_Integer i = UandR.Lower(); i <= UandR.Upper(); i++){ Standard_Real Ucur = UandR(i).X(); Ucur = ( Ucur - Uf ) / ( Ul - Uf ); gp_XY newUandR( Ucur, UandR(i).Y() ); myBuilder.SetRadius( newUandR, IC, IinC ); } } } //======================================================================= //function : IsConstant //purpose : //======================================================================= Standard_Boolean BRepFilletAPI_MakeFillet::IsConstant(const Standard_Integer IC) { return myBuilder.IsConstant(IC); } //======================================================================= //function : Radius //purpose : //======================================================================= Standard_Real BRepFilletAPI_MakeFillet::Radius(const Standard_Integer IC) { return myBuilder.Radius(IC); } //======================================================================= //function : ResetContour //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::ResetContour(const Standard_Integer IC) { myBuilder.ResetContour(IC); } //======================================================================= //function : IsConstant //purpose : //======================================================================= Standard_Boolean BRepFilletAPI_MakeFillet::IsConstant(const Standard_Integer IC, const TopoDS_Edge& E) { return myBuilder.IsConstant(IC,E); } //======================================================================= //function : Radius //purpose : //======================================================================= Standard_Real BRepFilletAPI_MakeFillet::Radius(const Standard_Integer IC, const TopoDS_Edge& E) { return myBuilder.Radius(IC,E); } //======================================================================= //function : SetRadius //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::SetRadius(const Standard_Real Radius, const Standard_Integer IC, const TopoDS_Edge& E) { myBuilder.SetRadius(Radius,IC,E); } //======================================================================= //function : GetBounds //purpose : //======================================================================= Standard_Boolean BRepFilletAPI_MakeFillet::GetBounds(const Standard_Integer IC, const TopoDS_Edge& E, Standard_Real& F, Standard_Real& L) { return myBuilder.GetBounds(IC,E,F,L); } //======================================================================= //function : GetLaw //purpose : //======================================================================= Handle(Law_Function) BRepFilletAPI_MakeFillet::GetLaw(const Standard_Integer IC, const TopoDS_Edge& E) { return myBuilder.GetLaw(IC,E); } //======================================================================= //function : SetLaw //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::SetLaw(const Standard_Integer IC, const TopoDS_Edge& E, const Handle(Law_Function)& L) { myBuilder.SetLaw(IC,E, L); } //======================================================================= //function : SetRadius //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::SetRadius(const Standard_Real Radius, const Standard_Integer IC, const TopoDS_Vertex& V) { myBuilder.SetRadius(Radius,IC,V); } //======================================================================= //function : SetFilletShape //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::SetFilletShape(const ChFi3d_FilletShape FShape) { myBuilder.SetFilletShape(FShape); } //======================================================================= //function : GetFilletShape //purpose : //======================================================================= ChFi3d_FilletShape BRepFilletAPI_MakeFillet::GetFilletShape() const { return myBuilder.GetFilletShape(); } //======================================================================= //function : NbContours //purpose : //======================================================================= Standard_Integer BRepFilletAPI_MakeFillet::NbContours()const { return myBuilder.NbElements(); } //======================================================================= //function : Contour //purpose : //======================================================================= Standard_Integer BRepFilletAPI_MakeFillet::Contour(const TopoDS_Edge& E)const { return myBuilder.Contains(E); } //======================================================================= //function : NbEdges //purpose : //======================================================================= Standard_Integer BRepFilletAPI_MakeFillet::NbEdges(const Standard_Integer I)const { const Handle(ChFiDS_Spine)& Spine = myBuilder.Value(I); Standard_Integer n = Spine->NbEdges(); return n; } //======================================================================= //function : Edge //purpose : //======================================================================= const TopoDS_Edge& BRepFilletAPI_MakeFillet::Edge(const Standard_Integer I, const Standard_Integer J)const { const Handle(ChFiDS_Spine)& Spine = myBuilder.Value(I); const TopoDS_Edge& S = Spine->Edges(J); return S; } //======================================================================= //function : Remove //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::Remove(const TopoDS_Edge& E) { myBuilder.Remove(E); } //======================================================================= //function : Length //purpose : //======================================================================= Standard_Real BRepFilletAPI_MakeFillet::Length(const Standard_Integer IC)const { return myBuilder.Length(IC); } //======================================================================= //function : FirstVertex //purpose : //======================================================================= TopoDS_Vertex BRepFilletAPI_MakeFillet::FirstVertex(const Standard_Integer IC)const { return myBuilder.FirstVertex(IC); } //======================================================================= //function : LastVertex //purpose : //======================================================================= TopoDS_Vertex BRepFilletAPI_MakeFillet::LastVertex(const Standard_Integer IC)const { return myBuilder.LastVertex(IC); } //======================================================================= //function : Abscissa //purpose : //======================================================================= Standard_Real BRepFilletAPI_MakeFillet::Abscissa(const Standard_Integer IC, const TopoDS_Vertex& V)const { return myBuilder.Abscissa(IC,V); } //======================================================================= //function : RelativeAbscissa //purpose : //======================================================================= Standard_Real BRepFilletAPI_MakeFillet::RelativeAbscissa(const Standard_Integer IC, const TopoDS_Vertex& V)const { return myBuilder.RelativeAbscissa(IC,V); } //======================================================================= //function : ClosedAndTangent //purpose : //======================================================================= Standard_Boolean BRepFilletAPI_MakeFillet::ClosedAndTangent (const Standard_Integer IC)const { return myBuilder.ClosedAndTangent(IC); } //======================================================================= //function : Closed //purpose : //======================================================================= Standard_Boolean BRepFilletAPI_MakeFillet::Closed (const Standard_Integer IC)const { return myBuilder.Closed(IC); } //======================================================================= //function : Builder //purpose : //======================================================================= Handle(TopOpeBRepBuild_HBuilder) BRepFilletAPI_MakeFillet::Builder()const { return myBuilder.Builder(); } //======================================================================= //function : Build //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::Build() { myBuilder.Compute(); if(myBuilder.IsDone()) { Done(); myShape = myBuilder.Shape(); // creation of the Map. TopExp_Explorer ex; for (ex.Init(myShape, TopAbs_FACE); ex.More(); ex.Next()) { myMap.Add(ex.Current()); } } } //======================================================================= //function : Reset //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::Reset() { NotDone(); myBuilder.Reset(); myMap.Clear(); } //======================================================================= //function : NbSurfaces //purpose : //======================================================================= Standard_Integer BRepFilletAPI_MakeFillet::NbSurfaces() const { return (myBuilder.Builder()->DataStructure())->NbSurfaces(); } //======================================================================= //function : NewFaces //purpose : //======================================================================= const TopTools_ListOfShape& BRepFilletAPI_MakeFillet::NewFaces (const Standard_Integer I) { return (*(TopTools_ListOfShape*)&(myBuilder.Builder()->NewFaces(I))); } //======================================================================= //function : Simulate //purpose : //======================================================================= void BRepFilletAPI_MakeFillet::Simulate(const Standard_Integer IC) { myBuilder.Simulate(IC); } //======================================================================= //function : NbSurf //purpose : //======================================================================= Standard_Integer BRepFilletAPI_MakeFillet::NbSurf(const Standard_Integer IC)const { return myBuilder.NbSurf(IC); } //======================================================================= //function : Sect //purpose : //======================================================================= Handle(ChFiDS_SecHArray1) BRepFilletAPI_MakeFillet::Sect(const Standard_Integer IC, const Standard_Integer IS)const { return myBuilder.Sect(IC, IS); } //======================================================================= //function : Generated //purpose : //======================================================================= const TopTools_ListOfShape& BRepFilletAPI_MakeFillet::Generated (const TopoDS_Shape& EorV) { return myBuilder.Generated(EorV); } //======================================================================= //function : Modified //purpose : //======================================================================= const TopTools_ListOfShape& BRepFilletAPI_MakeFillet::Modified (const TopoDS_Shape& F) { myGenerated.Clear(); if (myBuilder.Builder()->IsSplit(F, TopAbs_OUT)) { TopTools_ListIteratorOfListOfShape It(myBuilder.Builder()->Splits(F, TopAbs_OUT)); for(;It.More();It.Next()) { myGenerated.Append(It.Value()); } } if (myBuilder.Builder()->IsSplit(F, TopAbs_IN)) { TopTools_ListIteratorOfListOfShape It(myBuilder.Builder()->Splits(F, TopAbs_IN)); for(;It.More();It.Next()) { myGenerated.Append(It.Value()); } } if (myBuilder.Builder()->IsSplit(F, TopAbs_ON)) { TopTools_ListIteratorOfListOfShape It(myBuilder.Builder()->Splits(F, TopAbs_ON)); for(;It.More();It.Next()) { myGenerated.Append(It.Value()); } } return myGenerated; } //======================================================================= //function : IsDeleted //purpose : //======================================================================= Standard_Boolean BRepFilletAPI_MakeFillet::IsDeleted(const TopoDS_Shape& F) { if (myMap.Contains(F) || myBuilder.Builder()->IsSplit (F, TopAbs_OUT) || myBuilder.Builder()->IsSplit (F, TopAbs_IN) || myBuilder.Builder()->IsSplit (F, TopAbs_ON)) return Standard_False; return Standard_True; } //======================================================================= //function : NbFaultyContours //purpose : //======================================================================= Standard_Integer BRepFilletAPI_MakeFillet::NbFaultyContours() const { return myBuilder.NbFaultyContours(); } //======================================================================= //function : FaultyContour //purpose : //======================================================================= Standard_Integer BRepFilletAPI_MakeFillet::FaultyContour(const Standard_Integer I) const { return myBuilder.FaultyContour(I); } //======================================================================= //function : NbComputedSurfaces //purpose : //======================================================================= Standard_Integer BRepFilletAPI_MakeFillet::NbComputedSurfaces(const Standard_Integer IC) const { return myBuilder.NbComputedSurfaces (IC); } //======================================================================= //function : ComputedSurface //purpose : //======================================================================= Handle(Geom_Surface) BRepFilletAPI_MakeFillet::ComputedSurface(const Standard_Integer IC, const Standard_Integer IS) const { return myBuilder.ComputedSurface(IC,IS); } //======================================================================= //function : NbFaultyVertices //purpose : //======================================================================= Standard_Integer BRepFilletAPI_MakeFillet::NbFaultyVertices() const { return myBuilder.NbFaultyVertices(); } //======================================================================= //function : FaultyVertex //purpose : //======================================================================= TopoDS_Vertex BRepFilletAPI_MakeFillet::FaultyVertex(const Standard_Integer IV) const { return myBuilder.FaultyVertex(IV); } //======================================================================= //function : HasResult //purpose : //======================================================================= Standard_Boolean BRepFilletAPI_MakeFillet::HasResult() const { return myBuilder.HasResult(); } //======================================================================= //function : BadShape //purpose : //======================================================================= TopoDS_Shape BRepFilletAPI_MakeFillet::BadShape()const { return myBuilder.BadShape(); } //======================================================================= //function : StripeStatus //purpose : //======================================================================= ChFiDS_ErrorStatus BRepFilletAPI_MakeFillet::StripeStatus(const Standard_Integer IC)const { return myBuilder.StripeStatus(IC); }