-
Notifications
You must be signed in to change notification settings - Fork 3
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
What is the advantage of this repo versus compiling Godot with disable_3d=yes
?
#2
Comments
In Pixel Engine project, the aim is to create a lightweight editor and engine by removing most of the 3D code. While the process of disabling 3D functionality in the Godot engine is still a work in progress, the objective remains the same: to eliminate all 3D code from the export templates. However, optimizing this process may take longer as the focus is on performance for both 3D and 2D aspects. The ultimate goal of the project is to create an engine that is completely free of 3D code. This will enable the development of a more efficient and customizable 3D disable feature for the Godot Engine, where the 3D files can be separated into their own folders and disabled during the building process for both the Editor and Export templates. |
Also we are working towards optimizing Godot Engine 2D performance. please have a look on this article. IntroductionAfter three years of working with Godot, I wanted to share my feedback and insights on this powerful game development engine. As a dedicated user of Godot, I have experienced both its strengths and areas where improvements could be made. Through this feedback, I hope to contribute to the ongoing development and growth of the Godot community. Let's dive into the details and explore the strengths and areas for improvement in Godot! By default, Godot's core features and functionalities are bundled together in a single monolithic binary. This can make it challenging for developers to selectively include or exclude specific features based on their project requirements. This lack of modularity can result in larger binary sizes and potential overhead. 3D within 2D and 2D within 3D!One of the touted strengths of Godot is its capability to seamlessly integrate 3D elements within a 2D environment and vice versa. While this feature is often highlighted as a major selling point, it is important to acknowledge its limitations and clarify any misconceptions that may arise. The Role of the Dedicated 2D Engine in Godot and Modularity!Most 2D games don't require the use of meshes or advanced 3D features. While Godot has a dedicated 2D engine, it doesn't provide a straightforward option to fully disable 3D functionality. This can be seen as a limitation, especially for developers who want to create purely 2D games without any overhead or unnecessary features. It may seem counterintuitive to have a dedicated 2D engine within Godot without the ability to exclusively use the 2D engine. Godot is designed to be a flexible and versatile game engine that can support a wide range of game development needs. By including both 2D and 3D capabilities, Godot allows developers to seamlessly blend the two and create hybrid games that incorporate elements from both dimensions. This flexibility caters to developers who may want to experiment with mixed 2D and 3D gameplay or transition from 2D to 3D gradually. When considering the default inclusion of certain nodes in Godot's dedicated 2D engine, it's important to acknowledge that while many games are made with Godot, only a few utilize nodes such as Tree Node, Graph Node, and TextEdit Node. Additionally, it is rare for 2D games to make use of 3D nodes. This raises the question of whether including these nodes by default is the best choice. One suggestion is to have a stronger, more separated editor that is decoupled from the engine. This editor could ship with the ability to build export templates internally, allowing users to include or exclude specific features and nodes as desired. Furthermore, this editor should be easily installable and updatable without being sandboxed. While the current inclusion of certain nodes by default in the Godot editor aims to provide consistency and ease of use, as well as a close integration between the editor and engine, the concerns raised highlight the need for a more streamlined and customizable editor experience. Such an editor would cater to the specific needs of developers, offering greater flexibility and efficiency in game development. Conclusion
SolutionAfter discussing this with Aaron, he highlighted the engine profile system in Godot. This system allows us to automatically generate a list of classes used by the current project and exclude any unused ones during registration. By leveraging the linker, any dead code, including exposed but unused elements, is automatically removed. While this approach may not be as comprehensive as disabling code with compile flags, it still significantly reduces unnecessary engine code. Aaron has also submitted pull requests that focus on optimizing 2D performance. For specific 3D disabling, you can check out the following pull requests: Move 2D and 3D resources to their own folders Disable registering 3D physics types when 3D is disabled Move 3D scene import classes to their own folder These pull requests aim to provide a better disable functionality for 3D features in both the Godot editor and engine. By utilizing the engine profile system and exploring these pull requests, developers have more control over optimizing their projects and reducing unnecessary code. To properly explore the possibilities of a 2D-optimized Godot experience, I am maintaining a fork of Godot called Pixel Engine. Longer term I would love to contribute these changes upstream. Pixel Engine removes most 3D functionality. Building the editor with the also we have some plans that we can work on:
By addressing these points, we can provide developers with a better experience when it comes to building export templates and disabling 3D features in Godot. collaborationWe invite developers to join us in our efforts to enhance the 2D performance of Godot. Together, we can work towards optimizing the engine and making it even better for 2D game development. If you're passionate about improving the performance of Godot and want to contribute your skills and ideas, we welcome you to join our community. Let's collaborate and create a more efficient and powerful 2D game development experience with Godot. Here are our Discord usernames: Feel free to join us on Discord to discuss and collaborate on improving the 2D performance of Godot. We look forward to connecting with you! |
Just curious :-)
See: https://docs.godotengine.org/en/stable/contributing/development/compiling/optimizing_for_size.html#disabling-3d
The text was updated successfully, but these errors were encountered: