summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--HISTORY2
-rw-r--r--config.c4
-rw-r--r--config.h3
-rw-r--r--displaychannel.c59
-rw-r--r--displaymenu.c19
-rw-r--r--displaymenuview.c40
-rw-r--r--displaymenuview.h2
-rw-r--r--displaymessage.c10
-rw-r--r--displayreplay.c25
-rw-r--r--displaytracks.c18
-rw-r--r--displayvolume.c10
-rw-r--r--menuitem.c161
-rw-r--r--menuitem.h9
-rw-r--r--nopacity.c8
-rw-r--r--po/de_DE.po5
-rw-r--r--po/it_IT.po5
-rw-r--r--po/sk_SK.po5
-rw-r--r--setup.c2
-rw-r--r--textwindow.c5
-rw-r--r--themes/nOpacity-darkblue.theme2
-rw-r--r--themes/nOpacity-darkred.theme1
-rw-r--r--themes/nOpacity-green.theme3
-rw-r--r--timers.c24
23 files changed, 286 insertions, 136 deletions
diff --git a/HISTORY b/HISTORY
index b5b97da..70eb623 100644
--- a/HISTORY
+++ b/HISTORY
@@ -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
diff --git a/config.c b/config.c
index dc00700..897bb26 100644
--- a/config.c
+++ b/config.c
@@ -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);
diff --git a/config.h b/config.h
index 5e7b08b..7e7b6ea 100644
--- a/config.h
+++ b/config.h
@@ -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);
diff --git a/menuitem.c b/menuitem.c
index eca200e..bc10645 100644
--- a/menuitem.c
+++ b/menuitem.c
@@ -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);
}
diff --git a/menuitem.h b/menuitem.h
index bc59cd2..bf3b0eb 100644
--- a/menuitem.h
+++ b/menuitem.h
@@ -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;
diff --git a/nopacity.c b/nopacity.c
index 208cb22..d9e9595 100644
--- a/nopacity.c
+++ b/nopacity.c
@@ -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"
diff --git a/setup.c b/setup.c
index f70a45a..0048f34 100644
--- a/setup.c
+++ b/setup.c
@@ -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
diff --git a/timers.c b/timers.c
index 2199a72..930df48 100644
--- a/timers.c
+++ b/timers.c
@@ -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);