X-Git-Url: https://git.brokenzipper.com/gitweb?a=blobdiff_plain;f=otk%2Frendercontrol.hh;h=781c32d47a991b4cf50472a53a4d79655c02eec8;hb=cc050a4ec8b893c4f9958f83bd27dfae5132e77d;hp=14c0e92c97afb0d165400e4632da4c38725917a9;hpb=9f705c02b9c412c053fc12a2ebdc5cebe83400c8;p=chaz%2Fopenbox diff --git a/otk/rendercontrol.hh b/otk/rendercontrol.hh index 14c0e92c..781c32d4 100644 --- a/otk/rendercontrol.hh +++ b/otk/rendercontrol.hh @@ -11,21 +11,23 @@ namespace otk { class ScreenInfo; class Surface; +class RenderTexture; +class Font; +class RenderColor; +class ustring; class RenderControl { protected: - const ScreenInfo *_screen; - - int _red_bits; - int _green_bits; - int _blue_bits; + int _screen; + /* // color tables, meaning, 256 (possibly) different shades of each color, // based on the number of bits there are available for each color in the // visual unsigned char _red_color_table[256]; unsigned char _green_color_table[256]; unsigned char _blue_color_table[256]; + */ /* Bool _dither; @@ -59,14 +61,26 @@ protected: int _ncolors; */ - RenderControl(const ScreenInfo *screen); + RenderControl(int screen); + virtual void drawSolidBackground(Surface& sf, + const RenderTexture& texture) const; + public: virtual ~RenderControl(); static RenderControl *getRenderControl(int screen); - virtual void render(Surface *sf) = 0; + virtual void drawRoot(const RenderColor &color) const; + + //! Draws a string onto a Surface + virtual void drawString(Surface &sf, const Font &font, int x, int y, + const RenderColor &color, + const ustring &string) const; + + //! Draws a background onto a Surface, as specified by a RenderTexture + virtual void drawBackground(Surface &sf, + const RenderTexture &texture) const = 0; }; }