X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/3ecd3b8d7f2d52fd7b5956c1fe08f926cc2a2858..d101ae667283bfd67a287556fcc3cf468539102a:/lib/gui/esubtitle.cpp diff --git a/lib/gui/esubtitle.cpp b/lib/gui/esubtitle.cpp index f0b899f7..80211b4d 100644 --- a/lib/gui/esubtitle.cpp +++ b/lib/gui/esubtitle.cpp @@ -1,5 +1,6 @@ #include #include +#include /* ok, here's much room for improvements. @@ -10,32 +11,74 @@ */ eSubtitleWidget::eSubtitleWidget(eWidget *parent) - : eWidget(parent) + : eWidget(parent), m_hide_subtitles_timer(eApp) { setBackgroundColor(gRGB(0,0,0,255)); m_page_ok = 0; m_dvb_page_ok = 0; + CONNECT(m_hide_subtitles_timer.timeout, eSubtitleWidget::clearPage); } +#define startX 50 void eSubtitleWidget::setPage(const eDVBTeletextSubtitlePage &p) { m_page = p; m_page_ok = 1; - invalidate(); + invalidate(m_visible_region); // invalidate old visible regions + m_visible_region.rects.clear(); + + int elements = m_page.m_elements.size(); + if (elements) + { + int startY = elements > 1 + ? size().height() / 2 + : size().height() / 3 * 2; + int width = size().width() - startX * 2; + int height = size().height() - startY; + int size_per_element = height / (elements ? elements : 1); + for (int i=0; i::iterator it(m_dvb_page.m_regions.begin()); it != m_dvb_page.m_regions.end(); ++it) + { + eDebug("add %d %d %d %d", it->m_position.x(), it->m_position.y(), it->m_pixmap->size().width(), it->m_pixmap->size().height()); + m_visible_region.rects.push_back(eRect(it->m_position, it->m_pixmap->size())); + } m_dvb_page_ok = 1; - invalidate(); + m_hide_subtitles_timer.start(7500, true); + invalidate(m_visible_region); // invalidate new regions } void eSubtitleWidget::clearPage() { + eDebug("subtitle timeout... hide"); m_page_ok = 0; m_dvb_page_ok = 0; - invalidate(); + invalidate(m_visible_region); + m_visible_region.rects.clear(); +} + +void eSubtitleWidget::setPixmap(ePtr &pixmap, gRegion changed) +{ + m_pixmap = pixmap; + invalidate(changed); } int eSubtitleWidget::event(int event, void *data, void *data2) @@ -48,36 +91,31 @@ int eSubtitleWidget::event(int event, void *data, void *data2) gPainter &painter = *(gPainter*)data2; getStyle(style); - eWidget::event(event, data, data2); - ePtr font = new gFont("Regular", 30); - painter.setFont(font); - -/* if (!m_page_ok && !m_dvb_page_ok) - painter.renderText(eRect(ePoint(0, 0), size()), "waiting for subtitles...", gPainter::RT_WRAP); - else */if (m_page_ok) + + if (m_pixmap) + painter.blit(m_pixmap, ePoint(0,0)); + else if (m_page_ok) { int elements = m_page.m_elements.size(); - int height = size().height(); - int size_per_element = height / (elements ? elements : 1); + ePtr font = new gFont("Regular", 38); + painter.setFont(font); for (int i=0; i::iterator it(m_dvb_page.m_regions.begin()); it != m_dvb_page.m_regions.end(); ++it) - { - painter.resetClip(eRect(it->m_position, it->m_pixmap->size())); painter.blit(it->m_pixmap, it->m_position); - } } return 0; }