X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/1f5b1a20e4de369c197de1dae8fcb368e3e10b26..09047544dbeddd0a5df972934c8863bef9e11a99:/lib/service/listboxservice.h diff --git a/lib/service/listboxservice.h b/lib/service/listboxservice.h index f32e0865..b64e875f 100644 --- a/lib/service/listboxservice.h +++ b/lib/service/listboxservice.h @@ -3,30 +3,39 @@ #include #include - #include -class eServiceCenter; class eListboxServiceContent: public virtual iListboxContent { DECLARE_REF(eListboxServiceContent); public: eListboxServiceContent(); - void setRoot(const 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); void removeMarked(const eServiceReference &ref); int isMarked(const eServiceReference &ref); - + /* this is NOT thread safe! */ void markedQueryStart(); int markedQueryNext(eServiceReference &ref); int lookupService(const eServiceReference &ref); - + void setCurrent(const eServiceReference &ref); + enum { visModeSimple, visModeComplex @@ -36,15 +45,37 @@ public: /* only in complex mode: */ enum { - celServiceName, celServiceNumber, - celIcon, + celMarkerPixmap, + celFolderPixmap, + celServiceName, + celServiceTypePixmap, celServiceInfo, // "now" event celElements }; - + + enum { + picDVB_S, + picDVB_T, + picDVB_C, + picServiceGroup, + picFolder, + picMarker, + 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; } + int setItemHeight(int height); protected: void cursorHome(); @@ -53,7 +84,7 @@ protected: int cursorValid(); int cursorSet(int n); int cursorGet(); - + void cursorSave(); void cursorRestore(); int size(); @@ -68,6 +99,7 @@ protected: /* for complex mode */ eRect m_element_position[celElements]; ePtr m_element_font[celElements]; + ePtr m_pixmaps[picElements]; private: typedef std::list list; @@ -78,14 +110,23 @@ private: int m_size; eSize m_itemsize; - ePtr m_service_center; + ePtr m_service_center; + ePtr m_lst; eServiceReference m_root; - + /* support for marked services */ std::set m_marked; - std::set::const_iterator m_marked_iterator; + + /* support for movemode */ + bool m_current_marked; + + int m_numberoffset; + + eServiceReference m_is_playable_ignore; + + int m_itemheight; }; #endif