| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- #include <igl/avg_edge_length.h>
- #include <igl/cotmatrix.h>
- #include <igl/invert_diag.h>
- #include <igl/massmatrix.h>
- #include <igl/parula.h>
- #include <igl/per_corner_normals.h>
- #include <igl/per_face_normals.h>
- #include <igl/per_vertex_normals.h>
- #include <igl/principal_curvature.h>
- #include <igl/read_triangle_mesh.h>
- #include <igl/opengl/glfw/Viewer.h>
- Eigen::MatrixXd V;
- Eigen::MatrixXi F;
- int main(int argc, char *argv[])
- {
- using namespace Eigen;
- std::string filename = TUTORIAL_SHARED_PATH "/fertility.off";
- if(argc>1)
- {
- filename = argv[1];
- }
- // Load a mesh in OFF format
- igl::read_triangle_mesh(filename, V, F);
- // Alternative discrete mean curvature
- MatrixXd HN;
- SparseMatrix<double> L,M,Minv;
- igl::cotmatrix(V,F,L);
- igl::massmatrix(V,F,igl::MASSMATRIX_TYPE_VORONOI,M);
- igl::invert_diag(M,Minv);
- // Laplace-Beltrami of position
- HN = -Minv*(L*V);
- // Extract magnitude as mean curvature
- VectorXd H = HN.rowwise().norm();
- // Compute curvature directions via quadric fitting
- MatrixXd PD1,PD2;
- VectorXd PV1,PV2;
- igl::principal_curvature(V,F,PD1,PD2,PV1,PV2);
- // mean curvature
- H = 0.5*(PV1+PV2);
- igl::opengl::glfw::Viewer viewer;
- viewer.data().set_mesh(V, F);
- viewer.data().set_data(H);
- // Average edge length for sizing
- const double avg = igl::avg_edge_length(V,F);
- // Draw a red segment parallel to the maximal curvature direction
- const RowVector3d red(0.8,0.2,0.2),blue(0.2,0.2,0.8);
- viewer.data().add_edges(V + PD1*avg, V - PD1*avg, red);
- // Draw a blue segment parallel to the minimal curvature direction
- viewer.data().add_edges(V + PD2*avg, V - PD2*avg, blue);
- // Hide wireframe
- viewer.data().show_lines = false;
- viewer.launch();
- }
|