mirror of
https://github.com/PixarAnimationStudios/OpenSubdiv
synced 2025-01-10 00:30:07 +00:00
89c4ce78b7
- assigned appropriate patch count and base offsets to varying arrays - assigned appropriate patch count and base offsets to face-varying arrays - fixed append to face-varying PatchParam buffer for each array
165 lines
6.7 KiB
C++
165 lines
6.7 KiB
C++
//
|
|
// Copyright 2015 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.
|
|
//
|
|
|
|
#include "../osd/cpuPatchTable.h"
|
|
#include "../far/patchDescriptor.h"
|
|
|
|
#include <iostream>
|
|
|
|
namespace OpenSubdiv {
|
|
namespace OPENSUBDIV_VERSION {
|
|
|
|
namespace Osd {
|
|
|
|
CpuPatchTable::CpuPatchTable(const Far::PatchTable *farPatchTable) {
|
|
int nPatchArrays = farPatchTable->GetNumPatchArrays();
|
|
|
|
// count
|
|
int numPatches = 0;
|
|
int numIndices = 0;
|
|
for (int j = 0; j < nPatchArrays; ++j) {
|
|
int nPatch = farPatchTable->GetNumPatches(j);
|
|
int nCV = farPatchTable->GetPatchArrayDescriptor(j).GetNumControlVertices();
|
|
numPatches += nPatch;
|
|
numIndices += nPatch * nCV;
|
|
}
|
|
_patchArrays.reserve(nPatchArrays);
|
|
_indexBuffer.reserve(numIndices);
|
|
|
|
_varyingPatchArrays.reserve(nPatchArrays);
|
|
_varyingIndexBuffer.reserve(
|
|
numPatches*farPatchTable->GetVaryingPatchDescriptor().GetNumControlVertices());
|
|
|
|
_fvarPatchArrays.resize(farPatchTable->GetNumFVarChannels());
|
|
_fvarIndexBuffers.resize(farPatchTable->GetNumFVarChannels());
|
|
_fvarParamBuffers.resize(farPatchTable->GetNumFVarChannels());
|
|
for (int fvc=0; fvc<farPatchTable->GetNumFVarChannels(); ++fvc) {
|
|
_fvarPatchArrays[fvc].reserve(nPatchArrays);
|
|
_fvarIndexBuffers[fvc].reserve(
|
|
numPatches * farPatchTable->GetFVarValueStride(fvc));
|
|
_fvarParamBuffers[fvc].reserve(numPatches);
|
|
}
|
|
_patchParamBuffer.reserve(numPatches);
|
|
|
|
// for each patchArray
|
|
for (int j = 0; j < nPatchArrays; ++j) {
|
|
int numPatchesThisArray = farPatchTable->GetNumPatches(j);
|
|
|
|
// create vertex array and append indices to buffer:
|
|
PatchArray patchArray(
|
|
farPatchTable->GetPatchArrayDescriptor(j),
|
|
numPatchesThisArray,
|
|
(int)_indexBuffer.size(), (int)_patchParamBuffer.size());
|
|
_patchArrays.push_back(patchArray);
|
|
|
|
Far::ConstIndexArray indices = farPatchTable->GetPatchArrayVertices(j);
|
|
_indexBuffer.insert(_indexBuffer.end(), indices.begin(), indices.end());
|
|
|
|
// create varying array and append indices to buffer:
|
|
PatchArray varyingPatchArray(
|
|
farPatchTable->GetVaryingPatchDescriptor(),
|
|
numPatchesThisArray,
|
|
(int)_varyingIndexBuffer.size(), (int)_patchParamBuffer.size());
|
|
_varyingPatchArrays.push_back(varyingPatchArray);
|
|
|
|
Far::ConstIndexArray
|
|
varyingIndices = farPatchTable->GetPatchArrayVaryingVertices(j);
|
|
_varyingIndexBuffer.insert(_varyingIndexBuffer.end(),
|
|
varyingIndices.begin(), varyingIndices.end());
|
|
|
|
// create face-varying arrays for each channel:
|
|
for (int fvc=0; fvc<farPatchTable->GetNumFVarChannels(); ++fvc) {
|
|
// create face-varying array and append indices to buffer:
|
|
PatchArray fvarPatchArray(
|
|
farPatchTable->GetFVarPatchDescriptorRegular(fvc),
|
|
farPatchTable->GetFVarPatchDescriptorIrregular(fvc),
|
|
numPatchesThisArray,
|
|
(int)_fvarIndexBuffers[fvc].size(), (int)_fvarParamBuffers[fvc].size());
|
|
_fvarPatchArrays[fvc].push_back(fvarPatchArray);
|
|
|
|
Far::ConstIndexArray
|
|
fvarIndices = farPatchTable->GetPatchArrayFVarValues(j, fvc);
|
|
_fvarIndexBuffers[fvc].insert(_fvarIndexBuffers[fvc].end(),
|
|
fvarIndices.begin(), fvarIndices.end());
|
|
|
|
// append face-varying patch params (converting Far PatchParams to Osd)
|
|
Far::ConstPatchParamArray
|
|
fvarParam = farPatchTable->GetPatchArrayFVarPatchParams(j, fvc);
|
|
|
|
for (int k = 0; k < numPatchesThisArray; ++k) {
|
|
PatchParam param;
|
|
//param.patchParam = patchParamTable[patchIndex];
|
|
param.field0 = fvarParam[k].field0;
|
|
param.field1 = fvarParam[k].field1;
|
|
param.sharpness = 0.0f;
|
|
_fvarParamBuffers[fvc].push_back(param);
|
|
}
|
|
}
|
|
|
|
// patchParams bundling
|
|
// XXX: this process won't be needed if Far::PatchParam includes
|
|
// sharpness.
|
|
#if 0
|
|
// XXX: we need sharpness interface for patcharray or put sharpness
|
|
// into patchParam.
|
|
Far::ConstPatchParamArray patchParams =
|
|
farPatchTable->GetPatchParams(j);
|
|
for (int k = 0; k < patchParams.size(); ++k) {
|
|
float sharpness = 0.0;
|
|
_patchParamBuffer.push_back(patchParams[k].field0);
|
|
_patchParamBuffer.push_back(patchParams[k].field1);
|
|
_patchParamBuffer.push_back(*((unsigned int *)&sharpness));
|
|
}
|
|
#else
|
|
// XXX: workaround. GetPatchParamTable() will be deprecated though.
|
|
Far::PatchParamTable const & patchParamTable =
|
|
farPatchTable->GetPatchParamTable();
|
|
std::vector<Far::Index> const &sharpnessIndexTable =
|
|
farPatchTable->GetSharpnessIndexTable();
|
|
int numPatchesJ = farPatchTable->GetNumPatches(j);
|
|
for (int k = 0; k < numPatchesJ; ++k) {
|
|
float sharpness = 0.0;
|
|
int patchIndex = (int)_patchParamBuffer.size();
|
|
if (patchIndex < (int)sharpnessIndexTable.size()) {
|
|
int sharpnessIndex = sharpnessIndexTable[patchIndex];
|
|
if (sharpnessIndex >= 0)
|
|
sharpness = farPatchTable->GetSharpnessValues()[sharpnessIndex];
|
|
}
|
|
PatchParam param;
|
|
//param.patchParam = patchParamTable[patchIndex];
|
|
param.field0 = patchParamTable[patchIndex].field0;
|
|
param.field1 = patchParamTable[patchIndex].field1;
|
|
param.sharpness = sharpness;
|
|
_patchParamBuffer.push_back(param);
|
|
}
|
|
#endif
|
|
}
|
|
}
|
|
|
|
} // end namespace Osd
|
|
|
|
} // end namespace OPENSUBDIV_VERSION
|
|
} // end namespace OpenSubdiv
|
|
|