Fix a bug of bad fvar splicing for loop surface.

This commit is contained in:
Takahito Tejima 2013-09-23 14:18:43 -07:00
parent c018aa1fc6
commit d44724c5b7
7 changed files with 34 additions and 8 deletions

View File

@ -149,6 +149,9 @@ MyDrawDelegate::DrawElements(OpenSubdiv::OsdDrawContext::PatchArray const &patch
if (patchArray.GetDescriptor().GetType() == OpenSubdiv::FarPatchTables::QUADS) { if (patchArray.GetDescriptor().GetType() == OpenSubdiv::FarPatchTables::QUADS) {
glDrawElements(GL_LINES_ADJACENCY, patchArray.GetNumIndices(), GL_UNSIGNED_INT, glDrawElements(GL_LINES_ADJACENCY, patchArray.GetNumIndices(), GL_UNSIGNED_INT,
(void*)(patchArray.GetVertIndex()*sizeof(GLuint))); (void*)(patchArray.GetVertIndex()*sizeof(GLuint)));
} else if (patchArray.GetDescriptor().GetType() == OpenSubdiv::FarPatchTables::TRIANGLES) {
glDrawElements(GL_TRIANGLES, patchArray.GetNumIndices(), GL_UNSIGNED_INT,
(void*)(patchArray.GetVertIndex()*sizeof(GLuint)));
} else { } else {
#if defined(GL_ARB_tessellation_shader) || defined(GL_VERSION_4_0) #if defined(GL_ARB_tessellation_shader) || defined(GL_VERSION_4_0)
glDrawElements(GL_PATCHES, patchArray.GetNumIndices(), GL_UNSIGNED_INT, glDrawElements(GL_PATCHES, patchArray.GetNumIndices(), GL_UNSIGNED_INT,

View File

@ -141,8 +141,13 @@ MyEffect::BindDrawConfig(MyDrawConfig *config, OpenSubdiv::OsdDrawContext::Patch
GLint diffuseColor = config->diffuseColorUniform; GLint diffuseColor = config->diffuseColorUniform;
if (displayPatchColor) { if (displayPatchColor) {
float const * color = getAdaptivePatchColor( desc ); if (desc.GetType() == OpenSubdiv::FarPatchTables::QUADS or
glProgramUniform4f(program, diffuseColor, color[0], color[1], color[2], color[3]); desc.GetType() == OpenSubdiv::FarPatchTables::TRIANGLES) {
glProgramUniform4f(program, diffuseColor, 0.4f, 0.4f, 0.8f, 1);
} else {
const float *color = getAdaptivePatchColor( desc );
glProgramUniform4f(program, diffuseColor, color[0], color[1], color[2], color[3]);
}
} }
#endif #endif
} }

View File

@ -51,7 +51,8 @@ MyEffectRegistry::_CreateDrawSourceConfig(DescType const & desc) {
} }
const char *glslVersion = "#version 400\n"; const char *glslVersion = "#version 400\n";
if (desc.first.GetType() == OpenSubdiv::FarPatchTables::QUADS) { if (desc.first.GetType() == OpenSubdiv::FarPatchTables::QUADS or
desc.first.GetType() == OpenSubdiv::FarPatchTables::TRIANGLES) {
sconfig->vertexShader.source = shaderSource; sconfig->vertexShader.source = shaderSource;
sconfig->vertexShader.version = glslVersion; sconfig->vertexShader.version = glslVersion;
sconfig->vertexShader.AddDefine("VERTEX_SHADER"); sconfig->vertexShader.AddDefine("VERTEX_SHADER");
@ -76,6 +77,7 @@ MyEffectRegistry::_CreateDrawSourceConfig(DescType const & desc) {
// uniform loop // uniform loop
sconfig->geometryShader.AddDefine("PRIM_TRI"); sconfig->geometryShader.AddDefine("PRIM_TRI");
sconfig->fragmentShader.AddDefine("PRIM_TRI"); sconfig->fragmentShader.AddDefine("PRIM_TRI");
sconfig->commonShader.AddDefine("LOOP");
sconfig->commonShader.AddDefine("UNIFORM_SUBDIVISION"); sconfig->commonShader.AddDefine("UNIFORM_SUBDIVISION");
} else { } else {
// adaptive // adaptive

View File

@ -126,6 +126,12 @@ void emit(int index, vec3 normal)
#endif #endif
#ifdef FACEVARYING_COLOR #ifdef FACEVARYING_COLOR
#ifdef LOOP // ----- scheme : LOOP
vec2 uv;
OSD_COMPUTE_FACE_VARYING_TRI_2(uv, /*fvarOffste=*/0, index);
#else // ----- scheme : CATMARK / BILINEAR
#ifdef UNIFORM_SUBDIVISION #ifdef UNIFORM_SUBDIVISION
vec2 quadst[4] = vec2[](vec2(0,0), vec2(1,0), vec2(1,1), vec2(0,1)); vec2 quadst[4] = vec2[](vec2(0,0), vec2(1,0), vec2(1,1), vec2(0,1));
vec2 st = quadst[index]; vec2 st = quadst[index];
@ -134,6 +140,7 @@ void emit(int index, vec3 normal)
#endif #endif
vec2 uv; vec2 uv;
OSD_COMPUTE_FACE_VARYING_2(uv, /*fvarOffset=*/0, st); OSD_COMPUTE_FACE_VARYING_2(uv, /*fvarOffset=*/0, st);
#endif // ------ scheme
outpt.color = vec3(uv.s, uv.t, 0); outpt.color = vec3(uv.s, uv.t, 0);
#endif #endif
@ -283,7 +290,7 @@ lighting(vec4 diffuse, vec3 Peye, vec3 Neye)
float d = max(0.0, dot(n, l)); float d = max(0.0, dot(n, l));
float s = pow(max(0.0, dot(n, h)), 500.0f); float s = pow(max(0.0, dot(n, h)), 500.0f);
color += lightSource[i].ambient * ambientColor color += lightSource[i].ambient * diffuse * ambientColor
+ d * lightSource[i].diffuse * diffuse + d * lightSource[i].diffuse * diffuse
+ s * lightSource[i].specular; + s * lightSource[i].specular;
} }

View File

@ -137,7 +137,6 @@ void initializeShapes( ) {
g_defaultShapes.push_back(SimpleShape(bilinear_cube, "bilinear_cube", kBilinear)); g_defaultShapes.push_back(SimpleShape(bilinear_cube, "bilinear_cube", kBilinear));
/*
#include <shapes/loop_cube_creases0.h> #include <shapes/loop_cube_creases0.h>
g_defaultShapes.push_back(SimpleShape(loop_cube_creases0, "loop_cube_creases0", kLoop)); g_defaultShapes.push_back(SimpleShape(loop_cube_creases0, "loop_cube_creases0", kLoop));
@ -161,5 +160,4 @@ void initializeShapes( ) {
#include <shapes/loop_triangle_edgeonly.h> #include <shapes/loop_triangle_edgeonly.h>
g_defaultShapes.push_back(SimpleShape(loop_triangle_edgeonly, "loop_triangle_edgeonly", kLoop)); g_defaultShapes.push_back(SimpleShape(loop_triangle_edgeonly, "loop_triangle_edgeonly", kLoop));
*/
} }

View File

@ -418,12 +418,17 @@ rebuild()
for (int i = 0; i < g_modelCount*g_modelCount; ++i) { for (int i = 0; i < g_modelCount*g_modelCount; ++i) {
g_vertexOffsets.push_back(vertexOffset); g_vertexOffsets.push_back(vertexOffset);
while (g_defaultShapes[shape].scheme != scheme) {
++shape;
if (shape >= (int)g_defaultShapes.size()) shape = 0;
}
OpenSubdiv::FarMesh<OpenSubdiv::OsdVertex> *farMesh = createFarMesh( OpenSubdiv::FarMesh<OpenSubdiv::OsdVertex> *farMesh = createFarMesh(
g_defaultShapes[ shape ].data.c_str(), g_level, adaptive, scheme); g_defaultShapes[ shape ].data.c_str(), g_level, adaptive, scheme);
farMeshes.push_back(farMesh); farMeshes.push_back(farMesh);
vertexOffset += farMesh->GetNumVertices(); vertexOffset += farMesh->GetNumVertices();
shape++; ++shape;
if (shape >= (int)g_defaultShapes.size()) shape = 0; if (shape >= (int)g_defaultShapes.size()) shape = 0;
} }

View File

@ -89,6 +89,7 @@ private:
int _maxlevel; int _maxlevel;
int _maxvalence; int _maxvalence;
bool _isLoop;
// patch arrays for each mesh // patch arrays for each mesh
std::vector<FarPatchTables::PatchArrayVector> _multiPatchArrays; std::vector<FarPatchTables::PatchArrayVector> _multiPatchArrays;
@ -104,6 +105,7 @@ FarMultiMeshFactory<T, U>::Create(std::vector<FarMesh<U> const *> const &meshes)
const std::type_info &scheme = typeid(*(meshes[0]->GetSubdivisionTables())); const std::type_info &scheme = typeid(*(meshes[0]->GetSubdivisionTables()));
_maxlevel = 0; _maxlevel = 0;
_maxvalence = 0; _maxvalence = 0;
_isLoop = false;
for (size_t i = 0; i < meshes.size(); ++i) { for (size_t i = 0; i < meshes.size(); ++i) {
FarMesh<U> const *mesh = meshes[i]; FarMesh<U> const *mesh = meshes[i];
@ -244,10 +246,13 @@ FarMultiMeshFactory<T, U>::spliceSubdivisionTables(FarMesh<U> *farMesh, FarMeshV
if (scheme == typeid(FarCatmarkSubdivisionTables<U>) ) { if (scheme == typeid(FarCatmarkSubdivisionTables<U>) ) {
result = new FarCatmarkSubdivisionTables<U>(farMesh, _maxlevel); result = new FarCatmarkSubdivisionTables<U>(farMesh, _maxlevel);
_isLoop = false;
} else if (scheme == typeid(FarBilinearSubdivisionTables<U>) ) { } else if (scheme == typeid(FarBilinearSubdivisionTables<U>) ) {
result = new FarBilinearSubdivisionTables<U>(farMesh, _maxlevel); result = new FarBilinearSubdivisionTables<U>(farMesh, _maxlevel);
_isLoop = false;
} else if (scheme == typeid(FarLoopSubdivisionTables<U>) ) { } else if (scheme == typeid(FarLoopSubdivisionTables<U>) ) {
result = new FarLoopSubdivisionTables<U>(farMesh, _maxlevel); result = new FarLoopSubdivisionTables<U>(farMesh, _maxlevel);
_isLoop = true;
} }
result->_F_ITa.resize(total_F_ITa); result->_F_ITa.resize(total_F_ITa);
@ -569,7 +574,8 @@ FarMultiMeshFactory<T, U>::splicePatchTables(FarMeshVector const &meshes, bool h
FarPatchTables const *ptables = meshes[i]->GetPatchTables(); FarPatchTables const *ptables = meshes[i]->GetPatchTables();
FarPatchTables::PatchArray const *parray = ptables->GetPatchArray(*it); FarPatchTables::PatchArray const *parray = ptables->GetPatchArray(*it);
if (parray) { if (parray) {
int width = meshes[i]->GetTotalFVarWidth() * 4; // for each quad int nv = _isLoop ? 3 : 4;
int width = meshes[i]->GetTotalFVarWidth() * nv; // for each quads or tris
FarPatchTables::FVarDataTable::const_iterator begin = FarPatchTables::FVarDataTable::const_iterator begin =
ptables->_fvarTable.begin() + parray->GetPatchIndex() * width; ptables->_fvarTable.begin() + parray->GetPatchIndex() * width;
FarPatchTables::FVarDataTable::const_iterator end = FarPatchTables::FVarDataTable::const_iterator end =