X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fview.cpp;h=d0d3542835448352f66be17d6f15f4735253c263;hp=074967cfe1e3b14cafb925e0902e9e9cf11500b0;hb=bec07999d95b76f4b47cffcc564d0cd0afc0435e;hpb=7cf5ebbc9d91d09d0664598d3fb88606c3307deb diff --git a/source/view.cpp b/source/view.cpp index 074967cf..d0d35428 100644 --- a/source/view.cpp +++ b/source/view.cpp @@ -6,12 +6,18 @@ namespace Msp { namespace GL { -View::View(): - target(Framebuffer::system()), +View::View(Framebuffer &t): + target(t), camera(0), - content(0) + content(0), + internal_renderer(0) { } +View::~View() +{ + delete internal_renderer; +} + void View::set_camera(Camera *c) { camera = c; @@ -24,21 +30,26 @@ void View::set_content(Renderable *r) content = r; } -void View::synchronize_camera_aspect(Camera &c) +void View::render() { - synced_cameras.push_back(&c); - c.set_aspect_ratio(get_aspect_ratio()); + if(!internal_renderer) + internal_renderer = new Renderer; + render(*internal_renderer); } -void View::render() +void View::render(Renderer &renderer) { - target.clear(COLOR_BUFFER_BIT|DEPTH_BUFFER_BIT); + Bind bind_fbo(target); + target.clear(); if(content) { - Renderer renderer(camera); + Renderer::Push push(renderer); + if(camera) + renderer.set_camera(*camera); content->setup_frame(renderer); content->render(renderer); content->finish_frame(); + renderer.flush_shader_data(); } }