X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/2adbe932b3f5e51050bdac0f09c5bfddffec27a7..337572d8d61c37c2121a96ec7ab79e191eaa2e29:/lib/service/servicemp3.h diff --git a/lib/service/servicemp3.h b/lib/service/servicemp3.h index 5b2a3be5..5e706e9b 100644 --- a/lib/service/servicemp3.h +++ b/lib/service/servicemp3.h @@ -43,6 +43,10 @@ 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 iSubtitleOutput, public Object { @@ -113,7 +117,7 @@ public: struct audioStream { GstPad* pad; - enum { atUnknown, atMP2, atMP3, atAC3, atDTS, atAAC, atPCM, atOGG } type; + audiotype_t type; std::string language_code; /* iso-639, if available. */ audioStream() :pad(0), type(atUnknown) @@ -122,8 +126,24 @@ public: }; struct subtitleStream { - GstElement* element; + 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) + { + } }; private: int m_currentAudioStream; @@ -133,8 +153,8 @@ private: std::vector m_subtitleStreams; eSubtitleWidget *m_subtitle_widget; int m_currentTrickRatio; - eTimer m_seekTimeout; - void eServiceMP3::seekTimeoutCB(); + ePtr m_seekTimeout; + void seekTimeoutCB(); friend class eServiceFactoryMP3; std::string m_filename; eServiceMP3(const char *filename); @@ -147,7 +167,9 @@ private: GstElement *m_gst_pipeline; 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 */ @@ -155,7 +177,10 @@ private: 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, GstBuffer *buffer, GstPad *pad, gpointer user_data); + static void gstCBsubtitlePadEvent(GstPad *pad, GstEvent *event, gpointer user_data); + GstPad* gstCreateSubtitleSink(eServiceMP3* _this, subtype_t type); void gstPoll(const int&); + gint m_aspect, m_width, m_height, m_framerate, m_progressive; }; #endif