mirror of
https://git.code.sf.net/p/quake/quakeforge
synced 2025-01-23 17:30:42 +00:00
44c1ef5968
I really don't know what I was thinking when I wrote that code. Maybe I was trying for a half angle. Now the rendered "cone" matches up with a hard-clipped cone light (soft edges stick out a bit).
46 lines
1.1 KiB
GLSL
46 lines
1.1 KiB
GLSL
#version 450
|
|
#extension GL_GOOGLE_include_directive : enable
|
|
#extension GL_EXT_multiview : enable
|
|
|
|
layout (set = 0, binding = 0) uniform
|
|
#include "matrices.h"
|
|
;
|
|
|
|
#include "lighting.h"
|
|
|
|
layout (location = 0) in uint light_index;
|
|
layout (location = 1) in vec3 splat_vert;
|
|
layout (location = 0) out uint light_index_out;
|
|
|
|
vec4 // assumes a and b are unit vectors
|
|
from_to_rotation (vec3 a, vec3 b)
|
|
{
|
|
float d = dot (a + b, a + b);
|
|
float qc = sqrt (d);
|
|
vec3 qv = d > 1e-6 ? cross (a, b) / qc : vec3 (1, 0, 0);
|
|
return vec4 (qv, qc * 0.5);
|
|
}
|
|
|
|
vec3
|
|
quat_mul (vec4 q, vec3 v)
|
|
{
|
|
vec3 uv = cross (q.xyz, v);
|
|
vec3 uuv = cross (q.xyz, uv);
|
|
return v + ((uv * q.w) + uuv) * 2;
|
|
}
|
|
|
|
void
|
|
main (void)
|
|
{
|
|
LightData l = lights[light_index];
|
|
float sz = l.attenuation.w > 0 ? 1 / l.attenuation.w : sqrt(abs(l.color.w));
|
|
float c = l.direction.w;
|
|
float sxy = sz * (c < 0 ? (sqrt (1 - c*c) / -c) : 1);
|
|
vec3 scale = vec3 (sxy, sxy, sz);
|
|
|
|
vec4 q = from_to_rotation (vec3 (0, 0, -1), l.direction.xyz);
|
|
vec4 pos = vec4 (quat_mul (q, splat_vert * scale), 0);
|
|
|
|
gl_Position = Projection3d * (View[gl_ViewIndex] * (pos + l.position));
|
|
light_index_out = light_entids[gl_InstanceIndex];
|
|
}
|