X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/0e7fc97cfaaecf1b7fc93a73157a6a380e9058f4..5e214d181d1590e0002eabdc6f8395cd6ddde2a7:/lib/gui/esubtitle.cpp diff --git a/lib/gui/esubtitle.cpp b/lib/gui/esubtitle.cpp index f859c170..376fa24d 100644 --- a/lib/gui/esubtitle.cpp +++ b/lib/gui/esubtitle.cpp @@ -10,13 +10,16 @@ .... */ +eSubtitleWidget::eSubtitleStyle eSubtitleWidget::subtitleStyles[Subtitle_MAX]; + 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); + m_pango_page_ok = 0; + CONNECT(m_hide_subtitles_timer->timeout, eSubtitleWidget::clearPage); } #define startX 50 @@ -46,7 +49,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 +65,7 @@ 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 } @@ -93,7 +96,7 @@ void eSubtitleWidget::setPage(const ePangoSubtitlePage &p) } } int timeout_ms = m_pango_page.m_timeout; - m_hide_subtitles_timer.start(timeout_ms, true); + m_hide_subtitles_timer->start(timeout_ms, true); invalidate(m_visible_region); // invalidate new regions } @@ -113,15 +116,6 @@ 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) @@ -139,42 +133,42 @@ int eSubtitleWidget::event(int event, void *data, void *data2) else if (m_page_ok) { int elements = m_page.m_elements.size(); - ePtr font = new gFont("Regular", 38); - painter.setFont(font); + painter.setFont(subtitleStyles[Subtitle_TTX].font); for (int i=0; i font = new gFont("Regular", 38); + subfont_t face; + for (int i=0; i