mirror of
https://github.com/PixarAnimationStudios/OpenSubdiv
synced 2025-01-10 00:30:07 +00:00
f6d45a6de0
- Some missing includes of <algorithms> in order to have stdd::min() and similar functions. - Need to cast numIndices and numNVerts to int explicitly in order to solve warning treated as an error about precision loss. - Can't do vector[0] for an empty vector, it'll generate a runtime range check error. - MSVC only works fine with make_pair(foo, bar) syntax, without explicit template substitution here. Otherwise weird 'can't cast int to int&&' errors are happening.
176 lines
5.4 KiB
C++
176 lines
5.4 KiB
C++
//
|
|
// Copyright 2013 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 "evaluator_capi.h"
|
|
|
|
#include <iostream>
|
|
|
|
#include "adaptiveEvaluator.h"
|
|
#include "topology.h"
|
|
|
|
#if !defined(WITH_ASSERT_ABORT)
|
|
# define OSD_abort()
|
|
#else
|
|
# include <stdlib.h>
|
|
# define OSD_abort() abort()
|
|
#endif
|
|
|
|
#if defined(_MSC_VER)
|
|
# define __func__ __FUNCTION__
|
|
#endif
|
|
|
|
/* Define this when you want to have additional verbosity
|
|
* about what's being passed to OpenSubdiv.
|
|
*/
|
|
#undef DEBUG_PRINT
|
|
|
|
using namespace OpenSubdiv;
|
|
|
|
/* **************** Types declaration **************** */
|
|
|
|
typedef struct OpenSubdiv_EvaluatorDescr {
|
|
OsdUtilSubdivTopology topology;
|
|
OsdUtilAdaptiveEvaluator evaluator;
|
|
// std::vector<float> coarsePositions;
|
|
} OpenSubdiv_EvaluatorDescr;
|
|
|
|
|
|
/* **************** Mesh descriptor functions **************** */
|
|
|
|
OpenSubdiv_EvaluatorDescr *openSubdiv_createEvaluatorDescr(int numVertices)
|
|
{
|
|
OpenSubdiv_EvaluatorDescr *evaluator_descr =
|
|
new OpenSubdiv_EvaluatorDescr();
|
|
|
|
evaluator_descr->topology.numVertices = numVertices;
|
|
|
|
return evaluator_descr;
|
|
}
|
|
|
|
void openSubdiv_deleteEvaluatorDescr(
|
|
OpenSubdiv_EvaluatorDescr *evaluator_descr)
|
|
{
|
|
delete(evaluator_descr);
|
|
}
|
|
|
|
void openSubdiv_createEvaluatorDescrFace(OpenSubdiv_EvaluatorDescr *evaluator_descr, int num_vertices, int *indices)
|
|
{
|
|
#ifdef DEBUG_PRINT
|
|
printf("Adding face index:%d vertices:", (int)evaluator_descr->topology.nverts.size());
|
|
for (int i = 0; i < num_vertices; i++) {
|
|
printf("%d ", indices[i]);
|
|
}
|
|
printf("\n");
|
|
#endif
|
|
|
|
evaluator_descr->topology.nverts.push_back(num_vertices);
|
|
for (int i = 0; i < num_vertices; i++) {
|
|
evaluator_descr->topology.indices.push_back(indices[i]);
|
|
}
|
|
}
|
|
|
|
int openSubdiv_finishEvaluatorDescr(OpenSubdiv_EvaluatorDescr *evaluator_descr,
|
|
int refinementLevel)
|
|
{
|
|
std::string errorMessage;
|
|
evaluator_descr->topology.refinementLevel = refinementLevel;
|
|
// TODO: Pass the error message to the callee function so it know what's going on.
|
|
if (not evaluator_descr->topology.IsValid(&errorMessage)) {
|
|
std::cout <<"OpenSubdiv topology is not valid due to " << errorMessage << std::endl;
|
|
return 0;
|
|
} else {
|
|
if (not evaluator_descr->evaluator.Initialize(
|
|
evaluator_descr->topology, &errorMessage)) {
|
|
std::cout <<"OpenSubdiv uniform evaluator initialization failed due to " << errorMessage << std::endl;
|
|
return 0;
|
|
}
|
|
}
|
|
return 1;
|
|
}
|
|
|
|
|
|
int openSubdiv_setEvaluatorCoarsePositions(
|
|
OpenSubdiv_EvaluatorDescr *evaluator_descr,
|
|
const float *positions, int numVertices)
|
|
{
|
|
std::string errorMessage;
|
|
|
|
// TODO: returns void, need error check on length of positions?
|
|
evaluator_descr->evaluator.SetCoarsePositions(
|
|
positions, 3 * numVertices, &errorMessage);
|
|
|
|
if (not errorMessage.empty()) {
|
|
std::cout << "OpenSubdiv set coarse positions failed due to " << errorMessage << std::endl;
|
|
}
|
|
|
|
// Refine with 1 thread for now
|
|
if (not evaluator_descr->evaluator.Refine(1, &errorMessage)) {
|
|
std::cout << "OpenSubdiv refinement failed due to " << errorMessage << std::endl;
|
|
return 0;
|
|
}
|
|
|
|
return 1;
|
|
}
|
|
|
|
|
|
void openSubdiv_evaluateLimit(
|
|
OpenSubdiv_EvaluatorDescr *evaluation_descr,
|
|
int face_id, float u, float v,
|
|
float P[3], float dPdu[3], float dPdv[3])
|
|
{
|
|
OsdEvalCoords coords;
|
|
coords.u = u;
|
|
coords.v = v;
|
|
coords.face = face_id;
|
|
|
|
evaluation_descr->evaluator.EvaluateLimit(coords, P, dPdu, dPdv);
|
|
}
|
|
|
|
void openSubdiv_getEvaluatorTopology(
|
|
OpenSubdiv_EvaluatorDescr *evaluation_descr,
|
|
int *numVertices,
|
|
int *refinementLevel,
|
|
int *numIndices,
|
|
int **indices,
|
|
int *numNVerts,
|
|
int **nverts)
|
|
{
|
|
// TODO(sergey): Tag data is also need to do the full comparison,
|
|
// but it's not that clear how to pass it via C-API and no real
|
|
// application to test this yet.
|
|
*numVertices = evaluation_descr->topology.numVertices;
|
|
*refinementLevel = evaluation_descr->topology.refinementLevel;
|
|
*numIndices = (int)evaluation_descr->topology.indices.size();
|
|
*indices = &evaluation_descr->topology.indices[0];
|
|
*numNVerts = (int)evaluation_descr->topology.nverts.size();
|
|
*nverts = &evaluation_descr->topology.nverts[0];
|
|
}
|
|
|
|
OpenSubdiv_EvaluatorDescr *openSubdiv_getEvaluatorTopologyDescr(
|
|
OpenSubdiv_EvaluatorDescr *evaluator_descr)
|
|
{
|
|
return (OpenSubdiv_EvaluatorDescr *) &evaluator_descr->topology;
|
|
}
|
|
|