2015-02-24 22:30:59 +00:00
|
|
|
#version 150
|
|
|
|
|
2015-03-04 11:13:58 +00:00
|
|
|
uniform mat4 modelViewProjectionMatrix;
|
2015-03-08 12:52:17 +00:00
|
|
|
uniform mat4 viewProjectionMatrix;
|
2015-02-24 22:30:59 +00:00
|
|
|
uniform float time;
|
2015-03-01 16:01:41 +00:00
|
|
|
uniform bool bottom;
|
2015-03-01 17:19:19 +00:00
|
|
|
uniform bool left;
|
2015-03-08 12:52:17 +00:00
|
|
|
uniform vec3 camera;
|
2015-02-24 22:30:59 +00:00
|
|
|
|
|
|
|
layout(points) in;
|
2015-03-08 12:52:17 +00:00
|
|
|
layout(triangle_strip, max_vertices = 85) out;
|
|
|
|
|
|
|
|
out GS_OUT {
|
|
|
|
float maxAngle;
|
|
|
|
vec3 position;
|
|
|
|
}gs_out;
|
2015-03-01 17:45:31 +00:00
|
|
|
|
|
|
|
in vec3 Color[];
|
2015-03-08 12:52:17 +00:00
|
|
|
out vec4 flameCenter;
|
2015-02-27 23:00:30 +00:00
|
|
|
|
|
|
|
const float PI = 3.1415926;
|
2015-03-08 00:53:00 +00:00
|
|
|
const float transition_point_1 = 1.178097;
|
|
|
|
const float sin_p1_1 = 0.4;
|
|
|
|
const float sin_p2_1 = 2;
|
|
|
|
const float ex_p1_1 = 1.093;
|
|
|
|
const float ex_p2_1 = 1.9996;
|
|
|
|
const float begin_1 = 0;
|
|
|
|
const float end_1 = 2.5;
|
|
|
|
|
|
|
|
const float transition_point_2 = 1.570796;
|
|
|
|
const float sin_p1_2 = 0.2;
|
|
|
|
const float sin_p2_2 = 1.5;
|
|
|
|
const float ex_p1_2 = 0.4;
|
|
|
|
const float ex_p2_2 = 1.5;
|
|
|
|
const float begin_2 = 0;
|
|
|
|
const float end_2 = 3;
|
|
|
|
|
|
|
|
float flickerFunction() {
|
2015-03-08 12:52:17 +00:00
|
|
|
//return pow(0.6*sin(20.0*time), 2) + 0.4;
|
|
|
|
return 1.0;
|
2015-03-08 00:53:00 +00:00
|
|
|
}
|
2015-02-27 23:52:58 +00:00
|
|
|
|
2015-03-08 12:52:17 +00:00
|
|
|
|
2015-02-27 23:52:58 +00:00
|
|
|
float radiusFunction(float x) {
|
2015-03-08 00:53:00 +00:00
|
|
|
float value_1 = 0.0;
|
|
|
|
float value_2 = 0.0;
|
|
|
|
if (x < transition_point_1) {
|
|
|
|
value_1 = sin_p1_1 * sin(sin_p2_1 * x);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
value_1 = exp(ex_p1_1 - ex_p2_1 * x);
|
|
|
|
}
|
|
|
|
if (x < transition_point_2) {
|
|
|
|
value_2 = sin_p1_2 * sin(sin_p2_2 * x);
|
2015-02-27 23:52:58 +00:00
|
|
|
}
|
|
|
|
else {
|
2015-03-08 00:53:00 +00:00
|
|
|
value_2 = exp(ex_p1_2 - ex_p2_2 * x);
|
2015-02-27 23:52:58 +00:00
|
|
|
}
|
2015-03-08 00:53:00 +00:00
|
|
|
return mix(value_1, value_2, flickerFunction());
|
2015-02-27 23:52:58 +00:00
|
|
|
}
|
2015-02-24 22:30:59 +00:00
|
|
|
|
|
|
|
void main() {
|
2015-03-08 12:52:17 +00:00
|
|
|
flameCenter = gl_in[0].gl_Position;
|
|
|
|
vec3 color = Color[0];
|
|
|
|
vec2 cameraXZ = vec2(camera.x, camera.z);
|
|
|
|
vec3 cameraVector = vec3(flameCenter) - camera;
|
|
|
|
vec2 cameraVectorXZ = normalize(vec2(cameraVector.x, cameraVector.z));
|
|
|
|
vec2 rightAngleVector;
|
|
|
|
if (cameraVectorXZ.y == 0.0) {
|
|
|
|
rightAngleVector = vec2(0.0, 1.0);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
rightAngleVector = normalize(vec2(1.0, -cameraVectorXZ.x/cameraVectorXZ.y));
|
|
|
|
}
|
2015-03-01 17:45:31 +00:00
|
|
|
|
2015-03-03 22:32:43 +00:00
|
|
|
float resolution = 8.0;
|
2015-03-08 00:53:00 +00:00
|
|
|
float this_begin = mix(begin_1, begin_2, flickerFunction());
|
|
|
|
float this_end = mix(end_1, end_2, flickerFunction());
|
|
|
|
float step = abs(this_end-this_begin)/resolution/2.0;
|
2015-03-01 16:01:41 +00:00
|
|
|
float i = 0.0;
|
|
|
|
float render_end = 0.0;
|
|
|
|
if (bottom) {
|
2015-03-08 00:53:00 +00:00
|
|
|
i = this_begin;
|
|
|
|
render_end = (this_end-this_begin)/2.0+step;
|
2015-03-01 16:01:41 +00:00
|
|
|
}
|
|
|
|
else {
|
2015-03-08 00:53:00 +00:00
|
|
|
i = (this_end-this_begin)/2.0;
|
|
|
|
render_end = this_end;
|
2015-03-01 16:01:41 +00:00
|
|
|
}
|
2015-03-01 17:19:19 +00:00
|
|
|
for (i; i<render_end; i+=step) {
|
2015-02-27 23:52:58 +00:00
|
|
|
float downRadius = radiusFunction(i);
|
2015-03-01 17:19:19 +00:00
|
|
|
float upRadius = radiusFunction(i+step);
|
2015-03-08 12:52:17 +00:00
|
|
|
float maxUpAngle = acos(dot(cameraVectorXZ, normalize((vec2(gl_in[0].gl_Position.x, gl_in[0].gl_Position.z) + rightAngleVector * upRadius) - cameraXZ)));
|
|
|
|
float maxDownAngle = acos(dot(cameraVectorXZ, normalize((vec2(gl_in[0].gl_Position.x, gl_in[0].gl_Position.z) + rightAngleVector * downRadius) - cameraXZ)));
|
2015-03-01 17:19:19 +00:00
|
|
|
float circle_end = 0.0;
|
|
|
|
int j = 0;
|
|
|
|
if (left) {
|
|
|
|
j = 0;
|
|
|
|
circle_end = resolution/2.0;
|
2015-03-01 15:11:43 +00:00
|
|
|
}
|
2015-03-01 17:19:19 +00:00
|
|
|
else {
|
|
|
|
j = int(resolution/2.0);
|
|
|
|
circle_end = resolution;
|
|
|
|
}
|
|
|
|
for (j; j<circle_end; j++) {
|
|
|
|
float leftAngle = PI * 2.0 / resolution * j;
|
2015-02-27 23:52:58 +00:00
|
|
|
float rightAngle = PI * 2.0 / resolution * (j+1);
|
|
|
|
|
2015-03-01 17:56:56 +00:00
|
|
|
vec4 offset = vec4(cos(rightAngle) * downRadius, i, -sin(rightAngle) * downRadius, 0.0);
|
2015-03-08 12:52:17 +00:00
|
|
|
gs_out.position = vec3(gl_in[0].gl_Position + offset);
|
|
|
|
gs_out.maxAngle = maxDownAngle;
|
2015-03-04 11:13:58 +00:00
|
|
|
gl_Position = gl_in[0].gl_Position + modelViewProjectionMatrix * offset;
|
2015-03-01 18:40:39 +00:00
|
|
|
EmitVertex();
|
|
|
|
|
2015-03-01 21:22:48 +00:00
|
|
|
offset = vec4(cos(rightAngle) * upRadius, i + step, -sin(rightAngle) * upRadius, 0.0);
|
2015-03-08 12:52:17 +00:00
|
|
|
gs_out.position = vec3(gl_in[0].gl_Position + offset);
|
|
|
|
gs_out.maxAngle = maxUpAngle;
|
2015-03-04 11:13:58 +00:00
|
|
|
gl_Position = gl_in[0].gl_Position + modelViewProjectionMatrix * offset;
|
2015-03-01 18:40:39 +00:00
|
|
|
EmitVertex();
|
|
|
|
|
2015-03-01 21:22:48 +00:00
|
|
|
offset = vec4(cos(leftAngle) * downRadius, i, -sin(leftAngle) * downRadius, 0.0);
|
2015-03-08 12:52:17 +00:00
|
|
|
gs_out.position = vec3(gl_in[0].gl_Position + offset);
|
|
|
|
gs_out.maxAngle = maxDownAngle;
|
2015-03-04 11:13:58 +00:00
|
|
|
gl_Position = gl_in[0].gl_Position + modelViewProjectionMatrix * offset;
|
2015-03-01 18:40:39 +00:00
|
|
|
EmitVertex();
|
|
|
|
|
2015-03-01 21:22:48 +00:00
|
|
|
offset = vec4(cos(leftAngle) * upRadius, i + step, -sin(leftAngle) * upRadius, 0.0);
|
2015-03-08 12:52:17 +00:00
|
|
|
gs_out.position = vec3(gl_in[0].gl_Position + offset);
|
|
|
|
gs_out.maxAngle = maxUpAngle;
|
2015-03-04 11:13:58 +00:00
|
|
|
gl_Position = gl_in[0].gl_Position + modelViewProjectionMatrix * offset;
|
2015-02-27 23:52:58 +00:00
|
|
|
EmitVertex();
|
|
|
|
|
|
|
|
EndPrimitive();
|
|
|
|
}
|
2015-02-27 23:00:30 +00:00
|
|
|
}
|
2015-02-24 22:30:59 +00:00
|
|
|
|
|
|
|
}
|