2015-02-10 14:25:19 +05:00
|
|
|
// Copyright (C) 2007-2015 CEA/DEN, EDF R&D, OPEN CASCADE
|
2012-08-09 13:58:02 +06:00
|
|
|
//
|
|
|
|
// 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
|
|
|
|
//
|
2014-06-04 17:17:38 +06:00
|
|
|
// File : AdvancedEngine_IOperations.hxx
|
2012-08-09 13:58:02 +06:00
|
|
|
// Author : Vadim SANDLER, Open CASCADE S.A.S. (vadim.sandler@opencascade.com)
|
|
|
|
|
2014-06-04 17:17:38 +06:00
|
|
|
#ifndef _AdvancedEngine_IOperations_HXX_
|
|
|
|
#define _AdvancedEngine_IOperations_HXX_
|
|
|
|
|
|
|
|
#include "AdvancedEngine.hxx"
|
2012-08-09 13:58:02 +06:00
|
|
|
|
|
|
|
#include "GEOM_IOperations.hxx"
|
|
|
|
#include "GEOM_Engine.hxx"
|
|
|
|
#include "GEOM_Object.hxx"
|
|
|
|
|
2013-06-10 14:28:09 +06:00
|
|
|
#include <list>
|
2013-03-15 20:28:11 +06:00
|
|
|
#include <gp_Ax2.hxx>
|
|
|
|
|
2012-08-09 13:58:02 +06:00
|
|
|
class GEOMImpl_IBasicOperations;
|
|
|
|
class GEOMImpl_IBooleanOperations;
|
|
|
|
class GEOMImpl_IShapesOperations;
|
|
|
|
class GEOMImpl_ITransformOperations;
|
|
|
|
class GEOMImpl_IBlocksOperations;
|
|
|
|
class GEOMImpl_I3DPrimOperations;
|
|
|
|
class GEOMImpl_ILocalOperations;
|
|
|
|
class GEOMImpl_IHealingOperations;
|
2013-05-23 16:53:45 +06:00
|
|
|
class GEOMImpl_IGroupOperations;
|
|
|
|
class Handle_Geom_Surface;
|
|
|
|
class TopTools_ListOfShape;
|
2012-08-09 13:58:02 +06:00
|
|
|
|
2014-06-04 17:17:38 +06:00
|
|
|
class ADVANCEDENGINE_EXPORT AdvancedEngine_IOperations: public GEOM_IOperations
|
|
|
|
{
|
2012-08-09 13:58:02 +06:00
|
|
|
private:
|
|
|
|
bool MakePipeTShapePartition(Handle(GEOM_Object) theShape,
|
|
|
|
double theR1, double theW1, double theL1,
|
|
|
|
double theR2, double theW2, double theL2,
|
|
|
|
double theH = 0, double theW = 0,
|
|
|
|
double theRF = 0, bool isNormal = true);
|
2013-03-15 20:28:11 +06:00
|
|
|
|
2012-08-09 13:58:02 +06:00
|
|
|
bool MakePipeTShapeMirrorAndGlue(Handle(GEOM_Object) theShape,
|
|
|
|
double theR1, double theW1, double theL1,
|
|
|
|
double theR2, double theW2, double theL2);
|
2013-03-15 20:28:11 +06:00
|
|
|
|
|
|
|
bool MakePipeTShapeThicknessReduction (Handle(GEOM_Object) theShape,
|
|
|
|
double theR1, double theW1, double theL1,
|
|
|
|
double theR2, double theW2, double theL2,
|
|
|
|
double theRL, double theWL, double theLtransL, double theLthinL,
|
|
|
|
double theRR, double theWR, double theLtransR, double theLthinR,
|
|
|
|
double theRI, double theWI, double theLtransI, double theLthinI);
|
|
|
|
|
2012-08-09 13:58:02 +06:00
|
|
|
bool MakeGroups(Handle(GEOM_Object) theShape, int shapType,
|
|
|
|
double theR1, double theW1, double theL1,
|
|
|
|
double theR2, double theW2, double theL2,
|
2013-03-15 20:28:11 +06:00
|
|
|
double theH, double theW, double theRF,
|
2012-08-09 13:58:02 +06:00
|
|
|
Handle(TColStd_HSequenceOfTransient) theSeq,
|
|
|
|
gp_Trsf aTrsf);
|
2013-03-15 20:28:11 +06:00
|
|
|
|
2013-05-23 16:53:45 +06:00
|
|
|
bool GetFacesOnSurf(const TopoDS_Shape &theShape,
|
|
|
|
const Handle_Geom_Surface& theSurface,
|
|
|
|
const Standard_Real theTolerance,
|
|
|
|
TopTools_ListOfShape &theFaces);
|
|
|
|
|
|
|
|
TopoDS_Shape MakeConicalFace(const gp_Ax2 &theAxis,
|
|
|
|
const double theRadius,
|
|
|
|
const double theRadiusThin,
|
|
|
|
const double theHeight,
|
|
|
|
const gp_Trsf &theTrsf);
|
|
|
|
|
|
|
|
bool MakeInternalGroup(const Handle(GEOM_Object) &theShape,
|
|
|
|
const double theR1, const double theLen1,
|
|
|
|
const double theR2, const double theLen2,
|
|
|
|
const double theRL, const double theTransLenL,
|
|
|
|
const double theRR, const double theTransLenR,
|
|
|
|
const double theRI, const double theTransLenI,
|
|
|
|
const Handle(TColStd_HSequenceOfTransient) &theSeq,
|
|
|
|
const gp_Trsf &theTrsf);
|
|
|
|
|
2012-08-09 13:58:02 +06:00
|
|
|
gp_Trsf GetPositionTrsf(double theL1, double theL2,
|
|
|
|
Handle(GEOM_Object) P1 = 0,
|
|
|
|
Handle(GEOM_Object) P2 = 0,
|
|
|
|
Handle(GEOM_Object) P3 = 0);
|
2013-03-15 20:28:11 +06:00
|
|
|
|
2012-08-09 13:58:02 +06:00
|
|
|
bool CheckCompatiblePosition(double& theL1, double& theL2,
|
|
|
|
Handle(GEOM_Object) theP1,
|
|
|
|
Handle(GEOM_Object) theP2,
|
|
|
|
Handle(GEOM_Object) theP3,
|
|
|
|
double theTolerance);
|
2013-03-15 20:28:11 +06:00
|
|
|
|
2012-08-09 13:58:02 +06:00
|
|
|
private:
|
|
|
|
GEOMImpl_IBasicOperations* myBasicOperations;
|
|
|
|
GEOMImpl_IBooleanOperations* myBooleanOperations;
|
|
|
|
GEOMImpl_IShapesOperations* myShapesOperations;
|
|
|
|
GEOMImpl_ITransformOperations* myTransformOperations;
|
|
|
|
GEOMImpl_IBlocksOperations* myBlocksOperations;
|
|
|
|
GEOMImpl_I3DPrimOperations* my3DPrimOperations;
|
|
|
|
GEOMImpl_ILocalOperations* myLocalOperations;
|
|
|
|
GEOMImpl_IHealingOperations* myHealingOperations;
|
2013-05-23 16:53:45 +06:00
|
|
|
GEOMImpl_IGroupOperations* myGroupOperations;
|
2012-08-09 13:58:02 +06:00
|
|
|
|
2013-03-15 20:28:11 +06:00
|
|
|
public:
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Add three thickness reductions at the open ends of the pipe T-Shape
|
|
|
|
*
|
|
|
|
* \param theShape - the pipe T-Shape
|
|
|
|
* \param r1 - the internal radius of main pipe
|
|
|
|
* \param w1 - the thickness of main pipe
|
|
|
|
* \param l1 - the half-length of main pipe
|
|
|
|
* \param r2 - the internal radius of incident pipe
|
|
|
|
* \param w2 - the thickness of incident pipe
|
|
|
|
* \param l2 - the half-length of main pipe
|
|
|
|
* \param r*, w*, ltrans* and lthin* - internal radius, thickness, length of transition part
|
|
|
|
* and length of thin part of left(L), right(R) and
|
|
|
|
* incident(I) thickness reduction correspondingly
|
|
|
|
* \param fuseReductions - boolean flag (use true to generate single solid,
|
|
|
|
* false to obtain parts, useful for hexameshing)
|
|
|
|
* \retval TopoDS_Shape - Resulting shape
|
|
|
|
*/
|
2014-06-04 17:17:38 +06:00
|
|
|
static TopoDS_Shape MakePipeTShapeThicknessReduction
|
2013-03-15 20:28:11 +06:00
|
|
|
(TopoDS_Shape theShape,
|
|
|
|
double r1, double w1, double l1,
|
|
|
|
double r2, double w2, double l2,
|
|
|
|
double rL, double wL, double ltransL, double lthinL,
|
|
|
|
double rR, double wR, double ltransR, double lthinR,
|
|
|
|
double rI, double wI, double ltransI, double lthinI,
|
|
|
|
bool fuseReductions);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Create one thickness reduction element
|
|
|
|
*
|
|
|
|
* This method is called three times from MakePipeTShapeThicknessReduction
|
|
|
|
* to create three thickness reductions (one per each open end of a pipe T-Shape)
|
|
|
|
*
|
|
|
|
* \param theAxes - the position
|
|
|
|
* \param R - the internal radius of main pipe
|
|
|
|
* \param W - the thickness of main pipe
|
|
|
|
* \param Rthin - the internal radius of thin part
|
|
|
|
* \param Wthin - the thickness of thin part
|
|
|
|
* \param Ltrans - the length of transition part
|
|
|
|
* \param Lthin - the length of thin part
|
|
|
|
* \param fuse - boolean flag (use true to generate single solid,
|
|
|
|
* false to obtain parts, useful for hexameshing)
|
|
|
|
* \retval TopoDS_Shape - Resulting shape
|
|
|
|
*/
|
2014-06-04 17:17:38 +06:00
|
|
|
static TopoDS_Shape MakeThicknessReduction (gp_Ax2 theAxes,
|
|
|
|
const double R, const double W,
|
|
|
|
const double Rthin, const double Wthin,
|
|
|
|
const double Ltrans, const double Lthin,
|
|
|
|
bool fuse);
|
|
|
|
|
2012-08-09 13:58:02 +06:00
|
|
|
public:
|
2014-06-04 17:17:38 +06:00
|
|
|
AdvancedEngine_IOperations(GEOM_Engine* theEngine, int theDocID);
|
|
|
|
~AdvancedEngine_IOperations();
|
2012-08-09 13:58:02 +06:00
|
|
|
|
2014-06-04 17:17:38 +06:00
|
|
|
Handle(TColStd_HSequenceOfTransient)
|
2012-08-09 13:58:02 +06:00
|
|
|
MakePipeTShape(double theR1, double theW1, double theL1,
|
|
|
|
double theR2, double theW2, double theL2,
|
2013-03-15 20:28:11 +06:00
|
|
|
double theRL, double theWL, double theLtransL, double theLthinL,
|
|
|
|
double theRR, double theWR, double theLtransR, double theLthinR,
|
|
|
|
double theRI, double theWI, double theLtransI, double theLthinI,
|
2012-08-09 13:58:02 +06:00
|
|
|
bool theHexMesh = true);
|
2013-03-15 20:28:11 +06:00
|
|
|
|
2014-06-04 17:17:38 +06:00
|
|
|
Handle(TColStd_HSequenceOfTransient)
|
2012-08-09 13:58:02 +06:00
|
|
|
MakePipeTShapeWithPosition(double theR1, double theW1, double theL1,
|
|
|
|
double theR2, double theW2, double theL2,
|
2013-03-15 20:28:11 +06:00
|
|
|
double theRL, double theWL, double theLtransL, double theLthinL,
|
|
|
|
double theRR, double theWR, double theLtransR, double theLthinR,
|
|
|
|
double theRI, double theWI, double theLtransI, double theLthinI,
|
2012-08-09 13:58:02 +06:00
|
|
|
bool theHexMesh = true,
|
|
|
|
Handle(GEOM_Object) P1 = 0,
|
|
|
|
Handle(GEOM_Object) P2 = 0,
|
|
|
|
Handle(GEOM_Object) P3 = 0);
|
2013-03-15 20:28:11 +06:00
|
|
|
|
2014-06-04 17:17:38 +06:00
|
|
|
Handle(TColStd_HSequenceOfTransient)
|
2012-08-09 13:58:02 +06:00
|
|
|
MakePipeTShapeChamfer(double theR1, double theW1, double theL1,
|
|
|
|
double theR2, double theW2, double theL2,
|
2013-03-15 20:28:11 +06:00
|
|
|
double theRL, double theWL, double theLtransL, double theLthinL,
|
|
|
|
double theRR, double theWR, double theLtransR, double theLthinR,
|
|
|
|
double theRI, double theWI, double theLtransI, double theLthinI,
|
2012-08-09 13:58:02 +06:00
|
|
|
double theH, double theW,
|
|
|
|
bool theHexMesh = true);
|
2013-03-15 20:28:11 +06:00
|
|
|
|
2014-06-04 17:17:38 +06:00
|
|
|
Handle(TColStd_HSequenceOfTransient)
|
2012-08-09 13:58:02 +06:00
|
|
|
MakePipeTShapeChamferWithPosition(double theR1, double theW1, double theL1,
|
|
|
|
double theR2, double theW2, double theL2,
|
|
|
|
double theH, double theW,
|
2013-03-15 20:28:11 +06:00
|
|
|
double theRL, double theWL, double theLtransL, double theLthinL,
|
|
|
|
double theRR, double theWR, double theLtransR, double theLthinR,
|
|
|
|
double theRI, double theWI, double theLtransI, double theLthinI,
|
2012-08-09 13:58:02 +06:00
|
|
|
bool theHexMesh = true,
|
|
|
|
Handle(GEOM_Object) P1 = 0,
|
|
|
|
Handle(GEOM_Object) P2 = 0,
|
|
|
|
Handle(GEOM_Object) P3 = 0);
|
2013-03-15 20:28:11 +06:00
|
|
|
|
2014-06-04 17:17:38 +06:00
|
|
|
Handle(TColStd_HSequenceOfTransient)
|
2012-08-09 13:58:02 +06:00
|
|
|
MakePipeTShapeFillet(double theR1, double theW1, double theL1,
|
|
|
|
double theR2, double theW2, double theL2,
|
2013-03-15 20:28:11 +06:00
|
|
|
double theRL, double theWL, double theLtransL, double theLthinL,
|
|
|
|
double theRR, double theWR, double theLtransR, double theLthinR,
|
|
|
|
double theRI, double theWI, double theLtransI, double theLthinI,
|
2012-08-09 13:58:02 +06:00
|
|
|
double theRF, bool theHexMesh = true);
|
2013-03-15 20:28:11 +06:00
|
|
|
|
2014-06-04 17:17:38 +06:00
|
|
|
Handle(TColStd_HSequenceOfTransient)
|
2012-08-09 13:58:02 +06:00
|
|
|
MakePipeTShapeFilletWithPosition(double theR1, double theW1, double theL1,
|
|
|
|
double theR2, double theW2, double theL2,
|
2013-03-15 20:28:11 +06:00
|
|
|
double theRL, double theWL, double theLtransL, double theLthinL,
|
|
|
|
double theRR, double theWR, double theLtransR, double theLthinR,
|
|
|
|
double theRI, double theWI, double theLtransI, double theLthinI,
|
2012-08-09 13:58:02 +06:00
|
|
|
double theRF, bool theHexMesh = true,
|
|
|
|
Handle(GEOM_Object) P1 = 0,
|
|
|
|
Handle(GEOM_Object) P2 = 0,
|
|
|
|
Handle(GEOM_Object) P3 = 0);
|
|
|
|
|
2014-06-04 17:17:38 +06:00
|
|
|
Handle(GEOM_Object) MakeDividedDisk (double theR, double theRatio,
|
|
|
|
int theOrientation, int thePattern);
|
|
|
|
Handle(GEOM_Object) MakeDividedDiskPntVecR (Handle(GEOM_Object) thePnt,
|
|
|
|
Handle(GEOM_Object) theVec,
|
|
|
|
double theR,
|
|
|
|
double theRatio,
|
|
|
|
int thePattern);
|
2012-08-09 13:58:02 +06:00
|
|
|
|
2014-06-04 17:17:38 +06:00
|
|
|
Handle(GEOM_Object) MakeDividedCylinder (double theR,
|
|
|
|
double theH,
|
|
|
|
int thePattern);
|
2012-08-09 13:58:02 +06:00
|
|
|
|
2014-06-04 17:17:38 +06:00
|
|
|
Handle(GEOM_Object) MakeSmoothingSurface (std::list<Handle(GEOM_Object)> thelPoints,
|
|
|
|
int theNbMax,
|
|
|
|
int theDegMax,
|
|
|
|
double theDMax);
|
2012-08-09 13:58:02 +06:00
|
|
|
};
|
2014-06-04 17:17:38 +06:00
|
|
|
|
2012-08-09 13:58:02 +06:00
|
|
|
#endif
|