0026595: Lost some comments in OCCT-code after cdl elimination
[occt.git] / src / IntCurveSurface / IntCurveSurface_HInter.hxx
1 // Created on: 1993-04-07
2 // Created by: Laurent BUCHARD
3 // Copyright (c) 1993-1999 Matra Datavision
4 // Copyright (c) 1999-2014 OPEN CASCADE SAS
5 //
6 // This file is part of Open CASCADE Technology software library.
7 //
8 // This library is free software; you can redistribute it and/or modify it under
9 // the terms of the GNU Lesser General Public License version 2.1 as published
10 // by the Free Software Foundation, with special exception defined in the file
11 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
12 // distribution for complete text of the license and disclaimer of any warranty.
13 //
14 // Alternatively, this file may be used under the terms of Open CASCADE
15 // commercial license or contractual agreement.
16
17 #ifndef _IntCurveSurface_HInter_HeaderFile
18 #define _IntCurveSurface_HInter_HeaderFile
19
20 #include <Standard.hxx>
21 #include <Standard_DefineAlloc.hxx>
22 #include <Standard_Handle.hxx>
23
24 #include <IntCurveSurface_Intersection.hxx>
25 #include <Standard_Real.hxx>
26 #include <TColgp_Array2OfPnt.hxx>
27 #include <TColStd_Array1OfReal.hxx>
28 class Adaptor3d_HCurve;
29 class IntCurveSurface_TheHCurveTool;
30 class Adaptor3d_HSurface;
31 class Adaptor3d_HSurfaceTool;
32 class IntCurveSurface_ThePolygonOfHInter;
33 class IntCurveSurface_ThePolygonToolOfHInter;
34 class IntCurveSurface_ThePolyhedronOfHInter;
35 class IntCurveSurface_ThePolyhedronToolOfHInter;
36 class IntCurveSurface_TheInterferenceOfHInter;
37 class IntCurveSurface_TheCSFunctionOfHInter;
38 class IntCurveSurface_TheExactHInter;
39 class IntCurveSurface_TheQuadCurvExactHInter;
40 class IntCurveSurface_TheQuadCurvFuncOfTheQuadCurvExactHInter;
41 class Bnd_BoundSortBox;
42 class gp_Lin;
43 class gp_Circ;
44 class gp_Elips;
45 class gp_Parab;
46 class gp_Hypr;
47 class IntAna_IntConicQuad;
48 class Bnd_Box;
49
50
51
52 class IntCurveSurface_HInter  : public IntCurveSurface_Intersection
53 {
54 public:
55
56   DEFINE_STANDARD_ALLOC
57
58   
59   //! Empty Constructor
60   Standard_EXPORT IntCurveSurface_HInter();
61   
62   //! Compute the Intersection between the curve and the
63   //! surface
64   Standard_EXPORT void Perform (const Handle(Adaptor3d_HCurve)& Curve, const Handle(Adaptor3d_HSurface)& Surface);
65   
66   //! Compute the Intersection  between the curve  and
67   //! the surface. The   Curve is already  sampled and
68   //! its polygon : <Polygon> is given.
69   Standard_EXPORT void Perform (const Handle(Adaptor3d_HCurve)& Curve, const IntCurveSurface_ThePolygonOfHInter& Polygon, const Handle(Adaptor3d_HSurface)& Surface);
70   
71   //! Compute the Intersection  between the curve  and
72   //! the surface. The   Curve is already  sampled and
73   //! its polygon : <Polygon> is given. The Surface is
74   //! also sampled and <Polyhedron> is given.
75   Standard_EXPORT void Perform (const Handle(Adaptor3d_HCurve)& Curve, const IntCurveSurface_ThePolygonOfHInter& ThePolygon, const Handle(Adaptor3d_HSurface)& Surface, const IntCurveSurface_ThePolyhedronOfHInter& Polyhedron);
76   
77   //! Compute the Intersection  between the curve  and
78   //! the surface. The   Curve is already  sampled and
79   //! its polygon : <Polygon> is given. The Surface is
80   //! also sampled and <Polyhedron> is given.
81   Standard_EXPORT void Perform (const Handle(Adaptor3d_HCurve)& Curve, const IntCurveSurface_ThePolygonOfHInter& ThePolygon, const Handle(Adaptor3d_HSurface)& Surface, const IntCurveSurface_ThePolyhedronOfHInter& Polyhedron, Bnd_BoundSortBox& BndBSB);
82   
83   //! Compute the Intersection  between the curve  and
84   //! the surface. The Surface is already  sampled and
85   //! its polyhedron : <Polyhedron> is given.
86   Standard_EXPORT void Perform (const Handle(Adaptor3d_HCurve)& Curve, const Handle(Adaptor3d_HSurface)& Surface, const IntCurveSurface_ThePolyhedronOfHInter& Polyhedron);
87
88
89
90
91 protected:
92
93   
94   //! Compute the Intersection between the curve and the
95   //! surface
96   Standard_EXPORT void Perform (const Handle(Adaptor3d_HCurve)& Curve, const Handle(Adaptor3d_HSurface)& Surface, const Standard_Real U0, const Standard_Real V0, const Standard_Real U1, const Standard_Real V1);
97   
98   Standard_EXPORT void InternalPerformCurveQuadric (const Handle(Adaptor3d_HCurve)& Curve, const Handle(Adaptor3d_HSurface)& Surface);
99   
100   Standard_EXPORT void InternalPerform (const Handle(Adaptor3d_HCurve)& Curve, const IntCurveSurface_ThePolygonOfHInter& Polygon, const Handle(Adaptor3d_HSurface)& Surface, const IntCurveSurface_ThePolyhedronOfHInter& Polyhedron, const Standard_Real U1, const Standard_Real V1, const Standard_Real U2, const Standard_Real V2);
101   
102   Standard_EXPORT void InternalPerform (const Handle(Adaptor3d_HCurve)& Curve, const IntCurveSurface_ThePolygonOfHInter& Polygon, const Handle(Adaptor3d_HSurface)& Surface, const IntCurveSurface_ThePolyhedronOfHInter& Polyhedron, const Standard_Real U1, const Standard_Real V1, const Standard_Real U2, const Standard_Real V2, Bnd_BoundSortBox& BSB);
103   
104   Standard_EXPORT void InternalPerform (const Handle(Adaptor3d_HCurve)& Curve, const IntCurveSurface_ThePolygonOfHInter& Polygon, const Handle(Adaptor3d_HSurface)& Surface, const Standard_Real U1, const Standard_Real V1, const Standard_Real U2, const Standard_Real V2);
105   
106   Standard_EXPORT void PerformConicSurf (const gp_Lin& Line, const Handle(Adaptor3d_HCurve)& Curve, const Handle(Adaptor3d_HSurface)& Surface, const Standard_Real U1, const Standard_Real V1, const Standard_Real U2, const Standard_Real V2);
107   
108   Standard_EXPORT void PerformConicSurf (const gp_Circ& Circle, const Handle(Adaptor3d_HCurve)& Curve, const Handle(Adaptor3d_HSurface)& Surface, const Standard_Real U1, const Standard_Real V1, const Standard_Real U2, const Standard_Real V2);
109   
110   Standard_EXPORT void PerformConicSurf (const gp_Elips& Ellipse, const Handle(Adaptor3d_HCurve)& Curve, const Handle(Adaptor3d_HSurface)& Surface, const Standard_Real U1, const Standard_Real V1, const Standard_Real U2, const Standard_Real V2);
111   
112   Standard_EXPORT void PerformConicSurf (const gp_Parab& Parab, const Handle(Adaptor3d_HCurve)& Curve, const Handle(Adaptor3d_HSurface)& Surface, const Standard_Real U1, const Standard_Real V1, const Standard_Real U2, const Standard_Real V2);
113   
114   Standard_EXPORT void PerformConicSurf (const gp_Hypr& Hyper, const Handle(Adaptor3d_HCurve)& Curve, const Handle(Adaptor3d_HSurface)& Surface, const Standard_Real U1, const Standard_Real V1, const Standard_Real U2, const Standard_Real V2);
115   
116   Standard_EXPORT void AppendIntAna (const Handle(Adaptor3d_HCurve)& Curve, const Handle(Adaptor3d_HSurface)& Surface, const IntAna_IntConicQuad& InterAna);
117   
118   Standard_EXPORT void AppendPoint (const Handle(Adaptor3d_HCurve)& Curve, const Standard_Real w, const Handle(Adaptor3d_HSurface)& Surface, const Standard_Real u, const Standard_Real v);
119   
120   Standard_EXPORT void AppendSegment (const Handle(Adaptor3d_HCurve)& Curve, const Standard_Real u0, const Standard_Real u1, const Handle(Adaptor3d_HSurface)& Surface);
121
122
123
124
125 private:
126
127   
128   Standard_EXPORT void DoSurface (const Handle(Adaptor3d_HSurface)& surface, const Standard_Real u0, const Standard_Real u1, const Standard_Real v0, const Standard_Real v1, TColgp_Array2OfPnt& pntsOnSurface, Bnd_Box& boxSurface, Standard_Real& gap);
129   
130   Standard_EXPORT void DoNewBounds (const Handle(Adaptor3d_HSurface)& surface, const Standard_Real u0, const Standard_Real u1, const Standard_Real v0, const Standard_Real v1, const TColgp_Array2OfPnt& pntsOnSurface, const TColStd_Array1OfReal& X, const TColStd_Array1OfReal& Y, const TColStd_Array1OfReal& Z, TColStd_Array1OfReal& Bounds);
131
132
133
134
135 };
136
137
138
139
140
141
142
143 #endif // _IntCurveSurface_HInter_HeaderFile