2013-12-29 13:23:36 -05:00
|
|
|
uniform int dt;
|
2015-08-13 08:50:33 -04:00
|
|
|
uniform mat4 previous_frame_sourcematrix;
|
2013-12-30 08:57:55 -05:00
|
|
|
uniform mat4 sourcematrix;
|
2014-01-06 13:05:21 -05:00
|
|
|
uniform int level;
|
2014-01-06 17:58:04 -05:00
|
|
|
uniform float size_increase_factor;
|
2013-12-29 13:23:36 -05:00
|
|
|
|
2017-02-01 15:58:10 -05:00
|
|
|
#ifdef Explicit_Attrib_Location_Usable
|
2014-08-13 16:26:52 -04:00
|
|
|
layout (location = 4) in vec3 particle_position_initial;
|
|
|
|
layout (location = 5) in float lifetime_initial;
|
|
|
|
layout (location = 6) in vec3 particle_velocity_initial;
|
|
|
|
layout (location = 7) in float size_initial;
|
2013-12-31 12:25:10 -05:00
|
|
|
|
2014-08-13 16:26:52 -04:00
|
|
|
layout (location = 0) in vec3 particle_position;
|
|
|
|
layout (location = 1) in float lifetime;
|
|
|
|
layout (location = 2) in vec3 particle_velocity;
|
|
|
|
layout (location = 3) in float size;
|
2017-07-10 18:37:31 -04:00
|
|
|
|
|
|
|
#ifdef Needs_Vertex_Id_Workaround
|
|
|
|
layout (location = 8) in int vertex_id;
|
|
|
|
#endif
|
|
|
|
|
2014-09-09 19:42:51 -04:00
|
|
|
#else
|
|
|
|
in vec3 particle_position_initial;
|
|
|
|
in float lifetime_initial;
|
|
|
|
in vec3 particle_velocity_initial;
|
|
|
|
in float size_initial;
|
|
|
|
|
|
|
|
in vec3 particle_position;
|
|
|
|
in float lifetime;
|
|
|
|
in vec3 particle_velocity;
|
|
|
|
in float size;
|
2017-07-10 18:37:31 -04:00
|
|
|
|
|
|
|
#ifdef Needs_Vertex_Id_Workaround
|
|
|
|
in int vertex_id;
|
|
|
|
#endif
|
|
|
|
|
2014-09-09 19:42:51 -04:00
|
|
|
#endif
|
2013-12-29 13:23:36 -05:00
|
|
|
|
|
|
|
out vec3 new_particle_position;
|
|
|
|
out float new_lifetime;
|
2013-12-31 20:11:44 -05:00
|
|
|
out vec3 new_particle_velocity;
|
|
|
|
out float new_size;
|
2013-12-29 13:23:36 -05:00
|
|
|
|
|
|
|
void main(void)
|
|
|
|
{
|
2015-08-13 08:50:33 -04:00
|
|
|
float updated_lifetime = lifetime + (float(dt)/lifetime_initial);
|
|
|
|
if (updated_lifetime > 1.)
|
2014-01-12 14:49:23 -05:00
|
|
|
{
|
2017-07-10 18:37:31 -04:00
|
|
|
#ifdef Needs_Vertex_Id_Workaround
|
|
|
|
if (vertex_id < level)
|
|
|
|
#else
|
2015-08-13 08:50:33 -04:00
|
|
|
if (gl_VertexID < level)
|
2017-07-10 18:37:31 -04:00
|
|
|
#endif
|
2015-08-13 08:50:33 -04:00
|
|
|
{
|
|
|
|
float dt_from_last_frame = fract(updated_lifetime) * lifetime_initial;
|
2016-06-26 10:39:34 -04:00
|
|
|
float coeff = dt_from_last_frame / float(dt);
|
2017-02-01 15:58:10 -05:00
|
|
|
|
2015-08-13 08:50:33 -04:00
|
|
|
vec4 previous_frame_position = previous_frame_sourcematrix * vec4(particle_position_initial, 1.0);
|
|
|
|
vec4 current_frame_position = sourcematrix * vec4(particle_position_initial, 1.0);
|
2017-02-01 15:58:10 -05:00
|
|
|
|
2015-08-13 12:15:34 -04:00
|
|
|
vec4 updated_initialposition = mix(current_frame_position,
|
|
|
|
previous_frame_position,
|
|
|
|
coeff);
|
2017-02-01 15:58:10 -05:00
|
|
|
|
2015-08-13 12:15:34 -04:00
|
|
|
vec4 updated_initial_velocity = mix(sourcematrix * vec4(particle_velocity_initial, 0.0),
|
|
|
|
previous_frame_sourcematrix * vec4(particle_velocity_initial, 0.0),
|
|
|
|
coeff);
|
2015-08-13 08:50:33 -04:00
|
|
|
//+ (current_frame_position - previous_frame_position) / dt;
|
2015-08-13 12:15:34 -04:00
|
|
|
//To be accurate, emitter speed should be added.
|
|
|
|
//But the simple formula ( (current_frame_position - previous_frame_position) / dt ) with a constant speed
|
|
|
|
//between 2 frames creates visual artifacts when the framerate is low, and a more accurate formula would need
|
|
|
|
//more complex computations.
|
2017-02-01 15:58:10 -05:00
|
|
|
|
2015-08-13 08:50:33 -04:00
|
|
|
new_particle_position = updated_initialposition.xyz + dt_from_last_frame * updated_initial_velocity.xyz;
|
|
|
|
new_particle_velocity = updated_initial_velocity.xyz;
|
2017-02-01 15:58:10 -05:00
|
|
|
|
2015-08-13 08:50:33 -04:00
|
|
|
new_lifetime = fract(updated_lifetime);
|
2017-02-01 15:58:10 -05:00
|
|
|
new_size = mix(size_initial, size_initial * size_increase_factor, fract(updated_lifetime));
|
2015-08-13 08:50:33 -04:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
new_lifetime = fract(updated_lifetime);
|
2016-06-26 10:39:34 -04:00
|
|
|
new_size = 0.0;
|
2015-08-13 08:50:33 -04:00
|
|
|
}
|
2014-01-12 14:49:23 -05:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2015-08-13 08:50:33 -04:00
|
|
|
new_particle_position = particle_position + particle_velocity.xyz * float(dt);
|
|
|
|
new_particle_velocity = particle_velocity;
|
|
|
|
new_lifetime = updated_lifetime;
|
2016-06-26 10:39:34 -04:00
|
|
|
new_size = (size == 0.0) ? 0. : mix(size_initial, size_initial * size_increase_factor, updated_lifetime);
|
2014-01-12 14:49:23 -05:00
|
|
|
}
|
2015-08-13 08:50:33 -04:00
|
|
|
gl_Position = vec4(0.);
|
2013-12-29 13:23:36 -05:00
|
|
|
}
|