2012-08-10 22:14:02 +00:00
|
|
|
//
|
2013-09-26 19:04:57 +00:00
|
|
|
// Copyright 2013 Pixar
|
2012-08-10 22:14:02 +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-10 22:14:02 +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-10 22:14:02 +00:00
|
|
|
//
|
2013-09-26 19:04:57 +00:00
|
|
|
// You may obtain a copy of the Apache License at
|
2013-07-18 21:19:50 +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.
|
2012-08-10 22:14:02 +00:00
|
|
|
//
|
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
#include "../osd/drawContext.h"
|
2012-08-10 22:14:02 +00:00
|
|
|
|
|
|
|
namespace OpenSubdiv {
|
|
|
|
namespace OPENSUBDIV_VERSION {
|
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
OsdDrawContext::~OsdDrawContext() {}
|
2012-08-10 22:14:02 +00:00
|
|
|
|
2013-05-09 17:53:58 +00:00
|
|
|
void
|
2013-05-10 02:16:51 +00:00
|
|
|
OsdDrawContext::ConvertPatchArrays(FarPatchTables::PatchArrayVector const &farPatchArrays,
|
|
|
|
OsdDrawContext::PatchArrayVector &osdPatchArrays,
|
|
|
|
int maxValence, int numElements)
|
|
|
|
{
|
2013-05-09 17:53:58 +00:00
|
|
|
// create patch arrays for drawing (while duplicating subpatches for transition patch arrays)
|
|
|
|
static int subPatchCounts[] = { 1, 3, 4, 4, 4, 2 }; // number of subpatches for patterns
|
|
|
|
|
|
|
|
int numTotalPatchArrays = 0;
|
2013-05-10 02:16:51 +00:00
|
|
|
for (int i = 0; i < (int)farPatchArrays.size(); ++i) {
|
|
|
|
FarPatchTables::TransitionPattern pattern = farPatchArrays[i].GetDescriptor().GetPattern();
|
2013-05-09 17:53:58 +00:00
|
|
|
numTotalPatchArrays += subPatchCounts[(int)pattern];
|
|
|
|
}
|
|
|
|
|
|
|
|
// allocate drawing patch arrays
|
2013-05-10 02:16:51 +00:00
|
|
|
osdPatchArrays.clear();
|
|
|
|
osdPatchArrays.reserve(numTotalPatchArrays);
|
|
|
|
|
|
|
|
for (int i = 0; i < (int)farPatchArrays.size(); ++i) {
|
|
|
|
FarPatchTables::TransitionPattern pattern = farPatchArrays[i].GetDescriptor().GetPattern();
|
2013-05-09 17:53:58 +00:00
|
|
|
int numSubPatches = subPatchCounts[(int)pattern];
|
|
|
|
|
2013-05-10 02:16:51 +00:00
|
|
|
FarPatchTables::PatchArray const &parray = farPatchArrays[i];
|
2013-05-09 17:53:58 +00:00
|
|
|
FarPatchTables::Descriptor srcDesc = parray.GetDescriptor();
|
|
|
|
|
|
|
|
for (int j = 0; j < numSubPatches; ++j) {
|
2013-05-09 20:14:02 +00:00
|
|
|
PatchDescriptor desc(srcDesc, maxValence, j, numElements);
|
|
|
|
|
2013-05-10 02:16:51 +00:00
|
|
|
osdPatchArrays.push_back(PatchArray(desc, parray.GetArrayRange()));
|
2013-05-09 17:53:58 +00:00
|
|
|
}
|
|
|
|
}
|
2013-05-17 02:53:49 +00:00
|
|
|
/*
|
|
|
|
#if defined(GL_ES_VERSION_2_0)
|
|
|
|
// XXX: farmesh should have FarDensePatchTable for dense mesh indices.
|
|
|
|
// instead of GetFaceVertices().
|
2014-03-19 18:44:51 +00:00
|
|
|
const FarSubdivisionTables *tables = farMesh->GetSubdivisionTables();
|
2013-05-17 02:53:49 +00:00
|
|
|
int level = tables->GetMaxLevel();
|
|
|
|
const std::vector<int> &indices = farMesh->GetFaceVertices(level-1);
|
|
|
|
|
|
|
|
int numIndices = (int)indices.size();
|
|
|
|
|
|
|
|
// Allocate and fill index buffer.
|
|
|
|
glGenBuffers(1, &patchIndexBuffer);
|
|
|
|
glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, patchIndexBuffer);
|
|
|
|
glBufferData(GL_ELEMENT_ARRAY_BUFFER,
|
|
|
|
numIndices * sizeof(unsigned int), &(indices[0]), GL_STATIC_DRAW);
|
|
|
|
|
|
|
|
|
|
|
|
// OpenGLES 2 supports only triangle topologies for filled
|
|
|
|
// primitives i.e. not QUADS or PATCHES or LINES_ADJACENCY
|
|
|
|
// For the convenience of clients build build a triangles
|
|
|
|
// index buffer by splitting quads.
|
|
|
|
int numQuads = indices.size() / 4;
|
|
|
|
int numTrisIndices = numQuads * 6;
|
|
|
|
|
|
|
|
std::vector<short> trisIndices;
|
|
|
|
trisIndices.reserve(numTrisIndices);
|
|
|
|
for (int i=0; i<numQuads; ++i) {
|
|
|
|
const int * quad = &indices[i*4];
|
|
|
|
trisIndices.push_back(short(quad[0]));
|
|
|
|
trisIndices.push_back(short(quad[1]));
|
|
|
|
trisIndices.push_back(short(quad[2]));
|
|
|
|
|
|
|
|
trisIndices.push_back(short(quad[2]));
|
|
|
|
trisIndices.push_back(short(quad[3]));
|
|
|
|
trisIndices.push_back(short(quad[0]));
|
|
|
|
}
|
|
|
|
|
|
|
|
// Allocate and fill triangles index buffer.
|
|
|
|
glGenBuffers(1, &patchTrianglesIndexBuffer);
|
|
|
|
glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, patchTrianglesIndexBuffer);
|
|
|
|
glBufferData(GL_ELEMENT_ARRAY_BUFFER,
|
|
|
|
numTrisIndices * sizeof(short), &(trisIndices[0]), GL_STATIC_DRAW);
|
|
|
|
#endif
|
|
|
|
*/
|
|
|
|
|
2013-05-09 17:53:58 +00:00
|
|
|
}
|
|
|
|
|
2012-08-10 22:14:02 +00:00
|
|
|
} // end namespace OPENSUBDIV_VERSION
|
|
|
|
} // end namespace OpenSubdiv
|
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
|