diff options
| -rw-r--r-- | HISTORY | 2 | ||||
| -rw-r--r-- | config.c | 4 | ||||
| -rw-r--r-- | config.h | 3 | ||||
| -rw-r--r-- | displaychannel.c | 59 | ||||
| -rw-r--r-- | displaymenu.c | 19 | ||||
| -rw-r--r-- | displaymenuview.c | 40 | ||||
| -rw-r--r-- | displaymenuview.h | 2 | ||||
| -rw-r--r-- | displaymessage.c | 10 | ||||
| -rw-r--r-- | displayreplay.c | 25 | ||||
| -rw-r--r-- | displaytracks.c | 18 | ||||
| -rw-r--r-- | displayvolume.c | 10 | ||||
| -rw-r--r-- | menuitem.c | 161 | ||||
| -rw-r--r-- | menuitem.h | 9 | ||||
| -rw-r--r-- | nopacity.c | 8 | ||||
| -rw-r--r-- | po/de_DE.po | 5 | ||||
| -rw-r--r-- | po/it_IT.po | 5 | ||||
| -rw-r--r-- | po/sk_SK.po | 5 | ||||
| -rw-r--r-- | setup.c | 2 | ||||
| -rw-r--r-- | textwindow.c | 5 | ||||
| -rw-r--r-- | themes/nOpacity-darkblue.theme | 2 | ||||
| -rw-r--r-- | themes/nOpacity-darkred.theme | 1 | ||||
| -rw-r--r-- | themes/nOpacity-green.theme | 3 | ||||
| -rw-r--r-- | timers.c | 24 | 
23 files changed, 286 insertions, 136 deletions
| @@ -209,3 +209,5 @@ Version 0.1.2  - Fixed a bug that slow motion trick speed during recording replay was not     displayed  - Added previous and next Channel Group in Channel Display +- Introduced "plain" style without any blending effects configurable by +  dedicated theme color @@ -21,6 +21,7 @@ cNopacityConfig::cNopacityConfig() {      logoExtension = "png";      logoBorder = 15;      backgroundStyle = 0; +    roundedCornersChannel = 1;      displaySignalStrength = 1;      displayPrevNextChannelGroup = 1;      fontChannelHeaderSize = 0; @@ -162,6 +163,8 @@ cNopacityConfig::~cNopacityConfig() {  }  void cNopacityConfig::setDynamicValues() { +esyslog("nopacity: col blending %x, do Blending %x", Theme.Color(clrDoBlending), CLR_BLENDING_ON); +    doBlending = (Theme.Color(clrDoBlending) == CLR_BLENDING_ON)?true:false;      if (fontIndex == 0) {          fontName = strdup(fontDefaultName);      } else { @@ -300,6 +303,7 @@ bool cNopacityConfig::SetupParse(const char *Name, const char *Value) {      else if (strcmp(Name, "logoHeight") == 0)              logoHeight = atoi(Value);      else if (strcmp(Name, "logoBorder") == 0)              logoBorder = atoi(Value);      else if (strcmp(Name, "backgroundStyle") == 0)         backgroundStyle = atoi(Value); +    else if (strcmp(Name, "roundedCornersChannel") == 0)   roundedCornersChannel = atoi(Value);      else if (strcmp(Name, "displaySignalStrength") == 0)   displaySignalStrength = atoi(Value);      else if (strcmp(Name, "displayPrevNextChannelGroup") == 0) displayPrevNextChannelGroup = atoi(Value);      else if (strcmp(Name, "fontChannelHeaderSize") == 0)   fontChannelHeaderSize = atoi(Value); @@ -24,6 +24,8 @@ class cNopacityConfig {          cString epgImagePathDefault;
          void setDynamicValues();
          void loadRssFeeds(void);
 +        //Theme Setting
 +        bool doBlending;
          //Common
          int fontIndex;
          const char *fontDefaultName;
 @@ -44,6 +46,7 @@ class cNopacityConfig {          int logoHeight;
          int logoBorder;
          int backgroundStyle;
 +        int roundedCornersChannel;
          int displaySignalStrength;
          int displayPrevNextChannelGroup;
          int fontChannelHeaderSize;
 diff --git a/displaychannel.c b/displaychannel.c index de8ff1d..77c1488 100644 --- a/displaychannel.c +++ b/displaychannel.c @@ -187,43 +187,52 @@ void cNopacityDisplayChannel::CreateFonts(void) {  }  void cNopacityDisplayChannel::DrawBackground(void){ -     -    DrawBlendedBackground(pixmapBackgroundTop, Theme.Color(clrChannelBackground), Theme.Color(clrChannelBackBlend), true); +    if (config.doBlending) { +        DrawBlendedBackground(pixmapBackgroundTop, Theme.Color(clrChannelBackground), Theme.Color(clrChannelBackBlend), true); +        DrawBlendedBackground(pixmapBackgroundBottom, Theme.Color(clrChannelBackground), Theme.Color(clrChannelBackBlend), false); +    } else { +        pixmapBackgroundTop->Fill(Theme.Color(clrChannelBackground)); +        pixmapBackgroundBottom->Fill(Theme.Color(clrChannelBackground)); +    }      if (withInfo)          pixmapBackgroundMiddle->Fill(Theme.Color(clrChannelBackground)); -    DrawBlendedBackground(pixmapBackgroundBottom, Theme.Color(clrChannelBackground), Theme.Color(clrChannelBackBlend), false);      if ((config.backgroundStyle == bsFull) && withInfo) {          pixmapLogoBackground->Fill(Theme.Color(clrChannelBackground)); -        DrawBlendedBackground(pixmapLogoBackgroundTop, Theme.Color(clrChannelBackground), Theme.Color(clrChannelBackBlend), true); -        DrawBlendedBackground(pixmapLogoBackgroundBottom, Theme.Color(clrChannelBackground), Theme.Color(clrChannelBackBlend), false); +        if (config.doBlending) { +            DrawBlendedBackground(pixmapLogoBackgroundTop, Theme.Color(clrChannelBackground), Theme.Color(clrChannelBackBlend), true); +            DrawBlendedBackground(pixmapLogoBackgroundBottom, Theme.Color(clrChannelBackground), Theme.Color(clrChannelBackBlend), false); +        } else { +            pixmapLogoBackgroundTop->Fill(Theme.Color(clrChannelBackground)); +            pixmapLogoBackgroundBottom->Fill(Theme.Color(clrChannelBackground)); +        }      } else {          pixmapLogoBackgroundTop->Fill(clrTransparent);          pixmapLogoBackground->Fill(clrTransparent);          pixmapLogoBackgroundBottom->Fill(clrTransparent);      } -     -    int cornerTopSize = channelInfoHeight/2; -    int cornerBottomSize = streamInfoHeight/2; -    if ((cornerTopSize > 2)&&(cornerBottomSize > 2)) { -        if ((config.backgroundStyle == bsTrans) || ((config.logoPosition == lpNone))) { -            pixmapBackgroundTop->DrawEllipse(cRect(0, 0, cornerTopSize, cornerTopSize), clrTransparent, -2); -            pixmapBackgroundTop->DrawEllipse(cRect(infoWidth - cornerTopSize, 0, cornerTopSize, cornerTopSize), clrTransparent, -1); -            pixmapBackgroundBottom->DrawEllipse(cRect(0, cornerBottomSize, cornerBottomSize, cornerBottomSize), clrTransparent, -3); -            pixmapBackgroundBottom->DrawEllipse(cRect(infoWidth - cornerBottomSize, cornerBottomSize, cornerBottomSize, cornerBottomSize), clrTransparent, -4); -        } else if ((config.backgroundStyle == bsFull) && (config.logoPosition == lpLeft)){ -            pixmapLogoBackgroundTop->DrawEllipse(cRect(0, 0, cornerTopSize, cornerTopSize), clrTransparent, -2); -            pixmapBackgroundTop->DrawEllipse(cRect(infoWidth - cornerTopSize, 0, cornerTopSize, cornerTopSize), clrTransparent, -1); -            pixmapLogoBackgroundBottom->DrawEllipse(cRect(0, cornerBottomSize, cornerBottomSize, cornerBottomSize), clrTransparent, -3); -            pixmapBackgroundBottom->DrawEllipse(cRect(infoWidth - cornerBottomSize, cornerBottomSize, cornerBottomSize, cornerBottomSize), clrTransparent, -4); -        } else if ((config.backgroundStyle == bsFull) && (config.logoPosition == lpRight)){ -            pixmapBackgroundTop->DrawEllipse(cRect(0, 0, cornerTopSize, cornerTopSize), clrTransparent, -2); -            pixmapLogoBackgroundTop->DrawEllipse(cRect(pixmapLogoBackgroundTop->ViewPort().Width() - cornerTopSize, 0, cornerTopSize, cornerTopSize), clrTransparent, -1); -            pixmapBackgroundBottom->DrawEllipse(cRect(0, cornerBottomSize, cornerBottomSize, cornerBottomSize), clrTransparent, -3); -            pixmapLogoBackgroundBottom->DrawEllipse(cRect(pixmapLogoBackgroundBottom->ViewPort().Width() - cornerBottomSize, cornerBottomSize, cornerBottomSize, cornerBottomSize), clrTransparent, -4); +    if (config.roundedCornersChannel) { +        int cornerTopSize = channelInfoHeight/2; +        int cornerBottomSize = streamInfoHeight/2; +        if ((cornerTopSize > 2)&&(cornerBottomSize > 2)) { +            if ((config.backgroundStyle == bsTrans) || ((config.logoPosition == lpNone))) { +                pixmapBackgroundTop->DrawEllipse(cRect(0, 0, cornerTopSize, cornerTopSize), clrTransparent, -2); +                pixmapBackgroundTop->DrawEllipse(cRect(infoWidth - cornerTopSize, 0, cornerTopSize, cornerTopSize), clrTransparent, -1); +                pixmapBackgroundBottom->DrawEllipse(cRect(0, cornerBottomSize, cornerBottomSize, cornerBottomSize), clrTransparent, -3); +                pixmapBackgroundBottom->DrawEllipse(cRect(infoWidth - cornerBottomSize, cornerBottomSize, cornerBottomSize, cornerBottomSize), clrTransparent, -4); +            } else if ((config.backgroundStyle == bsFull) && (config.logoPosition == lpLeft)){ +                pixmapLogoBackgroundTop->DrawEllipse(cRect(0, 0, cornerTopSize, cornerTopSize), clrTransparent, -2); +                pixmapBackgroundTop->DrawEllipse(cRect(infoWidth - cornerTopSize, 0, cornerTopSize, cornerTopSize), clrTransparent, -1); +                pixmapLogoBackgroundBottom->DrawEllipse(cRect(0, cornerBottomSize, cornerBottomSize, cornerBottomSize), clrTransparent, -3); +                pixmapBackgroundBottom->DrawEllipse(cRect(infoWidth - cornerBottomSize, cornerBottomSize, cornerBottomSize, cornerBottomSize), clrTransparent, -4); +            } else if ((config.backgroundStyle == bsFull) && (config.logoPosition == lpRight)){ +                pixmapBackgroundTop->DrawEllipse(cRect(0, 0, cornerTopSize, cornerTopSize), clrTransparent, -2); +                pixmapLogoBackgroundTop->DrawEllipse(cRect(pixmapLogoBackgroundTop->ViewPort().Width() - cornerTopSize, 0, cornerTopSize, cornerTopSize), clrTransparent, -1); +                pixmapBackgroundBottom->DrawEllipse(cRect(0, cornerBottomSize, cornerBottomSize, cornerBottomSize), clrTransparent, -3); +                pixmapLogoBackgroundBottom->DrawEllipse(cRect(pixmapLogoBackgroundBottom->ViewPort().Width() - cornerBottomSize, cornerBottomSize, cornerBottomSize, cornerBottomSize), clrTransparent, -4); +            }          }      } -          pixmapChannelInfo->Fill(clrTransparent);      pixmapDate->Fill(clrTransparent);      pixmapLogo->Fill(clrTransparent); diff --git a/displaymenu.c b/displaymenu.c index e99da16..d62416e 100644 --- a/displaymenu.c +++ b/displaymenu.c @@ -59,11 +59,12 @@ cNopacityDisplayMenu::~cNopacityDisplayMenu() {          delete detailView;      }      timers.Clear(); -    for (int i=0; i<14; i++) -        cOsdProvider::DropImage(handleBackgrounds[i]); -    for (int i=0; i<4; i++) -        cOsdProvider::DropImage(handleButtons[i]); - +    if (config.doBlending) { +        for (int i=0; i<14; i++) +            cOsdProvider::DropImage(handleBackgrounds[i]); +        for (int i=0; i<4; i++) +            cOsdProvider::DropImage(handleButtons[i]); +    }      delete osd;      cDevice::PrimaryDevice()->ScaleVideo(cRect::Null);      menuActive = false; @@ -362,22 +363,22 @@ void cNopacityDisplayMenu::SetButtonPositions(void) {  void cNopacityDisplayMenu::SetButtons(const char *Red, const char *Green, const char *Yellow, const char *Blue) {      if (Red) { -        menuView->DrawButton(Red, handleButtons[0], Theme.Color(clrButtonRedBorder), positionButtons[0]); +        menuView->DrawButton(Red, handleButtons[0], Theme.Color(clrButtonRed), Theme.Color(clrButtonRedBorder), positionButtons[0]);      } else          menuView->ClearButton(positionButtons[0]);      if (Green) { -        menuView->DrawButton(Green, handleButtons[1], Theme.Color(clrButtonGreenBorder), positionButtons[1]); +        menuView->DrawButton(Green, handleButtons[1],Theme.Color(clrButtonGreen),  Theme.Color(clrButtonGreenBorder), positionButtons[1]);      } else          menuView->ClearButton(positionButtons[1]);      if (Yellow) { -        menuView->DrawButton(Yellow, handleButtons[2], Theme.Color(clrButtonYellowBorder), positionButtons[2]); +        menuView->DrawButton(Yellow, handleButtons[2], Theme.Color(clrButtonYellow), Theme.Color(clrButtonYellowBorder), positionButtons[2]);      } else          menuView->ClearButton(positionButtons[2]);      if (Blue) { -        menuView->DrawButton(Blue, handleButtons[3], Theme.Color(clrButtonBlueBorder), positionButtons[3]); +        menuView->DrawButton(Blue, handleButtons[3], Theme.Color(clrButtonBlue), Theme.Color(clrButtonBlueBorder), positionButtons[3]);      } else          menuView->ClearButton(positionButtons[3]);  } diff --git a/displaymenuview.c b/displaymenuview.c index 4dcb244..6fce559 100644 --- a/displaymenuview.c +++ b/displaymenuview.c @@ -399,6 +399,8 @@ const cFont *cNopacityDisplayMenuView::GetTextAreaFont(bool FixedFont) {  }  void cNopacityDisplayMenuView::CreateBackgroundImages(int *handleBackgrounds, int *handleButtons) { +    if (!config.doBlending) +        return;      cImageLoader imgLoader;      //Default Menus      imgLoader.DrawBackground(Theme.Color(clrMenuItem), Theme.Color(clrMenuItemBlend), menuItemWidthDefault-2, menuItemHeightDefault-2); @@ -442,7 +444,7 @@ void cNopacityDisplayMenuView::CreateBackgroundImages(int *handleBackgrounds, in      handleBackgrounds[12] = cOsdProvider::StoreImage(imgLoader.GetImage());      imgLoader.DrawBackground(Theme.Color(clrMenuItemHigh), Theme.Color(clrMenuItemHighBlend), itemSize.X()-2, itemSize.Y()-2);      handleBackgrounds[13] = cOsdProvider::StoreImage(imgLoader.GetImage()); -     +    //Color Buttons      imgLoader.DrawBackground(Theme.Color(clrMenuBack), Theme.Color(clrButtonRed), buttonWidth-4, buttonHeight-4);      handleButtons[0] = cOsdProvider::StoreImage(imgLoader.GetImage());      imgLoader.DrawBackground(Theme.Color(clrMenuBack), Theme.Color(clrButtonGreen), buttonWidth-4, buttonHeight-4); @@ -454,10 +456,13 @@ void cNopacityDisplayMenuView::CreateBackgroundImages(int *handleBackgrounds, in  }  void cNopacityDisplayMenuView::DrawBorderDecoration() { -    cImageLoader imgLoader; -    bool mirrorHeader = (config.menuAdjustLeft) ? false : true; -    imgLoader.DrawBackground(Theme.Color(clrMenuHeaderBlend), Theme.Color(clrMenuHeader), osdWidth, headerHeight, mirrorHeader); -    pixmapHeader->DrawImage(cPoint(0,0), imgLoader.GetImage()); +    if (config.doBlending) { +        cImageLoader imgLoader; +        bool mirrorHeader = (config.menuAdjustLeft) ? false : true; +        imgLoader.DrawBackground(Theme.Color(clrMenuHeaderBlend), Theme.Color(clrMenuHeader), osdWidth, headerHeight, mirrorHeader); +        pixmapHeader->DrawImage(cPoint(0,0), imgLoader.GetImage()); +    } else  +        pixmapHeader->Fill(Theme.Color(clrMenuBack));      pixmapFooter->Fill(Theme.Color(clrMenuBack));      int borderWidth = 2; @@ -689,14 +694,17 @@ void cNopacityDisplayMenuView::ShowDiskUsage(bool show) {      }  } -void cNopacityDisplayMenuView::DrawButton(const char *text, int handleImage, tColor borderColor, int num) { +void cNopacityDisplayMenuView::DrawButton(const char *text, int handleImage, tColor buttonColor, tColor borderColor, int num) {      if (num < 0)          return;      int top = 2*buttonsBorder;      int left = num * buttonWidth + (2*num + 1) * buttonsBorder; -    pixmapFooter->DrawRectangle(cRect(left, top, buttonWidth, buttonHeight), borderColor); -    pixmapFooter->DrawImage(cPoint(left+2, top+2), handleImage); -     +    if (config.doBlending) { +        pixmapFooter->DrawRectangle(cRect(left, top, buttonWidth, buttonHeight), borderColor); +	pixmapFooter->DrawImage(cPoint(left+2, top+2), handleImage); +    } else { +        pixmapFooter->DrawRectangle(cRect(left, top, buttonWidth, buttonHeight), buttonColor); +    }      if (config.roundedCorners) {          int radius = config.cornerRadius;          if (radius > 2) { @@ -716,7 +724,8 @@ void cNopacityDisplayMenuView::DrawButton(const char *text, int handleImage, tCo      int textWidth = fontButtons->Width(text);      int textHeight = fontButtons->Height(); -    pixmapFooter->DrawText(cPoint(left + (buttonWidth-textWidth)/2, top + (buttonHeight-textHeight)/2), text, Theme.Color(clrMenuFontButton), clrTransparent, fontButtons); +    tColor clrFontBack = (config.doBlending)?(clrTransparent):buttonColor; +    pixmapFooter->DrawText(cPoint(left + (buttonWidth-textWidth)/2, top + (buttonHeight-textHeight)/2), text, Theme.Color(clrMenuFontButton), clrFontBack, fontButtons);  }  void cNopacityDisplayMenuView::ClearButton(int num) { @@ -796,11 +805,14 @@ void cNopacityDisplayMenuView::DrawMessage(eMessageType Type, const char *Text)      }      pixmapStatus = osd->CreatePixmap(7, cRect(0.1*osdWidth, 0.8*osdHeight, messageWidth, messageHeight));      pixmapStatus->Fill(col); -    cImageLoader imgLoader; -    imgLoader.DrawBackground2(Theme.Color(clrMenuBack), col, messageWidth-2, messageHeight-2); -    pixmapStatus->DrawImage(cPoint(1, 1), imgLoader.GetImage()); +    if (config.doBlending) { +        cImageLoader imgLoader; +        imgLoader.DrawBackground2(Theme.Color(clrMenuBack), col, messageWidth-2, messageHeight-2); +        pixmapStatus->DrawImage(cPoint(1, 1), imgLoader.GetImage()); +    }      int textWidth = fontMessage->Width(Text); -    pixmapStatus->DrawText(cPoint((messageWidth - textWidth) / 2, (messageHeight - fontMessage->Height()) / 2), Text, Theme.Color(clrMenuFontMessages), clrTransparent, fontMessage); +    tColor clrFontBack = (config.doBlending)?(clrTransparent):col; +    pixmapStatus->DrawText(cPoint((messageWidth - textWidth) / 2, (messageHeight - fontMessage->Height()) / 2), Text, Theme.Color(clrMenuFontMessages), clrFontBack, fontMessage);  }  void cNopacityDisplayMenuView::ClearMessage(void) { diff --git a/displaymenuview.h b/displaymenuview.h index 51eb053..a9c10b5 100644 --- a/displaymenuview.h +++ b/displaymenuview.h @@ -109,7 +109,7 @@ class cNopacityDisplayMenuView {          void DrawDate(bool initial);          void DrawDiskUsage(void);          void ShowDiskUsage(bool show); -        void DrawButton(const char *text, int handleImage, tColor borderColor, int num); +        void DrawButton(const char *text, int handleImage, tColor buttonColor, tColor borderColor, int num);          void ClearButton(int num);          int GetTimersInitHeight(void);          int GetTimersMaxHeight(void); diff --git a/displaymessage.c b/displaymessage.c index 780d17e..cc831a3 100644 --- a/displaymessage.c +++ b/displaymessage.c @@ -46,11 +46,13 @@ void cNopacityDisplayMessage::SetMessage(eMessageType Type, const char *Text) {      }      pixmapBackground->Fill(clrBlack);      pixmap->Fill(col); -    cImageLoader imgLoader; -    imgLoader.DrawBackground2(Theme.Color(clrMessageBlend), col, width-2, height-2); -    pixmap->DrawImage(cPoint(1, 1), imgLoader.GetImage()); +    if (config.doBlending) { +        cImageLoader imgLoader; +        imgLoader.DrawBackground2(Theme.Color(clrMessageBlend), col, width-2, height-2); +        pixmap->DrawImage(cPoint(1, 1), imgLoader.GetImage()); +    }      int textWidth = font->Width(Text); -    pixmap->DrawText(cPoint((width - textWidth) / 2, (height - font->Height()) / 2), Text, Theme.Color(clrMessageFont), clrTransparent, font); +    pixmap->DrawText(cPoint((width - textWidth) / 2, (height - font->Height()) / 2), Text, Theme.Color(clrMessageFont), (config.doBlending)?clrTransparent:col, font);      if (config.messageFadeTime)          Start();  } diff --git a/displayreplay.c b/displayreplay.c index ed2ea95..0f3c845 100644 --- a/displayreplay.c +++ b/displayreplay.c @@ -134,15 +134,22 @@ void cNopacityDisplayReplay::CreateFonts(void) {  void cNopacityDisplayReplay::DrawBackground(void) {      if (!modeOnly) { -        DrawBlendedBackground(pixmapHeader, Theme.Color(clrReplayBackground), Theme.Color(clrReplayBackBlend), true); -        DrawBlendedBackground(pixmapFooter, Theme.Color(clrReplayBackground), Theme.Color(clrReplayBackBlend), false); -        int cornerTopSize = headerHeight/2; -        int cornerBottomSize = footerHeight/2; -        if ((cornerTopSize > 2)&&(cornerBottomSize > 2)) { -            pixmapHeader->DrawEllipse(cRect(0,0, cornerTopSize, cornerTopSize), clrTransparent, -2); -            pixmapHeader->DrawEllipse(cRect(width - cornerTopSize, 0, cornerTopSize, cornerTopSize), clrTransparent, -1); -            pixmapFooter->DrawEllipse(cRect(0, cornerBottomSize, cornerBottomSize, cornerBottomSize), clrTransparent, -3); -            pixmapFooter->DrawEllipse(cRect(width - cornerBottomSize, cornerBottomSize, cornerBottomSize, cornerBottomSize), clrTransparent, -4); +        if (config.doBlending) { +            DrawBlendedBackground(pixmapHeader, Theme.Color(clrReplayBackground), Theme.Color(clrReplayBackBlend), true); +            DrawBlendedBackground(pixmapFooter, Theme.Color(clrReplayBackground), Theme.Color(clrReplayBackBlend), false); +        } else { +            pixmapHeader->Fill(Theme.Color(clrReplayBackground)); +            pixmapFooter->Fill(Theme.Color(clrReplayBackground)); +        } +        if (config.roundedCornersChannel) { +            int cornerTopSize = headerHeight/2; +            int cornerBottomSize = footerHeight/2; +            if ((cornerTopSize > 2)&&(cornerBottomSize > 2)) { +                pixmapHeader->DrawEllipse(cRect(0,0, cornerTopSize, cornerTopSize), clrTransparent, -2); +                pixmapHeader->DrawEllipse(cRect(width - cornerTopSize, 0, cornerTopSize, cornerTopSize), clrTransparent, -1); +                pixmapFooter->DrawEllipse(cRect(0, cornerBottomSize, cornerBottomSize, cornerBottomSize), clrTransparent, -3); +                pixmapFooter->DrawEllipse(cRect(width - cornerBottomSize, cornerBottomSize, cornerBottomSize, cornerBottomSize), clrTransparent, -4); +            }          }          pixmapBackground->Fill(Theme.Color(clrReplayBackground));          pixmapControls->Fill(clrTransparent); diff --git a/displaytracks.c b/displaytracks.c index 8dcdc96..bbcc8ce 100644 --- a/displaytracks.c +++ b/displaytracks.c @@ -25,8 +25,10 @@ cNopacityDisplayTracks::~cNopacityDisplayTracks() {      osd->DestroyPixmap(pixmapHeader);      osd->DestroyPixmap(pixmapHeaderAudio);      menuItems.Clear(); -    for (int i=0; i<2; i++) -        cOsdProvider::DropImage(handleBackgrounds[i]); +    if (config.doBlending) { +        for (int i=0; i<2; i++) +            cOsdProvider::DropImage(handleBackgrounds[i]); +    }      delete font;      delete fontHeader;      delete osd; @@ -98,6 +100,8 @@ void cNopacityDisplayTracks::CreateFonts(void) {  }  void cNopacityDisplayTracks::CreateBackgroundImages(void) { +    if (!config.doBlending) +        return;      cImageLoader imgLoader;      imgLoader.DrawBackground(Theme.Color(clrMenuItem), Theme.Color(clrMenuItemBlend), menuItemWidth-2, menuItemHeight-2);      handleBackgrounds[0] = cOsdProvider::StoreImage(imgLoader.GetImage()); @@ -108,16 +112,20 @@ void cNopacityDisplayTracks::CreateBackgroundImages(void) {  void cNopacityDisplayTracks::DrawHeader(const char *Title) {      pixmapContainer->Fill(Theme.Color(clrMenuBorder));      pixmapContainer->DrawRectangle(cRect(1, 1, width-2, height-2), Theme.Color(clrMenuBack)); -      pixmapHeader->Fill(Theme.Color(clrMenuItem)); -    pixmapHeader->DrawImage(cPoint(1, 1), handleBackgrounds[0]); +    if (config.doBlending) { +        pixmapHeader->DrawImage(cPoint(1, 1), handleBackgrounds[0]); +    } else { +        pixmapHeader->DrawRectangle(cRect(1, 1, width-2, height-2), Theme.Color(clrMenuItemHigh)); +    }      pixmapIcon = osd->CreatePixmap(3, cRect(2, 2, menuItemHeight-2, menuItemHeight-2));      pixmapIcon->Fill(clrTransparent);      cImageLoader imgLoader;      if (imgLoader.LoadIcon("skinIcons/tracks", menuItemHeight-6)) {          pixmapIcon->DrawImage(cPoint(3, 3), imgLoader.GetImage());      } -    pixmapHeader->DrawText(cPoint((width - fontHeader->Width(Title)) / 2, (menuItemHeight - fontHeader->Height()) / 2), Title, Theme.Color(clrTracksFontHead), clrTransparent, fontHeader); +    int clrFontBack = (config.doBlending)?clrTransparent:Theme.Color(clrMenuItemHigh); +    pixmapHeader->DrawText(cPoint((width - fontHeader->Width(Title)) / 2, (menuItemHeight - fontHeader->Height()) / 2), Title, Theme.Color(clrTracksFontHead), clrFontBack, fontHeader);  }  void cNopacityDisplayTracks::SetItem(const char *Text, int Index, bool Current) { diff --git a/displayvolume.c b/displayvolume.c index 9570e1a..5bbca51 100644 --- a/displayvolume.c +++ b/displayvolume.c @@ -18,9 +18,13 @@ cNopacityDisplayVolume::cNopacityDisplayVolume(void) {      pixmapBackgroundTop = osd->CreatePixmap(1, cRect(0, 0, width, height/2));      pixmapBackgroundBottom = osd->CreatePixmap(1, cRect(0, height/2, width, height/2)); - -    DrawBlendedBackground(pixmapBackgroundTop, Theme.Color(clrChannelBackground), Theme.Color(clrChannelBackBlend), true); -    DrawBlendedBackground(pixmapBackgroundBottom, Theme.Color(clrChannelBackground), Theme.Color(clrChannelBackBlend), false); +    if (config.doBlending) { +        DrawBlendedBackground(pixmapBackgroundTop, Theme.Color(clrChannelBackground), Theme.Color(clrChannelBackBlend), true); +        DrawBlendedBackground(pixmapBackgroundBottom, Theme.Color(clrChannelBackground), Theme.Color(clrChannelBackBlend), false); +    } else { +        pixmapBackgroundTop->Fill(Theme.Color(clrChannelBackground)); +        pixmapBackgroundBottom->Fill(Theme.Color(clrChannelBackground)); +    }      int cornerSize = height/4;      if (cornerSize > 2) {          pixmapBackgroundTop->DrawEllipse(cRect(0, 0, cornerSize, cornerSize), clrTransparent, -2); @@ -84,7 +84,11 @@ void cNopacityMenuItem::SetBackgrounds(int *handleBackgrounds) {  void cNopacityMenuItem::DrawDelimiter(const char *del, const char *icon, int handleBgrd) {      pixmap->Fill(Theme.Color(clrSeparatorBorder)); -    pixmap->DrawImage(cPoint(1, 1), handleBgrd); +    if (handleBgrd >= 0) +        pixmap->DrawImage(cPoint(1, 1), handleBackgrounds[handleBgrd]); +    else +        pixmap->DrawRectangle(cRect(1, 1, width-2, height-2), Theme.Color(clrMenuItem)); +      if (config.roundedCorners)          DrawRoundedCorners(Theme.Color(clrSeparatorBorder));      cImageLoader imgLoader; @@ -107,7 +111,8 @@ void cNopacityMenuItem::DrawDelimiter(const char *del, const char *icon, int han      } catch (...) {}      int x = config.iconHeight + 3;      int y = (height - font->Height()) / 2; -    pixmap->DrawText(cPoint(x, y), delimiter.c_str(), Theme.Color(clrMenuFontMenuItemSep), clrTransparent, font); +    tColor clrFontBack = (config.doBlending)?(clrTransparent):Theme.Color(clrMenuItem); +    pixmap->DrawText(cPoint(x, y), delimiter.c_str(), Theme.Color(clrMenuFontMenuItemSep), clrFontBack, font);  }  void cNopacityMenuItem::Action(void) { @@ -179,6 +184,23 @@ cNopacityMainMenuItem::cNopacityMainMenuItem(cOsd *osd, const char *text, bool s  cNopacityMainMenuItem::~cNopacityMainMenuItem(void) {  } +void cNopacityMainMenuItem::DrawBackground(void) { +    pixmap->Fill(Theme.Color(clrMenuBorder)); +    if (config.doBlending) { +        int handleBgrd; +        if (!isSetup) +            handleBgrd = (current)?handleBackgrounds[3]:handleBackgrounds[2]; +        else +            handleBgrd = (current)?handleBackgrounds[13]:handleBackgrounds[12]; +        pixmap->DrawImage(cPoint(1, 1), handleBgrd); +    } else { +        tColor col = (current)?Theme.Color(clrMenuItemHigh):Theme.Color(clrMenuItem); +        pixmap->DrawRectangle(cRect(1, 1, width-2, height-2), col); +    } +    if (config.roundedCorners) +        DrawRoundedCorners(Theme.Color(clrMenuBorder)); +} +  std::string cNopacityMainMenuItem::items[16] = { "Schedule", "Channels", "Timers", "Recordings", "Setup", "Commands",                                                  "OSD", "EPG", "DVB", "LNB", "CAM", "Recording", "Replay", "Miscellaneous", "Plugins", "Restart"}; @@ -307,15 +329,7 @@ void cNopacityMainMenuItem::SetTextShort(void) {  }  void cNopacityMainMenuItem::Render() { -    pixmap->Fill(Theme.Color(clrMenuBorder)); -    int handleBgrd; -    if (!isSetup) -        handleBgrd = (current)?handleBackgrounds[3]:handleBackgrounds[2]; -    else -        handleBgrd = (current)?handleBackgrounds[13]:handleBackgrounds[12]; -    pixmap->DrawImage(cPoint(1, 1), handleBgrd); -    if (config.roundedCorners) -        DrawRoundedCorners(Theme.Color(clrMenuBorder)); +    DrawBackground();      if (selectable) {          if (config.useMenuIcons) {              cString cIcon = GetIconName(); @@ -337,7 +351,7 @@ void cNopacityMainMenuItem::Render() {              Cancel(-1);          }      } else { -        DrawDelimiter(*itemTabs[1], "skinIcons/Channelseparator", handleBgrd); +        DrawDelimiter(*itemTabs[1], "skinIcons/Channelseparator", (config.doBlending)?-1:(isSetup?12:2));      }  } @@ -470,18 +484,22 @@ void cNopacityScheduleMenuItem::Render() {          }      } else {          if (Event) { -            DrawDelimiter(Event->Title(), "skinIcons/daydelimiter", handleBackgrounds[4]); +            DrawDelimiter(Event->Title(), "skinIcons/daydelimiter", (config.doBlending)?4:-1);          } else if (Channel) { -            DrawDelimiter(Channel->Name(), "skinIcons/Channelseparator", handleBackgrounds[4]); +            DrawDelimiter(Channel->Name(), "skinIcons/Channelseparator", (config.doBlending)?4:-1);          }      }  }  void cNopacityScheduleMenuItem::DrawBackground(int textLeft) { -    int handleBgrd = (current)?handleBackgrounds[5]:handleBackgrounds[4];      pixmap->Fill(Theme.Color(clrMenuBorder)); -    pixmap->DrawImage(cPoint(1, 1), handleBgrd); -    pixmap->DrawText(cPoint(textLeft, 3), strDateTime.c_str(), Theme.Color(clrMenuFontMenuItem), clrTransparent, font); +    if (config.doBlending) { +        int handleBgrd = (current)?handleBackgrounds[5]:handleBackgrounds[4]; +        pixmap->DrawImage(cPoint(1, 1), handleBgrd); +    } else { +        tColor col = (current)?Theme.Color(clrMenuItemHigh):Theme.Color(clrMenuItem); +        pixmap->DrawRectangle(cRect(1, 1, width-2, height-2), col); +    }      if (config.roundedCorners)          DrawRoundedCorners(Theme.Color(clrMenuBorder));      if (TimerMatch == tmFull) { @@ -495,6 +513,9 @@ void cNopacityScheduleMenuItem::DrawBackground(int textLeft) {              pixmapIcon->DrawImage(cPoint(width - 34, 2), imgLoader.GetImage());          }      } +    tColor clrFont = (current)?Theme.Color(clrMenuFontMenuItemHigh):Theme.Color(clrMenuFontMenuItem); +    tColor clrFontBack = (config.doBlending)?(clrTransparent):((current)?Theme.Color(clrMenuItemHigh):Theme.Color(clrMenuItem)); +    pixmap->DrawText(cPoint(textLeft, 3), strDateTime.c_str(), clrFont, clrFontBack, font);  }  void cNopacityScheduleMenuItem::DrawLogo(int logoWidth, int logoHeight) { @@ -590,16 +611,23 @@ void cNopacityChannelMenuItem::SetTextShort(void) {      pixmapTextScroller->DrawText(cPoint(5, (height/2 - font->Height())/2), strEntry.c_str(), clrFont, clrTransparent, font);  } -void cNopacityChannelMenuItem::DrawBackground(int handleBackground) { +void cNopacityChannelMenuItem::DrawBackground(void) {      pixmap->Fill(Theme.Color(clrMenuBorder)); -    pixmap->DrawImage(cPoint(1, 1), handleBackground); +    if (config.doBlending) { +        int handleBgrd = (current)?handleBackgrounds[7]:handleBackgrounds[6]; +        pixmap->DrawImage(cPoint(1, 1), handleBgrd); +    } else { +        tColor col = (current)?Theme.Color(clrMenuItemHigh):Theme.Color(clrMenuItem); +        pixmap->DrawRectangle(cRect(1, 1, width-2, height-2), col); +    }      if (config.roundedCorners)          DrawRoundedCorners(Theme.Color(clrMenuBorder));      int encryptedSize = height/4-2;      int sourceX = config.menuItemLogoWidth + 15; - -    pixmap->DrawText(cPoint(sourceX, 3*height/4 + (height/4 - fontSmall->Height())/2), *strChannelInfo, Theme.Color(clrMenuFontMenuItem), clrTransparent, fontSmall); +    tColor clrFont = (current)?Theme.Color(clrMenuFontMenuItemHigh):Theme.Color(clrMenuFontMenuItem); +    tColor clrFontBack = (config.doBlending)?(clrTransparent):((current)?Theme.Color(clrMenuItemHigh):Theme.Color(clrMenuItem));  +    pixmap->DrawText(cPoint(sourceX, 3*height/4 + (height/4 - fontSmall->Height())/2), *strChannelInfo, clrFont, clrFontBack, fontSmall);      if (Channel->Ca()) {          cImageLoader imgLoader;          if (imgLoader.LoadIcon("skinIcons/encrypted", encryptedSize)) { @@ -607,7 +635,7 @@ void cNopacityChannelMenuItem::DrawBackground(int handleBackground) {              sourceX += encryptedSize + 10;          }      } -    pixmap->DrawText(cPoint(sourceX, height/2 + (height/4 - fontSmall->Height())/2), *strChannelSource, Theme.Color(clrMenuFontMenuItem), clrTransparent, fontSmall); +    pixmap->DrawText(cPoint(sourceX, height/2 + (height/4 - fontSmall->Height())/2), *strChannelSource, clrFont, clrFontBack, fontSmall);  }  std::string cNopacityChannelMenuItem::readEPG(void) { @@ -645,10 +673,8 @@ std::string cNopacityChannelMenuItem::readEPG(void) {  void cNopacityChannelMenuItem::Render() { -    int handleBgrd = (current)?handleBackgrounds[7]:handleBackgrounds[6]; -          if (selectable) {                           //Channels -        DrawBackground(handleBgrd); +        DrawBackground();          int logoWidth = config.menuItemLogoWidth;          int logoHeight = config.menuItemLogoHeight;          if (!drawn) { @@ -679,7 +705,7 @@ void cNopacityChannelMenuItem::Render() {              infoTextWindow->Start();          }      } else {                                    //Channelseparators -        DrawDelimiter(Channel->Name(), "skinIcons/Channelseparator", handleBgrd); +        DrawDelimiter(Channel->Name(), "skinIcons/Channelseparator", (config.doBlending)?6:-1);      }  } @@ -759,9 +785,15 @@ void cNopacityTimerMenuItem::SetTextShort(void) {      pixmapTextScroller->DrawText(cPoint(0, height/2 + (height/2 - font->Height())/2), strEntry.c_str(), clrFont, clrTransparent, font);  } -void cNopacityTimerMenuItem::DrawBackground(int handleBackground, int textLeft) { +void cNopacityTimerMenuItem::DrawBackground(int textLeft) {      pixmap->Fill(Theme.Color(clrMenuBorder)); -    pixmap->DrawImage(cPoint(1, 1), handleBackground); +    if (config.doBlending) { +        int handleBgrd = (current)?handleBackgrounds[11]:handleBackgrounds[10]; +        pixmap->DrawImage(cPoint(1, 1), handleBgrd); +    } else { +        tColor col = (current)?Theme.Color(clrMenuItemHigh):Theme.Color(clrMenuItem); +        pixmap->DrawRectangle(cRect(1, 1, width-2, height-2), col); +    }      if (config.roundedCorners)          DrawRoundedCorners(Theme.Color(clrMenuBorder));      int iconSize = height/2; @@ -786,14 +818,15 @@ void cNopacityTimerMenuItem::DrawBackground(int handleBackground, int textLeft)          dateTime = cString::sprintf("! %s", strDateTime.c_str());      else          dateTime = strDateTime.c_str(); -    pixmap->DrawText(cPoint(textLeft + iconSize, (height/2 - fontSmall->Height())/2), *dateTime, Theme.Color(clrMenuFontMenuItem), clrTransparent, fontSmall); +    tColor clrFont = (current)?Theme.Color(clrMenuFontMenuItemHigh):Theme.Color(clrMenuFontMenuItem); +    tColor clrFontBack = (config.doBlending)?(clrTransparent):((current)?Theme.Color(clrMenuItemHigh):Theme.Color(clrMenuItem)); +    pixmap->DrawText(cPoint(textLeft + iconSize, (height/2 - fontSmall->Height())/2), *dateTime, clrFont, clrFontBack, fontSmall);  }  void cNopacityTimerMenuItem::Render() { -    int handleBgrd = (current)?handleBackgrounds[11]:handleBackgrounds[10];      textLeft = config.menuItemLogoWidth + 10;      if (selectable) {                            -        DrawBackground(handleBgrd, textLeft); +        DrawBackground(textLeft);          int logoWidth = config.menuItemLogoWidth;          int logoHeight = config.menuItemLogoHeight;          if (!drawn) { @@ -926,6 +959,19 @@ void cNopacityRecordingMenuItem::SetTextFull(void) {          SetTextFullRecording();  } +void cNopacityRecordingMenuItem::DrawBackground(void) { +    pixmap->Fill(Theme.Color(clrMenuBorder)); +    if (config.doBlending) { +        int handleBgrd = (current)?handleBackgrounds[9]:handleBackgrounds[8]; +        pixmap->DrawImage(cPoint(1, 1), handleBgrd); +    } else { +        tColor col = (current)?Theme.Color(clrMenuItemHigh):Theme.Color(clrMenuItem); +        pixmap->DrawRectangle(cRect(1, 1, width-2, height-2), col); +    } +    if (config.roundedCorners) +        DrawRoundedCorners(Theme.Color(clrMenuBorder)); +} +  void cNopacityRecordingMenuItem::SetTextFullFolder(void) {      tColor clrFont = (current)?Theme.Color(clrMenuFontMenuItemHigh):Theme.Color(clrMenuFontMenuItem);      pixmapTextScroller->Fill(clrTransparent); @@ -1031,26 +1077,23 @@ void cNopacityRecordingMenuItem::DrawRecDateTime(void) {      }      int textHeight = height/2 + (height/4 - fontSmall->Height())/2; -    pixmapIcon->DrawText(cPoint(iconDateTimeSize + 10, textHeight), *strDateTime, Theme.Color(clrMenuFontMenuItem), clrTransparent, fontSmall); +    tColor clrFont = (current)?Theme.Color(clrMenuFontMenuItemHigh):Theme.Color(clrMenuFontMenuItem); +    pixmapIcon->DrawText(cPoint(iconDateTimeSize + 10, textHeight), *strDateTime, clrFont, clrTransparent, fontSmall);      textHeight += height/4; -    pixmapIcon->DrawText(cPoint(iconDateTimeSize + 10, textHeight), *strDuration, Theme.Color(clrMenuFontMenuItem), clrTransparent, fontSmall); +    pixmapIcon->DrawText(cPoint(iconDateTimeSize + 10, textHeight), *strDuration, clrFont, clrTransparent, fontSmall);  }  void cNopacityRecordingMenuItem::DrawFolderNewSeen(void) {      int textHeight = 2*height/3 + (height/3 - fontSmall->Height())/2 - 10;      cString strTotalNew = cString::sprintf("%d %s (%d %s)", Total, (Total > 1)?tr("recordings"):tr("recording"), New, tr("new")); -    pixmapIcon->DrawText(cPoint(config.menuRecFolderSize + 10, textHeight), *strTotalNew, Theme.Color(clrMenuFontMenuItem), clrTransparent, fontSmall); +    tColor clrFont = (current)?Theme.Color(clrMenuFontMenuItemHigh):Theme.Color(clrMenuFontMenuItem); +    pixmapIcon->DrawText(cPoint(config.menuRecFolderSize + 10, textHeight), *strTotalNew, clrFont, clrTransparent, fontSmall);  }  void cNopacityRecordingMenuItem::Render() { -     -    int handleBgrd = (current)?handleBackgrounds[9]:handleBackgrounds[8];      if (selectable) {                            -        pixmap->Fill(Theme.Color(clrMenuBorder)); -        pixmap->DrawImage(cPoint(1, 1), handleBgrd); -        if (config.roundedCorners) -            DrawRoundedCorners(Theme.Color(clrMenuBorder)); +        DrawBackground();          if (isFolder) {              DrawFolderNewSeen();              SetTextShort(); @@ -1102,6 +1145,19 @@ bool cNopacityDefaultMenuItem::CheckProgressBar(const char *text) {      return false;  } +void cNopacityDefaultMenuItem::DrawBackground(void) { +    pixmap->Fill(Theme.Color(clrMenuBorder)); +    if (config.doBlending) { +        int handleBgrd = (current)?handleBackgrounds[1]:handleBackgrounds[0]; +        pixmap->DrawImage(cPoint(1, 1), handleBgrd); +    } else { +        tColor col = (current)?Theme.Color(clrMenuItemHigh):Theme.Color(clrMenuItem); +        pixmap->DrawRectangle(cRect(1, 1, width-2, height-2), col); +    } +    if (config.roundedCorners) +        DrawRoundedCorners(Theme.Color(clrMenuBorder)); +} +  void cNopacityDefaultMenuItem::DrawProgressBar(int x, int width, const char *bar, tColor color) {      const char *p = bar + 1;      bool isProgressbar = true; @@ -1188,19 +1244,17 @@ bool cNopacityDefaultMenuItem::DrawHeaderElement(void) {          *(c2 + 1) = 0;          int left = 5 + tabWidth[0]; -        pixmap->DrawText(cPoint(left, (height - font->Height()) / 2), c, Theme.Color(clrMenuFontMenuItemSep), clrTransparent, font); +        tColor clrFontBack = (config.doBlending)?(clrTransparent):((current)?Theme.Color(clrMenuItemHigh):Theme.Color(clrMenuItem)); +	pixmap->DrawText(cPoint(left, (height - font->Height()) / 2), c, Theme.Color(clrMenuFontMenuItemSep), clrFontBack, font);          return true;      }      return false;  }  void cNopacityDefaultMenuItem::Render() { -    pixmap->Fill(Theme.Color(clrMenuBorder)); -    int handleBgrd = (current)?handleBackgrounds[1]:handleBackgrounds[0]; +    DrawBackground();      tColor clrFont = (current)?Theme.Color(clrMenuFontMenuItemHigh):Theme.Color(clrMenuFontMenuItem); -    pixmap->DrawImage(cPoint(1, 1), handleBgrd); -    if (config.roundedCorners) -        DrawRoundedCorners(Theme.Color(clrMenuBorder)); +    tColor clrFontBack = (config.doBlending)?(clrTransparent):((current)?Theme.Color(clrMenuItemHigh):Theme.Color(clrMenuItem));      if (!selectable && (strncmp(Text, "---", 3) == 0)) {          if (DrawHeaderElement())              return; @@ -1229,7 +1283,7 @@ void cNopacityDefaultMenuItem::Render() {                      itemText = itemTabs[i];                  }                  if (i==0) posX += 5; -                pixmap->DrawText(cPoint(posX, (height - font->Height()) / 2), *itemText, clrFont, clrTransparent, font); +                pixmap->DrawText(cPoint(posX, (height - font->Height()) / 2), *itemText, clrFont, clrFontBack, font);              } else {                  if (!Running())                      SetTextShort(); @@ -1258,9 +1312,16 @@ cNopacityTrackMenuItem::~cNopacityTrackMenuItem(void) {  void cNopacityTrackMenuItem::Render() {      pixmap->Fill(Theme.Color(clrMenuBorder)); -    int handleBgrd = (current)?handleBackgrounds[1]:handleBackgrounds[0]; -    pixmap->DrawImage(cPoint(1, 1), handleBgrd); +    if (config.doBlending) { +        int handleBgrd = (current)?handleBackgrounds[1]:handleBackgrounds[0]; +        pixmap->DrawImage(cPoint(1, 1), handleBgrd); +    } else { +        tColor col = (current)?Theme.Color(clrMenuItemHigh):Theme.Color(clrMenuItem); +        pixmap->DrawRectangle(cRect(1, 1, width-2, height-2), col); +    }      if (config.roundedCorners)          DrawRoundedCorners(Theme.Color(clrMenuBorder)); -    pixmap->DrawText(cPoint(5, (height - font->Height())/2), Text, Theme.Color(clrTracksFontButtons), clrTransparent, font); +    tColor clrFont = (current)?Theme.Color(clrMenuFontMenuItemHigh):Theme.Color(clrTracksFontButtons); +    tColor clrFontBack = (config.doBlending)?(clrTransparent):((current)?Theme.Color(clrMenuItemHigh):Theme.Color(clrMenuItem)); +    pixmap->DrawText(cPoint(5, (height - font->Height())/2), Text, clrFont, clrFontBack, font);  } @@ -30,9 +30,9 @@ protected:      virtual void SetTextFull(void) {};      virtual void SetTextShort(void) {};      void DrawDelimiter(const char *del, const char *icon, int handleBgrd); +    void DrawRoundedCorners(tColor borderColor);      virtual void Action(void);      void DoSleep(int duration); -    void DrawRoundedCorners(tColor borderColor);  public:      cNopacityMenuItem(cOsd *osd, const char *text, bool sel);      virtual ~cNopacityMenuItem(void); @@ -64,6 +64,7 @@ private:      std::string strEntryFull;      static std::string items[16];      cString GetIconName(); +    void DrawBackground(void);      void SetTextFull(void);      void SetTextShort(void);  public: @@ -114,7 +115,7 @@ private:      cRect *vidWin;      void SetTextFull(void);      void SetTextShort(void); -    void DrawBackground(int handleBackground); +    void DrawBackground(void);      std::string readEPG(void);  public:      cNopacityChannelMenuItem(cOsd *osd, const cChannel *Channel, bool sel, cRect *vidWin); @@ -133,7 +134,7 @@ private:      std::string strDateTime;      void SetTextFull(void);      void SetTextShort(void); -    void DrawBackground(int handleBackground, int textLeft); +    void DrawBackground(int textLeft);      void DrawLogo(int logoWidth, int logoHeight);      std::string CreateDate(void);  public: @@ -159,6 +160,7 @@ private:      void SetTextShortFolder(void);      void SetTextFullRecording(void);      void SetTextShortRecording(void); +    void DrawBackground(void);      int DrawRecordingNewIcon(void);      int DrawRecordingEditedIcon(int startLeft);      void DrawFolderIcon(void); @@ -178,6 +180,7 @@ public:  class cNopacityDefaultMenuItem : public cNopacityMenuItem {  private:      bool CheckProgressBar(const char *text); +    void DrawBackground(void);      void DrawProgressBar(int x, int width, const char *bar, tColor color);      bool DrawHeaderElement(void);      std::string strEntry; @@ -5,6 +5,9 @@ static cTheme Theme;  static bool menuActive = false;  static bool firstDisplay = true; +//ENABLE BLENDING +#define CLR_BLENDING_ON         0xFFFFFFFF +  //COMMON  #define CLR_TRANSBLACK          0xDD000000  #define CLR_TRANSBLACK2         0xB0000000 @@ -34,7 +37,7 @@ static bool firstDisplay = true;  #define CLR_MENUITEMHIGHBLEND   0xEE0033FF  #define CLR_SEPARATORBORDER     0xEE444444  #define CLR_DISKALERT           0xDDFF0000 -#define CLR_MENUHEADER		     0xDD000000 +#define CLR_MENUHEADER		    0xDD000000  #define CLR_MENUHEADERBLEND     0xEE0033FF  //BUTTONS @@ -53,6 +56,9 @@ static bool firstDisplay = true;  #define CLR_MESSAGEWARNING      0x90BBBB00  #define CLR_MESSAGEERROR        0x90BB0000 +//ENABLE BLENDING +THEME_CLR(Theme, clrDoBlending,             CLR_BLENDING_ON); +  //CHANNELS  THEME_CLR(Theme, clrChannelBackground,      CLR_TRANSBLACK2);  THEME_CLR(Theme, clrChannelBackBlend,       CLR_DARKBLUE2); diff --git a/po/de_DE.po b/po/de_DE.po index 6f6c027..42b2bbf 100644 --- a/po/de_DE.po +++ b/po/de_DE.po @@ -8,7 +8,7 @@ msgid ""  msgstr ""  "Project-Id-Version: skinnopacity 0.0.1\n"  "Report-Msgid-Bugs-To: <see README>\n" -"POT-Creation-Date: 2013-05-04 11:26+0200\n" +"POT-Creation-Date: 2013-05-07 16:23+0200\n"  "PO-Revision-Date: 2012-11-11 17:49+0200\n"  "Last-Translator: louis\n"  "Language-Team: \n" @@ -365,6 +365,9 @@ msgstr "HĂśhe des unteren Rands"  msgid "Background Style"  msgstr "Hintergrund Stil" +msgid "Rounded Corners" +msgstr "" +  msgid "Channel Logo Position"  msgstr "Kanallogo Position" diff --git a/po/it_IT.po b/po/it_IT.po index 687359b..d733a45 100644 --- a/po/it_IT.po +++ b/po/it_IT.po @@ -8,7 +8,7 @@ msgid ""  msgstr ""  "Project-Id-Version: skinnopacity 0.0.1\n"  "Report-Msgid-Bugs-To: <see README>\n" -"POT-Creation-Date: 2013-05-04 11:26+0200\n" +"POT-Creation-Date: 2013-05-07 16:23+0200\n"  "PO-Revision-Date: 2013-03-19 22:56+0100\n"  "Last-Translator: Diego Pierotto <vdr-italian@tiscali.it>\n"  "Language-Team: \n" @@ -368,6 +368,9 @@ msgstr "Altezza bordo inferiore"  msgid "Background Style"  msgstr "" +msgid "Rounded Corners" +msgstr "" +  msgid "Channel Logo Position"  msgstr "Posizione logo canale" diff --git a/po/sk_SK.po b/po/sk_SK.po index c981db1..4be4d1f 100644 --- a/po/sk_SK.po +++ b/po/sk_SK.po @@ -8,7 +8,7 @@ msgid ""  msgstr ""  "Project-Id-Version: vdr-skinnopacity 0.0.6\n"  "Report-Msgid-Bugs-To: <see README>\n" -"POT-Creation-Date: 2013-05-04 11:26+0200\n" +"POT-Creation-Date: 2013-05-07 16:23+0200\n"  "PO-Revision-Date: 2013-03-12 15:59+0100\n"  "Last-Translator: Milan Hrala <hrala.milan@gmail.com>\n"  "Language-Team: \n" @@ -368,6 +368,9 @@ msgstr "Výška spodného okraja"  msgid "Background Style"  msgstr "" +msgid "Rounded Corners" +msgstr "" +  msgid "Channel Logo Position"  msgstr "Pozícia loga kanálu" @@ -80,6 +80,7 @@ void cNopacitySetup::Store(void) {      SetupStore("logoHeight", config.logoHeight);      SetupStore("logoBorder", config.logoBorder);      SetupStore("backgroundStyle", config.backgroundStyle); +    SetupStore("roundedCornersChannel", config.roundedCornersChannel);      SetupStore("displaySignalStrength", config.displaySignalStrength);      SetupStore("displayPrevNextChannelGroup", config.displayPrevNextChannelGroup);      SetupStore("channelFadeTime", config.channelFadeTime); @@ -470,6 +471,7 @@ void cNopacitySetupChannelDisplay::Set(void) {      Add(new cMenuEditIntItem(tr("Left & Right Border Width"), &tmpNopacityConfig->channelBorderVertical, 0, 300));      Add(new cMenuEditIntItem(tr("Bottom Border Height"), &tmpNopacityConfig->channelBorderBottom, 0, 300));      Add(new cMenuEditStraItem(tr("Background Style"), &tmpNopacityConfig->backgroundStyle, 2, bgStyle)); +    Add(new cMenuEditBoolItem(tr("Rounded Corners"), &tmpNopacityConfig->roundedCornersChannel));      Add(new cMenuEditStraItem(tr("Channel Logo Position"), &tmpNopacityConfig->logoPosition, 3, logoPos));      if (tmpNopacityConfig->logoPosition) {          Add(new cMenuEditIntItem(cString::sprintf("%s%s", *spacer, tr("Channel Logo Width")), &tmpNopacityConfig->logoWidth, 30, 500)); diff --git a/textwindow.c b/textwindow.c index a51aa0b..6e55ef9 100644 --- a/textwindow.c +++ b/textwindow.c @@ -58,9 +58,10 @@ bool cNopacityTextWindow::CreatePixmap(int border) {  void cNopacityTextWindow::DrawText(int border) {      int lineHeight = font->Height();      int currentLineHeight = lineHeight/2; +    tColor clrFontBack = (config.doBlending)?(clrTransparent):(Theme.Color(clrMenuBack));      cPixmap::Lock();      for (int i=0; (i < twText.Lines()) && Running(); i++) { -        pixmap->DrawText(cPoint(border, currentLineHeight), twText.GetLine(i), Theme.Color(clrMenuFontDetailViewText), clrTransparent, font); +        pixmap->DrawText(cPoint(border, currentLineHeight), twText.GetLine(i), Theme.Color(clrMenuFontDetailViewText), clrFontBack, font);          currentLineHeight += lineHeight;      }      cPixmap::Unlock();         @@ -158,4 +159,4 @@ void cNopacityTextWindow::Action(void) {                  cCondWait::SleepMs(FrameTime - Delta);          }      } -}
\ No newline at end of file +} diff --git a/themes/nOpacity-darkblue.theme b/themes/nOpacity-darkblue.theme index 4ef3669..2428047 100644 --- a/themes/nOpacity-darkblue.theme +++ b/themes/nOpacity-darkblue.theme @@ -1,4 +1,6 @@  Description = Dark Blue +#DO BLENDING +clrDoBlending = FFFFFFFF  clrChannelBackground = B0000000  clrChannelBackBlend = DD5078ab  clrChannelHead = FFEEEEEE diff --git a/themes/nOpacity-darkred.theme b/themes/nOpacity-darkred.theme index c1df037..0d16e44 100644 --- a/themes/nOpacity-darkred.theme +++ b/themes/nOpacity-darkred.theme @@ -1,4 +1,5 @@  Description = Dark Red +clrDoBlending = FFFFFFFF  clrChannelBackground = CC000000  clrChannelBackBlend = CC333333  clrChannelHead = FFEEEEEE diff --git a/themes/nOpacity-green.theme b/themes/nOpacity-green.theme index 876aa5e..6299d76 100644 --- a/themes/nOpacity-green.theme +++ b/themes/nOpacity-green.theme @@ -1,4 +1,5 @@ -Description = Green  +Description = Green +clrDoBlending = FFFFFFFF  clrChannelBackground = B0000000  clrChannelBackBlend = DD006600  clrChannelHead = FFFFCC00 @@ -117,8 +117,12 @@ void cNopacityTimer::Render(void) {      if (isTimerConflict) {
          pixmapLogo->Fill(clrTransparent);
          pixmap->Fill(Theme.Color(clrDiskAlert));
 -        imgLoader.DrawBackground(Theme.Color(clrDiskAlert), Theme.Color(clrMenuItemHigh), width-2, height-2);
 -        pixmap->DrawImage(cPoint(1,1), imgLoader.GetImage());
 +        if (config.doBlending) {
 +            imgLoader.DrawBackground(Theme.Color(clrDiskAlert), Theme.Color(clrMenuItemHigh), width-2, height-2);
 +            pixmap->DrawImage(cPoint(1,1), imgLoader.GetImage());
 +        } else {
 +            pixmap->DrawRectangle(cRect(1, 1, width-2, height-2), Theme.Color(clrDiskAlert));
 +        }        
          int numLines = showName.Lines();
          int textWidth = 0;
          int x = 0;
 @@ -133,12 +137,20 @@ void cNopacityTimer::Render(void) {          DrawLogo();
          if (timer->Recording()) {
              pixmap->Fill(Theme.Color(clrDiskAlert));
 -            imgLoader.DrawBackground(Theme.Color(clrDiskAlert), Theme.Color(clrMenuItemHigh), width-2, height-2);
 -            pixmap->DrawImage(cPoint(1,1), imgLoader.GetImage());
 +            if (config.doBlending) {
 +                imgLoader.DrawBackground(Theme.Color(clrDiskAlert), Theme.Color(clrMenuItemHigh), width-2, height-2);
 +                pixmap->DrawImage(cPoint(1,1), imgLoader.GetImage());
 +            } else {
 +                pixmap->DrawRectangle(cRect(1, 1, width-2, height-2), Theme.Color(clrDiskAlert));
 +            } 
          } else {
              pixmap->Fill(Theme.Color(clrMenuBorder));
 -            imgLoader.DrawBackground(Theme.Color(clrMenuItemHighBlend), Theme.Color(clrMenuItemHigh), width-2, height-2);
 -            pixmap->DrawImage(cPoint(1,1), imgLoader.GetImage());
 +            if (config.doBlending) {
 +                imgLoader.DrawBackground(Theme.Color(clrMenuItemHighBlend), Theme.Color(clrMenuItemHigh), width-2, height-2);
 +                pixmap->DrawImage(cPoint(1,1), imgLoader.GetImage());
 +            } else {
 +                pixmap->DrawRectangle(cRect(1, 1, width-2, height-2), Theme.Color(clrMenuItemHigh));
 +            } 
          }
          pixmap->DrawText(cPoint(5, config.timersLogoHeight), *Date, Theme.Color(clrMenuFontTimersHeader), clrTransparent, fontLarge);
 | 
