本文整理汇总了C++中MNMesh::ExtrudeFaces方法的典型用法代码示例。如果您正苦于以下问题:C++ MNMesh::ExtrudeFaces方法的具体用法?C++ MNMesh::ExtrudeFaces怎么用?C++ MNMesh::ExtrudeFaces使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类MNMesh
的用法示例。
在下文中一共展示了MNMesh::ExtrudeFaces方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: Do
void PolyOpExtrudeFace::Do(MNMesh & mesh)
{
MNChamferData chamData;
if (mType<2) {
MNFaceClusters fclust(mesh, MN_USER);
if (!mesh.ExtrudeFaceClusters (fclust)) return;
if (mType == 0) {
// Get fresh face clusters:
MNFaceClusters fclustAfter(mesh, MN_USER);
Tab<Point3> clusterNormals, clusterCenters;
fclustAfter.GetNormalsCenters (mesh, clusterNormals, clusterCenters);
mesh.GetExtrudeDirection (&chamData, &fclustAfter, clusterNormals.Addr(0));
} else {
mesh.GetExtrudeDirection (&chamData, MN_USER);
}
} else {
// Polygon-by-polygon extrusion.
if (!mesh.ExtrudeFaces (MN_USER)) return;
MNFaceClusters fclustAfter(mesh, MN_USER);
Tab<Point3> clusterNormals, clusterCenters;
fclustAfter.GetNormalsCenters (mesh, clusterNormals, clusterCenters);
mesh.GetExtrudeDirection (&chamData, &fclustAfter, clusterNormals.Addr(0));
}
// Move vertices
for (int i=0; i<mesh.numv; i++) {
if (mesh.v[i].GetFlag (MN_DEAD)) continue;
mesh.v[i].p += chamData.vdir[i]*mHeight;
}
}