mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
OpenGl_Resource was slightly corrected and OpenGl_Element was extended with Release method to manage GPU resources. OpenGl_PrimitiveArray now uses new OpenGl_VertexBuffer class (requires OpenGL 1.5+). Strange workarounds for feedback mode were removed. OpenGl_Context now provides access to shared GPU resources and manages resources queue for delayed release (replaces functionality of removed OpenGl_ResourceCleaner). Loaded GL_ARB_texture_buffer_object and GL_ARB_draw_instanced extensions. Global maps of views, workspaces and structures were moved to OpenGl_GraphicDriver members. UserDrawCallback() function moved to OpenGl_GraphicDriver methods. Aspect_GraphicCallbackStruct now holds handle of OpenGl_Context instead of system-dependent pointers to GL context definition. New classes NCollection_Vec2, NCollection_Vec3 and NCollection_Vec4 implements interface to low-level data (points, vertices, colors) in GLSL-style. Removed EnableVBO argument from vdrawparray Draw Harness command Corrected compilation errors Fixed wrong argument in Index VBO initialization Fixed several cases of incorrect memory management in TKV3d Visual3d_ViewManager::Remove() Destroy structures before last view removed for correct GPU resources management. Graphic3d_Structure::GraphicClear() Remove groups to avoid usage of dead OpenGl_Group pointers. V3d_View::Remove() Fixed mistake in #0000280 patch. Small correction Fixed OCC280 test command Replace removed view within created one in ViewerTest EventManager. ViewerTest, do not create unused 3D view In current design NIS_View always created and used for both - NIS objects and AIS objects.
159 lines
6.5 KiB
C++
159 lines
6.5 KiB
C++
// Created by: Kirill GAVRILOV
|
|
// Copyright (c) 2012 OPEN CASCADE SAS
|
|
//
|
|
// The content of this file is subject to the Open CASCADE Technology Public
|
|
// License Version 6.5 (the "License"). You may not use the content of this file
|
|
// except in compliance with the License. Please obtain a copy of the License
|
|
// at http://www.opencascade.org and read it completely before using this file.
|
|
//
|
|
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
|
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
|
//
|
|
// The Original Code and all software distributed under the License is
|
|
// distributed on an "AS IS" basis, without warranty of any kind, and the
|
|
// Initial Developer hereby disclaims all such warranties, including without
|
|
// limitation, any warranties of merchantability, fitness for a particular
|
|
// purpose or non-infringement. Please see the License for the specific terms
|
|
// and conditions governing the rights and limitations under the License.
|
|
|
|
#ifndef _OpenGl_VertexBuffer_H__
|
|
#define _OpenGl_VertexBuffer_H__
|
|
|
|
#include <OpenGl_GlCore20.hxx>
|
|
#include <OpenGl_Resource.hxx>
|
|
|
|
class Handle(OpenGl_Context);
|
|
class OpenGl_Context;
|
|
|
|
//! Vertex Buffer Object - is a general storage object for vertex attributes (position, normal, color).
|
|
//! Notice that you should use OpenGl_IndexBuffer specialization for array of indices.
|
|
class OpenGl_VertexBuffer : public OpenGl_Resource
|
|
{
|
|
|
|
public:
|
|
|
|
//! Helpful constants
|
|
static const GLuint NO_BUFFER = 0;
|
|
|
|
public:
|
|
|
|
//! Create uninitialized VBO.
|
|
Standard_EXPORT OpenGl_VertexBuffer();
|
|
|
|
//! Destroy object.
|
|
Standard_EXPORT virtual ~OpenGl_VertexBuffer();
|
|
|
|
Standard_EXPORT virtual GLenum GetTarget() const;
|
|
|
|
//! @return true if current object was initialized
|
|
inline bool IsValid() const
|
|
{
|
|
return myBufferId != NO_BUFFER;
|
|
}
|
|
|
|
//! @return the number of components per generic vertex attribute.
|
|
inline GLuint GetComponentsNb() const
|
|
{
|
|
return myComponentsNb;
|
|
}
|
|
|
|
//! @return number of vertex attributes / number of vertices.
|
|
inline GLsizei GetElemsNb() const
|
|
{
|
|
return myElemsNb;
|
|
}
|
|
|
|
//! @return data type of each component in the array.
|
|
inline GLenum GetDataType() const
|
|
{
|
|
return myDataType;
|
|
}
|
|
|
|
//! Creates VBO name (id) if not yet generated.
|
|
//! Data should be initialized by another method.
|
|
Standard_EXPORT bool Create (const Handle(OpenGl_Context)& theGlCtx);
|
|
|
|
//! Destroy object - will release GPU memory if any.
|
|
Standard_EXPORT virtual void Release (const OpenGl_Context* theGlCtx);
|
|
|
|
//! Bind this VBO.
|
|
Standard_EXPORT void Bind (const Handle(OpenGl_Context)& theGlCtx) const;
|
|
|
|
//! Unbind this VBO.
|
|
Standard_EXPORT void Unbind (const Handle(OpenGl_Context)& theGlCtx) const;
|
|
|
|
//! Notice that VBO will be unbound after this call.
|
|
//! @param theComponentsNb - specifies the number of components per generic vertex attribute; must be 1, 2, 3, or 4;
|
|
//! @param theElemsNb - elements count;
|
|
//! @param theData - pointer to GLfloat data (vertices/normals etc.).
|
|
Standard_EXPORT bool Init (const Handle(OpenGl_Context)& theGlCtx,
|
|
const GLuint theComponentsNb,
|
|
const GLsizei theElemsNb,
|
|
const GLfloat* theData);
|
|
|
|
//! Notice that VBO will be unbound after this call.
|
|
//! @param theComponentsNb - specifies the number of components per generic vertex attribute; must be 1, 2, 3, or 4;
|
|
//! @param theElemsNb - elements count;
|
|
//! @param theData - pointer to GLuint data (indices etc.).
|
|
Standard_EXPORT bool Init (const Handle(OpenGl_Context)& theGlCtx,
|
|
const GLuint theComponentsNb,
|
|
const GLsizei theElemsNb,
|
|
const GLuint* theData);
|
|
|
|
//! Notice that VBO will be unbound after this call.
|
|
//! @param theComponentsNb - specifies the number of components per generic vertex attribute; must be 1, 2, 3, or 4;
|
|
//! @param theElemsNb - elements count;
|
|
//! @param theData - pointer to GLubyte data (indices/colors etc.).
|
|
Standard_EXPORT bool Init (const Handle(OpenGl_Context)& theGlCtx,
|
|
const GLuint theComponentsNb,
|
|
const GLsizei theElemsNb,
|
|
const GLubyte* theData);
|
|
|
|
//! Notice that VBO will be unbound after this call.
|
|
//! Function replaces portion of data within this VBO using glBufferSubData().
|
|
//! The VBO should be initialized before call.
|
|
//! @param theElemFrom - element id from which replace buffer data (>=0);
|
|
//! @param theElemsNb - elements count (theElemFrom + theElemsNb < GetElemsNb());
|
|
//! @param theData - pointer to GLfloat data.
|
|
Standard_EXPORT bool SubData (const Handle(OpenGl_Context)& theGlCtx,
|
|
const GLsizei theElemFrom,
|
|
const GLsizei theElemsNb,
|
|
const GLfloat* theData);
|
|
|
|
//! Bind this VBO to active GLSL program.
|
|
Standard_EXPORT void BindVertexAttrib (const Handle(OpenGl_Context)& theGlCtx,
|
|
const GLuint theAttribLoc) const;
|
|
|
|
//! Unbind any VBO from active GLSL program.
|
|
Standard_EXPORT void UnbindVertexAttrib (const Handle(OpenGl_Context)& theGlCtx,
|
|
const GLuint theAttribLoc) const;
|
|
|
|
//! Bind this VBO as fixed pipeline attribute.
|
|
//! @param theGlCtx - handle to bound GL context;
|
|
//! @param theMode - array mode (GL_VERTEX_ARRAY, GL_NORMAL_ARRAY, GL_COLOR_ARRAY, GL_INDEX_ARRAY, GL_TEXTURE_COORD_ARRAY).
|
|
Standard_EXPORT void BindFixed (const Handle(OpenGl_Context)& theGlCtx,
|
|
const GLenum theMode) const;
|
|
|
|
//! Unbind this VBO as fixed pipeline attribute.
|
|
//! @param theGlCtx - handle to bound GL context;
|
|
//! @param theMode - array mode.
|
|
Standard_EXPORT void UnbindFixed (const Handle(OpenGl_Context)& theGlCtx,
|
|
const GLenum theMode) const;
|
|
|
|
protected:
|
|
|
|
GLuint myBufferId; //!< VBO name (index)
|
|
GLuint myComponentsNb; //!< Number of components per generic vertex attribute, must be 1, 2, 3, or 4
|
|
GLsizei myElemsNb; //!< Number of vertex attributes / number of vertices
|
|
GLenum myDataType; //!< Data type (GL_FLOAT, GL_UNSIGNED_INT, GL_UNSIGNED_BYTE etc.)
|
|
|
|
public:
|
|
|
|
DEFINE_STANDARD_RTTI(OpenGl_VertexBuffer) // Type definition
|
|
|
|
};
|
|
|
|
DEFINE_STANDARD_HANDLE(OpenGl_VertexBuffer, OpenGl_Resource)
|
|
|
|
#endif // _OpenGl_VertexBuffer_H__
|