2015-04-23 23:58:45 +00:00
|
|
|
//
|
|
|
|
// 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.
|
|
|
|
//
|
|
|
|
|
2015-05-19 18:22:37 +00:00
|
|
|
#ifndef OPENSUBDIV3_FAR_END_CAP_BSPLINE_BASIS_PATCH_FACTORY_H
|
|
|
|
#define OPENSUBDIV3_FAR_END_CAP_BSPLINE_BASIS_PATCH_FACTORY_H
|
2015-04-23 23:58:45 +00:00
|
|
|
|
2015-05-22 18:50:01 +00:00
|
|
|
#include "../far/patchTableFactory.h"
|
2015-04-23 23:58:45 +00:00
|
|
|
#include "../far/gregoryBasis.h"
|
|
|
|
#include "../vtr/level.h"
|
|
|
|
|
|
|
|
namespace OpenSubdiv {
|
|
|
|
namespace OPENSUBDIV_VERSION {
|
|
|
|
|
|
|
|
namespace Far {
|
|
|
|
|
|
|
|
class TopologyRefiner;
|
|
|
|
|
|
|
|
/// \brief A BSpline endcap factory
|
|
|
|
///
|
2015-05-22 18:50:01 +00:00
|
|
|
/// note: This is an internal use class in PatchTableFactory, and
|
2015-04-23 23:58:45 +00:00
|
|
|
/// will be replaced with SdcSchemeWorker for mask coefficients
|
|
|
|
/// and Vtr::Level for topology traversal.
|
|
|
|
///
|
|
|
|
class EndCapBSplineBasisPatchFactory {
|
|
|
|
|
|
|
|
public:
|
|
|
|
// XXXX need to add support for face-varying channel stencils
|
|
|
|
|
|
|
|
/// \brief This factory accumulates vertex for bspline basis end cap
|
|
|
|
///
|
|
|
|
/// @param refiner TopologyRefiner from which to generate patches
|
|
|
|
///
|
|
|
|
/// @param shareBoundaryVertices Use same boundary vertices for neighboring
|
|
|
|
/// patches. It reduces the number of stencils
|
|
|
|
/// to be used.
|
|
|
|
///
|
|
|
|
EndCapBSplineBasisPatchFactory(TopologyRefiner const & refiner);
|
|
|
|
|
|
|
|
/// \brief Returns end patch point indices for \a faceIndex of \a level.
|
|
|
|
/// Note that end patch points are not included in the vertices in
|
|
|
|
/// the topologyRefiner, they're expected to come after the end.
|
|
|
|
/// The returning indices are offsetted by refiner->GetNumVerticesTotal.
|
|
|
|
///
|
|
|
|
/// @param level vtr refinement level
|
|
|
|
///
|
|
|
|
/// @param faceIndex vtr faceIndex at the level
|
|
|
|
///
|
2015-05-29 19:41:11 +00:00
|
|
|
/// @param levelPatchTags Array of patchTags for all faces in the level
|
|
|
|
///
|
|
|
|
/// @param levelVertOffset relative offset of patch vertex indices
|
|
|
|
///
|
2015-04-23 23:58:45 +00:00
|
|
|
ConstIndexArray GetPatchPoints(
|
2015-05-29 19:41:11 +00:00
|
|
|
Vtr::internal::Level const * level, Index faceIndex,
|
|
|
|
PatchTableFactory::PatchFaceTag const * levelPatchTags,
|
|
|
|
int levelVertOffset);
|
2015-04-23 23:58:45 +00:00
|
|
|
|
2015-05-22 18:50:01 +00:00
|
|
|
/// \brief Create a StencilTable for end patch points, relative to the max
|
2015-04-23 23:58:45 +00:00
|
|
|
/// subdivision level.
|
|
|
|
///
|
2015-05-22 18:50:01 +00:00
|
|
|
StencilTable* CreateVertexStencilTable() const {
|
|
|
|
return GregoryBasis::CreateStencilTable(_vertexStencils);
|
2015-04-23 23:58:45 +00:00
|
|
|
}
|
|
|
|
|
2015-05-22 18:50:01 +00:00
|
|
|
/// \brief Create a StencilTable for end patch varying primvar.
|
2015-04-23 23:58:45 +00:00
|
|
|
/// This table is used as a convenient way to get varying primvars
|
|
|
|
/// populated on end patch points along with positions.
|
|
|
|
///
|
2015-05-22 18:50:01 +00:00
|
|
|
StencilTable* CreateVaryingStencilTable() const {
|
|
|
|
return GregoryBasis::CreateStencilTable(_varyingStencils);
|
2015-04-23 23:58:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2015-09-16 03:14:04 +00:00
|
|
|
ConstIndexArray getPatchPointsFromGregoryBasis(
|
|
|
|
Vtr::internal::Level const * level, Index thisFace,
|
|
|
|
ConstIndexArray facePoints,
|
|
|
|
int levelVertOffset);
|
|
|
|
|
|
|
|
ConstIndexArray getPatchPoints(
|
|
|
|
Vtr::internal::Level const *level, Index thisFace,
|
|
|
|
Index extraOrdinaryIndex, ConstIndexArray facePoints,
|
|
|
|
int levelVertOffset);
|
|
|
|
|
|
|
|
void computeLimitStencils(
|
|
|
|
Vtr::internal::Level const *level,
|
|
|
|
ConstIndexArray facePoints, int vid,
|
|
|
|
GregoryBasis::Point *P, GregoryBasis::Point *Ep, GregoryBasis::Point *Em);
|
|
|
|
|
|
|
|
|
2015-04-23 23:58:45 +00:00
|
|
|
TopologyRefiner const *_refiner;
|
|
|
|
GregoryBasis::PointsVector _vertexStencils;
|
|
|
|
GregoryBasis::PointsVector _varyingStencils;
|
|
|
|
int _numVertices;
|
|
|
|
int _numPatches;
|
|
|
|
std::vector<Index> _patchPoints;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // end namespace Far
|
|
|
|
|
|
|
|
} // end namespace OPENSUBDIV_VERSION
|
|
|
|
} // end namespace OpenSubdiv
|
|
|
|
|
2015-05-19 18:22:37 +00:00
|
|
|
#endif // OPENSUBDIV3_FAR_END_CAP_BSPLINE_BASIS_PATCH_FACTORY_H
|