Updated instancing example, using instanced attributes (instead of one big ubo), staging, new meshes, etc.
This commit is contained in:
parent
3faee12381
commit
8e2115a0d4
7 changed files with 298 additions and 152 deletions
|
|
@ -3,15 +3,20 @@
|
|||
#extension GL_ARB_separate_shader_objects : enable
|
||||
#extension GL_ARB_shading_language_420pack : enable
|
||||
|
||||
layout (binding = 1) uniform sampler2DArray samplerArray;
|
||||
|
||||
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 = 4) in vec3 inUV;
|
||||
|
||||
layout (location = 0) out vec4 outFragColor;
|
||||
|
||||
void main()
|
||||
{
|
||||
vec4 color = texture(samplerArray, inUV) * vec4(inColor, 1.0);
|
||||
|
||||
vec3 N = normalize(inNormal);
|
||||
vec3 L = normalize(vec3(1.0));
|
||||
|
||||
|
|
@ -22,7 +27,8 @@ void main()
|
|||
vec4 IDiffuse = vec4(1.0) * max(dot(inNormal, inLightVec), 0.0);
|
||||
|
||||
float specular = 0.75;
|
||||
vec4 ISpecular = vec4(0.5, 0.5, 0.5, 1.0) * pow(max(dot(Reflected, Eye), 0.0), 4.0) * specular;
|
||||
vec4 ISpecular = vec4(0.5, 0.5, 0.5, 1.0) * pow(max(dot(Reflected, Eye), 0.0), 32.0) * specular;
|
||||
|
||||
outFragColor = vec4((IAmbient + IDiffuse) * vec4(inColor, 1.0) + ISpecular);
|
||||
outFragColor = vec4((IAmbient + IDiffuse) * color + ISpecular);
|
||||
|
||||
}
|
||||
Binary file not shown.
|
|
@ -3,35 +3,75 @@
|
|||
#extension GL_ARB_separate_shader_objects : enable
|
||||
#extension GL_ARB_shading_language_420pack : enable
|
||||
|
||||
// Vertex attributes
|
||||
layout (location = 0) in vec4 inPos;
|
||||
layout (location = 1) in vec3 inNormal;
|
||||
layout (location = 2) in vec2 inUV;
|
||||
layout (location = 3) in vec3 inColor;
|
||||
|
||||
struct Instance
|
||||
{
|
||||
mat4 model;
|
||||
vec4 color;
|
||||
};
|
||||
// Instanced attributes
|
||||
layout (location = 4) in vec3 instancePos;
|
||||
layout (location = 5) in vec3 instanceRot;
|
||||
layout (location = 6) in float instanceScale;
|
||||
layout (location = 7) in int instanceTexIndex;
|
||||
|
||||
layout (binding = 0) uniform UBO
|
||||
{
|
||||
mat4 projection;
|
||||
mat4 view;
|
||||
Instance instance[343];
|
||||
float time;
|
||||
} 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;
|
||||
layout (location = 4) out vec3 outUV;
|
||||
|
||||
void main()
|
||||
{
|
||||
outNormal = inNormal;
|
||||
outColor = ubo.instance[gl_InstanceIndex].color.rgb;
|
||||
mat4 modelView = ubo.view * ubo.instance[gl_InstanceIndex].model;
|
||||
gl_Position = ubo.projection * modelView * inPos;
|
||||
outEyePos = vec3(modelView * inPos);
|
||||
vec4 lightPos = vec4(0.0, 0.0, 0.0, 1.0) * modelView;
|
||||
outColor = inColor;
|
||||
outUV = vec3(inUV, instanceTexIndex);
|
||||
|
||||
mat4 mx, my, mz;
|
||||
|
||||
// rotate around x
|
||||
float s = sin(instanceRot.x);
|
||||
float c = cos(instanceRot.x);
|
||||
|
||||
mx[0] = vec4(c, s, 0.0, 0.0);
|
||||
mx[1] = vec4(-s, c, 0.0, 0.0);
|
||||
mx[2] = vec4(0.0, 0.0, 1.0, 0.0);
|
||||
mx[3] = vec4(0.0, 0.0, 0.0, 1.0);
|
||||
|
||||
// rotate around y
|
||||
s = sin(instanceRot.y + ubo.time);
|
||||
c = cos(instanceRot.y + ubo.time);
|
||||
|
||||
my[0] = vec4(c, 0.0, s, 0.0);
|
||||
my[1] = vec4(0.0, 1.0, 0.0, 0.0);
|
||||
my[2] = vec4(-s, 0.0, c, 0.0);
|
||||
my[3] = vec4(0.0, 0.0, 0.0, 1.0);
|
||||
|
||||
// rot around z
|
||||
s = sin(instanceRot.z);
|
||||
c = cos(instanceRot.z);
|
||||
|
||||
mz[0] = vec4(1.0, 0.0, 0.0, 0.0);
|
||||
mz[1] = vec4(0.0, c, s, 0.0);
|
||||
mz[2] = vec4(0.0, -s, c, 0.0);
|
||||
mz[3] = vec4(0.0, 0.0, 0.0, 1.0);
|
||||
|
||||
mat4 rotMat = mz * my * mx;
|
||||
|
||||
outNormal = inNormal * mat3(rotMat);
|
||||
|
||||
vec4 pos = vec4((inPos.xyz * instanceScale) + instancePos, 1.0) * rotMat;
|
||||
|
||||
outEyePos = vec3(ubo.view * pos);
|
||||
|
||||
gl_Position = ubo.projection * ubo.view * pos;
|
||||
|
||||
vec4 lightPos = vec4(0.0, 0.0, 0.0, 1.0) * ubo.view;
|
||||
outLightVec = normalize(lightPos.xyz - outEyePos);
|
||||
}
|
||||
|
|
|
|||
Binary file not shown.
Binary file not shown.
Loading…
Add table
Add a link
Reference in a new issue