X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Feffects%2Fshadowmap.cpp;h=bcdb0c9f39ef6ec24ac5ac3121f8a8b3bd0be64b;hb=6353307898cd397e2bcde13e2448a8a678a60004;hp=a6d431bc200da86e025dcc2b640aa9d2a342d0e0;hpb=1863f17c5c5563be8492d7f01e5c613a740ea1e9;p=libs%2Fgl.git diff --git a/source/effects/shadowmap.cpp b/source/effects/shadowmap.cpp index a6d431bc..bcdb0c9f 100644 --- a/source/effects/shadowmap.cpp +++ b/source/effects/shadowmap.cpp @@ -6,7 +6,6 @@ #include "resources.h" #include "scene.h" #include "shadowmap.h" -#include "tests.h" using namespace std; @@ -39,8 +38,11 @@ void ShadowMap::init(unsigned s) 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; set_darkness(1.0f); shdata.uniform("shd_world_matrix", Matrix()); @@ -91,12 +93,11 @@ void ShadowMap::setup_frame(Renderer &renderer) shdata.uniform("shd_world_matrix", shadow_matrix); - BindRestore bind_fbo(fbo); - Bind bind_depth(DepthTest::lequal()); - 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); renderer.render(shadow_caster); }