|
@@ -0,0 +1,140 @@
|
|
|
|
+from __future__ import print_function
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+import sys, os
|
|
|
|
+sys.path.insert(0, os.getcwd() + "/../")
|
|
|
|
+
|
|
|
|
+import pyigl as igl
|
|
|
|
+from iglhelpers import e2p
|
|
|
|
+import math
|
|
|
|
+TUTORIAL_SHARED_PATH = "../../tutorial/shared/"
|
|
|
|
+
|
|
|
|
+global V, F, T, tree, FN, VN, EN, E, EMAP, max_distance, slice_z, overlay
|
|
|
|
+
|
|
|
|
+V = igl.eigen.MatrixXd()
|
|
|
|
+F = igl.eigen.MatrixXi()
|
|
|
|
+T = igl.eigen.MatrixXi()
|
|
|
|
+tree = igl.AABB()
|
|
|
|
+FN = igl.eigen.MatrixXd()
|
|
|
|
+VN = igl.eigen.MatrixXd()
|
|
|
|
+EN = igl.eigen.MatrixXd()
|
|
|
|
+E = igl.eigen.MatrixXi()
|
|
|
|
+EMAP = igl.eigen.MatrixXi()
|
|
|
|
+
|
|
|
|
+max_distance = 1
|
|
|
|
+slice_z = 0.5
|
|
|
|
+overlay = False
|
|
|
|
+
|
|
|
|
+viewer = igl.viewer.Viewer()
|
|
|
|
+
|
|
|
|
+def update_visualization(viewer):
|
|
|
|
+ global V, F, T, tree, FN, VN, EN, E, EMAP, max_distance, slice_z, overlay
|
|
|
|
+ plane = igl.eigen.MatrixXd([0.0, 0.0, 1.0, -((1-slice_z) * V.col(2).minCoeff() + slice_z * V.col(2).maxCoeff())])
|
|
|
|
+ V_vis = igl.eigen.MatrixXd()
|
|
|
|
+ F_vis = igl.eigen.MatrixXi()
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+ J = igl.eigen.MatrixXi()
|
|
|
|
+ bary = igl.eigen.SparseMatrixd()
|
|
|
|
+ igl.slice_tets(V, T, plane, V_vis, F_vis, J, bary)
|
|
|
|
+ max_l = 0.03
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+ viewer.data.clear()
|
|
|
|
+ viewer.data.set_mesh(V_vis, F_vis)
|
|
|
|
+
|
|
|
|
+ viewer.core.lighting_factor = overlay
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+def key_down(viewer, key, modifier):
|
|
|
|
+ global slice_z, overlay
|
|
|
|
+
|
|
|
|
+ if key == ord(' '):
|
|
|
|
+ overlay = not overlay
|
|
|
|
+ elif key == ord('.'):
|
|
|
|
+ slice_z = min(slice_z + 0.01, 0.99)
|
|
|
|
+ elif key == ord(','):
|
|
|
|
+ slice_z = max(slice_z - 0.01, 0.01)
|
|
|
|
+ else:
|
|
|
|
+ return False
|
|
|
|
+
|
|
|
|
+ update_visualization(viewer)
|
|
|
|
+ return True
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+print("Press [space] to toggle showing surface.")
|
|
|
|
+print("Press '.'/',' to push back/pull forward slicing plane.")
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+igl.readMESH(TUTORIAL_SHARED_PATH + "bunny.mesh", V, T, F);
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+sqrD = igl.eigen.MatrixXd()
|
|
|
|
+I = igl.eigen.MatrixXi()
|
|
|
|
+C = igl.eigen.MatrixXd()
|
|
|
|
+igl.point_mesh_squared_distance(V, V, F, sqrD, I, C)
|
|
|
|
+max_distance = math.sqrt(sqrD.maxCoeff())
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+tree.init(V, F)
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+igl.per_face_normals(V, F, FN)
|
|
|
|
+igl.per_vertex_normals(V, F, igl.PER_VERTEX_NORMALS_WEIGHTING_TYPE_ANGLE, FN, VN)
|
|
|
|
+igl.per_edge_normals(V, F, igl.PER_EDGE_NORMALS_WEIGHTING_TYPE_UNIFORM, FN, EN, E, EMAP)
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+update_visualization(viewer);
|
|
|
|
+viewer.callback_key_down = key_down
|
|
|
|
+viewer.core.show_lines = False
|
|
|
|
+viewer.launch()
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|