Skip to content

Commit

Permalink
Merge pull request #58386 from KoBeWi/fix3bility
Browse files Browse the repository at this point in the history
  • Loading branch information
akien-mga authored Feb 21, 2022
2 parents c221539 + 642591b commit 4e44a15
Show file tree
Hide file tree
Showing 4 changed files with 19 additions and 10 deletions.
2 changes: 1 addition & 1 deletion editor/plugins/canvas_item_editor_plugin.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -3756,7 +3756,7 @@ void CanvasItemEditor::_draw_invisible_nodes_positions(Node *p_node, const Trans
}

CanvasItem *canvas_item = Object::cast_to<CanvasItem>(p_node);
if (canvas_item && !canvas_item->is_visible()) {
if (canvas_item && !canvas_item->is_visible_in_tree()) {
return;
}

Expand Down
23 changes: 16 additions & 7 deletions scene/2d/canvas_item.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -353,25 +353,31 @@ bool CanvasItem::is_visible_in_tree() const {
return visible && parent_visible_in_tree;
}

void CanvasItem::_propagate_visibility_changed(bool p_visible, bool p_was_visible) {
void CanvasItem::_propagate_visibility_changed(bool p_visible, bool p_is_source) {
if (p_visible && first_draw) { //avoid propagating it twice
first_draw = false;
}
parent_visible_in_tree = p_visible;
if (!p_is_source) {
parent_visible_in_tree = p_visible;
}
notification(NOTIFICATION_VISIBILITY_CHANGED);

if (visible && p_visible) {
update();
} else if (!p_visible && (visible || p_was_visible)) {
} else if (!p_visible && (visible || p_is_source)) {
emit_signal(SceneStringNames::get_singleton()->hide);
}
_block();

for (int i = 0; i < get_child_count(); i++) {
CanvasItem *c = Object::cast_to<CanvasItem>(get_child(i));

if (c && c->visible) { //should the toplevels stop propagation? i think so but..
c->_propagate_visibility_changed(p_visible);
if (c) { // Should the top_levels stop propagation? I think so, but...
if (c->visible) {
c->_propagate_visibility_changed(p_visible);
} else {
c->parent_visible_in_tree = p_visible;
}
}
}

Expand All @@ -386,11 +392,14 @@ void CanvasItem::set_visible(bool p_visible) {
visible = p_visible;
VisualServer::get_singleton()->canvas_item_set_visible(canvas_item, p_visible);

if (!is_inside_tree()) {
if (!parent_visible_in_tree) {
if (is_inside_tree()) {
notification(NOTIFICATION_VISIBILITY_CHANGED);
}
return;
}

_propagate_visibility_changed(p_visible, !p_visible);
_propagate_visibility_changed(p_visible, true);
_change_notify("visible");
}

Expand Down
2 changes: 1 addition & 1 deletion scene/2d/canvas_item.h
Original file line number Diff line number Diff line change
Expand Up @@ -210,7 +210,7 @@ class CanvasItem : public Node {

void _toplevel_raise_self();

void _propagate_visibility_changed(bool p_visible, bool p_was_visible = false);
void _propagate_visibility_changed(bool p_visible, bool p_is_source = false);

void _update_callback();

Expand Down
2 changes: 1 addition & 1 deletion scene/main/canvas_layer.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ void CanvasLayer::set_visible(bool p_visible) {
if (c->is_visible()) {
c->_propagate_visibility_changed(p_visible);
} else {
c->notification(CanvasItem::NOTIFICATION_VISIBILITY_CHANGED);
c->parent_visible_in_tree = p_visible;
}
}
}
Expand Down

0 comments on commit 4e44a15

Please sign in to comment.