X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/490bc59fbd4777f1a5041a71c1de7c5e76ff1eae..684910d920f90134ade6dd3b944a749336a47029:/lib/gdi/grc.h diff --git a/lib/gdi/grc.h b/lib/gdi/grc.h index 3231aab3..3b8201ad 100644 --- a/lib/gdi/grc.h +++ b/lib/gdi/grc.h @@ -7,6 +7,10 @@ gPixmap aufsetzt (und damit unbeschleunigt ist). */ +// for debugging use: +//#define SYNC_PAINT +#undef SYNC_PAINT + #include #include #include @@ -18,6 +22,7 @@ #include #include #include +#include class eTextPara; @@ -54,7 +59,11 @@ struct gOpcode flip, notify, - shutdown + enableSpinner, disableSpinner, incrementSpinner, + + shutdown, + + setCompositing, } opcode; gDC *dc; @@ -73,7 +82,7 @@ struct gOpcode struct prenderText { eRect area; - std::string text; + char *text; int flags; } *renderText; @@ -96,8 +105,8 @@ struct gOpcode struct pblit { gPixmap *pixmap; - ePoint position; int flags; + eRect position; eRect clip; } *blit; @@ -131,16 +140,17 @@ struct gOpcode ePoint value; int rel; } *setOffset; + + gCompositingData *setCompositing; } parm; }; -#define MAXSIZE 1024 +#define MAXSIZE 2048 /* gRC is the singleton which controls the fifo and dispatches commands */ class gRC: public iObject, public Object { -DECLARE_REF(gRC); -private: + DECLARE_REF(gRC); friend class gPainter; static gRC *instance; @@ -157,6 +167,16 @@ private: eFixedMessagePump m_notify_pump; void recv_notify(const int &i); + + ePtr m_spinner_dc; + int m_spinner_enabled; + + void enableSpinner(); + void disableSpinner(); + + ePtr m_compositing; + + int m_prev_idle_count; public: gRC(); virtual ~gRC(); @@ -164,7 +184,9 @@ public: void submit(const gOpcode &o); Signal0 notify; - + + void setSpinnerDC(gDC *dc) { m_spinner_dc = dc; } + static gRC *getInstance(); }; @@ -181,7 +203,7 @@ class gPainter public: gPainter(gDC *dc, eRect rect=eRect()); virtual ~gPainter(); - + void setBackgroundColor(const gColor &color); void setForegroundColor(const gColor &color); @@ -215,10 +237,13 @@ public: enum { - BT_ALPHATEST = 1 + BT_ALPHATEST = 1, + BT_ALPHABLEND = 2, + BT_SCALE = 4 /* will be automatically set by blitScale */ }; - void blit(gPixmap *pixmap, ePoint pos, const eRect &what=eRect(), int flags=0); + void blit(gPixmap *pixmap, ePoint pos, const eRect &clip=eRect(), int flags=0); + void blitScale(gPixmap *pixmap, const eRect &pos, const eRect &clip=eRect(), int flags=0, int aflags = BT_SCALE); void setPalette(gRGB *colors, int start=0, int len=256); void setPalette(gPixmap *source); @@ -234,26 +259,32 @@ public: void clip(const gRegion &clip); void clippop(); - void flush(); - void waitVSync(); void flip(); void notify(); + void setCompositing(gCompositingData *comp); + + void flush(); }; class gDC: public iObject { -DECLARE_REF(gDC); + DECLARE_REF(gDC); protected: ePtr m_pixmap; gColor m_foreground_color, m_background_color; + gRGB m_foreground_color_rgb, m_background_color_rgb; ePtr m_current_font; ePoint m_current_offset; std::stack m_clip_stack; gRegion m_current_clip; + ePtr m_spinner_saved, m_spinner_temp; + ePtr *m_spinner_pic; + eRect m_spinner_pos; + int m_spinner_num, m_spinner_i; public: virtual void exec(gOpcode *opcode); gDC(gPixmap *pixmap); @@ -263,6 +294,12 @@ public: int getPixmap(ePtr &pm) { pm = m_pixmap; return 0; } gRGB getRGB(gColor col); virtual eSize size() { return m_pixmap->size(); } + virtual int islocked() { return 0; } + + void enableSpinner(); + void disableSpinner(); + void incrementSpinner(); + void setSpinner(eRect pos, ePtr *pic, int len); }; #endif