-
-
Notifications
You must be signed in to change notification settings - Fork 21.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add a warning for when the scene root node is transformed #81892
Add a warning for when the scene root node is transformed #81892
Conversation
a9dd0ac
to
532fa0a
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Tested locally, running fine.
I always miss the presence of GUID or some other unique identification on which is the object that generated the warning, but in this case it seens to be pretty much on topic here.
Note that this may change if we do decide to print node configuration warnings in a running project (when debugging is enabled). This is something I've considered at some point, as it can help with difficult-to-diagnose runtime-only issues without requiring code duplication. See godotengine/godot-proposals#3004. |
532fa0a
to
a6efd0d
Compare
a6efd0d
to
aa9bd7a
Compare
I'm personally not a fan of this. I believe warnings should be reserved for when the configuration of a node results in behavior that in all circumstances is not correct (like a collision without a node that derives from it). I don't see anything objectively wrong with changing the transforms of a root node, as long as instantiations of it are handled correctly such as in the above-mentioned PR. |
aa9bd7a
to
13533ad
Compare
The warning isn't entirely correct. Most often only position is overriden, e.g. when dropping the scene into viewport. |
13533ad
to
12bdf93
Compare
12bdf93
to
9a123b0
Compare
9a123b0
to
4c4c08c
Compare
4c4c08c
to
da2ba4f
Compare
I would argue that if users want a scene to have inherent scale or rotation, they should instead scale or rotate the child nodes. This way this inherent scale or rotation will not be discarded if the user sets If a user sets a scene's scale to be (2, 2, 2), it's expected that the scene should get bigger by a factor of 2. If the original scene had a root node scale of (10, 10, 10), this would result in the scene getting smaller by a factor of 5. |
da2ba4f
to
d7fe2cf
Compare
d7fe2cf
to
38b4f82
Compare
Isn't this (at least partially) superseded by #80561? |
@KoBeWi They are separate things, but you are correct that there is a partial overlap. However, this PR covers the case of a user accidentally transforming their scene's root node. |
So I'm not sure about the warning itself, but the implementation is fine. Except the warning does not update when you transform the node; you have to save the scene or update warnings in other way. Is that expected behavior? |
38b4f82
to
4a4d2ff
Compare
@KoBeWi Yes, I noticed that too. It's a minor problem, I think it's fine, unless someone knows how to fix it. |
It's confusing when you reset transform, but the warning is still there. At least mention in the warning that clearing it requires scene reload. |
4a4d2ff
to
dacadcf
Compare
dacadcf
to
cf2fb47
Compare
cf2fb47
to
e1429cd
Compare
Thanks! |
@aaronfranke As part of my configuration info refactor #90049 I need to somehow integrate this into the new system. Was there any particular reason the checks and warnings were added to I assume it was because |
@RedMser This was done because the warning is only valid for the scene root node, not just any Node2D/Node3D. Also, in general, I would be interested in having less editor-specific stuff inside of non-editor classes, even if guarded by |
I can see where you're coming from, but I really don't like the thought of having the list of configuration info populated from multiple different sources. It's already tedious to follow the inheritance chain for config warnings, but having to now also check a separate function as an additional source of warnings doesn't seem great to me. Sadly I don't have a proposal for a solution that makes both of us happy. Especially with how Resource would now also get config info, which means more editor-specifics in these classes... |
tbh you can check whether the node is scene root from within the node, by using |
This is a low priority PR, but I think it's a good idea.
This PR adds a configuration warning for when the root node has a transform. This is usually a mistake when saving a branch as a scene, or having the wrong node selected when doing transform operations. Instances of the scene will set their own transform, so it's best practice to not have the root be transformed.