Viewer.h 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  1. // This file is part of libigl, a simple c++ geometry processing library.
  2. //
  3. // Copyright (C) 2014 Daniele Panozzo <daniele.panozzo@gmail.com>
  4. //
  5. // This Source Code Form is subject to the terms of the Mozilla Public License
  6. // v. 2.0. If a copy of the MPL was not distributed with this file, You can
  7. // obtain one at http://mozilla.org/MPL/2.0/.
  8. #ifndef IGL_OPENGL_GLFW_VIEWER_H
  9. #define IGL_OPENGL_GLFW_VIEWER_H
  10. #ifndef IGL_OPENGL_4
  11. #define IGL_OPENGL_4
  12. #endif
  13. #include "../../igl_inline.h"
  14. #include "../MeshGL.h"
  15. #include "../ViewerCore.h"
  16. #include "../ViewerData.h"
  17. #include "ViewerPlugin.h"
  18. #include <Eigen/Core>
  19. #include <Eigen/Geometry>
  20. #include <vector>
  21. #include <string>
  22. #include <cstdint>
  23. #define IGL_MOD_SHIFT 0x0001
  24. #define IGL_MOD_CONTROL 0x0002
  25. #define IGL_MOD_ALT 0x0004
  26. #define IGL_MOD_SUPER 0x0008
  27. struct GLFWwindow;
  28. namespace igl
  29. {
  30. namespace opengl
  31. {
  32. namespace glfw
  33. {
  34. // GLFW-based mesh viewer
  35. class Viewer
  36. {
  37. public:
  38. // UI Enumerations
  39. enum class MouseButton {Left, Middle, Right};
  40. enum class MouseMode { None, Rotation, Zoom, Pan, Translation} mouse_mode;
  41. IGL_INLINE int launch(bool resizable = true, bool fullscreen = false, const std::string &name = "libigl viewer", int width = 1280, int height = 800);
  42. IGL_INLINE int launch_init(bool resizable = true, bool fullscreen = false, const std::string &name = "libigl viewer", int width = 1280, int height = 800);
  43. IGL_INLINE bool launch_rendering(bool loop = true);
  44. IGL_INLINE void launch_shut();
  45. IGL_INLINE void init();
  46. IGL_INLINE void init_plugins();
  47. IGL_INLINE void shutdown_plugins();
  48. Viewer();
  49. ~Viewer();
  50. // Mesh IO
  51. IGL_INLINE bool load_mesh_from_file(const std::string & mesh_file_name);
  52. IGL_INLINE bool save_mesh_to_file(const std::string & mesh_file_name);
  53. // Callbacks
  54. IGL_INLINE bool key_pressed(unsigned int unicode_key,int modifier);
  55. IGL_INLINE bool key_down(int key,int modifier);
  56. IGL_INLINE bool key_up(int key,int modifier);
  57. IGL_INLINE bool mouse_down(MouseButton button,int modifier);
  58. IGL_INLINE bool mouse_up(MouseButton button,int modifier);
  59. IGL_INLINE bool mouse_move(int mouse_x,int mouse_y);
  60. IGL_INLINE bool mouse_scroll(float delta_y);
  61. // Scene IO
  62. IGL_INLINE bool load_scene();
  63. IGL_INLINE bool load_scene(std::string fname);
  64. IGL_INLINE bool save_scene();
  65. IGL_INLINE bool save_scene(std::string fname);
  66. // Draw everything
  67. IGL_INLINE void draw();
  68. // OpenGL context resize
  69. IGL_INLINE void resize(int w,int h); // explicitly set window size
  70. IGL_INLINE void post_resize(int w,int h); // external resize due to user interaction
  71. // Helper functions
  72. IGL_INLINE void snap_to_canonical_quaternion();
  73. IGL_INLINE void open_dialog_load_mesh();
  74. IGL_INLINE void open_dialog_save_mesh();
  75. ////////////////////////
  76. // Multi-mesh methods //
  77. ////////////////////////
  78. // Return the current mesh, or the mesh corresponding to a given unique identifier
  79. //
  80. // Inputs:
  81. // mesh_id unique identifier associated to the desired mesh (current mesh if -1)
  82. IGL_INLINE ViewerData& data(int mesh_id = -1);
  83. // Append a new "slot" for a mesh (i.e., create empty entries at the end of
  84. // the data_list and opengl_state_list.
  85. //
  86. // Inputs:
  87. // visible If true, the new mesh is set to be visible on all existing viewports
  88. // Returns the id of the last appended mesh
  89. //
  90. // Side Effects:
  91. // selected_data_index is set this newly created, last entry (i.e.,
  92. // #meshes-1)
  93. IGL_INLINE int append_mesh(bool visible = true);
  94. // Erase a mesh (i.e., its corresponding data and state entires in data_list
  95. // and opengl_state_list)
  96. //
  97. // Inputs:
  98. // index index of mesh to erase
  99. // Returns whether erasure was successful <=> cannot erase last mesh
  100. //
  101. // Side Effects:
  102. // If selected_data_index is greater than or equal to index then it is
  103. // decremented
  104. // Example:
  105. // // Erase all mesh slots except first and clear remaining mesh
  106. // viewer.selected_data_index = viewer.data_list.size()-1;
  107. // while(viewer.erase_mesh(viewer.selected_data_index)){};
  108. // viewer.data().clear();
  109. //
  110. IGL_INLINE bool erase_mesh(const size_t index);
  111. // Retrieve mesh index from its unique identifier
  112. // Returns 0 if not found
  113. IGL_INLINE size_t mesh_index(const int id) const;
  114. ////////////////////////////
  115. // Multi-viewport methods //
  116. ////////////////////////////
  117. // Return the current viewport, or the viewport corresponding to a given unique identifier
  118. //
  119. // Inputs:
  120. // core_id unique identifier corresponding to the desired viewport (current viewport if 0)
  121. IGL_INLINE ViewerCore& core(unsigned core_id = 0);
  122. // Append a new "slot" for a viewport (i.e., copy properties of the current viewport, only
  123. // changing the viewport size/position)
  124. //
  125. // Inputs:
  126. // viewport Vector specifying the viewport origin and size in screen coordinates.
  127. // append_empty If true, existing meshes are hidden on the new viewport.
  128. //
  129. // Returns the unique id of the newly inserted viewport. There can be a maximum of 31
  130. // viewports created in the same viewport. Erasing a viewport does not change the id of
  131. // other existing viewports
  132. IGL_INLINE int append_core(Eigen::Vector4f viewport, bool append_empty = false);
  133. // Erase a viewport
  134. //
  135. // Inputs:
  136. // index index of the viewport to erase
  137. IGL_INLINE bool erase_core(const size_t index);
  138. // Retrieve viewport index from its unique identifier
  139. // Returns 0 if not found
  140. IGL_INLINE size_t core_index(const int id) const;
  141. // Change selected_core_index to the viewport containing the mouse
  142. // (current_mouse_x, current_mouse_y)
  143. IGL_INLINE void select_hovered_core();
  144. public:
  145. //////////////////////
  146. // Member variables //
  147. //////////////////////
  148. // Alec: I call this data_list instead of just data to avoid confusion with
  149. // old "data" variable.
  150. // Stores all the data that should be visualized
  151. std::vector<ViewerData> data_list;
  152. size_t selected_data_index;
  153. int next_data_id;
  154. GLFWwindow* window;
  155. // Stores all the viewing options
  156. std::vector<ViewerCore> core_list;
  157. size_t selected_core_index;
  158. int next_core_id;
  159. // List of registered plugins
  160. std::vector<ViewerPlugin*> plugins;
  161. // Temporary data stored when the mouse button is pressed
  162. Eigen::Quaternionf down_rotation;
  163. int current_mouse_x;
  164. int current_mouse_y;
  165. int down_mouse_x;
  166. int down_mouse_y;
  167. float down_mouse_z;
  168. Eigen::Vector3f down_translation;
  169. bool down;
  170. bool hack_never_moved;
  171. // Keep track of the global position of the scrollwheel
  172. float scroll_position;
  173. // C++-style functions
  174. //
  175. // Returns **true** if action should be cancelled.
  176. std::function<bool(Viewer& viewer)> callback_init;
  177. std::function<bool(Viewer& viewer)> callback_pre_draw;
  178. std::function<bool(Viewer& viewer)> callback_post_draw;
  179. std::function<bool(Viewer& viewer, int button, int modifier)> callback_mouse_down;
  180. std::function<bool(Viewer& viewer, int button, int modifier)> callback_mouse_up;
  181. std::function<bool(Viewer& viewer, int mouse_x, int mouse_y)> callback_mouse_move;
  182. std::function<bool(Viewer& viewer, float delta_y)> callback_mouse_scroll;
  183. std::function<bool(Viewer& viewer, unsigned int key, int modifiers)> callback_key_pressed;
  184. std::function<bool(Viewer& viewer, int w, int h)> callback_post_resize;
  185. // THESE SHOULD BE DEPRECATED:
  186. std::function<bool(Viewer& viewer, unsigned int key, int modifiers)> callback_key_down;
  187. std::function<bool(Viewer& viewer, unsigned int key, int modifiers)> callback_key_up;
  188. // Pointers to per-callback data
  189. void* callback_init_data;
  190. void* callback_pre_draw_data;
  191. void* callback_post_draw_data;
  192. void* callback_mouse_down_data;
  193. void* callback_mouse_up_data;
  194. void* callback_mouse_move_data;
  195. void* callback_mouse_scroll_data;
  196. void* callback_key_pressed_data;
  197. void* callback_key_down_data;
  198. void* callback_key_up_data;
  199. public:
  200. EIGEN_MAKE_ALIGNED_OPERATOR_NEW
  201. };
  202. } // end namespace
  203. } // end namespace
  204. } // end namespace
  205. #ifndef IGL_STATIC_LIBRARY
  206. # include "Viewer.cpp"
  207. #endif
  208. #endif