summaryrefslogtreecommitdiff
path: root/inc/AIS_SymmetricRelation.hxx
blob: cd730d3e2726d5e31f2be41c0da9b91a6865838e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
// 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_SymmetricRelation_HeaderFile
#define _AIS_SymmetricRelation_HeaderFile

#ifndef _Standard_HeaderFile
#include <Standard.hxx>
#endif
#ifndef _Standard_DefineHandle_HeaderFile
#include <Standard_DefineHandle.hxx>
#endif
#ifndef _Handle_AIS_SymmetricRelation_HeaderFile
#include <Handle_AIS_SymmetricRelation.hxx>
#endif

#ifndef _TopoDS_Shape_HeaderFile
#include <TopoDS_Shape.hxx>
#endif
#ifndef _gp_Pnt_HeaderFile
#include <gp_Pnt.hxx>
#endif
#ifndef _gp_Dir_HeaderFile
#include <gp_Dir.hxx>
#endif
#ifndef _AIS_Relation_HeaderFile
#include <AIS_Relation.hxx>
#endif
#ifndef _Handle_Geom_Plane_HeaderFile
#include <Handle_Geom_Plane.hxx>
#endif
#ifndef _Standard_Boolean_HeaderFile
#include <Standard_Boolean.hxx>
#endif
#ifndef _Handle_PrsMgr_PresentationManager3d_HeaderFile
#include <Handle_PrsMgr_PresentationManager3d.hxx>
#endif
#ifndef _Handle_Prs3d_Presentation_HeaderFile
#include <Handle_Prs3d_Presentation.hxx>
#endif
#ifndef _Standard_Integer_HeaderFile
#include <Standard_Integer.hxx>
#endif
#ifndef _Handle_Prs3d_Projector_HeaderFile
#include <Handle_Prs3d_Projector.hxx>
#endif
#ifndef _Handle_PrsMgr_PresentationManager2d_HeaderFile
#include <Handle_PrsMgr_PresentationManager2d.hxx>
#endif
#ifndef _Handle_Graphic2d_GraphicObject_HeaderFile
#include <Handle_Graphic2d_GraphicObject.hxx>
#endif
#ifndef _Handle_Geom_Transformation_HeaderFile
#include <Handle_Geom_Transformation.hxx>
#endif
#ifndef _Handle_SelectMgr_Selection_HeaderFile
#include <Handle_SelectMgr_Selection.hxx>
#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;


//! A framework to display constraints of symmetricity <br>
//! between two or more datum Interactive Objects. <br>
//! A plane serves as the axis of symmetry between the <br>
//! shapes of which the datums are parts. <br>
class AIS_SymmetricRelation : public AIS_Relation {

public:

  //! Constructs an object to display constraints of symmetricity. <br>
//! This object is defined by a tool aSymmTool, a first <br>
//! shape FirstShape, a second shape SecondShape, and a plane aPlane. <br>
//! aPlane serves as the axis of symmetry. <br>
//! aSymmTool is the shape composed of FirstShape <br>
//! SecondShape and aPlane. It may be queried and <br>
//! edited using the functions GetTool and SetTool. <br>
//! The two shapes are typically two edges, two vertices or two points. <br>
  Standard_EXPORT   AIS_SymmetricRelation(const TopoDS_Shape& aSymmTool,const TopoDS_Shape& FirstShape,const TopoDS_Shape& SecondShape,const Handle(Geom_Plane)& aPlane);
  //! Returns true if the symmetric constraint display is movable. <br>
      virtual  Standard_Boolean IsMovable() const;
  //! Sets the tool aSymmetricTool composed of a first <br>
//! shape, a second shape, and a plane. <br>
//! This tool is initially created at construction time. <br>
        void SetTool(const TopoDS_Shape& aSymmetricTool) ;
  //! Returns the tool composed of a first shape, a second <br>
//! shape, and a plane. This tool is created at construction time. <br>
       const TopoDS_Shape& GetTool() const;
  //! computes the presentation according to a point of view <br>
//!          given by <aProjector>. <br>
//!          To be Used when the associated degenerated Presentations <br>
//!          have been transformed by <aTrsf> which is not a Pure <br>
//!          Translation. The HLR Prs can't be deducted automatically <br>
//!          WARNING :<aTrsf> must be applied <br>
//!           to the object to display before computation  !!! <br>
  Standard_EXPORT   virtual  void Compute(const Handle(Prs3d_Projector)& aProjector,const Handle(Geom_Transformation)& aTrsf,const Handle(Prs3d_Presentation)& aPresentation) ;




  DEFINE_STANDARD_RTTI(AIS_SymmetricRelation)

protected:




private: 

  
  Standard_EXPORT     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     void ComputeSelection(const Handle(SelectMgr_Selection)& aSelection,const Standard_Integer aMode) ;
  
  Standard_EXPORT     void ComputeTwoFacesSymmetric(const Handle(Prs3d_Presentation)& aprs) ;
  
  Standard_EXPORT     void ComputeTwoEdgesSymmetric(const Handle(Prs3d_Presentation)& aprs) ;
  
  Standard_EXPORT     void ComputeTwoVerticesSymmetric(const Handle(Prs3d_Presentation)& aprs) ;

TopoDS_Shape myTool;
gp_Pnt myFAttach;
gp_Pnt mySAttach;
gp_Dir myFDirAttach;
gp_Dir myAxisDirAttach;


};


#include <AIS_SymmetricRelation.lxx>



// other Inline functions and methods (like "C++: function call" methods)


#endif