// This file is generated by WOK (CPPExt). // Please do not edit this file; modify original file instead. // The copyright and license terms as defined for the original file apply to // this header file considered to be the "object code" form of the original source. #ifndef _BRepFeat_MakeDPrism_HeaderFile #define _BRepFeat_MakeDPrism_HeaderFile #ifndef _Standard_HeaderFile #include #endif #ifndef _Standard_Macro_HeaderFile #include #endif #ifndef _TopoDS_Face_HeaderFile #include #endif #ifndef _TopTools_DataMapOfShapeListOfShape_HeaderFile #include #endif #ifndef _Standard_Real_HeaderFile #include #endif #ifndef _TColGeom_SequenceOfCurve_HeaderFile #include #endif #ifndef _Handle_Geom_Curve_HeaderFile #include #endif #ifndef _TopTools_ListOfShape_HeaderFile #include #endif #ifndef _BRepFeat_StatusError_HeaderFile #include #endif #ifndef _BRepFeat_Form_HeaderFile #include #endif #ifndef _Standard_Integer_HeaderFile #include #endif #ifndef _Standard_Boolean_HeaderFile #include #endif class Geom_Curve; class Standard_ConstructionError; class TopoDS_Shape; class TopoDS_Face; class TopoDS_Edge; class TColGeom_SequenceOfCurve; class TopTools_ListOfShape; //! Describes functions to build draft
//! prism topologies from basis shape surfaces. These can be depressions or protrusions.
//! The semantics of draft prism feature creation is based on the
//! construction of shapes:
//! - along a length
//! - up to a limiting face
//! - from a limiting face to a height.
//! The shape defining construction of the draft prism feature can be
//! either the supporting edge or the concerned area of a face.
//! In case of the supporting edge, this contour can be attached to a
//! face of the basis shape by binding. When the contour is bound to this
//! face, the information that the contour will slide on the face
//! becomes available to the relevant class methods.
//! In case of the concerned area of a face, you could, for example, cut
//! it out and move it to a different height which will define the
//! limiting face of a protrusion or depression.
class BRepFeat_MakeDPrism : public BRepFeat_Form { public: void* operator new(size_t,void* anAddress) { return anAddress; } void* operator new(size_t size) { return Standard::Allocate(size); } void operator delete(void *anAddress) { if (anAddress) Standard::Free((Standard_Address&)anAddress); } //! A face Pbase is selected in the shape
//! Sbase to serve as the basis for the draft prism. The
//! draft will be defined by the angle Angle and Fuse offers a choice between:
//! - removing matter with a Boolean cut using the setting 0
//! - adding matter with Boolean fusion using the setting 1.
//! The sketch face Skface serves to determine the type of
//! operation. If it is inside the basis shape, a local
//! operation such as glueing can be performed.
//! Initializes the draft prism class
BRepFeat_MakeDPrism(const TopoDS_Shape& Sbase,const TopoDS_Face& Pbase,const TopoDS_Face& Skface,const Standard_Real Angle,const Standard_Integer Fuse,const Standard_Boolean Modify); Standard_EXPORT BRepFeat_MakeDPrism(); //! Initializes this algorithm for building draft prisms along surfaces.
//! A face Pbase is selected in the basis shape Sbase to
//! serve as the basis from the draft prism. The draft will be
//! defined by the angle Angle and Fuse offers a choice between:
//! - removing matter with a Boolean cut using the setting 0
//! - adding matter with Boolean fusion using the setting 1.
//! The sketch face Skface serves to determine the type of
//! operation. If it is inside the basis shape, a local
//! operation such as glueing can be performed.
Standard_EXPORT void Init(const TopoDS_Shape& Sbase,const TopoDS_Face& Pbase,const TopoDS_Face& Skface,const Standard_Real Angle,const Standard_Integer Fuse,const Standard_Boolean Modify) ; //! Indicates that the edge will slide on the face
//! .
//! Raises ConstructionError if the face does not belong to the
//! basis shape, or the edge to the prismed shape.
Standard_EXPORT void Add(const TopoDS_Edge& E,const TopoDS_Face& OnFace) ; Standard_EXPORT void Perform(const Standard_Real Height) ; Standard_EXPORT void Perform(const TopoDS_Shape& Until) ; //! Assigns one of the following semantics
//! - to a height Height
//! - to a face Until
//! - from a face From to a height Until.
//! Reconstructs the feature topologically according to the semantic option chosen.
Standard_EXPORT void Perform(const TopoDS_Shape& From,const TopoDS_Shape& Until) ; //! Realizes a semi-infinite prism, limited by the position of the prism base.
Standard_EXPORT void PerformUntilEnd() ; //! Realizes a semi-infinite prism, limited by the face Funtil.
Standard_EXPORT void PerformFromEnd(const TopoDS_Shape& FUntil) ; //! Builds an infinite prism. The infinite descendants will not be kept in the result.
Standard_EXPORT void PerformThruAll() ; //! Assigns both a limiting shape, Until from
//! TopoDS_Shape, and a height, Height at which to stop
//! generation of the prism feature.
Standard_EXPORT void PerformUntilHeight(const TopoDS_Shape& Until,const Standard_Real Height) ; Standard_EXPORT void Curves(TColGeom_SequenceOfCurve& S) ; Standard_EXPORT Handle_Geom_Curve BarycCurve() ; //! Determination of TopEdges and LatEdges.
//! sig = 1 -> TopEdges = FirstShape of the DPrism
//! sig = 2 -> TOpEdges = LastShape of the DPrism
Standard_EXPORT void BossEdges(const Standard_Integer sig) ; //! Returns the list of TopoDS Edges of the top of the boss.
Standard_EXPORT const TopTools_ListOfShape& TopEdges() ; //! Returns the list of TopoDS Edges of the bottom of the boss.
Standard_EXPORT const TopTools_ListOfShape& LatEdges() ; protected: private: TopoDS_Face myPbase; TopTools_DataMapOfShapeListOfShape mySlface; Standard_Real myAngle; TColGeom_SequenceOfCurve myCurves; Handle_Geom_Curve myBCurve; TopTools_ListOfShape myTopEdges; TopTools_ListOfShape myLatEdges; BRepFeat_StatusError myStatusError; }; #include // other Inline functions and methods (like "C++: function call" methods) #endif