X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Feffects%2Fshadowmap.cpp;h=f688a6e3a7d4e858c23cf5126908475545bbe712;hb=91d87a3ecae2b21a87829442d82e65f071009e92;hp=cf73e810070581d8c03c6e5f3c61391d127d1551;hpb=2b2676392aff2eb6b38c3e463cc67f4d67a4ef8b;p=libs%2Fgl.git diff --git a/source/effects/shadowmap.cpp b/source/effects/shadowmap.cpp index cf73e810..f688a6e3 100644 --- a/source/effects/shadowmap.cpp +++ b/source/effects/shadowmap.cpp @@ -14,32 +14,17 @@ namespace GL { ShadowMap::ShadowMap(unsigned s, Renderable &r, const Light &l, Renderable &c): Effect(r), + size(s), light(l), shadow_caster(c), - sampler(Resources::get_global().get("_linear_clamp_shadow.samp")) + sampler(Resources::get_global().get("_linear_clamp_shadow.samp")), + radius(1), + depth_bias(4), + rendered(false) { - init(s); -} - -ShadowMap::ShadowMap(unsigned s, Renderable &r, const Light &l): - Effect(r), - light(l), - shadow_caster(r), - sampler(Resources::get_global().get("_linear_clamp_shadow.samp")) -{ - init(s); -} - -void ShadowMap::init(unsigned s) -{ - size = s; - radius = 1; - depth_bias = 4; - rendered = false; - depth_buf.storage(DEPTH_COMPONENT32F, size, size, 1); + fbo.set_format((DEPTH_ATTACHMENT,DEPTH_COMPONENT32F)); fbo.attach(DEPTH_ATTACHMENT, depth_buf, 0); - fbo.require_complete(); depth_test.enabled = true; depth_test.compare = LEQUAL; @@ -93,10 +78,9 @@ void ShadowMap::setup_frame(Renderer &renderer) shdata.uniform("shd_world_matrix", shadow_matrix); - BindRestore bind_fbo(fbo); - fbo.clear(DEPTH_BUFFER_BIT); - Renderer::Push push(renderer); + renderer.set_framebuffer(&fbo); + renderer.clear(DEPTH_BUFFER_BIT); renderer.set_camera(shadow_camera); renderer.set_depth_test(&depth_test);