/*
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