X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Frender%2Fview.h;h=b8a116a65e3b80435a4aa4cdae39020dffad6252;hp=9c756bbcdb453c62b1701a8421d3df075c6076f0;hb=016f0f0dd51511f98d0bf398d99199d7dec1543c;hpb=791f266553f0e6c6fc006d96eb9bc2967beb7012 diff --git a/source/render/view.h b/source/render/view.h index 9c756bbc..b8a116a6 100644 --- a/source/render/view.h +++ b/source/render/view.h @@ -1,6 +1,7 @@ #ifndef MSP_GL_VIEW_H_ #define MSP_GL_VIEW_H_ +#include #include "framebuffer.h" namespace Msp { @@ -11,29 +12,38 @@ class Renderable; class Renderer; /** -Manages the presentation of rendering results on the screen. +An ultimate render target, which is typically visible to the user of the +application in some way. + +The content renderable's render() function is called with an empty tag. A +Sequence can be used to specify other tags and add post-processing. */ -class View +class View: public NonCopyable { protected: - Framebuffer ⌖ - Camera *camera; - Renderable *content; - Renderer *internal_renderer; + Camera *camera = 0; + Renderable *content = 0; + Renderer *internal_renderer = 0; - View(Framebuffer &); + View() = default; public: + View(View &&); virtual ~View(); - virtual unsigned get_width() const { return target.get_width(); } - virtual unsigned get_height() const { return target.get_height(); } + virtual unsigned get_width() const { return get_target().get_width(); } + virtual unsigned get_height() const { return get_target().get_height(); } float get_aspect_ratio() const { return static_cast(get_width())/get_height(); } + /** Sets the camera to render with. The camera's aspect ratio is set to + match that of the view. */ void set_camera(Camera *); + void set_content(Renderable *); virtual void render(); virtual void render(Renderer &); +protected: + virtual const Framebuffer &get_target() const = 0; }; } // namespace GL