mirror of
https://github.com/pmmp/PocketMine-MP.git
synced 2025-05-14 09:49:50 +00:00
Fixed empty chunks on generation, closes #2998
This commit is contained in:
parent
db409851e9
commit
925b0c1b07
@ -2413,8 +2413,8 @@ class Level implements ChunkManager, Metadatable{
|
||||
}
|
||||
|
||||
Timings::$populationTimer->startTiming();
|
||||
$chunk = $this->getChunk($x, $z, false);
|
||||
if($chunk === null or !$chunk->isPopulated()){
|
||||
$chunk = $this->getChunk($x, $z, true);
|
||||
if(!$chunk->isPopulated()){
|
||||
$populate = true;
|
||||
for($xx = -1; $xx <= 1; ++$xx){
|
||||
for($zz = -1; $zz <= 1; ++$zz){
|
||||
@ -2433,7 +2433,7 @@ class Level implements ChunkManager, Metadatable{
|
||||
$this->chunkPopulationLock[Level::chunkHash($x + $xx, $z + $zz)] = true;
|
||||
}
|
||||
}
|
||||
$task = new PopulationTask($this, $x, $z, $chunk);
|
||||
$task = new PopulationTask($this, $chunk);
|
||||
$this->server->getScheduler()->scheduleAsyncTask($task);
|
||||
}
|
||||
Timings::$populationTimer->stopTiming();
|
||||
|
@ -305,6 +305,10 @@ class Chunk extends BaseChunk{
|
||||
$chunk->x = $chunkX;
|
||||
$chunk->z = $chunkZ;
|
||||
|
||||
for($y = 0; $y < 8; ++$y){
|
||||
$chunk->sections[$y] = new EmptyChunkSection($y);
|
||||
}
|
||||
|
||||
$chunk->heightMap = array_fill(0, 256, 0);
|
||||
$chunk->biomeColors = array_fill(0, 256, 0);
|
||||
|
||||
|
@ -36,8 +36,6 @@ class PopulationTask extends AsyncTask{
|
||||
public $state;
|
||||
public $levelId;
|
||||
public $chunk;
|
||||
public $chunkX;
|
||||
public $chunkZ;
|
||||
public $chunkClass;
|
||||
|
||||
public $chunk0;
|
||||
@ -50,12 +48,10 @@ class PopulationTask extends AsyncTask{
|
||||
public $chunk7;
|
||||
public $chunk8;
|
||||
|
||||
public function __construct(Level $level, $chunkX, $chunkZ, FullChunk $chunk = null){
|
||||
public function __construct(Level $level, FullChunk $chunk){
|
||||
$this->state = true;
|
||||
$this->levelId = $level->getId();
|
||||
$this->chunk = $chunk !== null ? $chunk->toFastBinary() : null;
|
||||
$this->chunkX = $chunkX;
|
||||
$this->chunkZ = $chunkZ;
|
||||
$this->chunk = $chunk->toFastBinary();
|
||||
$this->chunkClass = get_class($chunk);
|
||||
|
||||
for($i = 0; $i < 9; ++$i){
|
||||
@ -64,7 +60,7 @@ class PopulationTask extends AsyncTask{
|
||||
}
|
||||
$xx = -1 + $i % 3;
|
||||
$zz = -1 + (int) ($i / 3);
|
||||
$ck = $level->getChunk($chunkX + $xx, $chunkZ + $zz, false);
|
||||
$ck = $level->getChunk($chunk->getX() + $xx, $chunk->getZ() + $zz, false);
|
||||
$this->{"chunk$i"} = $ck !== null ? $ck->toFastBinary() : null;
|
||||
}
|
||||
}
|
||||
@ -79,15 +75,12 @@ class PopulationTask extends AsyncTask{
|
||||
return;
|
||||
}
|
||||
|
||||
$chunkX = $this->chunkX;
|
||||
$chunkZ = $this->chunkZ;
|
||||
|
||||
/** @var FullChunk[] $chunks */
|
||||
$chunks = [];
|
||||
/** @var FullChunk $chunkC */
|
||||
$chunkC = $this->chunkClass;
|
||||
|
||||
$chunk = $this->chunk !== null ? $chunkC::fromFastBinary($this->chunk) : $chunkC::getEmptyChunk($chunkX, $chunkZ);
|
||||
$chunk = $chunkC::fromFastBinary($this->chunk);
|
||||
|
||||
for($i = 0; $i < 9; ++$i){
|
||||
if($i === 4){
|
||||
@ -97,7 +90,7 @@ class PopulationTask extends AsyncTask{
|
||||
$zz = -1 + (int) ($i / 3);
|
||||
$ck = $this->{"chunk$i"};
|
||||
if($ck === null){
|
||||
$chunks[$i] = $chunkC::getEmptyChunk($chunkX + $xx, $chunkZ + $zz);
|
||||
$chunks[$i] = $chunkC::getEmptyChunk($chunk->getX() + $xx, $chunk->getZ() + $zz);
|
||||
}else{
|
||||
$chunks[$i] = $chunkC::fromFastBinary($ck);
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user