X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/d101ae667283bfd67a287556fcc3cf468539102a..b19b6c15482681e331f346acb56b1566102e1418:/lib/gui/esubtitle.cpp diff --git a/lib/gui/esubtitle.cpp b/lib/gui/esubtitle.cpp index 80211b4d..c837afc6 100644 --- a/lib/gui/esubtitle.cpp +++ b/lib/gui/esubtitle.cpp @@ -11,12 +11,12 @@ */ eSubtitleWidget::eSubtitleWidget(eWidget *parent) - : eWidget(parent), m_hide_subtitles_timer(eApp) + : eWidget(parent), m_hide_subtitles_timer(eTimer::create(eApp)) { setBackgroundColor(gRGB(0,0,0,255)); m_page_ok = 0; m_dvb_page_ok = 0; - CONNECT(m_hide_subtitles_timer.timeout, eSubtitleWidget::clearPage); + CONNECT(m_hide_subtitles_timer->timeout, eSubtitleWidget::clearPage); } #define startX 50 @@ -46,7 +46,7 @@ void eSubtitleWidget::setPage(const eDVBTeletextSubtitlePage &p) m_visible_region.rects.push_back(area); } } - m_hide_subtitles_timer.start(7500, true); + m_hide_subtitles_timer->start(7500, true); invalidate(m_visible_region); // invalidate new regions } @@ -62,7 +62,38 @@ void eSubtitleWidget::setPage(const eDVBSubtitlePage &p) m_visible_region.rects.push_back(eRect(it->m_position, it->m_pixmap->size())); } m_dvb_page_ok = 1; - m_hide_subtitles_timer.start(7500, true); + m_hide_subtitles_timer->start(7500, true); + invalidate(m_visible_region); // invalidate new regions +} + +void eSubtitleWidget::setPage(const ePangoSubtitlePage &p) +{ + m_pango_page = p; + m_pango_page_ok = 1; + invalidate(m_visible_region); // invalidate old visible regions + m_visible_region.rects.clear(); + + int elements = m_pango_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; istart(timeout_ms, true); invalidate(m_visible_region); // invalidate new regions } @@ -71,6 +102,7 @@ void eSubtitleWidget::clearPage() eDebug("subtitle timeout... hide"); m_page_ok = 0; m_dvb_page_ok = 0; + m_pango_page_ok = 0; invalidate(m_visible_region); m_visible_region.rects.clear(); } @@ -81,6 +113,15 @@ void eSubtitleWidget::setPixmap(ePtr &pixmap, gRegion changed) invalidate(changed); } +std::string eSubtitleWidget::replace_all(const std::string &in, const std::string &entity, const std::string &symbol) +{ + std::string out = in; + std::string::size_type loc = 0; + while (( loc = out.find(entity, loc)) != std::string::npos ) + out.replace(loc, entity.length(), symbol); + return out; +} + int eSubtitleWidget::event(int event, void *data, void *data2) { switch (event) @@ -112,6 +153,45 @@ int eSubtitleWidget::event(int event, void *data, void *data2) painter.renderText(area, element.m_text, gPainter::RT_WRAP|gPainter::RT_VALIGN_CENTER|gPainter::RT_HALIGN_CENTER); } } + else if (m_pango_page_ok) + { + int elements = m_pango_page.m_elements.size(); + ePtr font = new gFont("Regular", 38); + for (int i=0; i::iterator it(m_dvb_page.m_regions.begin()); it != m_dvb_page.m_regions.end(); ++it)