X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/a848baced9e4cd8b5c1e76cafbf93ea032171f9c..9e0b367cd7017f8abf3e3ea804966ce6e23a768f:/lib/service/servicemp3.h diff --git a/lib/service/servicemp3.h b/lib/service/servicemp3.h index bf29efcf..29c1d438 100644 --- a/lib/service/servicemp3.h +++ b/lib/service/servicemp3.h @@ -5,10 +5,16 @@ #include #include #include +#include +#include #include +/* for subtitles */ +#include class eStaticServiceMP3Info; +class eSubtitleWidget; + class eServiceFactoryMP3: public iServiceHandler { DECLARE_REF(eServiceFactoryMP3); @@ -39,8 +45,12 @@ public: typedef struct _GstElement GstElement; +typedef enum { atUnknown, atMPEG, atMP3, atAC3, atDTS, atAAC, atPCM, atOGG, atFLAC } audiotype_t; +typedef enum { stPlainText, stSSA, stSRT } subtype_t; +typedef enum { ctNone, ctMPEGTS, ctMPEGPS, ctMKV, ctAVI, ctMP4, ctVCD, ctCDA } containertype_t; + class eServiceMP3: public iPlayableService, public iPauseableService, - public iServiceInformation, public iSeekableService, public iAudioTrackSelection, public iAudioChannelSelection, public Object + public iServiceInformation, public iSeekableService, public iAudioTrackSelection, public iAudioChannelSelection, public iSubtitleOutput, public iStreamedService, public Object { DECLARE_REF(eServiceMP3); public: @@ -59,17 +69,17 @@ public: RESULT seek(ePtr &ptr); RESULT audioTracks(ePtr &ptr); RESULT audioChannel(ePtr &ptr); + RESULT subtitle(ePtr &ptr); // not implemented (yet) RESULT frontendInfo(ePtr &ptr) { ptr = 0; return -1; } RESULT subServices(ePtr &ptr) { ptr = 0; return -1; } RESULT timeshift(ePtr &ptr) { ptr = 0; return -1; } RESULT cueSheet(ePtr &ptr) { ptr = 0; return -1; } - RESULT subtitle(ePtr &ptr) { ptr = 0; return -1; } RESULT audioDelay(ePtr &ptr) { ptr = 0; return -1; } RESULT rdsDecoder(ePtr &ptr) { ptr = 0; return -1; } - RESULT stream(ePtr &ptr) { ptr = 0; return -1; } RESULT keys(ePtr &ptr) { ptr = 0; return -1; } + RESULT stream(ePtr &ptr) { ptr = 0; return -1; } // iPausableService RESULT pause(); @@ -89,6 +99,7 @@ public: RESULT getName(std::string &name); int getInfo(int w); std::string getInfoString(int w); + PyObject *getInfoObject(int w); // iAudioTrackSelection int getNumberOfTracks(); @@ -100,36 +111,102 @@ public: int getCurrentChannel(); RESULT selectChannel(int i); + // iSubtitleOutput + RESULT enableSubtitles(eWidget *parent, SWIG_PYOBJECT(ePyObject) entry); + RESULT disableSubtitles(eWidget *parent); + PyObject *getSubtitleList(); + PyObject *getCachedSubtitle(); + + // iStreamedService + RESULT streamed(ePtr &ptr); + PyObject *getBufferCharge(); + int setBufferSize(int size); + struct audioStream { GstPad* pad; - enum { atMP2, atMP3, atAC3, atDTS, atAAC }; - int type; // mpeg2, ac3, dts, ... + audiotype_t type; + std::string language_code; /* iso-639, if available. */ + std::string codec; /* clear text codec description */ + audioStream() + :pad(0), type(atUnknown) + { + } + }; + struct subtitleStream + { + GstPad* pad; + subtype_t type; std::string language_code; /* iso-639, if available. */ + subtitleStream() + :pad(0) + { + } + }; + struct sourceStream + { + audiotype_t audiotype; + containertype_t containertype; + bool is_video; + bool is_streaming; + sourceStream() + :audiotype(atUnknown), containertype(ctNone), is_video(FALSE), is_streaming(FALSE) + { + } + }; + struct bufferInfo + { + int bufferPercent; + int avgInRate; + int avgOutRate; + long long bufferingLeft; + bufferInfo() + :bufferPercent(0), avgInRate(0), avgOutRate(0), bufferingLeft(-1) + { + } }; private: int m_currentAudioStream; + int m_currentSubtitleStream; + int selectAudioStream(int i); std::vector m_audioStreams; + std::vector m_subtitleStreams; + eSubtitleWidget *m_subtitle_widget; + int m_currentTrickRatio; + ePtr m_seekTimeout; + void seekTimeoutCB(); friend class eServiceFactoryMP3; - std::string m_filename; - eServiceMP3(const char *filename); + eServiceReference m_ref; + int m_buffer_size; + bufferInfo m_bufferInfo; + eServiceMP3(eServiceReference ref); Signal2 m_event; enum { stIdle, stRunning, stStopped, }; int m_state; - GstElement *m_gst_pipeline; + GstElement *m_gst_playbin; GstTagList *m_stream_tags; eFixedMessagePump m_pump; + std::string m_error_message; + audiotype_t gstCheckAudioPad(GstStructure* structure); void gstBusCall(GstBus *bus, GstMessage *msg); static GstBusSyncReply gstBusSyncHandler(GstBus *bus, GstMessage *message, gpointer user_data); - static void gstCBpadAdded(GstElement *decodebin, GstPad *pad, gpointer data); /* for mpegdemux */ - static void gstCBfilterPadAdded(GstElement *filter, GstPad *pad, gpointer user_data); /* for id3demux */ - static void gstCBnewPad(GstElement *decodebin, GstPad *pad, gboolean last, gpointer data); /* for decodebin */ - static void gstCBunknownType(GstElement *decodebin, GstPad *pad, GstCaps *l, gpointer data); + static void gstCBsubtitleAvail(GstElement *element, gpointer user_data); + GstPad* gstCreateSubtitleSink(eServiceMP3* _this, subtype_t type); void gstPoll(const int&); + + std::list m_subtitle_pages; + ePtr m_subtitle_sync_timer; + void pushSubtitles(); + void pullSubtitle(); + int m_subs_to_pull; + eSingleLock m_subs_to_pull_lock; + + gint m_aspect, m_width, m_height, m_framerate, m_progressive; + RESULT trickSeek(gdouble ratio); }; #endif