X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fview.h;h=6aca12f1a117ab3d3c0f14ffdfb565075d289d0b;hp=93eb49d7d64c82d8223a21c406bea9aaf49675f4;hb=6b0a93110454cc8d84d0d9b9b29fe9d0ecbaa4d5;hpb=9759cae2abf138acc548e3f230967e2c843e967e diff --git a/source/view.h b/source/view.h index 93eb49d7..6aca12f1 100644 --- a/source/view.h +++ b/source/view.h @@ -2,38 +2,40 @@ #define MSP_GL_VIEW_H_ #include -#include -#include +#include "framebuffer.h" namespace Msp { namespace GL { class Camera; -class Framebuffer; class Renderable; /** Manages the presentation of rendering results on the screen. */ -class View +class View: public sigc::trackable { -private: - Graphics::Window &window; - Graphics::GLContext &context; +protected: Framebuffer ⌖ - const Renderable *content; + Camera *camera; + Renderable *content; std::list synced_cameras; + View(); + public: - View(Graphics::Window &, Graphics::GLContext &); + virtual unsigned get_width() const { return target.get_width(); } + virtual unsigned get_height() const { return target.get_height(); } + float get_aspect_ratio() const { return static_cast(get_width())/get_height(); } - void set_content(const Renderable *); - void synchronize_camera_aspect(Camera &); + void set_camera(Camera *); + void set_content(Renderable *); - void render(); + // Deprecated + float get_aspect() const { return get_aspect_ratio(); } + void synchronize_camera_aspect(Camera &); -private: - void window_resized(unsigned, unsigned); + virtual void render(); }; } // namespace GL