diff --git a/scene/2d/tile_map.cpp b/scene/2d/tile_map.cpp index 98275510d62..7fb4e36b632 100644 --- a/scene/2d/tile_map.cpp +++ b/scene/2d/tile_map.cpp @@ -708,7 +708,7 @@ void TileMap::_erase_quadrant(Map::Element *Q) { rect_cache_dirty = true; } -void TileMap::_make_quadrant_dirty(Map::Element *Q) { +void TileMap::_make_quadrant_dirty(Map::Element *Q, bool update) { Quadrant &q = Q->get(); if (!q.dirty_list.in_list()) @@ -719,7 +719,10 @@ void TileMap::_make_quadrant_dirty(Map::Element *Q) { pending_update = true; if (!is_inside_tree()) return; - _update_dirty_quadrants(); + + if (update) { + _update_dirty_quadrants(); + } } void TileMap::set_cellv(const Vector2 &p_pos, int p_tile, bool p_flip_x, bool p_flip_y, bool p_transpose) { @@ -1016,8 +1019,9 @@ void TileMap::_recreate_quadrants() { } Q->get().cells.insert(E->key()); - _make_quadrant_dirty(Q); + _make_quadrant_dirty(Q, false); } + _update_dirty_quadrants(); } void TileMap::_clear_quadrants() { diff --git a/scene/2d/tile_map.h b/scene/2d/tile_map.h index 07947004b32..d6774d42bb8 100644 --- a/scene/2d/tile_map.h +++ b/scene/2d/tile_map.h @@ -188,7 +188,7 @@ private: Map::Element *_create_quadrant(const PosKey &p_qk); void _erase_quadrant(Map::Element *Q); - void _make_quadrant_dirty(Map::Element *Q); + void _make_quadrant_dirty(Map::Element *Q, bool update = true); void _recreate_quadrants(); void _clear_quadrants(); void _update_dirty_quadrants();