X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fview.cpp;h=d0d3542835448352f66be17d6f15f4735253c263;hb=9be04243c92f024327e74ad8d48861581d83b7ed;hp=7ab41912ef19d1be6251e279725a9fbfa7830bbe;hpb=e598e9d8dacad73b7ee1688e2be738e94b07b9fa;p=libs%2Fgl.git diff --git a/source/view.cpp b/source/view.cpp index 7ab41912..d0d35428 100644 --- a/source/view.cpp +++ b/source/view.cpp @@ -9,9 +9,15 @@ namespace GL { 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,22 +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) { Bind bind_fbo(target); - target.clear(COLOR_BUFFER_BIT|DEPTH_BUFFER_BIT); + 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(); } }