fix can't set AudioStreamPlayer stream to null
This commit is contained in:
parent
0a1c1c660f
commit
2bdac0a5d9
|
@ -242,7 +242,6 @@ void AudioStreamPlayer2D::_notification(int p_what) {
|
||||||
|
|
||||||
void AudioStreamPlayer2D::set_stream(Ref<AudioStream> p_stream) {
|
void AudioStreamPlayer2D::set_stream(Ref<AudioStream> p_stream) {
|
||||||
|
|
||||||
ERR_FAIL_COND(!p_stream.is_valid());
|
|
||||||
AudioServer::get_singleton()->lock();
|
AudioServer::get_singleton()->lock();
|
||||||
|
|
||||||
mix_buffer.resize(AudioServer::get_singleton()->thread_get_mix_buffer_size());
|
mix_buffer.resize(AudioServer::get_singleton()->thread_get_mix_buffer_size());
|
||||||
|
@ -254,14 +253,15 @@ void AudioStreamPlayer2D::set_stream(Ref<AudioStream> p_stream) {
|
||||||
setseek = -1;
|
setseek = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (p_stream.is_valid()) {
|
||||||
stream = p_stream;
|
stream = p_stream;
|
||||||
stream_playback = p_stream->instance_playback();
|
stream_playback = p_stream->instance_playback();
|
||||||
|
}
|
||||||
|
|
||||||
AudioServer::get_singleton()->unlock();
|
AudioServer::get_singleton()->unlock();
|
||||||
|
|
||||||
if (stream_playback.is_null()) {
|
if (p_stream.is_valid() && stream_playback.is_null()) {
|
||||||
stream.unref();
|
stream.unref();
|
||||||
ERR_FAIL_COND(stream_playback.is_null());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -552,7 +552,6 @@ void AudioStreamPlayer3D::_notification(int p_what) {
|
||||||
|
|
||||||
void AudioStreamPlayer3D::set_stream(Ref<AudioStream> p_stream) {
|
void AudioStreamPlayer3D::set_stream(Ref<AudioStream> p_stream) {
|
||||||
|
|
||||||
ERR_FAIL_COND(!p_stream.is_valid());
|
|
||||||
AudioServer::get_singleton()->lock();
|
AudioServer::get_singleton()->lock();
|
||||||
|
|
||||||
mix_buffer.resize(AudioServer::get_singleton()->thread_get_mix_buffer_size());
|
mix_buffer.resize(AudioServer::get_singleton()->thread_get_mix_buffer_size());
|
||||||
|
@ -564,14 +563,15 @@ void AudioStreamPlayer3D::set_stream(Ref<AudioStream> p_stream) {
|
||||||
setseek = -1;
|
setseek = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (p_stream.is_valid()) {
|
||||||
stream = p_stream;
|
stream = p_stream;
|
||||||
stream_playback = p_stream->instance_playback();
|
stream_playback = p_stream->instance_playback();
|
||||||
|
}
|
||||||
|
|
||||||
AudioServer::get_singleton()->unlock();
|
AudioServer::get_singleton()->unlock();
|
||||||
|
|
||||||
if (stream_playback.is_null()) {
|
if (p_stream.is_valid() && stream_playback.is_null()) {
|
||||||
stream.unref();
|
stream.unref();
|
||||||
ERR_FAIL_COND(stream_playback.is_null());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -159,7 +159,6 @@ void AudioStreamPlayer::set_stream(Ref<AudioStream> p_stream) {
|
||||||
|
|
||||||
if (p_stream.is_valid() && stream_playback.is_null()) {
|
if (p_stream.is_valid() && stream_playback.is_null()) {
|
||||||
stream.unref();
|
stream.unref();
|
||||||
ERR_FAIL_COND(stream_playback.is_null());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue