X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/6047456faa97f18ca8b6ea7bfbb2ac1856765580..d04e6435efecf42a192a4f6c71dca9a1a053d5fb:/lib/service/listboxservice.h diff --git a/lib/service/listboxservice.h b/lib/service/listboxservice.h index d64805c5..589afba6 100644 --- a/lib/service/listboxservice.h +++ b/lib/service/listboxservice.h @@ -1,9 +1,9 @@ #ifndef __lib_service_listboxservice_h #define __lib_service_listboxservice_h +#include #include #include - #include class eListboxServiceContent: public virtual iListboxContent @@ -11,9 +11,19 @@ class eListboxServiceContent: public virtual iListboxContent DECLARE_REF(eListboxServiceContent); public: eListboxServiceContent(); - void setRoot(const eServiceReference &ref); - void getCurrent(eServiceReference &ref); + void addService(const eServiceReference &ref, bool beforeCurrent=false); + void removeCurrent(); + void FillFinished(); + + void setIgnoreService( const eServiceReference &service ); + void setRoot(const eServiceReference &ref, bool justSet=false); + void getCurrent(eServiceReference &ref); + + int getNextBeginningWithChar(char c); + int getPrevMarkerPos(); + int getNextMarkerPos(); + /* support for marked services */ void initMarked(); void addMarked(const eServiceReference &ref); @@ -25,7 +35,8 @@ public: int markedQueryNext(eServiceReference &ref); int lookupService(const eServiceReference &ref); - + void setCurrent(const eServiceReference &ref); + enum { visModeSimple, visModeComplex @@ -35,20 +46,56 @@ public: /* only in complex mode: */ enum { - celServiceName, celServiceNumber, - celIcon, + celMarkerPixmap, + celFolderPixmap, + celServiceEventProgressbar, + celServiceName, + celServiceTypePixmap, celServiceInfo, // "now" event celElements }; - + + enum { + picDVB_S, + picDVB_T, + picDVB_C, + picServiceGroup, + picFolder, + picMarker, + picServiceEventProgressbar, + picElements + }; + void setElementPosition(int element, eRect where); void setElementFont(int element, gFont *font); + void setPixmap(int type, ePtr &pic); void sort(); int setCurrentMarked(bool); + void setNumberOffset(int offset) { m_numberoffset = offset; } + + int getItemHeight() { return m_itemheight; } + void setItemHeight(int height); + + enum { + markedForeground, + markedForegroundSelected, + markedBackground, + markedBackgroundSelected, + serviceNotAvail, + serviceEventProgressbarColor, + serviceEventProgressbarColorSelected, + serviceEventProgressbarBorderColor, + serviceEventProgressbarBorderColorSelected, + serviceDescriptionColor, + serviceDescriptionColorSelected, + colorElements + }; + + void setColor(int color, gRGB &col); protected: void cursorHome(); void cursorEnd(); @@ -71,6 +118,9 @@ protected: /* for complex mode */ eRect m_element_position[celElements]; ePtr m_element_font[celElements]; + ePtr m_pixmaps[picElements]; + gRGB m_color[colorElements]; + bool m_color_set[colorElements]; private: typedef std::list list; @@ -82,6 +132,7 @@ private: eSize m_itemsize; ePtr m_service_center; + ePtr m_lst; eServiceReference m_root; @@ -91,7 +142,12 @@ private: /* support for movemode */ bool m_current_marked; - list::iterator m_swap; + + int m_numberoffset; + + eServiceReference m_is_playable_ignore; + + int m_itemheight; }; #endif