forked from Mirrorlandia_minetest/minetest
Biomemap: Avoid empty biomemap entry to fix failing biome dust (#7393)
'generateBiomes()' constructs the biomemap as it generates biomes. The biome calculated at first stone surface encountered is added to the biomemap. Previously, if no stone surface was encountered in a mapchunk column the biomemap was left empty for that (x, z) position, causing biome dust and water surface decoration placement to fail. If at the base of a mapchunk column the biomemap is empty, add the currently active biome to the biomemap, or if biome is NULL calculate it for this position and add it to the biomemap.
This commit is contained in:
parent
162ffd7fba
commit
99143f4947
@ -692,6 +692,7 @@ void MapgenBasic::generateBiomes()
|
|||||||
// (Re)calculate biome
|
// (Re)calculate biome
|
||||||
biome = biomegen->getBiomeAtIndex(index, v3s16(x, y, z));
|
biome = biomegen->getBiomeAtIndex(index, v3s16(x, y, z));
|
||||||
|
|
||||||
|
// Add biome to biomemap at first stone surface detected
|
||||||
if (biomemap[index] == BIOME_NONE && is_stone_surface)
|
if (biomemap[index] == BIOME_NONE && is_stone_surface)
|
||||||
biomemap[index] = biome->index;
|
biomemap[index] = biome->index;
|
||||||
|
|
||||||
@ -761,6 +762,19 @@ void MapgenBasic::generateBiomes()
|
|||||||
|
|
||||||
VoxelArea::add_y(em, vi, -1);
|
VoxelArea::add_y(em, vi, -1);
|
||||||
}
|
}
|
||||||
|
// If no stone surface was detected in this mapchunk column the biomemap
|
||||||
|
// will be empty for this (x, z) position. Add the currently active
|
||||||
|
// biome to the biomemap, or if biome is NULL calculate it for this
|
||||||
|
// position.
|
||||||
|
if (biomemap[index] == BIOME_NONE) {
|
||||||
|
if (biome) {
|
||||||
|
biomemap[index] = biome->index;
|
||||||
|
} else {
|
||||||
|
biome =
|
||||||
|
biomegen->getBiomeAtIndex(index, v3s16(x, node_min.Y, z));
|
||||||
|
biomemap[index] = biome->index;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user