X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/0c59a4279f93f08fe95fca5f2e55f3e025f0cceb..ecc23dd3be5128650082a594b7e2939922d7462c:/lib/gui/esubtitle.cpp diff --git a/lib/gui/esubtitle.cpp b/lib/gui/esubtitle.cpp index c837afc6..bf0239df 100644 --- a/lib/gui/esubtitle.cpp +++ b/lib/gui/esubtitle.cpp @@ -10,12 +10,15 @@ .... */ +eSubtitleWidget::eSubtitleStyle eSubtitleWidget::subtitleStyles[Subtitle_MAX]; + eSubtitleWidget::eSubtitleWidget(eWidget *parent) : eWidget(parent), m_hide_subtitles_timer(eTimer::create(eApp)) { setBackgroundColor(gRGB(0,0,0,255)); m_page_ok = 0; m_dvb_page_ok = 0; + m_pango_page_ok = 0; CONNECT(m_hide_subtitles_timer->timeout, eSubtitleWidget::clearPage); } @@ -110,18 +113,12 @@ void eSubtitleWidget::clearPage() void eSubtitleWidget::setPixmap(ePtr &pixmap, gRegion changed) { m_pixmap = pixmap; + + changed.scale(size().width(), pixmap->size().width(), size().height(), pixmap->size().height()); + 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) @@ -135,46 +132,46 @@ int eSubtitleWidget::event(int event, void *data, void *data2) eWidget::event(event, data, data2); if (m_pixmap) - painter.blit(m_pixmap, ePoint(0,0)); + painter.blitScale(m_pixmap, eRect(ePoint(0, 0), size())); 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::iterator it(m_dvb_page.m_regions.begin()); it != m_dvb_page.m_regions.end(); ++it) - painter.blit(it->m_pixmap, it->m_position); + { + /* dvb subtitles are living in their 720x576 cage... i think. check this for HD. */ + eRect r = eRect(it->m_position, it->m_pixmap->size()); + r.scale(size().width(), 720, size().height(), 576); + painter.blitScale(it->m_pixmap, r); + } } return 0; } @@ -203,3 +208,13 @@ int eSubtitleWidget::event(int event, void *data, void *data2) return eWidget::event(event, data, data2); } } + +void eSubtitleWidget::setFontStyle(subfont_t face, gFont *font, int haveColor, const gRGB &col, const gRGB &shadowCol, const ePoint &shadowOffset) +{ + subtitleStyles[face].font = font; + subtitleStyles[face].have_foreground_color = haveColor; + subtitleStyles[face].foreground_color = col; + subtitleStyles[face].shadow_color = shadowCol; + subtitleStyles[face].shadow_offset = shadowOffset; +} +