mirror of
https://github.com/Jozufozu/Flywheel.git
synced 2025-01-03 19:06:27 +01:00
intel graphics now like the shaders
This commit is contained in:
parent
83cb735e62
commit
4cbea0f9c9
6 changed files with 86 additions and 80 deletions
|
@ -28,28 +28,28 @@ uniform int debug;
|
||||||
mat4 rotate(vec3 axis, float angle) {
|
mat4 rotate(vec3 axis, float angle) {
|
||||||
float s = sin(angle);
|
float s = sin(angle);
|
||||||
float c = cos(angle);
|
float c = cos(angle);
|
||||||
float oc = 1.0 - c;
|
float oc = 1 - c;
|
||||||
|
|
||||||
return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.,
|
return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0,
|
||||||
oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.,
|
oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0,
|
||||||
oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.,
|
oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0,
|
||||||
0., 0., 0., 1.);
|
0, 0, 0, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
float diffuse(vec3 normal) {
|
float diffuse(vec3 normal) {
|
||||||
float x = normal.x;
|
float x = normal.x;
|
||||||
float y = normal.y;
|
float y = normal.y;
|
||||||
float z = normal.z;
|
float z = normal.z;
|
||||||
return min(x * x * 0.6f + y * y * ((3f + y) / 4f) + z * z * 0.8f, 1f);
|
return min(x * x * .6 + y * y * ((3 + y) / 4) + z * z * .8, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
vec3 rot = fract(rotationDegrees / 360.) * PI * 2.;
|
vec3 rot = fract(rotationDegrees / 360) * PI * 2;
|
||||||
|
|
||||||
mat4 rotation = rotate(vec3(0, 1, 0), rot.y) * rotate(vec3(0, 0, 1), rot.z) * rotate(vec3(1, 0, 0), rot.x);
|
mat4 rotation = rotate(vec3(0, 1, 0), rot.y) * rotate(vec3(0, 0, 1), rot.z) * rotate(vec3(1, 0, 0), rot.x);
|
||||||
|
|
||||||
vec4 renderPos = rotation * vec4(aPos - vec3(0.5), 1f);
|
vec4 renderPos = rotation * vec4(aPos - vec3(.5), 1);
|
||||||
renderPos += vec4(instancePos + vec3(0.5), 0);
|
renderPos += vec4(instancePos + vec3(.5), 0);
|
||||||
|
|
||||||
float scrollSize = scrollTexture.w - scrollTexture.y;
|
float scrollSize = scrollTexture.w - scrollTexture.y;
|
||||||
|
|
||||||
|
@ -59,7 +59,7 @@ void main() {
|
||||||
|
|
||||||
Diffuse = diffuse(norm);
|
Diffuse = diffuse(norm);
|
||||||
Light = light;
|
Light = light;
|
||||||
TexCoords = aTexCoords - sourceUV + scrollTexture.xy + vec2(0., scroll);
|
TexCoords = aTexCoords - sourceUV + scrollTexture.xy + vec2(0, scroll);
|
||||||
gl_Position = projection * view * renderPos;
|
gl_Position = projection * view * renderPos;
|
||||||
|
|
||||||
if (debug == 1) {
|
if (debug == 1) {
|
||||||
|
|
|
@ -24,25 +24,25 @@ uniform int debug;
|
||||||
mat4 rotate(vec3 axis, float angle) {
|
mat4 rotate(vec3 axis, float angle) {
|
||||||
float s = sin(angle);
|
float s = sin(angle);
|
||||||
float c = cos(angle);
|
float c = cos(angle);
|
||||||
float oc = 1.0 - c;
|
float oc = 1 - c;
|
||||||
|
|
||||||
return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.,
|
return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0,
|
||||||
oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.,
|
oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0,
|
||||||
oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.,
|
oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0,
|
||||||
0., 0., 0., 1.);
|
0, 0, 0, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
float diffuse(vec3 normal) {
|
float diffuse(vec3 normal) {
|
||||||
float x = normal.x;
|
float x = normal.x;
|
||||||
float y = normal.y;
|
float y = normal.y;
|
||||||
float z = normal.z;
|
float z = normal.z;
|
||||||
return min(x * x * 0.6f + y * y * ((3f + y) / 4f) + z * z * 0.8f, 1f);
|
return min(x * x * .6 + y * y * ((3 + y) / 4) + z * z * .8, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
vec4 worldPos = model * vec4(aPos, 1);
|
vec4 worldPos = model * vec4(aPos, 1);
|
||||||
|
|
||||||
vec3 norm = (model * vec4(aNormal, 0.)).xyz;
|
vec3 norm = (model * vec4(aNormal, 0)).xyz;
|
||||||
|
|
||||||
BoxCoord = (worldPos.xyz - lightBoxMin) / lightBoxSize;
|
BoxCoord = (worldPos.xyz - lightBoxMin) / lightBoxSize;
|
||||||
Diffuse = diffuse(norm);
|
Diffuse = diffuse(norm);
|
||||||
|
|
|
@ -30,15 +30,23 @@ uniform mat4 projection;
|
||||||
uniform mat4 view;
|
uniform mat4 view;
|
||||||
uniform int debug;
|
uniform int debug;
|
||||||
|
|
||||||
|
|
||||||
mat4 rotate(vec3 axis, float angle) {
|
mat4 rotate(vec3 axis, float angle) {
|
||||||
float s = sin(angle);
|
float s = sin(angle);
|
||||||
float c = cos(angle);
|
float c = cos(angle);
|
||||||
float oc = 1.0 - c;
|
float oc = 1 - c;
|
||||||
|
|
||||||
return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.,
|
return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0,
|
||||||
oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.,
|
oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0,
|
||||||
oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.,
|
oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0,
|
||||||
0., 0., 0., 1.);
|
0, 0, 0, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
float diffuse(vec3 normal) {
|
||||||
|
float x = normal.x;
|
||||||
|
float y = normal.y;
|
||||||
|
float z = normal.z;
|
||||||
|
return min(x * x * .6 + y * y * ((3 + y) / 4) + z * z * .8, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
mat4 rotation(vec3 rot) {
|
mat4 rotation(vec3 rot) {
|
||||||
|
@ -47,31 +55,24 @@ mat4 rotation(vec3 rot) {
|
||||||
|
|
||||||
mat4 kineticRotation() {
|
mat4 kineticRotation() {
|
||||||
const float speed = -20;
|
const float speed = -20;
|
||||||
float degrees = rotationOffset + time * speed * -3./10.;
|
float degrees = rotationOffset + time * speed * -3/10;
|
||||||
float angle = fract(degrees / 360.) * PI * 2.;
|
float angle = fract(degrees / 360) * PI * 2;
|
||||||
|
|
||||||
return rotate(normalize(localRotationAxis), angle);
|
return rotate(normalize(localRotationAxis), angle);
|
||||||
}
|
}
|
||||||
|
|
||||||
float diffuse(vec3 normal) {
|
|
||||||
float x = normal.x;
|
|
||||||
float y = normal.y;
|
|
||||||
float z = normal.z;
|
|
||||||
return min(x * x * 0.6f + y * y * ((3f + y) / 4f) + z * z * 0.8f, 1f);
|
|
||||||
}
|
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
mat4 kineticRotation = kineticRotation();
|
mat4 kineticRotation = kineticRotation();
|
||||||
vec4 localPos = kineticRotation * vec4(aPos - rotationCenter, 1) + vec4(rotationCenter, 0);
|
vec4 localPos = kineticRotation * vec4(aPos - rotationCenter, 1) + vec4(rotationCenter, 0);
|
||||||
//localPos = vec4(localPos.xyz + instancePos, 1);
|
//localPos = vec4(localPos.xyz + instancePos, 1);
|
||||||
|
|
||||||
vec3 rot = fract(localRotation / 360.) * PI * 2.;
|
vec3 rot = fract(localRotation / 360) * PI * 2;
|
||||||
mat4 localRot = rotation(rot);
|
mat4 localRot = rotation(rot);
|
||||||
localPos = localRot * vec4(localPos.xyz - 0.5, 1f) + vec4(instancePos + 0.5, 0);
|
localPos = localRot * vec4(localPos.xyz - .5, 1) + vec4(instancePos + .5, 0);
|
||||||
|
|
||||||
vec4 worldPos = model * localPos;
|
vec4 worldPos = model * localPos;
|
||||||
|
|
||||||
vec3 norm = normalize(model * localRot * kineticRotation * vec4(aNormal, 0.)).xyz;
|
vec3 norm = normalize(model * localRot * kineticRotation * vec4(aNormal, 0)).xyz;
|
||||||
|
|
||||||
BoxCoord = (worldPos.xyz - lightBoxMin) / lightBoxSize;
|
BoxCoord = (worldPos.xyz - lightBoxMin) / lightBoxSize;
|
||||||
Diffuse = diffuse(norm);
|
Diffuse = diffuse(norm);
|
||||||
|
@ -81,6 +82,6 @@ void main() {
|
||||||
if (debug == 2) {
|
if (debug == 2) {
|
||||||
Color = vec4(norm, 1);
|
Color = vec4(norm, 1);
|
||||||
} else {
|
} else {
|
||||||
Color = vec4(1.);
|
Color = vec4(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -29,15 +29,23 @@ uniform mat4 projection;
|
||||||
uniform mat4 view;
|
uniform mat4 view;
|
||||||
uniform int debug;
|
uniform int debug;
|
||||||
|
|
||||||
|
|
||||||
mat4 rotate(vec3 axis, float angle) {
|
mat4 rotate(vec3 axis, float angle) {
|
||||||
float s = sin(angle);
|
float s = sin(angle);
|
||||||
float c = cos(angle);
|
float c = cos(angle);
|
||||||
float oc = 1.0 - c;
|
float oc = 1 - c;
|
||||||
|
|
||||||
return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.,
|
return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0,
|
||||||
oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.,
|
oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0,
|
||||||
oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.,
|
oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0,
|
||||||
0., 0., 0., 1.);
|
0, 0, 0, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
float diffuse(vec3 normal) {
|
||||||
|
float x = normal.x;
|
||||||
|
float y = normal.y;
|
||||||
|
float z = normal.z;
|
||||||
|
return min(x * x * .6 + y * y * ((3 + y) / 4) + z * z * .8, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
mat4 rotation(vec3 rot) {
|
mat4 rotation(vec3 rot) {
|
||||||
|
@ -49,32 +57,25 @@ mat4 localRotation() {
|
||||||
return rotation(rot);
|
return rotation(rot);
|
||||||
}
|
}
|
||||||
|
|
||||||
float diffuse(vec3 normal) {
|
|
||||||
float x = normal.x;
|
|
||||||
float y = normal.y;
|
|
||||||
float z = normal.z;
|
|
||||||
return min(x * x * 0.6f + y * y * ((3f + y) / 4f) + z * z * 0.8f, 1f);
|
|
||||||
}
|
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
mat4 localRotation = localRotation();
|
mat4 localRotation = localRotation();
|
||||||
vec4 localPos = localRotation * vec4(aPos - 0.5, 1f) + vec4(instancePos + 0.5, 0);
|
vec4 localPos = localRotation * vec4(aPos - .5, 1) + vec4(instancePos + .5, 0);
|
||||||
|
|
||||||
vec4 worldPos = model * localPos;
|
vec4 worldPos = model * localPos;
|
||||||
|
|
||||||
float scrollSize = scrollTexture.w - scrollTexture.y;
|
float scrollSize = scrollTexture.w - scrollTexture.y;
|
||||||
float scroll = fract(speed * time / (36 * 16.)) * scrollSize * scrollMult;
|
float scroll = fract(speed * time / (36 * 16)) * scrollSize * scrollMult;
|
||||||
|
|
||||||
vec3 norm = normalize(model * localRotation * vec4(aNormal, 0.)).xyz;
|
vec3 norm = normalize(model * localRotation * vec4(aNormal, 0)).xyz;
|
||||||
|
|
||||||
BoxCoord = (worldPos.xyz - lightBoxMin) / lightBoxSize;
|
BoxCoord = (worldPos.xyz - lightBoxMin) / lightBoxSize;
|
||||||
Diffuse = diffuse(norm);
|
Diffuse = diffuse(norm);
|
||||||
TexCoords = aTexCoords - sourceUV + scrollTexture.xy + vec2(0., scroll);
|
TexCoords = aTexCoords - sourceUV + scrollTexture.xy + vec2(0, scroll);
|
||||||
gl_Position = projection * view * worldPos;
|
gl_Position = projection * view * worldPos;
|
||||||
|
|
||||||
if (debug == 2) {
|
if (debug == 2) {
|
||||||
Color = vec4(norm, 1);
|
Color = vec4(norm, 1);
|
||||||
} else {
|
} else {
|
||||||
Color = vec4(1.);
|
Color = vec4(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,35 +29,35 @@ uniform int debug;
|
||||||
mat4 rotate(vec3 axis, float angle) {
|
mat4 rotate(vec3 axis, float angle) {
|
||||||
float s = sin(angle);
|
float s = sin(angle);
|
||||||
float c = cos(angle);
|
float c = cos(angle);
|
||||||
float oc = 1.0 - c;
|
float oc = 1 - c;
|
||||||
|
|
||||||
return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.,
|
return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0,
|
||||||
oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.,
|
oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0,
|
||||||
oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.,
|
oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0,
|
||||||
0., 0., 0., 1.);
|
0, 0, 0, 1);
|
||||||
}
|
|
||||||
|
|
||||||
mat4 kineticRotation() {
|
|
||||||
float degrees = rotationOffset + time * speed * -3./10.;
|
|
||||||
float angle = fract(degrees / 360.) * PI * 2.;
|
|
||||||
|
|
||||||
return rotate(normalize(rotationAxis), angle);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
float diffuse(vec3 normal) {
|
float diffuse(vec3 normal) {
|
||||||
float x = normal.x;
|
float x = normal.x;
|
||||||
float y = normal.y;
|
float y = normal.y;
|
||||||
float z = normal.z;
|
float z = normal.z;
|
||||||
return min(x * x * 0.6f + y * y * ((3f + y) / 4f) + z * z * 0.8f, 1f);
|
return min(x * x * .6 + y * y * ((3 + y) / 4) + z * z * .8, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
mat4 kineticRotation() {
|
||||||
|
float degrees = rotationOffset + time * speed * -3/10;
|
||||||
|
float angle = fract(degrees / 360) * PI * 2;
|
||||||
|
|
||||||
|
return rotate(normalize(rotationAxis), angle);
|
||||||
}
|
}
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
mat4 kineticRotation = kineticRotation();
|
mat4 kineticRotation = kineticRotation();
|
||||||
vec4 localPos = kineticRotation * vec4(aPos - 0.5, 1f) + vec4(instancePos + 0.5, 0);
|
vec4 localPos = kineticRotation * vec4(aPos - .5, 1) + vec4(instancePos + .5, 0);
|
||||||
|
|
||||||
vec4 worldPos = model * localPos;
|
vec4 worldPos = model * localPos;
|
||||||
|
|
||||||
vec3 norm = normalize(model * kineticRotation * vec4(aNormal, 0.)).xyz;
|
vec3 norm = normalize(model * kineticRotation * vec4(aNormal, 0)).xyz;
|
||||||
|
|
||||||
BoxCoord = (worldPos.xyz - lightBoxMin) / lightBoxSize;
|
BoxCoord = (worldPos.xyz - lightBoxMin) / lightBoxSize;
|
||||||
Diffuse = diffuse(norm);
|
Diffuse = diffuse(norm);
|
||||||
|
@ -67,6 +67,6 @@ void main() {
|
||||||
if (debug == 2) {
|
if (debug == 2) {
|
||||||
Color = vec4(norm, 1);
|
Color = vec4(norm, 1);
|
||||||
} else {
|
} else {
|
||||||
Color = vec4(1.);
|
Color = vec4(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -22,34 +22,38 @@ uniform mat4 projection;
|
||||||
uniform mat4 view;
|
uniform mat4 view;
|
||||||
uniform int debug;
|
uniform int debug;
|
||||||
|
|
||||||
mat4 kineticRotation() {
|
mat4 rotate(vec3 axis, float angle) {
|
||||||
float degrees = rotationOffset + time * speed * -3./10.;
|
|
||||||
float angle = fract(degrees / 360.) * PI * 2.;
|
|
||||||
|
|
||||||
vec3 axis = normalize(rotationAxis);
|
|
||||||
float s = sin(angle);
|
float s = sin(angle);
|
||||||
float c = cos(angle);
|
float c = cos(angle);
|
||||||
float oc = 1.0 - c;
|
float oc = 1 - c;
|
||||||
|
|
||||||
return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.,
|
return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0,
|
||||||
oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.,
|
oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0,
|
||||||
oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.,
|
oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0,
|
||||||
0., 0., 0., 1.);
|
0, 0, 0, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
float diffuse(vec3 normal) {
|
float diffuse(vec3 normal) {
|
||||||
float x = normal.x;
|
float x = normal.x;
|
||||||
float y = normal.y;
|
float y = normal.y;
|
||||||
float z = normal.z;
|
float z = normal.z;
|
||||||
return min(x * x * 0.6f + y * y * ((3f + y) / 4f) + z * z * 0.8f, 1f);
|
return min(x * x * .6 + y * y * ((3 + y) / 4) + z * z * .8, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mat4 kineticRotation() {
|
||||||
|
float degrees = rotationOffset + time * speed * -3/10;
|
||||||
|
float angle = fract(degrees / 360) * PI * 2;
|
||||||
|
|
||||||
|
return rotate(normalize(rotationAxis), angle);
|
||||||
|
}
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
mat4 rotation = kineticRotation();
|
mat4 rotation = kineticRotation();
|
||||||
vec4 renderPos = rotation * vec4(aPos - vec3(0.5), 1);
|
vec4 renderPos = rotation * vec4(aPos - vec3(0.5), 1);
|
||||||
|
|
||||||
renderPos += vec4(instancePos + vec3(0.5), 0);
|
renderPos += vec4(instancePos + vec3(0.5), 0);
|
||||||
|
|
||||||
vec3 norm = (rotation * vec4(aNormal, 0.)).xyz;
|
vec3 norm = (rotation * vec4(aNormal, 0)).xyz;
|
||||||
|
|
||||||
Diffuse = diffuse(norm);
|
Diffuse = diffuse(norm);
|
||||||
TexCoords = aTexCoords;
|
TexCoords = aTexCoords;
|
||||||
|
|
Loading…
Reference in a new issue