X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/aa052184a12e61d01983f8c9047183e6b0d499f3..544e1af49c6c1c25a3ef97b27ac3e6764a008824:/lib/gdi/grc.h diff --git a/lib/gdi/grc.h b/lib/gdi/grc.h index fb9e2ea1..7071425e 100644 --- a/lib/gdi/grc.h +++ b/lib/gdi/grc.h @@ -58,6 +58,8 @@ struct gOpcode flip, notify, + enableSpinner, disableSpinner, incrementSpinner, + shutdown } opcode; @@ -143,8 +145,7 @@ struct gOpcode /* 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; @@ -161,6 +162,13 @@ private: eFixedMessagePump m_notify_pump; void recv_notify(const int &i); + + ePtr m_spinner_dc; + int m_spinner_enabled; + + void enableSpinner(); + void disableSpinner(); + public: gRC(); virtual ~gRC(); @@ -168,7 +176,9 @@ public: void submit(const gOpcode &o); Signal0 notify; - + + void setSpinnerDC(gDC *dc) { m_spinner_dc = dc; } + static gRC *getInstance(); }; @@ -219,7 +229,8 @@ public: enum { - BT_ALPHATEST = 1 + BT_ALPHATEST = 1, + BT_ALPHABLEND = 2 }; void blit(gPixmap *pixmap, ePoint pos, const eRect &what=eRect(), int flags=0); @@ -238,8 +249,6 @@ public: void clip(const gRegion &clip); void clippop(); - void flush(); - void waitVSync(); void flip(); void notify(); @@ -247,7 +256,7 @@ public: class gDC: public iObject { -DECLARE_REF(gDC); + DECLARE_REF(gDC); protected: ePtr m_pixmap; @@ -259,6 +268,10 @@ protected: 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); @@ -269,6 +282,11 @@ public: 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