-
-
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
Add a clipping plane property to SpatialMaterial #4423
Comments
Related to #1779, #3021 and #3922. I think it's better to focus on making the default materials extensible, as their default implementation can't grow forever without bound. This is especially the case for features that won't be used in most projects. Otherwise, performance will inevitably go down as more shader variants need to be compiled (or as more branching is done). PS:
BaseMaterial3D -> ShaderMaterial conversion could be exposed to scripting, but it would only work within editor builds, not in exported projects. That said, in the In |
@Calinou You are so right! That is a far better idea to expose the material for easier custom shader injection. Also, grazi for the heads up about I feel like I've heard it around the Godot doesn't yet have stencil buffering, or that it's slated for 4.0? (wondering if I should look into taking a stab at implemening it, or focus on more pressing features of my game, and wait for more graphics savvy developers figure that out) and thank-you for all the resources to look up! |
Stencil support isn't planned for 4.0, but it could happen in a future 4.x release. For more information, there's also an old discussion about this (back when Godot only had OpenGL renderers): godotengine/godot#23721 See also #1753, which is a very similar proposal. |
Describe the project you are working on
I am developing a 'euclidean hole' plugin (aka. portals).
This proposed feature works in tandem with my previous PR: godotengine/godot#56664
Using the most common strategies implemented by Valve and detailed in Sebastian Lague's tutorial, the original and duplicate mesh which pass through the portal to create the illusion of a single body must be clipped by the portal to complete the effect.
Describe the problem or limitation you are having in your project
Shader code (used in this completed feature) discards any vertex behind the provided plane.
However, converting all mesh materials to a shader and injecting the code is time consuming and limits the flexibility of making quick adjustments to a regular spatial material.
This complexity increases with the number of meshes chosen to be able to pass through a portal.
Describe the feature / enhancement and how it helps to overcome the problem or limitation
by baking in the shader code, which does not effect any other shader options, we benefit from the flexibility to turn on and off the clipping portion of the shader through scripts.
Additionally, any mesh with a spatial material can be clipped by a plane. Which improves the pipeline for importing assets that require this feature.
Describe how your proposal will work, with code, pseudo-code, mock-ups, and/or diagrams
Clipping plane turned off
data:image/s3,"s3://crabby-images/a1661/a1661526bd8c02fde6dc504b05cb09f18722d9bc" alt="image"
Clipping plane turned on (default (0, 0, 0, 0))
data:image/s3,"s3://crabby-images/45dcc/45dcc2484ade42090cecbdf2dc0053d4c6fa6f7e" alt="image"
The clipping plane data can be update like any other spatial material property using gdscript.
If this enhancement will not be used often, can it be worked around with a few lines of script?
and editor script could likely be written to convert materials from spatial to shader, and inject/remove the code for the effect, but it would have to access editor features, as at the time this material feature was developed there was no way I had found to convert materials using gdscript.
Is there a reason why this should be core and not an add-on in the asset library?
such an editor script would be more resource intensive and less intuitive. However, that assessment comes a priori of having written any plugins.
The text was updated successfully, but these errors were encountered: