summaryrefslogtreecommitdiff
path: root/inc/AIS_IdenticRelation.hxx
blob: 0fb8781a09fdfd3cc09ad9f9d566453778edef2e (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
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
// 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 <Standard.hxx>
#endif
#ifndef _Standard_DefineHandle_HeaderFile
#include <Standard_DefineHandle.hxx>
#endif
#ifndef _Handle_AIS_IdenticRelation_HeaderFile
#include <Handle_AIS_IdenticRelation.hxx>
#endif

#ifndef _Standard_Boolean_HeaderFile
#include <Standard_Boolean.hxx>
#endif
#ifndef _gp_Pnt_HeaderFile
#include <gp_Pnt.hxx>
#endif
#ifndef _AIS_Relation_HeaderFile
#include <AIS_Relation.hxx>
#endif
#ifndef _Handle_Geom_Plane_HeaderFile
#include <Handle_Geom_Plane.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
#ifndef _Handle_Geom_Line_HeaderFile
#include <Handle_Geom_Line.hxx>
#endif
#ifndef _Handle_Geom_Circle_HeaderFile
#include <Handle_Geom_Circle.hxx>
#endif
#ifndef _Handle_Geom_Ellipse_HeaderFile
#include <Handle_Geom_Ellipse.hxx>
#endif
#ifndef _Standard_Real_HeaderFile
#include <Standard_Real.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;
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 <br>
//! between two or more datums figuring in shape <br>
//! Interactive Objects. <br>
class AIS_IdenticRelation : public AIS_Relation {

public:

  
//!   Initializes the relation of identity between the two <br>
//! entities, FirstShape and SecondShape. The plane <br>
//! aPlane is initialized in case a visual reference is <br>
//! needed to show identity. <br>
  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. <br>
      virtual  Standard_Boolean IsMovable() 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_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 <br>
//!          between 2 arcs in the case of automatic presentation <br>
  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 <br>
//!          between 2 circles in the case of non automatic presentation <br>
  Standard_EXPORT     void ComputeNotAutoCircPresentation(const Handle(Geom_Circle)& aCircle) ;
  //! Computes the presentation of the identic constraint <br>
//!          between 2 arcs in the case of non automatic presentation <br>
  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 <br>
//!          between 2 arcs in the case of automatic presentation <br>
  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 <br>
//!          between 2 ellipses in the case of non automatic presentation <br>
  Standard_EXPORT     void ComputeNotAutoElipsPresentation(const Handle(Geom_Ellipse)& theEll) ;
  //! Computes the presentation of the identic constraint <br>
//!          between 2 arcs in the case of non automatic presentation <br>
  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 <AIS_IdenticRelation.lxx>



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


#endif