2012-08-22 23:22:08 +00:00
|
|
|
//
|
2013-09-26 19:04:57 +00:00
|
|
|
// Copyright 2013 Pixar
|
2012-08-22 23:22:08 +00:00
|
|
|
//
|
2013-09-26 19:04:57 +00:00
|
|
|
// 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:
|
2012-08-22 23:22:08 +00:00
|
|
|
//
|
2013-09-26 19:04:57 +00:00
|
|
|
// 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.
|
2012-08-22 23:22:08 +00:00
|
|
|
//
|
2013-09-26 19:04:57 +00:00
|
|
|
// You may obtain a copy of the Apache License at
|
2012-08-22 23:22:08 +00:00
|
|
|
//
|
2013-09-26 19:04:57 +00:00
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
2013-07-18 21:19:50 +00:00
|
|
|
//
|
2013-09-26 19:04:57 +00:00
|
|
|
// 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.
|
2013-05-17 17:21:38 +00:00
|
|
|
//
|
2013-09-26 19:04:57 +00:00
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
#ifndef OSD_GL_DRAW_CONTEXT_H
|
|
|
|
#define OSD_GL_DRAW_CONTEXT_H
|
2012-08-22 23:22:08 +00:00
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
#include "../version.h"
|
2012-08-22 23:22:08 +00:00
|
|
|
|
2014-03-28 19:10:13 +00:00
|
|
|
#include "../far/patchTables.h"
|
2012-12-11 01:15:13 +00:00
|
|
|
#include "../osd/drawContext.h"
|
|
|
|
#include "../osd/drawRegistry.h"
|
|
|
|
#include "../osd/vertex.h"
|
2012-08-22 23:22:08 +00:00
|
|
|
|
2013-06-10 22:54:40 +00:00
|
|
|
#include "../osd/opengl.h"
|
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
#include <map>
|
2012-08-22 23:22:08 +00:00
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
namespace OpenSubdiv {
|
|
|
|
namespace OPENSUBDIV_VERSION {
|
2012-08-22 23:22:08 +00:00
|
|
|
|
2014-09-05 22:07:46 +00:00
|
|
|
namespace Osd {
|
|
|
|
|
2013-05-17 17:21:38 +00:00
|
|
|
/// \brief OpenGL specialized DrawContext class
|
|
|
|
///
|
2014-09-05 22:07:46 +00:00
|
|
|
/// GLDrawContext implements the OSD drawing interface with the OpenGL API.
|
2013-05-17 17:21:38 +00:00
|
|
|
/// Some functionality may be disabled depending on compile and run-time driver
|
|
|
|
/// support.
|
|
|
|
///
|
|
|
|
/// Contexts interface the serialized topological data pertaining to the
|
|
|
|
/// geometric primitives with the capabilities of the selected discrete
|
|
|
|
/// compute device.
|
|
|
|
///
|
2014-09-05 22:07:46 +00:00
|
|
|
class GLDrawContext : public DrawContext {
|
2012-08-22 23:22:08 +00:00
|
|
|
public:
|
2012-12-11 01:15:13 +00:00
|
|
|
typedef GLuint VertexBufferBinding;
|
|
|
|
|
2014-09-05 22:07:46 +00:00
|
|
|
virtual ~GLDrawContext();
|
2012-12-11 01:15:13 +00:00
|
|
|
|
2014-09-05 22:07:46 +00:00
|
|
|
/// \brief Create an GLDraContext from Far::PatchTables
|
2013-05-11 02:35:25 +00:00
|
|
|
///
|
2014-09-05 22:07:46 +00:00
|
|
|
/// @param patchTables a valid set of Far::PatchTables
|
2013-05-16 00:53:40 +00:00
|
|
|
///
|
2014-04-17 23:47:48 +00:00
|
|
|
/// @param numVertexElements the number of vertex elements
|
2013-05-11 02:35:25 +00:00
|
|
|
///
|
2014-09-05 22:07:46 +00:00
|
|
|
static GLDrawContext * Create(Far::PatchTables const * patchTables, int numVertexElements);
|
2013-05-11 02:35:25 +00:00
|
|
|
|
|
|
|
/// Set vbo as a vertex texture (for gregory patch drawing)
|
2013-05-16 00:53:40 +00:00
|
|
|
///
|
|
|
|
/// @param vbo the vertex buffer object to update
|
|
|
|
///
|
2012-12-11 01:15:13 +00:00
|
|
|
template<class VERTEX_BUFFER>
|
2013-05-11 02:35:25 +00:00
|
|
|
void UpdateVertexTexture(VERTEX_BUFFER *vbo) {
|
2013-09-05 20:09:54 +00:00
|
|
|
if (vbo)
|
2014-04-17 23:47:48 +00:00
|
|
|
updateVertexTexture(vbo->BindVBO());
|
2012-12-11 01:15:13 +00:00
|
|
|
}
|
|
|
|
|
2013-05-16 00:53:40 +00:00
|
|
|
/// true if the GL version detected supports shader tessellation
|
|
|
|
static bool SupportsAdaptiveTessellation();
|
|
|
|
|
2013-06-01 00:11:16 +00:00
|
|
|
/// Returns the GL texture buffer containing the patch control vertices array
|
|
|
|
GLuint GetPatchIndexBuffer() const {
|
|
|
|
return _patchIndexBuffer;
|
|
|
|
}
|
2012-12-20 18:25:41 +00:00
|
|
|
|
2013-06-01 00:11:16 +00:00
|
|
|
/// Returns the GL texture buffer containing the patch local parameterization
|
|
|
|
/// data
|
|
|
|
GLuint GetPatchParamTextureBuffer() const {
|
|
|
|
return _patchParamTextureBuffer;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Returns the GL texture buffer containing the vertex data
|
|
|
|
GLuint GetVertexTextureBuffer() const {
|
|
|
|
return _vertexTextureBuffer;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Returns the GL texture buffer containing patch vertex valence data (only
|
|
|
|
/// used by Gregory patches)
|
|
|
|
GLuint GetVertexValenceTextureBuffer() const {
|
|
|
|
return _vertexValenceTextureBuffer;
|
|
|
|
}
|
2012-12-11 01:15:13 +00:00
|
|
|
|
2013-06-01 00:11:16 +00:00
|
|
|
/// Returns the GL texture buffer containing patch quad offsets data (only
|
|
|
|
/// used by Gregory patches)
|
|
|
|
GLuint GetQuadOffsetsTextureBuffer() const {
|
|
|
|
return _quadOffsetsTextureBuffer;
|
|
|
|
}
|
2012-12-11 01:15:13 +00:00
|
|
|
|
2013-06-04 18:02:27 +00:00
|
|
|
/// Returns the GL texture buffer containing fvar data
|
|
|
|
GLuint GetFvarDataTextureBuffer() const {
|
|
|
|
return _fvarDataTextureBuffer;
|
|
|
|
}
|
|
|
|
|
2014-09-05 22:07:46 +00:00
|
|
|
/// Sets face-varying data buffer
|
|
|
|
///
|
|
|
|
/// @param patchTables A valid set of Far::PatchTables
|
|
|
|
///
|
|
|
|
/// @param fvarWidth Total face-varying primvar data width in fvarData
|
|
|
|
///
|
|
|
|
/// @param fvarData Vector containing the face-varying data
|
|
|
|
///
|
|
|
|
/// @return True if the operation was successful
|
|
|
|
///
|
|
|
|
bool SetFVarDataTexture(Far::PatchTables const & patchTables,
|
|
|
|
int fvarWidth, FVarData const & fvarData);
|
|
|
|
|
2013-05-10 02:16:51 +00:00
|
|
|
protected:
|
2014-09-05 22:07:46 +00:00
|
|
|
|
2013-06-01 00:11:16 +00:00
|
|
|
GLuint _patchIndexBuffer;
|
|
|
|
|
|
|
|
GLuint _patchParamTextureBuffer;
|
|
|
|
GLuint _fvarDataTextureBuffer;
|
|
|
|
|
|
|
|
GLuint _vertexTextureBuffer;
|
|
|
|
GLuint _vertexValenceTextureBuffer;
|
|
|
|
GLuint _quadOffsetsTextureBuffer;
|
|
|
|
|
2014-09-05 22:07:46 +00:00
|
|
|
GLDrawContext();
|
2013-05-11 02:35:25 +00:00
|
|
|
|
|
|
|
// allocate buffers from patchTables
|
2014-09-05 22:07:46 +00:00
|
|
|
bool create(Far::PatchTables const & patchTables, int numElements);
|
2013-05-11 02:35:25 +00:00
|
|
|
|
2014-04-17 23:47:48 +00:00
|
|
|
void updateVertexTexture(GLuint vbo);
|
2012-08-22 23:22:08 +00:00
|
|
|
};
|
|
|
|
|
2014-09-05 22:07:46 +00:00
|
|
|
} // end namespace Osd
|
|
|
|
|
|
|
|
} // end namespace OPENSUBDIV_VERSION
|
2012-08-22 23:22:08 +00:00
|
|
|
using namespace OPENSUBDIV_VERSION;
|
|
|
|
|
|
|
|
} // end namespace OpenSubdiv
|
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
#endif /* OSD_DRAW_CONTEXT_H */
|