12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- import sys, os
- sys.path.insert(0, os.getcwd() + "/../")
- import pyigl as igl
- from shared import TUTORIAL_SHARED_PATH, check_dependencies
- dependencies = ["glfw"]
- check_dependencies(dependencies)
- V = igl.eigen.MatrixXd()
- F = igl.eigen.MatrixXi()
- igl.readOFF(TUTORIAL_SHARED_PATH + "bunny.off", V, F)
- m = V.colwiseMinCoeff()
- M = V.colwiseMaxCoeff()
- V_box = igl.eigen.MatrixXd(
- [
- [m[0, 0], m[0, 1], m[0, 2]],
- [M[0, 0], m[0, 1], m[0, 2]],
- [M[0, 0], M[0, 1], m[0, 2]],
- [m[0, 0], M[0, 1], m[0, 2]],
- [m[0, 0], m[0, 1], M[0, 2]],
- [M[0, 0], m[0, 1], M[0, 2]],
- [M[0, 0], M[0, 1], M[0, 2]],
- [m[0, 0], M[0, 1], M[0, 2]]
- ]
- )
- E_box = igl.eigen.MatrixXd(
- [
- [0, 1],
- [1, 2],
- [2, 3],
- [3, 0],
- [4, 5],
- [5, 6],
- [6, 7],
- [7, 4],
- [0, 4],
- [1, 5],
- [2, 6],
- [7, 3]
- ]
- ).castint()
- viewer = igl.glfw.Viewer()
- viewer.data().set_mesh(V, F)
- viewer.data().add_points(V_box, igl.eigen.MatrixXd([[1, 0, 0]]))
- for i in range(0, E_box.rows()):
- viewer.data().add_edges(
- V_box.row(E_box[i, 0]),
- V_box.row(E_box[i, 1]),
- igl.eigen.MatrixXd([[1, 0, 0]]))
- l1 = 'x: ' + str(m[0, 0]) + ' y: ' + str(m[0, 1]) + ' z: ' + str(m[0, 2])
- viewer.data().add_label(m.transpose(), l1)
- l2 = 'x: ' + str(M[0, 0]) + ' y: ' + str(M[0, 1]) + ' z: ' + str(M[0, 2])
- viewer.data().add_label(M.transpose(), l2)
- viewer.launch()
|