-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathdraw_colorChecker.frag
42 lines (34 loc) · 1.48 KB
/
draw_colorChecker.frag
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
41
42
#ifdef GL_ES
precision mediump float;
#endif
uniform vec2 u_resolution;
uniform vec2 u_mouse;
uniform float u_time;
// #define CIE_D50
#include "lygia/math/const.glsl"
#include "lygia/space/ratio.glsl"
#include "lygia/space/scale.glsl"
#include "lygia/space/rotate.glsl"
#include "lygia/draw/colorChecker.glsl"
#include "lygia/color/space/xyz2srgb.glsl"
#include "lygia/color/space/lab2srgb.glsl"
#include "lygia/color/space/lch2srgb.glsl"
#include "lygia/color/space/xyY2srgb.glsl"
void main(void) {
vec4 color = vec4(vec3(0.5), 1.0);
vec2 pixel = 1.0/u_resolution.xy;
vec2 st = gl_FragCoord.xy * pixel;
vec2 uv = ratio(st, u_resolution);
uv = scale(uv, 1.1);
vec4 spyderA = colorCheckerSpyderA(uv * 2.0);
vec4 spyderB = colorCheckerSpyderB(uv * 2.0 + vec2(0.0, -1.0));
vec4 macbeth = colorCheckerMacbeth(rotate(uv * 1.5, -HALF_PI) + vec2(-0.25, 0.68) );
// macbeth = xyz2srgb( colorCheckerMacbethXYZ(rotate(uv * 1.5, -HALF_PI) + vec2(-0.25, 0.68) ) );
// macbeth = lab2srgb( colorCheckerMacbethLAB(rotate(uv * 1.5, -HALF_PI) + vec2(-0.25, 0.68) ) );
// macbeth = lch2srgb( colorCheckerMacbethLCH(rotate(uv * 1.5, -HALF_PI) + vec2(-0.25, 0.68) ) );
// macbeth = xyY2srgb( colorCheckerMacbethXYY(rotate(uv * 1.5, -HALF_PI) + vec2(-0.25, 0.68) ) );
color.rgb = mix(color.rgb, spyderA.rgb, spyderA.a);
color.rgb = mix(color.rgb, spyderB.rgb, spyderB.a);
color.rgb = mix(color.rgb, macbeth.rgb, macbeth.a);
gl_FragColor = color;
}