X-Git-Url: https://git.brokenzipper.com/gitweb?a=blobdiff_plain;f=otk%2Ftruerendercontrol.hh;h=e0a0b31bc8fe75d45fc80280430914093dc85237;hb=58847af218e486f5c1a34ffe947a961a74f97c0a;hp=574b5272c8accd90698c29062d489d88f6c5ada5;hpb=e6d6a1b6b59d53f9d149f034274b205844eacf1e;p=chaz%2Fopenbox diff --git a/otk/truerendercontrol.hh b/otk/truerendercontrol.hh index 574b5272..e0a0b31b 100644 --- a/otk/truerendercontrol.hh +++ b/otk/truerendercontrol.hh @@ -4,20 +4,48 @@ #include "rendercontrol.hh" +#include + namespace otk { +#ifdef WORDS_BIGENDIAN +const int default_red_shift=0; +const int default_green_shift=8; +const int default_blue_shift=16; +const int endian=MSBFirst; +#else +const int default_red_shift=16; +const int default_green_shift=8; +const int default_blue_shift=0; +const int endian=LSBFirst; +#endif /* WORDS_BIGENDIAN */ + class TrueRenderControl : public RenderControl { private: + // the number of bits to shift a color value (from 0-255) to the right, to + // fit it into the the color mask (do this before the offset) + int _red_shift; + int _green_shift; + int _blue_shift; + // the offset of each color in a color mask int _red_offset; int _green_offset; int _blue_offset; + inline void highlight(pixel32 *x, pixel32 *y, bool raised) const; + void reduceDepth(Surface &sf, XImage *im) const; + void verticalGradient(Surface &sf, const RenderTexture &texture) const; + void diagonalGradient(Surface &sf, const RenderTexture &texture) const; + void crossDiagonalGradient(Surface &sf, const RenderTexture &texture) const; + virtual void drawGradientBackground(Surface &sf, + const RenderTexture &texture) const; + public: - TrueRenderControl(const ScreenInfo *screen); + TrueRenderControl(int screen); virtual ~TrueRenderControl(); - virtual void render(Widget *wi); + virtual void drawBackground(Surface& sf, const RenderTexture &texture) const; }; }