diff options
Diffstat (limited to 'displaychannel.c')
-rw-r--r-- | displaychannel.c | 57 |
1 files changed, 42 insertions, 15 deletions
diff --git a/displaychannel.c b/displaychannel.c index 488ff3d1..ee4ce3e9 100644 --- a/displaychannel.c +++ b/displaychannel.c @@ -89,6 +89,7 @@ cFlatDisplayChannel::cFlatDisplayChannel(bool WithInfo) : m_Receiver(NULL) { bitrateVideo = bitrateAudio = bitrateDolby = 0.0; m_Receiver = NULL; + /* if( Config.ChannelBitrateShow ) { const cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); eTrackType track = cDevice::PrimaryDevice()->GetCurrentAudioTrack(); @@ -97,7 +98,7 @@ cFlatDisplayChannel::cFlatDisplayChannel(bool WithInfo) : m_Receiver(NULL) { cDevice::ActualDevice()->AttachReceiver(m_Receiver); } } - + */ if( Config.ChannelWeatherShow ) DrawWidgetWeather(); @@ -573,23 +574,36 @@ void cFlatDisplayChannel::BitrateDraw(void) { delete BitrateFont; } +// Indicates a channel switch on the given DVB device. +// If ChannelNumber is 0, this is before the channel is being switched, +// otherwise ChannelNumber is the number of the channel that has been switched to. +// LiveView tells whether this channel switch is for live viewing. void cFlatDisplayChannel::ChannelSwitch(const cDevice * device, int channelNumber, bool liveView) { - if( !Config.ChannelBitrateShow ) + if( liveView == false) // ChannelSwitch from EPG-Scan, streamdev or other? + return; + if( channelNumber == 0 ) { // before the channel is being switched -> remove receiver + if (m_Receiver) { + //dsyslog("ChannelSwitch: Receiver REMOVE"); + m_Receiver->Deactivate(); + DELETENULL(m_Receiver); + } return; + } + // at this point we finally switch to a new channel on liveView bitrateVideo = bitrateAudio = bitrateDolby = 0.0; eTrackType track = cDevice::PrimaryDevice()->GetCurrentAudioTrack(); const cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); - if (!liveView || !channelNumber || !channel || channel->Number() != channelNumber) - return; + if( channel && Config.ChannelBitrateShow && doOutput ) { + if ( m_Receiver ) { // this should not be happen!!! + //dsyslog("ChannelSwitch: Receiver is still Active -> remove it!"); + m_Receiver->Deactivate(); + DELETENULL(m_Receiver); + } + //dsyslog("ChannelSwitch: Receiver ATTACH %d - %s", cDevice::PrimaryDevice()->DeviceNumber(), channel->Name()); - if (m_Receiver) { - m_Receiver->Deactivate(); - DELETENULL(m_Receiver); - } - if (channel) { m_Receiver = new cFemonReceiver(channel, IS_AUDIO_TRACK(track) ? int(track - ttAudioFirst) : 0, IS_DOLBY_TRACK(track) ? int(track - ttDolbyFirst) : 0); cDevice::ActualDevice()->AttachReceiver(m_Receiver); } @@ -597,17 +611,20 @@ void cFlatDisplayChannel::ChannelSwitch(const cDevice * device, int channelNumbe void cFlatDisplayChannel::SetAudioTrack(int Index, const char * const *Tracks) { - if( !Config.ChannelBitrateShow ) - return; - bitrateVideo = bitrateAudio = bitrateDolby = 0.0; eTrackType track = cDevice::PrimaryDevice()->GetCurrentAudioTrack(); - if (m_Receiver) { + if( m_Receiver ) { + dsyslog("SetAudioTrack: Receiver remove"); m_Receiver->Deactivate(); DELETENULL(m_Receiver); } + + if( !Config.ChannelBitrateShow ) + return; + const cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); - if (channel) { + if( channel && doOutput ) { + dsyslog("SetAudioTrack: Receiver attach - %s", channel->Name()); m_Receiver = new cFemonReceiver(channel, IS_AUDIO_TRACK(track) ? int(track - ttAudioFirst) : 0, IS_DOLBY_TRACK(track) ? int(track - ttDolbyFirst) : 0); cDevice::ActualDevice()->AttachReceiver(m_Receiver); } @@ -637,7 +654,17 @@ void cFlatDisplayChannel::Flush(void) { } } - if( Config.ChannelBitrateShow ) { + if( Config.ChannelBitrateShow && doOutput && !m_Receiver ) { + const cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); + eTrackType track = cDevice::PrimaryDevice()->GetCurrentAudioTrack(); + if( channel ) { + //dsyslog("ChannelSwitch: Receiver ATTACH %d - %s FLUSH", cDevice::PrimaryDevice()->DeviceNumber(), channel->Name()); + m_Receiver = new cFemonReceiver(channel, IS_AUDIO_TRACK(track) ? int(track - ttAudioFirst) : 0, IS_DOLBY_TRACK(track) ? int(track - ttDolbyFirst) : 0); + cDevice::ActualDevice()->AttachReceiver(m_Receiver); + } + } + + if( Config.ChannelBitrateShow && m_Receiver ) { bitrateVideo = m_Receiver->VideoBitrate(); bitrateAudio = m_Receiver->AudioBitrate(); bitrateDolby = m_Receiver->AC3Bitrate(); |