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
|
|
|
|
2014-09-05 22:07:46 +00:00
|
|
|
#include <cstring>
|
|
|
|
|
2012-08-10 22:14:02 +00:00
|
|
|
namespace OpenSubdiv {
|
|
|
|
namespace OPENSUBDIV_VERSION {
|
|
|
|
|
2014-09-05 22:07:46 +00:00
|
|
|
namespace Osd {
|
|
|
|
|
|
|
|
DrawContext::~DrawContext() {}
|
2012-08-10 22:14:02 +00:00
|
|
|
|
2013-05-09 17:53:58 +00:00
|
|
|
void
|
2014-09-05 22:07:46 +00:00
|
|
|
DrawContext::ConvertPatchArrays(Far::PatchTables::PatchArrayVector const &farPatchArrays,
|
|
|
|
DrawContext::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) {
|
2014-09-05 22:07:46 +00:00
|
|
|
Far::PatchTables::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) {
|
2014-09-05 22:07:46 +00:00
|
|
|
Far::PatchTables::TransitionPattern pattern = farPatchArrays[i].GetDescriptor().GetPattern();
|
2013-05-09 17:53:58 +00:00
|
|
|
int numSubPatches = subPatchCounts[(int)pattern];
|
|
|
|
|
2014-09-05 22:07:46 +00:00
|
|
|
Far::PatchTables::PatchArray const &parray = farPatchArrays[i];
|
|
|
|
Far::PatchTables::Descriptor srcDesc = parray.GetDescriptor();
|
2013-05-09 17:53:58 +00:00
|
|
|
|
|
|
|
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
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-09-05 22:07:46 +00:00
|
|
|
void
|
|
|
|
DrawContext::packFVarData(Far::PatchTables const & patchTables,
|
|
|
|
int fvarWidth, FVarData const & src, FVarData & dst) {
|
|
|
|
|
|
|
|
assert(fvarWidth and (not src.empty()));
|
|
|
|
|
|
|
|
Far::PatchTables::FVarPatchTables const * fvarPatchTables =
|
|
|
|
patchTables.GetFVarPatchTables();
|
|
|
|
assert(fvarPatchTables);
|
|
|
|
|
|
|
|
// OsdMesh only accesses channel 0
|
|
|
|
std::vector<unsigned int> const & indices = fvarPatchTables->GetPatchVertices(0);
|
2012-08-10 22:14:02 +00:00
|
|
|
|
2014-09-05 22:07:46 +00:00
|
|
|
dst.resize(indices.size() * fvarWidth);
|
|
|
|
float * ptr = &dst[0];
|
2012-12-11 01:15:13 +00:00
|
|
|
|
2014-09-05 22:07:46 +00:00
|
|
|
for (int fvert=0; fvert<(int)indices.size(); ++fvert, ptr+=fvarWidth) {
|
|
|
|
|
|
|
|
int index = indices[fvert] * fvarWidth;
|
|
|
|
assert(index<(int)dst.size());
|
|
|
|
|
|
|
|
memcpy(ptr, &src[index], fvarWidth*sizeof(float));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
} // end namespace Osd
|
|
|
|
|
|
|
|
} // end namespace OPENSUBDIV_VERSION
|
|
|
|
} // end namespace OpenSubdiv
|