C3D Toolkit  Kernel - 117982, Vision - 2.9.2.2

Constructor of a shell by stitching the faces. More...

#include <cr_stitch_solid.h>

+ Inheritance diagram for MbStitchedSolid:
+ Collaboration diagram for MbStitchedSolid:

Public Member Functions

template<class CreatorsVectorPtr >
 MbStitchedSolid (const PArray< CreatorsVectorPtr > &creatorsData, bool tryClosed, double precision, const MbSNameMaker &names, bool edgesMerging)
 Constructor. More...
 
 MbStitchedSolid (const std::vector< c3d::CreatorsSPtrVector > &creatorsData, const MbShellStitchParams &stitchParams)
 Constructor. More...
 
MbeCreatorType IsA () const override
 Get the object type.
 
MbCreatorDuplicate (MbRegDuplicate *=nullptr) const override
 Create a copy of the object. More...
 
bool IsSame (const MbCreator &other, double accuracy) const override
 Determine whether an object is equal? More...
 
bool SetEqual (const MbCreator &) override
 Make the objects equal if they are similar.
 
void Transform (const MbMatrix3D &, MbRegTransform *=nullptr) override
 Transform according to the matrix. More...
 
void Move (const MbVector3D &, MbRegTransform *=nullptr) override
 Translate along a vector. More...
 
void Rotate (const MbAxis3D &, double angle, MbRegTransform *=nullptr) override
 Rotate an object about the axis. More...
 
void GetProperties (MbProperties &) override
 Get properties of the object.
 
void SetProperties (const MbProperties &) override
 Set properties of the object.
 
MbePrompt GetPropertyName () override
 Get a name of object property.
 
void GetBasisItems (RPArray< MbSpaceItem > &) override
 Get the basis objects.
 
void GetBasisPoints (MbControlData3D &) const override
 Get control points of object.
 
void SetBasisPoints (const MbControlData3D &) override
 Change the object by control points.
 
size_t GetCreatorsCount (MbeCreatorType ct) const override
 Count internal creators by type.
 
bool GetInternalCreators (MbeCreatorType, c3d::ConstCreatorsSPtrVector &) const override
 Get internal creators by type.
 
bool SetInternalCreators (MbeCreatorType, c3d::CreatorsSPtrVector &) override
 Get internal creators by type.
 
bool CreateShell (MbFaceShell *&shell, MbeCopyMode sameShell, RPArray< MbSpaceItem > *items=nullptr) override
 Create a shell from the initial data. More...
 
void SetYourVersion (VERSION version, bool forAll) override
 Set the objects version.
 
- Public Member Functions inherited from MbCreator
virtual ~MbCreator ()
 Destructor.
 
MbeRefType RefType () const override
 Get the registration type (for copying, duplication).
 
virtual MbeCreatorType Type () const
 Get the group type of the object.
 
virtual bool IsSimilar (const MbCreator &item) const
 Determine whether an object is similar? More...
 
bool CreateShell (c3d::ShellSPtr &shell, MbeCopyMode sameShell, RPArray< MbSpaceItem > *items=nullptr)
 Create a shell from the initial data. More...
 
virtual bool CreateWireFrame (MbWireFrame *&frame, MbeCopyMode sameShell, RPArray< MbSpaceItem > *items=nullptr)
 Create a wire-frame from the source data. More...
 
bool CreateWireFrame (SPtr< MbWireFrame > &frame, MbeCopyMode sameShell)
 Create a wire-frame from the source data. More...
 
virtual bool CreatePointFrame (MbPointFrame *&frame, MbeCopyMode sameShell, RPArray< MbSpaceItem > *items=nullptr)
 Create a point-frame from the source data. More...
 
bool CreatePointFrame (SPtr< MbPointFrame > &frame, MbeCopyMode sameShell)
 Create a point-frame from the source data. More...
 
virtual bool CreateMesh (MbMesh *&mesh, MbeCopyMode sameShell, RPArray< MbSpaceItem > *items=nullptr)
 Create a polygonal object from the source data. More...
 
bool CreateMesh (SPtr< MbMesh > &mesh, MbeCopyMode sameShell)
 Create a polygonal object from the source data. More...
 
virtual void Refresh (MbFaceShell &)
 Update the shell shape.
 
virtual void Refresh (MbWireFrame &)
 Update the frame shape.
 
virtual bool Perform (MbCreator *) const
 Displace/Change the creator.
 
VERSION GetYourVersion () const
 Get the object version.
 
const MbSNameMakerGetYourNameMaker () const
 Get the name-maker.
 
MbSNameMakerSetYourNameMaker ()
 Get the object's name-maker for editing.
 
void SetNameMaker (const MbSNameMaker &n)
 Set the object's name-maker.
 
SimpleName GetMainName () const
 Get the main name of the object.
 
void SetMainName (SimpleName n)
 Set the main name of the object.
 
MbeProcessState GetStatus () const
 Get the flag of state.
 
void SetStatus (MbeProcessState l)
 Set the flag of state.
 
void PrepareWrite () const
 Register the object. More...
 
- Public Member Functions inherited from MbRefItem
refcount_t GetUseCount () const
 Get count of references (get count of owners of an object).
 
refcount_t AddRef () const
 Increase count of references by one.
 
refcount_t DecRef () const
 Decrease count of references by one.
 
refcount_t Release () const
 Decrease count of references by one and if count of references became zero, then remove itself.
 
- Public Member Functions inherited from TapeBase
 TapeBase (RegistrableRec regs=noRegistrable)
 Constructor.
 
 TapeBase (const TapeBase &)
 Copy-constructor.
 
virtual ~TapeBase ()
 Destructor.
 
RegistrableRec GetRegistrable () const
 Whether the stream class is registrable.
 
void SetRegistrable (RegistrableRec regs=registrable) const
 Set the state of registration of the stream class.
 
virtual const char * GetPureName (const VersionContainer &) const
 Get the class name.
 
virtual bool IsFamilyRegistrable () const
 Whether the object belongs to a registrable family.
 

Additional Inherited Members

- Protected Member Functions inherited from MbCreator
 MbCreator (MbSNameMaker *)
 Constructor by name-maker.
 
 MbCreator (const MbSNameMaker &)
 Constructor by name-maker.
 
 MbCreator (const MbCreator &)
 Copy-constructor.
 
- Protected Member Functions inherited from MbRefItem
 MbRefItem ()
 Constructor without parameters.
 
- Protected Attributes inherited from MbCreator
SPtr< MbSNameMakernames
 An object defining the names of elements and objects created by the constructor.
 
MbeProcessState status
 State of the constructor and of the operation result.
 

Detailed Description

Constructor of a shell by stitching the faces.

Constructor of a shell by stitching the faces.
The operation takes open shells and separate faces as input data, and looks for the entirely or partially coincident edges among their boundary edges and "stitches" them, i.e. makes associations between faces, edges and vertices. During the operation edges and vertices can be defined more precisely by intersection of adjacent faces if necessary. The algorithm is the following:

  1. For each vertex the bounding box is calculated in which the search of the coincident vertices will be performed. This bounding box depends on the length of the edges adjacent to the vertex and on thickness of the thin wall if such a situation is detected.
  2. Using the calculated bounding boxes all the vertices are subdivided into the groups each of which will form a single resultant vertex.
  3. All the edges are divided into groups with similar resultant groups of vertices.
  4. In each group of edges pairs of edges coincident with the given tolerance are searched for.
  5. Each unpaired edge is split by vertices lying on it, and pt.1 to 4 are repeated for them.
  6. Using intersections of adjacent faces paired edges are refined and stitched, and each group of vertices is replaced with a single vertex.

Constructor & Destructor Documentation

◆ MbStitchedSolid() [1/2]

template<class CreatorsVectorPtr >
MbStitchedSolid::MbStitchedSolid ( const PArray< CreatorsVectorPtr > &  creatorsData,
bool  tryClosed,
double  precision,
const MbSNameMaker names,
bool  edgesMerging 
)
inline

Constructor.

Constructor by parameters.

Parameters
[in]creatorsData- Set of creators for each shell being stitched.
[in]tryClosed- Whether to construct a closed shell.
[in]precision- Maximal acceptable distance between edges being stitched.
[in]names- Names maker with version.
[in]edgesMerging- Whether to merge similar edges (true).

◆ MbStitchedSolid() [2/2]

MbStitchedSolid::MbStitchedSolid ( const std::vector< c3d::CreatorsSPtrVector > &  creatorsData,
const MbShellStitchParams stitchParams 
)
inline

Constructor.

Constructor by parameters.

Parameters
[in]creatorsData- Set of creators for each shell being stitched.
[in]tryClosed- Whether to construct a closed shell.
[in]precision- Maximal acceptable distance between edges being stitched.
[in]names- Names maker with version.
[in]edgesMerging- Whether to merge similar edges (true).

Member Function Documentation

◆ Duplicate()

MbCreator& MbStitchedSolid::Duplicate ( MbRegDuplicate iReg = nullptr) const
overridevirtual

Create a copy of the object.

Create a copy of the object using the registrator. The registrator is used to prevent multiple copying of an object. If the object contains references to other objects, then the included objects are copied too. It is allowed not to pass the registrator to a function. Then the new copy of the object will be created. It is allowed not to use the registrator while copying a single object or a set of disconnected objects. The registrator must be used to copy several correlated objects successively. It is possible that the relation between objects means that the objects contain references on the common objects. Then, while copying without using the registrator, one can get a set of copies which contain references to the different copies of a single embedded object, what leads to loss of relationship between the copies.

Parameters
[in]iReg- Registrator.
Returns
The object copy.

Implements MbCreator.

◆ IsSame()

bool MbStitchedSolid::IsSame ( const MbCreator other,
double  accuracy 
) const
overridevirtual

Determine whether an object is equal?

Still considered objects of the same type, all data is the same (equal).

Parameters
[in]other- The object to compare.
[in]accuracy- The accuracy to compare.
Returns
Whether the objects are equal.

Implements MbCreator.

◆ Transform()

void MbStitchedSolid::Transform ( const MbMatrix3D matr,
MbRegTransform iReg = nullptr 
)
overridevirtual

Transform according to the matrix.

Transform the initial object according to the matrix using the registrator. If the object contains references to the other geometric objects, then the nested objects are transformed according to the matrix. The registrator is used for preventing multiple transformation of the object. The function can be used without the registrator to transform a single object. The registrator must be used to transform a set of interdependent objects to prevent repeated transformation of the nested objects, since it is not ruled out that several objects from the set contain references to one or several common objects subject to transformation.

Parameters
[in]matr- A transformation matrix.
[in]iReg- Registrator.

Implements MbCreator.

◆ Move()

void MbStitchedSolid::Move ( const MbVector3D to,
MbRegTransform iReg = nullptr 
)
overridevirtual

Translate along a vector.

Move a geometric object along the vector using the registrator. If the object contains references to the other objects, then the translation operation is applied to the nested objects. The registrator is used for preventing multiple transformation of the object. The function can be used without the registrator to transform a single object. The registrator must be used to transform a set of interdependent objects to prevent repeated transformation of the nested objects, since it is not ruled out that several objects from the set contain references to one or several common objects subject to moving.

Parameters
[in]to- Movement vector.
[in]iReg- Registrator.

Implements MbCreator.

◆ Rotate()

void MbStitchedSolid::Rotate ( const MbAxis3D axis,
double  angle,
MbRegTransform iReg = nullptr 
)
overridevirtual

Rotate an object about the axis.

Rotate an object about the axis by the given angle using the registrator. If the object contains references to the other geometric objects, then the rotation operation is applied to the nested objects too. The registrator is used for preventing multiple transformation of the object. The function can be used without the registrator to transform a single object. The registrator must be used to transform a set of interdependent objects to prevent repeated transformation of the nested objects, since it is not ruled out that several objects from the set contain references to one or several common objects subject to rotation.

Parameters
[in]axis- The rotation axis.
[in]angle- The rotation angle.
[in]iReg- Registrator.

Implements MbCreator.

◆ CreateShell()

bool MbStitchedSolid::CreateShell ( MbFaceShell *&  shell,
MbeCopyMode  sameShell,
RPArray< MbSpaceItem > *  items = nullptr 
)
overridevirtual

Create a shell from the initial data.

Construction of a new shell or modification of the given one from the source data according to the constructor.

Parameters
[in]shell- A shell to be modified or a new shell.
[in]sameShell- Whether to perform complete copying of elements while constructing.
[in]items- Container for the elements of not performed constructions (can be nullptr).
Returns
Whether the construction is performed.

Reimplemented from MbCreator.


The documentation for this class was generated from the following file: