123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- import sys, os
- sys.path.insert(0, os.getcwd() + "/../")
- import pyigl as igl
- V = igl.eigen.MatrixXd()
- F = igl.eigen.MatrixXi()
- N_vertices = igl.eigen.MatrixXd()
- N_faces = igl.eigen.MatrixXd()
- N_corners = igl.eigen.MatrixXd()
- def key_pressed(viewer, key, modifier):
- if key == ord('1'):
- viewer.data.set_normals(N_faces)
- return True
- elif key == ord('2'):
- viewer.data.set_normals(N_vertices)
- return True
- elif key == ord('3'):
- viewer.data.set_normals(N_corners)
- return True
- return False
- igl.readOFF("../../tutorial/shared/fandisk.off", V, F);
- N_faces = igl.eigen.MatrixXd()
- igl.per_face_normals(V,F,N_faces)
- N_vertices = igl.eigen.MatrixXd()
- igl.per_vertex_normals(V,F,igl.PER_VERTEX_NORMALS_WEIGHTING_TYPE_AREA,N_vertices)
- N_corners = igl.eigen.MatrixXd()
- igl.per_corner_normals(V,F,20,N_corners)
- viewer = igl.viewer.Viewer()
- viewer.callback_key_pressed = key_pressed
- viewer.core.show_lines = False
- viewer.data.set_mesh(V, F)
- viewer.data.set_normals(N_faces)
- print("Press '1' for per-face normals.")
- print("Press '2' for per-vertex normals.")
- print("Press '3' for per-corner normals.")
- viewer.launch()
|