0031505: Point Cloud Rendering - fix on-screen statistics about number of visible...
[occt.git] / src / OpenGl / OpenGl_Text.hxx
1 // Created on: 2011-07-13
2 // Created by: Sergey ZERCHANINOV
3 // Copyright (c) 2011-2013 OPEN CASCADE SAS
4 //
5 // This file is part of Open CASCADE Technology software library.
6 //
7 // This library is free software; you can redistribute it and/or modify it under
8 // the terms of the GNU Lesser General Public License version 2.1 as published
9 // by the Free Software Foundation, with special exception defined in the file
10 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
11 // distribution for complete text of the license and disclaimer of any warranty.
12 //
13 // Alternatively, this file may be used under the terms of Open CASCADE
14 // commercial license or contractual agreement.
15
16 #ifndef OpenGl_Text_Header
17 #define OpenGl_Text_Header
18
19 #include <OpenGl_Element.hxx>
20
21 #include <OpenGl_Aspects.hxx>
22 #include <OpenGl_TextBuilder.hxx>
23
24 #include <TCollection_ExtendedString.hxx>
25 #include <Graphic3d_Vertex.hxx>
26 #include <Graphic3d_HorizontalTextAlignment.hxx>
27 #include <Graphic3d_RenderingParams.hxx>
28 #include <Graphic3d_Text.hxx>
29 #include <Graphic3d_VerticalTextAlignment.hxx>
30
31 #include <gp_Ax2.hxx>
32
33 //! Text rendering
34 class OpenGl_Text : public OpenGl_Element
35 {
36
37 public:
38
39   //! Creates new text in 3D space.
40   Standard_EXPORT OpenGl_Text (const Handle(Graphic3d_Text)& theTextParams);
41
42   //! Destructor
43   Standard_EXPORT virtual ~OpenGl_Text();
44
45   //! Release cached VBO resources and the previous font if height changed.
46   //! Cached structures will be refilled by the next render.
47   //! Call Reset after modifying text parameters.
48   Standard_EXPORT void Reset (const Handle(OpenGl_Context)& theCtx);
49
50   //! Returns text parameters
51   //! @sa Reset()
52   const Handle(Graphic3d_Text)& Text() const { return myText; }
53
54   //! Sets text parameters
55   //! @sa Reset()
56   void SetText (const Handle(Graphic3d_Text)& theText) { myText = theText; }
57
58   //! Return true if text is 2D
59   Standard_Boolean Is2D() const { return myIs2d; }
60
61   //! Set true if text is 2D
62   void Set2D (const Standard_Boolean theEnable) { myIs2d = theEnable; }
63
64   //! Setup new font size
65   Standard_EXPORT void SetFontSize (const Handle(OpenGl_Context)& theContext,
66                                     const Standard_Integer        theFontSize);
67
68   Standard_EXPORT virtual void Render  (const Handle(OpenGl_Workspace)& theWorkspace) const Standard_OVERRIDE;
69   Standard_EXPORT virtual void Release (OpenGl_Context* theContext) Standard_OVERRIDE;
70
71   //! Returns estimated GPU memory usage for holding data without considering overheads and allocation alignment rules.
72   Standard_EXPORT virtual Standard_Size EstimatedDataSize() const Standard_OVERRIDE;
73
74   //! Increment draw calls statistics.
75   Standard_EXPORT virtual void UpdateDrawStats (Graphic3d_FrameStatsDataTmp& theStats,
76                                                 bool theIsDetailed) const Standard_OVERRIDE;
77
78 public: //! @name methods for compatibility with layers
79
80   //! Empty constructor
81   Standard_EXPORT OpenGl_Text();
82
83   //! Create key for shared resource
84   Standard_EXPORT static TCollection_AsciiString FontKey (const OpenGl_Aspects& theAspect,
85                                                           Standard_Integer theHeight,
86                                                           unsigned int theResolution);
87
88   //! Find shared resource for specified font or initialize new one
89   Standard_EXPORT static Handle(OpenGl_Font) FindFont (const Handle(OpenGl_Context)& theCtx,
90                                                        const OpenGl_Aspects& theAspect,
91                                                        Standard_Integer theHeight,
92                                                        unsigned int theResolution,
93                                                        const TCollection_AsciiString& theKey);
94
95   //! Compute text width
96   Standard_EXPORT static void StringSize (const Handle(OpenGl_Context)& theCtx,
97                                           const NCollection_String&     theText,
98                                           const OpenGl_Aspects&         theTextAspect,
99                                           const Standard_ShortReal      theHeight,
100                                           const unsigned int            theResolution,
101                                           Standard_ShortReal&           theWidth,
102                                           Standard_ShortReal&           theAscent,
103                                           Standard_ShortReal&           theDescent);
104
105   //! Perform rendering
106   Standard_EXPORT void Render (const Handle(OpenGl_Context)& theCtx,
107                                const OpenGl_Aspects& theTextAspect,
108                                unsigned int theResolution = Graphic3d_RenderingParams::THE_DEFAULT_RESOLUTION) const;
109
110   //! Dumps the content of me into the stream
111   Standard_EXPORT virtual void DumpJson (Standard_OStream& theOStream, Standard_Integer theDepth = -1) const Standard_OVERRIDE;
112
113 //! @name obsolete methods
114 public:
115
116   //! Setup new string and position
117   Standard_DEPRECATED("Deprecated method Init() with obsolete arguments, use Init() and Text() instead of it")
118   Standard_EXPORT void Init (const Handle(OpenGl_Context)& theCtx,
119                              const Standard_Utf8Char*      theText,
120                              const OpenGl_Vec3&            thePoint);
121
122   //! Setup new position
123   Standard_DEPRECATED("Deprecated method SetPosition(), use Graphic3d_Text for it")
124   Standard_EXPORT void SetPosition (const OpenGl_Vec3& thePoint);
125
126 protected:
127
128   friend class OpenGl_Trihedron;
129   friend class OpenGl_GraduatedTrihedron;
130
131   //! Release cached VBO resources
132   Standard_EXPORT void releaseVbos (OpenGl_Context* theCtx);
133
134 private:
135
136   //! Setup matrix.
137   void setupMatrix (const Handle(OpenGl_Context)& theCtx,
138                     const OpenGl_Aspects& theTextAspect,
139                     const OpenGl_Vec3& theDVec) const;
140
141   //! Draw arrays of vertices.
142   void drawText (const Handle(OpenGl_Context)& theCtx,
143                  const OpenGl_Aspects& theTextAspect) const;
144
145   //! Draw rectangle from bounding text box.
146   void drawRect (const Handle(OpenGl_Context)& theCtx,
147                  const OpenGl_Aspects& theTextAspect,
148                  const OpenGl_Vec4& theColorSubs) const;
149
150   //! Main rendering code
151   void render (const Handle(OpenGl_Context)& theCtx,
152                const OpenGl_Aspects& theTextAspect,
153                const OpenGl_Vec4& theColorText,
154                const OpenGl_Vec4& theColorSubs,
155                unsigned int theResolution) const;
156
157 protected:
158
159   Handle(Graphic3d_Text)                                  myText;     //!< text parameters
160   mutable Handle(OpenGl_Font)                             myFont;
161   mutable NCollection_Vector<GLuint>                      myTextures;   //!< textures' IDs
162   mutable NCollection_Vector<Handle(OpenGl_VertexBuffer)> myVertsVbo;   //!< VBOs of vertices
163   mutable NCollection_Vector<Handle(OpenGl_VertexBuffer)> myTCrdsVbo;   //!< VBOs of texture coordinates
164   mutable Handle(OpenGl_VertexBuffer)                     myBndVertsVbo;//!< VBOs of vertices for bounding box
165   mutable Font_Rect                                       myBndBox;
166
167 protected:
168
169   mutable OpenGl_Mat4d myProjMatrix;
170   mutable OpenGl_Mat4d myModelMatrix;
171   mutable OpenGl_Mat4d myOrientationMatrix;
172   mutable OpenGl_Vec3d myWinXYZ;
173   mutable GLdouble myScaleHeight;
174
175 protected:
176
177   Standard_Boolean myIs2d;
178 public:
179
180   DEFINE_STANDARD_ALLOC
181
182 };
183
184 #endif //OpenGl_Text_Header