Merge pull request #81902 from lawnjelly/fix_particle_zero_scale

[3.x] Fix zero scale in particle shader
This commit is contained in:
Rémi Verschelde 2023-09-19 09:49:31 +02:00 committed by GitHub
commit 1d7a417aff
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 7 additions and 1 deletions

View File

@ -659,8 +659,14 @@ void ParticlesMaterial::_update_shader() {
} }
//scale by scale //scale by scale
code += " float base_scale = tex_scale * mix(scale, 1.0, scale_random * scale_rand);\n"; code += " float base_scale = tex_scale * mix(scale, 1.0, scale_random * scale_rand);\n";
// Prevent zero scale (which can cause rendering issues). // Prevent zero scale (which can cause rendering issues).
code += " base_scale = sign(base_scale) * max(abs(base_scale), 0.000001);\n"; code += " if (base_scale >= 0.0) {\n";
code += " base_scale = max(base_scale, 0.000001);\n";
code += " } else {\n";
code += " base_scale = min(base_scale, -0.000001);\n";
code += " }\n";
if (trail_size_modifier.is_valid()) { if (trail_size_modifier.is_valid()) {
code += " if (trail_divisor > 1) {\n"; code += " if (trail_divisor > 1) {\n";
code += " base_scale *= textureLod(trail_size_modifier, vec2(float(int(NUMBER) % trail_divisor) / float(trail_divisor - 1), 0.0), 0.0).r;\n"; code += " base_scale *= textureLod(trail_size_modifier, vec2(float(int(NUMBER) % trail_divisor) / float(trail_divisor - 1), 0.0), 0.0).r;\n";