X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fxinestream.h;h=554b448aac489ff7ab5b899b7cec8181ac63249a;hb=19f69a037e98b6b510fca0f270a5a0cf05de522d;hp=c03dd0324f1dc2cc46da810ef9d34dffcd6a0a85;hpb=194033440e2552a820c3b8197198402acee67c5b;p=xinema.git diff --git a/source/xinestream.h b/source/xinestream.h index c03dd03..554b448 100644 --- a/source/xinestream.h +++ b/source/xinestream.h @@ -2,6 +2,7 @@ #define XINESTREAM_H_ #include +#include #include #include #include @@ -19,13 +20,23 @@ public: PLAYING }; + enum + { + OFF = -1 + }; + sigc::signal signal_state_changed; sigc::signal signal_title_changed; sigc::signal signal_duration_changed; sigc::signal signal_position_changed; + sigc::signal signal_channels_changed; + sigc::signal signal_current_audio_channel_changed; + sigc::signal signal_current_spu_channel_changed; + sigc::signal signal_finished; private: XineEngine &engine; + std::string filename; xine_stream_t *stream; xine_event_queue_t *queue; Msp::Mutex mutex; @@ -33,15 +44,21 @@ private: std::string title; Msp::Time::TimeDelta duration; Msp::Time::TimeDelta position; + std::vector audio_channels; + std::vector spu_channels; + int current_audio; + int current_spu; + bool channels_changed; public: XineStream(XineEngine &, const std::string &); ~XineStream(); + Msp::Mutex &get_mutex() { return mutex; } State get_state() const { return state; } const Msp::Time::TimeDelta &get_duration() const { return duration; } const Msp::Time::TimeDelta &get_position() const { return position; } - const std::string &get_title() const { return title; } + const std::string &get_title() const; void play(); void seek(const Msp::Time::TimeDelta &); @@ -51,9 +68,17 @@ private: void set_state(State); public: + const std::vector &get_audio_channels() const { return audio_channels; } + const std::vector &get_spu_channels() const { return spu_channels; } + void select_audio_channel(int); + void select_spu_channel(int); + int get_current_audio_channel() const { return current_audio; } + int get_current_spu_channel() const { return current_spu; } + void tick(); private: void update_info(); + void update_channels(); void handle_event(const xine_event_t &); };