You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
39 lines
1006 B
39 lines
1006 B
1 year ago
|
#include <igl/read_triangle_mesh.h>
|
||
|
#include <igl/unique.h>
|
||
|
#include <igl/opengl/glfw/Viewer.h>
|
||
|
#include <igl/fast_find_self_intersections.h>
|
||
|
|
||
|
int main(int argc, char *argv[])
|
||
|
{
|
||
|
|
||
|
Eigen::MatrixXd V;
|
||
|
Eigen::MatrixXi F;
|
||
|
igl::read_triangle_mesh(argc<=1?TUTORIAL_SHARED_PATH "/cow.off":argv[1], V, F);
|
||
|
|
||
|
|
||
|
// Plot the mesh
|
||
|
igl::opengl::glfw::Viewer viewer;
|
||
|
viewer.data().set_mesh(V, F);
|
||
|
|
||
|
Eigen::VectorXi EI;
|
||
|
Eigen::MatrixXd EV;
|
||
|
Eigen::MatrixXi IF,EE;
|
||
|
|
||
|
if(igl::fast_find_self_intersections(V,F,false,false,IF,EV,EE,EI))
|
||
|
{
|
||
|
std::cout<<"Found "<<IF.rows()<<" self intersecting pairs"<<std::endl;
|
||
|
// plot edge vertices
|
||
|
viewer.data().set_edges(EV,EE, Eigen::RowVector3d(1,0,0));
|
||
|
}
|
||
|
Eigen::VectorXi I;
|
||
|
igl::unique(IF,I);
|
||
|
Eigen::VectorXd D = Eigen::MatrixXd::Zero(F.rows(),1);
|
||
|
D(I).setConstant(1.0);
|
||
|
viewer.data().set_data(D,0,1,igl::COLOR_MAP_TYPE_PARULA);
|
||
|
viewer.data().set_face_based(true);
|
||
|
viewer.data().double_sided=true;
|
||
|
|
||
|
// Launch the viewer
|
||
|
viewer.launch();
|
||
|
}
|