mirror of
https://github.com/PixarAnimationStudios/OpenSubdiv
synced 2025-01-18 12:10:06 +00:00
spelling phase 4 -- examples, tutorials, regression tests
Read all comments and made corrections to files that aren't part of OpenSubdiv itself but are packaged with it. Commandline output of glPtexViewer is affected. Otherwise no functional changes.
This commit is contained in:
parent
408f9902f0
commit
a42dab2b64
@ -123,8 +123,8 @@ findExtensionSupportedDevice(cl_device_id *clDevices,
|
||||
std::string extString(extensions);
|
||||
delete[] extensions;
|
||||
|
||||
// parse string. This is bit deficient since the extentions
|
||||
// is space separated.
|
||||
// parse string. This is a bit deficient since the extensions
|
||||
// string is space separated.
|
||||
//
|
||||
// The actual string would be "cl_khr_d3d11_sharing"
|
||||
// or "cl_nv_d3d11_sharing"
|
||||
|
@ -32,10 +32,10 @@ public:
|
||||
CudaDeviceContext();
|
||||
~CudaDeviceContext();
|
||||
|
||||
/// Initialze cuda device from the current GL context
|
||||
/// Initialize cuda device from the current GL context
|
||||
bool Initialize();
|
||||
|
||||
/// Initialze cuda device from the ID3D11Device
|
||||
/// Initialize cuda device from the ID3D11Device
|
||||
bool Initialize(ID3D11Device *device);
|
||||
|
||||
/// Returns true if the cuda device has already been initialized
|
||||
|
@ -58,7 +58,7 @@ public:
|
||||
private:
|
||||
D3D11PtexMipmapTexture();
|
||||
|
||||
int _width, // widht / height / depth of the 3D texel buffer
|
||||
int _width, // width / height / depth of the 3D texel buffer
|
||||
_height,
|
||||
_depth;
|
||||
|
||||
|
@ -48,7 +48,7 @@ public:
|
||||
/// Returns the texels texture array.
|
||||
GLuint GetTexelsTexture() const { return _texels; }
|
||||
|
||||
/// Returns the amount of allocated memory (in byte)
|
||||
/// Returns the amount of allocated memory (in bytes)
|
||||
size_t GetMemoryUsage() const { return _memoryUsage; }
|
||||
|
||||
~GLPtexMipmapTexture();
|
||||
@ -56,7 +56,7 @@ public:
|
||||
private:
|
||||
GLPtexMipmapTexture();
|
||||
|
||||
GLsizei _width, // widht / height / depth of the 3D texel buffer
|
||||
GLsizei _width, // width / height / depth of the 3D texel buffer
|
||||
_height,
|
||||
_depth;
|
||||
|
||||
|
@ -260,9 +260,8 @@ GetShaderVersion(){
|
||||
return shader_version;
|
||||
}
|
||||
|
||||
/* Generates the version defintion needed by the glsl shaders based on the
|
||||
* opengl string
|
||||
*/
|
||||
// Generates the version definition needed by the glsl shaders based on the
|
||||
// opengl string
|
||||
std::string GetShaderVersionInclude(){
|
||||
return "#version " + GetShaderVersion() + "\n";
|
||||
}
|
||||
@ -295,4 +294,4 @@ bool GL_ARBComputeShaderOrGL_VERSION_4_3() {
|
||||
|
||||
#undef IS_SUPPORTED
|
||||
|
||||
} // namesapce GLUtils
|
||||
} // namespace GLUtils
|
||||
|
@ -65,10 +65,10 @@
|
||||
|
||||
|
||||
//
|
||||
// Templated funtions able to retrieve any attribute that
|
||||
// Templated functions able to retrieve any attribute that
|
||||
// can be retrieved via the overloaded MPlug::getValue()
|
||||
// methods. Any attributes that need MPlug::getData()
|
||||
// Need to use non-templated functions below
|
||||
// need to use non-templated functions below
|
||||
//
|
||||
template<class T> static int
|
||||
findAttribute( MFnDependencyNode &depFn, const char *attr, T *val )
|
||||
|
@ -111,7 +111,7 @@ PtexMipmapTextureLoader::Block::guttering(PtexMipmapTextureLoader *loader,
|
||||
(everything else, including boundary)
|
||||
Since guttering pixels are placed on the border of each
|
||||
ptex faces, it's not possible to store more than 4 pixels
|
||||
at a coner for a reasonable interpolation.
|
||||
at a corner for a reasonable interpolation.
|
||||
In this case, we need to average all corner pixels and
|
||||
overwrite with an averaged value, so that every face
|
||||
vertex picks the same value.
|
||||
@ -452,7 +452,7 @@ PtexMipmapTextureLoader::PtexMipmapTextureLoader(PtexTexture *ptex,
|
||||
_pageWidth(0), _pageHeight(0), _texelBuffer(NULL), _layoutBuffer(NULL),
|
||||
_memoryUsage(0)
|
||||
{
|
||||
// byte per pixel
|
||||
// bytes per pixel
|
||||
_bpp = ptex->numChannels() * Ptex::DataSize(ptex->dataType());
|
||||
|
||||
int numFaces = ptex->numFaces();
|
||||
|
@ -19,7 +19,7 @@ ABOUT:
|
||||
|
||||
The PNG output is not optimal; it is 20-50% larger than the file
|
||||
written by a decent optimizing implementation. This library is designed
|
||||
for source code compactness and simplicitly, not optimal image file size
|
||||
for source code compactness and simplicity, not optimal image file size
|
||||
or run-time performance.
|
||||
|
||||
USAGE:
|
||||
|
@ -1712,7 +1712,7 @@ WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPTSTR lpCmdLine, int nCmd
|
||||
wcex.lpszClassName = szWindowClass;
|
||||
RegisterClass(&wcex);
|
||||
|
||||
// crete window
|
||||
// create window
|
||||
RECT rect = { 0, 0, g_width, g_height };
|
||||
AdjustWindowRect(&rect, WS_OVERLAPPEDWINDOW, FALSE);
|
||||
|
||||
|
@ -1532,7 +1532,7 @@ WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPTSTR lpCmdLine, int nCmd
|
||||
wcex.lpszClassName = szWindowClass;
|
||||
RegisterClass(&wcex);
|
||||
|
||||
// crete window
|
||||
// create window
|
||||
RECT rect = { 0, 0, g_width, g_height };
|
||||
AdjustWindowRect(&rect, WS_OVERLAPPEDWINDOW, FALSE);
|
||||
|
||||
|
@ -1385,7 +1385,7 @@ int main(int argc, char ** argv)
|
||||
}
|
||||
glfwMakeContextCurrent(g_window);
|
||||
|
||||
// accommocate high DPI displays (e.g. mac retina displays)
|
||||
// accommodate high DPI displays (e.g. mac retina displays)
|
||||
glfwGetFramebufferSize(g_window, &g_width, &g_height);
|
||||
glfwSetFramebufferSizeCallback(g_window, reshape);
|
||||
|
||||
@ -1406,7 +1406,7 @@ int main(int argc, char ** argv)
|
||||
exit(1);
|
||||
}
|
||||
#ifdef CORE_PROFILE
|
||||
// clear GL errors which was generated during glewInit()
|
||||
// clear GL errors which were generated during glewInit()
|
||||
glGetError();
|
||||
#endif
|
||||
#endif
|
||||
|
@ -247,10 +247,10 @@ public:
|
||||
DEVICE_CONTEXT *deviceContext = NULL)
|
||||
: _srcDesc( /*offset*/ 0, /*length*/ 3, /*stride*/ 3),
|
||||
_srcVaryingDesc(/*offset*/ 0, /*length*/ 3, /*stride*/ 3),
|
||||
_vertexDesc( /*offset*/ 0, /*legnth*/ 3, /*stride*/ 6),
|
||||
_varyingDesc( /*offset*/ 3, /*legnth*/ 3, /*stride*/ 6),
|
||||
_duDesc( /*offset*/ 0, /*legnth*/ 3, /*stride*/ 6),
|
||||
_dvDesc( /*offset*/ 3, /*legnth*/ 3, /*stride*/ 6),
|
||||
_vertexDesc( /*offset*/ 0, /*length*/ 3, /*stride*/ 6),
|
||||
_varyingDesc( /*offset*/ 3, /*length*/ 3, /*stride*/ 6),
|
||||
_duDesc( /*offset*/ 0, /*length*/ 3, /*stride*/ 6),
|
||||
_dvDesc( /*offset*/ 3, /*length*/ 3, /*stride*/ 6),
|
||||
_deviceContext(deviceContext) {
|
||||
_srcData = SRC_VERTEX_BUFFER::Create(3, numTotalVerts, _deviceContext);
|
||||
_srcVaryingData = SRC_VERTEX_BUFFER::Create(3, numTotalVerts, _deviceContext);
|
||||
@ -346,7 +346,7 @@ public:
|
||||
|
||||
EVALUATOR::EvalPatches(
|
||||
_srcVaryingData, _srcVaryingDesc,
|
||||
// varyingdata is interleved in vertexData.
|
||||
// varying data is interleaved in vertexData.
|
||||
_vertexData, _varyingDesc,
|
||||
_patchCoords->GetNumVertices(),
|
||||
_patchCoords,
|
||||
|
@ -39,7 +39,7 @@
|
||||
// particle is assigned a location on the subdivision surface limit that is
|
||||
// composed of a unique ptex face index, with a local (s,t) parametric pair.
|
||||
//
|
||||
// The system also generates an array of parametric velocties (ds, dt) for each
|
||||
// The system also generates an array of parametric velocities (ds, dt) for each
|
||||
// particle. An Update() function then applies the velocities to the locations and
|
||||
// moves the points along the parametric space.
|
||||
//
|
||||
@ -49,7 +49,7 @@
|
||||
// bounces it, if the edge happens to be a boundary.
|
||||
//
|
||||
// Note: currently the adjacency code does not handle 'diagonal' crossings, nor
|
||||
// crossings between quand and non-quad faces.
|
||||
// crossings between quad and non-quad faces.
|
||||
//
|
||||
class STParticles {
|
||||
|
||||
|
@ -737,7 +737,7 @@ display() {
|
||||
|
||||
glEnable(GL_DEPTH_TEST);
|
||||
|
||||
// make sure that the vertex buffer is interoped back as a GL resources.
|
||||
// make sure that the vertex buffer is interoped back as a GL resource.
|
||||
GLuint vbo = g_mesh->BindVertexBuffer();
|
||||
|
||||
glBindVertexArray(g_vao);
|
||||
@ -1153,7 +1153,7 @@ int main(int argc, char ** argv) {
|
||||
exit(1);
|
||||
}
|
||||
#ifdef CORE_PROFILE
|
||||
// clear GL errors which was generated during glewInit()
|
||||
// clear GL errors which were generated during glewInit()
|
||||
glGetError();
|
||||
#endif
|
||||
#endif
|
||||
|
@ -648,7 +648,7 @@ display() {
|
||||
|
||||
bindTextures(effect);
|
||||
|
||||
// make sure that the vertex buffer is interoped back as a GL resources.
|
||||
// make sure that the vertex buffer is interoped back as a GL resource.
|
||||
g_mesh->BindVertexBuffer();
|
||||
|
||||
glBindVertexArray(g_vao);
|
||||
@ -694,7 +694,7 @@ display() {
|
||||
g_fpsTimer.Stop();
|
||||
double fps = 1.0/g_fpsTimer.GetElapsed();
|
||||
g_fpsTimer.Start();
|
||||
// Avereage fps over a defined number of time samples for
|
||||
// Average fps over a defined number of time samples for
|
||||
// easier reading in the HUD
|
||||
g_fpsTimeSamples[g_currentFpsTimeSample++] = float(fps);
|
||||
if (g_currentFpsTimeSample >= NUM_FPS_TIME_SAMPLES)
|
||||
@ -776,7 +776,7 @@ drawStroke(int x, int y) {
|
||||
|
||||
glBindBufferBase(GL_UNIFORM_BUFFER, g_tessellationBinding, g_tessellationUB);
|
||||
|
||||
// make sure that the vertex buffer is interoped back as a GL resources.
|
||||
// make sure that the vertex buffer is interoped back as a GL resource.
|
||||
g_mesh->BindVertexBuffer();
|
||||
|
||||
glBindVertexArray(g_vao);
|
||||
@ -1153,7 +1153,7 @@ int main(int argc, char ** argv) {
|
||||
exit(1);
|
||||
}
|
||||
#ifdef CORE_PROFILE
|
||||
// clear GL errors which was generated during glewInit()
|
||||
// clear GL errors which were generated during glewInit()
|
||||
glGetError();
|
||||
#endif
|
||||
#endif
|
||||
|
@ -1117,7 +1117,7 @@ updateConstantUniformBlock() {
|
||||
memcpy(g_modelViewProjection, constantData.ModelViewProjectionMatrix,
|
||||
16*sizeof(float));
|
||||
|
||||
// lighs
|
||||
// lights
|
||||
Constant::Light light0 = { { 0.6f, 1.0f, 0.6f, 0.0f },
|
||||
{ 0.1f, 0.1f, 0.1f, 1.0f },
|
||||
{ 1.7f, 1.3f, 1.1f, 1.0f },
|
||||
@ -1401,7 +1401,7 @@ display() {
|
||||
if (g_hud.IsVisible()) {
|
||||
double fps = 1.0/elapsed;
|
||||
|
||||
// Avereage fps over a defined number of time samples for
|
||||
// Average fps over a defined number of time samples for
|
||||
// easier reading in the HUD
|
||||
g_fpsTimeSamples[g_currentFpsTimeSample++] = float(fps);
|
||||
if (g_currentFpsTimeSample >= NUM_FPS_TIME_SAMPLES)
|
||||
@ -1695,9 +1695,9 @@ void usage(const char *program) {
|
||||
printf(" -e <specularEnvMap.hdr> : specular environment map for IBL\n");
|
||||
printf(" -s <shaderfile.glsl> : custom shader file\n");
|
||||
printf(" -y : Y-up model\n");
|
||||
printf(" -m level : max mimmap level (default=10)\n");
|
||||
printf(" -m level : max mipmap level (default=10)\n");
|
||||
printf(" -x <ptex limit MB> : ptex target memory size\n");
|
||||
printf(" --disp <scale> : Displacment scale\n");
|
||||
printf(" --disp <scale> : Displacement scale\n");
|
||||
}
|
||||
|
||||
//------------------------------------------------------------------------------
|
||||
|
@ -635,7 +635,7 @@ display() {
|
||||
|
||||
glEnable(GL_DEPTH_TEST);
|
||||
|
||||
// make sure that the vertex buffer is interoped back as a GL resources.
|
||||
// make sure that the vertex buffer is interoped back as a GL resource.
|
||||
g_scene->BindVertexBuffer();
|
||||
|
||||
glBindVertexArray(g_vao);
|
||||
@ -1193,7 +1193,7 @@ int main(int argc, char ** argv) {
|
||||
glfwMakeContextCurrent(g_window);
|
||||
GLUtils::PrintGLVersion();
|
||||
|
||||
// accommocate high DPI displays (e.g. mac retina displays)
|
||||
// accommodate high DPI displays (e.g. mac retina displays)
|
||||
glfwGetFramebufferSize(g_window, &g_width, &g_height);
|
||||
glfwSetFramebufferSizeCallback(g_window, reshape);
|
||||
|
||||
@ -1212,7 +1212,7 @@ int main(int argc, char ** argv) {
|
||||
exit(1);
|
||||
}
|
||||
#ifdef CORE_PROFILE
|
||||
// clear GL errors which was generated during glewInit()
|
||||
// clear GL errors which were generated during glewInit()
|
||||
glGetError();
|
||||
#endif
|
||||
#endif
|
||||
|
@ -169,7 +169,7 @@ SceneBase::createStencilTable(Shape const *shape, int level, bool varying,
|
||||
|
||||
_stencilTableSize = createMeshRefiner(vertexStencils, varyingStencils,
|
||||
numControlVertices);
|
||||
// note: refiner takes ownerships of vertexStencils/ varyingStencils, patchTable
|
||||
// note: refiner takes ownership of vertexStencils, varyingStencils, patchTable
|
||||
|
||||
delete refiner;
|
||||
return numControlVertices + vertexStencils->GetNumStencils();
|
||||
|
@ -1093,7 +1093,7 @@ int main(int argc, char **argv) {
|
||||
exit(1);
|
||||
}
|
||||
#ifdef CORE_PROFILE
|
||||
// clear GL errors which was generated during glewInit()
|
||||
// clear GL errors which were generated during glewInit()
|
||||
glGetError();
|
||||
#endif
|
||||
#endif
|
||||
|
@ -85,10 +85,10 @@ OpenSubdiv::Osd::GLLegacyGregoryPatchTable *g_legacyGregoryPatchTable = NULL;
|
||||
|
||||
|
||||
/* Function to get the correct shader file based on the opengl version.
|
||||
The implementation varies depending if glew is available or not. In case
|
||||
The implementation varies depending if glew is available or not. In case it
|
||||
is available the capabilities are queried during execution and the correct
|
||||
source is returned. If glew in not available during compile time the version
|
||||
is determined*/
|
||||
source is returned. If glew is not available the version is determined at
|
||||
compile time */
|
||||
static const char *shaderSource(){
|
||||
#if not defined(OSD_USES_GLEW)
|
||||
|
||||
@ -110,7 +110,7 @@ static const char *res =
|
||||
;
|
||||
//Determine the shader file to use. Since some opengl implementations
|
||||
//define that an extension is available but not an implementation
|
||||
//for it you cannnot trust in the glew header definitions to know that is
|
||||
//for it you cannot trust in the glew header definitions to know that is
|
||||
//available, but you need to query it during runtime.
|
||||
if (GLUtils::SupportsAdaptiveTessellation())
|
||||
res = gen;
|
||||
@ -1078,7 +1078,7 @@ display() {
|
||||
inverseMatrix(g_transformData.ModelViewInverseMatrix,
|
||||
g_transformData.ModelViewMatrix);
|
||||
|
||||
// make sure that the vertex buffer is interoped back as a GL resources.
|
||||
// make sure that the vertex buffer is interoped back as a GL resource.
|
||||
GLuint vbo = g_mesh->BindVertexBuffer();
|
||||
|
||||
// vertex texture update for legacy gregory drawing
|
||||
@ -1697,7 +1697,7 @@ int main(int argc, char ** argv) {
|
||||
glfwMakeContextCurrent(g_window);
|
||||
GLUtils::PrintGLVersion();
|
||||
|
||||
// accommocate high DPI displays (e.g. mac retina displays)
|
||||
// accommodate high DPI displays (e.g. mac retina displays)
|
||||
glfwGetFramebufferSize(g_window, &g_width, &g_height);
|
||||
glfwSetFramebufferSizeCallback(g_window, reshape);
|
||||
|
||||
@ -1716,7 +1716,7 @@ int main(int argc, char ** argv) {
|
||||
exit(1);
|
||||
}
|
||||
#ifdef CORE_PROFILE
|
||||
// clear GL errors which was generated during glewInit()
|
||||
// clear GL errors which were generated during glewInit()
|
||||
glGetError();
|
||||
#endif
|
||||
#endif
|
||||
|
@ -371,7 +371,7 @@ gatherTopology( MFnMesh & inMeshFn,
|
||||
// Note : Only supports 1 channel of UVs and 1 channel of color
|
||||
if (*hasUVs || *hasColors) {
|
||||
|
||||
// Create 2 face-varying channel descriptor that will hold UVs and color
|
||||
// Create 2 face-varying channel descriptors that will hold UVs and color
|
||||
desc.numFVarChannels = 2;
|
||||
channels = new Descriptor::FVarChannel[desc.numFVarChannels];
|
||||
desc.fvarChannels = channels;
|
||||
@ -750,7 +750,7 @@ convertToMayaMeshData(OpenSubdiv::Far::TopologyRefiner const & refiner,
|
||||
colorArray.set(colIt, c.r, c.g, c.b, c.a);
|
||||
}
|
||||
|
||||
// Currently, the plugin only supports one color sets
|
||||
// Currently, the plugin only supports one color set
|
||||
int colorSetIndex = 0;
|
||||
|
||||
// Assign color buffer and map the ids for each face-vertex
|
||||
|
@ -147,7 +147,7 @@ global proc string[] mayaPolySmooth(string $meshes[]) {
|
||||
}
|
||||
|
||||
//
|
||||
// Clearnup the DAG from nodes created with mayaPolySmooth
|
||||
// Cleanup the DAG from nodes created with mayaPolySmooth
|
||||
//
|
||||
global proc mayaPolySmoothCleanup() {
|
||||
|
||||
|
@ -41,7 +41,7 @@ namespace {
|
||||
};
|
||||
|
||||
|
||||
// Copies vertex data from hmesh into hbrVertexData reordered to match
|
||||
// Copies vertex data from hbrMesh into hbrVertexData reordered to match
|
||||
// the given refiner and subdivision level. This is used for later easy
|
||||
// comparison between the two.
|
||||
template<class T>
|
||||
|
@ -241,7 +241,7 @@ inline bool
|
||||
TopologyRefinerFactory<Shape>::assignFaceVaryingTopology(
|
||||
Far::TopologyRefiner & refiner, Shape const & shape) {
|
||||
|
||||
// UV layyout (we only parse 1 channel)
|
||||
// UV layout (we only parse 1 channel)
|
||||
if (not shape.faceuvs.empty()) {
|
||||
|
||||
int nfaces = getNumBaseFaces(refiner),
|
||||
|
@ -52,7 +52,7 @@ struct Shape {
|
||||
ns, // specular exponent
|
||||
ni, // optical density (1.0=no refraction, glass=1.5)
|
||||
sharpness, // reflection sharpness
|
||||
tf[3], // transimission filter
|
||||
tf[3], // transmission filter
|
||||
d; // dissolve factor (1.0 = opaque)
|
||||
|
||||
int illum;
|
||||
|
@ -29,7 +29,7 @@ _add_possibly_cuda_executable(hbr_regression
|
||||
$<TARGET_OBJECTS:regression_common_obj>
|
||||
)
|
||||
|
||||
# This is waht we "should" be using but we need to escape the backslash and cmake
|
||||
# This is what we "should" be using but we need to escape the backslash and cmake
|
||||
# regex doesn't allow that apparently
|
||||
#file(TO_NATIVE_PATH "${PROJECT_SOURCE_DIR}/regression/hbr_regression/baseline/" HBR_BASELINE_DIR)
|
||||
|
||||
|
@ -26,7 +26,7 @@
|
||||
//------------------------------------------------------------------------------
|
||||
// Tutorial description:
|
||||
//
|
||||
// This tutorial presents in a very succint way the requisite steps to
|
||||
// This tutorial presents in a very succinct way the requisite steps to
|
||||
// instantiate and refine a mesh with Far from simple topological data.
|
||||
//
|
||||
|
||||
@ -124,7 +124,7 @@ int main(int, char **) {
|
||||
|
||||
int maxlevel = 2;
|
||||
|
||||
// Uniformly refine the topolgy up to 'maxlevel'
|
||||
// Uniformly refine the topology up to 'maxlevel'
|
||||
refiner->RefineUniform(Far::TopologyRefiner::UniformOptions(maxlevel));
|
||||
|
||||
|
||||
|
@ -430,7 +430,7 @@ int main(int, char **) {
|
||||
|
||||
int maxlevel = 5;
|
||||
|
||||
// Uniformly refine the topolgy up to 'maxlevel'
|
||||
// Uniformly refine the topology up to 'maxlevel'
|
||||
refiner->RefineUniform(Far::TopologyRefiner::UniformOptions(maxlevel));
|
||||
|
||||
|
||||
|
@ -130,7 +130,7 @@ getSdcOptions( OpenSubdiv::HbrMesh<T> const & mesh, OpenSubdiv::SdcOptions * opt
|
||||
// uniquely. To remedy the problem, the converter uses a std::map to connect
|
||||
// Hbr's half-edge pointers to unique indices.
|
||||
//
|
||||
// This remapping code is provided as an example of efficient implementaiton of
|
||||
// This remapping code is provided as an example of efficient implementation of
|
||||
// the translation from an arbitrary topo rep to Vtr.
|
||||
//
|
||||
// Even though Vtr is capable of re-generating edge and vertex relationships on
|
||||
@ -178,7 +178,7 @@ public:
|
||||
return (int)_edgeset.size();
|
||||
}
|
||||
|
||||
// Returns a point to the Hbr halfege of index 'idx'
|
||||
// Returns a pointer to the Hbr halfege of index 'idx'
|
||||
OpenSubdiv::HbrHalfedge<T> const * GetEdge(int idx) const {
|
||||
return _edgeids[idx];
|
||||
}
|
||||
|
@ -124,7 +124,7 @@ int main(int, char **) {
|
||||
|
||||
Far::TopologyRefiner * refiner = createFarTopologyRefiner();
|
||||
|
||||
// Uniformly refine the topolgy up to 'maxlevel'
|
||||
// Uniformly refine the topology up to 'maxlevel'
|
||||
refiner->RefineUniform(Far::TopologyRefiner::UniformOptions(maxlevel));
|
||||
|
||||
// Allocate buffers for vertex primvar data.
|
||||
@ -140,7 +140,7 @@ int main(int, char **) {
|
||||
int nTotalVerts = refiner->GetNumVerticesTotal();
|
||||
int nTempVerts = nTotalVerts - nCoarseVerts - nFineVerts;
|
||||
|
||||
// Allocate and intialize the primvar data for the original coarse vertices:
|
||||
// Allocate and initialize the primvar data for the original coarse vertices:
|
||||
std::vector<VertexPosition> coarsePosBuffer(nCoarseVerts);
|
||||
std::vector<VertexColor> coarseClrBuffer(nCoarseVerts);
|
||||
|
||||
|
@ -81,11 +81,11 @@ private:
|
||||
//------------------------------------------------------------------------------
|
||||
// Face-varying container implementation.
|
||||
//
|
||||
// We are using a uv texture layout as a 'face-varying' primtiive variable
|
||||
// We are using a uv texture layout as a 'face-varying' primitive variable
|
||||
// attribute. Because face-varying data is specified 'per-face-per-vertex',
|
||||
// we cannot use the same container that we use for 'vertex' or 'varying'
|
||||
// data. We specify a new container, which only carries (u,v) coordinates.
|
||||
// Similarly to our 'Vertex' container, we add a minimaliztic interpolation
|
||||
// Similarly to our 'Vertex' container, we add a minimalistic interpolation
|
||||
// interface with a 'Clear()' and 'AddWithWeight()' methods.
|
||||
//
|
||||
struct FVarVertexUV {
|
||||
@ -248,7 +248,7 @@ int main(int, char **) {
|
||||
Far::TopologyRefinerFactory<Descriptor>::Create(desc,
|
||||
Far::TopologyRefinerFactory<Descriptor>::Options(type, options));
|
||||
|
||||
// Uniformly refine the topolgy up to 'maxlevel'
|
||||
// Uniformly refine the topology up to 'maxlevel'
|
||||
// note: fullTopologyInLastLevel must be true to work with face-varying data
|
||||
{
|
||||
Far::TopologyRefiner::UniformOptions refineOptions(maxlevel);
|
||||
|
@ -111,7 +111,7 @@ int main(int, char **) {
|
||||
Far::TopologyRefiner * refiner = createTopologyRefiner();
|
||||
|
||||
|
||||
// Uniformly refine the topolgy up to 'maxlevel'.
|
||||
// Uniformly refine the topology up to 'maxlevel'.
|
||||
int maxlevel = 3;
|
||||
refiner->RefineUniform(Far::TopologyRefiner::UniformOptions(maxlevel));
|
||||
|
||||
|
@ -113,11 +113,11 @@ static Far::TopologyRefiner * createTopologyRefiner();
|
||||
//------------------------------------------------------------------------------
|
||||
int main(int, char **) {
|
||||
|
||||
// Generate some FarTopologyRefiner (see far_tutorial_0 for details).
|
||||
// Generate a FarTopologyRefiner (see far_tutorial_0 for details).
|
||||
Far::TopologyRefiner * refiner = createTopologyRefiner();
|
||||
|
||||
|
||||
// Uniformly refine the topolgy up to 'maxlevel'.
|
||||
// Uniformly refine the topology up to 'maxlevel'.
|
||||
int maxlevel = 4;
|
||||
refiner->RefineUniform(Far::TopologyRefiner::UniformOptions(maxlevel));
|
||||
|
||||
@ -159,7 +159,7 @@ int main(int, char **) {
|
||||
// Allocate varying primvar buffer (1 stencil for each vertex)
|
||||
std::vector<Vertex> varyingBuffer(varyingStencils->GetNumStencils());
|
||||
|
||||
// Use the a per-vertex array of RGB colors as 'varying' primvar data
|
||||
// Use per-vertex array of RGB colors as 'varying' primvar data
|
||||
Vertex * varyingCVs = reinterpret_cast<Vertex *>(g_colors);
|
||||
|
||||
delete refiner;
|
||||
|
@ -28,7 +28,7 @@
|
||||
//
|
||||
// This tutorial shows how to create and manipulate table of cascading stencils.
|
||||
//
|
||||
// We initalize a Far::TopologyRefiner initalized with a cube and apply uniform
|
||||
// We initialize a Far::TopologyRefiner with a cube and apply uniform
|
||||
// refinement. We then use a Far::StencilTableFactory to generate a stencil
|
||||
// table. We set the factory Options to not factorize intermediate levels,
|
||||
// thus giving a table of "cascading" stencils.
|
||||
@ -122,15 +122,15 @@ static Far::TopologyRefiner * createTopologyRefiner();
|
||||
//------------------------------------------------------------------------------
|
||||
int main(int, char **) {
|
||||
|
||||
// Generate some FarTopologyRefiner (see far_tutorial_0 for details).
|
||||
// Generate a FarTopologyRefiner (see far_tutorial_0 for details).
|
||||
Far::TopologyRefiner * refiner = createTopologyRefiner();
|
||||
|
||||
// Uniformly refine the topolgy up to 'maxlevel'.
|
||||
// Uniformly refine the topology up to 'maxlevel'.
|
||||
int maxlevel = 4;
|
||||
refiner->RefineUniform(Far::TopologyRefiner::UniformOptions(maxlevel));
|
||||
|
||||
// Use the FarStencilTable factory to create cascading stencil table
|
||||
// note: we want stencils for the each refinement level
|
||||
// note: we want stencils for each refinement level
|
||||
// "cascade" mode is achieved by setting "factorizeIntermediateLevels"
|
||||
// to false
|
||||
Far::StencilTableFactory::Options options;
|
||||
@ -145,7 +145,7 @@ int main(int, char **) {
|
||||
|
||||
Vertex * destVerts = &vertexBuffer[0];
|
||||
|
||||
int start = 0, end = 0; // stencils batches for each level of subdivision
|
||||
int start = 0, end = 0; // stencil batches for each level of subdivision
|
||||
for (int level=0; level<maxlevel; ++level) {
|
||||
|
||||
int nverts = refiner->GetLevel(level+1).GetNumVertices();
|
||||
|
@ -26,7 +26,7 @@
|
||||
//------------------------------------------------------------------------------
|
||||
// Tutorial description:
|
||||
//
|
||||
// This tutorial presents in a very succint way the requisite steps to
|
||||
// This tutorial presents in a very succinct way the requisite steps to
|
||||
// instantiate an Hbr mesh from simple topological data.
|
||||
//
|
||||
|
||||
|
@ -27,7 +27,7 @@
|
||||
// Tutorial description:
|
||||
//
|
||||
// This tutorial shows how to safely create Hbr meshes from arbitrary topology.
|
||||
// Because Hbr is a half-edge data structure, it cannot represeent non-manifold
|
||||
// Because Hbr is a half-edge data structure, it cannot represent non-manifold
|
||||
// topology. Ensuring that the geometry used is manifold is a requirement to use
|
||||
// Hbr safely. This tutorial presents some simple tests to detect inappropriate
|
||||
// topology.
|
||||
|
@ -27,7 +27,7 @@
|
||||
// Tutorial description:
|
||||
//
|
||||
// This tutorial shows how to subdivide uniformly a simple Hbr mesh. We are
|
||||
// building upon previous turtorials and assuming a fully instantiated mesh:
|
||||
// building upon previous tutorials and assuming a fully instantiated mesh:
|
||||
// we start with an HbrMesh pointer initialized from the same pyramid shape
|
||||
// used in hbr_tutorial_0.
|
||||
//
|
||||
@ -45,7 +45,7 @@
|
||||
|
||||
//------------------------------------------------------------------------------
|
||||
//
|
||||
// For this tutorial, we have to flesh the Vertex class further. Note that now
|
||||
// For this tutorial, we have to flesh out the Vertex class further. Note that now
|
||||
// the copy constructor, Clear() and AddwithWeight() methods have been
|
||||
// implemented to interpolate our float3 position data.
|
||||
//
|
||||
@ -113,7 +113,7 @@ int main(int, char **) {
|
||||
|
||||
// Total number of faces in the mesh, across all levels
|
||||
//
|
||||
// Mote: this function iterates over the list of faces and can be slow
|
||||
// Note: this function iterates over the list of faces and can be slow
|
||||
int nfaces = hmesh->GetNumFaces();
|
||||
|
||||
if (level==(maxlevel-1)) {
|
||||
@ -126,7 +126,7 @@ int main(int, char **) {
|
||||
|
||||
Hface * f = hmesh->GetFace(face);
|
||||
|
||||
// Mote : hole tags would have to be dealt with here.
|
||||
// Note: hole tags would have to be dealt with here.
|
||||
f->Refine();
|
||||
}
|
||||
|
||||
|
@ -156,7 +156,7 @@ createTopologyRefiner(int maxlevel) {
|
||||
Far::TopologyRefinerFactory<Descriptor>::Create(desc,
|
||||
Far::TopologyRefinerFactory<Descriptor>::Options(type, options));
|
||||
|
||||
// Uniformly refine the topolgy up to 'maxlevel'
|
||||
// Uniformly refine the topology up to 'maxlevel'
|
||||
refiner->RefineUniform(Far::TopologyRefiner::UniformOptions(maxlevel));
|
||||
|
||||
return refiner;
|
||||
|
Loading…
Reference in New Issue
Block a user