301_Slice.py 876 B

12345678910111213141516171819202122232425262728293031323334
  1. from __future__ import print_function
  2. import igl
  3. V = igl.eigen.MatrixXd()
  4. F = igl.eigen.MatrixXi()
  5. igl.readOFF("../tutorial/shared/decimated-knight.off",V,F)
  6. # 100 random indicies into rows of F
  7. I = igl.eigen.MatrixXi()
  8. igl.floor((0.5*(igl.eigen.MatrixXd.Random(100,1)+1.)*F.rows()),I);
  9. # 50 random indicies into rows of I
  10. J = igl.eigen.MatrixXi()
  11. igl.floor((0.5*(igl.eigen.MatrixXd.Random(50,1)+1.)*I.rows()),J)
  12. # K = I(J);
  13. K = igl.eigen.MatrixXi()
  14. igl.slice(I,J,K)
  15. # default green for all faces
  16. #C = p2e(np.array([[0.4,0.8,0.3]])).replicate(F.rows(),1)
  17. C = igl.eigen.MatrixXd([[0.4,0.8,0.3]]).replicate(F.rows(),1)
  18. # Red for each in K
  19. R = igl.eigen.MatrixXd([[1.0,0.3,0.3]]).replicate(K.rows(),1)
  20. # C(K,:) = R
  21. igl.slice_into(R,K,1,C)
  22. # Plot the mesh with pseudocolors
  23. viewer = igl.viewer.Viewer()
  24. viewer.data.set_mesh(V, F)
  25. viewer.data.set_colors(C)
  26. viewer.launch()