mirror of
https://github.com/PixarAnimationStudios/OpenSubdiv
synced 2024-12-02 00:00:07 +00:00
0beb654f0b
Noticed a few typos when browsing comments. Proceeded with a "manual spell check", reading all comments and tweaking spelling, grammar, punctuation. Didn't bother with Hbr library. Comments only, no functional changes.
98 lines
3.1 KiB
C++
98 lines
3.1 KiB
C++
//
|
|
// Copyright 2013 Pixar
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "Apache License")
|
|
// with the following modification; you may not use this file except in
|
|
// compliance with the Apache License and the following modification to it:
|
|
// Section 6. Trademarks. is deleted and replaced with:
|
|
//
|
|
// 6. Trademarks. This License does not grant permission to use the trade
|
|
// names, trademarks, service marks, or product names of the Licensor
|
|
// and its affiliates, except as required to comply with Section 4(c) of
|
|
// the License and to reproduce the content of the NOTICE file.
|
|
//
|
|
// You may obtain a copy of the Apache License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the Apache License with the above modification is
|
|
// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
// KIND, either express or implied. See the Apache License for the specific
|
|
// language governing permissions and limitations under the Apache License.
|
|
//
|
|
|
|
#ifndef OPENSUBDIV3_OSD_CPU_GL_VERTEX_BUFFER_H
|
|
#define OPENSUBDIV3_OSD_CPU_GL_VERTEX_BUFFER_H
|
|
|
|
#include "../version.h"
|
|
|
|
#include <cstddef>
|
|
#include "../osd/opengl.h"
|
|
|
|
namespace OpenSubdiv {
|
|
namespace OPENSUBDIV_VERSION {
|
|
|
|
namespace Osd {
|
|
|
|
///
|
|
/// \brief Concrete vertex buffer class for cpu subdivision and OpenGL drawing.
|
|
///
|
|
/// CpuGLVertexBuffer implements CpuVertexBufferInterface and
|
|
/// GLVertexBufferInterface.
|
|
///
|
|
/// The buffer interop between Cpu and GL is handled automatically when a
|
|
/// client calls BindCpuBuffer and BindVBO methods.
|
|
///
|
|
class CpuGLVertexBuffer {
|
|
public:
|
|
/// Creator. Returns NULL if error.
|
|
static CpuGLVertexBuffer * Create(int numElements, int numVertices,
|
|
void *deviceContext = NULL);
|
|
|
|
/// Destructor.
|
|
~CpuGLVertexBuffer();
|
|
|
|
/// This method is meant to be used in client code in order to provide
|
|
/// coarse vertices data to Osd.
|
|
void UpdateData(const float *src, int startVertex, int numVertices,
|
|
void *deviceContext = NULL);
|
|
|
|
/// Returns how many elements defined in this vertex buffer.
|
|
int GetNumElements() const;
|
|
|
|
/// Returns how many vertices allocated in this vertex buffer.
|
|
int GetNumVertices() const;
|
|
|
|
/// Returns cpu memory. GL buffer will be mapped to cpu address
|
|
/// if necessary.
|
|
float * BindCpuBuffer();
|
|
|
|
/// Returns the name of GL buffer object. If the buffer is mapped
|
|
/// to cpu address, it will be unmapped back to GL.
|
|
GLuint BindVBO(void *deviceContext = NULL);
|
|
|
|
protected:
|
|
/// Constructor.
|
|
CpuGLVertexBuffer(int numElements, int numVertices);
|
|
|
|
/// Allocates VBO for this buffer. Returns true if success.
|
|
bool allocate();
|
|
|
|
private:
|
|
int _numElements;
|
|
int _numVertices;
|
|
GLuint _vbo;
|
|
float *_cpuBuffer;
|
|
bool _dataDirty;
|
|
};
|
|
|
|
} // end namespace Osd
|
|
|
|
} // end namespace OPENSUBDIV_VERSION
|
|
using namespace OPENSUBDIV_VERSION;
|
|
|
|
} // end namespace OpenSubdiv
|
|
|
|
#endif // OPENSUBDIV3_OSD_CPU_GL_VERTEX_BUFFER_H
|