Particle spawner: Do not spawn particles distant from player (#5766)

Previously, every particle was rendered by (even if not actually visible to)
the client regardless of distance. This significantly reduced client FPS.

Acts clientside, particle spawners are always sent to clients, but each
particle is checked for distance from the player.
As with 'add particle' the distance limit is set to 'max block send distance'
as this determines how far a client can see.
This commit is contained in:
Paramat 2017-05-20 15:46:35 +01:00 committed by Loïc Blot
parent af2f02552f
commit 60baf8120c

@ -27,6 +27,7 @@ with this program; if not, write to the Free Software Foundation, Inc.,
#include "clientmap.h"
#include "mapnode.h"
#include "client.h"
#include "settings.h"
/*
Utility
@ -293,6 +294,9 @@ void ParticleSpawner::step(float dtime, ClientEnvironment* env)
{
m_time += dtime;
static const float radius =
g_settings->getS16("max_block_send_distance") * MAP_BLOCKSIZE;
bool unloaded = false;
bool is_attached = false;
v3f attached_pos = v3f(0,0,0);
@ -316,11 +320,13 @@ void ParticleSpawner::step(float dtime, ClientEnvironment* env)
{
m_amount--;
// Pretend to, but don't actually spawn a
// particle if it is attached to an unloaded
// object.
// Pretend to, but don't actually spawn a particle if it is
// attached to an unloaded object or distant from player.
if (!unloaded) {
v3f ppos = m_player->getPosition() / BS;
v3f pos = random_v3f(m_minpos, m_maxpos);
if (pos.getDistanceFrom(ppos) <= radius) {
v3f vel = random_v3f(m_minvel, m_maxvel);
v3f acc = random_v3f(m_minacc, m_maxacc);
@ -359,6 +365,7 @@ void ParticleSpawner::step(float dtime, ClientEnvironment* env)
m_glow);
m_particlemanager->addParticle(toadd);
}
}
i = m_spawntimes.erase(i);
}
else
@ -376,7 +383,11 @@ void ParticleSpawner::step(float dtime, ClientEnvironment* env)
{
if (rand()/(float)RAND_MAX < dtime)
{
// Do not spawn particle if distant from player
v3f ppos = m_player->getPosition() / BS;
v3f pos = random_v3f(m_minpos, m_maxpos);
if (pos.getDistanceFrom(ppos) <= radius) {
v3f vel = random_v3f(m_minvel, m_maxvel);
v3f acc = random_v3f(m_minacc, m_maxacc);
@ -418,6 +429,7 @@ void ParticleSpawner::step(float dtime, ClientEnvironment* env)
}
}
}
}
ParticleManager::ParticleManager(ClientEnvironment* env) :