A polygon mesh can be open or closed in both directions (M-direction and N-direction); it has a number of columns and rows, a plane, and if it has a surface fitting entity, it also has a density value for both directions. The OdDbPolygonMesh class has methods for getting and setting these properties. In the following examples, the pPolyMesh variable stores a pointer to the polygon mesh object.
The OdDbPolygonMesh entity has the following properties that determine whether the polygon mesh is open or closed:
To check the closed status for a polygon mesh, use the isMClosed() and isNClosed() methods which return the status as a boolean value. For example:
// Check closed status in M direction
odPrintConsoleString(L"\nPolygon mesh is %s in M direction", ((pPolyMesh->isMClosed()) ? L"closed" : L"opened"));
// Check closed status in N direction
odPrintConsoleString(L"\nPolygon mesh is %s in N direction", ((pPolyMesh->isNClosed()) ? L"closed" : L"opened"));
To switch the closed status for a polygon mesh, use the makeMClosed(), makeNClosed(), makeMOpen, and makeNOpen() methods which do not have arguments. For example:
// Make the closed polygon mesh
pPolyMesh->makeMClosed();
pPolyMesh->makeNClosed();
// Make the opened polygon mesh
pPolyMesh->makeMOpen();
pPolyMesh->makeNOpen();
The polygon mesh is planar when all vertices lie in the same plane.
To get the plane for a polygon mesh, use the getPlane() method which requires a reference to a variable of the OdGePlane type in which the plane instance must be saved as the first argument, a reference to a variable of the OdDb::Planarity type in which the plane type must be saved as the second argument, and returns the plane properties through arguments and the resulting code. To check whether or not a polygon mesh is planar, use the isPlanar() method.
A polygon mesh entity stores the number of rows and columns.
To get the number of rows, use the mSize() method, which returns the number of rows as an integer value. To get the number of columns, use the nSize() method, which returns the number of columns as an integer value. For example:
// Get number of rows
OdInt16 sizeM = pPolyMesh->mSize();
odPrintConsoleString(L"\nNumber of rows = %i", sizeM);
// Get number of columns
OdInt16 sizeN = pPolyMesh->nSize();
odPrintConsoleString(L"\nNumber of columns = %i", sizeN);
To set the number of rows, use the setMSize() method, which requires the number of the rows as an integer value. To set the number of columns, use the setNSize() method, which requires the number of columns as an integer value. For example:
// Set number of rows
OdInt16 sizeM = 10
pPolyMesh->setMSize(sizeM);
// Set number of columns
OdInt16 sizeN = 10;
pPolyMesh->setNSize(sizeN);
The OdDbPolygonMesh entity has MDensity and NDensity properties that determine the density of Quadratic, Cubic, and Bezier polygon meshes. These properties specify or return the vertex count used to determine the density of the rows (MDensity) and columns (NDensity) of a polygon mesh.
To get the density of the rows and columns, use the mSurfaceDensity() and nSurfaceDensity() methods which return MDensity and NDensity properties as an integer value. For example:
// Get density of rows
OdInt16 denM = pPolyMesh->mSurfaceDensity();
odPrintConsoleString(L"\nDensity of rows = %i", denM);
// Get density of columns
OdInt16 denN = pPolyMesh->nSurfaceDensity();
odPrintConsoleString(L"\nDensity of columns = %i", denN);
To set the density of rows, use the setMSurfaceDensity() method, which requires density of the rows as an integer value. To set the density of columns, use the setNSurfaceDensity() method, which requires the density of the columns as an integer value.
Types of Polygon Meshes and Vertices
Working with Vertices of Polygon Meshes
Example of Working with Polygon Meshes
Copyright © 2002 – 2020. Open Design Alliance. All rights reserved.
|