X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/c5f61282a2391235e05ff40bc40a2f0852ea1a9f..1c242c0a654a5c4048ba4219a0982f8ba8a85246:/lib/gdi/grc.h diff --git a/lib/gdi/grc.h b/lib/gdi/grc.h index e277db34..478ca46c 100644 --- a/lib/gdi/grc.h +++ b/lib/gdi/grc.h @@ -7,12 +7,15 @@ gPixmap aufsetzt (und damit unbeschleunigt ist). */ +// for debugging use: +//#define SYNC_PAINT +#undef SYNC_PAINT + #include #include #include #include -#include #include #include #include @@ -55,7 +58,9 @@ struct gOpcode flip, notify, - end,shutdown + enableSpinner, disableSpinner, incrementSpinner, + + shutdown } opcode; gDC *dc; @@ -74,7 +79,7 @@ struct gOpcode struct prenderText { eRect area; - std::string text; + char *text; int flags; } *renderText; @@ -135,6 +140,8 @@ struct gOpcode } parm; }; +#define MAXSIZE 2048 + /* gRC is the singleton which controls the fifo and dispatches commands */ class gRC: public iObject, public Object { @@ -142,37 +149,37 @@ DECLARE_REF(gRC); private: friend class gPainter; static gRC *instance; - + +#ifndef SYNC_PAINT static void *thread_wrapper(void *ptr); pthread_t the_thread; + pthread_mutex_t mutex; + pthread_cond_t cond; +#endif void *thread(); - queueRingBuffer queue; - + gOpcode queue[MAXSIZE]; + int rp, wp; + eFixedMessagePump m_notify_pump; void recv_notify(const int &i); + + ePtr m_spinner_dc; + int m_spinner_enabled; + + void enableSpinner(); + void disableSpinner(); + public: - eLock queuelock; gRC(); virtual ~gRC(); - void submit(const gOpcode &o) - { - static int collected=0; - queue.enqueue(o); - collected++; -// if (o.opcode==gOpcode::end||o.opcode==gOpcode::shutdown) - { - queuelock.unlock(collected); -#ifdef SYNC_PAINT - thread(); -#endif - collected=0; - } - } + void submit(const gOpcode &o); Signal0 notify; - + + void setSpinnerDC(gDC *dc) { m_spinner_dc = dc; } + static gRC *getInstance(); }; @@ -189,7 +196,7 @@ class gPainter public: gPainter(gDC *dc, eRect rect=eRect()); virtual ~gPainter(); - + void setBackgroundColor(const gColor &color); void setForegroundColor(const gColor &color); @@ -223,7 +230,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); @@ -242,8 +250,6 @@ public: void clip(const gRegion &clip); void clippop(); - void flush(); - void waitVSync(); void flip(); void notify(); @@ -256,12 +262,17 @@ 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); @@ -271,6 +282,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