git.cweiske.de
/
enigma2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
more complete implementation of national option character subsets
[enigma2.git]
/
lib
/
dvb
/
decoder.h
diff --git
a/lib/dvb/decoder.h
b/lib/dvb/decoder.h
index d1f040ec180852f8d2abacbefd5c1ebd1cdae0e1..8e8f65ad9fce3097c8cbacbcfbfcd228dbcd91bd 100644
(file)
--- a/
lib/dvb/decoder.h
+++ b/
lib/dvb/decoder.h
@@
-9,11
+9,13
@@
class eDVBAudio: public iObject
DECLARE_REF(eDVBAudio);
private:
ePtr<eDVBDemux> m_demux;
DECLARE_REF(eDVBAudio);
private:
ePtr<eDVBDemux> m_demux;
- int m_fd, m_fd_demux;
+ int m_fd, m_fd_demux
, m_dev
;
public:
public:
- enum {
aMPEG, aAC3, aDTS
};
+ enum {
aMPEG, aAC3, aDTS, aAAC
};
eDVBAudio(eDVBDemux *demux, int dev);
int startPid(int pid, int type);
eDVBAudio(eDVBDemux *demux, int dev);
int startPid(int pid, int type);
+ enum { aMonoLeft, aStereo, aMonoRight };
+ void setChannel(int channel);
void stop();
#if HAVE_DVB_API_VERSION < 3
void start();
void stop();
#if HAVE_DVB_API_VERSION < 3
void start();
@@
-22,6
+24,7
@@
public:
void flush();
void freeze();
void unfreeze();
void flush();
void freeze();
void unfreeze();
+ int getPTS(pts_t &now);
virtual ~eDVBAudio();
};
virtual ~eDVBAudio();
};
@@
-30,12
+33,13
@@
class eDVBVideo: public iObject
DECLARE_REF(eDVBVideo);
private:
ePtr<eDVBDemux> m_demux;
DECLARE_REF(eDVBVideo);
private:
ePtr<eDVBDemux> 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:
int m_is_slow_motion, m_is_fast_forward;
public:
+ enum { MPEG2, MPEG4_H264 };
eDVBVideo(eDVBDemux *demux, int dev);
eDVBVideo(eDVBDemux *demux, int dev);
- int startPid(int pid);
+ int startPid(int pid
, int type=MPEG2
);
void stop();
#if HAVE_DVB_API_VERSION < 3
void start();
void stop();
#if HAVE_DVB_API_VERSION < 3
void start();
@@
-46,6
+50,7
@@
public:
int setSlowMotion(int repeat);
int setFastForward(int skip);
void unfreeze();
int setSlowMotion(int repeat);
int setFastForward(int skip);
void unfreeze();
+ int getPTS(pts_t &now);
virtual ~eDVBVideo();
};
virtual ~eDVBVideo();
};
@@
-62,22
+67,42
@@
public:
virtual ~eDVBPCR();
};
virtual ~eDVBPCR();
};
+class eDVBTText: public iObject
+{
+DECLARE_REF(eDVBTText);
+private:
+ ePtr<eDVBDemux> m_demux;
+ int m_fd_demux;
+public:
+ eDVBTText(eDVBDemux *demux);
+ int startPid(int pid);
+ void stop();
+ virtual ~eDVBTText();
+};
+
class eTSMPEGDecoder: public Object, public iTSMPEGDecoder
{
class eTSMPEGDecoder: public Object, public iTSMPEGDecoder
{
+ static int m_pcm_delay;
+ static int m_ac3_delay;
+ static int m_audio_channel;
DECLARE_REF(eTSMPEGDecoder);
DECLARE_REF(eTSMPEGDecoder);
+ std::string m_radio_pic;
private:
ePtr<eDVBDemux> m_demux;
ePtr<eDVBAudio> m_audio;
ePtr<eDVBVideo> m_video;
ePtr<eDVBPCR> m_pcr;
private:
ePtr<eDVBDemux> m_demux;
ePtr<eDVBAudio> m_audio;
ePtr<eDVBVideo> m_video;
ePtr<eDVBPCR> m_pcr;
- int m_vpid, m_apid, m_atype, m_pcrpid;
+ ePtr<eDVBTText> m_text;
+ int m_vpid, m_vtype, m_apid, m_atype, m_pcrpid, m_textpid;
enum
{
changeVideo = 1,
changeAudio = 2,
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<eConnection> m_demux_event;
int setState();
ePtr<eConnection> m_demux_event;
@@
-86,9
+111,16
@@
public:
enum { pidNone = -1 };
eTSMPEGDecoder(eDVBDemux *demux, int decoder);
virtual ~eTSMPEGDecoder();
enum { pidNone = -1 };
eTSMPEGDecoder(eDVBDemux *demux, int decoder);
virtual ~eTSMPEGDecoder();
- RESULT setVideoPID(int vpid);
+ RESULT setVideoPID(int vpid
, int type
);
RESULT setAudioPID(int apid, int type);
RESULT setAudioPID(int apid, int type);
+ RESULT setAudioChannel(int channel);
+ int getAudioChannel();
+ RESULT setPCMDelay(int delay);
+ int getPCMDelay() { return m_pcm_delay; }
+ RESULT setAC3Delay(int delay);
+ int getAC3Delay() { return m_ac3_delay; }
RESULT setSyncPCR(int pcrpid);
RESULT setSyncPCR(int pcrpid);
+ RESULT setTextPID(int textpid);
RESULT setSyncMaster(int who);
RESULT start();
RESULT freeze(int cont);
RESULT setSyncMaster(int who);
RESULT start();
RESULT freeze(int cont);
@@
-99,5
+131,11
@@
public:
RESULT setSlowMotion(int repeat);
RESULT setZoom(int what);
RESULT flush();
RESULT setSlowMotion(int repeat);
RESULT setZoom(int what);
RESULT flush();
+ RESULT setTrickmode(int what);
+ RESULT showSinglePic(const char *filename);
+ RESULT setRadioPic(const std::string &filename);
+ /* what 0=auto, 1=video, 2=audio. */
+ RESULT getPTS(int what, pts_t &pts);
};
};
+
#endif
#endif