X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/740ae9b4a03c13901e4f4ffc008e4c0cfd63d896..191cade7c45bee53df2776ff5bb3f26b2cdafc12:/lib/dvb/decoder.h diff --git a/lib/dvb/decoder.h b/lib/dvb/decoder.h index fb543fed..bceca040 100644 --- a/lib/dvb/decoder.h +++ b/lib/dvb/decoder.h @@ -9,7 +9,7 @@ class eDVBAudio: public iObject DECLARE_REF(eDVBAudio); private: ePtr m_demux; - int m_fd, m_fd_demux; + int m_fd, m_fd_demux, m_dev; public: enum {aMPEG, aAC3, aDTS }; eDVBAudio(eDVBDemux *demux, int dev); @@ -22,6 +22,7 @@ public: void flush(); void freeze(); void unfreeze(); + int getPTS(pts_t &now); virtual ~eDVBAudio(); }; @@ -30,7 +31,7 @@ class eDVBVideo: public iObject DECLARE_REF(eDVBVideo); private: ePtr m_demux; - int m_fd, m_fd_demux; + int m_fd, m_fd_demux, m_dev; int m_is_slow_motion, m_is_fast_forward; public: @@ -46,6 +47,7 @@ public: int setSlowMotion(int repeat); int setFastForward(int skip); void unfreeze(); + int getPTS(pts_t &now); virtual ~eDVBVideo(); }; @@ -62,6 +64,19 @@ public: virtual ~eDVBPCR(); }; +class eDVBTText: public iObject +{ +DECLARE_REF(eDVBTText); +private: + ePtr m_demux; + int m_fd_demux; +public: + eDVBTText(eDVBDemux *demux); + int startPid(int pid); + void stop(); + virtual ~eDVBTText(); +}; + class eTSMPEGDecoder: public Object, public iTSMPEGDecoder { DECLARE_REF(eTSMPEGDecoder); @@ -70,14 +85,16 @@ private: ePtr m_audio; ePtr m_video; ePtr m_pcr; - int m_vpid, m_apid, m_atype, m_pcrpid; + ePtr m_text; + int m_vpid, m_apid, m_atype, m_pcrpid, m_textpid; enum { changeVideo = 1, changeAudio = 2, - changePCR = 4 + changePCR = 4, + changeText = 8 }; - int m_changed; + int m_changed, m_decoder; int m_is_ff, m_is_sm, m_is_trickmode; int setState(); ePtr m_demux_event; @@ -90,6 +107,7 @@ public: RESULT setVideoPID(int vpid); RESULT setAudioPID(int apid, int type); RESULT setSyncPCR(int pcrpid); + RESULT setTextPID(int textpid); RESULT setSyncMaster(int who); RESULT start(); RESULT freeze(int cont); @@ -101,5 +119,9 @@ public: RESULT setZoom(int what); RESULT flush(); RESULT setTrickmode(int what); + + /* what 0=auto, 1=video, 2=audio. */ + RESULT getPTS(int what, pts_t &pts); }; + #endif