Fix all remaining errors
This commit is contained in:
parent
e6f7184193
commit
a1a7c090ed
15 changed files with 82 additions and 208 deletions
|
@ -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),
|
||||||
|
|
|
@ -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()));
|
||||||
|
|
|
@ -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"));
|
||||||
}
|
}
|
||||||
|
|
|
@ -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()) {
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
|
@ -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);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue