main.cpp 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. #include <igl/readOFF.h>
  2. #include <igl/combine.h>
  3. #include <igl/opengl/glfw/Viewer.h>
  4. #include <igl/opengl/glfw/imgui/ImGuiMenu.h>
  5. #include <igl/fast_find_intersections.h>
  6. Eigen::MatrixXd V1,V2;
  7. Eigen::MatrixXi F1,F2;
  8. igl::AABB<Eigen::MatrixXd,3> tree;
  9. double min_z,max_z;
  10. double slice_z;
  11. void update_visualization(igl::opengl::glfw::Viewer & viewer)
  12. {
  13. Eigen::MatrixXi I;
  14. Eigen::MatrixXd edges;
  15. //shifted intersection object
  16. Eigen::MatrixXd V2_(V2.rows(),V2.cols());
  17. V2_<< V2.col(0), V2.col(1), V2.col(2).array()+slice_z;
  18. igl::fast_find_intersections(tree, V1,F1, V2_,F2, I,edges);
  19. Eigen::MatrixXi edges_link=Eigen::MatrixXi::NullaryExpr(edges.rows()/2,2, [](int i,int j) { return i*2+j;});
  20. // Plot the edges of the intersects
  21. viewer.data().set_edges ( edges, edges_link, Eigen::RowVector3d(1,0,0));
  22. // show faces which are intersected
  23. Eigen::VectorXd face_data=Eigen::VectorXd::Zero(F1.rows());
  24. for(int i=0; i<I.rows(); ++i)
  25. face_data(I(i,0)) = 1.0;
  26. viewer.data().set_data(face_data);
  27. }
  28. bool key_down(igl::opengl::glfw::Viewer& viewer, unsigned char key, int mod)
  29. {
  30. switch(key)
  31. {
  32. default:
  33. return false;
  34. case '.':
  35. slice_z = std::min(slice_z+0.01,max_z);
  36. break;
  37. case ',':
  38. slice_z = std::max(slice_z-0.01,min_z);
  39. break;
  40. }
  41. update_visualization(viewer);
  42. return true;
  43. }
  44. int main(int argc, char *argv[])
  45. {
  46. // Load two meshes
  47. igl::readOFF(TUTORIAL_SHARED_PATH "/cow.off", V1, F1);
  48. igl::readOFF(TUTORIAL_SHARED_PATH "/planexy.off", V2, F2);
  49. // initialize AABB tree with first mesh (it doesn't move)
  50. tree.init(V1,F1);
  51. std::cout<<"Usage:"<<std::endl;
  52. std::cout<<"'.'/',' push back/pull forward slicing plane."<<std::endl;
  53. std::cout<<std::endl;
  54. min_z=V1.col(2).minCoeff();
  55. max_z=V1.col(2).maxCoeff();
  56. slice_z=(max_z+min_z)/2;
  57. //center slicing object
  58. V2.col(2).array() -= V2.col(2).array().mean();
  59. // Plot the mesh
  60. igl::opengl::glfw::Viewer viewer;
  61. viewer.data().set_mesh(V1, F1);
  62. update_visualization(viewer);
  63. igl::opengl::glfw::imgui::ImGuiMenu menu;
  64. //plugin.widgets.push_back(&menu);
  65. menu.callback_draw_viewer_window = [](){};
  66. viewer.callback_key_down = &key_down;
  67. // show the cow closer
  68. viewer.core().camera_zoom = 2.0;
  69. // Launch the viewer
  70. viewer.launch();
  71. }