Bug fixes and code improvements

This commit is contained in:
Runemoro 2018-01-05 20:33:19 -05:00
parent 5ad37b1992
commit 2b0fde9633
67 changed files with 313 additions and 340 deletions

View file

@ -4,15 +4,18 @@ import net.minecraft.client.resources.I18n;
import net.minecraftforge.fml.relauncher.Side; import net.minecraftforge.fml.relauncher.Side;
import net.minecraftforge.fml.relauncher.SideOnly; import net.minecraftforge.fml.relauncher.SideOnly;
import java.util.ArrayList;
import java.util.List; import java.util.List;
public final class I18nUtils { public final class I18nUtils {
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
public static void translateAndAdd(String key, List<String> list) { public static List<String> translateMultiline(String key) {
List<String> list = new ArrayList<>();
int i = 0; int i = 0;
while (I18n.hasKey(key + Integer.toString(i))) { while (I18n.hasKey(key + i)) {
list.add(I18n.format(key + Integer.toString(i))); list.add(I18n.format(key + i));
i++; i++;
} }
return list;
} }
} }

View file

@ -1,8 +1,7 @@
package org.dimdev.dimdoors.shared; package org.dimdev.ddutils;
import lombok.*; import lombok.*;
import net.minecraft.nbt.NBTTagCompound; import net.minecraft.nbt.NBTTagCompound;
import org.dimdev.ddutils.Location;
import org.dimdev.ddutils.nbt.INBTStorable; import org.dimdev.ddutils.nbt.INBTStorable;
import org.dimdev.ddutils.nbt.NBTUtils; import org.dimdev.ddutils.nbt.NBTUtils;
import org.dimdev.ddutils.nbt.SavedToNBT; import org.dimdev.ddutils.nbt.SavedToNBT;
@ -11,6 +10,7 @@ import org.dimdev.ddutils.nbt.SavedToNBT;
@SavedToNBT public class RotatedLocation implements INBTStorable { @SavedToNBT public class RotatedLocation implements INBTStorable {
@Getter @SavedToNBT /*private*/ Location location; @Getter @SavedToNBT /*private*/ Location location;
@Getter @SavedToNBT /*private*/ float yaw; @Getter @SavedToNBT /*private*/ float yaw;
@Getter @SavedToNBT /*private*/ float pitch;
@Override public NBTTagCompound writeToNBT(NBTTagCompound nbt) { return NBTUtils.writeToNBT(this, nbt); } @Override public NBTTagCompound writeToNBT(NBTTagCompound nbt) { return NBTUtils.writeToNBT(this, nbt); }
@Override public void readFromNBT(NBTTagCompound nbt) { NBTUtils.readFromNBT(this, nbt); } @Override public void readFromNBT(NBTTagCompound nbt) { NBTUtils.readFromNBT(this, nbt); }

View file

@ -5,6 +5,7 @@ import net.minecraft.block.material.Material;
import net.minecraft.block.state.IBlockState; import net.minecraft.block.state.IBlockState;
import net.minecraft.entity.Entity; import net.minecraft.entity.Entity;
import net.minecraft.entity.player.EntityPlayer; import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.init.Items;
import net.minecraft.item.Item; import net.minecraft.item.Item;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import net.minecraft.util.EnumBlockRenderType; import net.minecraft.util.EnumBlockRenderType;
@ -59,20 +60,21 @@ public abstract class BlockSpecialAir extends Block { // TODO: make water and pi
@Override @Override
@SuppressWarnings("deprecation") @SuppressWarnings("deprecation")
public AxisAlignedBB getCollisionBoundingBox(IBlockState blockState, IBlockAccess worldIn, BlockPos pos) { public AxisAlignedBB getCollisionBoundingBox(IBlockState blockState, IBlockAccess world, BlockPos pos) {
return null; return null;
} }
// Disable raytrace hitting this block unless the hitIfLiquid flag is true // Disable raytrace hitting this block in survival unless the hitIfLiquid flag is true
@Override @Override
public boolean canCollideCheck(IBlockState state, boolean hitIfLiquid) { public boolean canCollideCheck(IBlockState state, boolean hitIfLiquid) {
return hitIfLiquid; //EntityPlayer player = DimDoors.proxy.getLocalPlayer();
return /*player != null && player.isCreative() ||*/ hitIfLiquid; // TODO: re-enable this later
} }
// Disable dropping/picking item // Disable dropping/picking item
@Override @Override
public ItemStack getPickBlock(IBlockState state, RayTraceResult target, World world, BlockPos pos, EntityPlayer player) { public ItemStack getPickBlock(IBlockState state, RayTraceResult target, World world, BlockPos pos, EntityPlayer player) {
return null; return new ItemStack(Items.AIR);
} }
@Override @Override

View file

@ -2,8 +2,8 @@ package org.dimdev.dimdoors;
import org.dimdev.dimdoors.shared.commands.CommandPocket; import org.dimdev.dimdoors.shared.commands.CommandPocket;
import org.dimdev.dimdoors.shared.commands.CommandDimTeleport; import org.dimdev.dimdoors.shared.commands.CommandDimTeleport;
import org.dimdev.dimdoors.shared.DDConfig; import org.dimdev.dimdoors.shared.Config;
import org.dimdev.dimdoors.shared.DDProxyCommon; import org.dimdev.dimdoors.shared.CommonProxy;
import org.dimdev.dimdoors.shared.items.ModItems; import org.dimdev.dimdoors.shared.items.ModItems;
import org.dimdev.dimdoors.shared.world.gateways.GatewayGenerator; import org.dimdev.dimdoors.shared.world.gateways.GatewayGenerator;
import lombok.Getter; import lombok.Getter;
@ -21,7 +21,7 @@ import org.apache.logging.log4j.Logger;
@Mod(modid = DimDoors.MODID, name = "Dimensional Doors", @Mod(modid = DimDoors.MODID, name = "Dimensional Doors",
version = DimDoors.VERSION, version = DimDoors.VERSION,
dependencies = "required-after:forge@[14.23.0.2517,)") dependencies = "required-after:forge@[14.23.0.2517,)") // TODO
public class DimDoors { public class DimDoors {
public static final String MODID = "dimdoors"; public static final String MODID = "dimdoors";
@ -31,9 +31,9 @@ public class DimDoors {
public static DimDoors instance; public static DimDoors instance;
public static Logger log; // TODO: make non-static? public static Logger log; // TODO: make non-static?
@SidedProxy(clientSide = "org.dimdev.dimdoors.client.DDProxyClient", @SidedProxy(clientSide = "org.dimdev.dimdoors.client.ClientProxy",
serverSide = "org.dimdev.dimdoors.server.DDProxyServer") serverSide = "org.dimdev.dimdoors.server.ServerProxy")
public static DDProxyCommon proxy; public static CommonProxy proxy;
public static final CreativeTabs DIM_DOORS_CREATIVE_TAB = new CreativeTabs("dimensional_doors_creative_tab") { public static final CreativeTabs DIM_DOORS_CREATIVE_TAB = new CreativeTabs("dimensional_doors_creative_tab") {
@Override @Override
@ -49,7 +49,7 @@ public class DimDoors {
public void onPreInitialization(FMLPreInitializationEvent event) { public void onPreInitialization(FMLPreInitializationEvent event) {
log = event.getModLog(); log = event.getModLog();
proxy.onPreInitialization(event); proxy.onPreInitialization(event);
DDConfig.loadConfig(event); Config.loadConfig(event);
} }
@Mod.EventHandler @Mod.EventHandler

View file

@ -1,13 +1,12 @@
package org.dimdev.dimdoors.client; package org.dimdev.dimdoors.client;
import org.dimdev.dimdoors.shared.DDProxyCommon; import org.dimdev.dimdoors.shared.CommonProxy;
import org.dimdev.dimdoors.shared.entities.EntityMonolith; import org.dimdev.dimdoors.shared.entities.EntityMonolith;
import org.dimdev.dimdoors.shared.tileentities.TileEntityEntranceRift; import org.dimdev.dimdoors.shared.tileentities.TileEntityEntranceRift;
import org.dimdev.dimdoors.shared.tileentities.TileEntityFloatingRift; import org.dimdev.dimdoors.shared.tileentities.TileEntityFloatingRift;
import net.minecraft.client.Minecraft; import net.minecraft.client.Minecraft;
import net.minecraft.entity.player.EntityPlayer; import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.world.WorldProvider; import net.minecraft.world.WorldProvider;
import net.minecraft.world.WorldServer;
import net.minecraftforge.client.IRenderHandler; import net.minecraftforge.client.IRenderHandler;
import net.minecraftforge.fml.client.registry.ClientRegistry; import net.minecraftforge.fml.client.registry.ClientRegistry;
import net.minecraftforge.fml.client.registry.RenderingRegistry; import net.minecraftforge.fml.client.registry.RenderingRegistry;
@ -17,7 +16,7 @@ import net.minecraftforge.fml.relauncher.Side;
import net.minecraftforge.fml.relauncher.SideOnly; import net.minecraftforge.fml.relauncher.SideOnly;
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
public class DDProxyClient extends DDProxyCommon { public class ClientProxy extends CommonProxy {
@Override @Override
public void onPreInitialization(FMLPreInitializationEvent event) { public void onPreInitialization(FMLPreInitializationEvent event) {
@ -49,11 +48,6 @@ public class DDProxyClient extends DDProxyCommon {
return Minecraft.getMinecraft().player; return Minecraft.getMinecraft().player;
} }
@Override
public WorldServer getWorldServer(int dim) {
return Minecraft.getMinecraft().getIntegratedServer().getWorld(dim);
}
@Override @Override
public void setCloudRenderer(WorldProvider provider, IRenderHandler renderer) { public void setCloudRenderer(WorldProvider provider, IRenderHandler renderer) {
provider.setCloudRenderer(renderer); provider.setCloudRenderer(renderer);

View file

@ -1,9 +1,9 @@
package org.dimdev.dimdoors.client; package org.dimdev.dimdoors.client;
import net.minecraft.client.renderer.GlStateManager;
import org.dimdev.dimdoors.shared.entities.EntityMonolith; import org.dimdev.dimdoors.shared.entities.EntityMonolith;
import net.minecraftforge.fml.relauncher.Side; import net.minecraftforge.fml.relauncher.Side;
import net.minecraftforge.fml.relauncher.SideOnly; import net.minecraftforge.fml.relauncher.SideOnly;
import org.lwjgl.opengl.GL11;
import net.minecraft.client.model.ModelBase; import net.minecraft.client.model.ModelBase;
import net.minecraft.client.model.ModelRenderer; import net.minecraft.client.model.ModelRenderer;
@ -23,11 +23,11 @@ public class ModelMonolith extends ModelBase {
} }
@Override @Override
public void render(Entity entityIn, float limbSwing, float limbSwingAmount, float ageInTicks, float netHeadYaw, float headPitch, float scale) { public void render(Entity entity, float limbSwing, float limbSwingAmount, float ageInTicks, float netHeadYaw, float headPitch, float scale) {
EntityMonolith monolith = (EntityMonolith) entityIn; EntityMonolith monolith = (EntityMonolith) entity;
setRotationAngles(0, 0, 0, 0, 0, 0, monolith); setRotationAngles(0, 0, 0, 0, 0, 0, monolith);
GL11.glScalef(monolith.getRenderSizeModifier(), monolith.getRenderSizeModifier(), monolith.getRenderSizeModifier()); GlStateManager.scale(monolith.getRenderSizeModifier(), monolith.getRenderSizeModifier(), monolith.getRenderSizeModifier());
wholeMonolith.render(scale); wholeMonolith.render(scale);
} }
} }

View file

@ -26,7 +26,7 @@ public class ParticleRiftEffect extends ParticleSimpleAnimated { // TODO: colors
} }
@Override @Override
public void renderParticle(BufferBuilder buffer, Entity entityIn, float partialTicks, float rotationX, float rotationZ, float rotationYZ, float rotationXY, float rotationXZ) { public void renderParticle(BufferBuilder buffer, Entity entity, float partialTicks, float rotationX, float rotationZ, float rotationYZ, float rotationXY, float rotationXZ) {
if (particleAge < particleMaxAge / 3 || (particleAge + particleMaxAge) / 3 % 2 == 0) { if (particleAge < particleMaxAge / 3 || (particleAge + particleMaxAge) / 3 % 2 == 0) {
float oldRed = particleRed; float oldRed = particleRed;
float oldGreen = particleGreen; float oldGreen = particleGreen;
@ -34,7 +34,7 @@ public class ParticleRiftEffect extends ParticleSimpleAnimated { // TODO: colors
float oldAlpha = particleAlpha; float oldAlpha = particleAlpha;
setRBGColorF(colorMultiplier * particleRed, colorMultiplier * particleGreen, colorMultiplier * particleBlue); setRBGColorF(colorMultiplier * particleRed, colorMultiplier * particleGreen, colorMultiplier * particleBlue);
setAlphaF(0.7f); setAlphaF(0.7f);
super.renderParticle(buffer, entityIn, partialTicks, rotationX, rotationZ, rotationYZ, rotationXY, rotationXZ); super.renderParticle(buffer, entity, partialTicks, rotationX, rotationZ, rotationYZ, rotationXY, rotationXZ);
setRBGColorF(oldRed, oldGreen, oldBlue); setRBGColorF(oldRed, oldGreen, oldBlue);
setAlphaF(oldAlpha); setAlphaF(oldAlpha);
} }

View file

@ -1,5 +1,6 @@
package org.dimdev.dimdoors.client; package org.dimdev.dimdoors.client;
import net.minecraft.client.renderer.GlStateManager;
import org.dimdev.dimdoors.DimDoors; import org.dimdev.dimdoors.DimDoors;
import org.dimdev.dimdoors.shared.entities.EntityMonolith; import org.dimdev.dimdoors.shared.entities.EntityMonolith;
import net.minecraft.client.Minecraft; import net.minecraft.client.Minecraft;
@ -12,7 +13,6 @@ import net.minecraftforge.common.MinecraftForge;
import net.minecraftforge.fml.relauncher.Side; import net.minecraftforge.fml.relauncher.Side;
import net.minecraftforge.fml.relauncher.SideOnly; import net.minecraftforge.fml.relauncher.SideOnly;
import org.lwjgl.opengl.GL11; import org.lwjgl.opengl.GL11;
import org.lwjgl.opengl.GL12;
import java.util.Arrays; import java.util.Arrays;
import java.util.List; import java.util.List;
@ -74,11 +74,11 @@ public class RenderMonolith extends RenderLiving<EntityMonolith> {
public void render(EntityMonolith par1EntityLivingBase, double x, double y, double z, float par8, float par9) { public void render(EntityMonolith par1EntityLivingBase, double x, double y, double z, float par8, float par9) {
if (MinecraftForge.EVENT_BUS.post(new RenderLivingEvent.Pre<>(par1EntityLivingBase, this, 1, x, y, z))) return; if (MinecraftForge.EVENT_BUS.post(new RenderLivingEvent.Pre<>(par1EntityLivingBase, this, 1, x, y, z))) return;
GL11.glPushMatrix(); GlStateManager.pushMatrix();
GL11.glDisable(GL11.GL_CULL_FACE); GlStateManager.disableCull();
GL11.glDisable(GL11.GL_LIGHTING); GlStateManager.disableLighting();
GL11.glEnable(GL11.GL_BLEND); GlStateManager.enableBlend();
GL11.glBlendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE_MINUS_SRC_ALPHA); GlStateManager.blendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE_MINUS_SRC_ALPHA);
mainModel.swingProgress = getSwingProgress(par1EntityLivingBase, par9); mainModel.swingProgress = getSwingProgress(par1EntityLivingBase, par9);
try { try {
@ -92,32 +92,32 @@ public class RenderMonolith extends RenderLiving<EntityMonolith> {
applyRotations(par1EntityLivingBase, rotation, interpolatedYaw, par9); applyRotations(par1EntityLivingBase, rotation, interpolatedYaw, par9);
float f6 = 0.0625F; float f6 = 0.0625F;
GL11.glEnable(GL12.GL_RESCALE_NORMAL); GlStateManager.enableRescaleNormal();
GL11.glScalef(-1.0F, -1.0F, 1.0F); GlStateManager.scale(-1.0F, -1.0F, 1.0F);
preRenderCallback(par1EntityLivingBase, par9); preRenderCallback(par1EntityLivingBase, par9);
GL11.glRotatef(par1EntityLivingBase.pitchLevel, 1.0F, 0.0F, 0.0F); GlStateManager.rotate(par1EntityLivingBase.pitchLevel, 1.0F, 0.0F, 0.0F);
GL11.glTranslatef(0.0F, 24.0F * f6 - 0.0078125F, 0.0F); GlStateManager.translate(0.0F, 24.0F * f6 - 0.0078125F, 0.0F);
renderModel(par1EntityLivingBase, 0, 0, rotation, interpolatedYaw, pitch, f6); renderModel(par1EntityLivingBase, 0, 0, rotation, interpolatedYaw, pitch, f6);
OpenGlHelper.setActiveTexture(OpenGlHelper.lightmapTexUnit); OpenGlHelper.setActiveTexture(OpenGlHelper.lightmapTexUnit);
GL11.glDisable(GL11.GL_TEXTURE_2D); GlStateManager.disableTexture2D();
OpenGlHelper.setActiveTexture(OpenGlHelper.defaultTexUnit); OpenGlHelper.setActiveTexture(OpenGlHelper.defaultTexUnit);
GL11.glDisable(GL12.GL_RESCALE_NORMAL); GlStateManager.disableRescaleNormal();
} catch (Exception e) { } catch (Exception e) {
DimDoors.log.error(e); DimDoors.log.error(e);
} }
OpenGlHelper.setActiveTexture(OpenGlHelper.lightmapTexUnit); OpenGlHelper.setActiveTexture(OpenGlHelper.lightmapTexUnit);
GL11.glEnable(GL11.GL_TEXTURE_2D); GlStateManager.enableTexture2D();
OpenGlHelper.setActiveTexture(OpenGlHelper.defaultTexUnit); OpenGlHelper.setActiveTexture(OpenGlHelper.defaultTexUnit);
GL11.glEnable(GL11.GL_CULL_FACE); GlStateManager.enableCull();
GL11.glEnable(GL11.GL_LIGHTING); GlStateManager.enableLighting();
GL11.glDisable(GL11.GL_BLEND); GlStateManager.disableBlend();
GL11.glPopMatrix(); GlStateManager.popMatrix();
MinecraftForge.EVENT_BUS.post(new RenderLivingEvent.Post<>(par1EntityLivingBase, this, 1, x, y, z)); MinecraftForge.EVENT_BUS.post(new RenderLivingEvent.Post<>(par1EntityLivingBase, this, 1, x, y, z));
} }

View file

@ -19,8 +19,6 @@ import net.minecraft.client.Minecraft;
import net.minecraft.client.renderer.tileentity.TileEntitySpecialRenderer; import net.minecraft.client.renderer.tileentity.TileEntitySpecialRenderer;
import net.minecraft.util.ResourceLocation; import net.minecraft.util.ResourceLocation;
import static org.lwjgl.opengl.GL11.*;
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
public class TileEntityEntranceRiftRenderer extends TileEntitySpecialRenderer<TileEntityEntranceRift> { // TODO: see TileEntityEndGatewayRenderer public class TileEntityEntranceRiftRenderer extends TileEntitySpecialRenderer<TileEntityEntranceRift> { // TODO: see TileEntityEndGatewayRenderer
@ -32,7 +30,7 @@ public class TileEntityEntranceRiftRenderer extends TileEntitySpecialRenderer<Ti
// TODO: allow any angle, make static and in a separate class // TODO: allow any angle, make static and in a separate class
public void renderDimensionalWall(double x, double y, double z, RGBA[] colors, EnumFacing orientation, double extendUp, double extendDown, double extendLeft, double extendRight, double pushIn) { public void renderDimensionalWall(double x, double y, double z, RGBA[] colors, EnumFacing orientation, double extendUp, double extendDown, double extendLeft, double extendRight, double pushIn) {
GL11.glDisable(GL11.GL_LIGHTING); GlStateManager.disableLighting();
for (int pass = 0; pass < 16; pass++) { for (int pass = 0; pass < 16; pass++) {
GlStateManager.pushMatrix(); GlStateManager.pushMatrix();
@ -212,36 +210,36 @@ public class TileEntityEntranceRiftRenderer extends TileEntitySpecialRenderer<Ti
//z = ActiveRenderInfo.getPosition().zCoord; //z = ActiveRenderInfo.getPosition().zCoord;
GlStateManager.rotate(180.0F - 90 * rotation.getHorizontalIndex(), 0.0F, 1.0F, 0.0F); GlStateManager.rotate(180.0F - 90 * rotation.getHorizontalIndex(), 0.0F, 1.0F, 0.0F);
//GL11.glRotatef((float)(-90 * rotation), 0.0F, 0.0F, 1.0F); // GlStateManager.rotate((float)(-90 * rotation), 0.0F, 0.0F, 1.0F);
GlStateManager.translate(0.007F, .25F, 0F); GlStateManager.translate(0.007F, .25F, 0F);
switch (rotation) { switch (rotation) {
case SOUTH: case SOUTH:
GL11.glTranslatef(0.5F, 0F, -0.03F); GlStateManager.translate(0.5F, 0F, -0.03F);
break; break;
case WEST: case WEST:
GL11.glTranslatef(-0.5F, 0, -0.03F); GlStateManager.translate(-0.5F, 0, -0.03F);
break; break;
case NORTH: case NORTH:
GL11.glTranslatef(-.5F, 0F, .97F); GlStateManager.translate(-.5F, 0F, .97F);
break; break;
case EAST: case EAST:
GL11.glTranslatef(.5F, 0F, .97F); GlStateManager.translate(.5F, 0F, .97F);
break; break;
} }
GL11.glDisable(GL_LIGHTING); GlStateManager.disableLighting();
GL11.glEnable(GL11.GL_BLEND); GlStateManager.enableBlend();
if (i == 1) { if (i == 1) {
bindTexture(keyholeLight); bindTexture(keyholeLight);
GlStateManager.color(1, 1, 1, .7f); GlStateManager.color(1, 1, 1, .7f);
GlStateManager.blendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_DST_COLOR); GlStateManager.blendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE_MINUS_DST_COLOR);
} else { } else {
bindTexture(keyPath); bindTexture(keyPath);
GlStateManager.blendFunc(GL_ONE_MINUS_SRC_ALPHA, GL_SRC_ALPHA); GlStateManager.blendFunc(GL11.GL_ONE_MINUS_SRC_ALPHA, GL11.GL_SRC_ALPHA);
} }
GlStateManager.rotate(180.0F, 0.0F, 1.0F, 0.0F); GlStateManager.rotate(180.0F, 0.0F, 1.0F, 0.0F);

View file

@ -202,7 +202,6 @@ public class TileEntityFloatingRiftRenderer extends TileEntitySpecialRenderer<Ti
private void project(BufferBuilder buffer, Vector4f vector, int u, int v, RGBA color) { private void project(BufferBuilder buffer, Vector4f vector, int u, int v, RGBA color) {
double scalar = 1d/(vector.getW()+1d); double scalar = 1d/(vector.getW()+1d);
Vector3f center = Vector3f.from(0.5f);
Vector3f vector1 = vector.toVector3().mul(scalar); Vector3f vector1 = vector.toVector3().mul(scalar);
buffer.pos(vector1.getX(), vector1.getY(), vector1.getZ()).tex(u,v).color(color.getRed(), color.getGreen(), color.getBlue(), color.getAlpha()).endVertex(); buffer.pos(vector1.getX(), vector1.getY(), vector1.getZ()).tex(u,v).color(color.getRed(), color.getGreen(), color.getBlue(), color.getAlpha()).endVertex();

View file

@ -1,16 +1,14 @@
package org.dimdev.dimdoors.server; package org.dimdev.dimdoors.server;
import org.dimdev.dimdoors.shared.DDProxyCommon; import org.dimdev.dimdoors.shared.CommonProxy;
import net.minecraft.entity.player.EntityPlayer; import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.world.WorldProvider; import net.minecraft.world.WorldProvider;
import net.minecraft.world.WorldServer;
import net.minecraftforge.client.IRenderHandler; import net.minecraftforge.client.IRenderHandler;
import net.minecraftforge.common.DimensionManager;
/** /**
* @author Robijnvogel * @author Robijnvogel
*/ */
public class DDProxyServer extends DDProxyCommon { public class ServerProxy extends CommonProxy {
@Override @Override
public boolean isClient() { public boolean isClient() {
@ -22,11 +20,6 @@ public class DDProxyServer extends DDProxyCommon {
return null; return null;
} }
@Override
public WorldServer getWorldServer(int dim) {
return DimensionManager.getWorld(0).getMinecraftServer().getWorld(dim);
}
@Override @Override
public void setCloudRenderer(WorldProvider provider, IRenderHandler renderer) {} public void setCloudRenderer(WorldProvider provider, IRenderHandler renderer) {}

View file

@ -1,5 +1,8 @@
package org.dimdev.dimdoors.shared; package org.dimdev.dimdoors.shared;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.world.WorldProvider;
import net.minecraftforge.client.IRenderHandler;
import org.dimdev.dimdoors.DimDoors; import org.dimdev.dimdoors.DimDoors;
import org.dimdev.dimdoors.shared.blocks.ModBlocks; import org.dimdev.dimdoors.shared.blocks.ModBlocks;
import org.dimdev.dimdoors.shared.entities.EntityMonolith; import org.dimdev.dimdoors.shared.entities.EntityMonolith;
@ -16,9 +19,8 @@ import net.minecraftforge.fml.common.event.FMLPreInitializationEvent;
import net.minecraftforge.fml.common.registry.EntityRegistry; import net.minecraftforge.fml.common.registry.EntityRegistry;
import net.minecraftforge.fml.common.registry.GameRegistry; import net.minecraftforge.fml.common.registry.GameRegistry;
public abstract class DDProxyCommon implements IDDProxy { public abstract class CommonProxy {
@Override
public void onPreInitialization(FMLPreInitializationEvent event) { public void onPreInitialization(FMLPreInitializationEvent event) {
MinecraftForge.EVENT_BUS.register(EventHandler.class); MinecraftForge.EVENT_BUS.register(EventHandler.class);
MinecraftForge.EVENT_BUS.register(ModBlocks.class); MinecraftForge.EVENT_BUS.register(ModBlocks.class);
@ -49,7 +51,6 @@ public abstract class DDProxyCommon implements IDDProxy {
RiftDestination.destinationRegistry.put("relative", RelativeDestination.class); RiftDestination.destinationRegistry.put("relative", RelativeDestination.class);
} }
@Override
public void onInitialization(FMLInitializationEvent event) { public void onInitialization(FMLInitializationEvent event) {
SchematicHandler.INSTANCE.loadSchematics(); SchematicHandler.INSTANCE.loadSchematics();
} }
@ -58,4 +59,12 @@ public abstract class DDProxyCommon implements IDDProxy {
GameRegistry.registerTileEntity(TileEntityEntranceRift.class, "TileEntityEntranceRift"); GameRegistry.registerTileEntity(TileEntityEntranceRift.class, "TileEntityEntranceRift");
GameRegistry.registerTileEntity(TileEntityFloatingRift.class, "TileEntityFloatingRift"); GameRegistry.registerTileEntity(TileEntityFloatingRift.class, "TileEntityFloatingRift");
} }
public abstract boolean isClient();
public abstract EntityPlayer getLocalPlayer();
public abstract void setCloudRenderer(WorldProvider provider, IRenderHandler renderer);
public abstract void setSkyRenderer(WorldProvider provider, IRenderHandler renderer);
} }

View file

@ -13,7 +13,7 @@ import scala.actors.threadpool.Arrays;
/** /**
* @author Robijnvogel * @author Robijnvogel
*/ */
public final class DDConfig { public final class Config {
public static File configurationFolder; public static File configurationFolder;
@Getter private static int pocketGridSize = 32; @Getter private static int pocketGridSize = 32;

View file

@ -1,29 +0,0 @@
package org.dimdev.dimdoors.shared;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.world.WorldProvider;
import net.minecraft.world.WorldServer;
import net.minecraftforge.client.IRenderHandler;
import net.minecraftforge.fml.common.event.FMLInitializationEvent;
import net.minecraftforge.fml.common.event.FMLPreInitializationEvent;
/**
*
* @author Robijnvogel
*/
public interface IDDProxy {
public boolean isClient();
public void onPreInitialization(FMLPreInitializationEvent event);
public void onInitialization(FMLInitializationEvent event);
public EntityPlayer getLocalPlayer();
public WorldServer getWorldServer(int dim);
public void setCloudRenderer(WorldProvider provider, IRenderHandler renderer);
public void setSkyRenderer(WorldProvider provider, IRenderHandler renderer);
}

View file

@ -53,12 +53,12 @@ public class SchematicHandler { // TODO: make this more general (not dimdoors-re
} }
// Load config jsons // Load config jsons
File jsonFolder = new File(DDConfig.configurationFolder, "/jsons"); File jsonFolder = new File(Config.configurationFolder, "/jsons");
if (!jsonFolder.exists()) { if (!jsonFolder.exists()) {
jsonFolder.mkdirs(); jsonFolder.mkdirs();
} }
// Init schematics config folder // Init schematics config folder
File schematicFolder = new File(DDConfig.configurationFolder, "/schematics"); File schematicFolder = new File(Config.configurationFolder, "/schematics");
if (!schematicFolder.exists()) { if (!schematicFolder.exists()) {
schematicFolder.mkdirs(); schematicFolder.mkdirs();
} }
@ -78,7 +78,7 @@ public class SchematicHandler { // TODO: make this more general (not dimdoors-re
private static List<PocketTemplate> loadTemplatesFromJson(String jsonString) { private static List<PocketTemplate> loadTemplatesFromJson(String jsonString) {
String schematicJarDirectory = "/assets/dimdoors/pockets/schematic/"; String schematicJarDirectory = "/assets/dimdoors/pockets/schematic/";
File schematicFolder = new File(DDConfig.configurationFolder, "/schematics"); File schematicFolder = new File(Config.configurationFolder, "/schematics");
JsonParser parser = new JsonParser(); JsonParser parser = new JsonParser();
JsonElement jsonElement = parser.parse(jsonString); JsonElement jsonElement = parser.parse(jsonString);
@ -285,16 +285,16 @@ public class SchematicHandler { // TODO: make this more general (not dimdoors-re
} }
public PocketTemplate getPersonalPocketTemplate() { public PocketTemplate getPersonalPocketTemplate() {
return getRandomTemplate("private", -1, DDConfig.getMaxPocketSize(), true); // TODO: config option for getLargest return getRandomTemplate("private", -1, Config.getMaxPocketSize(), true); // TODO: config option for getLargest
} }
public PocketTemplate getPublicPocketTemplate() { public PocketTemplate getPublicPocketTemplate() {
return getRandomTemplate("public", -1, DDConfig.getMaxPocketSize(), true); // TODO: config option for getLargest return getRandomTemplate("public", -1, Config.getMaxPocketSize(), true); // TODO: config option for getLargest
} }
public void saveSchematic(Schematic schematic, String name) { public void saveSchematic(Schematic schematic, String name) {
NBTTagCompound schematicNBT = Schematic.saveToNBT(schematic); NBTTagCompound schematicNBT = Schematic.saveToNBT(schematic);
File saveFolder = new File(DDConfig.configurationFolder, "/Schematics/Saved"); File saveFolder = new File(Config.configurationFolder, "/Schematics/Saved");
if (!saveFolder.exists()) { if (!saveFolder.exists()) {
saveFolder.mkdirs(); saveFolder.mkdirs();
} }

View file

@ -43,7 +43,7 @@ public class VirtualLocation {
virtualLocation = new VirtualLocation(0, 0, 0, 0, 0); // TODO: door was placed in a pocket dim but outside of a pocket... virtualLocation = new VirtualLocation(0, 0, 0, 0, 0); // TODO: door was placed in a pocket dim but outside of a pocket...
} }
} else if (location.getWorld().provider instanceof WorldProviderLimbo) { } else if (location.getWorld().provider instanceof WorldProviderLimbo) {
virtualLocation = new VirtualLocation(location, DDConfig.getMaxDungeonDepth()); virtualLocation = new VirtualLocation(location, Config.getMaxDungeonDepth());
} }
if (virtualLocation == null) { if (virtualLocation == null) {
virtualLocation = new VirtualLocation(location, 0); virtualLocation = new VirtualLocation(location, 0);
@ -55,8 +55,8 @@ public class VirtualLocation {
public VirtualLocation transformDepth(int depth) { // TODO: Config option for block ratio between depths (see video of removed features) public VirtualLocation transformDepth(int depth) { // TODO: Config option for block ratio between depths (see video of removed features)
Random random = new Random(); Random random = new Random();
int depthDiff = Math.abs(this.depth - depth); int depthDiff = Math.abs(this.depth - depth);
int base = DDConfig.getOwCoordinateOffsetBase(); int base = Config.getOwCoordinateOffsetBase();
double power = DDConfig.getOwCoordinateOffsetPower(); double power = Config.getOwCoordinateOffsetPower();
int xOffset = random.nextInt((int) Math.pow(base * (depthDiff + 1), power)) * (random.nextBoolean() ? 1 : -1); int xOffset = random.nextInt((int) Math.pow(base * (depthDiff + 1), power)) * (random.nextBoolean() ? 1 : -1);
int zOffset = random.nextInt((int) Math.pow(base * (depthDiff + 1), power)) * (random.nextBoolean() ? 1 : -1); int zOffset = random.nextInt((int) Math.pow(base * (depthDiff + 1), power)) * (random.nextBoolean() ? 1 : -1);
return new VirtualLocation(getDim(), getPos().offset(EnumFacing.EAST, xOffset).offset(EnumFacing.SOUTH, zOffset), depth); return new VirtualLocation(getDim(), getPos().offset(EnumFacing.EAST, xOffset).offset(EnumFacing.SOUTH, zOffset), depth);

View file

@ -6,7 +6,6 @@ import net.minecraft.block.state.BlockFaceShape;
import org.dimdev.dimdoors.shared.rifts.RiftRegistry; import org.dimdev.dimdoors.shared.rifts.RiftRegistry;
import org.dimdev.dimdoors.shared.tileentities.TileEntityEntranceRift; import org.dimdev.dimdoors.shared.tileentities.TileEntityEntranceRift;
import org.dimdev.dimdoors.shared.tileentities.TileEntityFloatingRift; import org.dimdev.dimdoors.shared.tileentities.TileEntityFloatingRift;
import org.dimdev.dimdoors.shared.rifts.TileEntityRift;
import net.minecraft.block.Block; import net.minecraft.block.Block;
import net.minecraft.block.BlockDoor; import net.minecraft.block.BlockDoor;
import net.minecraft.block.material.Material; import net.minecraft.block.material.Material;
@ -47,19 +46,19 @@ public abstract class BlockDimensionalDoor extends BlockDoor implements IRiftPro
} }
@Override @Override
public boolean onBlockActivated(World worldIn, BlockPos pos, IBlockState state, EntityPlayer playerIn, EnumHand hand, EnumFacing facing, float hitX, float hitY, float hitZ) { public boolean onBlockActivated(World world, BlockPos pos, IBlockState state, EntityPlayer player, EnumHand hand, EnumFacing facing, float hitX, float hitY, float hitZ) {
if (!canOpen(worldIn, pos, playerIn)) return false; if (!canOpen(world, pos, player)) return false;
BlockPos blockpos = state.getValue(HALF) == BlockDoor.EnumDoorHalf.LOWER ? pos : pos.down(); BlockPos blockpos = state.getValue(HALF) == BlockDoor.EnumDoorHalf.LOWER ? pos : pos.down();
IBlockState iblockstate = pos.equals(blockpos) ? state : worldIn.getBlockState(blockpos); IBlockState iblockstate = pos.equals(blockpos) ? state : world.getBlockState(blockpos);
if (iblockstate.getBlock() != this) { if (iblockstate.getBlock() != this) {
return false; return false;
} else { } else {
state = iblockstate.cycleProperty(OPEN); state = iblockstate.cycleProperty(OPEN);
worldIn.setBlockState(blockpos, state, 10); world.setBlockState(blockpos, state, 10);
worldIn.markBlockRangeForRenderUpdate(blockpos, pos); world.markBlockRangeForRenderUpdate(blockpos, pos);
worldIn.playEvent(playerIn, state.getValue(OPEN) ? getOpenSound() : getCloseSound(), pos, 0); world.playEvent(player, state.getValue(OPEN) ? getOpenSound() : getCloseSound(), pos, 0);
return true; return true;
} }
} }
@ -73,9 +72,9 @@ public abstract class BlockDimensionalDoor extends BlockDoor implements IRiftPro
} }
@Override @Override
public void neighborChanged(IBlockState state, World worldIn, BlockPos pos, Block blockIn, BlockPos fromPos) { public void neighborChanged(IBlockState state, World world, BlockPos pos, Block block, BlockPos fromPos) {
if (canOpen(worldIn, pos, null)) { if (canOpen(world, pos, null)) {
super.neighborChanged(state, worldIn, pos, blockIn, fromPos); super.neighborChanged(state, world, pos, block, fromPos);
} }
} }
@ -101,7 +100,7 @@ public abstract class BlockDimensionalDoor extends BlockDoor implements IRiftPro
&& world.getBlockState(pos).getBlock().isReplaceable(world, pos.up()); && world.getBlockState(pos).getBlock().isReplaceable(world, pos.up());
} }
} else { } else {
return super.canPlaceBlockAt(world, pos.down()); return super.canPlaceBlockAt(world, pos);
} }
} }
@ -111,12 +110,12 @@ public abstract class BlockDimensionalDoor extends BlockDoor implements IRiftPro
} }
@Override @Override
public ItemStack getItem(World worldIn, BlockPos pos, IBlockState state) { // TODO: use BLOCK_ITEM map public ItemStack getItem(World world, BlockPos pos, IBlockState state) { // TODO: use BLOCK_ITEM map
return new ItemStack(getItem()); return new ItemStack(getItem());
} }
@Override @Override
public TileEntityEntranceRift createNewTileEntity(World worldIn, int meta) { public TileEntityEntranceRift createNewTileEntity(World world, int meta) {
TileEntityEntranceRift rift = new TileEntityEntranceRift(); TileEntityEntranceRift rift = new TileEntityEntranceRift();
rift.orientation = getStateFromMeta(meta).getValue(BlockDoor.FACING).getOpposite(); rift.orientation = getStateFromMeta(meta).getValue(BlockDoor.FACING).getOpposite();
rift.extendUp += 1; rift.extendUp += 1;
@ -124,14 +123,14 @@ public abstract class BlockDimensionalDoor extends BlockDoor implements IRiftPro
} }
@Override @Override
public void breakBlock(World worldIn, BlockPos pos, IBlockState state) { public void breakBlock(World world, BlockPos pos, IBlockState state) {
if (!hasTileEntity(state)) return; if (!hasTileEntity(state)) return;
TileEntityEntranceRift rift = getRift(worldIn, pos, state); TileEntityEntranceRift rift = getRift(world, pos, state);
super.breakBlock(worldIn, pos, state); super.breakBlock(world, pos, state);
if (worldIn.isRemote) return; if (world.isRemote) return;
if (rift.isPlaceRiftOnBreak() || rift.isRegistered() && RiftRegistry.getRiftInfo(rift.getLocation()).getSources().size() > 0 && !rift.isAlwaysDelete()) { if (rift.isPlaceRiftOnBreak() || rift.isRegistered() && RiftRegistry.getRiftInfo(rift.getLocation()).getSources().size() > 0 && !rift.isAlwaysDelete()) {
worldIn.setBlockState(pos, ModBlocks.RIFT.getDefaultState()); world.setBlockState(pos, ModBlocks.RIFT.getDefaultState());
TileEntityFloatingRift newRift = (TileEntityFloatingRift) worldIn.getTileEntity(pos); TileEntityFloatingRift newRift = (TileEntityFloatingRift) world.getTileEntity(pos);
newRift.copyFrom(rift); newRift.copyFrom(rift);
newRift.updateAvailableLinks(); newRift.updateAvailableLinks();
} else { } else {

View file

@ -35,19 +35,19 @@ public abstract class BlockDimensionalTrapdoor extends BlockTrapDoor implements
} }
@Override @Override
public boolean onBlockActivated(World worldIn, BlockPos pos, IBlockState state, EntityPlayer playerIn, EnumHand hand, EnumFacing facing, float hitX, float hitY, float hitZ) { public boolean onBlockActivated(World world, BlockPos pos, IBlockState state, EntityPlayer player, EnumHand hand, EnumFacing facing, float hitX, float hitY, float hitZ) {
if (!canOpen(worldIn, pos, playerIn)) return false; if (!canOpen(world, pos, player)) return false;
state = state.cycleProperty(OPEN); state = state.cycleProperty(OPEN);
worldIn.setBlockState(pos, state, 2); world.setBlockState(pos, state, 2);
playSound(playerIn, worldIn, pos, state.getValue(OPEN)); playSound(player, world, pos, state.getValue(OPEN));
return true; return true;
} }
@Override @Override
public void neighborChanged(IBlockState state, World worldIn, BlockPos pos, Block blockIn, BlockPos fromPos) { public void neighborChanged(IBlockState state, World world, BlockPos pos, Block block, BlockPos fromPos) {
if (canOpen(worldIn, pos, null)) { if (canOpen(world, pos, null)) {
super.neighborChanged(state, worldIn, pos, blockIn, fromPos); super.neighborChanged(state, world, pos, block, fromPos);
} }
} }
@ -56,7 +56,7 @@ public abstract class BlockDimensionalTrapdoor extends BlockTrapDoor implements
} }
@Override @Override
public TileEntityEntranceRift createNewTileEntity(World worldIn, int meta) { public TileEntityEntranceRift createNewTileEntity(World world, int meta) {
TileEntityEntranceRift rift = new TileEntityEntranceRift(); TileEntityEntranceRift rift = new TileEntityEntranceRift();
rift.orientation = EnumFacing.UP; rift.orientation = EnumFacing.UP;
return rift; return rift;

View file

@ -33,7 +33,7 @@ public class BlockDoorGold extends BlockDoor {
} }
@Override @Override
public ItemStack getItem(World worldIn, BlockPos pos, IBlockState state) { public ItemStack getItem(World world, BlockPos pos, IBlockState state) {
return new ItemStack(ModItems.GOLD_DOOR); return new ItemStack(ModItems.GOLD_DOOR);
} }
} }

View file

@ -33,7 +33,7 @@ public class BlockDoorQuartz extends BlockDoor {
} }
@Override @Override
public ItemStack getItem(World worldIn, BlockPos pos, IBlockState state) { public ItemStack getItem(World world, BlockPos pos, IBlockState state) {
return new ItemStack(ModItems.QUARTZ_DOOR); return new ItemStack(ModItems.QUARTZ_DOOR);
} }
} }

View file

@ -131,7 +131,7 @@ public class BlockFabric extends Block {
@Override @Override
@SuppressWarnings("deprecation") @SuppressWarnings("deprecation")
public MapColor getMapColor(IBlockState state, IBlockAccess worldIn, BlockPos pos) { public MapColor getMapColor(IBlockState state, IBlockAccess world, BlockPos pos) {
switch (state.getValue(TYPE)) { switch (state.getValue(TYPE)) {
case REALITY: case REALITY:
case ANCIENT: case ANCIENT:
@ -174,21 +174,21 @@ public class BlockFabric extends Block {
} }
@Override @Override
public void onEntityWalk(World world, BlockPos pos, Entity entityIn) { public void onEntityWalk(World world, BlockPos pos, Entity entity) {
IBlockState state = world.getBlockState(pos); IBlockState state = world.getBlockState(pos);
if (state.getValue(TYPE) == EnumType.ETERNAL && world.provider instanceof WorldProviderLimbo && entityIn instanceof EntityPlayer) { if (state.getValue(TYPE) == EnumType.ETERNAL && world.provider instanceof WorldProviderLimbo && entity instanceof EntityPlayer) {
Location loc = VirtualLocation.fromLocation(new Location(world, pos)).projectToWorld(); Location loc = VirtualLocation.fromLocation(new Location(world, pos)).projectToWorld();
BlockPos correctedPos = loc.getWorld().getTopSolidOrLiquidBlock(loc.getPos()); BlockPos correctedPos = loc.getWorld().getTopSolidOrLiquidBlock(loc.getPos());
Random random = new Random(); Random random = new Random();
TeleportUtils.teleport(entityIn, new Location(loc.getDim(), correctedPos), random.nextFloat() * 360, random.nextFloat() * 360); TeleportUtils.teleport(entity, new Location(loc.getDim(), correctedPos), random.nextFloat() * 360, random.nextFloat() * 360);
} }
} }
@Override @Override
public void updateTick(World worldIn, BlockPos pos, IBlockState state, Random rand) { public void updateTick(World world, BlockPos pos, IBlockState state, Random rand) {
// Spread unravelled fabric decay in Limbo // Spread unravelled fabric decay in Limbo
if (state.getValue(TYPE) == EnumType.UNRAVELED && worldIn.provider instanceof WorldProviderLimbo) { if (state.getValue(TYPE) == EnumType.UNRAVELED && world.provider instanceof WorldProviderLimbo) {
LimboDecay.applySpreadDecay(worldIn, pos); LimboDecay.applySpreadDecay(world, pos);
} }
} }
} }

View file

@ -37,22 +37,22 @@ public class BlockFloatingRift extends BlockSpecialAir implements ITileEntityPro
} }
@Override @Override
public TileEntityFloatingRift createNewTileEntity(World worldIn, int meta) { public TileEntityFloatingRift createNewTileEntity(World world, int meta) {
return new TileEntityFloatingRift(); return new TileEntityFloatingRift();
} }
@Override @Override
@SuppressWarnings("deprecation") @SuppressWarnings("deprecation")
public MapColor getMapColor(IBlockState state, IBlockAccess worldIn, BlockPos pos) { public MapColor getMapColor(IBlockState state, IBlockAccess world, BlockPos pos) {
return MapColor.BLUE; return MapColor.BLUE;
} }
// Unregister the rift on break // Unregister the rift on break
@Override @Override
public void breakBlock(World worldIn, BlockPos pos, IBlockState state) { public void breakBlock(World world, BlockPos pos, IBlockState state) {
TileEntityFloatingRift rift = (TileEntityFloatingRift) worldIn.getTileEntity(pos); TileEntityFloatingRift rift = (TileEntityFloatingRift) world.getTileEntity(pos);
rift.unregister(); rift.unregister();
super.breakBlock(worldIn, pos, state); super.breakBlock(world, pos, state);
} }
@Override @Override
@ -77,20 +77,20 @@ public class BlockFloatingRift extends BlockSpecialAir implements ITileEntityPro
// Render rift effects // Render rift effects
@Override @Override
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
public void randomDisplayTick(IBlockState stateIn, World worldIn, BlockPos pos, Random rand) { // TODO public void randomDisplayTick(IBlockState state, World world, BlockPos pos, Random rand) { // TODO
//ArrayList<BlockPos> targets = findReachableBlocks(worldIn, pos, 2, false); //ArrayList<BlockPos> targets = findReachableBlocks(world, pos, 2, false);
TileEntityFloatingRift rift = (TileEntityFloatingRift) worldIn.getTileEntity(pos); TileEntityFloatingRift rift = (TileEntityFloatingRift) world.getTileEntity(pos);
if (0 > 0) { if (0 > 0) {
FMLClientHandler.instance().getClient().effectRenderer.addEffect(new ParticleRiftEffect.GogglesRiftEffect( FMLClientHandler.instance().getClient().effectRenderer.addEffect(new ParticleRiftEffect.GogglesRiftEffect(
worldIn, world,
pos.getX() + .5, pos.getY() + .5, pos.getZ() + .5, pos.getX() + .5, pos.getY() + .5, pos.getZ() + .5,
rand.nextGaussian() * 0.01D, rand.nextGaussian() * 0.01D, rand.nextGaussian() * 0.01D)); rand.nextGaussian() * 0.01D, rand.nextGaussian() * 0.01D, rand.nextGaussian() * 0.01D));
} }
if (rift.shouldClose) { // Renders an opposite color effect if it is being closed by the rift remover if (rift.shouldClose) { // Renders an opposite color effect if it is being closed by the rift remover
FMLClientHandler.instance().getClient().effectRenderer.addEffect(new ParticleRiftEffect.ClosingRiftEffect( FMLClientHandler.instance().getClient().effectRenderer.addEffect(new ParticleRiftEffect.ClosingRiftEffect(
worldIn, world,
pos.getX() + .5, pos.getY() + .5, pos.getZ() + .5, pos.getX() + .5, pos.getY() + .5, pos.getZ() + .5,
rand.nextGaussian() * 0.01D, rand.nextGaussian() * 0.01D, rand.nextGaussian() * 0.01D)); rand.nextGaussian() * 0.01D, rand.nextGaussian() * 0.01D, rand.nextGaussian() * 0.01D));
} }

View file

@ -1,7 +1,7 @@
package org.dimdev.dimdoors.shared.entities; package org.dimdev.dimdoors.shared.entities;
import org.dimdev.dimdoors.shared.sound.ModSounds; import org.dimdev.dimdoors.shared.sound.ModSounds;
import org.dimdev.dimdoors.shared.DDConfig; import org.dimdev.dimdoors.shared.Config;
import org.dimdev.ddutils.Location; import org.dimdev.ddutils.Location;
import org.dimdev.ddutils.TeleportUtils; import org.dimdev.ddutils.TeleportUtils;
import org.dimdev.dimdoors.shared.world.limbodimension.WorldProviderLimbo; import org.dimdev.dimdoors.shared.world.limbodimension.WorldProviderLimbo;
@ -54,7 +54,7 @@ public class EntityMonolith extends EntityFlying implements IMob {
} }
public boolean isDangerous() { public boolean isDangerous() {
return DDConfig.isMonolithTeleportationEnabled() && (world.provider instanceof WorldProviderLimbo || DDConfig.isDangerousLimboMonolithsEnabled()); return Config.isMonolithTeleportationEnabled() && (world.provider instanceof WorldProviderLimbo || Config.isDangerousLimboMonolithsEnabled());
} }
@Override @Override
@ -148,7 +148,7 @@ public class EntityMonolith extends EntityFlying implements IMob {
} }
// Teleport the target player if various conditions are met // Teleport the target player if various conditions are met
if (aggro >= MAX_AGGRO && !world.isRemote && DDConfig.isMonolithTeleportationEnabled() && !player.capabilities.isCreativeMode && isDangerous()) { if (aggro >= MAX_AGGRO && !world.isRemote && Config.isMonolithTeleportationEnabled() && !player.isCreative() && isDangerous()) {
aggro = 0; aggro = 0;
Location destination = WorldProviderLimbo.getLimboSkySpawn(player); Location destination = WorldProviderLimbo.getLimboSkySpawn(player);
TeleportUtils.teleport(player, destination, 0, 0); TeleportUtils.teleport(player, destination, 0, 0);
@ -214,7 +214,7 @@ public class EntityMonolith extends EntityFlying implements IMob {
playSound(ModSounds.MONK, 1F, 1F); playSound(ModSounds.MONK, 1F, 1F);
soundTime = 100; soundTime = 100;
} }
if (aggroPercent > 0.70 && soundTime < 100) { if (aggroPercent > 0.70 && soundTime < 100) { // TODO: null rather than player?
world.playSound(player, player.getPosition(), ModSounds.TEARING, SoundCategory.HOSTILE, 1F, (float) (1 + rand.nextGaussian())); world.playSound(player, player.getPosition(), ModSounds.TEARING, SoundCategory.HOSTILE, 1F, (float) (1 + rand.nextGaussian()));
soundTime = 100 + rand.nextInt(75); soundTime = 100 + rand.nextInt(75);
} }
@ -277,7 +277,5 @@ public class EntityMonolith extends EntityFlying implements IMob {
} }
return true; return true;
// TODO: this would throw a null pointer exception if enabled (the bounding box is null)
//return world.checkNoEntityCollision(getCollisionBoundingBox()) && world.getCollisionBoxes(this, getEntityBoundingBox()).isEmpty() && !world.containsAnyLiquid(getCollisionBoundingBox());
} }
} }

View file

@ -25,7 +25,7 @@ public class ItemDimensionalDoorGold extends ItemDoor {
@Override @Override
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
public void addInformation(ItemStack stack, World worldIn, List<String> tooltip, ITooltipFlag flagIn) { public void addInformation(ItemStack stack, World world, List<String> tooltip, ITooltipFlag flagIn) {
I18nUtils.translateAndAdd("info.gold_dimensional_door", tooltip); tooltip.addAll(I18nUtils.translateMultiline("info.gold_dimensional_door"));
} }
} }

View file

@ -24,7 +24,7 @@ public class ItemDimensionalDoorIron extends ItemDimensionalDoor {
@Override @Override
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
public void addInformation(ItemStack stack, World worldIn, List<String> tooltip, ITooltipFlag flagIn) { public void addInformation(ItemStack stack, World world, List<String> tooltip, ITooltipFlag flagIn) {
I18nUtils.translateAndAdd("info.dimensional_door", tooltip); tooltip.addAll(I18nUtils.translateMultiline("info.dimensional_door"));
} }
} }

View file

@ -24,7 +24,7 @@ public class ItemDimensionalDoorPersonal extends ItemDimensionalDoor {
@Override @Override
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
public void addInformation(ItemStack stack, World worldIn, List<String> tooltip, ITooltipFlag flagIn) { public void addInformation(ItemStack stack, World world, List<String> tooltip, ITooltipFlag flagIn) {
I18nUtils.translateAndAdd("info.quartz_dimensional_door", tooltip); tooltip.addAll(I18nUtils.translateMultiline("info.quartz_dimensional_door"));
} }
} }

View file

@ -24,7 +24,7 @@ public class ItemDimensionalDoorUnstable extends ItemDimensionalDoor {
@Override @Override
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
public void addInformation(ItemStack stack, World worldIn, List<String> tooltip, ITooltipFlag flagIn) { public void addInformation(ItemStack stack, World world, List<String> tooltip, ITooltipFlag flagIn) {
I18nUtils.translateAndAdd("info.unstable_dimensional_door", tooltip); tooltip.addAll(I18nUtils.translateMultiline("info.unstable_dimensional_door"));
} }
} }

View file

@ -24,7 +24,7 @@ public class ItemDimensionalDoorWarp extends ItemDimensionalDoor {
@Override @Override
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
public void addInformation(ItemStack stack, World worldIn, List<String> tooltip, ITooltipFlag flagIn) { public void addInformation(ItemStack stack, World world, List<String> tooltip, ITooltipFlag flagIn) {
I18nUtils.translateAndAdd("info.warp_dimensional_door", tooltip); tooltip.addAll(I18nUtils.translateMultiline("info.warp_dimensional_door"));
} }
} }

View file

@ -25,7 +25,7 @@ public class ItemDimensionalTrapdoorWood extends ItemDimensionalTrapdoor {
@Override @Override
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
public void addInformation(ItemStack stack, World worldIn, List<String> tooltip, ITooltipFlag flagIn) { public void addInformation(ItemStack stack, World world, List<String> tooltip, ITooltipFlag flag) {
I18nUtils.translateAndAdd("info.wood_dimensional_trapdoor", tooltip); tooltip.addAll(I18nUtils.translateMultiline("info.wood_dimensional_trapdoor"));
} }
} }

View file

@ -50,24 +50,24 @@ public class ItemRiftBlade extends ItemSword {
} }
@Override @Override
public ActionResult<ItemStack> onItemRightClick(World worldIn, EntityPlayer playerIn, EnumHand handIn) { public ActionResult<ItemStack> onItemRightClick(World world, EntityPlayer player, EnumHand hand) {
ItemStack stack = playerIn.getHeldItem(handIn); ItemStack stack = player.getHeldItem(hand);
if (worldIn.isRemote) { if (world.isRemote) {
return new ActionResult<>(EnumActionResult.FAIL, stack); return new ActionResult<>(EnumActionResult.FAIL, stack);
} }
//SchematicHandler.Instance.getPersonalPocketTemplate().place(0, 20, 0, 20, 0, 0, 1, EnumPocketType.DUNGEON); //this line can be activated for testing purposes //SchematicHandler.Instance.getPersonalPocketTemplate().place(0, 20, 0, 20, 0, 0, 1, EnumPocketType.DUNGEON); //this line can be activated for testing purposes
RayTraceResult hit = rayTrace(worldIn, playerIn, true); RayTraceResult hit = rayTrace(world, player, true);
if (RayTraceHelper.isFloatingRift(hit, worldIn)) { if (RayTraceHelper.isFloatingRift(hit, world)) {
TileEntityFloatingRift rift = (TileEntityFloatingRift) worldIn.getTileEntity(hit.getBlockPos()); TileEntityFloatingRift rift = (TileEntityFloatingRift) world.getTileEntity(hit.getBlockPos());
rift.teleport(playerIn); rift.teleport(player);
stack.damageItem(1, playerIn); stack.damageItem(1, player);
return new ActionResult<>(EnumActionResult.SUCCESS, stack); return new ActionResult<>(EnumActionResult.SUCCESS, stack);
} else if (RayTraceHelper.isLivingEntity(hit)) { } else if (RayTraceHelper.isLivingEntity(hit)) {
TeleportUtils.teleport(playerIn, new Location(worldIn, hit.getBlockPos()), playerIn.rotationYaw, playerIn.rotationPitch); //@todo teleport to a location 1 or 2 blocks distance from the entity TeleportUtils.teleport(player, new Location(world, hit.getBlockPos()), player.rotationYaw, player.rotationPitch); //@todo teleport to a location 1 or 2 blocks distance from the entity
stack.damageItem(1, playerIn); // TODO: check if successful stack.damageItem(1, player); // TODO: check if successful
return new ActionResult<>(EnumActionResult.SUCCESS, stack); return new ActionResult<>(EnumActionResult.SUCCESS, stack);
} }
@ -75,7 +75,7 @@ public class ItemRiftBlade extends ItemSword {
} }
@Override @Override
public void addInformation(ItemStack stack, World worldIn, List<String> tooltip, ITooltipFlag flagIn) { public void addInformation(ItemStack stack, World world, List<String> tooltip, ITooltipFlag flagIn) {
I18nUtils.translateAndAdd("info.rift_blade", tooltip); tooltip.addAll(I18nUtils.translateMultiline("info.rift_blade"));
} }
} }

View file

@ -10,11 +10,11 @@ import net.minecraft.util.ResourceLocation;
import net.minecraft.world.World; import net.minecraft.world.World;
import org.dimdev.dimdoors.DimDoors; import org.dimdev.dimdoors.DimDoors;
public class ItemRiftConnectionTool extends Item { public class ItemRiftConfigurationTool extends Item {
public static final String ID = "rift_connection_tool"; public static final String ID = "rift_configuration_tool";
ItemRiftConnectionTool() { ItemRiftConfigurationTool() {
setMaxStackSize(1); setMaxStackSize(1);
setMaxDamage(16); setMaxDamage(16);
setCreativeTab(DimDoors.DIM_DOORS_CREATIVE_TAB); setCreativeTab(DimDoors.DIM_DOORS_CREATIVE_TAB);
@ -23,9 +23,9 @@ public class ItemRiftConnectionTool extends Item {
} }
@Override @Override
public ActionResult<ItemStack> onItemRightClick(World worldIn, EntityPlayer playerIn, EnumHand handIn) { public ActionResult<ItemStack> onItemRightClick(World world, EntityPlayer player, EnumHand handIn) {
// TODO: reimplement this using the new registry system (open a GUI that allows configuring the rift) // TODO: reimplement this using the new registry system (open a GUI that allows configuring the rift)
ItemStack stack = playerIn.getHeldItem(handIn); ItemStack stack = player.getHeldItem(handIn);
return new ActionResult<>(EnumActionResult.FAIL, stack); return new ActionResult<>(EnumActionResult.FAIL, stack);
} }
} }

View file

@ -1,7 +1,9 @@
package org.dimdev.dimdoors.shared.items; package org.dimdev.dimdoors.shared.items;
import net.minecraft.util.*;
import org.dimdev.dimdoors.DimDoors; import org.dimdev.dimdoors.DimDoors;
import org.dimdev.dimdoors.shared.RayTraceHelper; import org.dimdev.dimdoors.shared.RayTraceHelper;
import org.dimdev.dimdoors.shared.sound.ModSounds;
import org.dimdev.dimdoors.shared.tileentities.TileEntityFloatingRift; import org.dimdev.dimdoors.shared.tileentities.TileEntityFloatingRift;
import org.dimdev.ddutils.I18nUtils; import org.dimdev.ddutils.I18nUtils;
import net.minecraft.client.util.ITooltipFlag; import net.minecraft.client.util.ITooltipFlag;
@ -9,10 +11,6 @@ import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.init.Blocks; import net.minecraft.init.Blocks;
import net.minecraft.item.Item; import net.minecraft.item.Item;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import net.minecraft.util.ActionResult;
import net.minecraft.util.EnumActionResult;
import net.minecraft.util.EnumHand;
import net.minecraft.util.ResourceLocation;
import net.minecraft.util.math.RayTraceResult; import net.minecraft.util.math.RayTraceResult;
import net.minecraft.world.World; import net.minecraft.world.World;
@ -30,24 +28,26 @@ public class ItemRiftRemover extends Item {
} }
@Override @Override
public void addInformation(ItemStack stack, World worldIn, List<String> tooltip, ITooltipFlag flagIn) { public void addInformation(ItemStack stack, World world, List<String> tooltip, ITooltipFlag flagIn) {
I18nUtils.translateAndAdd("info.rift_remover", tooltip); tooltip.addAll(I18nUtils.translateMultiline("info.rift_remover"));
} }
@Override @Override
public ActionResult<ItemStack> onItemRightClick(World world, EntityPlayer playerIn, EnumHand handIn) { // TODO: permissions public ActionResult<ItemStack> onItemRightClick(World world, EntityPlayer player, EnumHand handIn) { // TODO: permissions
ItemStack stack = playerIn.getHeldItem(handIn); ItemStack stack = player.getHeldItem(handIn);
if (world.isRemote) { if (world.isRemote) {
return new ActionResult<>(EnumActionResult.FAIL, stack); return new ActionResult<>(EnumActionResult.FAIL, stack);
} }
RayTraceResult hit = rayTrace(world, playerIn, true); RayTraceResult hit = rayTrace(world, player, true);
if (RayTraceHelper.isFloatingRift(hit, world)) { if (RayTraceHelper.isFloatingRift(hit, world)) {
TileEntityFloatingRift rift = (TileEntityFloatingRift) world.getTileEntity(hit.getBlockPos()); TileEntityFloatingRift rift = (TileEntityFloatingRift) world.getTileEntity(hit.getBlockPos());
world.setBlockState(rift.getPos(), Blocks.AIR.getDefaultState()); world.setBlockState(rift.getPos(), Blocks.AIR.getDefaultState());
world.playSound(null, player.getPosition(), ModSounds.RIFT_CLOSE, SoundCategory.BLOCKS, 0.6f, 1);
// TODO: render rift removing animation
stack.damageItem(10, playerIn); stack.damageItem(10, player);
return new ActionResult<>(EnumActionResult.SUCCESS, stack); return new ActionResult<>(EnumActionResult.SUCCESS, stack);
} }
return new ActionResult<>(EnumActionResult.FAIL, stack); return new ActionResult<>(EnumActionResult.FAIL, stack);

View file

@ -1,20 +1,21 @@
package org.dimdev.dimdoors.shared.items; package org.dimdev.dimdoors.shared.items;
import net.minecraft.client.resources.I18n;
import net.minecraft.entity.player.EntityPlayer; import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.init.Blocks; import net.minecraft.init.Blocks;
import net.minecraft.nbt.NBTTagCompound; import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.util.*; import net.minecraft.util.*;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import net.minecraft.util.text.translation.I18n;
import net.minecraftforge.fml.relauncher.Side; import net.minecraftforge.fml.relauncher.Side;
import net.minecraftforge.fml.relauncher.SideOnly; import net.minecraftforge.fml.relauncher.SideOnly;
import org.dimdev.ddutils.I18nUtils;
import org.dimdev.ddutils.Location; import org.dimdev.ddutils.Location;
import org.dimdev.dimdoors.DimDoors; import org.dimdev.dimdoors.DimDoors;
import net.minecraft.client.util.ITooltipFlag; import net.minecraft.client.util.ITooltipFlag;
import net.minecraft.item.Item; import net.minecraft.item.Item;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import net.minecraft.world.World; import net.minecraft.world.World;
import org.dimdev.dimdoors.shared.RotatedLocation; import org.dimdev.ddutils.RotatedLocation;
import org.dimdev.dimdoors.shared.blocks.ModBlocks; import org.dimdev.dimdoors.shared.blocks.ModBlocks;
import org.dimdev.dimdoors.shared.rifts.GlobalDestination; import org.dimdev.dimdoors.shared.rifts.GlobalDestination;
import org.dimdev.dimdoors.shared.rifts.TileEntityRift; import org.dimdev.dimdoors.shared.rifts.TileEntityRift;
@ -22,8 +23,6 @@ import org.dimdev.dimdoors.shared.sound.ModSounds;
import java.util.List; import java.util.List;
import static org.dimdev.ddutils.I18nUtils.translateAndAdd;
public class ItemRiftSignature extends Item { public class ItemRiftSignature extends Item {
public static final String ID = "rift_signature"; public static final String ID = "rift_signature";
@ -59,7 +58,7 @@ public class ItemRiftSignature extends Item {
if (target != null) { if (target != null) {
// Place a rift at the saved point TODO: check that the player still has permission // Place a rift at the saved point TODO: check that the player still has permission
if (!target.getLocation().getBlockState().equals(ModBlocks.RIFT)) { if (!target.getLocation().getBlockState().getBlock().equals(ModBlocks.RIFT)) {
if (!target.getLocation().getBlockState().getBlock().equals(Blocks.AIR)) { if (!target.getLocation().getBlockState().getBlock().equals(Blocks.AIR)) {
return EnumActionResult.FAIL; // TODO: send a message return EnumActionResult.FAIL; // TODO: send a message
} }
@ -82,12 +81,13 @@ public class ItemRiftSignature extends Item {
clearSource(stack); clearSource(stack);
DimDoors.chat(player, "Rift Created"); DimDoors.chat(player, "Rift Created");
world.playSound(player, player.getPosition(), ModSounds.RIFT_END, SoundCategory.BLOCKS, 0.6f, 1); // null = send sound to the player too, we have to do this because this code is not run client-side
world.playSound(null, player.getPosition(), ModSounds.RIFT_END, SoundCategory.BLOCKS, 0.6f, 1);
} else { } else {
// 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(new Location(world, pos), player.rotationYaw)); setSource(stack, new RotatedLocation(new Location(world, pos), player.rotationYaw, 0));
DimDoors.chat(player, "Location Stored in Rift Signature"); DimDoors.chat(player, "Location Stored in Rift Signature");
world.playSound(player, player.getPosition(), ModSounds.RIFT_START, SoundCategory.BLOCKS, 0.6f, 1); world.playSound(null, player.getPosition(), ModSounds.RIFT_START, SoundCategory.BLOCKS, 0.6f, 1);
} }
return EnumActionResult.SUCCESS; return EnumActionResult.SUCCESS;
@ -116,12 +116,12 @@ public class ItemRiftSignature extends Item {
@Override @Override
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
public void addInformation(ItemStack stack, World worldIn, List<String> tooltip, ITooltipFlag flagIn) { public void addInformation(ItemStack stack, World world, List<String> tooltip, ITooltipFlag flagIn) {
RotatedLocation transform = getSource(stack); RotatedLocation transform = getSource(stack);
if (transform != null) { if (transform != null) {
tooltip.add(I18n.translateToLocalFormatted("info.rift_signature.bound", transform.getLocation().getX(), transform.getLocation().getY(), transform.getLocation().getZ(), transform.getLocation().getDim())); tooltip.add(I18n.format("info.rift_signature.bound", transform.getLocation().getX(), transform.getLocation().getY(), transform.getLocation().getZ(), transform.getLocation().getDim()));
} else { } else {
translateAndAdd("info.rift_signature.unbound", tooltip); tooltip.addAll(I18nUtils.translateMultiline("info.rift_signature.unbound"));
} }
} }
} }

View file

@ -12,9 +12,10 @@ import net.minecraft.util.text.translation.I18n;
import net.minecraft.world.World; import net.minecraft.world.World;
import net.minecraftforge.fml.relauncher.Side; import net.minecraftforge.fml.relauncher.Side;
import net.minecraftforge.fml.relauncher.SideOnly; import net.minecraftforge.fml.relauncher.SideOnly;
import org.dimdev.ddutils.I18nUtils;
import org.dimdev.ddutils.Location; import org.dimdev.ddutils.Location;
import org.dimdev.dimdoors.DimDoors; import org.dimdev.dimdoors.DimDoors;
import org.dimdev.dimdoors.shared.RotatedLocation; import org.dimdev.ddutils.RotatedLocation;
import org.dimdev.dimdoors.shared.blocks.ModBlocks; import org.dimdev.dimdoors.shared.blocks.ModBlocks;
import org.dimdev.dimdoors.shared.rifts.GlobalDestination; import org.dimdev.dimdoors.shared.rifts.GlobalDestination;
import org.dimdev.dimdoors.shared.rifts.TileEntityRift; import org.dimdev.dimdoors.shared.rifts.TileEntityRift;
@ -22,8 +23,6 @@ import org.dimdev.dimdoors.shared.sound.ModSounds;
import java.util.List; import java.util.List;
import static org.dimdev.ddutils.I18nUtils.translateAndAdd;
public class ItemStabilizedRiftSignature extends Item { // TODO: common superclass with rift signature public class ItemStabilizedRiftSignature extends Item { // TODO: common superclass with rift signature
public static final String ID = "stabilized_rift_signature"; public static final String ID = "stabilized_rift_signature";
@ -80,12 +79,12 @@ public class ItemStabilizedRiftSignature extends Item { // TODO: common supercla
stack.damageItem(1, player); stack.damageItem(1, player);
DimDoors.chat(player, "Rift Created"); DimDoors.chat(player, "Rift Created");
world.playSound(player, player.getPosition(), ModSounds.RIFT_END, SoundCategory.BLOCKS, 0.6f, 1); world.playSound(null, player.getPosition(), ModSounds.RIFT_END, SoundCategory.BLOCKS, 0.6f, 1);
} else { } else {
// 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(new Location(world, pos), player.rotationYaw)); setSource(stack, new RotatedLocation(new Location(world, pos), player.rotationYaw, 0));
DimDoors.chat(player, "Location Stored in Rift Signature"); DimDoors.chat(player, "Location Stored in Rift Signature");
world.playSound(player, player.getPosition(), ModSounds.RIFT_START, SoundCategory.BLOCKS, 0.6f, 1); world.playSound(null, player.getPosition(), ModSounds.RIFT_START, SoundCategory.BLOCKS, 0.6f, 1);
} }
return EnumActionResult.SUCCESS; return EnumActionResult.SUCCESS;
@ -114,12 +113,12 @@ public class ItemStabilizedRiftSignature extends Item { // TODO: common supercla
@Override @Override
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
public void addInformation(ItemStack stack, World worldIn, List<String> tooltip, ITooltipFlag flagIn) { public void addInformation(ItemStack stack, World world, List<String> tooltip, ITooltipFlag flagIn) {
RotatedLocation transform = getTarget(stack); RotatedLocation transform = getTarget(stack);
if (transform != null) { if (transform != null) {
tooltip.add(I18n.translateToLocalFormatted("info.stabilized_rift_signature.bound", transform.getLocation().getX(), transform.getLocation().getY(), transform.getLocation().getZ(), transform.getLocation().getDim())); tooltip.add(I18n.translateToLocalFormatted("info.stabilized_rift_signature.bound", transform.getLocation().getX(), transform.getLocation().getY(), transform.getLocation().getZ(), transform.getLocation().getDim()));
} else { } else {
translateAndAdd("info.stabilized_rift_signature.unbound", tooltip); tooltip.addAll(I18nUtils.translateMultiline("info.stabilized_rift_signature.unbound"));
} }
} }
} }

View file

@ -18,8 +18,8 @@ public class ItemWovenWorldThreadArmor extends ItemArmor {
1.0f) 1.0f)
.setRepairItem(new ItemStack(ModItems.WORLD_THREAD)); .setRepairItem(new ItemStack(ModItems.WORLD_THREAD));
public ItemWovenWorldThreadArmor(String name, int renderIndexIn, EntityEquipmentSlot equipmentSlotIn) { public ItemWovenWorldThreadArmor(String name, int renderIndex, EntityEquipmentSlot equipmentSlotIn) {
super(WOVEN_WORLD_THREAD, renderIndexIn, equipmentSlotIn); super(WOVEN_WORLD_THREAD, renderIndex, equipmentSlotIn);
setUnlocalizedName(name); setUnlocalizedName(name);
setRegistryName(DimDoors.MODID, name); setRegistryName(DimDoors.MODID, name);
setCreativeTab(DimDoors.DIM_DOORS_CREATIVE_TAB); setCreativeTab(DimDoors.DIM_DOORS_CREATIVE_TAB);

View file

@ -25,7 +25,7 @@ public final class ModItems {
public static final ItemStableFabric STABLE_FABRIC = new ItemStableFabric(); public static final ItemStableFabric STABLE_FABRIC = new ItemStableFabric();
// Tools // Tools
public static final ItemRiftConnectionTool RIFT_CONNECTION_TOOL = new ItemRiftConnectionTool(); public static final ItemRiftConfigurationTool RIFT_CONNECTION_TOOL = new ItemRiftConfigurationTool();
public static final ItemRiftBlade RIFT_BLADE = new ItemRiftBlade(); public static final ItemRiftBlade RIFT_BLADE = new ItemRiftBlade();
public static final ItemRiftRemover RIFT_REMOVER = new ItemRiftRemover(); public static final ItemRiftRemover RIFT_REMOVER = new ItemRiftRemover();
public static final ItemRiftSignature RIFT_SIGNATURE = new ItemRiftSignature(); public static final ItemRiftSignature RIFT_SIGNATURE = new ItemRiftSignature();

View file

@ -39,7 +39,7 @@ public class PocketGenerator {
float netherProbability = virtualLocation.getDim() == -1 ? 1 : (float) depth / 50; // TODO: improve nether probability float netherProbability = virtualLocation.getDim() == -1 ? 1 : (float) depth / 50; // TODO: improve nether probability
Random random = new Random(); Random random = new Random();
String group = random.nextFloat() < netherProbability ? "nether" : "ruins"; String group = random.nextFloat() < netherProbability ? "nether" : "ruins";
PocketTemplate pocketTemplate = SchematicHandler.INSTANCE.getRandomTemplate(group, depth, DDConfig.getMaxPocketSize(), false); PocketTemplate pocketTemplate = SchematicHandler.INSTANCE.getRandomTemplate(group, depth, Config.getMaxPocketSize(), false);
return generatePocketFromTemplate(ModDimensions.getDungeonDim(), pocketTemplate, virtualLocation); return generatePocketFromTemplate(ModDimensions.getDungeonDim(), pocketTemplate, virtualLocation);
} }

View file

@ -3,7 +3,7 @@ package org.dimdev.dimdoors.shared.pockets;
import com.google.common.collect.BiMap; import com.google.common.collect.BiMap;
import com.google.common.collect.HashBiMap; import com.google.common.collect.HashBiMap;
import org.dimdev.ddutils.nbt.SavedToNBT; import org.dimdev.ddutils.nbt.SavedToNBT;
import org.dimdev.dimdoors.shared.DDConfig; import org.dimdev.dimdoors.shared.Config;
import org.dimdev.ddutils.math.GridUtils; import org.dimdev.ddutils.math.GridUtils;
import org.dimdev.dimdoors.DimDoors; import org.dimdev.dimdoors.DimDoors;
import org.dimdev.ddutils.nbt.NBTUtils; import org.dimdev.ddutils.nbt.NBTUtils;
@ -64,10 +64,10 @@ import net.minecraft.world.storage.WorldSavedData;
} }
public void initNewRegistry() { public void initNewRegistry() {
gridSize = DDConfig.getPocketGridSize(); gridSize = Config.getPocketGridSize();
maxPocketSize = DDConfig.getMaxPocketSize(); maxPocketSize = Config.getMaxPocketSize();
privatePocketSize = DDConfig.getPrivatePocketSize(); privatePocketSize = Config.getPrivatePocketSize();
publicPocketSize = DDConfig.getPublicPocketSize(); publicPocketSize = Config.getPublicPocketSize();
nextID = 0; nextID = 0;
pockets = new HashMap<>(); pockets = new HashMap<>();

View file

@ -1,5 +1,6 @@
package org.dimdev.dimdoors.shared.pockets; package org.dimdev.dimdoors.shared.pockets;
import org.dimdev.ddutils.WorldUtils;
import org.dimdev.dimdoors.shared.rifts.TileEntityRift; import org.dimdev.dimdoors.shared.rifts.TileEntityRift;
import org.dimdev.ddutils.Location; import org.dimdev.ddutils.Location;
import org.dimdev.ddutils.schem.Schematic; import org.dimdev.ddutils.schem.Schematic;
@ -46,7 +47,7 @@ public class PocketTemplate {
int zBase = pocket.getZ() * gridSize * 16; int zBase = pocket.getZ() * gridSize * 16;
DimDoors.log.info("Placing new pocket using schematic " + schematic.schematicName + " at x = " + xBase + ", z = " + zBase); DimDoors.log.info("Placing new pocket using schematic " + schematic.schematicName + " at x = " + xBase + ", z = " + zBase);
WorldServer world = DimDoors.proxy.getWorldServer(dim); WorldServer world = WorldUtils.getWorld(dim);
Schematic.place(schematic, world, xBase, yBase, zBase); Schematic.place(schematic, world, xBase, yBase, zBase);
// Set pocket riftLocations // Set pocket riftLocations

View file

@ -20,18 +20,18 @@ import java.util.UUID;
@Getter @AllArgsConstructor @Builder(toBuilder = true) @ToString @Getter @AllArgsConstructor @Builder(toBuilder = true) @ToString
@SavedToNBT public class AvailableLinkDestination extends RiftDestination { // TODO @SavedToNBT public class AvailableLinkDestination extends RiftDestination { // TODO
@SavedToNBT /*package-private*/ float newDungeonRiftProbability; @SavedToNBT protected float newDungeonRiftProbability;
@SavedToNBT /*package-private*/ float depthPenalization; // TODO: these make the equation assymetric @SavedToNBT protected float depthPenalization; // TODO: these make the equation assymetric
@SavedToNBT /*package-private*/ float distancePenalization; @SavedToNBT protected float distancePenalization;
@SavedToNBT /*package-private*/ float closenessPenalization; @SavedToNBT protected float closenessPenalization;
@SavedToNBT /*package-private*/ boolean dungeonRiftsOnly; @SavedToNBT protected boolean dungeonRiftsOnly;
@SavedToNBT /*package-private*/ boolean overworldRifts; @SavedToNBT protected boolean overworldRifts;
@SavedToNBT /*package-private*/ boolean unstable; @SavedToNBT protected boolean unstable;
@SavedToNBT /*package-private*/ float nonFloatingRiftWeight; @SavedToNBT protected float nonFloatingRiftWeight;
@SavedToNBT /*package-private*/ float floatingRiftWeight; @SavedToNBT protected float floatingRiftWeight;
@SavedToNBT /*package-private*/ boolean noLinkBack; @SavedToNBT protected boolean noLinkBack;
// private int maxLinks; // private int maxLinks;
@Builder.Default private UUID uuid = UUID.randomUUID(); @Builder.Default private UUID uuid = UUID.randomUUID();

View file

@ -12,7 +12,7 @@ import org.dimdev.ddutils.nbt.SavedToNBT;
@Getter @AllArgsConstructor @Builder(toBuilder = true) @ToString @Getter @AllArgsConstructor @Builder(toBuilder = true) @ToString
@SavedToNBT public class GlobalDestination extends RiftDestination { // TODO: location directly in nbt like minecraft? @SavedToNBT public class GlobalDestination extends RiftDestination { // TODO: location directly in nbt like minecraft?
@SavedToNBT @Getter /*package-private*/ Location loc; @SavedToNBT @Getter protected Location loc;
public GlobalDestination() {} public GlobalDestination() {}

View file

@ -13,7 +13,7 @@ import org.dimdev.ddutils.nbt.SavedToNBT;
@Getter @AllArgsConstructor @Builder(toBuilder = true) @ToString @Getter @AllArgsConstructor @Builder(toBuilder = true) @ToString
@SavedToNBT public class LocalDestination extends RiftDestination { // TODO: use BlockPos @SavedToNBT public class LocalDestination extends RiftDestination { // TODO: use BlockPos
@SavedToNBT /*package-private*/ BlockPos pos; @SavedToNBT protected BlockPos pos;
public LocalDestination() {} public LocalDestination() {}

View file

@ -1,5 +1,6 @@
package org.dimdev.dimdoors.shared.rifts; package org.dimdev.dimdoors.shared.rifts;
import org.dimdev.dimdoors.shared.VirtualLocation;
import org.dimdev.dimdoors.shared.pockets.Pocket; import org.dimdev.dimdoors.shared.pockets.Pocket;
import org.dimdev.dimdoors.shared.pockets.PocketGenerator; import org.dimdev.dimdoors.shared.pockets.PocketGenerator;
import lombok.AllArgsConstructor; import lombok.AllArgsConstructor;
@ -26,7 +27,13 @@ public class NewPublicDestination extends RiftDestination { // TODO: more config
@Override @Override
public boolean teleport(TileEntityRift rift, Entity entity) { public boolean teleport(TileEntityRift rift, Entity entity) {
Pocket pocket = PocketGenerator.generatePublicPocket(rift.virtualLocation != null ? rift.virtualLocation.randomTransformDepth() : null); // TODO: random transform VirtualLocation newVirtualLocation = null;
if (rift.virtualLocation != null) {
int depth = rift.virtualLocation.getDepth();
if (depth == 0) depth++;
newVirtualLocation = new VirtualLocation(rift.virtualLocation.getLocation(), depth);
}
Pocket pocket = PocketGenerator.generatePublicPocket(newVirtualLocation);
pocket.setup(); pocket.setup();
pocket.linkPocketTo(new GlobalDestination(rift.getLocation())); pocket.linkPocketTo(new GlobalDestination(rift.getLocation()));
rift.makeDestinationPermanent(weightedDestination, pocket.getEntrance()); rift.makeDestinationPermanent(weightedDestination, pocket.getEntrance());

View file

@ -16,9 +16,9 @@ import java.util.List;
@Getter @AllArgsConstructor @Builder(toBuilder = true) @ToString @Getter @AllArgsConstructor @Builder(toBuilder = true) @ToString
@SavedToNBT public class PocketEntranceDestination extends RiftDestination { @SavedToNBT public class PocketEntranceDestination extends RiftDestination {
@SavedToNBT /*package-private*/ float weight; @SavedToNBT protected float weight;
@SavedToNBT @SuppressWarnings({"UnusedAssignment", "RedundantSuppression"}) @Builder.Default /*package-private*/ List<WeightedRiftDestination> ifDestinations = new LinkedList<>(); // TODO addIfDestination method in builder @SavedToNBT @SuppressWarnings({"UnusedAssignment", "RedundantSuppression"}) @Builder.Default protected List<WeightedRiftDestination> ifDestinations = new LinkedList<>(); // TODO addIfDestination method in builder
@SavedToNBT @SuppressWarnings({"UnusedAssignment", "RedundantSuppression"}) @Builder.Default /*package-private*/ List<WeightedRiftDestination> otherwiseDestinations = new LinkedList<>(); // TODO addOtherwiseDestination method in builder @SavedToNBT @SuppressWarnings({"UnusedAssignment", "RedundantSuppression"}) @Builder.Default protected List<WeightedRiftDestination> otherwiseDestinations = new LinkedList<>(); // TODO addOtherwiseDestination method in builder
public PocketEntranceDestination() {} public PocketEntranceDestination() {}

View file

@ -13,7 +13,7 @@ import org.dimdev.ddutils.nbt.SavedToNBT;
@Getter @AllArgsConstructor @Builder(toBuilder = true) @ToString @Getter @AllArgsConstructor @Builder(toBuilder = true) @ToString
@SavedToNBT public class RelativeDestination extends RiftDestination { // TODO: use Vec3i @SavedToNBT public class RelativeDestination extends RiftDestination { // TODO: use Vec3i
@SavedToNBT /*package-private*/ Vec3i offset; @SavedToNBT protected Vec3i offset;
public RelativeDestination() {} public RelativeDestination() {}

View file

@ -15,7 +15,7 @@ public abstract class RiftDestination implements INBTStorable {
/*private*/ public static final BiMap<String, Class<? extends RiftDestination>> destinationRegistry = HashBiMap.create(); // TODO: move to RiftDestinationRegistry /*private*/ public static final BiMap<String, Class<? extends RiftDestination>> destinationRegistry = HashBiMap.create(); // TODO: move to RiftDestinationRegistry
//private String type; //private String type;
/*package-private*/ WeightedRiftDestination weightedDestination; protected WeightedRiftDestination weightedDestination;
public RiftDestination() { public RiftDestination() {
//type = destinationRegistry.inverse().get(getClass()); //type = destinationRegistry.inverse().get(getClass());

View file

@ -26,11 +26,11 @@ import java.util.*;
private static final String DATA_NAME = DimDoors.MODID + "_rifts"; private static final String DATA_NAME = DimDoors.MODID + "_rifts";
@Getter private static final int DATA_VERSION = 0; // IMPORTANT: Update this and upgradeRegistry when making changes. @Getter private static final int DATA_VERSION = 0; // IMPORTANT: Update this and upgradeRegistry when making changes.
@SavedToNBT @Getter /*package-private*/ /*final*/ Map<Location, RiftInfo> rifts = new HashMap<>(); // TODO: convert to a static directed graph, but store links per-world @SavedToNBT @Getter protected /*final*/ Map<Location, RiftInfo> rifts = new HashMap<>(); // TODO: convert to a static directed graph, but store links per-world
@SavedToNBT @Getter /*package-private*/ /*final*/ Map<String, Location> privatePocketEntrances = new HashMap<>(); // Player UUID -> last rift used to exit pocket TODO: split into PrivatePocketRiftRegistry subclass @SavedToNBT @Getter protected /*final*/ Map<String, Location> privatePocketEntrances = new HashMap<>(); // Player UUID -> last rift used to exit pocket TODO: split into PrivatePocketRiftRegistry subclass
@SavedToNBT @Getter /*package-private*/ /*final*/ Map<String, List<Location>> privatePocketEntranceLists = new HashMap<>(); // Player UUID -> private pocket entrances TODO: split into PrivatePocketRiftRegistry subclass @SavedToNBT @Getter protected /*final*/ Map<String, List<Location>> privatePocketEntranceLists = new HashMap<>(); // Player UUID -> private pocket entrances TODO: split into PrivatePocketRiftRegistry subclass
@SavedToNBT @Getter /*package-private*/ /*final*/ Map<String, Location> privatePocketExits = new HashMap<>(); // Player UUID -> last rift used to enter pocket @SavedToNBT @Getter protected /*final*/ Map<String, Location> privatePocketExits = new HashMap<>(); // Player UUID -> last rift used to enter pocket
@SavedToNBT @Getter /*package-private*/ /*final*/ Map<String, Location> overworldRifts = new HashMap<>(); @SavedToNBT @Getter protected /*final*/ Map<String, Location> overworldRifts = new HashMap<>();
@Getter private int dim; @Getter private int dim;
private World world; private World world;

View file

@ -2,7 +2,7 @@ package org.dimdev.dimdoors.shared.tools;
import net.minecraft.block.Block; import net.minecraft.block.Block;
import org.dimdev.dimdoors.DimDoors; import org.dimdev.dimdoors.DimDoors;
import org.dimdev.dimdoors.server.DDProxyServer; import org.dimdev.dimdoors.server.ServerProxy;
import org.dimdev.dimdoors.shared.blocks.BlockDimensionalDoor; import org.dimdev.dimdoors.shared.blocks.BlockDimensionalDoor;
import org.dimdev.dimdoors.shared.blocks.BlockFabric; import org.dimdev.dimdoors.shared.blocks.BlockFabric;
import org.dimdev.dimdoors.shared.blocks.ModBlocks; import org.dimdev.dimdoors.shared.blocks.ModBlocks;
@ -48,8 +48,8 @@ public final class PocketSchematicGenerator {
Loader.instance().setupTestHarness(mc); Loader.instance().setupTestHarness(mc);
Loader.instance().setActiveModContainer(mc); Loader.instance().setActiveModContainer(mc);
ModBlocks.registerBlocks(new RegistryEvent.Register<Block>(GameData.BLOCKS, RegistryManager.ACTIVE.getRegistry(GameData.BLOCKS))); ModBlocks.registerBlocks(new RegistryEvent.Register<Block>(GameData.BLOCKS, RegistryManager.ACTIVE.getRegistry(GameData.BLOCKS)));
new DDProxyServer().registerTileEntities(); new ServerProxy().registerTileEntities();
new DDProxyServer().registerRiftDestinations(); new ServerProxy().registerRiftDestinations();
Loader.instance().setActiveModContainer(null); Loader.instance().setActiveModContainer(null);
// Parse arguments // Parse arguments

View file

@ -35,17 +35,17 @@ public class CustomSkyProvider extends IRenderHandler {
starGLCallList = GLAllocation.generateDisplayLists(3); starGLCallList = GLAllocation.generateDisplayLists(3);
glSkyList = starGLCallList + 1; glSkyList = starGLCallList + 1;
glSkyList2 = starGLCallList + 2; glSkyList2 = starGLCallList + 2;
GL11.glDisable(GL11.GL_FOG); GlStateManager.disableFog();
GL11.glDisable(GL11.GL_ALPHA_TEST); GlStateManager.disableAlpha();
GL11.glEnable(GL11.GL_BLEND); GlStateManager.enableBlend();
GL11.glBlendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE_MINUS_SRC_ALPHA); GlStateManager.blendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE_MINUS_SRC_ALPHA);
RenderHelper.disableStandardItemLighting(); RenderHelper.disableStandardItemLighting();
GL11.glDepthMask(false); GlStateManager.depthMask(false);
mc.renderEngine.bindTexture(locationEndSkyPng); mc.renderEngine.bindTexture(locationEndSkyPng);
if (mc.world.provider.isSurfaceWorld()) { if (mc.world.provider.isSurfaceWorld()) {
GL11.glDisable(GL11.GL_TEXTURE_2D); GlStateManager.disableTexture2D();
final Vec3d vec3 = world.getSkyColor(mc.getRenderViewEntity(), partialTicks); final Vec3d vec3 = world.getSkyColor(mc.getRenderViewEntity(), partialTicks);
float f1 = (float) vec3.x; float f1 = (float) vec3.x;
float f2 = (float) vec3.y; float f2 = (float) vec3.y;
@ -61,17 +61,17 @@ public class CustomSkyProvider extends IRenderHandler {
f3 = f4; f3 = f4;
} }
GL11.glColor3f(f1, f2, f3); GlStateManager.color(f1, f2, f3);
final Tessellator tessellator = Tessellator.getInstance(); final Tessellator tessellator = Tessellator.getInstance();
final BufferBuilder buffer = tessellator.getBuffer(); final BufferBuilder buffer = tessellator.getBuffer();
GL11.glDepthMask(false); GlStateManager.depthMask(false);
GL11.glEnable(GL11.GL_FOG); GlStateManager.enableFog();
GL11.glColor3f(f1, f2, f3); GlStateManager.color(f1, f2, f3);
GL11.glCallList(glSkyList); GlStateManager.callList(glSkyList);
GL11.glDisable(GL11.GL_FOG); GlStateManager.disableFog();
GL11.glDisable(GL11.GL_ALPHA_TEST); GlStateManager.disableAlpha();
GL11.glEnable(GL11.GL_BLEND); GlStateManager.enableBlend();
GL11.glBlendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE_MINUS_SRC_ALPHA); GlStateManager.blendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE_MINUS_SRC_ALPHA);
RenderHelper.disableStandardItemLighting(); RenderHelper.disableStandardItemLighting();
float[] afloat = world.provider.calcSunriseSunsetColors(world.getCelestialAngle(partialTicks), partialTicks); float[] afloat = world.provider.calcSunriseSunsetColors(world.getCelestialAngle(partialTicks), partialTicks);
float f7; float f7;
@ -80,12 +80,12 @@ public class CustomSkyProvider extends IRenderHandler {
float f10; float f10;
if (afloat != null) { if (afloat != null) {
GL11.glDisable(GL11.GL_TEXTURE_2D); GlStateManager.disableTexture2D();
GL11.glShadeModel(GL11.GL_SMOOTH); GlStateManager.shadeModel(GL11.GL_SMOOTH);
GL11.glPushMatrix(); GlStateManager.pushMatrix();
GL11.glRotatef(90.0F, 1.0F, 0.0F, 0.0F); GlStateManager.rotate(90.0F, 1.0F, 0.0F, 0.0F);
GL11.glRotatef(MathHelper.sin(world.getCelestialAngleRadians(partialTicks)) < 0.0F ? 180.0F : 0.0F, 0.0F, 0.0F, 1.0F); GlStateManager.rotate(MathHelper.sin(world.getCelestialAngleRadians(partialTicks)) < 0.0F ? 180.0F : 0.0F, 0.0F, 0.0F, 1.0F);
GL11.glRotatef(90.0F, 0.0F, 0.0F, 1.0F); GlStateManager.rotate(90.0F, 0.0F, 0.0F, 1.0F);
f4 = afloat[0]; f4 = afloat[0];
f7 = afloat[1]; f7 = afloat[1];
f8 = afloat[2]; f8 = afloat[2];
@ -112,21 +112,21 @@ public class CustomSkyProvider extends IRenderHandler {
} }
tessellator.draw(); tessellator.draw();
GL11.glPopMatrix(); GlStateManager.popMatrix();
GL11.glShadeModel(GL11.GL_FLAT); GlStateManager.shadeModel(GL11.GL_FLAT);
} }
GL11.glEnable(GL11.GL_TEXTURE_2D); GlStateManager.enableTexture2D();
GL11.glBlendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE); GlStateManager.blendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE);
GL11.glPushMatrix(); GlStateManager.pushMatrix();
f4 = 1.0F - world.getRainStrength(partialTicks); f4 = 1.0F - world.getRainStrength(partialTicks);
f7 = 0.0F; f7 = 0.0F;
f8 = 0.0F; f8 = 0.0F;
f9 = 0.0F; f9 = 0.0F;
GL11.glColor4f(1.0F, 1.0F, 1.0F, f4); GlStateManager.color(1.0F, 1.0F, 1.0F, f4);
GL11.glTranslatef(f7, f8, f9); GlStateManager.translate(f7, f8, f9);
GL11.glRotatef(-90.0F, 0.0F, 1.0F, 0.0F); GlStateManager.rotate(-90.0F, 0.0F, 1.0F, 0.0F);
GL11.glRotatef(world.getCelestialAngle(partialTicks) * 360.0F, 1.0F, 0.0F, 0.0F); GlStateManager.rotate(world.getCelestialAngle(partialTicks) * 360.0F, 1.0F, 0.0F, 0.0F);
f10 = 30.0F; f10 = 30.0F;
mc.renderEngine.bindTexture(getSunRenderPath()); mc.renderEngine.bindTexture(getSunRenderPath());
buffer.begin(GL11.GL_QUADS, DefaultVertexFormats.POSITION_TEX); buffer.begin(GL11.GL_QUADS, DefaultVertexFormats.POSITION_TEX);
@ -149,28 +149,28 @@ public class CustomSkyProvider extends IRenderHandler {
buffer.pos(f10, -100, -f10).tex((float) i, (float) i1).endVertex(); buffer.pos(f10, -100, -f10).tex((float) i, (float) i1).endVertex();
buffer.pos(-f10, -100, -f10).tex(f16, (float) i1).endVertex(); buffer.pos(-f10, -100, -f10).tex(f16, (float) i1).endVertex();
tessellator.draw(); tessellator.draw();
GL11.glDisable(GL11.GL_TEXTURE_2D); GlStateManager.disableTexture2D();
float f18 = world.getStarBrightness(partialTicks) * f4; float f18 = world.getStarBrightness(partialTicks) * f4;
if (f18 > 0.0F) { if (f18 > 0.0F) {
GL11.glColor4f(f18, f18, f18, f18); GlStateManager.color(f18, f18, f18, f18);
GL11.glCallList(starGLCallList); GlStateManager.callList(starGLCallList);
} }
GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F); GlStateManager.color(1.0F, 1.0F, 1.0F, 1.0F);
GL11.glDisable(GL11.GL_BLEND); GlStateManager.disableBlend();
GL11.glEnable(GL11.GL_ALPHA_TEST); GlStateManager.enableAlpha();
GL11.glEnable(GL11.GL_FOG); GlStateManager.enableFog();
GL11.glPopMatrix(); GlStateManager.popMatrix();
GL11.glDisable(GL11.GL_TEXTURE_2D); GlStateManager.disableTexture2D();
GL11.glColor3f(0.0F, 0.0F, 0.0F); GlStateManager.color(0.0F, 0.0F, 0.0F);
double d0 = mc.player.getLook(partialTicks).y - world.getHorizon(); double d0 = mc.player.getLook(partialTicks).y - world.getHorizon();
if (d0 < 0.0D) { if (d0 < 0.0D) {
GL11.glPushMatrix(); GlStateManager.pushMatrix();
GL11.glTranslatef(0.0F, 12.0F, 0.0F); GlStateManager.translate(0.0F, 12.0F, 0.0F);
GL11.glCallList(glSkyList2); GlStateManager.callList(glSkyList2);
GL11.glPopMatrix(); GlStateManager.popMatrix();
f8 = 1.0F; f8 = 1.0F;
f9 = -((float) (d0 + 65.0D)); f9 = -((float) (d0 + 65.0D));
f10 = -f8; f10 = -f8;
@ -200,17 +200,17 @@ public class CustomSkyProvider extends IRenderHandler {
} }
if (world.provider.isSkyColored()) { if (world.provider.isSkyColored()) {
GL11.glColor3f(f1 * 0.2F + 0.04F, f2 * 0.2F + 0.04F, f3 * 0.6F + 0.1F); GlStateManager.color(f1 * 0.2F + 0.04F, f2 * 0.2F + 0.04F, f3 * 0.6F + 0.1F);
} else { } else {
GL11.glColor3f(f1, f2, f3); GlStateManager.color(f1, f2, f3);
} }
GL11.glPushMatrix(); GlStateManager.pushMatrix();
GL11.glTranslatef(0.0F, -((float) (d0 - 16.0D)), 0.0F); GlStateManager.translate(0.0F, -((float) (d0 - 16.0D)), 0.0F);
GL11.glCallList(glSkyList2); GlStateManager.callList(glSkyList2);
GL11.glPopMatrix(); GlStateManager.popMatrix();
GL11.glEnable(GL11.GL_TEXTURE_2D); GlStateManager.enableTexture2D();
GL11.glDepthMask(true); GlStateManager.depthMask(true);
} }
} }
} }

View file

@ -4,7 +4,7 @@ import lombok.Getter;
import net.minecraft.world.DimensionType; import net.minecraft.world.DimensionType;
import net.minecraft.world.World; import net.minecraft.world.World;
import net.minecraftforge.common.DimensionManager; import net.minecraftforge.common.DimensionManager;
import org.dimdev.dimdoors.shared.DDConfig; import org.dimdev.dimdoors.shared.Config;
import org.dimdev.dimdoors.shared.world.limbodimension.WorldProviderLimbo; import org.dimdev.dimdoors.shared.world.limbodimension.WorldProviderLimbo;
import org.dimdev.dimdoors.shared.world.pocketdimension.WorldProviderDungeonPocket; import org.dimdev.dimdoors.shared.world.pocketdimension.WorldProviderDungeonPocket;
import org.dimdev.dimdoors.shared.world.pocketdimension.WorldProviderPersonalPocket; import org.dimdev.dimdoors.shared.world.pocketdimension.WorldProviderPersonalPocket;
@ -26,7 +26,7 @@ public final class ModDimensions {
public static void registerDimensions() { public static void registerDimensions() {
// TODO: more than 1 dimension/dimension type // TODO: more than 1 dimension/dimension type
int dim = DDConfig.getBaseDim(); int dim = Config.getBaseDim();
limboDim = dim++; limboDim = dim++;
privateDim = dim++; privateDim = dim++;
publicDim = dim++; publicDim = dim++;

View file

@ -1,6 +1,6 @@
package org.dimdev.dimdoors.shared.world.gateways; package org.dimdev.dimdoors.shared.world.gateways;
import org.dimdev.dimdoors.shared.DDConfig; import org.dimdev.dimdoors.shared.Config;
import org.dimdev.dimdoors.shared.blocks.ModBlocks; import org.dimdev.dimdoors.shared.blocks.ModBlocks;
import org.dimdev.dimdoors.shared.world.pocketdimension.WorldProviderPocket; import org.dimdev.dimdoors.shared.world.pocketdimension.WorldProviderPocket;
import net.minecraft.block.material.Material; import net.minecraft.block.material.Material;
@ -61,7 +61,7 @@ public class GatewayGenerator implements IWorldGenerator
// Check if we're allowed to generate rift clusters in this dimension. // Check if we're allowed to generate rift clusters in this dimension.
// If so, randomly decide whether to one. // If so, randomly decide whether to one.
if (DDConfig.getRiftClusterDimensions().isAccepted(dimensionID) && random.nextInt(MAX_CLUSTER_GENERATION_CHANCE) < DDConfig.getClusterGenerationChance()) { if (Config.getRiftClusterDimensions().isAccepted(dimensionID) && random.nextInt(MAX_CLUSTER_GENERATION_CHANCE) < Config.getClusterGenerationChance()) {
do { do {
//Pick a random point on the surface of the chunk //Pick a random point on the surface of the chunk
x = chunkX * CHUNK_LENGTH + random.nextInt(CHUNK_LENGTH); x = chunkX * CHUNK_LENGTH + random.nextInt(CHUNK_LENGTH);
@ -84,7 +84,7 @@ public class GatewayGenerator implements IWorldGenerator
// Check if we can place a Rift Gateway in this dimension, then randomly decide whether to place one. // Check if we can place a Rift Gateway in this dimension, then randomly decide whether to place one.
// This only happens if a rift cluster was NOT generated. // This only happens if a rift cluster was NOT generated.
else if (DDConfig.getRiftGatewayDimensions().isAccepted(dimensionID) && random.nextInt(MAX_GATEWAY_GENERATION_CHANCE) < DDConfig.getGatewayGenerationChance()) { else if (Config.getRiftGatewayDimensions().isAccepted(dimensionID) && random.nextInt(MAX_GATEWAY_GENERATION_CHANCE) < Config.getGatewayGenerationChance()) {
valid = false; valid = false;
x = y = z = 0; //Stop the compiler from freaking out x = y = z = 0; //Stop the compiler from freaking out

View file

@ -35,9 +35,9 @@ public class BiomeLimbo extends Biome {
@Override public BiomeDecorator createBiomeDecorator() { return null; } @Override public BiomeDecorator createBiomeDecorator() { return null; }
@Override public void decorate(World worldIn, Random rand, BlockPos pos) {} @Override public void decorate(World world, Random rand, BlockPos pos) {}
@Override public void genTerrainBlocks(World worldIn, Random rand, ChunkPrimer chunkPrimerIn, int x, int z, double noiseVal) {} @Override public void genTerrainBlocks(World world, Random rand, ChunkPrimer chunkPrimer, int x, int z, double noiseVal) {}
@Override @Override
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)

View file

@ -86,7 +86,7 @@ public class LimboGenerator implements IChunkGenerator {
} }
@Override @Override
public boolean generateStructures(Chunk chunkIn, int x, int z) { public boolean generateStructures(Chunk chunk, int x, int z) {
return false; return false;
} }
@ -289,17 +289,17 @@ public class LimboGenerator implements IChunkGenerator {
@Nullable @Nullable
@Override @Override
public BlockPos getNearestStructurePos(World worldIn, String structureName, BlockPos position, boolean findUnexplored) { public BlockPos getNearestStructurePos(World world, String structureName, BlockPos position, boolean findUnexplored) {
return null; return null;
} }
@Override @Override
public void recreateStructures(Chunk chunkIn, int x, int z) { public void recreateStructures(Chunk chunk, int x, int z) {
} }
@Override @Override
public boolean isInsideStructure(World worldIn, String structureName, BlockPos pos) { public boolean isInsideStructure(World world, String structureName, BlockPos pos) {
return false; return false;
} }
} }

View file

@ -21,8 +21,8 @@ public class BiomeBlank extends Biome {
.setBaseHeight(0F) .setBaseHeight(0F)
.setHeightVariation(0F) .setHeightVariation(0F)
.setRainDisabled() .setRainDisabled()
.setRainfall(0)); .setRainfall(0)
// TODO: set water color too? .setWaterColor(white ? 0xFFFFFF : 0x111111));
this.white = white; this.white = white;
topBlock = Blocks.AIR.getDefaultState(); topBlock = Blocks.AIR.getDefaultState();
@ -39,14 +39,14 @@ public class BiomeBlank extends Biome {
@Override public BiomeDecorator createBiomeDecorator() { return null; } // For efficiency @Override public BiomeDecorator createBiomeDecorator() { return null; } // For efficiency
@Override public void decorate(World worldIn, Random rand, BlockPos pos) {} @Override public void decorate(World world, Random rand, BlockPos pos) {}
@Override public void genTerrainBlocks(World worldIn, Random rand, ChunkPrimer chunkPrimerIn, int x, int z, double noiseVal) {} @Override public void genTerrainBlocks(World world, Random rand, ChunkPrimer chunkPrimer, int x, int z, double noiseVal) {}
@Override @Override
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
public int getSkyColorByTemp(float currentTemperature) { public int getSkyColorByTemp(float currentTemperature) {
return white ? 0xFFFFFF : 0x000000; return white ? 0xFCFCFC : 0x000000; // https://bugs.mojang.com/projects/MC/issues/MC-123703
} }
// TODO: check that black/white grass and foliage in getModdedBiomeGrassColor is compatible with other mods such as Quark's greener grass option // TODO: check that black/white grass and foliage in getModdedBiomeGrassColor is compatible with other mods such as Quark's greener grass option

View file

@ -30,15 +30,15 @@ public class ChunkGeneratorBlank implements IChunkGenerator {
public void populate(int x, int z) {} public void populate(int x, int z) {}
@Override @Override
public boolean generateStructures(Chunk chunkIn, int x, int z) { public boolean generateStructures(Chunk chunk, int x, int z) {
return false; return false;
} }
@Override @Nullable public BlockPos getNearestStructurePos(World worldIn, String structureName, BlockPos position, boolean findUnexplored) { return null; } @Override @Nullable public BlockPos getNearestStructurePos(World world, String structureName, BlockPos position, boolean findUnexplored) { return null; }
@Override public void recreateStructures(Chunk chunkIn, int x, int z) {} @Override public void recreateStructures(Chunk chunk, int x, int z) {}
@Override public boolean isInsideStructure(World worldIn, String structureName, BlockPos pos) { return false; } @Override public boolean isInsideStructure(World world, String structureName, BlockPos pos) { return false; }
@Override @Override
public List<Biome.SpawnListEntry> getPossibleCreatures(EnumCreatureType creatureType, BlockPos pos) { public List<Biome.SpawnListEntry> getPossibleCreatures(EnumCreatureType creatureType, BlockPos pos) {

View file

@ -32,12 +32,12 @@ public class WorldProviderPersonalPocket extends WorldProviderPocket {
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
@Override @Override
public Vec3d getSkyColor(Entity cameraEntity, float partialTicks) { public Vec3d getSkyColor(Entity cameraEntity, float partialTicks) {
return new Vec3d(1, 1, 1); return new Vec3d(0.99, 0.99, 0.99); // https://bugs.mojang.com/projects/MC/issues/MC-123703
} }
@Override @Override
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
public Vec3d getFogColor(float celestialAngle, float partialTicks) { public Vec3d getFogColor(float celestialAngle, float partialTicks) {
return new Vec3d(1, 1, 1); return new Vec3d(0.99, 0.99, 0.99); // https://bugs.mojang.com/projects/MC/issues/MC-123703
} }
} }

View file

@ -30,7 +30,7 @@ item.warp_dimensional_door.name=Warp-Tür
item.rift_key=Spaltschlüssel item.rift_key=Spaltschlüssel
item.rift_signature.name=Spaltsignatur item.rift_signature.name=Spaltsignatur
item.stabilized_rift_signature.name=Stabilisierte Spaltsignatur item.stabilized_rift_signature.name=Stabilisierte Spaltsignatur
item.rift_connection_tool.name=Below Average Rift Connection Tool item.rift_configuration_tool.name=Rift Configuration Tool
item.rift_remover.name=Spaltentferner item.rift_remover.name=Spaltentferner
item.rift_blade.name=Spaltklinge item.rift_blade.name=Spaltklinge

View file

@ -31,7 +31,7 @@ item.warp_dimensional_door.name=Warp Door
item.rift_key=Rift Key item.rift_key=Rift Key
item.rift_signature.name=Rift Signature item.rift_signature.name=Rift Signature
item.stabilized_rift_signature.name=Stabilized Rift Signature item.stabilized_rift_signature.name=Stabilized Rift Signature
item.rift_connection_tool.name=Below Average Rift Connection Tool item.rift_configuration_tool.name=Rift Configuration Tool
item.rift_remover.name=Rift Remover item.rift_remover.name=Rift Remover
item.rift_blade.name=Rift Blade item.rift_blade.name=Rift Blade

View file

@ -31,7 +31,7 @@ item.warp_dimensional_door.name=Porte-raccourci
item.rift_key=Clé de fissure item.rift_key=Clé de fissure
item.rift_signature.name=Signature de fissure item.rift_signature.name=Signature de fissure
item.stabilized_rift_signature.name=Signature de fissure stabilisée item.stabilized_rift_signature.name=Signature de fissure stabilisée
item.rift_connection_tool.name=Outil de connexion de fissures sous la moyenne item.rift_configuration_tool.name=Outil de connexion de fissures sous la moyenne
item.rift_remover.name=Enleveur de fissure item.rift_remover.name=Enleveur de fissure
item.rift_blade.name=Lame de fissure item.rift_blade.name=Lame de fissure

View file

@ -30,7 +30,7 @@ item.warp_dimensional_door.name=Porta distorta
item.rift_key=Chiave per frattura item.rift_key=Chiave per frattura
item.rift_signature.name=Segno di frattura item.rift_signature.name=Segno di frattura
item.stabilized_rift_signature.name=Segno di frattura stabilizzato item.stabilized_rift_signature.name=Segno di frattura stabilizzato
item.rift_connection_tool.name=Below Average Rift Connection Tool item.rift_configuration_tool.name=Rift Configuration Tool
item.rift_remover.name=Rimovitore di frattura item.rift_remover.name=Rimovitore di frattura
item.rift_blade.name=Lama dimensionale item.rift_blade.name=Lama dimensionale

View file

@ -30,7 +30,7 @@ item.warp_dimensional_door.name=Verdraaideur
item.rift_key=Scheur Sleutel item.rift_key=Scheur Sleutel
item.rift_signature.name=Scheurtekening item.rift_signature.name=Scheurtekening
item.stabilized_rift_signature.name=Gestabiliseerde Scheurtekening item.stabilized_rift_signature.name=Gestabiliseerde Scheurtekening
item.rift_connection_tool.name=Ondergemiddeld Scheurverbindingsgereedschap item.rift_configuration_tool.name=Ondergemiddeld Scheurverbindingsgereedschap
item.rift_remover.name=Scheurverwijderaar item.rift_remover.name=Scheurverwijderaar
item.rift_blade.name=Scheurkling item.rift_blade.name=Scheurkling

View file

@ -31,7 +31,7 @@ item.warp_dimensional_door.name=Ușă de distorsiune
item.rift_key=Cheie de fisură item.rift_key=Cheie de fisură
item.rift_signature.name=Semnătură de fisură item.rift_signature.name=Semnătură de fisură
item.stabilized_rift_signature.name=Semnătură de fisură stabilizată item.stabilized_rift_signature.name=Semnătură de fisură stabilizată
item.rift_connection_tool.name=Sculă pentru conectarea fisurilor sub medie item.rift_configuration_tool.name=Sculă pentru configurarea fisurilor
item.rift_remover.name=Închizator de fisură item.rift_remover.name=Închizator de fisură
item.rift_blade.name=Lamă de fisură item.rift_blade.name=Lamă de fisură

View file

@ -30,7 +30,7 @@ item.warp_dimensional_door.name=Дверь искажения
item.rift_key=Ключ разлома item.rift_key=Ключ разлома
item.rift_signature.name=Подписыватель разлома item.rift_signature.name=Подписыватель разлома
item.stabilized_rift_signature.name=Стабилизированный подписыватель разлома item.stabilized_rift_signature.name=Стабилизированный подписыватель разлома
item.rift_connection_tool.name=Below Average Rift Connection Tool item.rift_configuration_tool.name=Rift Configuration Tool
item.rift_remover.name=Уничтожитель разломов item.rift_remover.name=Уничтожитель разломов
item.rift_blade.name=Клинок разлома item.rift_blade.name=Клинок разлома

View file

@ -30,7 +30,7 @@ item.warp_dimensional_door.name=扭曲之门
item.rift_key=裂痕钥匙 item.rift_key=裂痕钥匙
item.rift_signature.name=裂痕印记 item.rift_signature.name=裂痕印记
item.stabilized_rift_signature.name=裂痕印记(稳定) item.stabilized_rift_signature.name=裂痕印记(稳定)
item.rift_connection_tool.name=Below Average Rift Connection Tool item.rift_configuration_tool.name=Rift Configuration Tool
item.rift_remover.name=裂痕移除器 item.rift_remover.name=裂痕移除器
item.rift_blade.name=裂痕之刃 item.rift_blade.name=裂痕之刃

View file

@ -1,7 +1,7 @@
{ {
"parent": "builtin/generated", "parent": "builtin/generated",
"textures": { "textures": {
"layer0": "dimdoors:items/rift_connection_tool" "layer0": "dimdoors:items/rift_configuration_tool"
}, },
"display": { "display": {
"thirdperson": { "thirdperson": {

View file

Before

Width:  |  Height:  |  Size: 3.2 KiB

After

Width:  |  Height:  |  Size: 3.2 KiB