While working on a debug shader for a bevy project I lost precious hours debugging strange behaviour from a fragment shader.

@fragment
fn fragment(input: FragmentInput) -> @location(0) vec4<f32> {
    return vec4(0.188, 0.298, 0.478, 1.0);
}

What would you expect the color of the resulting fragments be? Wrong! It’s not #304C7A.

For some reason, I might have never noticed this in any of my shader work. Or it’s new in bevy. Or it is setting you can configure in the WGPU output texture.

But the colors returned from a fragment shader should be in Linear RGB, not sRGB. I used this function to get the correct color:

fn srgb_to_linear(srgb_color: vec3<f32>) -> vec3<f32> {
    return pow(srgb_color, vec3<f32>(2.2));
}