X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;ds=sidebyside;f=source%2Fview.cpp;h=19d583ae19b04d1c2eb0f8348b9469255b15d5cf;hb=c1e297b01f07be122e9909a1ae9c04f0c51dfc21;hp=074967cfe1e3b14cafb925e0902e9e9cf11500b0;hpb=7cf5ebbc9d91d09d0664598d3fb88606c3307deb;p=libs%2Fgl.git diff --git a/source/view.cpp b/source/view.cpp index 074967cf..19d583ae 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,18 +30,22 @@ 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); 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();