File: DrawTrSurf_BSplineSurface.hxx

package info (click to toggle)
oce 0.18.3-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 301,548 kB
  • sloc: cpp: 1,190,609; ansic: 67,225; sh: 11,630; tcl: 7,954; cs: 5,221; python: 2,867; java: 1,522; makefile: 342; xml: 292; perl: 37
file content (127 lines) | stat: -rw-r--r-- 4,557 bytes parent folder | download | duplicates (5)
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
// 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 _DrawTrSurf_BSplineSurface_HeaderFile
#define _DrawTrSurf_BSplineSurface_HeaderFile

#include <Standard.hxx>
#include <Standard_DefineHandle.hxx>
#include <Handle_DrawTrSurf_BSplineSurface.hxx>

#include <Standard_Boolean.hxx>
#include <Draw_MarkerShape.hxx>
#include <Draw_Color.hxx>
#include <Standard_Integer.hxx>
#include <DrawTrSurf_Surface.hxx>
#include <Handle_Geom_BSplineSurface.hxx>
#include <Standard_Real.hxx>
#include <Handle_Draw_Drawable3D.hxx>
class Geom_BSplineSurface;
class Draw_Color;
class Draw_Display;
class Draw_Drawable3D;



//! This class defines a drawable BSplineSurface.
//! With this class you can draw the control points and the knots
//! of the surface.
//! You can use the general class Surface from DrawTrSurf too,
//! if you just want to sea boundaries and isoparametric curves.
class DrawTrSurf_BSplineSurface : public DrawTrSurf_Surface
{

public:

  
  //! default drawing mode.
  //! The isoparametric curves corresponding to the knots values are
  //! drawn.
  //! The control points and the knots points are drawn.
  //! The boundaries are yellow, the isoparametric curves are blues.
  //! For the discretisation 50 points are computed in each parametric
  //! direction.
  Standard_EXPORT DrawTrSurf_BSplineSurface(const Handle(Geom_BSplineSurface)& S);
  

  //! The isoparametric curves corresponding to the knots values are
  //! drawn.
  Standard_EXPORT DrawTrSurf_BSplineSurface(const Handle(Geom_BSplineSurface)& S, const Draw_Color& BoundsColor, const Draw_Color& IsosColor, const Draw_Color& PolesColor, const Draw_Color& KnotsColor, const Draw_MarkerShape KnotsShape, const Standard_Integer KnotsSize, const Standard_Boolean ShowPoles, const Standard_Boolean ShowKnots, const Standard_Integer Discret, const Standard_Real Deflection, const Standard_Integer DrawMode);
  
  //! Parametric equidistant iso curves are drawn.
  Standard_EXPORT DrawTrSurf_BSplineSurface(const Handle(Geom_BSplineSurface)& S, const Standard_Integer NbUIsos, const Standard_Integer NbVIsos, const Draw_Color& BoundsColor, const Draw_Color& IsosColor, const Draw_Color& PolesColor, const Draw_Color& KnotsColor, const Draw_MarkerShape KnotsShape, const Standard_Integer KnotsSize, const Standard_Boolean ShowPoles, const Standard_Boolean ShowKnots, const Standard_Integer Discret, const Standard_Real Deflection, const Standard_Integer DrawMode);
  
  Standard_EXPORT   void DrawOn (Draw_Display& dis)  const;
  
  Standard_EXPORT   void ShowPoles() ;
  
  Standard_EXPORT   void ShowKnots() ;
  
  //! change the number of isoparametric curves to be drawn.
  Standard_EXPORT virtual   void ShowIsos (const Standard_Integer Nu, const Standard_Integer Nv) ;
  
  //! change the number of isoparametric curves to be drawn.
  Standard_EXPORT   void ShowKnotsIsos() ;
  
  //! rub out all the isoparametric curves.
  Standard_EXPORT virtual   void ClearIsos() ;
  
  Standard_EXPORT   void ClearPoles() ;
  
  Standard_EXPORT   void ClearKnots() ;
  
  Standard_EXPORT   void FindPole (const Standard_Real X, const Standard_Real Y, const Draw_Display& D, const Standard_Real Prec, Standard_Integer& UIndex, Standard_Integer& VIndex)  const;
  
  Standard_EXPORT   void FindUKnot (const Standard_Real X, const Standard_Real Y, const Draw_Display& D, const Standard_Real Prec, Standard_Integer& UIndex)  const;
  
  Standard_EXPORT   void FindVKnot (const Standard_Real X, const Standard_Real Y, const Draw_Display& D, const Standard_Real Prec, Standard_Integer& VIndex)  const;
  
      void SetPolesColor (const Draw_Color& aColor) ;
  
      void SetKnotsColor (const Draw_Color& aColor) ;
  
      void SetKnotsShape (const Draw_MarkerShape Shape) ;
  
      Draw_MarkerShape KnotsShape()  const;
  
      Draw_Color KnotsColor()  const;
  
      Draw_Color PolesColor()  const;
  
  //! For variable copy.
  Standard_EXPORT virtual   Handle(Draw_Drawable3D) Copy()  const;




  DEFINE_STANDARD_RTTI(DrawTrSurf_BSplineSurface)

protected:




private: 


  Standard_Boolean drawPoles;
  Standard_Boolean drawKnots;
  Standard_Boolean knotsIsos;
  Draw_MarkerShape knotsForm;
  Draw_Color knotsLook;
  Standard_Integer knotsDim;
  Draw_Color polesLook;


};


#include <DrawTrSurf_BSplineSurface.lxx>





#endif // _DrawTrSurf_BSplineSurface_HeaderFile