Fix Theora video playback without a Vorbis stream
- prevent audio resampler errors when number of channels is 0, - don't check for 'audio_done' when there is no audio data.
This commit is contained in:
parent
d412cb65be
commit
763b29f34e
|
@ -513,7 +513,7 @@ void VideoStreamPlaybackTheora::update(float p_delta) {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool frame_done=false;
|
bool frame_done=false;
|
||||||
bool audio_done=false;
|
bool audio_done=!vorbis_p;
|
||||||
|
|
||||||
bool theora_done=false;
|
bool theora_done=false;
|
||||||
|
|
||||||
|
|
|
@ -208,9 +208,16 @@ void VideoPlayer::set_stream(const Ref<VideoStream> &p_stream) {
|
||||||
playback->set_paused(paused);
|
playback->set_paused(paused);
|
||||||
texture=playback->get_texture();
|
texture=playback->get_texture();
|
||||||
|
|
||||||
|
const int channels = playback->get_channels();
|
||||||
|
|
||||||
AudioServer::get_singleton()->lock();
|
AudioServer::get_singleton()->lock();
|
||||||
resampler.setup(playback->get_channels(),playback->get_mix_rate(),server_mix_rate,buffering_ms,0);
|
if (channels > 0)
|
||||||
|
resampler.setup(channels,playback->get_mix_rate(),server_mix_rate,buffering_ms,0);
|
||||||
|
else
|
||||||
|
resampler.clear();
|
||||||
AudioServer::get_singleton()->unlock();
|
AudioServer::get_singleton()->unlock();
|
||||||
|
|
||||||
|
if (channels > 0)
|
||||||
playback->set_mix_callback(_audio_mix_callback,this);
|
playback->set_mix_callback(_audio_mix_callback,this);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in New Issue