X-Git-Url: http://code.vuplus.com/gitweb/?p=vuplus_dvbapp;a=blobdiff_plain;f=lib%2Fgdi%2Fgrc.h;h=16f7db7e4080d18d37e56781f51b3d16fdde70a8;hp=8de5dadf3fb935eb37587e199bf1adf3044ea262;hb=2872929ce24198202fa096d28ab94dea9f925450;hpb=ab5aa90e1e05a89845c6e802ef1b2366d203aa45 diff --git a/lib/gdi/grc.h b/lib/gdi/grc.h index 8de5dad..16f7db7 100644 --- a/lib/gdi/grc.h +++ b/lib/gdi/grc.h @@ -7,17 +7,22 @@ gPixmap aufsetzt (und damit unbeschleunigt ist). */ +// for debugging use: +//#define SYNC_PAINT +#undef SYNC_PAINT + #include #include #include #include -#include #include +#include #include #include #include #include +#include class eTextPara; @@ -41,13 +46,29 @@ struct gOpcode setBackgroundColor, setForegroundColor, + setBackgroundColorRGB, + setForegroundColorRGB, + setOffset, setClip, addClip, popClip, flush, - end,shutdown + waitVSync, + flip, + notify, + + enableSpinner, disableSpinner, incrementSpinner, + + shutdown, + + setCompositing, + sendShow, + sendHide, +#ifdef USE_LIBVUGLES2 + setView, +#endif } opcode; gDC *dc; @@ -66,7 +87,7 @@ struct gOpcode struct prenderText { eRect area; - std::string text; + char *text; int flags; } *renderText; @@ -89,8 +110,8 @@ struct gOpcode struct pblit { gPixmap *pixmap; - ePoint position; int flags; + eRect position; eRect clip; } *blit; @@ -114,48 +135,75 @@ struct gOpcode gColor color; } *setColor; + struct psetColorRGB + { + gRGB color; + } *setColorRGB; + struct psetOffset { ePoint value; int rel; } *setOffset; - } parm; + + gCompositingData *setCompositing; - int flags; + struct psetShowHideInfo + { + ePoint point; + eSize size; + } *setShowHideInfo; +#ifdef USE_LIBVUGLES2 + struct psetViewInfo + { + eSize size; + } *setViewInfo; +#endif + } parm; }; +#define MAXSIZE 2048 + /* gRC is the singleton which controls the fifo and dispatches commands */ -class gRC: public iObject +class gRC: public iObject, public Object { -DECLARE_REF(gRC); -private: + DECLARE_REF(gRC); + 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(); + + ePtr m_compositing; + + int m_prev_idle_count; 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(); }; @@ -172,10 +220,13 @@ class gPainter public: gPainter(gDC *dc, eRect rect=eRect()); virtual ~gPainter(); - + 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 @@ -200,10 +251,19 @@ public: void fill(const gRegion &area); void clear(); - - void blit(gPixmap *pixmap, ePoint pos, const eRect &what=eRect(), int flags=0); + + enum + { + BT_ALPHATEST = 1, + BT_ALPHABLEND = 2, + BT_SCALE = 4 /* will be automatically set by blitScale */ + }; + + 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); void mergePalette(gPixmap *target); void line(ePoint start, ePoint end); @@ -216,31 +276,52 @@ public: void clip(const gRegion &clip); void clippop(); + void waitVSync(); + void flip(); + void notify(); + void setCompositing(gCompositingData *comp); + void flush(); + void sendShow(ePoint point, eSize size); + void sendHide(ePoint point, eSize size); +#ifdef USE_LIBVUGLES2 + void setView(eSize size); +#endif }; 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); + virtual void exec(const gOpcode *opcode); gDC(gPixmap *pixmap); gDC(); virtual ~gDC(); 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(); } + virtual int islocked() { return 0; } + + virtual void enableSpinner(); + virtual void disableSpinner(); + virtual void incrementSpinner(); + virtual void setSpinner(eRect pos, ePtr *pic, int len); }; #endif