-
-
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
Allow specific materials to use bilinear mipmap filtering instead of trilinear #7411
Comments
While I do understand the proposal, I wonder if there is a way to make this less verbose, more accessible. I find the whole name |
I think the long names aren't too bad because they're not used frequently. They'll often be selected from a list in the editor too, be it the inspector or autocomplete. I can't think of a way to shorten them without losing clarity. The OpenGL constants like It could also be split up into two orthogonal settings, i.e.
Doing this in a non-confusing backwards compatible way would be a challenge, though. |
I did not know about that! But it's too limiting because it's project-wide; the 3D parts of the game do benefit from trilinear filtering. |
We can probably add an equivalent project setting that only affects 2D samplers' mipmap filtering mode. This way, compatibility with existing projects is preserved. |
What if someone wants to use linear-within-nearest-mipmap filtering with some 2D textures but not others? For example, if some textures have their scale animated, you'd want to use trilinear on those, but not on the others. My proposal would allow this. Are there any objections to the proposal, apart from the difficulty of picking names for the new constants? |
Edit: An alternative way is to expose a separate boolean property, aptly named Use Nearest Mipmap Filter below the filter mode property in BaseMaterial3D and CanvasItemMaterial. It can be hidden when the chosen filter mode has no mipmaps. In custom shaders, sampler filter modes would still use a I've left the old answer below for posterity. The issue is that adding new sampler modes will require adding them at the end of the enum to avoid breaking compatibility, which looks awkward. There's also high potential for confusion with users picking the "wrong" option for their project, as we usually go for the approach where the last options in the enums are the highest quality (and most expensive) ones. Imagine we have the following:
I can picture a lot of users picking Linear Mipmaps Anisotropic (Bilinear) instead of Linear Mipmaps Anisotropic for realistic-looking 3D scene setups. We could explicitly mention (Trilinear) in the existing mipmaps options, but not everyone knows that trilinear filtering is higher-quality than bilinear filtering. (Remember that most modern games don't give you a choice nowadays, so a lot of younger users will never have seen the difference.) The Use Nearest Mipmap Filter project setting name would also become a bit ambiguous, as it would effectively become a "force nearest mipmap filter" setting instead. It's not the end of the world though. |
Thank you for considering this!
Agreed that ordering is important. Are enums in the editor and documentation ordered by their integer value, or by the order in which
What would the default value be? To preserve backwards compatibility, when Nearest With Mipmaps is selected, it should be true, but when Linear With Mipmaps is selected, it should be false. |
The latter. |
By default, we always use trilinear filtering, even when using the Nearest Mipmaps filter mode on a material. It's important to make the distinction between texture filtering (nearest/linear) and mipmap filtering (bilinear/trilinear – which you may actually interpret as "nearest" and "linear" respectively). Mipmap filtering refers to the way mips are blended between each other, rather than the texture filtering for distant mipmaps. This means we can keep that new boolean property I have a testing project here: https://github.com/Calinou/godot-mipmaps-test |
I was basing myself on the naming and documentation, which says:
Your test project shows that that is only correct if It's all very confusing :( |
That documentation is incorrect, so I fixed it: godotengine/godot#83907 |
Describe the project you are working on
The GUI of a game, containing
TextureRect
s with line art, whose displayed size is not known ahead of time.Describe the problem or limitation you are having in your project
I want these textures to scale to arbitrary sizes, but look as crisp as possible without being pixelated. If the texture is displayed at close to its native size,
TEXTURE_FILTER_LINEAR
does the job nicely. However, if it's scaled down too much, then edges become jagged.The standard solution is of course to use mipmaps. In Godot we can do this using the
TEXTURE_FILTER_LINEAR_WITH_MIPMAPS
filter mode. But this results in a more blurred look, because it doesn't just interpolate between four adjacent texels, it also interpolates between two adjacent mipmap levels (trilinear interpolation).Describe the feature / enhancement and how it helps to overcome the problem or limitation
The best look would be obtained by selecting the nearest mipmap, and then interpolating within that mipmap. In OpenGL, this is what
GL_LINEAR_MIPMAP_NEAREST
does, which has been available for literally 30 years. But somehow Godot doesn't expose it.In 3D, this filter mode would result in a sharp edge between mipmap levels. But in 2D, as long as the scale of the texture doesn't change dynamically, it's a faster and better looking solution than trilinear interpolation. The difference is subtle but noticeable:
Describe how your proposal will work, with code, pseudo-code, mock-ups, and/or diagrams
We already have these:
TEXTURE_FILTER_NEAREST_WITH_MIPMAPS
=GL_NEAREST_MIPMAP_NEAREST
TEXTURE_FILTER_LINEAR_WITH_MIPMAPS
=GL_LINEAR_MIPMAP_LINEAR
The proposal is to add:
TEXTURE_FILTER_NEAREST_WITH_LINEAR_MIPMAPS
=GL_NEAREST_MIPMAP_LINEAR
TEXTURE_FILTER_LINEAR_WITH_NEAREST_MIPMAP
=GL_LINEAR_MIPMAP_NEAREST
In shaders, the hint format for
sampler2D
could be extended to:The second
nearest
/linear
indicates the interpolation between mipmap levels. If omitted, it defaults to the firstnearest
/linear
for backwards compatibility.If this enhancement will not be used often, can it be worked around with a few lines of script?
I suppose it could be done using a custom shader, but this would cost performance because the interpolation is done in shader code instead of native hardware.
Is there a reason why this should be core and not an add-on in the asset library?
Seems like a trivial addition when done in core, but a hassle when attempted as a library.
The text was updated successfully, but these errors were encountered: