本文整理汇总了C++中Manifold::add_face方法的典型用法代码示例。如果您正苦于以下问题:C++ Manifold::add_face方法的具体用法?C++ Manifold::add_face怎么用?C++ Manifold::add_face使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Manifold
的用法示例。
在下文中一共展示了Manifold::add_face方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: dual
void dual(HMesh::Manifold& m)
{
FaceAttributeVector<Vec3d> face_center(m.no_faces());
for (auto f : m.faces()) {
// find mid point
Vec3d mpt(0.0, 0.0, 0.0);
int nb_p = 0;
for (auto hw = m.walker(f); !hw.full_circle(); hw = hw.circulate_face_ccw()) {
mpt += m.pos(hw.vertex());
nb_p++;
}
mpt = mpt / nb_p;
face_center[f] = mpt;
}
Manifold newMesh;
for (auto v : m.vertices()) {
vector<Vec3d> pts;
for (auto hw = m.walker(v); !hw.full_circle(); hw = hw.circulate_vertex_ccw()) {
// if (hw.opp().face() == InvalidFaceID)
// {
// pts.push_back((m.pos(hw.vertex()) + m.pos(hw.opp().vertex()))/2.0);
// pts.push_back(face_center[hw.face()]);
// }
// else if(hw.face() == InvalidFaceID)
// {
// pts.push_back((m.pos(hw.vertex()) + m.pos(hw.opp().vertex()))/2.0);
// }
// else
if (m.in_use(hw.face()))
{
pts.push_back(face_center[hw.face()]);
}
}
newMesh.add_face(pts);
}
stitch_mesh(newMesh, 0.01);
m = newMesh;
}