Open CASCADE Technology Reference Manual 8.0.0
Loading...
Searching...
No Matches
Public Member Functions
Draft_Modification Class Reference

#include <Draft_Modification.hxx>

Inheritance diagram for Draft_Modification:
Inheritance graph
[legend]

Public Member Functions

 Draft_Modification (const TopoDS_Shape &S)
 
void Clear ()
 Resets on the same shape.
 
void Init (const TopoDS_Shape &S)
 Changes the basis shape and resets.
 
bool Add (const TopoDS_Face &F, const gp_Dir &Direction, const double Angle, const gp_Pln &NeutralPlane, const bool Flag=true)
 Adds the face F and propagates the draft modification to its neighbour faces if they are tangent. If an error occurs, will return False and ProblematicShape will return the "bad" face.
 
void Remove (const TopoDS_Face &F)
 Removes the face F and the neighbour faces if they are tangent. It will be necessary to call this method if the method Add returns false, to unset ProblematicFace.
 
void Perform ()
 Performs the draft angle modification and sets the value returned by the method IsDone. If an error occurs, IsDone will return false, and an error status will be given by the method Error, and the shape on which the problem appeared will be given by ProblematicShape.
 
bool IsDone () const
 Returns True if Perform has been successfully called. Otherwise more information can be obtained using the methods Error() and ProblematicShape().
 
Draft_ErrorStatus Error () const
 
const TopoDS_ShapeProblematicShape () const
 Returns the shape (Face, Edge or Vertex) on which an error occurred.
 
const NCollection_List< TopoDS_Shape > & ConnectedFaces (const TopoDS_Face &F)
 Returns all the faces which have been added together with the face <F>.
 
const NCollection_List< TopoDS_Shape > & ModifiedFaces ()
 Returns all the faces on which a modification has been given.
 
bool NewSurface (const TopoDS_Face &F, occ::handle< Geom_Surface > &S, TopLoc_Location &L, double &Tol, bool &RevWires, bool &RevFace) override
 Returns true if the face <F> has been modified. In this case, is the new geometric support of the face, <L> the new location, <Tol> the new tolerance.<RevWires> has to be set to true when the modification reverses the normal of the surface. (the wires have to be reversed). <RevFace> has to be set to true if the orientation of the modified face changes in the shells which contain it. Here it will be set to false.
 
bool NewCurve (const TopoDS_Edge &E, occ::handle< Geom_Curve > &C, TopLoc_Location &L, double &Tol) override
 Returns true if the edge <E> has been modified. In this case, is the new geometric support of the edge, <L> the new location, <Tol> the new tolerance. Otherwise, returns false, and , <L>, <Tol> are not significant.
 
bool NewPoint (const TopoDS_Vertex &V, gp_Pnt &P, double &Tol) override
 Returns true if the vertex <V> has been modified. In this case,.
 
bool NewCurve2d (const TopoDS_Edge &E, const TopoDS_Face &F, const TopoDS_Edge &NewE, const TopoDS_Face &NewF, occ::handle< Geom2d_Curve > &C, double &Tol) override
 Returns true if the edge <E> has a new curve on surface on the face <F>.In this case, is the new geometric support of the edge, <L> the new location, <Tol> the new tolerance.
 
bool NewParameter (const TopoDS_Vertex &V, const TopoDS_Edge &E, double &P, double &Tol) override
 Returns true if the Vertex <V> has a new parameter on the edge <E>. In this case,.
 
GeomAbs_Shape Continuity (const TopoDS_Edge &E, const TopoDS_Face &F1, const TopoDS_Face &F2, const TopoDS_Edge &NewE, const TopoDS_Face &NewF1, const TopoDS_Face &NewF2) override
 Returns the continuity of <NewE> between <NewF1> and <NewF2>.
 
- Public Member Functions inherited from BRepTools_Modification
virtual bool NewTriangulation (const TopoDS_Face &F, occ::handle< Poly_Triangulation > &T)
 Returns true if the face has been modified according to changed triangulation. If the face has been modified:
 
virtual bool NewPolygon (const TopoDS_Edge &E, occ::handle< Poly_Polygon3D > &P)
 Returns true if the edge has been modified according to changed polygon. If the edge has been modified:
 
virtual bool NewPolygonOnTriangulation (const TopoDS_Edge &E, const TopoDS_Face &F, occ::handle< Poly_PolygonOnTriangulation > &P)
 Returns true if the edge has been modified according to changed polygon on triangulation. If the edge has been modified:
 
- Public Member Functions inherited from Standard_Transient
 Standard_Transient ()
 Empty constructor.
 
 Standard_Transient (const Standard_Transient &)
 Copy constructor – does nothing.
 
Standard_Transientoperator= (const Standard_Transient &)
 Assignment operator, needed to avoid copying reference counter.
 
virtual ~Standard_Transient ()=default
 Destructor must be virtual.
 
virtual const opencascade::handle< Standard_Type > & DynamicType () const
 Returns a type descriptor about this object.
 
bool IsInstance (const opencascade::handle< Standard_Type > &theType) const
 Returns a true value if this is an instance of Type.
 
bool IsInstance (const char *const theTypeName) const
 Returns a true value if this is an instance of TypeName.
 
bool IsKind (const opencascade::handle< Standard_Type > &theType) const
 Returns true if this is an instance of Type or an instance of any class that inherits from Type. Note that multiple inheritance is not supported by OCCT RTTI mechanism.
 
bool IsKind (const char *const theTypeName) const
 Returns true if this is an instance of TypeName or an instance of any class that inherits from TypeName. Note that multiple inheritance is not supported by OCCT RTTI mechanism.
 
Standard_TransientThis () const
 Returns non-const pointer to this object (like const_cast). For protection against creating handle to objects allocated in stack or call from constructor, it will raise exception Standard_ProgramError if reference counter is zero.
 
int GetRefCount () const noexcept
 Get the reference counter of this object.
 
void IncrementRefCounter () noexcept
 Increments the reference counter of this object. Uses relaxed memory ordering since incrementing only requires atomicity, not synchronization with other memory operations.
 
int DecrementRefCounter () noexcept
 Decrements the reference counter of this object; returns the decremented value. Uses release ordering for the decrement to ensure all writes to the object are visible before the count reaches zero. An acquire fence is added only when the count reaches zero, ensuring proper synchronization before deletion. This is more efficient than using acq_rel for every decrement.
 
virtual void Delete () const
 Memory deallocator for transient classes.
 

Additional Inherited Members

- Public Types inherited from Standard_Transient
typedef void base_type
 Returns a type descriptor about this object.
 
- Static Public Member Functions inherited from Standard_Transient
static constexpr const charget_type_name ()
 Returns a type descriptor about this object.
 
static const opencascade::handle< Standard_Type > & get_type_descriptor ()
 Returns type descriptor of Standard_Transient class.
 

Constructor & Destructor Documentation

◆ Draft_Modification()

Draft_Modification::Draft_Modification ( const TopoDS_Shape & S)

Member Function Documentation

◆ Add()

bool Draft_Modification::Add ( const TopoDS_Face & F,
const gp_Dir & Direction,
const double Angle,
const gp_Pln & NeutralPlane,
const bool Flag = true )

Adds the face F and propagates the draft modification to its neighbour faces if they are tangent. If an error occurs, will return False and ProblematicShape will return the "bad" face.

◆ Clear()

void Draft_Modification::Clear ( )

Resets on the same shape.

◆ ConnectedFaces()

const NCollection_List< TopoDS_Shape > & Draft_Modification::ConnectedFaces ( const TopoDS_Face & F)

Returns all the faces which have been added together with the face <F>.

◆ Continuity()

GeomAbs_Shape Draft_Modification::Continuity ( const TopoDS_Edge & E,
const TopoDS_Face & F1,
const TopoDS_Face & F2,
const TopoDS_Edge & NewE,
const TopoDS_Face & NewF1,
const TopoDS_Face & NewF2 )
overridevirtual

Returns the continuity of <NewE> between <NewF1> and <NewF2>.

<NewE> is the new edge created from <E>. <NewF1> (resp. <NewF2>) is the new face created from <F1> (resp. <F2>).

Implements BRepTools_Modification.

◆ Error()

Draft_ErrorStatus Draft_Modification::Error ( ) const

◆ Init()

void Draft_Modification::Init ( const TopoDS_Shape & S)

Changes the basis shape and resets.

◆ IsDone()

bool Draft_Modification::IsDone ( ) const

Returns True if Perform has been successfully called. Otherwise more information can be obtained using the methods Error() and ProblematicShape().

◆ ModifiedFaces()

const NCollection_List< TopoDS_Shape > & Draft_Modification::ModifiedFaces ( )

Returns all the faces on which a modification has been given.

◆ NewCurve()

bool Draft_Modification::NewCurve ( const TopoDS_Edge & E,
occ::handle< Geom_Curve > & C,
TopLoc_Location & L,
double & Tol )
overridevirtual

Returns true if the edge <E> has been modified. In this case, is the new geometric support of the edge, <L> the new location, <Tol> the new tolerance. Otherwise, returns false, and , <L>, <Tol> are not significant.

Implements BRepTools_Modification.

◆ NewCurve2d()

bool Draft_Modification::NewCurve2d ( const TopoDS_Edge & E,
const TopoDS_Face & F,
const TopoDS_Edge & NewE,
const TopoDS_Face & NewF,
occ::handle< Geom2d_Curve > & C,
double & Tol )
overridevirtual

Returns true if the edge <E> has a new curve on surface on the face <F>.In this case, is the new geometric support of the edge, <L> the new location, <Tol> the new tolerance.

Otherwise, returns false, and , <L>, <Tol> are not significant.

<NewE> is the new edge created from <E>. <NewF> is the new face created from <F>. They may be useful.

Implements BRepTools_Modification.

◆ NewParameter()

bool Draft_Modification::NewParameter ( const TopoDS_Vertex & V,
const TopoDS_Edge & E,
double & P,
double & Tol )
overridevirtual

Returns true if the Vertex <V> has a new parameter on the edge <E>. In this case,.

is the parameter, <Tol> the new tolerance. Otherwise, returns false, and

, <Tol> are not significant.

Implements BRepTools_Modification.

◆ NewPoint()

bool Draft_Modification::NewPoint ( const TopoDS_Vertex & V,
gp_Pnt & P,
double & Tol )
overridevirtual

Returns true if the vertex <V> has been modified. In this case,.

is the new geometric support of the vertex, <Tol> the new tolerance. Otherwise, returns false, and

, <Tol> are not significant.

Implements BRepTools_Modification.

◆ NewSurface()

bool Draft_Modification::NewSurface ( const TopoDS_Face & F,
occ::handle< Geom_Surface > & S,
TopLoc_Location & L,
double & Tol,
bool & RevWires,
bool & RevFace )
overridevirtual

Returns true if the face <F> has been modified. In this case, is the new geometric support of the face, <L> the new location, <Tol> the new tolerance.<RevWires> has to be set to true when the modification reverses the normal of the surface. (the wires have to be reversed). <RevFace> has to be set to true if the orientation of the modified face changes in the shells which contain it. Here it will be set to false.

Otherwise, returns false, and , <L>, <Tol> , <RevWires> ,<RevFace> are not significant.

Implements BRepTools_Modification.

◆ Perform()

void Draft_Modification::Perform ( )

Performs the draft angle modification and sets the value returned by the method IsDone. If an error occurs, IsDone will return false, and an error status will be given by the method Error, and the shape on which the problem appeared will be given by ProblematicShape.

◆ ProblematicShape()

const TopoDS_Shape & Draft_Modification::ProblematicShape ( ) const

Returns the shape (Face, Edge or Vertex) on which an error occurred.

◆ Remove()

void Draft_Modification::Remove ( const TopoDS_Face & F)

Removes the face F and the neighbour faces if they are tangent. It will be necessary to call this method if the method Add returns false, to unset ProblematicFace.


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