-
Notifications
You must be signed in to change notification settings - Fork 107
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
Washed out texture colors #386
Comments
Kinda figured it out.
Hardcoding the surface configuration to So as far as I understand, while I don't have gamma correction implemented, I should pick a non-srgb format? |
This is related to linear / physical colorspace vs sRGB. It's common that in shaders you work with linear (i.e. physical) colors, so that things like interpolation (over faces) and lighting calculations are correct. But the value you want to put on your monitor you want to be in sRGB. This is a relatively complex topic. I wrote a post about this when I dove into this for our render engine pygfx. I'll try to explain it briefly for your use-case below. You can programmatically convert using the following Python code (somewhat verbose for clarity): def srgb2physical(c):
if c <= 0.04045:
return c / 12.92
else:
return ((c + 0.055) / 1.055) ** 2.4
def physical2srgb(c):
if c <= 0.0031308:
return c * 12.92
else:
return c ** (1 / 2.4) * 1.055 - 0.055 Another option is to use the What's also good to know is that in the majority of images, the colors are already in sRGB format. For your situation that means that you load the image, data is already sRGB, and with the You can either:
In most cases the second option is probably the best. In pygfx we take option 3, because colors come into the shader with different routes. We use this function to convert the color in the shader: fn srgb2physical(color: vec3<f32>) -> vec3<f32> {
let f = pow((color + 0.055) / 1.055, vec3<f32>(2.4));
let t = color / 12.92;
return select(f, t, color <= vec3<f32>(0.04045));
} |
I'm currently trying to use wgpu-native as a rendering backend with V, so I hope this is the right place to ask about this.
I've managed to get the pipeline setup to work and loaded a texture, but now the colors look wrong.
I'm not doing any lighting or effects, yet.
Left side is my texture, right side is how it's rendered:
I first suspected the PNG color values to be wrong, but those look fine to me.
Here's my render code. Not Rust, but should be similar enough to get the picture.
https://gitlab.com/valdala/valdala/-/blob/6be4385efd7bd3470010355f594345307ace6b8e/application/graphics/renderer.v
Here's the shader:
https://gitlab.com/valdala/valdala/-/blob/6be4385efd7bd3470010355f594345307ace6b8e/application/shaders/textured.wgsl
Here's most of the pipeline setup:
https://gitlab.com/valdala/valdala/-/blob/6be4385efd7bd3470010355f594345307ace6b8e/application/webgpu/device.v
The sampler type is set to
Filtering
and the texture format toRGBA8Unorm
.The pixel data is provided in four 8-bit unsigned integers, red, green, blue and alpha from 0 to 255.
As far as I understand, that should work?
The text was updated successfully, but these errors were encountered: