From d205df8517cabea52bb2a9c7c3a2d1f706e38553 Mon Sep 17 00:00:00 2001 From: Andreas Monzner Date: Thu, 24 Nov 2005 19:27:32 +0000 Subject: [PATCH] show current running event title in favourites service list --- lib/python/Components/ServiceList.py | 7 +-- lib/service/listboxservice.cpp | 76 +++++++++++++++++++++------- lib/service/listboxservice.h | 8 +-- 3 files changed, 67 insertions(+), 24 deletions(-) diff --git a/lib/python/Components/ServiceList.py b/lib/python/Components/ServiceList.py index e0a31534..d39e7427 100644 --- a/lib/python/Components/ServiceList.py +++ b/lib/python/Components/ServiceList.py @@ -93,8 +93,9 @@ class ServiceList(HTMLComponent, GUIComponent): self.l.setElementPosition(self.l.celServiceName, eRect(0, 0, self.instance.size().width(), 28)) else: self.instance.setItemHeight(28) - self.l.setElementFont(self.l.celServiceName, gFont("Arial", 22)) - self.l.setElementPosition(self.l.celServiceName, eRect(50, 0, self.instance.size().width(), 28)) self.l.setElementFont(self.l.celServiceNumber, gFont("Arial", 20)) - self.l.setElementPosition(self.l.celServiceNumber, eRect(0, 2, 50, 28)) + self.l.setElementPosition(self.l.celServiceNumber, eRect(0, 0, 40, 28)) + self.l.setElementFont(self.l.celServiceName, gFont("Arial", 22)) + self.l.setElementPosition(self.l.celServiceName, eRect(50, 0, self.instance.size().width()-50, 28)) + self.l.setElementFont(self.l.celServiceInfo, gFont("Arial", 18)) self.l.setVisualMode(eListboxServiceContent.visModeComplex) diff --git a/lib/service/listboxservice.cpp b/lib/service/listboxservice.cpp index fe690608..9eafc853 100644 --- a/lib/service/listboxservice.cpp +++ b/lib/service/listboxservice.cpp @@ -1,5 +1,7 @@ #include #include +#include +#include void eListboxServiceContent::setRoot(const eServiceReference &root) { @@ -136,7 +138,7 @@ void eListboxServiceContent::sort() DEFINE_REF(eListboxServiceContent); eListboxServiceContent::eListboxServiceContent() - :m_visual_mode(visModeSimple), m_size(0), m_current_marked(false), m_numberoffset(0) + :epgcache(eEPGCache::getInstance()), m_visual_mode(visModeSimple), m_size(0), m_current_marked(false), m_numberoffset(0) { cursorHome(); eServiceCenter::getInstance(m_service_center); @@ -324,38 +326,76 @@ void eListboxServiceContent::paint(gPainter &painter, eWindowStyle &style, const { if (!m_element_font[e]) continue; - painter.setFont(m_element_font[e]); - + int flags=gPainter::RT_VALIGN_CENTER; + + eRect area = m_element_position[e]; + std::string text = ""; - + switch (e) { - case celServiceName: - { - if (service_info) - service_info->getName(*m_cursor, text); - break; - } + case celIcon: + // render icon here... + continue; case celServiceNumber: { char bla[10]; sprintf(bla, "%d", m_numberoffset + m_cursor_number + 1); text = bla; + flags|=gPainter::RT_HALIGN_RIGHT; + break; + } + case celServiceName: + { + if (service_info) + service_info->getName(*m_cursor, text); break; } case celServiceInfo: { - text = "now&next"; + ePtr evt; + time_t t=-1; + if ( !epgcache->lookupEventTime(*m_cursor, t, evt) ) + text = '(' + evt->getEventName() + ')'; + else + continue; break; } - case celIcon: - continue; } - - eRect area = m_element_position[e]; - area.moveBy(offset.x(), offset.y()); - - painter.renderText(area, text); + + eTextPara *para = new eTextPara(area); + + para->setFont(m_element_font[e]); + para->renderString(text); + + if (e == celServiceName) + { + eRect bbox = para->getBoundBox(); + int name_width = bbox.width()+10; + m_element_position[celServiceInfo].setLeft(area.left()+name_width); + m_element_position[celServiceInfo].setTop(area.top()); + m_element_position[celServiceInfo].setWidth(area.width()-name_width); + m_element_position[celServiceInfo].setHeight(area.height()); + } + + if (flags & gPainter::RT_HALIGN_RIGHT) + para->realign(eTextPara::dirRight); + else if (flags & gPainter::RT_HALIGN_CENTER) + para->realign(eTextPara::dirCenter); + else if (flags & gPainter::RT_HALIGN_BLOCK) + para->realign(eTextPara::dirBlock); + + ePoint offs = offset; + + if (flags & gPainter::RT_VALIGN_CENTER) + { + eRect bbox = para->getBoundBox(); + int vcentered_top = (area.height() - bbox.height()) / 2; + int correction = vcentered_top - bbox.top(); + offs += ePoint(0, correction); + } + + painter.renderPara(para, offs); } if (selected) diff --git a/lib/service/listboxservice.h b/lib/service/listboxservice.h index dde08188..1d5dc2a2 100644 --- a/lib/service/listboxservice.h +++ b/lib/service/listboxservice.h @@ -3,12 +3,14 @@ #include #include - #include +class eEPGCache; + class eListboxServiceContent: public virtual iListboxContent { DECLARE_REF(eListboxServiceContent); + eEPGCache *epgcache; public: eListboxServiceContent(); void setRoot(const eServiceReference &ref); @@ -36,9 +38,9 @@ public: /* only in complex mode: */ enum { - celServiceName, - celServiceNumber, celIcon, + celServiceNumber, + celServiceName, celServiceInfo, // "now" event celElements }; -- 2.30.2