Move shaders into glsl and hlsl directories
Move `data/shaders` to `data/shaders/glsl` Move `data/hlsl` to `data/shaders/hlsl` Fix up shader paths in the cpp files to point to the new glsl location. `data/shaders/hlsl/compile.py` still overwrites the glsl .spv files (for now). Issue: #723
This commit is contained in:
parent
cac1d2e850
commit
ca884587a4
1043 changed files with 1207 additions and 1201 deletions
7
data/shaders/glsl/offscreen/generate-spirv.bat
Normal file
7
data/shaders/glsl/offscreen/generate-spirv.bat
Normal file
|
|
@ -0,0 +1,7 @@
|
|||
glslangvalidator -V phong.vert -o phong.vert.spv
|
||||
glslangvalidator -V phong.frag -o phong.frag.spv
|
||||
glslangvalidator -V quad.vert -o quad.vert.spv
|
||||
glslangvalidator -V quad.frag -o quad.frag.spv
|
||||
glslangvalidator -V mirror.vert -o mirror.vert.spv
|
||||
glslangvalidator -V mirror.frag -o mirror.frag.spv
|
||||
|
||||
38
data/shaders/glsl/offscreen/mirror.frag
Normal file
38
data/shaders/glsl/offscreen/mirror.frag
Normal file
|
|
@ -0,0 +1,38 @@
|
|||
#version 450
|
||||
|
||||
layout (binding = 1) uniform sampler2D samplerColor;
|
||||
|
||||
layout (location = 0) in vec2 inUV;
|
||||
layout (location = 1) in vec4 inPos;
|
||||
|
||||
layout (location = 0) out vec4 outFragColor;
|
||||
|
||||
void main()
|
||||
{
|
||||
vec4 tmp = vec4(1.0 / inPos.w);
|
||||
vec4 projCoord = inPos * tmp;
|
||||
|
||||
// Scale and bias
|
||||
projCoord += vec4(1.0);
|
||||
projCoord *= vec4(0.5);
|
||||
|
||||
// Slow single pass blur
|
||||
// For demonstration purposes only
|
||||
const float blurSize = 1.0 / 512.0;
|
||||
|
||||
outFragColor = vec4(vec3(0.0), 1.);
|
||||
|
||||
if (gl_FrontFacing)
|
||||
{
|
||||
// Only render mirrored scene on front facing (upper) side of mirror surface
|
||||
vec4 reflection = vec4(0.0);
|
||||
for (int x = -3; x <= 3; x++)
|
||||
{
|
||||
for (int y = -3; y <= 3; y++)
|
||||
{
|
||||
reflection += texture(samplerColor, vec2(projCoord.s + x * blurSize, projCoord.t + y * blurSize)) / 49.0;
|
||||
}
|
||||
}
|
||||
outFragColor += reflection;
|
||||
};
|
||||
}
|
||||
BIN
data/shaders/glsl/offscreen/mirror.frag.spv
Normal file
BIN
data/shaders/glsl/offscreen/mirror.frag.spv
Normal file
Binary file not shown.
21
data/shaders/glsl/offscreen/mirror.vert
Normal file
21
data/shaders/glsl/offscreen/mirror.vert
Normal file
|
|
@ -0,0 +1,21 @@
|
|||
#version 450
|
||||
|
||||
layout (location = 0) in vec3 inPos;
|
||||
layout (location = 1) in vec2 inUV;
|
||||
|
||||
layout (binding = 0) uniform UBO
|
||||
{
|
||||
mat4 projection;
|
||||
mat4 view;
|
||||
mat4 model;
|
||||
} ubo;
|
||||
|
||||
layout (location = 0) out vec2 outUV;
|
||||
layout (location = 1) out vec4 outPos;
|
||||
|
||||
void main()
|
||||
{
|
||||
outUV = inUV;
|
||||
outPos = ubo.projection * ubo.view * ubo.model * vec4(inPos.xyz, 1.0);
|
||||
gl_Position = outPos;
|
||||
}
|
||||
BIN
data/shaders/glsl/offscreen/mirror.vert.spv
Normal file
BIN
data/shaders/glsl/offscreen/mirror.vert.spv
Normal file
Binary file not shown.
26
data/shaders/glsl/offscreen/phong.frag
Normal file
26
data/shaders/glsl/offscreen/phong.frag
Normal file
|
|
@ -0,0 +1,26 @@
|
|||
#version 450
|
||||
|
||||
layout (location = 0) in vec3 inNormal;
|
||||
layout (location = 1) in vec3 inColor;
|
||||
layout (location = 2) in vec3 inEyePos;
|
||||
layout (location = 3) in vec3 inLightVec;
|
||||
|
||||
layout (location = 0) out vec4 outFragColor;
|
||||
|
||||
void main()
|
||||
{
|
||||
vec3 Eye = normalize(-inEyePos);
|
||||
vec3 Reflected = normalize(reflect(-inLightVec, inNormal));
|
||||
|
||||
vec4 IAmbient = vec4(0.1, 0.1, 0.1, 1.0);
|
||||
vec4 IDiffuse = vec4(max(dot(inNormal, inLightVec), 0.0));
|
||||
float specular = 0.75;
|
||||
vec4 ISpecular = vec4(0.0);
|
||||
if (dot(inEyePos, inNormal) < 0.0)
|
||||
{
|
||||
ISpecular = vec4(0.5, 0.5, 0.5, 1.0) * pow(max(dot(Reflected, Eye), 0.0), 16.0) * specular;
|
||||
}
|
||||
|
||||
outFragColor = vec4((IAmbient + IDiffuse) * vec4(inColor, 1.0) + ISpecular);
|
||||
|
||||
}
|
||||
BIN
data/shaders/glsl/offscreen/phong.frag.spv
Normal file
BIN
data/shaders/glsl/offscreen/phong.frag.spv
Normal file
Binary file not shown.
31
data/shaders/glsl/offscreen/phong.vert
Normal file
31
data/shaders/glsl/offscreen/phong.vert
Normal file
|
|
@ -0,0 +1,31 @@
|
|||
#version 450
|
||||
|
||||
layout (location = 0) in vec4 inPos;
|
||||
layout (location = 2) in vec3 inColor;
|
||||
layout (location = 3) in vec3 inNormal;
|
||||
|
||||
layout (binding = 0) uniform UBO
|
||||
{
|
||||
mat4 projection;
|
||||
mat4 view;
|
||||
mat4 model;
|
||||
vec4 lightPos;
|
||||
} ubo;
|
||||
|
||||
layout (location = 0) out vec3 outNormal;
|
||||
layout (location = 1) out vec3 outColor;
|
||||
layout (location = 2) out vec3 outEyePos;
|
||||
layout (location = 3) out vec3 outLightVec;
|
||||
|
||||
void main()
|
||||
{
|
||||
outNormal = inNormal;
|
||||
outColor = inColor;
|
||||
gl_Position = ubo.projection * ubo.view * ubo.model * inPos;
|
||||
outEyePos = vec3(ubo.view * ubo.model * inPos);
|
||||
outLightVec = normalize(ubo.lightPos.xyz - outEyePos);
|
||||
|
||||
// Clip against reflection plane
|
||||
vec4 clipPlane = vec4(0.0, -1.0, 0.0, 1.5);
|
||||
gl_ClipDistance[0] = dot(inPos, clipPlane);
|
||||
}
|
||||
BIN
data/shaders/glsl/offscreen/phong.vert.spv
Normal file
BIN
data/shaders/glsl/offscreen/phong.vert.spv
Normal file
Binary file not shown.
12
data/shaders/glsl/offscreen/quad.frag
Normal file
12
data/shaders/glsl/offscreen/quad.frag
Normal file
|
|
@ -0,0 +1,12 @@
|
|||
#version 450
|
||||
|
||||
layout (binding = 1) uniform sampler2D samplerColor;
|
||||
|
||||
layout (location = 0) in vec2 inUV;
|
||||
|
||||
layout (location = 0) out vec4 outFragColor;
|
||||
|
||||
void main()
|
||||
{
|
||||
outFragColor = texture(samplerColor, inUV);
|
||||
}
|
||||
BIN
data/shaders/glsl/offscreen/quad.frag.spv
Normal file
BIN
data/shaders/glsl/offscreen/quad.frag.spv
Normal file
Binary file not shown.
18
data/shaders/glsl/offscreen/quad.vert
Normal file
18
data/shaders/glsl/offscreen/quad.vert
Normal file
|
|
@ -0,0 +1,18 @@
|
|||
#version 450
|
||||
|
||||
layout (location = 0) in vec3 inPos;
|
||||
layout (location = 1) in vec2 inUV;
|
||||
|
||||
layout (binding = 0) uniform UBO
|
||||
{
|
||||
mat4 projection;
|
||||
mat4 model;
|
||||
} ubo;
|
||||
|
||||
layout (location = 0) out vec2 outUV;
|
||||
|
||||
void main()
|
||||
{
|
||||
outUV = inUV;
|
||||
gl_Position = ubo.projection * ubo.model * vec4(inPos.xyz, 1.0);
|
||||
}
|
||||
BIN
data/shaders/glsl/offscreen/quad.vert.spv
Normal file
BIN
data/shaders/glsl/offscreen/quad.vert.spv
Normal file
Binary file not shown.
Loading…
Add table
Add a link
Reference in a new issue