/* This file is part of Nori, a simple educational ray tracer Copyright (c) 2015 by Wenzel Jakob Nori is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License Version 3 as published by the Free Software Foundation. Nori is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #pragma once #include NORI_NAMESPACE_BEGIN /** * \brief Main scene data structure * * This class holds information on scene objects and is responsible for * coordinating rendering jobs. It also provides useful query routines that * are mostly used by the \ref Integrator implementations. */ class Scene : public NoriObject { public: /// Construct a new scene object Scene(const PropertyList &); /// Release all memory virtual ~Scene(); /// Return a pointer to the scene's kd-tree const Accel *getAccel() const { return m_accel; } /// Return a pointer to the scene's integrator const Integrator *getIntegrator() const { return m_integrator; } /// Return a pointer to the scene's integrator Integrator *getIntegrator() { return m_integrator; } /// Return a pointer to the scene's camera const Camera *getCamera() const { return m_camera; } /// Return a pointer to the scene's sample generator (const version) const Sampler *getSampler() const { return m_sampler; } /// Return a pointer to the scene's sample generator Sampler *getSampler() { return m_sampler; } /// Return a reference to an array containing all meshes const std::vector &getMeshes() const { return m_meshes; } /** * \brief Intersect a ray against all triangles stored in the scene * and return detailed intersection information * * \param ray * A 3-dimensional ray data structure with minimum/maximum * extent information * * \param its * A detailed intersection record, which will be filled by the * intersection query * * \return \c true if an intersection was found */ bool rayIntersect(const Ray3f &ray, Intersection &its) const { return m_accel->rayIntersect(ray, its, false); } /** * \brief Intersect a ray against all triangles stored in the scene * and \a only determine whether or not there is an intersection. * * This method much faster than the other ray tracing function, * but the performance comes at the cost of not providing any * additional information about the detected intersection * (not even its position). * * \param ray * A 3-dimensional ray data structure with minimum/maximum * extent information * * \return \c true if an intersection was found */ bool rayIntersect(const Ray3f &ray) const { Intersection its; /* Unused */ return m_accel->rayIntersect(ray, its, true); } /// \brief Return an axis-aligned box that bounds the scene const BoundingBox3f &getBoundingBox() const { return m_accel->getBoundingBox(); } const std::pair getRandomEmitter(float rnd) const { if(m_emp.size() <=0) return std::pair(nullptr,nullptr); auto const & n = m_emp.size(); size_t index = std::min(static_cast(std::floor(n*rnd)),n-1); return m_emp[index]; } float getEmitterPDF() const { if(m_emp.size() <=0) return 0.0; return 1.0/m_emp.size(); } const Emitter* getEmitterEnv() const { return m_emenv; } /** * \brief Inherited from \ref NoriObject::activate() * * Initializes the internal data structures (kd-tree, * emitter sampling data structures, etc.) */ void activate(); /// Add a child object to the scene (meshes, integrators etc.) void addChild(NoriObject *obj); /// Return a string summary of the scene (for debugging purposes) std::string toString() const; EClassType getClassType() const { return EScene; } private: std::vector m_meshes; std::vector> m_emp; Emitter* m_emenv = nullptr; Integrator *m_integrator = nullptr; Sampler *m_sampler = nullptr; Camera *m_camera = nullptr; Accel *m_accel = nullptr; }; NORI_NAMESPACE_END