summaryrefslogtreecommitdiff
path: root/displaychannel.c
diff options
context:
space:
mode:
Diffstat (limited to 'displaychannel.c')
-rw-r--r--displaychannel.c74
1 files changed, 16 insertions, 58 deletions
diff --git a/displaychannel.c b/displaychannel.c
index a2ef3cff..af8c34b7 100644
--- a/displaychannel.c
+++ b/displaychannel.c
@@ -345,45 +345,23 @@ void cFlatDisplayChannel::SetEvents(const cEvent *Present, const cEvent *Followi
epg = Present->Title();
epgShort = Present->ShortText();
- /*
- if( epgWidth > channelWidth - left - timeStringWidth) {
- int dotsWidth = font->Width("... ");
- cTextWrapper epgInfoWrapper(Present->Title(), font, channelWidth - left - timeStringWidth - dotsWidth);
- epg = epgInfoWrapper.GetLine(0);
- epg = cString::sprintf("%s...", *epg);
- epgWidth = font->Width(*epg);
- if( Present->HasTimer() ) {
- isRec = true;
- epgWidth += marginItem + RecWidth;
- }
- } else {
- epg = Present->Title();
- }
+ int maxWidth = max(timeStringWidth, seenWidth);
- if( epgShortWidth > channelWidth - left - seenWidth) {
- int dotsWidth = fontSml->Width("... ");
- cTextWrapper epgInfoWrapper(Present->ShortText(), fontSml, channelWidth - left - timeStringWidth - dotsWidth);
- epgShort = epgInfoWrapper.GetLine(0);
- epgShort = cString::sprintf("%s...", *epgShort);
- } else {
- epgShort = Present->ShortText();
- }
- */
chanInfoBottomPixmap->DrawText(cPoint(channelWidth - timeStringWidth - marginItem * 2, 0), *timeString,
Theme.Color(clrChannelFontEpg), Theme.Color(clrChannelBg), fontSml, timeStringWidth, 0, taRight);
chanInfoBottomPixmap->DrawText(cPoint(channelWidth - seenWidth - marginItem * 2, fontSmlHeight), *seen,
Theme.Color(clrChannelFontEpg), Theme.Color(clrChannelBg), fontSml, seenWidth, 0, taRight);
- if( (epgWidth > channelWidth - left - timeStringWidth) && Config.ScrollerEnable ) {
- scrollers.AddScroller(*epg, cRect(Config.decorBorderChannelSize + left, Config.decorBorderChannelSize+channelHeight - heightBottom, channelWidth - left - timeStringWidth, fontHeight), Theme.Color(clrChannelFontEpg), clrTransparent, font);
+ if( (epgWidth > channelWidth - left - maxWidth) && Config.ScrollerEnable ) {
+ scrollers.AddScroller(*epg, cRect(Config.decorBorderChannelSize + left, Config.decorBorderChannelSize+channelHeight - heightBottom, channelWidth - left - maxWidth, fontHeight), Theme.Color(clrChannelFontEpg), clrTransparent, font);
} else {
- chanInfoBottomPixmap->DrawText(cPoint(left, 0), *epg, Theme.Color(clrChannelFontEpg), Theme.Color(clrChannelBg), font, channelWidth - left - timeStringWidth);
+ chanInfoBottomPixmap->DrawText(cPoint(left, 0), *epg, Theme.Color(clrChannelFontEpg), Theme.Color(clrChannelBg), font, channelWidth - left - maxWidth);
}
- if( (epgShortWidth > channelWidth - left - seenWidth) && Config.ScrollerEnable ) {
- scrollers.AddScroller(*epgShort, cRect(Config.decorBorderChannelSize + left, Config.decorBorderChannelSize+channelHeight - heightBottom + fontHeight, channelWidth - left - seenWidth, fontSmlHeight), Theme.Color(clrChannelFontEpg), clrTransparent, fontSml);
+ if( (epgShortWidth > channelWidth - left - maxWidth) && Config.ScrollerEnable ) {
+ scrollers.AddScroller(*epgShort, cRect(Config.decorBorderChannelSize + left, Config.decorBorderChannelSize+channelHeight - heightBottom + fontHeight, channelWidth - left - maxWidth, fontSmlHeight), Theme.Color(clrChannelFontEpg), clrTransparent, fontSml);
} else {
- chanInfoBottomPixmap->DrawText(cPoint(left, fontHeight), *epgShort, Theme.Color(clrChannelFontEpg), Theme.Color(clrChannelBg), fontSml, channelWidth - left - seenWidth);
+ chanInfoBottomPixmap->DrawText(cPoint(left, fontHeight), *epgShort, Theme.Color(clrChannelFontEpg), Theme.Color(clrChannelBg), fontSml, channelWidth - left - maxWidth);
}
if( isRec ) {
@@ -411,48 +389,28 @@ void cFlatDisplayChannel::SetEvents(const cEvent *Present, const cEvent *Followi
cString dur = cString::sprintf("%d min", Following->Duration() / 60);
int durWidth = fontSml->Width(*dur) + fontSml->Width(" ");
+ int maxWidth = max(timeStringWidth, durWidth);
+
epg = Following->Title();
epgShort = Following->ShortText();
-/*
- if( epgWidth > channelWidth - left - timeStringWidth ) {
- int dotsWidth = font->Width("... ");
- cTextWrapper epgInfoWrapper(Following->Title(), font, channelWidth - left - timeStringWidth - dotsWidth);
- epg = epgInfoWrapper.GetLine(0);
- epg = cString::sprintf("%s...", *epg);
- epgWidth = font->Width(*epg);
- if( Following->HasTimer() ) {
- isRec = true;
- epgWidth += marginItem + RecWidth;
- }
- } else {
- epg = Following->Title();
- }
- if (epgShortWidth > channelWidth - left - durWidth ) {
- int dotsWidth = fontSml->Width("... ");
- cTextWrapper epgInfoWrapper(Following->ShortText(), fontSml, channelWidth - left - timeStringWidth - dotsWidth);
- epgShort = epgInfoWrapper.GetLine(0);
- epgShort = cString::sprintf("%s...", *epgShort);
- } else {
- epgShort = Following->ShortText();
- }
-*/
+
chanInfoBottomPixmap->DrawText(cPoint(channelWidth - timeStringWidth - marginItem * 2, fontHeight + fontSmlHeight), *timeString,
Theme.Color(clrChannelFontEpgFollow), Theme.Color(clrChannelBg), fontSml, timeStringWidth, 0, taRight);
chanInfoBottomPixmap->DrawText(cPoint(channelWidth - durWidth - marginItem * 2, fontHeight + fontSmlHeight*2), *dur,
Theme.Color(clrChannelFontEpgFollow), Theme.Color(clrChannelBg), fontSml, durWidth, 0, taRight);
- if( (epgWidth > channelWidth - left - timeStringWidth) && Config.ScrollerEnable ) {
- scrollers.AddScroller(*epg, cRect(Config.decorBorderChannelSize + left, Config.decorBorderChannelSize+channelHeight - heightBottom + fontHeight + fontSmlHeight, channelWidth - left - timeStringWidth, fontHeight), Theme.Color(clrChannelFontEpg), clrTransparent, font);
+ if( (epgWidth > channelWidth - left - maxWidth) && Config.ScrollerEnable ) {
+ scrollers.AddScroller(*epg, cRect(Config.decorBorderChannelSize + left, Config.decorBorderChannelSize+channelHeight - heightBottom + fontHeight + fontSmlHeight, channelWidth - left - maxWidth, fontHeight), Theme.Color(clrChannelFontEpgFollow), clrTransparent, font);
} else {
chanInfoBottomPixmap->DrawText(cPoint(left, fontHeight + fontSmlHeight), *epg,
- Theme.Color(clrChannelFontEpgFollow), Theme.Color(clrChannelBg), font, channelWidth - left - timeStringWidth);
+ Theme.Color(clrChannelFontEpgFollow), Theme.Color(clrChannelBg), font, channelWidth - left - maxWidth);
}
- if( (epgShortWidth > channelWidth - left - durWidth) && Config.ScrollerEnable ) {
- scrollers.AddScroller(*epgShort, cRect(Config.decorBorderChannelSize + left, Config.decorBorderChannelSize+channelHeight - heightBottom + fontHeight*2 + fontSmlHeight, channelWidth - left - durWidth, fontSmlHeight), Theme.Color(clrChannelFontEpg), clrTransparent, fontSml);
+ if( (epgShortWidth > channelWidth - left - maxWidth) && Config.ScrollerEnable ) {
+ scrollers.AddScroller(*epgShort, cRect(Config.decorBorderChannelSize + left, Config.decorBorderChannelSize+channelHeight - heightBottom + fontHeight*2 + fontSmlHeight, channelWidth - left - maxWidth, fontSmlHeight), Theme.Color(clrChannelFontEpgFollow), clrTransparent, fontSml);
} else {
chanInfoBottomPixmap->DrawText(cPoint(left, fontHeight*2 + fontSmlHeight), *epgShort,
- Theme.Color(clrChannelFontEpgFollow), Theme.Color(clrChannelBg), fontSml, channelWidth - left - durWidth);
+ Theme.Color(clrChannelFontEpgFollow), Theme.Color(clrChannelBg), fontSml, channelWidth - left - maxWidth);
}
if( isRec ) {