X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fambientocclusion.h;h=b6daa776d6af8804f5cf1186cb7974d1b5f3783d;hp=704ddb25d8c0ed673455a765d39ba8ae64ef96be;hb=133fe7352831197c9ec59f923c1126651d80edcb;hpb=f14435e58bfa0fa697a06ba9a454bb30cd37d9d8 diff --git a/source/ambientocclusion.h b/source/ambientocclusion.h index 704ddb25..b6daa776 100644 --- a/source/ambientocclusion.h +++ b/source/ambientocclusion.h @@ -6,6 +6,7 @@ #include "postprocessor.h" #include "program.h" #include "programdata.h" +#include "rendertarget.h" #include "texture2d.h" #include "texturing.h" @@ -20,24 +21,30 @@ http://en.wikipedia.org/wiki/Screen_Space_Ambient_Occlusion class AmbientOcclusion: public PostProcessor { private: - Texture2D occlusion; Texture2D rotate_lookup; - Framebuffer fbo; - Texturing occlude_texturing; + RenderTarget occlude_target; + Texturing texturing; Program occlude_shader; - ProgramData occlude_shdata; - Texturing combine_texturing; Program combine_shader; - ProgramData combine_shdata; - Mesh quad; + mutable ProgramData shdata; + const Mesh &quad; public: - AmbientOcclusion(unsigned, unsigned, float); + AmbientOcclusion(unsigned, unsigned, float = 1.0f); +private: + static float random(unsigned &); + +public: + void set_n_samples(unsigned); + void set_occlusion_radius(float); + + // Deprecated void set_depth_ratio(float); + void set_darkness(float); - virtual void render(const Texture2D &, const Texture2D &); + virtual void render(Renderer &, const Texture2D &, const Texture2D &); }; } // namespace GL