fix(VideoStreamPlayer): Redraw when video resolution changes during playback

This commit is contained in:
unvermuthet
2025-03-10 14:41:01 +01:00
parent cae3d722a3
commit de4d1e6d8c
2 changed files with 29 additions and 2 deletions

View File

@ -176,7 +176,7 @@ void VideoStreamPlayer::_notification(int p_notification) {
return;
}
Size2 s = expand ? get_size() : texture->get_size();
Size2 s = expand ? get_size() : texture_size;
draw_texture_rect(texture, Rect2(Point2(), s), false);
} break;
@ -212,9 +212,25 @@ void VideoStreamPlayer::_notification(int p_notification) {
}
}
void VideoStreamPlayer::texture_changed(const Ref<Texture2D> &p_texture) {
const Size2 new_texture_size = p_texture.is_valid() ? p_texture->get_size() : Size2();
if (new_texture_size == texture_size) {
return;
}
texture_size = new_texture_size;
queue_redraw();
if (!expand) {
update_minimum_size();
}
}
Size2 VideoStreamPlayer::get_minimum_size() const {
if (!expand && texture.is_valid()) {
return texture->get_size();
return texture_size;
} else {
return Size2();
}
@ -266,10 +282,19 @@ void VideoStreamPlayer::set_stream(const Ref<VideoStream> &p_stream) {
stream->connect_changed(callable_mp(this, &VideoStreamPlayer::set_stream).bind(stream));
}
if (texture.is_valid()) {
texture->disconnect_changed(callable_mp(this, &VideoStreamPlayer::texture_changed));
}
if (playback.is_valid()) {
playback->set_paused(paused);
texture = playback->get_texture();
if (texture.is_valid()) {
texture_size = texture->get_size();
texture->connect_changed(callable_mp(this, &VideoStreamPlayer::texture_changed).bind(texture));
}
const int channels = playback->get_channels();
AudioServer::get_singleton()->lock();

View File

@ -51,6 +51,8 @@ class VideoStreamPlayer : public Control {
RID stream_rid;
Ref<Texture2D> texture;
Size2 texture_size;
void texture_changed(const Ref<Texture2D> &p_texture);
AudioRBResampler resampler;
Vector<AudioFrame> mix_buffer;