Lightmetrica  0.0.1.50dbee3 (yosakoi)
 All Classes Functions Variables Typedefs Enumerations Enumerator
emitter.h
1 /*
2  Lightmetrica : A research-oriented renderer
3 
4  Copyright (c) 2014 Hisanari Otsu
5 
6  This program is free software: you can redistribute it and/or modify
7  it under the terms of the GNU General Public License as published by
8  the Free Software Foundation, either version 3 of the License, or
9  (at your option) any later version.
10 
11  This program is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  GNU General Public License for more details.
15 
16  You should have received a copy of the GNU General Public License
17  along with this program. If not, see <http://www.gnu.org/licenses/>.
18 */
19 
20 #pragma once
21 #ifndef LIB_LIGHTMETRICA_EMITTER_H
22 #define LIB_LIGHTMETRICA_EMITTER_H
23 
24 #include "generalizedbsdf.h"
25 #include "aabb.h"
26 
27 LM_NAMESPACE_BEGIN
28 
29 struct Primitive;
30 struct SurfaceGeometry;
31 class Scene;
32 class EmitterShape;
33 
38 class Emitter : public GeneralizedBSDF
39 {
40 public:
41 
42  Emitter() {}
43  virtual ~Emitter() {}
44 
45 public:
46 
53  virtual void SamplePosition(const Math::Vec2& sample, SurfaceGeometry& geom, Math::PDFEval& pdf) const = 0;
54 
60  virtual Math::Vec3 EvaluatePosition(const SurfaceGeometry& geom) const = 0;
61 
67  virtual Math::PDFEval EvaluatePositionPDF(const SurfaceGeometry& geom) const = 0;
68 
76  virtual void RegisterPrimitives(const std::vector<Primitive*>& primitives) = 0;
77 
84  virtual void PostConfigure(const Scene& scene) = 0;
85 
94  virtual EmitterShape* CreateEmitterShape() const = 0;
95 
98  virtual AABB GetAABB() const = 0;
99 
100 };
101 
102 LM_NAMESPACE_END
103 
104 #endif // LIB_LIGHTMETRICA_EMITTER_H
virtual Math::Vec3 EvaluatePosition(const SurfaceGeometry &geom) const =0
Definition: generalizedbsdf.h:168
virtual void RegisterPrimitives(const std::vector< Primitive * > &primitives)=0
Definition: primitive.h:39
virtual EmitterShape * CreateEmitterShape() const =0
Definition: scene.h:47
Definition: emittershape.h:41
Definition: surfacegeometry.h:36
virtual Math::PDFEval EvaluatePositionPDF(const SurfaceGeometry &geom) const =0
virtual void PostConfigure(const Scene &scene)=0
Definition: aabb.h:28
Definition: emitter.h:38
virtual void SamplePosition(const Math::Vec2 &sample, SurfaceGeometry &geom, Math::PDFEval &pdf) const =0