0023272: Image comparison algorithm
[occt.git] / src / OpenGl / OpenGl_GraphicDriver.hxx
1 // Created on: 2011-10-20
2 // Created by: Sergey ZERCHANINOV
3 // Copyright (c) 2011-2012 OPEN CASCADE SAS
4 //
5 // The content of this file is subject to the Open CASCADE Technology Public
6 // License Version 6.5 (the "License"). You may not use the content of this file
7 // except in compliance with the License. Please obtain a copy of the License
8 // at http://www.opencascade.org and read it completely before using this file.
9 //
10 // The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
11 // main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
12 //
13 // The Original Code and all software distributed under the License is
14 // distributed on an "AS IS" basis, without warranty of any kind, and the
15 // Initial Developer hereby disclaims all such warranties, including without
16 // limitation, any warranties of merchantability, fitness for a particular
17 // purpose or non-infringement. Please see the License for the specific terms
18 // and conditions governing the rights and limitations under the License.
19
20
21 #ifndef _OpenGl_GraphicDriver_HeaderFile
22 #define _OpenGl_GraphicDriver_HeaderFile
23
24 #include <Graphic3d_GraphicDriver.hxx>
25 #include <Handle_OpenGl_GraphicDriver.hxx>
26 #include <OpenGl_Context.hxx>
27
28 #include <Standard_CString.hxx>
29
30 #include <Handle_TColStd_HArray1OfByte.hxx>
31 #include <Handle_TColStd_HArray1OfReal.hxx>
32 #include <Quantity_PlaneAngle.hxx>
33 #include <Quantity_NameOfColor.hxx>
34 #include <Handle_AlienImage_AlienImage.hxx>
35
36 #include <Aspect_Display.hxx>
37 #include <Aspect_GradientFillMethod.hxx>
38 #include <Aspect_FillMethod.hxx>
39 #include <Aspect_CLayer2d.hxx>
40 #include <Aspect_TypeOfTriedronPosition.hxx>
41 #include <Aspect_TypeOfTriedronEcho.hxx>
42 #include <Aspect_Handle.hxx>
43 #include <Aspect_PrintAlgo.hxx>
44
45 #include <Graphic3d_CView.hxx>
46 #include <Graphic3d_CStructure.hxx>
47 #include <Graphic3d_CGroup.hxx>
48 #include <Graphic3d_TypeOfPrimitive.hxx>
49 #include <Graphic3d_CPick.hxx>
50 #include <Graphic3d_TypeOfPolygon.hxx>
51 #include <Graphic3d_TextPath.hxx>
52 #include <Graphic3d_HorizontalTextAlignment.hxx>
53 #include <Graphic3d_VerticalTextAlignment.hxx>
54 #include <Graphic3d_PrimitiveArray.hxx>
55 #include <Graphic3d_CUserDraw.hxx>
56 #include <Graphic3d_CGraduatedTrihedron.hxx>
57 #include <Graphic3d_TypeOfComposition.hxx>
58 #include <Graphic3d_TypeOfTexture.hxx>
59 #include <Graphic3d_CInitTexture.hxx>
60 #include <Graphic3d_ExportFormat.hxx>
61 #include <Graphic3d_SortType.hxx>
62 #include <Graphic3d_PtrFrameBuffer.hxx>
63 #include <Graphic3d_Array1OfVertex.hxx>
64 #include <Graphic3d_Array1OfVertexN.hxx>
65 #include <Graphic3d_Array1OfVertexNT.hxx>
66 #include <Graphic3d_Array1OfVertexC.hxx>
67 #include <Graphic3d_Array1OfVertexNC.hxx>
68 #include <Graphic3d_Array2OfVertex.hxx>
69 #include <Graphic3d_Array2OfVertexN.hxx>
70 #include <Graphic3d_Array2OfVertexNT.hxx>
71 #include <Graphic3d_BufferType.hxx>
72 #include <NCollection_DataMap.hxx>
73
74 class TColStd_Array1OfInteger;
75 class TColStd_Array1OfReal;
76 class TColStd_Array2OfReal;
77 class TColStd_HArray1OfByte;
78 class Graphic3d_VertexNC;
79 class Graphic3d_Vector;
80 class Quantity_Color;
81 class Graphic3d_Vertex;
82 class Aspect_Array1OfEdge;
83 class TCollection_ExtendedString;
84 class AlienImage_AlienImage;
85 class Image_PixMap;
86 class TColStd_HArray1OfReal;
87 class Handle(OpenGl_View);
88 class Handle(OpenGl_Workspace);
89 class OpenGl_Element;
90 class OpenGl_Structure;
91
92 //! This class defines an OpenGl graphic driver <br>
93 class OpenGl_GraphicDriver : public Graphic3d_GraphicDriver
94 {
95  public:
96
97   //! Constructor
98   Standard_EXPORT OpenGl_GraphicDriver (const Standard_CString theShrName);
99
100   Standard_EXPORT Standard_Boolean Begin (const Standard_CString ADisplay);
101   Standard_EXPORT Standard_Boolean Begin (const Aspect_Display ADisplay);
102   Standard_EXPORT void End ();
103   Standard_EXPORT Standard_Integer InquireLightLimit ();
104   Standard_EXPORT void InquireMat (const Graphic3d_CView& ACView, TColStd_Array2OfReal& AMatO, TColStd_Array2OfReal& AMatM);
105   Standard_EXPORT Standard_Integer InquireViewLimit ();
106   Standard_EXPORT Standard_Boolean InquireTextureAvailable ();
107   Standard_EXPORT void Blink (const Graphic3d_CStructure& ACStructure,const Standard_Boolean Create);
108   Standard_EXPORT void BoundaryBox (const Graphic3d_CStructure& ACStructure, const Standard_Boolean Create);
109   Standard_EXPORT void HighlightColor (const Graphic3d_CStructure& ACStructure, const Standard_ShortReal R, const Standard_ShortReal G, const Standard_ShortReal B, const Standard_Boolean Create);
110   Standard_EXPORT void NameSetStructure (const Graphic3d_CStructure& ACStructure);
111
112 public: // Methods for graphical groups
113
114   Standard_EXPORT void ClearGroup (const Graphic3d_CGroup& ACGroup);
115   Standard_EXPORT void CloseGroup (const Graphic3d_CGroup& ACGroup);
116   Standard_EXPORT void FaceContextGroup (const Graphic3d_CGroup& theCGroup,
117                                          const Standard_Integer  theNoInsert);
118   Standard_EXPORT void Group (Graphic3d_CGroup& theCGroup);
119   Standard_EXPORT void LineContextGroup (const Graphic3d_CGroup& theCGroup,
120                                          const Standard_Integer  theNoInsert);
121   Standard_EXPORT void MarkerContextGroup (const Graphic3d_CGroup& theCGroup,
122                                            const Standard_Integer  theNoInsert);
123   Standard_EXPORT void MarkerContextGroup (const Graphic3d_CGroup& theCGroup,
124                                            const Standard_Integer  theNoInsert,
125                                            const Standard_Integer  theMarkWidth,
126                                            const Standard_Integer  theMarkHeight,
127                                            const Handle(TColStd_HArray1OfByte)& theTexture);
128   Standard_EXPORT void OpenGroup (const Graphic3d_CGroup& theCGroup);
129   Standard_EXPORT void RemoveGroup (const Graphic3d_CGroup& theCGroup);
130   Standard_EXPORT void TextContextGroup (const Graphic3d_CGroup& theCGroup,
131                                          const Standard_Integer  theNoInsert);
132
133 public: // Methods for graphical structures
134
135   Standard_EXPORT void ClearStructure (const Graphic3d_CStructure& theCStructure);
136   Standard_EXPORT void ContextStructure (const Graphic3d_CStructure& theCStructure);
137   Standard_EXPORT void Connect (const Graphic3d_CStructure& theFather,
138                                 const Graphic3d_CStructure& theSon);
139   Standard_EXPORT void Disconnect (const Graphic3d_CStructure& theFather,
140                                    const Graphic3d_CStructure& theSon);
141   Standard_EXPORT void DisplayStructure (const Graphic3d_CView&      theCView,
142                                          const Graphic3d_CStructure& theCStructure,
143                                          const Standard_Integer      thePriority);
144   Standard_EXPORT void EraseStructure (const Graphic3d_CView&      theCView,
145                                        const Graphic3d_CStructure& theCStructure);
146   Standard_EXPORT void RemoveStructure (const Graphic3d_CStructure& theCStructure);
147   Standard_EXPORT void Structure (Graphic3d_CStructure& theCStructure);
148
149 public:
150
151   Standard_EXPORT void ActivateView (const Graphic3d_CView& ACView);
152   Standard_EXPORT void AntiAliasing (const Graphic3d_CView& ACView, const Standard_Boolean AFlag);
153   Standard_EXPORT void Background (const Graphic3d_CView& ACView);
154   Standard_EXPORT void GradientBackground (const Graphic3d_CView& ACView, const Quantity_Color& AColor1, const Quantity_Color& AColor2, const Aspect_GradientFillMethod FillStyle);
155   Standard_EXPORT void BackgroundImage (const Standard_CString FileName, const Graphic3d_CView& ACView, const Aspect_FillMethod FillStyle);
156   Standard_EXPORT void SetBgImageStyle (const Graphic3d_CView& ACView, const Aspect_FillMethod FillStyle);
157   Standard_EXPORT void SetBgGradientStyle (const Graphic3d_CView& ACView, const Aspect_GradientFillMethod FillStyle);
158   Standard_EXPORT void ClipLimit (const Graphic3d_CView& ACView, const Standard_Boolean AWait);
159   Standard_EXPORT void DeactivateView (const Graphic3d_CView& ACView);
160   Standard_EXPORT void DepthCueing (const Graphic3d_CView& ACView, const Standard_Boolean AFlag);
161   Standard_EXPORT Standard_Boolean ProjectRaster (const Graphic3d_CView& ACView, const Standard_ShortReal AX, const Standard_ShortReal AY, const Standard_ShortReal AZ, Standard_Integer& AU, Standard_Integer& AV);
162   Standard_EXPORT Standard_Boolean UnProjectRaster (const Graphic3d_CView& ACView, const Standard_Integer Axm, const Standard_Integer Aym, const Standard_Integer AXM, const Standard_Integer AYM, const Standard_Integer AU, const Standard_Integer AV, Standard_ShortReal& AX, Standard_ShortReal& AY, Standard_ShortReal& AZ);
163   Standard_EXPORT Standard_Boolean UnProjectRasterWithRay (const Graphic3d_CView& ACView, const Standard_Integer Axm, const Standard_Integer Aym, const Standard_Integer AXM, const Standard_Integer AYM, const Standard_Integer AU, const Standard_Integer AV, Standard_ShortReal& AX, Standard_ShortReal& AY, Standard_ShortReal& AZ, Standard_ShortReal& DX, Standard_ShortReal& DY, Standard_ShortReal& DZ);
164   Standard_EXPORT void RatioWindow (const Graphic3d_CView& ACView);
165   Standard_EXPORT void Redraw (const Graphic3d_CView& ACView, const Aspect_CLayer2d& ACUnderLayer, const Aspect_CLayer2d& ACOverLayer, const Standard_Integer x = 0, const Standard_Integer y = 0, const Standard_Integer width = 0, const Standard_Integer height = 0);
166   Standard_EXPORT void RemoveView (const Graphic3d_CView& ACView);
167   Standard_EXPORT void SetLight (const Graphic3d_CView& ACView);
168   Standard_EXPORT void SetPlane (const Graphic3d_CView& ACView);
169   Standard_EXPORT void SetVisualisation (const Graphic3d_CView& ACView);
170   Standard_EXPORT void TransformStructure (const Graphic3d_CStructure& ACStructure);
171   Standard_EXPORT void DegenerateStructure (const Graphic3d_CStructure& ACStructure);
172   Standard_EXPORT void Transparency (const Graphic3d_CView& ACView, const Standard_Boolean AFlag);
173   Standard_EXPORT void Update (const Graphic3d_CView& ACView, const Aspect_CLayer2d& ACUnderLayer, const Aspect_CLayer2d& ACOverLayer);
174   Standard_EXPORT Standard_Boolean View (Graphic3d_CView& ACView);
175   Standard_EXPORT void ViewMapping (const Graphic3d_CView& ACView, const Standard_Boolean AWait);
176   Standard_EXPORT void ViewOrientation (const Graphic3d_CView& ACView,const Standard_Boolean AWait);
177   Standard_EXPORT void Environment (const Graphic3d_CView& ACView);
178   Standard_EXPORT void Marker (const Graphic3d_CGroup& ACGroup, const Graphic3d_Vertex& APoint, const Standard_Boolean EvalMinMax = Standard_True);
179   Standard_EXPORT void MarkerSet (const Graphic3d_CGroup& ACGroup, const Graphic3d_Array1OfVertex& ListVertex, const Standard_Boolean EvalMinMax = Standard_True);
180   Standard_EXPORT void Polygon (const Graphic3d_CGroup& ACGroup, const Graphic3d_Array1OfVertex& ListVertex, const Graphic3d_TypeOfPolygon AType = Graphic3d_TOP_CONVEX, const Standard_Boolean EvalMinMax = Standard_True);
181   Standard_EXPORT void Text (const Graphic3d_CGroup& ACGroup, const Standard_CString AText, const Graphic3d_Vertex& APoint, const Standard_Real AHeight, const Quantity_PlaneAngle AAngle, const Graphic3d_TextPath ATp, const Graphic3d_HorizontalTextAlignment AHta, const Graphic3d_VerticalTextAlignment AVta, const Standard_Boolean EvalMinMax = Standard_True);
182   Standard_EXPORT void Text (const Graphic3d_CGroup& ACGroup, const Standard_CString AText, const Graphic3d_Vertex& APoint, const Standard_Real AHeight, const Standard_Boolean EvalMinMax = Standard_True);
183   Standard_EXPORT void Text (const Graphic3d_CGroup& ACGroup, const TCollection_ExtendedString& AText, const Graphic3d_Vertex& APoint, const Standard_Real AHeight, const Quantity_PlaneAngle AAngle, const Graphic3d_TextPath ATp, const Graphic3d_HorizontalTextAlignment AHta, const Graphic3d_VerticalTextAlignment AVta, const Standard_Boolean EvalMinMax = Standard_True);
184   Standard_EXPORT void Text (const Graphic3d_CGroup& ACGroup, const TCollection_ExtendedString& AText, const Graphic3d_Vertex& APoint, const Standard_Real AHeight, const Standard_Boolean EvalMinMax = Standard_True);
185   Standard_EXPORT void PrimitiveArray (const Graphic3d_CGroup& ACGroup,const Graphic3d_PrimitiveArray& parray,const Standard_Boolean EvalMinMax = Standard_True);
186   Standard_EXPORT void UserDraw (const Graphic3d_CGroup& ACGroup,const Graphic3d_CUserDraw& AUserDraw);
187   Standard_EXPORT void ZBufferTriedronSetup (const Quantity_NameOfColor XColor = Quantity_NOC_RED, const Quantity_NameOfColor YColor = Quantity_NOC_GREEN, const Quantity_NameOfColor ZColor = Quantity_NOC_BLUE1, const Standard_Real SizeRatio = 0.8, const Standard_Real AxisDiametr = 0.05, const Standard_Integer NbFacettes = 12);
188   Standard_EXPORT void TriedronDisplay (const Graphic3d_CView& ACView, const Aspect_TypeOfTriedronPosition APosition = Aspect_TOTP_CENTER, const Quantity_NameOfColor AColor = Quantity_NOC_WHITE, const Standard_Real AScale = 0.02, const Standard_Boolean AsWireframe = Standard_True);
189   Standard_EXPORT void TriedronErase (const Graphic3d_CView& ACView);
190   Standard_EXPORT void TriedronEcho (const Graphic3d_CView& ACView, const Aspect_TypeOfTriedronEcho AType = Aspect_TOTE_NONE);
191   Standard_EXPORT void GraduatedTrihedronDisplay (const Graphic3d_CView& view, const Graphic3d_CGraduatedTrihedron& cubic);
192   Standard_EXPORT void GraduatedTrihedronErase (const Graphic3d_CView& view);
193   Standard_EXPORT void GraduatedTrihedronMinMaxValues (const Standard_ShortReal xmin, const Standard_ShortReal ymin, const Standard_ShortReal zmin, const Standard_ShortReal xmax, const Standard_ShortReal ymax, const Standard_ShortReal zmax);
194   Standard_EXPORT void BeginAnimation (const Graphic3d_CView& ACView);
195   Standard_EXPORT void EndAnimation (const Graphic3d_CView& ACView);
196   Standard_EXPORT Standard_Boolean BeginAddMode (const Graphic3d_CView& ACView);
197   Standard_EXPORT void EndAddMode ();
198   Standard_EXPORT Standard_Boolean BeginImmediatMode(const Graphic3d_CView& ACView, const Aspect_CLayer2d& ACUnderLayer, const Aspect_CLayer2d& ACOverLayer, const Standard_Boolean DoubleBuffer, const Standard_Boolean RetainMode);
199   Standard_EXPORT void BeginPolyline ();
200   Standard_EXPORT void ClearImmediatMode (const Graphic3d_CView& ACView,const Standard_Boolean aFlush = Standard_True);
201   Standard_EXPORT void Draw (const Standard_ShortReal X, const Standard_ShortReal Y, const Standard_ShortReal Z);
202   Standard_EXPORT void DrawStructure (const Graphic3d_CStructure& ACStructure);
203   Standard_EXPORT void EndImmediatMode (const Standard_Integer Synchronize);
204   Standard_EXPORT void EndPolyline ();
205   Standard_EXPORT void Move (const Standard_ShortReal X, const Standard_ShortReal Y, const Standard_ShortReal Z);
206   Standard_EXPORT void SetLineColor (const Standard_ShortReal R, const Standard_ShortReal G, const Standard_ShortReal B);
207   Standard_EXPORT void SetLineType (const Standard_Integer Type);
208   Standard_EXPORT void SetLineWidth (const Standard_ShortReal Width);
209   Standard_EXPORT void SetMinMax (const Standard_ShortReal X1, const Standard_ShortReal Y1, const Standard_ShortReal Z1, const Standard_ShortReal X2, const Standard_ShortReal Y2, const Standard_ShortReal Z2);
210   Standard_EXPORT void Transform (const TColStd_Array2OfReal& AMatrix, const Graphic3d_TypeOfComposition AType);
211   Standard_EXPORT void Layer (Aspect_CLayer2d& ACLayer);
212   Standard_EXPORT void RemoveLayer (const Aspect_CLayer2d& ACLayer);
213   Standard_EXPORT void BeginLayer (const Aspect_CLayer2d& ACLayer);
214   Standard_EXPORT void BeginPolygon2d ();
215   Standard_EXPORT void BeginPolyline2d ();
216   Standard_EXPORT void ClearLayer (const Aspect_CLayer2d& ACLayer);
217   Standard_EXPORT void Draw (const Standard_ShortReal X,const Standard_ShortReal Y);
218   Standard_EXPORT void Edge (const Standard_ShortReal X,const Standard_ShortReal Y);
219   Standard_EXPORT void EndLayer ();
220   Standard_EXPORT void EndPolygon2d ();
221   Standard_EXPORT void EndPolyline2d ();
222   Standard_EXPORT void Move (const Standard_ShortReal X,const Standard_ShortReal Y);
223   Standard_EXPORT void Rectangle (const Standard_ShortReal X,const Standard_ShortReal Y,const Standard_ShortReal Width,const Standard_ShortReal Height);
224   Standard_EXPORT void SetColor (const Standard_ShortReal R,const Standard_ShortReal G,const Standard_ShortReal B);
225   Standard_EXPORT void SetTransparency (const Standard_ShortReal ATransparency);
226   Standard_EXPORT void UnsetTransparency ();
227   Standard_EXPORT void SetLineAttributes (const Standard_Integer Type,const Standard_ShortReal Width);
228
229   //! Set text attributes for under-/overlayer. <br>
230   //! <Font> argument defines the name of the font to be used, <br>
231   //! <Type> argument defines the display type of the text, <br>
232   //! <R> <G> <B> values define the color of decal or subtitle background. <br>
233   //! To set the color of the text you can use the SetColor method. <br>
234   Standard_EXPORT void SetTextAttributes (const Standard_CString FontName,const Standard_Integer Type,const Standard_ShortReal R,const Standard_ShortReal G,const Standard_ShortReal B);
235   Standard_EXPORT void Text (const Standard_CString AText,const Standard_ShortReal X,const Standard_ShortReal Y,const Standard_ShortReal AHeight);
236   Standard_EXPORT void TextSize (const Standard_CString AText,const Standard_ShortReal AHeight,Standard_ShortReal& AWidth,Standard_ShortReal& AnAscent,Standard_ShortReal& ADescent) const;
237   Standard_EXPORT void SetBackFacingModel (const Graphic3d_CView& aView);
238   //! print the contents of all layers of the view to the printer. <br>
239   //! <hPrnDC> : Pass the PrinterDeviceContext (HDC), <br>
240   //! <showBackground> : When set to FALSE then print the view without background color <br>
241   //! (background is white) <br>
242   //! else set to TRUE for printing with current background color. <br>
243   //! <filename>: If != NULL, then the view will be printed to a file. <br>
244   //! <printAlgorithm>: Select print algorithm: stretch, tile. <br>
245   //! <theScaleFactor>: Scaling coefficient, used internally to scale the <br>
246   //! printings accordingly to the scale factor selected in the printer <br>
247   //! properties dialog. <br>
248   //! Returns Standard_True if the data is passed to the printer, otherwise <br>
249   //! Standard_False if the print operation failed due to the printer errors, <br>
250   //! or lack of system memory. This might be related to insufficient memory <br>
251   //! or some internal errors. All this errors are indicated by the message <br>
252   //! boxes (on level of OpenGl_GraphicDriver). <br>
253   //! Warning: This function can reuse FBO assigned to the view <br>
254   //! Please take it into account if you use it for your purposes; <br>
255   Standard_EXPORT Standard_Boolean Print (const Graphic3d_CView& ACView, const Aspect_CLayer2d& ACUnderLayer, const Aspect_CLayer2d& ACOverLayer, const Aspect_Handle hPrnDC, const Standard_Boolean showBackground, const Standard_CString filename, const Aspect_PrintAlgo printAlgorithm = Aspect_PA_STRETCH, const Standard_Real theScaleFactor = 1.0) const;
256   Standard_EXPORT void SetDepthTestEnabled (const Graphic3d_CView& view,const Standard_Boolean isEnabled) const;
257   Standard_EXPORT Standard_Boolean IsDepthTestEnabled (const Graphic3d_CView& view) const;
258   //! Reads depths of shown pixels of the given rectangle (glReadPixels with GL_DEPTH_COMPONENT) <br>
259   Standard_EXPORT void ReadDepths (const Graphic3d_CView& view,const Standard_Integer x,const Standard_Integer y,const Standard_Integer width,const Standard_Integer height,const Standard_Address buffer) const;
260   //! Generate offscreen FBO (needs OpenGL2+ hardware) <br>
261   //! If not supported on hardware returns NULL. <br>
262   Standard_EXPORT Graphic3d_PtrFrameBuffer FBOCreate (const Graphic3d_CView& view, const Standard_Integer width, const Standard_Integer height);
263   //! Remove offscreen FBO <br>
264   Standard_EXPORT void FBORelease (const Graphic3d_CView& view, Graphic3d_PtrFrameBuffer& fboPtr);
265   //! Dump active rendering buffer into specified memory buffer. <br>
266   Standard_EXPORT Standard_Boolean BufferDump (const Graphic3d_CView&      theCView,
267                                                Image_PixMap&               theImage,
268                                                const Graphic3d_BufferType& theBufferType);
269   Standard_EXPORT void SetGLLightEnabled (const Graphic3d_CView& view,const Standard_Boolean isEnabled) const;
270   Standard_EXPORT Standard_Boolean IsGLLightEnabled (const Graphic3d_CView& view) const;
271   //! Clear visualization data in graphical driver and stop <br>
272   //! displaying the primitives array of the graphical group <theCGroup>. <br>
273   //! This method is internal and should be used by Graphic3d_Group only. <br>
274   Standard_EXPORT void RemovePrimitiveArray(const Graphic3d_CGroup& theCGroup,const Graphic3d_PrimitiveArray& thePArray);
275   Standard_EXPORT Standard_Integer InquirePlaneLimit();
276   Standard_EXPORT Standard_Integer CreateTexture(const Graphic3d_TypeOfTexture Type,const Handle(AlienImage_AlienImage)& Image,const Standard_CString FileName,const Handle(TColStd_HArray1OfReal)& TexUpperBounds) const;
277   Standard_EXPORT void DestroyTexture(const Standard_Integer TexId) const;
278   Standard_EXPORT void ModifyTexture(const Standard_Integer TexId,const Graphic3d_CInitTexture& AValue) const;
279   Standard_EXPORT Standard_ShortReal DefaultTextHeight() const;
280   Standard_EXPORT void FBOGetDimensions(const Graphic3d_CView& view,const Graphic3d_PtrFrameBuffer fboPtr,Standard_Integer& width,Standard_Integer& height,Standard_Integer& widthMax,Standard_Integer& heightMax);
281   Standard_EXPORT void FBOChangeViewport(const Graphic3d_CView& view,Graphic3d_PtrFrameBuffer& fboPtr,const Standard_Integer width,const Standard_Integer height);
282   Standard_EXPORT Standard_Boolean Export(const Standard_CString theFileName,const Graphic3d_ExportFormat theFormat,const Graphic3d_SortType theSortType,const Standard_Integer theWidth,const Standard_Integer theHeight,const Graphic3d_CView& theView,const Aspect_CLayer2d& theLayerUnder,const Aspect_CLayer2d& theLayerOver,const Standard_Real thePrecision = 0.005,const Standard_Address theProgressBarFunc = NULL,const Standard_Address theProgressObject = NULL);
283   
284   //! Add a new top-level z layer with ID <theLayerId> for <br>
285   //! the view. Z layers allow drawing structures in higher layers <br>
286   //! in foreground of structures in lower layers. To add a structure <br>
287   //! to desired layer on display it is necessary to set the layer <br>
288   //! index for the structure. <br>
289   Standard_EXPORT void AddZLayer(const Graphic3d_CView& theCView,
290                                  const Standard_Integer theLayerId);
291
292   //! Remove Z layer from the specified view. All structures <br>
293   //! displayed at the moment in layer will be displayed in default layer <br>
294   //! ( the bottom-level z layer ). To unset layer index from associated <br>
295   //! structures use method UnsetZLayer (...). <br>
296   Standard_EXPORT void RemoveZLayer(const Graphic3d_CView& theCView,
297                                     const Standard_Integer theLayerId);
298
299   //! Unset Z layer ID for all structures. The structure <br>
300   //! indexes will be set to default layer ( the bottom-level z layer with <br>
301   //! ID = 0 ). <br>
302   Standard_EXPORT void UnsetZLayer(const Standard_Integer theLayerId);
303
304   //! Change Z layer of a structure. The new z layer ID will <br>
305   //! be used to define the associated layer for structure on display. <br>
306   //! It is recommended to take care of redisplaying the structures already <br>
307   //! presented in view with previously set layer index. This is usually <br>
308   //! done by viewer manager. Z layers allow drawing structures in <br>
309   //! higher layers in foreground of structures in lower layers. <br>
310   Standard_EXPORT void ChangeZLayer(const Graphic3d_CStructure& theCStructure,
311                                     const Standard_Integer theLayerId);
312
313   //! Change Z layer of a structure already presented in view. <br>
314   //! It is recommended to update z layer of already <br>
315   //! displayed structures with this method before setting new z layer <br>
316   //! index to the structure. This is usually done by viewer manager. <br>
317   Standard_EXPORT void ChangeZLayer(const Graphic3d_CStructure& theCStructure,
318                                     const Graphic3d_CView& theCView,
319                                     const Standard_Integer theNewLayerId);
320
321   //! Get Z layer ID of the structure. If the structure doesn't exists in <br>
322   //! graphic driver, the method returns -1. <br>
323   Standard_EXPORT Standard_Integer GetZLayer(const Graphic3d_CStructure& theCStructure) const;
324
325 public:
326
327   //! Returns true if VBO usage does not forbidden.
328   Standard_EXPORT static Standard_Boolean ToUseVBO();
329
330   //! VBO usage can be forbidden by this method even if it is supported by GL driver.
331   //! Notice that disabling of VBO will cause rendering performance degradation.
332   //! Warning! This method should be called only before any primitives are displayed in GL scene!
333   Standard_EXPORT void EnableVBO (const Standard_Boolean theToTurnOn);
334
335   //! Returns information about GPU memory usage.
336   //! Please read OpenGl_Context::MemoryInfo() for more description.
337   Standard_EXPORT Standard_Boolean MemoryInfo (Standard_Size&           theFreeBytes,
338                                                TCollection_AsciiString& theInfo) const;
339
340   //! UserDraw function prototype
341   typedef OpenGl_Element* (*OpenGl_UserDrawCallback_t )(const CALL_DEF_USERDRAW* );
342
343   //! Method to setup UserDraw callback
344   Standard_EXPORT OpenGl_UserDrawCallback_t& UserDrawCallback();
345
346 private:
347
348   //! Method to retrieve valid GL context.
349   //! Could return NULL-handle if no window created by this driver.
350   Standard_EXPORT const Handle(OpenGl_Context)& GetSharedContext() const;
351
352   //! Deprecated.
353   void InvalidateAllWorkspaces();
354
355 public:
356
357   DEFINE_STANDARD_RTTI(OpenGl_GraphicDriver)
358
359 private:
360
361   NCollection_DataMap<Standard_Integer, Handle(OpenGl_View)>      myMapOfView;
362   NCollection_DataMap<Standard_Integer, Handle(OpenGl_Workspace)> myMapOfWS;
363   NCollection_DataMap<Standard_Integer, OpenGl_Structure*>        myMapOfStructure;
364   OpenGl_UserDrawCallback_t                                       myUserDrawCallback;
365
366 };
367
368 #endif //_OpenGl_GraphicDriver_HeaderFile