2021-02-21 18:30:12 +01:00
|
|
|
#version 450
|
|
|
|
|
|
|
|
|
|
layout(set = 0, binding = 0) uniform sampler2D tex;
|
|
|
|
|
|
|
|
|
|
layout(location = 0) in vec2 uv;
|
|
|
|
|
layout(location = 0) out vec4 out_color;
|
|
|
|
|
|
2025-02-27 16:48:32 +01:00
|
|
|
// struct wlr_vk_frag_texture_pcr_data
|
2025-02-27 16:57:00 +01:00
|
|
|
layout(push_constant, row_major) uniform UBO {
|
|
|
|
|
layout(offset = 80) mat4 matrix;
|
|
|
|
|
float alpha;
|
2025-03-01 12:43:08 +01:00
|
|
|
float luminance_multiplier;
|
2021-02-21 18:30:12 +01:00
|
|
|
} data;
|
|
|
|
|
|
2022-11-11 22:53:06 -05:00
|
|
|
layout (constant_id = 0) const int TEXTURE_TRANSFORM = 0;
|
|
|
|
|
|
2023-05-24 11:25:30 +02:00
|
|
|
// Matches enum wlr_vk_texture_transform
|
2022-11-11 22:53:06 -05:00
|
|
|
#define TEXTURE_TRANSFORM_IDENTITY 0
|
|
|
|
|
#define TEXTURE_TRANSFORM_SRGB 1
|
2025-02-27 16:37:00 +01:00
|
|
|
#define TEXTURE_TRANSFORM_ST2084_PQ 2
|
2025-08-17 15:51:26 +00:00
|
|
|
#define TEXTURE_TRANSFORM_GAMMA22 3
|
2022-11-11 22:53:06 -05:00
|
|
|
|
2023-10-17 12:21:08 +02:00
|
|
|
float srgb_channel_to_linear(float x) {
|
2024-01-23 19:54:22 +00:00
|
|
|
return mix(x / 12.92,
|
|
|
|
|
pow((x + 0.055) / 1.055, 2.4),
|
|
|
|
|
x > 0.04045);
|
2022-11-11 22:53:06 -05:00
|
|
|
}
|
|
|
|
|
|
2025-02-27 16:22:17 +01:00
|
|
|
vec3 srgb_color_to_linear(vec3 color) {
|
|
|
|
|
return vec3(
|
2023-10-17 12:21:08 +02:00
|
|
|
srgb_channel_to_linear(color.r),
|
|
|
|
|
srgb_channel_to_linear(color.g),
|
|
|
|
|
srgb_channel_to_linear(color.b)
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
2025-02-27 16:37:00 +01:00
|
|
|
vec3 pq_color_to_linear(vec3 color) {
|
|
|
|
|
float inv_m1 = 1 / 0.1593017578125;
|
|
|
|
|
float inv_m2 = 1 / 78.84375;
|
|
|
|
|
float c1 = 0.8359375;
|
|
|
|
|
float c2 = 18.8515625;
|
|
|
|
|
float c3 = 18.6875;
|
|
|
|
|
vec3 num = max(pow(color, vec3(inv_m2)) - c1, 0);
|
|
|
|
|
vec3 denom = c2 - c3 * pow(color, vec3(inv_m2));
|
|
|
|
|
return pow(num / denom, vec3(inv_m1));
|
|
|
|
|
}
|
|
|
|
|
|
2021-02-21 18:30:12 +01:00
|
|
|
void main() {
|
2025-02-27 16:22:17 +01:00
|
|
|
vec4 in_color = textureLod(tex, uv, 0);
|
|
|
|
|
|
|
|
|
|
// Convert from pre-multiplied alpha to straight alpha
|
|
|
|
|
float alpha = in_color.a;
|
|
|
|
|
vec3 rgb;
|
|
|
|
|
if (alpha == 0) {
|
|
|
|
|
rgb = vec3(0);
|
|
|
|
|
} else {
|
|
|
|
|
rgb = in_color.rgb / alpha;
|
|
|
|
|
}
|
|
|
|
|
|
2022-11-11 22:53:06 -05:00
|
|
|
if (TEXTURE_TRANSFORM == TEXTURE_TRANSFORM_SRGB) {
|
2025-02-27 16:22:17 +01:00
|
|
|
rgb = srgb_color_to_linear(rgb);
|
2025-02-27 16:37:00 +01:00
|
|
|
} else if (TEXTURE_TRANSFORM == TEXTURE_TRANSFORM_ST2084_PQ) {
|
|
|
|
|
rgb = pq_color_to_linear(rgb);
|
2025-08-17 15:51:26 +00:00
|
|
|
} else if (TEXTURE_TRANSFORM == TEXTURE_TRANSFORM_GAMMA22) {
|
|
|
|
|
rgb = pow(rgb, vec3(2.2));
|
2022-11-11 22:53:06 -05:00
|
|
|
}
|
|
|
|
|
|
2025-03-01 12:43:08 +01:00
|
|
|
rgb *= data.luminance_multiplier;
|
|
|
|
|
|
2025-02-27 16:57:00 +01:00
|
|
|
rgb = mat3(data.matrix) * rgb;
|
|
|
|
|
|
2025-02-27 16:22:17 +01:00
|
|
|
// Back to pre-multiplied alpha
|
|
|
|
|
out_color = vec4(rgb * alpha, alpha);
|
|
|
|
|
|
2021-10-16 15:31:48 +01:00
|
|
|
out_color *= data.alpha;
|
2021-02-21 18:30:12 +01:00
|
|
|
}
|