Optimize liquid queue on generate map for liquid_finite
This commit is contained in:
parent
21a4adcd27
commit
848c3fe51a
@ -228,9 +228,12 @@ public:
|
|||||||
ServerMap *map = &env->getServerMap();
|
ServerMap *map = &env->getServerMap();
|
||||||
if (map->transforming_liquid_size() > 500)
|
if (map->transforming_liquid_size() > 500)
|
||||||
return;
|
return;
|
||||||
//todo: look around except top
|
if ( map->getNodeNoEx(p - v3s16(0, 1, 0 )).getContent() != CONTENT_AIR // below
|
||||||
MapNode n_below = map->getNodeNoEx(p - v3s16(0, 1, 0));
|
&& map->getNodeNoEx(p - v3s16(1, 0, 0 )).getContent() != CONTENT_AIR // right
|
||||||
if (n_below.getContent() != CONTENT_AIR)
|
&& map->getNodeNoEx(p - v3s16(-1, 0, 0 )).getContent() != CONTENT_AIR // left
|
||||||
|
&& map->getNodeNoEx(p - v3s16(0, 0, 1 )).getContent() != CONTENT_AIR // back
|
||||||
|
&& map->getNodeNoEx(p - v3s16(0, 0, -1)).getContent() != CONTENT_AIR // front
|
||||||
|
)
|
||||||
return;
|
return;
|
||||||
map->transforming_liquid_add(p);
|
map->transforming_liquid_add(p);
|
||||||
}
|
}
|
||||||
|
@ -836,8 +836,10 @@ void Mapgen::updateHeightmap(v3s16 nmin, v3s16 nmax) {
|
|||||||
|
|
||||||
|
|
||||||
void Mapgen::updateLiquid(UniqueQueue<v3s16> *trans_liquid, v3s16 nmin, v3s16 nmax) {
|
void Mapgen::updateLiquid(UniqueQueue<v3s16> *trans_liquid, v3s16 nmin, v3s16 nmax) {
|
||||||
bool isliquid, wasliquid;
|
bool isliquid, wasliquid, rare;
|
||||||
v3s16 em = vm->m_area.getExtent();
|
v3s16 em = vm->m_area.getExtent();
|
||||||
|
rare = g_settings->getBool("liquid_finite");
|
||||||
|
int rarecnt = 0;
|
||||||
|
|
||||||
for (s16 z = nmin.Z; z <= nmax.Z; z++) {
|
for (s16 z = nmin.Z; z <= nmax.Z; z++) {
|
||||||
for (s16 x = nmin.X; x <= nmax.X; x++) {
|
for (s16 x = nmin.X; x <= nmax.X; x++) {
|
||||||
@ -847,8 +849,8 @@ void Mapgen::updateLiquid(UniqueQueue<v3s16> *trans_liquid, v3s16 nmin, v3s16 nm
|
|||||||
for (s16 y = nmax.Y; y >= nmin.Y; y--) {
|
for (s16 y = nmax.Y; y >= nmin.Y; y--) {
|
||||||
isliquid = ndef->get(vm->m_data[i]).isLiquid();
|
isliquid = ndef->get(vm->m_data[i]).isLiquid();
|
||||||
|
|
||||||
// there was a change between liquid and nonliquid, add to queue
|
// there was a change between liquid and nonliquid, add to queue. no need to add every with liquid_finite
|
||||||
if (isliquid != wasliquid)
|
if (isliquid != wasliquid && (!rare || !(rarecnt++ % 36)))
|
||||||
trans_liquid->push_back(v3s16(x, y, z));
|
trans_liquid->push_back(v3s16(x, y, z));
|
||||||
|
|
||||||
wasliquid = isliquid;
|
wasliquid = isliquid;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user