X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/8ade23537a682d4b0c9709d533b25702bde2ee23..c4a14f843f363645e85bda24d03d68c6afcda9fa:/lib/gdi/grc.h diff --git a/lib/gdi/grc.h b/lib/gdi/grc.h index 5eb81314..53bf7f09 100644 --- a/lib/gdi/grc.h +++ b/lib/gdi/grc.h @@ -17,6 +17,7 @@ #include #include #include +#include class eTextPara; @@ -40,10 +41,15 @@ struct gOpcode setBackgroundColor, setForegroundColor, + setBackgroundColorRGB, + setForegroundColorRGB, + setOffset, setClip, addClip, popClip, + flush, + end,shutdown } opcode; @@ -111,6 +117,11 @@ struct gOpcode gColor color; } *setColor; + struct psetColorRGB + { + gRGB color; + } *setColorRGB; + struct psetOffset { ePoint value; @@ -124,7 +135,7 @@ struct gOpcode /* gRC is the singleton which controls the fifo and dispatches commands */ class gRC: public iObject { -DECLARE_REF; +DECLARE_REF(gRC); private: static gRC *instance; @@ -173,15 +184,24 @@ public: void setBackgroundColor(const gColor &color); void setForegroundColor(const gColor &color); + void setBackgroundColor(const gRGB &color); + void setForegroundColor(const gRGB &color); + void setFont(gFont *font); /* flags only THESE: */ enum { // todo, make mask. you cannot align both right AND center AND block ;) + RT_HALIGN_LEFT = 0, /* default */ RT_HALIGN_RIGHT = 1, RT_HALIGN_CENTER = 2, RT_HALIGN_BLOCK = 4, - RT_VALIGN_CENTER = 8 + + RT_VALIGN_TOP = 0, /* default */ + RT_VALIGN_CENTER = 8, + RT_VALIGN_BOTTOM = 16, + + RT_WRAP = 32 }; void renderText(const eRect &position, const std::string &string, int flags=0); @@ -195,6 +215,7 @@ public: void blit(gPixmap *pixmap, ePoint pos, const eRect &what=eRect(), int flags=0); void setPalette(gRGB *colors, int start=0, int len=256); + void setPalette(gPixmap *source); void mergePalette(gPixmap *target); void line(ePoint start, ePoint end); @@ -212,7 +233,7 @@ public: class gDC: public iObject { -DECLARE_REF; +DECLARE_REF(gDC); protected: ePtr m_pixmap; @@ -231,7 +252,7 @@ public: gRegion &getClip() { return m_current_clip; } int getPixmap(ePtr &pm) { pm = m_pixmap; return 0; } gRGB getRGB(gColor col); - virtual eSize getSize() { return m_pixmap->getSize(); } + virtual eSize size() { return m_pixmap->size(); } }; #endif