Skip to content

Instantly share code, notes, and snippets.

@spoeken
Created May 29, 2024 10:22
Show Gist options
  • Save spoeken/063bbaa319ed2935d083757d7d17c8ee to your computer and use it in GitHub Desktop.
Save spoeken/063bbaa319ed2935d083757d7d17c8ee to your computer and use it in GitHub Desktop.
WebGL - 2d Lookup table - 64x64x64 3d LUT presented in a 8x8 grid

export const lutVert = () => {
return `#version 300 es
precision highp float;
in vec4 a_position;
in vec2 a_texCoord;
out vec2 v_texCoord;
void main() {
// vec4 positionVec4 = a_position;
vec4 positionVec4 = vec4(a_position.xyz, 1.0);
positionVec4.xy = positionVec4.xy * 2.0 - 1.0;
positionVec4.y *= -1.0; // Flip it vertically
gl_Position = positionVec4;
v_texCoord = a_texCoord;
}`;
};
export const lutFrag = () => {
return `#version 300 es
precision highp float;
in vec2 v_texCoord;
uniform sampler2D u_image;
uniform sampler2D u_lookupTable;
out vec4 outColor;
void main() {
vec4 color = texture(u_image, v_texCoord);
// Calculate the slice index for the blue channel
float gridSize = 8.0;
float lutSize = 64.0;
float sliceIndex = floor(color.b * (lutSize - 1.0));
// Calculate the grid coordinates for the blue channel
vec2 sliceCoords = vec2(
mod(sliceIndex, gridSize),
floor(sliceIndex / gridSize)
);
// Calculate the texture coordinates within the current slice
vec2 lutCoords = vec2(
(color.r * (lutSize - 1.0) + sliceCoords.x * lutSize) / (lutSize * gridSize),
(color.g * (lutSize - 1.0) + sliceCoords.y * lutSize) / (lutSize * gridSize)
);
// Sample the LUT with the calculated texture coordinates
vec3 lookupValue = texture(u_lookupTable, lutCoords).rgb;
// Output the modified color
outColor = vec4(lookupValue, color.a);
}`;
};
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment