From 06036225f49fd75abc76e63995f4a4e8d5eb1fe5 Mon Sep 17 00:00:00 2001 From: Relintai Date: Thu, 28 Jul 2022 19:15:06 +0200 Subject: [PATCH] Ported: More low priority redraw request cases Some more cases of textures etc causing continuous updates in vital updates only mode are fixed. - lawnjelly https://github.com/godotengine/godot/commit/f8df04ed50676c298e57853d56f6f24424ff70b7 --- drivers/gles2/rasterizer_canvas_base_gles2.cpp | 4 ++-- drivers/gles2/rasterizer_canvas_gles2.cpp | 4 ++-- drivers/gles2/rasterizer_scene_gles2.cpp | 4 ++-- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/drivers/gles2/rasterizer_canvas_base_gles2.cpp b/drivers/gles2/rasterizer_canvas_base_gles2.cpp index a71f442cc..cc1073da1 100644 --- a/drivers/gles2/rasterizer_canvas_base_gles2.cpp +++ b/drivers/gles2/rasterizer_canvas_base_gles2.cpp @@ -196,7 +196,7 @@ RasterizerStorageGLES2::Texture *RasterizerCanvasBaseGLES2::_bind_canvas_texture } else { if (texture->redraw_if_visible) { - VisualServerRaster::redraw_request(); + VisualServerRaster::redraw_request(false); } texture = texture->get_ptr(); @@ -236,7 +236,7 @@ RasterizerStorageGLES2::Texture *RasterizerCanvasBaseGLES2::_bind_canvas_texture } else { if (normal_map->redraw_if_visible) { //check before proxy, because this is usually used with proxies - VisualServerRaster::redraw_request(); + VisualServerRaster::redraw_request(false); } normal_map = normal_map->get_ptr(); diff --git a/drivers/gles2/rasterizer_canvas_gles2.cpp b/drivers/gles2/rasterizer_canvas_gles2.cpp index 5113c5918..4abe74a24 100644 --- a/drivers/gles2/rasterizer_canvas_gles2.cpp +++ b/drivers/gles2/rasterizer_canvas_gles2.cpp @@ -1693,7 +1693,7 @@ void RasterizerCanvasGLES2::_legacy_canvas_render_item(Item *p_ci, RenderItemSta } if (t->redraw_if_visible) { - VisualServerRaster::redraw_request(); + VisualServerRaster::redraw_request(false); } t = t->get_ptr(); @@ -2055,7 +2055,7 @@ void RasterizerCanvasGLES2::render_joined_item(const BItemJoined &p_bij, RenderI } if (t->redraw_if_visible) { - VisualServerRaster::redraw_request(); + VisualServerRaster::redraw_request(false); } t = t->get_ptr(); diff --git a/drivers/gles2/rasterizer_scene_gles2.cpp b/drivers/gles2/rasterizer_scene_gles2.cpp index ca932a53a..4aa7be65f 100644 --- a/drivers/gles2/rasterizer_scene_gles2.cpp +++ b/drivers/gles2/rasterizer_scene_gles2.cpp @@ -1407,7 +1407,7 @@ bool RasterizerSceneGLES2::_setup_material(RasterizerStorageGLES2::Material *p_m } if (t->redraw_if_visible) { //must check before proxy because this is often used with proxies - VisualServerRaster::redraw_request(); + VisualServerRaster::redraw_request(false); } t = t->get_ptr(); @@ -1784,7 +1784,7 @@ void RasterizerSceneGLES2::_render_geometry(RenderList::Element *p_element) { RasterizerStorageGLES2::Texture *t = storage->texture_owner.get(c.texture); if (t->redraw_if_visible) { - VisualServerRaster::redraw_request(); + VisualServerRaster::redraw_request(false); } t = t->get_ptr();