-
-
Notifications
You must be signed in to change notification settings - Fork 97
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
Implement support for removing editor-only nodes from an exported project #8148
Comments
I believe another workaround that does not involve a runtime script is using https://docs.godotengine.org/en/stable/classes/class_editorexportplugin.html#class-editorexportplugin-method-customize-scene However, for resources it does not seem possible to exclude it from exports easily, since returning null just means "don't modify the resource". |
I remember there was a proposal/discussion, but I can't find it.
See:
|
Agreed. I am also here looking for the feature. This could be useful when prototyping, creating a delightful mess in my node tree with bunch of temporary disabled nodes that all are variations of single thing. I understand that this is solvable with basic organizational skills and actually sorting my scripts well in the project hierarchy but I just can't force myself to do that and I'd much prefer to have nodes thaat just don't appear in the game itself and are editor-only nodes that I could use as guides/prototypes(sketching)/notes... |
From my comment in godotengine/godot#56446 (comment): It would be best to do a more powerful and generic way to exclude nodes/resources/code anywhere. IMO the best implementation would be through a property
This property would have the special value In terms of UI, you could make that "editor-only" button (see PR) toggle just the editor-only state by default, and show a more complete context menu with specific toggles if you right-click it or if it's any value except |
An approach for your use case is to treat your scene as an intermediary resource. 3D model files, for example, are "raw" scenes that are post-processed at import time into the actual scenes Godot instantiates when you use them. Likewise, you can use a source scene to position and configure your meshes and then run it through a post-save script to bake everything into a single mesh and save it to a separate file. You can already do it with a tool script and ResourceSaver.save. The source scene is never used at runtime since its only purpose is to edit the baked mesh. All that's left is to exclude the source scene from the exported project to avoid bloat. This can already be done with EditorExportPlugin._export_file too. I use this method a lot for level building. I want to keep the original scene for easy editing but rarely want to use it directly since I can do numerous cleanups and optimizations for the version I use at runtime. |
It would be even more useful filtering exporting nodes based on feature tags in the export. |
Describe the project you are working on
A voxel-based open-world game. I build the world out of modular pieces I make in MagicaVoxel, and I have scripts to procedurally populate the world.
Describe the problem or limitation you are having in your project
I compose my world out of tens of thousands of modular pieces that I made in MagicaVoxel, and some procedural voxel objects (e.g. L trees). These modular pieces are often overlapping or right next to each other (lots of hiding and duplicate faces). It's very slow to render so many individual meshes, so I put all static voxel objects into the same group, and I have another script that bakes them into a single chunked global mesh that is very fast to render, and I hide all the individual meshes.
I also have tool scripts that procedurally (at editor time) instantiate nodes. For example, I'll place a spline along a river bed, and my tool will instantiate hundreds of slightly rotated/offset rocks.
I can scan for objects in my static group at play time and destroy the tens of thousands of them, but this seems like unneccessary work, and also unneccessary data, as my shipped game doesn't need "rock 6667", "rock 6668", "rock 6669", nor does it need the underlying voxel resources, nor do I want my editor-time procedural nodes ("spawn along spine", etc). I want to ship my game with only the optimized mesh.
I saw godotengine/godot#12453 which was closed in favor of #370, which was closed in favor of #1835, which doesn't solve my problem. Maybe #3433 is related, but I want the nodes complete stripped from the exported build, not simply "hidden".
Describe the feature / enhancement and how it helps to overcome the problem or limitation
editor_only
, and these resources don't make it into exported projects.@editor_only.
These properties don't get serialized and methods don't get compiled into exported projects.Describe how your proposal will work, with code, pseudo-code, mock-ups, and/or diagrams
Editor only nodes:
In the "Group Editor", the option to toggle if a group is editor only. When I'm not in the editor (I hit "play" or export the project), these nodes and their children are completely gone.
In my voxel game, I would create 2 groups that I tag as editor only: "Baked Voxel Objects" and "Procedural generators". I will use this for my tools and objects that I only ever need in the editor.
Editor Only Resources
A boolean property on resources to say if they are editor only.
In my voxel importer script, I will set the
editor_only
property to true on the generated Resources containing the voxel data. These resources will never make it into the exported project.@editor_only properties and methods
If this enhancement will not be used often, can it be worked around with a few lines of script?
This can be worked around with a runtime script that scans all group objects and frees them. However, there is runtime overhead in doing this, and the data still makes it into the exported project - using up the end user's disk and memory.
Is there a reason why this should be core and not an add-on in the asset library?
This extends the node management and gdscript which touches core code.
The text was updated successfully, but these errors were encountered: