scene.hpp 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. #ifndef SCENE_HPP
  2. #define SCENE_HPP
  3. #include <embree3/rtcore.h>
  4. #include <unordered_set>
  5. #include <unordered_map>
  6. #include <OBJ_Loader.h>
  7. #include <Eigen/Dense>
  8. #include <Eigen/Geometry>
  9. #include <memory>
  10. #include "texture.hpp"
  11. struct scene_object {};
  12. struct mesh_object : scene_object{
  13. size_t mesh_index;
  14. std::unique_ptr<texture> tex;
  15. mesh_object(size_t mi, std::unique_ptr<texture>&& _tex) : mesh_index(mi), tex(std::move(_tex)){}
  16. };
  17. struct sphere_object : scene_object{
  18. std::unique_ptr<texture> tex;
  19. sphere_object(std::unique_ptr<texture>&& _tex) : tex(std::move(_tex)){}
  20. };
  21. struct pointlight{
  22. Eigen::Vector3f pos;
  23. Eigen::Vector3f color;
  24. };
  25. struct scene{
  26. RTCScene m_scene;
  27. RTCDevice m_dev;
  28. std::unordered_set<unsigned int> emitters;
  29. std::unordered_map<unsigned int, size_t> geom_id_to_object_index_map;
  30. std::vector<objl::Mesh> added_meshes;
  31. std::vector<pointlight> pointlight;
  32. std::vector<std::unique_ptr<scene_object>> added_objects;
  33. scene(RTCDevice sc);
  34. unsigned int add_object(const objl::Mesh& mesh, const Eigen::Matrix4f& transform, bool emitter = false);
  35. unsigned int add_object(size_t mesh_index, const Eigen::Matrix4f& transform, bool emitter = false);
  36. unsigned int add_sphere(const Eigen::Vector3f& pos, float rad, bool emitter = false);
  37. void build();
  38. };
  39. scene get_scene(RTCDevice dev);
  40. #endif