scene.hpp 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  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 "material.hpp"
  11. struct scene_object {
  12. material mat;
  13. scene_object(material&& _mat) : mat(std::move(_mat)){}
  14. virtual void kueder(){}
  15. };
  16. struct mesh_object : scene_object{
  17. size_t mesh_index;
  18. mesh_object(size_t mi, material&& _mat) : mesh_index(mi), scene_object(std::move(_mat)){}
  19. virtual void kueder(){}
  20. };
  21. struct sphere_object : scene_object{
  22. sphere_object(material&& _mat) : scene_object(std::move(_mat)){}
  23. virtual void kueder(){}
  24. };
  25. struct pointlight{
  26. Eigen::Vector3f pos;
  27. Eigen::Vector3f color;
  28. };
  29. struct scene{
  30. RTCScene m_scene;
  31. RTCDevice m_dev;
  32. std::unordered_set<unsigned int> emitters;
  33. std::unordered_map<unsigned int, size_t> geom_id_to_object_index_map;
  34. std::vector<objl::Mesh> added_meshes;
  35. std::vector<pointlight> pointlight;
  36. std::vector<std::unique_ptr<scene_object>> added_objects;
  37. scene(RTCDevice sc);
  38. unsigned int add_object(const objl::Mesh& mesh, const Eigen::Matrix4f& transform, bool emitter = false);
  39. unsigned int add_object(size_t mesh_index, const Eigen::Matrix4f& transform, bool emitter = false);
  40. unsigned int add_sphere(const Eigen::Vector3f& pos, float rad, bool emitter = false);
  41. void build();
  42. };
  43. scene get_scene(RTCDevice dev);
  44. #endif