From 8f4884436faf92253e6ac1a43bd6596dc2e31c70 Mon Sep 17 00:00:00 2001 From: Martin Schirrmacher Date: Sat, 16 Nov 2013 20:29:31 +0100 Subject: add menu items symbols, lent code from skinElchi --- displaymenu.c | 118 +++++++++++++++++++++++++++++++++++++++++++++++++++++++--- displaymenu.h | 4 ++ 2 files changed, 117 insertions(+), 5 deletions(-) diff --git a/displaymenu.c b/displaymenu.c index 89fad873..0af751f0 100644 --- a/displaymenu.c +++ b/displaymenu.c @@ -1,5 +1,20 @@ #include "displaymenu.h" +#include "symbols/720/Bvpssml.xpm" +#include "symbols/1080/Cnew.xpm" +#include "symbols/1080/Carrowturn.xpm" +#include "symbols/1080/Crec.xpm" +#include "symbols/1080/Cclock.xpm" +#include "symbols/1080/Cclocksml.xpm" +#include "symbols/1080/Cvpssml.xpm" + +cBitmap cFlatDisplayMenu::bmCNew(Cnew_xpm); +cBitmap cFlatDisplayMenu::bmCArrowTurn(Carrowturn_xpm); +cBitmap cFlatDisplayMenu::bmCRec(Crec_xpm); +cBitmap cFlatDisplayMenu::bmCClock(Cclock_xpm); +cBitmap cFlatDisplayMenu::bmCClocksml(Cclocksml_xpm); +cBitmap cFlatDisplayMenu::bmCVPS(Bvpssml_xpm); + cFlatDisplayMenu::cFlatDisplayMenu(void) { CreateFullOsd(); TopBarCreate(); @@ -36,6 +51,13 @@ cFlatDisplayMenu::cFlatDisplayMenu(void) { scrollbarPixmap->Fill(clrTransparent); menuCategory = mcUndefined; + + bmNew = &bmCNew; + bmRec = &bmCRec; + bmArrowTurn = &bmCArrowTurn; + bmClock = &bmCClock; + bmClocksml = &bmCClocksml; + bmVPS = &bmCVPS; } cFlatDisplayMenu::~cFlatDisplayMenu() { @@ -172,13 +194,99 @@ void cFlatDisplayMenu::SetItem(const char *Text, int Index, bool Current, bool S ColorBg = Theme.Color(clrItemBg); } } - - for (int i = 0; i < MaxTabs; i++) - { + menuPixmap->DrawRectangle(cRect(Config.decorBorderMenuItemSize, y, Width, fontHeight), ColorBg); + int lh = fontHeight; + int x1 = 0; + int xOff = x1; + for (int i = 0; i < MaxTabs; i++) { const char *s = GetTabbedText(Text, i); - if (s) { + if( s ) { + // from skinelchi + char buffer[9]; + bool istimer = false; + bool isnewrecording = false; + bool hasEventtimer = false; + bool haspartEventtimer = false; + bool isRecording = false; + bool hasVPS = false; + bool isRunning = false; + int xt = Tab(i); - if( CheckProgressBar( s ) ) { + + if( true ) { + // check if timer info symbols: " !#>" + if (i == 0 && strlen(s) == 1 && strchr(" !#>", s[0])) { + istimer = true; // update status + } else if ( (strlen(s) == 6 && s[5] == '*' && s[2] == ':' && isdigit(*s) + && isdigit(*(s + 1)) && isdigit(*(s + 3)) && isdigit(*(s + 4))) + || (strlen(s) == 5 && s[4] == '*' && s[1] == ':' && isdigit(*s) + && isdigit(*(s + 2)) && isdigit(*(s + 3))) + || (strlen(s) == 9 && s[8] == '*' && s[5] == '.' && s[2] == '.' + && isdigit(*s) && isdigit(*(s + 1)) && isdigit(*(s + 3)) + && isdigit(*(s + 4)) && isdigit(*(s + 6)) && isdigit(*(s + 7)))) { + // check if new recording: "10:10*", "1:10*", "01.01.06*" + + isnewrecording = true; // update status + strncpy(buffer, s, strlen(s)); // make a copy + buffer[strlen(s) - 1] = '\0'; // remove the '*' character + } else if ( (strlen(s) == 3) && ( i == 2 || i == 3 || i == 4) ) { + if (s[0] == 'R') isRecording = true; + if (s[0] == 'T') hasEventtimer = true; + if (s[0] == 't') haspartEventtimer = true; + if (s[1] == 'V') hasVPS = true; + if (s[2] == '*') isRunning = true; + } else if ( (strlen(s) == 4) && ( i == 3 ) ) { //epgsearch What's on now default + if (s[1] == 'R') isRecording = true; + if (s[1] == 'T') hasEventtimer = true; + if (s[1] == 't') haspartEventtimer = true; + if (s[2] == 'V') hasVPS = true; + if (s[3] == '*') isRunning = true; + } + } + xOff = x1 + Tab(i) + Config.decorBorderMenuItemSize; + if( istimer ) { + // timer menu + switch( s[0] ) { + case '!': + menuPixmap->DrawBitmap(cPoint(xOff, y + (lh - bmArrowTurn->Height()) / 2), *bmArrowTurn, ColorFg, ColorBg); + break; + case '#': + menuPixmap->DrawBitmap(cPoint(xOff, y + (lh - bmRec->Height()) / 2), *bmRec, ColorFg, ColorBg); + break; + case '>': + menuPixmap->DrawBitmap(cPoint(xOff, y + (lh - bmClock->Height()) / 2), *bmClock, ColorFg, ColorBg); + break; + case ' ': + default: + break; + } + } else if (isRecording || hasEventtimer || haspartEventtimer || hasVPS || isRunning) { + // program schedule menu + if (isRecording) + menuPixmap->DrawBitmap(cPoint(xOff, y + (lh - bmRec->Height()) / 2), *bmRec, ColorFg, ColorBg); + else { + if (hasEventtimer) + menuPixmap->DrawBitmap(cPoint(xOff, y + (lh - bmClock->Height()) / 2), *bmClock, ColorFg, ColorBg); + if (haspartEventtimer) + menuPixmap->DrawBitmap(cPoint(xOff + (bmClock->Height() - bmClocksml->Height()) / 2, y + (lh - bmClocksml->Height()) / 2), *bmClocksml, ColorFg, ColorBg); + } + xOff += bmClock->Width(); // clock is wider than rec + + if (hasVPS) + menuPixmap->DrawBitmap(cPoint(xOff, y + (lh - bmVPS->Height()) / 2), *bmVPS, ColorFg, ColorBg); + xOff += bmVPS->Width(); + + if( isRunning ) + menuPixmap->DrawText(cPoint(xOff, y), "*", ColorFg, ColorBg, font, xOff); + + } else if (isnewrecording) { + // recordings menu + menuPixmap->DrawText(cPoint(xOff, y), buffer, ColorFg, ColorBg, font, xOff); + + // draw symbol "new" centered + int gap = std::max(0, (Tab(i+1)-Tab(i)- font->Width(buffer) - bmNew->Width()) / 2); + menuPixmap->DrawBitmap(cPoint(xOff + font->Width(buffer) + gap, y + (lh - bmNew->Height()) / 2), *bmNew, ColorFg, ColorBg); + } else if( CheckProgressBar( s ) ) { int colWidth = Tab(i+1) - Tab(i); tColor ColorFg = Config.decorProgressMenuItemFg; diff --git a/displaymenu.h b/displaymenu.h index c6a9e1e7..60fa9dbc 100644 --- a/displaymenu.h +++ b/displaymenu.h @@ -36,6 +36,10 @@ class cFlatDisplayMenu : public cFlatBaseRender, public cSkinDisplayMenu { int ItemsHeight(void); bool CheckProgressBar(const char *text); void DrawProgressBarFromText(int Top, int Left, int Width, const char *bar, tColor ColorFg, tColor ColorBarFg, tColor ColorBg); + + cBitmap *bmNew, *bmRec, *bmArrowTurn, *bmClock, *bmClocksml, *bmVPS; + static cBitmap bmCNew, bmCRec, bmCArrowTurn, bmCClock, bmCClocksml, bmCHD, bmCVPS; + public: cFlatDisplayMenu(void); virtual ~cFlatDisplayMenu(); -- cgit v1.2.3