Fix AudioStreamPlayer not paused on pause mode change

Fixes #58543.
This commit is contained in:
Paweł Fertyk 2023-11-23 13:41:05 +01:00 committed by Relintai
parent 63fac11503
commit 2154c87432
2 changed files with 25 additions and 12 deletions

View File

@ -617,25 +617,27 @@ void Node::set_pause_mode(PauseMode p_mode) {
} }
bool prev_inherits = data.pause_mode == PAUSE_MODE_INHERIT; bool prev_inherits = data.pause_mode == PAUSE_MODE_INHERIT;
bool prev_can_process = is_inside_tree() && can_process();
data.pause_mode = p_mode; data.pause_mode = p_mode;
if (!is_inside_tree()) { if (!is_inside_tree()) {
return; //pointless return; //pointless
} }
if ((data.pause_mode == PAUSE_MODE_INHERIT) == prev_inherits) { if ((data.pause_mode == PAUSE_MODE_INHERIT) != prev_inherits) {
return; ///nothing changed Node *owner = nullptr;
}
Node *owner = nullptr; if (data.pause_mode == PAUSE_MODE_INHERIT) {
if (data.parent) {
if (data.pause_mode == PAUSE_MODE_INHERIT) { owner = data.parent->data.pause_owner;
if (data.parent) { }
owner = data.parent->data.pause_owner; } else {
owner = this;
} }
} else {
owner = this;
}
_propagate_pause_owner(owner); _propagate_pause_owner(owner);
}
if (prev_can_process != can_process()) {
_propagate_pause_change_notification(can_process() ? NOTIFICATION_UNPAUSED : NOTIFICATION_PAUSED);
}
} }
Node::PauseMode Node::get_pause_mode() const { Node::PauseMode Node::get_pause_mode() const {
@ -738,6 +740,16 @@ int Node::seen_by_get_count() {
return data._seen_by.size(); return data._seen_by.size();
} }
void Node::_propagate_pause_change_notification(int p_notification) {
notification(p_notification);
for (int i = 0; i < data.children.size(); i++) {
if (data.children[i]->data.pause_mode == PAUSE_MODE_INHERIT) {
data.children[i]->_propagate_pause_change_notification(p_notification);
}
}
}
void Node::set_network_master(int p_peer_id, bool p_recursive) { void Node::set_network_master(int p_peer_id, bool p_recursive) {
data.network_master = p_peer_id; data.network_master = p_peer_id;

View File

@ -223,6 +223,7 @@ private:
void _print_stray_nodes(); void _print_stray_nodes();
void _propagate_pause_owner(Node *p_owner); void _propagate_pause_owner(Node *p_owner);
void _propagate_groups_dirty(); void _propagate_groups_dirty();
void _propagate_pause_change_notification(int p_notification);
Array _get_node_and_resource(const NodePath &p_path); Array _get_node_and_resource(const NodePath &p_path);
void _duplicate_signals(const Node *p_original, Node *p_copy) const; void _duplicate_signals(const Node *p_original, Node *p_copy) const;