X-Git-Url: http://code.vuplus.com/gitweb/?p=vuplus_dvbapp;a=blobdiff_plain;f=lib%2Fservice%2Fservicedvb.h;h=e3c7fd58933fa13e0510f46bbb0129a1ed2333c9;hp=d7d05c7833e5cd6f1faf1480ad401a48e9d28048;hb=28dcf6be0ee22fedd728fef11ccff484f8a851e8;hpb=c50acf3391bec3f2abaf219c8f52c7d57d6149b5 diff --git a/lib/service/servicedvb.h b/lib/service/servicedvb.h index d7d05c7..e3c7fd5 100644 --- a/lib/service/servicedvb.h +++ b/lib/service/servicedvb.h @@ -38,7 +38,7 @@ class eBouquet; class eDVBServiceList: public iListableService, public iMutableServiceList { -DECLARE_REF(eDVBServiceList); + DECLARE_REF(eDVBServiceList); public: virtual ~eDVBServiceList(); PyObject *getContent(const char* formatstr, bool sorted=false); @@ -81,7 +81,7 @@ public: PyObject *getAll(bool original); // a sum of getFrontendData/Status/TransponderData }; -class eSubtitleWidget; +class eSubtitleWidget; class eDVBServicePlay: public eDVBServiceBase, public iPlayableService, public iPauseableService, @@ -91,7 +91,7 @@ class eDVBServicePlay: public eDVBServiceBase, public iCueSheet, public iSubtitleOutput, public iAudioDelay, public iRdsDecoder, public iStreamableService { -DECLARE_REF(eDVBServicePlay); + DECLARE_REF(eDVBServicePlay); public: virtual ~eDVBServicePlay(); @@ -114,13 +114,14 @@ public: RESULT audioDelay(ePtr &ptr); RESULT rdsDecoder(ePtr &ptr); RESULT keys(ePtr &ptr) { ptr = 0; return -1; } + RESULT streamed(ePtr &ptr) { ptr = 0; return -1; } // iPauseableService RESULT pause(); RESULT unpause(); RESULT setSlowMotion(int ratio); RESULT setFastForward(int ratio); - + // iSeekableService RESULT getLength(pts_t &len); RESULT seekTo(pts_t to); @@ -128,7 +129,6 @@ public: RESULT getPlayPosition(pts_t &pos); RESULT setTrickmode(int trick=0); RESULT isCurrentlySeekable(); - RESULT seekChapter(int chapter); // iServiceInformation RESULT getName(std::string &name); @@ -183,6 +183,7 @@ public: // iStreamableService RESULT stream(ePtr &ptr); PyObject *getStreamingData(); + private: friend class eServiceFactoryDVB; eServiceReference m_reference; @@ -209,7 +210,7 @@ private: Signal2 m_event; /* pvr */ - int m_is_pvr, m_is_paused, m_timeshift_enabled, m_timeshift_active; + int m_is_pvr, m_is_paused, m_timeshift_enabled, m_timeshift_active, m_timeshift_changed; int m_first_program_info; std::string m_timeshift_file; @@ -219,6 +220,7 @@ private: int m_current_audio_stream; int selectAudioStream(int n = -1); + RESULT setFastForward_internal(int ratio, bool final_seek=false); /* timeshift */ ePtr m_record; @@ -231,6 +233,8 @@ private: void updateDecoder(); int m_skipmode; + int m_fastforward; + int m_slowmotion; /* cuesheet */ @@ -273,7 +277,7 @@ private: ePtr m_new_dvb_subtitle_page_connection; std::list m_dvb_subtitle_pages; - eTimer m_subtitle_sync_timer; + ePtr m_subtitle_sync_timer; void checkSubtitleTiming(); /* radiotext */ @@ -283,7 +287,6 @@ private: ePtr m_video_event_connection; void video_event(struct iTSMPEGDecoder::videoEvent); - struct iTSMPEGDecoder::videoEvent m_videoEventData; }; class eStaticServiceDVBBouquetInformation: public iStaticServiceInformation @@ -294,7 +297,7 @@ public: eServiceReference &getPlayableService() { return m_playable_service; } RESULT getName(const eServiceReference &ref, std::string &name); int getLength(const eServiceReference &ref); - int isPlayable(const eServiceReference &ref, const eServiceReference &ignore); + int isPlayable(const eServiceReference &ref, const eServiceReference &ignore, bool simulate=false); RESULT getEvent(const eServiceReference &ref, ePtr &ptr, time_t start_time); };