Now only one override is allowed per World, as there is really no reason to have support for more than one per world pair. This fixes lots of issues with the system.

This commit is contained in:
Relintai 2022-08-30 15:47:22 +02:00
parent ae0316ff59
commit 9bdb8b6bce
3 changed files with 81 additions and 114 deletions

View File

@ -678,8 +678,8 @@ void Viewport::_process_picking(bool p_ignore_paused) {
} }
RID Viewport::get_viewport_rid() const { RID Viewport::get_viewport_rid() const {
if (_override_world) { if (_overriding_world) {
return _override_world->get_viewport_rid(); return _overriding_world->get_viewport_rid();
} }
return viewport; return viewport;
@ -712,8 +712,8 @@ void Viewport::set_size(const Size2 &p_size) {
} }
Rect2 Viewport::get_visible_rect() const { Rect2 Viewport::get_visible_rect() const {
if (_override_world) { if (_overriding_world) {
return _override_world->get_visible_rect(); return _overriding_world->get_visible_rect();
} }
Rect2 r; Rect2 r;
@ -836,8 +836,9 @@ void Viewport::_on_after_world_override_changed() {
} }
void Viewport::enable_canvas_transform_override(bool p_enable) { void Viewport::enable_canvas_transform_override(bool p_enable) {
if (_override_world) { if (_overriding_world) {
_override_world->enable_canvas_transform_override(p_enable); _overriding_world->enable_canvas_transform_override(p_enable);
return;
} }
if (override_canvas_transform == p_enable) { if (override_canvas_transform == p_enable) {
@ -853,16 +854,17 @@ void Viewport::enable_canvas_transform_override(bool p_enable) {
} }
bool Viewport::is_canvas_transform_override_enbled() const { bool Viewport::is_canvas_transform_override_enbled() const {
if (_override_world) { if (_overriding_world) {
return _override_world->is_canvas_transform_override_enbled(); return _overriding_world->is_canvas_transform_override_enbled();
} }
return override_canvas_transform; return override_canvas_transform;
} }
void Viewport::set_canvas_transform_override(const Transform2D &p_transform) { void Viewport::set_canvas_transform_override(const Transform2D &p_transform) {
if (_override_world) { if (_overriding_world) {
_override_world->set_canvas_transform_override(p_transform); _overriding_world->set_canvas_transform_override(p_transform);
return;
} }
if (canvas_transform_override == p_transform) { if (canvas_transform_override == p_transform) {
@ -876,20 +878,17 @@ void Viewport::set_canvas_transform_override(const Transform2D &p_transform) {
} }
Transform2D Viewport::get_canvas_transform_override() const { Transform2D Viewport::get_canvas_transform_override() const {
if (_override_world) { if (_overriding_world) {
return _override_world->get_canvas_transform_override(); return _overriding_world->get_canvas_transform_override();
}
if (_override_world) {
return _override_world->get_canvas_transform_override();
} }
return canvas_transform_override; return canvas_transform_override;
} }
void Viewport::set_canvas_transform(const Transform2D &p_transform) { void Viewport::set_canvas_transform(const Transform2D &p_transform) {
if (_override_world) { if (_overriding_world) {
_override_world->set_canvas_transform(p_transform); _overriding_world->set_canvas_transform(p_transform);
return;
} }
canvas_transform = p_transform; canvas_transform = p_transform;
@ -900,8 +899,8 @@ void Viewport::set_canvas_transform(const Transform2D &p_transform) {
} }
Transform2D Viewport::get_canvas_transform() const { Transform2D Viewport::get_canvas_transform() const {
if (_override_world) { if (_overriding_world) {
return _override_world->get_canvas_transform(); return _overriding_world->get_canvas_transform();
} }
return canvas_transform; return canvas_transform;
@ -914,8 +913,9 @@ void Viewport::_update_global_transform() {
} }
void Viewport::set_global_canvas_transform(const Transform2D &p_transform) { void Viewport::set_global_canvas_transform(const Transform2D &p_transform) {
if (_override_world) { if (_overriding_world) {
_override_world->set_global_canvas_transform(p_transform); _overriding_world->set_global_canvas_transform(p_transform);
return;
} }
global_canvas_transform = p_transform; global_canvas_transform = p_transform;
@ -924,8 +924,8 @@ void Viewport::set_global_canvas_transform(const Transform2D &p_transform) {
} }
Transform2D Viewport::get_global_canvas_transform() const { Transform2D Viewport::get_global_canvas_transform() const {
if (_override_world) { if (_overriding_world) {
return _override_world->get_global_canvas_transform(); return _overriding_world->get_global_canvas_transform();
} }
return global_canvas_transform; return global_canvas_transform;
@ -1148,8 +1148,8 @@ void Viewport::set_camera_override_orthogonal(float p_size, float p_z_near, floa
} }
Transform2D Viewport::get_final_transform() const { Transform2D Viewport::get_final_transform() const {
if (_override_world) { if (_overriding_world) {
return _override_world->get_final_transform(); return _overriding_world->get_final_transform();
} }
return stretch_transform * global_canvas_transform; return stretch_transform * global_canvas_transform;
@ -2889,15 +2889,16 @@ String Viewport::get_configuration_warning() const {
} }
void Viewport::gui_reset_canvas_sort_index() { void Viewport::gui_reset_canvas_sort_index() {
if (_override_world) { if (_overriding_world) {
_override_world->gui_reset_canvas_sort_index(); _overriding_world->gui_reset_canvas_sort_index();
return;
} }
gui.canvas_sort_index = 0; gui.canvas_sort_index = 0;
} }
int Viewport::gui_get_canvas_sort_index() { int Viewport::gui_get_canvas_sort_index() {
if (_override_world) { if (_overriding_world) {
return _override_world->gui_get_canvas_sort_index(); return _overriding_world->gui_get_canvas_sort_index();
} }
return gui.canvas_sort_index++; return gui.canvas_sort_index++;

View File

@ -210,13 +210,11 @@ void World::set_override_world(World *p_world) {
return; return;
} }
World *old_world = get_override_world();
Ref<World3D> old_world_3d = find_world_3d();
_on_before_world_override_changed(); _on_before_world_override_changed();
if (old_world) { if (_overriding_world) {
old_world->_remove_overridden_world(this); _overriding_world->set_override_world(NULL);
_overriding_world = NULL;
} }
_clear_override_cameras(); _clear_override_cameras();
@ -224,25 +222,7 @@ void World::set_override_world(World *p_world) {
_override_world = p_world; _override_world = p_world;
if (_override_world) { if (_override_world) {
_override_world->_add_overridden_world(this); _override_world->_overriding_world = this;
}
if (old_world_3d.is_valid()) {
Ref<World3D> new_world_3d = find_world_3d();
if (old_world_3d != new_world_3d) {
if (new_world_3d.is_valid()) {
old_world_3d->move_cameras_into(new_world_3d);
} else {
ERR_PRINT("!new_world_3d.is_valid()");
}
}
} else {
ERR_PRINT("!old_world_3d.is_valid()");
}
if (_override_world) {
_add_override_cameras_into(_override_world); _add_override_cameras_into(_override_world);
} }
@ -257,97 +237,97 @@ void World::set_override_world_bind(Node *p_world) {
} }
void World::gui_reset_canvas_sort_index() { void World::gui_reset_canvas_sort_index() {
if (_override_world) { if (_overriding_world) {
_override_world->gui_reset_canvas_sort_index(); _overriding_world->gui_reset_canvas_sort_index();
} }
} }
int World::gui_get_canvas_sort_index() { int World::gui_get_canvas_sort_index() {
if (_override_world) { if (_overriding_world) {
return _override_world->gui_get_canvas_sort_index(); return _overriding_world->gui_get_canvas_sort_index();
} }
return 0; return 0;
} }
void World::enable_canvas_transform_override(bool p_enable) { void World::enable_canvas_transform_override(bool p_enable) {
if (_override_world) { if (_overriding_world) {
_override_world->enable_canvas_transform_override(p_enable); _overriding_world->enable_canvas_transform_override(p_enable);
} }
} }
bool World::is_canvas_transform_override_enbled() const { bool World::is_canvas_transform_override_enbled() const {
if (_override_world) { if (_overriding_world) {
return _override_world->is_canvas_transform_override_enbled(); return _overriding_world->is_canvas_transform_override_enbled();
} }
return false; return false;
} }
void World::set_canvas_transform_override(const Transform2D &p_transform) { void World::set_canvas_transform_override(const Transform2D &p_transform) {
if (_override_world) { if (_overriding_world) {
_override_world->set_canvas_transform_override(p_transform); _overriding_world->set_canvas_transform_override(p_transform);
} }
} }
Transform2D World::get_canvas_transform_override() const { Transform2D World::get_canvas_transform_override() const {
if (_override_world) { if (_overriding_world) {
return _override_world->get_canvas_transform_override(); return _overriding_world->get_canvas_transform_override();
} }
return Transform2D(); return Transform2D();
} }
void World::set_canvas_transform(const Transform2D &p_transform) { void World::set_canvas_transform(const Transform2D &p_transform) {
if (_override_world) { if (_overriding_world) {
_override_world->set_canvas_transform(p_transform); _overriding_world->set_canvas_transform(p_transform);
} }
} }
Transform2D World::get_canvas_transform() const { Transform2D World::get_canvas_transform() const {
if (_override_world) { if (_overriding_world) {
return _override_world->get_canvas_transform(); return _overriding_world->get_canvas_transform();
} }
return Transform2D(); return Transform2D();
} }
void World::set_global_canvas_transform(const Transform2D &p_transform) { void World::set_global_canvas_transform(const Transform2D &p_transform) {
if (_override_world) { if (_overriding_world) {
_override_world->set_global_canvas_transform(p_transform); _overriding_world->set_global_canvas_transform(p_transform);
} }
} }
Transform2D World::get_global_canvas_transform() const { Transform2D World::get_global_canvas_transform() const {
if (_override_world) { if (_overriding_world) {
return _override_world->get_global_canvas_transform(); return _overriding_world->get_global_canvas_transform();
} }
return Transform2D(); return Transform2D();
} }
Transform2D World::get_final_transform() const { Transform2D World::get_final_transform() const {
if (_override_world) { if (_overriding_world) {
return _override_world->get_final_transform(); return _overriding_world->get_final_transform();
} }
return Transform2D(); return Transform2D();
} }
Rect2 World::get_visible_rect() const { Rect2 World::get_visible_rect() const {
if (_override_world) { if (_overriding_world) {
return _override_world->get_visible_rect(); return _overriding_world->get_visible_rect();
} }
return Rect2(); return Rect2();
} }
RID World::get_viewport_rid() const { RID World::get_viewport_rid() const {
if (_override_world) { if (_overriding_world) {
return _override_world->get_viewport_rid(); return _overriding_world->get_viewport_rid();
} }
return RID(); return RID();
} }
Vector2 World::get_camera_coords(const Vector2 &p_viewport_coords) const { Vector2 World::get_camera_coords(const Vector2 &p_viewport_coords) const {
if (_override_world) { if (_overriding_world) {
return _override_world->get_camera_coords(p_viewport_coords); return _overriding_world->get_camera_coords(p_viewport_coords);
} }
Transform2D xf = get_final_transform(); Transform2D xf = get_final_transform();
@ -355,8 +335,8 @@ Vector2 World::get_camera_coords(const Vector2 &p_viewport_coords) const {
} }
Vector2 World::get_camera_rect_size() const { Vector2 World::get_camera_rect_size() const {
if (_override_world) { if (_overriding_world) {
return _override_world->get_camera_rect_size(); return _overriding_world->get_camera_rect_size();
} }
return size; return size;
@ -448,6 +428,7 @@ void World::_add_override_cameras_into(World *p_from) {
World::World() { World::World() {
world_2d = Ref<World2D>(memnew(World2D)); world_2d = Ref<World2D>(memnew(World2D));
_override_world = NULL; _override_world = NULL;
_overriding_world = NULL;
_override_in_parent_viewport = false; _override_in_parent_viewport = false;
camera = NULL; camera = NULL;
_own_active_camera = NULL; _own_active_camera = NULL;
@ -574,26 +555,6 @@ void World::_propagate_exit_world(Node *p_node) {
} }
} }
void World::_add_overridden_world(World *p_world) {
ERR_FAIL_COND(!p_world);
_overriding_worlds.push_back(p_world);
}
void World::_remove_overridden_world(World *p_world) {
ERR_FAIL_COND(!p_world);
for (int i = 0; i < _overriding_worlds.size(); ++i) {
World *w = _overriding_worlds[i];
if (w == p_world) {
_overriding_worlds.remove(i);
return;
}
}
ERR_FAIL();
}
void World::_own_world_3d_changed() { void World::_own_world_3d_changed() {
ERR_FAIL_COND(world_3d.is_null()); ERR_FAIL_COND(world_3d.is_null());
ERR_FAIL_COND(own_world_3d.is_null()); ERR_FAIL_COND(own_world_3d.is_null());
@ -645,12 +606,6 @@ void World::_notification(int p_what) {
case NOTIFICATION_EXIT_TREE: { case NOTIFICATION_EXIT_TREE: {
if (!Engine::get_singleton()->is_editor_hint()) { if (!Engine::get_singleton()->is_editor_hint()) {
set_override_world(NULL); set_override_world(NULL);
while (_overriding_worlds.size() > 0) {
World *w = _overriding_worlds[0];
w->set_override_world(NULL);
}
} }
} break; } break;
} }

View File

@ -28,6 +28,7 @@ public:
bool get_override_in_parent_viewport(); bool get_override_in_parent_viewport();
void set_override_in_parent_viewport(const bool value); void set_override_in_parent_viewport(const bool value);
//If a World has an override these are overridden
Ref<World2D> find_world_2d() const; Ref<World2D> find_world_2d() const;
Ref<World3D> find_world_3d() const; Ref<World3D> find_world_3d() const;
Ref<World2D> find_world_2d_no_override() const; Ref<World2D> find_world_2d_no_override() const;
@ -38,6 +39,19 @@ public:
void set_override_world(World *p_world); void set_override_world(World *p_world);
void set_override_world_bind(Node *p_world); void set_override_world_bind(Node *p_world);
// If a world has an override the override defers these to the overridden
// As these are called by the child Nodes of the overriding world
// Viewport root
// -- World w1
// ---- PanelContainer pc
// w1 is set as override for the root.
// pc's CanvasItem will use the canvas in w1, and will likely call gui_reset_canvas_sort_index() in w1 at least some point.
// What we want, is to defer this call to the root viewport, as that is the class that is able to deal with it.
// This is what makes overrides transparent to nodes like the Camera, as they can just use the world that they are a child of
// and overrides can be handled for them in the backgorund.
virtual void gui_reset_canvas_sort_index(); virtual void gui_reset_canvas_sort_index();
virtual int gui_get_canvas_sort_index(); virtual int gui_get_canvas_sort_index();
@ -87,9 +101,6 @@ public:
virtual void _update_listener_2d(); virtual void _update_listener_2d();
protected: protected:
void _add_overridden_world(World *p_world);
void _remove_overridden_world(World *p_world);
virtual void _own_world_3d_changed(); virtual void _own_world_3d_changed();
virtual void _on_set_use_own_world_3d(bool p_use_own_world_3d); virtual void _on_set_use_own_world_3d(bool p_use_own_world_3d);
virtual void _on_set_world_3d(const Ref<World3D> &p_old_world); virtual void _on_set_world_3d(const Ref<World3D> &p_old_world);
@ -113,8 +124,8 @@ protected:
bool _override_in_parent_viewport; bool _override_in_parent_viewport;
World *_override_world; World *_override_world;
World *_overriding_world;
Vector<World *> _overriding_worlds;
Vector<Camera *> _override_cameras; Vector<Camera *> _override_cameras;
Camera *camera; Camera *camera;