X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/dc5b3144665e827fccf38fcab1c167e6dacdac7a..36dc37e5d0c9ef8fc5f923ad38ee6cc98f316556:/lib/service/servicedvb.cpp diff --git a/lib/service/servicedvb.cpp b/lib/service/servicedvb.cpp index de4f84ee..3b111510 100644 --- a/lib/service/servicedvb.cpp +++ b/lib/service/servicedvb.cpp @@ -27,7 +27,7 @@ #include -// #define INTERNAL_TELETEXT +#define INTERNAL_TELETEXT #ifndef BYTE_ORDER #error no byte order defined! @@ -646,6 +646,8 @@ eDVBServicePlay::eDVBServicePlay(const eServiceReference &ref, eDVBService *serv m_cutlist_enabled = 1; m_subtitle_widget = 0; + + CONNECT(m_subtitle_sync_timer.timeout, eDVBServicePlay::checkSubtitleTiming); } eDVBServicePlay::~eDVBServicePlay() @@ -1843,13 +1845,23 @@ void eDVBServicePlay::cutlistToCuesheet() m_cue->commitSpans(); } -RESULT eDVBServicePlay::enableSubtitles(eWidget *parent, int index) +RESULT eDVBServicePlay::enableSubtitles(eWidget *parent, PyObject *entry) { if (m_subtitle_widget) disableSubtitles(parent); + if (!m_teletext_parser) + return -1; + + if (!PyInt_Check(entry)) + return -1; + m_subtitle_widget = new eSubtitleWidget(parent); m_subtitle_widget->resize(parent->size()); /* full size */ + + int page = PyInt_AsLong(entry); + + m_teletext_parser->setPage(page); return 0; } @@ -1861,16 +1873,75 @@ RESULT eDVBServicePlay::disableSubtitles(eWidget *parent) return 0; } -RESULT eDVBServicePlay::getSubtitleList(PyList *list) +PyObject *eDVBServicePlay::getSubtitleList() { - return -1; + if (!m_teletext_parser) + { + Py_INCREF(Py_None); + return Py_None; + } + + PyObject *l = PyList_New(0); + + for (std::set::iterator i(m_teletext_parser->m_found_subtitle_pages.begin()); i != m_teletext_parser->m_found_subtitle_pages.end(); ++i) + { + PyObject *tuple = PyTuple_New(2); + char desc[20]; + sprintf(desc, "Page %x", *i); + PyTuple_SetItem(tuple, 0, PyString_FromString(desc)); + PyTuple_SetItem(tuple, 1, PyInt_FromLong(*i)); + PyList_Append(l, tuple); + } + + return l; } void eDVBServicePlay::newSubtitlePage(const eDVBTeletextSubtitlePage &page) { - eDebug("new subtitle page received!"); if (m_subtitle_widget) - m_subtitle_widget->addPage(page); + { + m_subtitle_pages.push_back(page); + + checkSubtitleTiming(); + } +} + +void eDVBServicePlay::checkSubtitleTiming() +{ + while (1) + { + if (m_subtitle_pages.empty()) + return; + + eDVBTeletextSubtitlePage p = m_subtitle_pages.front(); + + pts_t pos = 0; + + if (m_decoder) + m_decoder->getPTS(0, pos); + + int diff = p.m_pts - pos; + if (diff < 0) + { + eDebug("[late (%d ms)]", -diff / 90); + diff = 0; + } + if (diff > 900000) + { + eDebug("[invalid]"); + diff = 0; + } + + if (!diff) + { + m_subtitle_widget->setPage(p); + m_subtitle_pages.pop_front(); + } else + { + m_subtitle_sync_timer.start(diff / 90, 1); + break; + } + } } DEFINE_REF(eDVBServicePlay)