-
Notifications
You must be signed in to change notification settings - Fork 24
/
yuv_to_rgb.glsl
40 lines (35 loc) · 1.17 KB
/
yuv_to_rgb.glsl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#[compute]
#version 450
// Invocations in the (x, y, z) dimension
layout(local_size_x = 8, local_size_y = 8, local_size_z = 1) in;
// Our textures
layout(r8, set = 0, binding = 0) uniform restrict readonly image2D tex_y;
layout(r8, set = 1, binding = 0) uniform restrict readonly image2D tex_u;
layout(r8, set = 2, binding = 0) uniform restrict readonly image2D tex_v;
layout(r8, set = 3, binding = 0) uniform restrict readonly image2D tex_a;
layout(rgba8, set = 4, binding = 0) uniform restrict writeonly image2D output_image;
layout(push_constant, std430) uniform Params {
bool use_alpha;
}
params;
// The code we want to execute in each invocation
void main() {
ivec2 uv = ivec2(gl_GlobalInvocationID.xy);
ivec2 uv_chroma = ivec2(gl_GlobalInvocationID.xy) / 2;
float y = imageLoad(tex_y, uv).r;
vec2 chroma;
chroma.r = imageLoad(tex_u, uv_chroma).r;
chroma.g = imageLoad(tex_v, uv_chroma).r;
float u = chroma.r - 0.5;
float v = chroma.g - 0.5;
vec4 rgba;
rgba.r = y + (1.403 * v);
rgba.g = y - (0.344 * u) - (0.714 * v);
rgba.b = y + (1.770 * u);
if (params.use_alpha) {
rgba.a = imageLoad(tex_a, uv).r;
} else {
rgba.a = 1.0;
}
imageStore(output_image, uv, rgba);
}