Fixed NPE in yCoordHelper, Other Bugs, Reimplemented Limbo Decay #52
@@ -2,66 +2,71 @@ package StevenDimDoors.mod_pocketDim.helpers;
|
|||||||
|
|
||||||
import StevenDimDoors.mod_pocketDim.LinkData;
|
import StevenDimDoors.mod_pocketDim.LinkData;
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
|
import net.minecraft.block.material.Material;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
import net.minecraft.world.chunk.Chunk;
|
import net.minecraft.world.chunk.Chunk;
|
||||||
|
|
||||||
|
|
||||||
public class yCoordHelper
|
public class yCoordHelper
|
||||||
{
|
{
|
||||||
|
private static final int MAXIMUM_UNCOVERED_Y = 245;
|
||||||
|
|
||||||
public static int getFirstUncovered(LinkData pointerLink)
|
public static int getFirstUncovered(LinkData pointerLink)
|
||||||
{
|
{
|
||||||
return yCoordHelper.getFirstUncovered(pointerLink.destDimID, pointerLink.destXCoord,pointerLink.destYCoord, pointerLink.destZCoord);
|
return yCoordHelper.getFirstUncovered(
|
||||||
|
pointerLink.destDimID,
|
||||||
|
pointerLink.destXCoord,
|
||||||
|
pointerLink.destYCoord,
|
||||||
|
pointerLink.destZCoord);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static int getFirstUncovered(int worldID, int x, int yStart, int z)
|
public static int getFirstUncovered(int worldID, int x, int yStart, int z)
|
||||||
{
|
{
|
||||||
if(dimHelper.getWorld(worldID)==null||dimHelper.getWorld(worldID).provider==null)
|
if (dimHelper.getWorld(worldID) == null ||
|
||||||
|
dimHelper.getWorld(worldID).provider == null)
|
||||||
{
|
{
|
||||||
dimHelper.initDimension(worldID);
|
dimHelper.initDimension(worldID);
|
||||||
}
|
}
|
||||||
|
|
||||||
return yCoordHelper.getFirstUncovered(dimHelper.getWorld(worldID), x, yStart, z);
|
return yCoordHelper.getFirstUncovered(dimHelper.getWorld(worldID), x, yStart, z);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static int getFirstUncovered(World world, int x, int yStart, int z)
|
public static int getFirstUncovered(World world, int x, int yStart, int z)
|
||||||
{
|
{
|
||||||
int yCoord=yStart;
|
|
||||||
|
|
||||||
Chunk chunk = world.getChunkProvider().loadChunk(x >> 4, z >> 4);
|
Chunk chunk = world.getChunkProvider().loadChunk(x >> 4, z >> 4);
|
||||||
|
|
||||||
int xC=(x % 16)< 0 ? (x % 16)+16 : (x % 16);
|
int localX = x < 0 ? (x % 16) + 16 : (x % 16);
|
||||||
int yC=yCoord;
|
int localZ = z < 0 ? (z % 16) + 16 : (z % 16);
|
||||||
int zC=(z % 16)< 0 ? (z % 16)+16 : (z % 16);
|
int height = MAXIMUM_UNCOVERED_Y; //world.getHeight();
|
||||||
|
int y;
|
||||||
|
|
||||||
|
boolean covered = true;
|
||||||
boolean flag=false;
|
for (y = yStart; y < height && covered; y++)
|
||||||
|
|
||||||
do
|
|
||||||
{
|
{
|
||||||
flag=false;
|
covered = IsCoveredBlock(chunk, localX, y - 1, localZ) || IsCoveredBlock(chunk, localX, y, localZ);
|
||||||
if(yC>0&&chunk.getBlockID(xC, yC-1, zC)!=0)
|
}
|
||||||
{
|
|
||||||
if(!Block.blocksList[chunk.getBlockID(xC, yC-1, zC)].blockMaterial.isReplaceable()||Block.blocksList[chunk.getBlockID(xC, yC-1, zC)].blockMaterial.isLiquid())
|
return y;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean IsCoveredBlock(Chunk chunk, int localX, int y, int localZ)
|
||||||
{
|
{
|
||||||
|
int blockID;
|
||||||
|
Block block;
|
||||||
|
Material material;
|
||||||
|
|
||||||
flag=true;
|
if (y < 0)
|
||||||
|
return false;
|
||||||
|
|
||||||
}
|
blockID = chunk.getBlockID(localX, y, localZ);
|
||||||
}
|
if (blockID == 0)
|
||||||
|
return false;
|
||||||
if(yC>0&&chunk.getBlockID(xC, yC, zC)!=0)
|
|
||||||
{
|
block = Block.blocksList[blockID];
|
||||||
if(!Block.blocksList[chunk.getBlockID(xC, yC, zC)].blockMaterial.isReplaceable()||Block.blocksList[chunk.getBlockID(xC, yC, zC)].blockMaterial.isLiquid())
|
if (block == null)
|
||||||
{
|
return false;
|
||||||
|
|
||||||
flag=true;
|
material = block.blockMaterial;
|
||||||
|
return (!material.isLiquid() && !material.isReplaceable());
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
yC++;
|
|
||||||
}
|
|
||||||
while(flag&&yC<245);
|
|
||||||
|
|
||||||
|
|
||||||
return yC-1;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user