Fix all remaining errors

This commit is contained in:
Runemoro 2020-03-16 04:53:43 -04:00
parent e6f7184193
commit a1a7c090ed
15 changed files with 82 additions and 208 deletions

View file

@ -26,10 +26,10 @@ public final class ModItemGroups {
new ItemStack(ModItems.RIFT_SIGNATURE), new ItemStack(ModItems.RIFT_SIGNATURE),
new ItemStack(ModItems.STABILIZED_RIFT_SIGNATURE), new ItemStack(ModItems.STABILIZED_RIFT_SIGNATURE),
new ItemStack(ModItems.RIFT_STABILIZER), new ItemStack(ModItems.RIFT_STABILIZER),
new ItemStack(ModItems.WOVEN_WORLD_THREAD_HELMET), new ItemStack(ModItems.WORLD_THREAD_HELMET),
new ItemStack(ModItems.WOVEN_WORLD_THREAD_CHESTPLATE), new ItemStack(ModItems.WORLD_THREAD_CHESTPLATE),
new ItemStack(ModItems.WOVEN_WORLD_THREAD_LEGGINGS), new ItemStack(ModItems.WORLD_THREAD_LEGGINGS),
new ItemStack(ModItems.WOVEN_WORLD_THREAD_BOOTS), new ItemStack(ModItems.WORLD_THREAD_BOOTS),
new ItemStack(ModItems.STABLE_FABRIC), new ItemStack(ModItems.STABLE_FABRIC),
new ItemStack(ModItems.WHITE_FABRIC), new ItemStack(ModItems.WHITE_FABRIC),
new ItemStack(ModItems.ORANGE_FABRIC), new ItemStack(ModItems.ORANGE_FABRIC),

View file

@ -22,16 +22,16 @@ public final class ModItems {
public static final Item GOLD_DOOR = register(ModBlocks.GOLD_DOOR); public static final Item GOLD_DOOR = register(ModBlocks.GOLD_DOOR);
public static final Item QUARTZ_DOOR = register(ModBlocks.QUARTZ_DOOR); public static final Item QUARTZ_DOOR = register(ModBlocks.QUARTZ_DOOR);
public static final Item IRON_DIMENSIONAL_DOOR = new DimensionalDoorItem( public static final Item IRON_DIMENSIONAL_DOOR = register(new DimensionalDoorItem(
ModBlocks.IRON_DIMENSIONAL_DOOR, ModBlocks.IRON_DIMENSIONAL_DOOR,
new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS).maxCount(1), new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS).maxCount(1),
rift -> { rift -> {
PublicPocketTarget destination = new PublicPocketTarget(); PublicPocketTarget destination = new PublicPocketTarget();
rift.setDestination(destination); rift.setDestination(destination);
} }
); ));
public static final Item GOLD_DIMENSIONAL_DOOR = new DimensionalDoorItem( public static final Item GOLD_DIMENSIONAL_DOOR = register(new DimensionalDoorItem(
ModBlocks.GOLD_DIMENSIONAL_DOOR, ModBlocks.GOLD_DIMENSIONAL_DOOR,
new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS).maxCount(1), new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS).maxCount(1),
rift -> { rift -> {
@ -49,9 +49,9 @@ public final class ModItems {
.noLinkBack(false) .noLinkBack(false)
.newRiftWeight(1).build()); .newRiftWeight(1).build());
} }
); ));
public static final Item QUARTZ_DIMENSIONAL_DOOR = new DimensionalDoorItem( public static final Item QUARTZ_DIMENSIONAL_DOOR = register(new DimensionalDoorItem(
ModBlocks.QUARTZ_DIMENSIONAL_DOOR, ModBlocks.QUARTZ_DIMENSIONAL_DOOR,
new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS).maxCount(1), new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS).maxCount(1),
rift -> { rift -> {
@ -61,17 +61,17 @@ public final class ModItems {
rift.setDestination(new PrivatePocketTarget()); // entrances rift.setDestination(new PrivatePocketTarget()); // entrances
} }
} }
); ));
public static final Item UNSTABLE_DIMENSIONAL_DOOR = new DimensionalDoorItem( public static final Item UNSTABLE_DIMENSIONAL_DOOR = register(new DimensionalDoorItem(
ModBlocks.IRON_DIMENSIONAL_DOOR, ModBlocks.IRON_DIMENSIONAL_DOOR,
new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS).maxCount(1), new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS).maxCount(1),
rift -> { rift -> {
// TODO // TODO
} }
); ));
public static final Item WOOD_DIMENSIONAL_DOOR = new DimensionalDoorItem( public static final Item WOOD_DIMENSIONAL_DOOR = register(new DimensionalDoorItem(
ModBlocks.WOOD_DIMENSIONAL_DOOR, ModBlocks.WOOD_DIMENSIONAL_DOOR,
new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS).maxCount(1), new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS).maxCount(1),
rift -> rift.setDestination( rift -> rift.setDestination(
@ -84,13 +84,13 @@ public final class ModItems {
.weightMaximum(100) .weightMaximum(100)
.noLink(false).newRiftWeight(0).build() .noLink(false).newRiftWeight(0).build()
) )
); ));
public static final Item WOOD_DIMENSIONAL_TRAPDOOR = new DimensionalTrapdoorItem( public static final Item WOOD_DIMENSIONAL_TRAPDOOR = register(new DimensionalTrapdoorItem(
ModBlocks.WOOD_DIMENSIONAL_DOOR, ModBlocks.WOOD_DIMENSIONAL_DOOR,
new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS).maxCount(1), new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS).maxCount(1),
rift -> rift.setDestination(new EscapeTarget(false)) rift -> rift.setDestination(new EscapeTarget(false))
); ));
public static final Item WHITE_FABRIC = register(ModBlocks.WHITE_FABRIC); public static final Item WHITE_FABRIC = register(ModBlocks.WHITE_FABRIC);
public static final Item ORANGE_FABRIC = register(ModBlocks.ORANGE_FABRIC); public static final Item ORANGE_FABRIC = register(ModBlocks.ORANGE_FABRIC);
@ -133,20 +133,20 @@ public final class ModItems {
// Dimensional doors // Dimensional doors
public static final Item WORLD_THREAD = new Item(new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS)); public static final Item WORLD_THREAD = register(new Identifier("dimdoors:world_thread"), new Item(new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS)));
public static final Item STABLE_FABRIC = new Item(new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS)); public static final Item STABLE_FABRIC = register(new Identifier("dimdoors:stable_fabric"), new Item(new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS)));
public static final Item RIFT_CONFIGURATION_TOOL = new RiftConfigurationToolItem(); public static final Item RIFT_CONFIGURATION_TOOL = register(new Identifier("dimdoors:rift_configuration_tool"), new RiftConfigurationToolItem());
public static final Item RIFT_BLADE = new RiftBladeItem(new Item.Settings().maxDamage(100).group(ModItemGroups.DIMENSIONAL_DOORS)); public static final Item RIFT_BLADE = register(new Identifier("dimdoors:rift_blade"), new RiftBladeItem(new Item.Settings().maxDamage(100).group(ModItemGroups.DIMENSIONAL_DOORS)));
public static final Item RIFT_REMOVER = new RiftRemoverItem(new Item.Settings().maxCount(1).maxDamage(100).group(ModItemGroups.DIMENSIONAL_DOORS)); public static final Item RIFT_REMOVER = register(new Identifier("dimdoors:rift_remover"), new RiftRemoverItem(new Item.Settings().maxCount(1).maxDamage(100).group(ModItemGroups.DIMENSIONAL_DOORS)));
public static final Item RIFT_SIGNATURE = new RiftSignatureItem(new Item.Settings().maxCount(1).maxDamage(1).group(ModItemGroups.DIMENSIONAL_DOORS)); public static final Item RIFT_SIGNATURE = register(new Identifier("dimdoors:rift_signature"), new RiftSignatureItem(new Item.Settings().maxCount(1).maxDamage(1).group(ModItemGroups.DIMENSIONAL_DOORS)));
public static final Item STABILIZED_RIFT_SIGNATURE = new StabilizedRiftSignatureItem(new Item.Settings().maxCount(1).maxDamage(20).group(ModItemGroups.DIMENSIONAL_DOORS)); public static final Item STABILIZED_RIFT_SIGNATURE = register(new Identifier("dimdoors:stabilized_rift_signature"), new StabilizedRiftSignatureItem(new Item.Settings().maxCount(1).maxDamage(20).group(ModItemGroups.DIMENSIONAL_DOORS)));
public static final Item RIFT_STABILIZER = new RiftStabilizerItem(new Item.Settings().maxCount(1).maxDamage(6).group(ModItemGroups.DIMENSIONAL_DOORS)); public static final Item RIFT_STABILIZER = register(new Identifier("dimdoors:rift_stabilizer"), new RiftStabilizerItem(new Item.Settings().maxCount(1).maxDamage(6).group(ModItemGroups.DIMENSIONAL_DOORS)));
public static final Item WOVEN_WORLD_THREAD_HELMET = new WorldThreadArmorItem("world_thread_helmet", EquipmentSlot.HEAD, new Item.Settings()); public static final Item WORLD_THREAD_HELMET = register(new Identifier("dimdoors:world_thread_helmet"), new WorldThreadArmorItem("world_thread_helmet", EquipmentSlot.HEAD, new Item.Settings()));
public static final Item WOVEN_WORLD_THREAD_CHESTPLATE = new WorldThreadArmorItem("world_thread_chestplate", EquipmentSlot.CHEST, new Item.Settings()); public static final Item WORLD_THREAD_CHESTPLATE = register(new Identifier("dimdoors:world_thread_chestplate"), new WorldThreadArmorItem("world_thread_chestplate", EquipmentSlot.CHEST, new Item.Settings()));
public static final Item WOVEN_WORLD_THREAD_LEGGINGS = new WorldThreadArmorItem("world_thread_leggings", EquipmentSlot.LEGS, new Item.Settings()); public static final Item WORLD_THREAD_LEGGINGS = register(new Identifier("dimdoors:world_thread_leggings"), new WorldThreadArmorItem("world_thread_leggings", EquipmentSlot.LEGS, new Item.Settings()));
public static final Item WOVEN_WORLD_THREAD_BOOTS = new WorldThreadArmorItem("world_thread_boots", EquipmentSlot.FEET, new Item.Settings()); public static final Item WORLD_THREAD_BOOTS = register(new Identifier("dimdoors:world_thread_boots"), new WorldThreadArmorItem("world_thread_boots", EquipmentSlot.FEET, new Item.Settings()));
public static final Item CREEPY_RECORD = new MusicDiscItem(10, ModSoundEvents.CREEPY, new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS)); public static final Item CREEPY_RECORD = register(new Identifier("dimdoors:creepy_record"), new MusicDiscItem(10, ModSoundEvents.CREEPY, new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS)));
public static final Item WHITE_VOID_RECORD = new MusicDiscItem(10, ModSoundEvents.CREEPY, new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS)); public static final Item WHITE_VOID_RECORD = register(new Identifier("dimdoors:white_void_record"), new MusicDiscItem(10, ModSoundEvents.CREEPY, new Item.Settings().group(ModItemGroups.DIMENSIONAL_DOORS)));
private static Item register(Block block) { private static Item register(Block block) {
return register(new BlockItem(block, new Item.Settings())); return register(new BlockItem(block, new Item.Settings()));

View file

@ -23,7 +23,6 @@ import org.dimdev.dimdoors.sound.ModSoundEvents;
import org.dimdev.util.Location; import org.dimdev.util.Location;
import org.dimdev.util.RotatedLocation; import org.dimdev.util.RotatedLocation;
import java.util.List; import java.util.List;
public class StabilizedRiftSignatureItem extends Item { // TODO: common superclass with rift signature public class StabilizedRiftSignatureItem extends Item { // TODO: common superclass with rift signature
@ -63,19 +62,19 @@ public class StabilizedRiftSignatureItem extends Item { // TODO: common supercla
if (target == null) { if (target == null) {
// The link signature has not been used. Store its current target as the first location. // The link signature has not been used. Store its current target as the first location.
setSource(stack, new RotatedLocation(world, pos, player.yaw, 0)); setSource(stack, new RotatedLocation((ServerWorld) world, pos, player.yaw, 0));
player.sendMessage(new TranslatableText(getTranslationKey() + ".stored"), true); player.sendMessage(new TranslatableText(getTranslationKey() + ".stored"));
world.playSound(null, player.getBlockPos(), ModSoundEvents.RIFT_START, SoundCategory.BLOCKS, 0.6f, 1); world.playSound(null, player.getSenseCenterPos(), ModSoundEvents.RIFT_START, SoundCategory.BLOCKS, 0.6f, 1);
} else { } else {
// Place a rift at the target point // Place a rift at the target point
if (target.getBlockState().getBlock() != ModBlocks.DETACHED_RIFT) { if (target.getBlockState().getBlock() != ModBlocks.DETACHED_RIFT) {
if (!target.getBlockState().getBlock().canReplace(world.getBlockState(((Location) target).getBlockPos()), itemPlacementContext)) { if (!target.getBlockState().getBlock().canReplace(world.getBlockState(target.getBlockPos()), itemPlacementContext)) {
player.sendMessage(new TranslatableText("tools.target_became_block")); player.sendMessage(new TranslatableText("tools.target_became_block"));
// Don't clear source, stabilized signatures always stay bound // Don't clear source, stabilized signatures always stay bound
return ActionResult.FAIL; return ActionResult.FAIL;
} }
World targetWorld = ((Location) target).world; World targetWorld = target.world;
targetWorld.setBlockState(((Location) target).getBlockPos(), ModBlocks.DETACHED_RIFT.getDefaultState()); targetWorld.setBlockState(target.getBlockPos(), ModBlocks.DETACHED_RIFT.getDefaultState());
DetachedRiftBlockEntity rift1 = (DetachedRiftBlockEntity) target.getBlockEntity(); DetachedRiftBlockEntity rift1 = (DetachedRiftBlockEntity) target.getBlockEntity();
rift1.register(); rift1.register();
} }
@ -88,8 +87,8 @@ public class StabilizedRiftSignatureItem extends Item { // TODO: common supercla
stack.damage(1, player, playerEntity -> {}); stack.damage(1, player, playerEntity -> {});
player.sendMessage(new TranslatableText(getTranslationKey() + ".created"), true); player.sendMessage(new TranslatableText(getTranslationKey() + ".created"));
world.playSound(null, player.getBlockPos(), ModSoundEvents.RIFT_END, SoundCategory.BLOCKS, 0.6f, 1); world.playSound(null, player.getSenseCenterPos(), ModSoundEvents.RIFT_END, SoundCategory.BLOCKS, 0.6f, 1);
} }
return ActionResult.SUCCESS; return ActionResult.SUCCESS;
@ -120,7 +119,7 @@ public class StabilizedRiftSignatureItem extends Item { // TODO: common supercla
RotatedLocation transform = getTarget(itemStack); RotatedLocation transform = getTarget(itemStack);
if (transform != null) { if (transform != null) {
list.add(new TranslatableText(getTranslationKey() + ".bound.info", transform.getX(), transform.getY(), transform.getZ(), ((Location) transform).getWorldId())); list.add(new TranslatableText(getTranslationKey() + ".bound.info", transform.getX(), transform.getY(), transform.getZ(), transform.getWorldId()));
} else { } else {
list.add(new TranslatableText(getTranslationKey() + ".unbound.info")); list.add(new TranslatableText(getTranslationKey() + ".unbound.info"));
} }

View file

@ -168,12 +168,12 @@ public class PocketTemplate {
} }
public void place(Pocket pocket, boolean setup) { public void place(Pocket pocket, boolean setup) {
pocket.setSize(size); pocket.setSize(size * 16, size * 16, size * 16);
int gridSize = PocketRegistry.instance(pocket.world).getGridSize(); int gridSize = PocketRegistry.instance(pocket.world).getGridSize();
World world = pocket.world; World world = pocket.world;
int xBase = pocket.getX() * gridSize * 16; int xBase = pocket.box.minX;
int yBase = 0; int yBase = pocket.box.minY;
int zBase = pocket.getZ() * gridSize * 16; int zBase = pocket.box.minZ;
//Converting the schematic from bytearray if needed //Converting the schematic from bytearray if needed
if (schematic == null) { if (schematic == null) {
@ -195,10 +195,10 @@ public class PocketTemplate {
public void setup(Pocket pocket, VirtualTarget linkTo, LinkProperties linkProperties) { public void setup(Pocket pocket, VirtualTarget linkTo, LinkProperties linkProperties) {
int gridSize = PocketRegistry.instance(pocket.world).getGridSize(); int gridSize = PocketRegistry.instance(pocket.world).getGridSize();
World world = pocket.world; ServerWorld world = pocket.world;
int xBase = pocket.getX() * gridSize * 16; int xBase = pocket.box.minX;
int yBase = 0; int yBase = pocket.box.minY;
int zBase = pocket.getZ() * gridSize * 16; int zBase = pocket.box.minZ;
// Fill chests and make rift list // Fill chests and make rift list
List<RiftBlockEntity> rifts = new ArrayList<>(); List<RiftBlockEntity> rifts = new ArrayList<>();
@ -221,12 +221,12 @@ public class PocketTemplate {
LootTable table; LootTable table;
if (tile instanceof ChestBlockEntity) { if (tile instanceof ChestBlockEntity) {
LOGGER.debug("Now populating chest."); LOGGER.debug("Now populating chest.");
table = world.getServer().getLootManager().getSupplier(new Identifier("dimdoors:dungeon_chest")); table = world.getServer().getLootManager().getTable(new Identifier("dimdoors:dungeon_chest"));
} else { //(tile instanceof TileEntityDispenser) } else { //(tile instanceof TileEntityDispenser)
LOGGER.debug("Now populating dispenser."); LOGGER.debug("Now populating dispenser.");
table = world.getServer().getLootManager().getSupplier(new Identifier("dimdoors:dispenser_projectiles")); table = world.getServer().getLootManager().getTable(new Identifier("dimdoors:dispenser_projectiles"));
} }
LootContext ctx = new LootContext.Builder().setRandom(world.random).build(LootContextTypes.CHEST); LootContext ctx = new LootContext.Builder(world).setRandom(world.random).build(LootContextTypes.CHEST);
table.supplyInventory(inventory, ctx); table.supplyInventory(inventory, ctx);
LOGGER.debug("Inventory should be populated now. Chest is: " + (inventory.isInvEmpty() ? "empty." : "filled.")); LOGGER.debug("Inventory should be populated now. Chest is: " + (inventory.isInvEmpty() ? "empty." : "filled."));
if (inventory.isInvEmpty()) { if (inventory.isInvEmpty()) {

View file

@ -24,7 +24,7 @@ public class RiftPlaceholder extends Rift { // TODO: don't extend rift
@Override @Override
public void markDirty() { public void markDirty() {
RiftRegistry.instance().markSubregistryDirty(world);
} }
@Override @Override

View file

@ -25,7 +25,7 @@ public class PublicPocketTarget extends RestoringTarget {
VirtualLocation newVirtualLocation = null; VirtualLocation newVirtualLocation = null;
if (riftVirtualLocation != null) { if (riftVirtualLocation != null) {
int depth = Math.max(riftVirtualLocation.depth, 1); int depth = Math.max(riftVirtualLocation.depth, 1);
newVirtualLocation = new VirtualLocation(riftVirtualLocation.dimension, riftVirtualLocation.x, riftVirtualLocation.z, depth); newVirtualLocation = new VirtualLocation(riftVirtualLocation.world, riftVirtualLocation.x, riftVirtualLocation.z, depth);
} }
Pocket pocket = PocketGenerator.generatePublicPocket(newVirtualLocation, new GlobalReference(location), null); Pocket pocket = PocketGenerator.generatePublicPocket(newVirtualLocation, new GlobalReference(location), null);

View file

@ -1,33 +1,19 @@
package org.dimdev.dimdoors.world; package org.dimdev.dimdoors.world;
import net.minecraft.util.Identifier; import net.minecraft.util.Identifier;
import net.minecraft.util.registry.Registry;
import net.minecraft.world.biome.Biome; import net.minecraft.world.biome.Biome;
import net.minecraftforge.common.BiomeDictionary;
import net.minecraftforge.event.RegistryEvent;
import net.minecraftforge.fml.common.eventhandler.SubscribeEvent;
import org.dimdev.dimdoors.world.limbo.LimboBiome; import org.dimdev.dimdoors.world.limbo.LimboBiome;
import org.dimdev.dimdoors.world.pocketdimension.BlankBiome; import org.dimdev.dimdoors.world.pocketdimension.BlankBiome;
public final class ModBiomes { public final class ModBiomes {
public static final LimboBiome LIMBO = new LimboBiome(); public static final Biome LIMBO = register(new Identifier("dimdoors:limbo"), new LimboBiome());
public static final BlankBiome WHITE_VOID = new BlankBiome(true, false); public static final Biome WHITE_VOID = register(new Identifier("dimdoors:white_void"), new BlankBiome(true, false));
public static final BlankBiome BLACK_VOID = new BlankBiome(false, false); public static final Biome BLACK_VOID = register(new Identifier("dimdoors:black_void"), new BlankBiome(false, false));
public static final BlankBiome DANGEROUS_BLACK_VOID = new BlankBiome(false, true); public static final Biome DANGEROUS_BLACK_VOID = register(new Identifier("dimdoors:dangeroud_black_void"), new BlankBiome(false, true));
@SubscribeEvent private static Biome register(Identifier id, Biome biome) {
public static void registerBiomes(RegistryEvent.Register<Biome> event) { Registry.register(Registry.BIOME, id, biome);
LIMBO.setRegistryName(new Identifier("dimdoors", "limbo")); return biome;
WHITE_VOID.setRegistryName(new Identifier("dimdoors", "white_void"));
BLACK_VOID.setRegistryName(new Identifier("dimdoors", "black_void"));
DANGEROUS_BLACK_VOID.setRegistryName(new Identifier("dimdoors", "dangerous_black_void"));
event.getRegistry().registerAll(
LIMBO,
WHITE_VOID,
BLACK_VOID,
DANGEROUS_BLACK_VOID);
BiomeDictionary.addTypes(LIMBO, BiomeDictionary.Type.VOID);
BiomeDictionary.addTypes(WHITE_VOID, BiomeDictionary.Type.VOID);
BiomeDictionary.addTypes(BLACK_VOID, BiomeDictionary.Type.VOID);
BiomeDictionary.addTypes(DANGEROUS_BLACK_VOID, BiomeDictionary.Type.VOID);
} }
} }

View file

@ -23,7 +23,11 @@ public class LimboGateway extends BaseGateway {
world.setBlockState(new BlockPos(x, y + 1, z - 1), unravelledFabric); world.setBlockState(new BlockPos(x, y + 1, z - 1), unravelledFabric);
world.setBlockState(new BlockPos(x, y + 1, z + 1), unravelledFabric); world.setBlockState(new BlockPos(x, y + 1, z + 1), unravelledFabric);
DimensionalDoorItem.placeDoor(world, new BlockPos(x, y + 1, z), Direction.NORTH, ModBlocks.DIMENSIONAL_PORTAL, false); placePortal(world, new BlockPos(x, y + 1, z), Direction.NORTH);
}
private void placePortal(World world, BlockPos pos, Direction facing) {
// todo
} }
@Override @Override

View file

@ -1,66 +1,9 @@
package org.dimdev.dimdoors.world.limbo; package org.dimdev.dimdoors.world.limbo;
import net.fabricmc.api.EnvType;
import net.fabricmc.api.Environment;
import net.minecraft.util.math.BlockPos;
import net.minecraft.world.World;
import net.minecraft.world.biome.Biome; import net.minecraft.world.biome.Biome;
import net.minecraft.world.chunk.ChunkPrimer;
import org.dimdev.dimdoors.entity.MonolithEntity;
import java.util.Random;
public class LimboBiome extends Biome { public class LimboBiome extends Biome {
public LimboBiome() { public LimboBiome() {
super(new Biome.BiomeProperties("Limbo") super(new Settings());
.setRainDisabled()
.setRainfall(0)
.setWaterColor(0x000000));
// topBlock = Blocks.AIR.getDefaultState();
// fillerBlock = Blocks.AIR.getDefaultState();
spawnableMonsterList.clear();
spawnableCreatureList.clear();
spawnableWaterCreatureList.clear();
spawnableCaveCreatureList.clear();
spawnableMonsterList.add(new SpawnListEntry(MonolithEntity.class, 100, 1, 1));
flowers.clear();
decorator.extraTreeChance = 0;
decorator.flowersPerChunk = 0;
decorator.grassPerChunk = 0;
decorator.gravelPatchesPerChunk = 0;
decorator.sandPatchesPerChunk = 0;
decorator.clayPerChunk = 0;
decorator.generateFalls = false;
}
// Some mods like RFTools rely on the decorator being present, so we need to create one even if we don't use it.
//@Override public BiomeDecorator createBiomeDecorator() { return null; }
@Override
public void decorate(World world, Random rand, BlockPos pos) {}
@Override
public void genTerrainBlocks(World world, Random rand, ChunkPrimer chunkPrimer, int x, int z, double noiseVal) {}
// TODO: check that black/white grass and foliage in getModdedBiomeGrassColor is compatible with other mods such as Quark's greener grass option
@Override
@Environment(EnvType.CLIENT)
public int getGrassColorAtPos(BlockPos pos) {
return getModdedBiomeGrassColor(0x000000);
}
@Override
@Environment(EnvType.CLIENT)
public int getFoliageColorAtPos(BlockPos pos) {
return getModdedBiomeFoliageColor(0x000000);
}
@Override
public float getSpawningChance() {
return 0.1F;
} }
} }

View file

@ -12,8 +12,8 @@ import org.dimdev.util.Location;
public class LimboDimension extends Dimension { public class LimboDimension extends Dimension {
public LimboDimension(World world, DimensionType dimensionType, float f) { public LimboDimension(World world, DimensionType dimensionType) {
super(world, dimensionType, f); super(world, dimensionType, 0);
} }
public static Location getLimboSkySpawn(Entity entity) { public static Location getLimboSkySpawn(Entity entity) {

View file

@ -1,71 +1,9 @@
package org.dimdev.dimdoors.world.pocketdimension; package org.dimdev.dimdoors.world.pocketdimension;
import net.fabricmc.api.EnvType;
import net.fabricmc.api.Environment;
import net.minecraft.init.Blocks;
import net.minecraft.util.math.BlockPos;
import net.minecraft.world.World;
import net.minecraft.world.biome.Biome; import net.minecraft.world.biome.Biome;
import net.minecraft.world.chunk.ChunkPrimer;
import java.util.Random;
public class BlankBiome extends Biome { public class BlankBiome extends Biome {
public BlankBiome(boolean white, boolean dangerous) {
private final boolean white; super(new Biome.Settings());
public BlankBiome(boolean white, boolean monoliths) {
super(new BiomeProperties((monoliths ? "Dangerous " : "") + (white ? "White" : "Black") + " Void")
.setBaseHeight(0F)
.setHeightVariation(0F)
.setRainDisabled()
.setRainfall(0)
.setWaterColor(white ? 0xFFFFFF : 0x000055));
this.white = white;
topBlock = Blocks.AIR.getDefaultState();
fillerBlock = Blocks.AIR.getDefaultState();
spawnableMonsterList.clear();
spawnableCreatureList.clear();
spawnableWaterCreatureList.clear();
spawnableCaveCreatureList.clear();
flowers.clear();
decorator.extraTreeChance = 0;
decorator.flowersPerChunk = 0;
decorator.grassPerChunk = 0;
decorator.gravelPatchesPerChunk = 0;
decorator.sandPatchesPerChunk = 0;
decorator.clayPerChunk = 0;
decorator.generateFalls = false;
}
// Some mods like RFTools rely on the decorator being present, so we need to create one even if we don't use it.
//@Override public BiomeDecorator createBiomeDecorator() { return null; }
@Override
public void decorate(World world, Random rand, BlockPos pos) {}
@Override
public void genTerrainBlocks(World world, Random rand, ChunkPrimer chunkPrimer, int x, int z, double noiseVal) {}
@Override
@Environment(EnvType.CLIENT)
public int getSkyColorByTemp(float currentTemperature) {
return white ? 0xFCFCFC : 0x000000; // https://bugs.mojang.com/projects/MC/issues/MC-123703
}
@Override
@Environment(EnvType.CLIENT)
public int getGrassColorAtPos(BlockPos pos) {
return getModdedBiomeGrassColor(white ? 0xFFFFFF : 0x003300);
}
@Override
@Environment(EnvType.CLIENT)
public int getFoliageColorAtPos(BlockPos pos) {
return getModdedBiomeFoliageColor(white ? 0xFFFFFF : 0x003300);
} }
} }

View file

@ -9,8 +9,8 @@ import net.minecraft.world.gen.chunk.ChunkGenerator;
import org.dimdev.pocketlib.PocketWorldDimension; import org.dimdev.pocketlib.PocketWorldDimension;
public class DungeonPocketDimension extends PocketWorldDimension { public class DungeonPocketDimension extends PocketWorldDimension {
public DungeonPocketDimension(World world, DimensionType dimensionType, float f) { public DungeonPocketDimension(World world, DimensionType dimensionType) {
super(world, dimensionType, f); super(world, dimensionType, 0);
} }
@Override @Override

View file

@ -9,8 +9,8 @@ import net.minecraft.world.gen.chunk.ChunkGenerator;
import org.dimdev.pocketlib.PocketWorldDimension; import org.dimdev.pocketlib.PocketWorldDimension;
public class PersonalPocketDimension extends PocketWorldDimension { public class PersonalPocketDimension extends PocketWorldDimension {
public PersonalPocketDimension(World world, DimensionType dimensionType, float f) { public PersonalPocketDimension(World world, DimensionType dimensionType) {
super(world, dimensionType, f); super(world, dimensionType, 0);
} }
@Override @Override

View file

@ -9,8 +9,8 @@ import net.minecraft.world.gen.chunk.ChunkGenerator;
import org.dimdev.pocketlib.PocketWorldDimension; import org.dimdev.pocketlib.PocketWorldDimension;
public class PublicPocketDimension extends PocketWorldDimension { public class PublicPocketDimension extends PocketWorldDimension {
public PublicPocketDimension(World world, DimensionType dimensionType, float f) { public PublicPocketDimension(World world, DimensionType dimensionType) {
super(world, dimensionType, f); super(world, dimensionType, 0);
} }
@Override @Override

View file

@ -28,7 +28,7 @@ public final class Pocket {
public Pocket(int id, ServerWorld world, int x, int z) { public Pocket(int id, ServerWorld world, int x, int z) {
this.id = id; this.id = id;
this.world = world; this.world = world;
new BlockBox(x * 16, 0, z * 16, (x + 1) * 16, 255, (z + 1) * 16); new BlockBox(x * 16, 0, z * 16, (x + 1) * 16, 0, (z + 1) * 16);
} }
boolean isInBounds(BlockPos pos) { boolean isInBounds(BlockPos pos) {
@ -99,4 +99,8 @@ public final class Pocket {
return (outerVolume - innerVolume) / BLOCKS_PAINTED_PER_DYE; return (outerVolume - innerVolume) / BLOCKS_PAINTED_PER_DYE;
} }
public void setSize(int x, int y, int z) {
box = new BlockBox(box.minX, box.minY, box.minZ, box.minX + x, box.minY + y, box.minZ + z);
}
} }