// 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 _AIS_RadiusDimension_HeaderFile #define _AIS_RadiusDimension_HeaderFile #ifndef _Standard_HeaderFile #include #endif #ifndef _Standard_DefineHandle_HeaderFile #include #endif #ifndef _Handle_AIS_RadiusDimension_HeaderFile #include #endif #ifndef _gp_Circ_HeaderFile #include #endif #ifndef _Standard_Real_HeaderFile #include #endif #ifndef _gp_Pnt_HeaderFile #include #endif #ifndef _gp_Lin_HeaderFile #include #endif #ifndef _Standard_Boolean_HeaderFile #include #endif #ifndef _AIS_Relation_HeaderFile #include #endif #ifndef _DsgPrs_ArrowSide_HeaderFile #include #endif #ifndef _AIS_KindOfDimension_HeaderFile #include #endif #ifndef _Handle_PrsMgr_PresentationManager3d_HeaderFile #include #endif #ifndef _Handle_Prs3d_Presentation_HeaderFile #include #endif #ifndef _Standard_Integer_HeaderFile #include #endif #ifndef _Handle_Prs3d_Projector_HeaderFile #include #endif #ifndef _Handle_PrsMgr_PresentationManager2d_HeaderFile #include #endif #ifndef _Handle_Graphic2d_GraphicObject_HeaderFile #include #endif #ifndef _Handle_Geom_Transformation_HeaderFile #include #endif #ifndef _Handle_SelectMgr_Selection_HeaderFile #include #endif class TopoDS_Shape; class TCollection_ExtendedString; class gp_Pnt; class PrsMgr_PresentationManager3d; class Prs3d_Presentation; class Prs3d_Projector; class PrsMgr_PresentationManager2d; class Graphic2d_GraphicObject; class Geom_Transformation; class SelectMgr_Selection; //! A framework to define display of radii.
//! These displays serve as relational references in 3D
//! presentations of surfaces, and are particularly useful
//! in viewing fillets. The display consists of arrows and
//! text giving the length of a radius. This display is
//! recalculated if the applicative owner shape changes
//! in dimension, and the text gives the modified length.
//! The algorithm analyzes a length along a face as an
//! arc. It then reconstructs the circle corresponding to
//! the arc and calculates the radius of this circle.
class AIS_RadiusDimension : public AIS_Relation { public: //! Constructs the radius display object defined by the
//! shape aShape, the dimension aVal, and the text aText.
Standard_EXPORT AIS_RadiusDimension(const TopoDS_Shape& aShape,const Standard_Real aVal,const TCollection_ExtendedString& aText); //! Constructs radius display object defined by the shape
//! aShape, the dimension aVal, the position aPosition,
//! the type of arrow aSymbolPrs, the arrow length
//! anArrowSize and the text aText.
Standard_EXPORT AIS_RadiusDimension(const TopoDS_Shape& aShape,const Standard_Real aVal,const TCollection_ExtendedString& aText,const gp_Pnt& aPosition,const DsgPrs_ArrowSide aSymbolPrs,const Standard_Real anArrowSize = 0.0); Standard_EXPORT void SetFirstShape(const TopoDS_Shape& aFShape) ; //! Indicates that the dimension selected is a radius.
virtual AIS_KindOfDimension KindOfDimension() const; //! Returns true if the radius selected is movable.
virtual Standard_Boolean IsMovable() const; //! Draws an arrowhead pointing towards the center of
//! the shape aShape defined at construction time if
//! false, and away from the center if true.
Standard_Boolean DrawFromCenter() const; //! Sets the Boolean drawfromcenter to true or false.
//! If drawfromcenter is false, the arrowhead will point
//! towards the center of the shape aShape defined at
//! construction time.
void SetDrawFromCenter(const Standard_Boolean drawfromcenter) ; //! computes the presentation according to a point of view
//! given by .
//! To be Used when the associated degenerated Presentations
//! have been transformed by which is not a Pure
//! Translation. The HLR Prs can't be deducted automatically
//! WARNING : must be applied
//! to the object to display before computation !!!
Standard_EXPORT virtual void Compute(const Handle(Prs3d_Projector)& aProjector,const Handle(Geom_Transformation)& aTrsf,const Handle(Prs3d_Presentation)& aPresentation) ; DEFINE_STANDARD_RTTI(AIS_RadiusDimension) protected: private: Standard_EXPORT virtual void Compute(const Handle(PrsMgr_PresentationManager3d)& aPresentationManager,const Handle(Prs3d_Presentation)& aPresentation,const Standard_Integer aMode = 0) ; Standard_EXPORT void Compute(const Handle(Prs3d_Projector)& aProjector,const Handle(Prs3d_Presentation)& aPresentation) ; Standard_EXPORT void Compute(const Handle(PrsMgr_PresentationManager2d)& aPresentationManager,const Handle(Graphic2d_GraphicObject)& aPresentation,const Standard_Integer aMode = 0) ; Standard_EXPORT virtual void ComputeSelection(const Handle(SelectMgr_Selection)& aSelection,const Standard_Integer aMode) ; Standard_EXPORT void ComputeRadius(const Handle(Prs3d_Presentation)& aPresentation) ; Standard_EXPORT void InitFirstShape() ; gp_Circ myCircle; Standard_Real myFirstPar; Standard_Real myLastPar; gp_Pnt myCenter; gp_Pnt myEndOfArrow; gp_Lin myFirstLine; gp_Lin myLastLine; Standard_Boolean mydrawFromCenter; }; #include // other Inline functions and methods (like "C++: function call" methods) #endif