-
-
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 editor vital redraws only option #53463
Conversation
8bdf3f7
to
0b7f1d5
Compare
0b7f1d5
to
4ea4313
Compare
4ea4313
to
583f08d
Compare
f7c02aa
to
b995895
Compare
I'm really not sure about this. I like the idea of reducing the work the engine does while in the editor, but to me this seems to add significant complexity for uncertain benefit. When would it make sense for a user to set it to vital updates only? The tradeoff is essentially trading your scene working for extra battery life. So the possible subset of users for this feature are developers who are working from laptops that aren't plugged in and who don't care about their VFX being visible. Further, the redraw requests only happen when the editor viewport is open, so the battery savings are limited to the periods of time when the user is working in the viewport. I would expect that users would want to see their animations, particles, and shaders while in the viewport. Further, users will have to turn this setting off if they want to develop particle effects, shader effects, or animations. To me, that seems like a real hindrance. |
Well, I'm not using a laptop, but a fanless PC, and for the last 2 and a half years using godot I've had to make sure to manually close scene tabs, and do stuff to turn off shaders to prevent overloading my PC. For people like me, it means we just switch one option and we are sorted. We can program gdscript without worrying about which scenes are open in the background etc. Then on the rare occasions we need to edit a time shader or something, we just switch it back on. It's actually really useful for people on non-monster PCs. There's also a whole section of people who are quite eco-minded about power use and don't want to be constantly using CPU cycles for no reason, or want those cycles available for other tasks in the background. Running Godot on an old laptop, or raspberry PI, you can't really do that and run even a browser at the same time. With this it makes all this possible on basic machines.
In theory yes, in practice no. I'm sitting here with blubits demo project open and it's quite happily spinning away while I'm editing gdscript, or have a 2d window open with nothing visible updating... |
btw there was a proposal about it: godotengine/godot-proposals#942 |
My comment above was made under the assumption that shaders only force a redraw while they are visible in the viewport and the viewport is visible. If we could fix it so that the redraw only occurs when the element that needs to be redrawn is visible, would that change the need for this proposal? |
Shouldn't this just be fixed? Why draw scenes in the background in the first place if they aren't visible? |
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.
The only thing I don't love is the addition of && OS::get_singleton()->_are_low_priority_redraws_enabled()
scattered conditionals. Whats the rule here for future additions and checks? How can i tell what VS stuff should be guarded by _are_low_priority_redraws_enabled
or not?
So only comment, is that it's kinda scattered around where these checks need to go as it's different for particles, animation tree, tree players, and I'm guessing anything in the future.
Out of curiosity, why choose these specific things to put into _are_low_priority_redraws_enabled
whats the threshold criteria, or is it arbitrary?
Yes sure the updating when not selected should be fixed. This was a longstanding problem and I think a PR was done about a year ago which helped prevent it (I forget the details). But it's a multi-surface problem I suspect - anything anywhere that gets updated can request a redraw. And anything calling the
No, not really, that's sort of an 'also' problem that is derailing the main point. The issue is that on some machines the editor is difficult to use on a complex project because of the constant unneeded processing, and it's a massive pain. You can't select something in the UI because it's busy updating everything because of a shader that you aren't even interested in seeing. Then some program in the background can't run properly because Godot is hogging all the CPU (while you are maybe out of the room making a cup of tea!). So in practice you end up shutting Godot down all the time because it is too expensive to leave running. The PR itself is not super complex.
I started off just by altering the
See visual_server_raster.h: e.g.
As to which areas have this in, This is new, but the old version is roughly similar except you historically had to recompile (but no longer). You can now just put a breakpoint on the
There are a few cases in things like process notifications where you could potentially just turn off INTERNAL_PROCESS etc as an alternative. We did this for the Camera a while back. But the logic is a bit messy and the bulk of the benefit can be done simply by wrapping the notification in an |
Right, but this is kinda to be expected as the editor itself uses the game engine and will repaint everything, not a graphics stack that will only repaint areas that change and need recomposition. I'm guessing is why any change to VS is going to redraw, which is expected for a game engine renderer. And isn't the background CPU usage issue covered by platform specifics about whether or not the editor is a foregrounded/focused window or not? The main tick should be throttled to something very low (4-6fps is common) for windows or applications that aren't in the foreground or focused.
The above seems like an issue of doing some work on the main engine thread, that should have probably be offloaded to a worker? A side note, is I sometimes use performance in the editor as a general baseline & feeling to how something is going to perform exported. |
This is done now, I've added a |
75618d9
to
21b554a
Compare
0a1ec0c
to
1eb35cc
Compare
Just made some small changes: SummaryI noticed that in the old state, particle systems would not display at all when first loaded (aside from the particle 2D icon). This was occurring because particle systems need to be updated at least a few times in order to emit some particles(!). This was confusing in terms of user experience. I've done a fix for this and the experience is vastly better. The problem was occurring because particles were not being processed at all in vital updates mode. So I made a slight modification so that a As a result of this I have unified the function name to Note that the update with redraw is not used for the animation players. The reason being that the act of processing the animations calls the |
1eb35cc
to
6a26282
Compare
When editor continuous redraws is switched off, the editor only redraws when a redraw_request was issued by an element in the scene. This works well in most situations, but when scenes have dynamic content they will continuously issue redraw_requests. This can be fine on high power desktops but can be an annoyance on lower power machines. This PR splits redraw requests into high and low priority requests, defaulting to high priority. Requests due to e.g. shaders using TIME are assigned low priority. An extra editor setting is used to record the user preference and an extra option is added to the editor spinner menu, to allow the user to select between 3 modes: * Continuous * Update all changes * Update vital changes
6a26282
to
a0c6d16
Compare
Thanks! |
I wonder if the vital redraws only option could be automatically enabled when the project is running (and then disabled when the project is stopped). This would fix performance issues when running a project while an animation is being displayed in the editor. There's a FPS limiter when the editor is unfocused right now, but it doesn't always suffice on slower hardware. To support this, I guess an additional boolean editor setting should be added, such as "Automatic Vital Redraws Only When Running Project". |
Yeah we can certainly have a look at this. 👍 |
When editor continuous redraws is switched off, the editor only redraws when a redraw_request was issued by an element in the scene. This works well in most situations, but when scenes contain dynamic content they will continuously issue redraw_requests.
This can be fine on high power desktops but can be an annoyance on lower power machines / laptops where it will eat battery.
This PR splits redraw requests into high and low priority requests, defaulting to high priority. Requests due to e.g. shaders using TIME are assigned low priority.
An extra editor setting is used to record the user preference and an extra option is added to the editor spinner menu, to allow the user to select between 3 modes:
Fixes #16397
Implements godotengine/godot-proposals#942
See for instance #40499
(There is no requirement to have a quick changeable setting in the spinner menu, I've added this for discussion, but it would also be perfectly feasible to have the editor settings option only.)
Notes
redraw_requests
to support theDEV_ENABLED
flag. Now no recompile is necessary on DEV builds, you can place the breakpoints immediately in_changes_changed()
.Supported so far