X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Feffects%2Fenvironmentmap.h;h=4338581648b5b05917f48d8024ff98fc14bc56ea;hb=0fa506250545acb83bc86f1734826544d6f1eda6;hp=5d1e7c91a7207b02666b736bf8320c4cad99c41f;hpb=82282de52e8e8f3bbafefaf92bf76f53f2c2495e;p=libs%2Fgl.git diff --git a/source/effects/environmentmap.h b/source/effects/environmentmap.h index 5d1e7c91..43385816 100644 --- a/source/effects/environmentmap.h +++ b/source/effects/environmentmap.h @@ -1,19 +1,19 @@ #ifndef MSP_GL_ENVIRONMENTMAP_H_ #define MSP_GL_ENVIRONMENTMAP_H_ +#include #include "camera.h" #include "effect.h" #include "framebuffer.h" -#include "matrix.h" #include "programdata.h" -#include "renderbuffer.h" +#include "texture2d.h" #include "texturecube.h" -#include "vector.h" namespace Msp { namespace GL { -class Resources; +class Mesh; +class Sampler; /** Creates a cube map texture of the surroundings of the renderable. This texture @@ -26,7 +26,35 @@ environment. */ class EnvironmentMap: public Effect { -private: +public: + struct Template: Effect::Template + { + class Loader: public DataFile::DerivedObjectLoader + { + private: + static ActionMap shared_actions; + + public: + Loader(Template &, Collection &); + private: + virtual void init_actions(); + + void fixed_position(float, float, float); + }; + + unsigned size = 512; + PixelFormat format = RGB16F; + std::string environment_name; + unsigned roughness_levels = 5; + Vector3 fixed_position; + bool use_fixed_position = false; + float near_clip = 0.1f; + float far_clip = 100.0f; + + virtual EnvironmentMap *create(const std::map &) const; + }; + +protected: struct Face { Framebuffer fbo; @@ -36,21 +64,33 @@ private: unsigned size; Renderable &environment; TextureCube env_tex; - Renderbuffer depth_buf; + Texture2D depth_buf; Face faces[6]; + Vector3 fixed_position; + bool use_fixed_pos = false; + + TextureCube irradiance; + const Program &irradiance_shprog; + Framebuffer irradiance_fbo; + const Program &specular_shprog; + std::vector specular_fbos; + ProgramData prefilter_shdata; + const Mesh &fullscreen_mesh; + const Sampler &sampler; + const Sampler &mip_sampler; ProgramData shdata; - bool rendered; - unsigned update_interval; - unsigned update_delay; + bool rendered = false; + bool in_setup_frame = false; + unsigned update_interval = 1; + unsigned update_delay = 0; public: - EnvironmentMap(Resources &, unsigned size, Renderable &rend, Renderable &env); - EnvironmentMap(Resources &, unsigned size, PixelFormat, Renderable &rend, Renderable &env); -private: - void init(unsigned, PixelFormat, unsigned); + EnvironmentMap(unsigned size, PixelFormat, Renderable &rend, Renderable &env); + EnvironmentMap(unsigned size, PixelFormat, unsigned, Renderable &rend, Renderable &env); + + void set_fixed_position(const Vector3 &); -public: void set_depth_clip(float, float); /** Sets the interval in frames between environment map updates. A value of @@ -64,6 +104,8 @@ public: virtual void finish_frame(); virtual void render(Renderer &, Tag = Tag()) const; + + virtual void set_debug_name(const std::string &); }; } // namespace GL