// 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_IdenticRelation_HeaderFile #define _AIS_IdenticRelation_HeaderFile #ifndef _Standard_HeaderFile #include #endif #ifndef _Standard_DefineHandle_HeaderFile #include #endif #ifndef _Handle_AIS_IdenticRelation_HeaderFile #include #endif #ifndef _Standard_Boolean_HeaderFile #include #endif #ifndef _gp_Pnt_HeaderFile #include #endif #ifndef _AIS_Relation_HeaderFile #include #endif #ifndef _Handle_Geom_Plane_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 #ifndef _Handle_Geom_Line_HeaderFile #include #endif #ifndef _Handle_Geom_Circle_HeaderFile #include #endif #ifndef _Handle_Geom_Ellipse_HeaderFile #include #endif #ifndef _Standard_Real_HeaderFile #include #endif class TopoDS_Shape; class Geom_Plane; class PrsMgr_PresentationManager3d; class Prs3d_Presentation; class Prs3d_Projector; class PrsMgr_PresentationManager2d; class Graphic2d_GraphicObject; class Geom_Transformation; class SelectMgr_Selection; class Geom_Line; class gp_Pnt; class Geom_Circle; class Geom_Ellipse; class TopoDS_Wire; class TopoDS_Vertex; class gp_Dir; //! Constructs a constraint by a relation of identity
//! between two or more datums figuring in shape
//! Interactive Objects.
class AIS_IdenticRelation : public AIS_Relation { public: //! Initializes the relation of identity between the two
//! entities, FirstShape and SecondShape. The plane
//! aPlane is initialized in case a visual reference is
//! needed to show identity.
Standard_EXPORT AIS_IdenticRelation(const TopoDS_Shape& FirstShape,const TopoDS_Shape& SecondShape,const Handle(Geom_Plane)& aPlane); //! Returns true if the interactive object is movable.
virtual Standard_Boolean IsMovable() const; //! 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_IdenticRelation) 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 ComputeOneEdgeOVertexPresentation(const Handle(Prs3d_Presentation)& aPresentation) ; Standard_EXPORT void ComputeTwoEdgesPresentation(const Handle(Prs3d_Presentation)& aPresentation) ; Standard_EXPORT void ComputeTwoLinesPresentation(const Handle(Prs3d_Presentation)& aPresentation,const Handle(Geom_Line)& aLin,gp_Pnt& Pnt1On1,gp_Pnt& Pnt2On1,gp_Pnt& Pnt1On2,gp_Pnt& Pnt2On2,const Standard_Boolean isInf1,const Standard_Boolean isInf2) ; Standard_EXPORT void ComputeTwoCirclesPresentation(const Handle(Prs3d_Presentation)& aPresentation,const Handle(Geom_Circle)& aCircle,const gp_Pnt& Pnt1On1,const gp_Pnt& Pnt2On1,const gp_Pnt& Pnt1On2,const gp_Pnt& Pnt2On2) ; //! Computes the presentation of the identic constraint
//! between 2 arcs in the case of automatic presentation
Standard_EXPORT void ComputeAutoArcPresentation(const Handle(Geom_Circle)& aCircle,const gp_Pnt& firstp,const gp_Pnt& lastp,const Standard_Boolean isstatic = Standard_False) ; //! Computes the presentation of the identic constraint
//! between 2 circles in the case of non automatic presentation
Standard_EXPORT void ComputeNotAutoCircPresentation(const Handle(Geom_Circle)& aCircle) ; //! Computes the presentation of the identic constraint
//! between 2 arcs in the case of non automatic presentation
Standard_EXPORT void ComputeNotAutoArcPresentation(const Handle(Geom_Circle)& aCircle,const gp_Pnt& pntfirst,const gp_Pnt& pntlast) ; Standard_EXPORT void ComputeTwoEllipsesPresentation(const Handle(Prs3d_Presentation)& aPrs,const Handle(Geom_Ellipse)& anEll,const gp_Pnt& Pnt1On1,const gp_Pnt& Pnt2On1,const gp_Pnt& Pnt1On2,const gp_Pnt& Pnt2On2) ; //! Computes the presentation of the identic constraint
//! between 2 arcs in the case of automatic presentation
Standard_EXPORT void ComputeAutoArcPresentation(const Handle(Geom_Ellipse)& theEll,const gp_Pnt& firstp,const gp_Pnt& lastp,const Standard_Boolean isstatic = Standard_False) ; //! Computes the presentation of the identic constraint
//! between 2 ellipses in the case of non automatic presentation
Standard_EXPORT void ComputeNotAutoElipsPresentation(const Handle(Geom_Ellipse)& theEll) ; //! Computes the presentation of the identic constraint
//! between 2 arcs in the case of non automatic presentation
Standard_EXPORT void ComputeNotAutoArcPresentation(const Handle(Geom_Ellipse)& theEll,const gp_Pnt& pntfirst,const gp_Pnt& pntlast) ; Standard_EXPORT void ComputeTwoVerticesPresentation(const Handle(Prs3d_Presentation)& aPresentation) ; Standard_EXPORT Standard_Real ComputeSegSize() const; Standard_EXPORT Standard_Boolean ComputeDirection(const TopoDS_Wire& aWire,const TopoDS_Vertex& aVertex,gp_Dir& aDir) const; Standard_EXPORT gp_Dir ComputeLineDirection(const Handle(Geom_Line)& aLin,const gp_Pnt& anExtremity) const; Standard_EXPORT gp_Dir ComputeCircleDirection(const Handle(Geom_Circle)& aCirc,const TopoDS_Vertex& ConnectedVertex) const; Standard_Boolean isCircle; gp_Pnt myFAttach; gp_Pnt mySAttach; gp_Pnt myCenter; }; #include // other Inline functions and methods (like "C++: function call" methods) #endif