commit
472704fe51
4 changed files with 149 additions and 151 deletions
|
@ -1,6 +1,5 @@
|
|||
package StevenDimDoors.mod_pocketDim.ticking;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Random;
|
||||
import java.util.concurrent.ConcurrentLinkedQueue;
|
||||
|
||||
|
@ -65,7 +64,7 @@ public class CustomLimboPopulator implements IRegularTickReceiver {
|
|||
limboWorld = PocketManager.loadDimension(properties.LimboDimensionID);
|
||||
}
|
||||
placeMonolithsInLimbo(limboWorld, location.ChunkX, location.ChunkZ);
|
||||
mod_pocketDim.instance.gatewayGenerator.generate(limboWorld.rand, location.ChunkX, location.ChunkZ,
|
||||
mod_pocketDim.gatewayGenerator.generate(limboWorld.rand, location.ChunkX, location.ChunkZ,
|
||||
limboWorld, limboWorld.getChunkProvider(), limboWorld.getChunkProvider());
|
||||
}
|
||||
else
|
||||
|
|
|
@ -2,22 +2,16 @@ package StevenDimDoors.mod_pocketDim.ticking;
|
|||
|
||||
import java.util.List;
|
||||
|
||||
import net.minecraft.block.Block;
|
||||
import net.minecraft.block.material.Material;
|
||||
import net.minecraft.entity.DataWatcher;
|
||||
import net.minecraft.entity.Entity;
|
||||
import net.minecraft.entity.EntityFlying;
|
||||
import net.minecraft.entity.EntityLiving;
|
||||
import net.minecraft.entity.SharedMonsterAttributes;
|
||||
import net.minecraft.entity.monster.IMob;
|
||||
import net.minecraft.entity.player.EntityPlayer;
|
||||
import net.minecraft.nbt.NBTTagCompound;
|
||||
import net.minecraft.util.AxisAlignedBB;
|
||||
import net.minecraft.util.ChunkCoordinates;
|
||||
import net.minecraft.util.DamageSource;
|
||||
import net.minecraft.util.MathHelper;
|
||||
import net.minecraft.world.World;
|
||||
import net.minecraftforge.common.ForgeHooks;
|
||||
import StevenDimDoors.mod_pocketDim.mod_pocketDim;
|
||||
import StevenDimDoors.mod_pocketDim.config.DDProperties;
|
||||
import StevenDimDoors.mod_pocketDim.core.DDTeleporter;
|
||||
|
@ -27,26 +21,27 @@ import StevenDimDoors.mod_pocketDim.world.PocketProvider;
|
|||
|
||||
public class MobMonolith extends EntityFlying implements IMob
|
||||
{
|
||||
public static final int MAX_AGGRO_RANGE = 35;
|
||||
public static final int MAX_SOUND_COOLDOWN = 200;
|
||||
public static final float MAX_AGGRO = 100;
|
||||
public static final int TEXTURE_STATES = 18;
|
||||
public static final byte MAX_AGGRO = 100;
|
||||
private static final int MAX_TEXTURE_STATE = 18;
|
||||
private static final int MAX_SOUND_COOLDOWN = 200;
|
||||
private static final int MAX_AGGRO_RANGE = 35;
|
||||
private static final int AGGRO_WATCHER_INDEX = 16;
|
||||
|
||||
private static final float WIDTH = 3f;
|
||||
private static final float HEIGHT = 3f;
|
||||
private static final float EYE_HEIGHT = HEIGHT / 2;
|
||||
|
||||
public float pitchLevel;
|
||||
|
||||
public float aggro = 0;
|
||||
private float soundTime = 0;
|
||||
private byte textureState = 0;
|
||||
|
||||
private int aggroMax;
|
||||
private byte aggro = 0;
|
||||
private int soundTime = 0;
|
||||
|
||||
private static DDProperties properties = null;
|
||||
|
||||
public MobMonolith(World par1World)
|
||||
{
|
||||
super(par1World);
|
||||
this.setSize(3F, 3F);
|
||||
this.setSize(WIDTH, HEIGHT);
|
||||
this.noClip = true;
|
||||
this.aggroMax = rand.nextInt(245)+200;
|
||||
if (properties == null)
|
||||
properties = DDProperties.instance();
|
||||
}
|
||||
|
@ -66,10 +61,17 @@ public class MobMonolith extends EntityFlying implements IMob
|
|||
}
|
||||
else
|
||||
{
|
||||
this.aggro = this.aggroMax;
|
||||
this.aggro = MAX_AGGRO;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean canBreatheUnderwater()
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public AxisAlignedBB getBoundingBox()
|
||||
{
|
||||
|
@ -104,22 +106,15 @@ public class MobMonolith extends EntityFlying implements IMob
|
|||
@Override
|
||||
public float getEyeHeight()
|
||||
{
|
||||
return this.height +2F;
|
||||
}
|
||||
|
||||
public void setEntityPosition(Entity entity, double x, double y, double z)
|
||||
{
|
||||
entity.lastTickPosX = entity.prevPosX = entity.posX = x;
|
||||
entity.lastTickPosY = entity.prevPosY = entity.posY = y + entity.yOffset;
|
||||
entity.lastTickPosZ = entity.prevPosZ = entity.posZ = z;
|
||||
entity.setPosition(x, y, z);
|
||||
return EYE_HEIGHT;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void entityInit()
|
||||
{
|
||||
super.entityInit();
|
||||
this.dataWatcher.addObject(16, Byte.valueOf((byte)0));
|
||||
// Add a byte for the aggro level
|
||||
this.dataWatcher.addObject(AGGRO_WATCHER_INDEX, Byte.valueOf((byte) 0));
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -131,73 +126,93 @@ public class MobMonolith extends EntityFlying implements IMob
|
|||
@Override
|
||||
public void onEntityUpdate()
|
||||
{
|
||||
// Remove this Monolith if it's not in Limbo or in a pocket dimension
|
||||
if (!(this.worldObj.provider instanceof LimboProvider || this.worldObj.provider instanceof PocketProvider))
|
||||
{
|
||||
this.setDead();
|
||||
super.onEntityUpdate();
|
||||
return;
|
||||
}
|
||||
|
||||
super.onEntityUpdate();
|
||||
|
||||
EntityPlayer entityPlayer = this.worldObj.getClosestPlayerToEntity(this,MAX_AGGRO_RANGE);
|
||||
// Check for players and update aggro levels even if there are no players in range
|
||||
EntityPlayer player = this.worldObj.getClosestPlayerToEntity(this, MAX_AGGRO_RANGE);
|
||||
boolean visibility = (player != null) ? this.canEntityBeSeen(player) : false;
|
||||
this.updateAggroLevel(player, visibility);
|
||||
|
||||
//need to always manage aggro level, even if player is out of range.
|
||||
this.setAggroLevel(entityPlayer);
|
||||
|
||||
//these things only matter if the player is in range.
|
||||
if (entityPlayer != null)
|
||||
{
|
||||
this.faceEntity(entityPlayer, 1, 1);
|
||||
this.playSounds(entityPlayer);
|
||||
//teleport the player if the conditions are met
|
||||
if (aggro >= MAX_AGGRO && !this.worldObj.isRemote && properties.MonolithTeleportationEnabled && !entityPlayer.capabilities.isCreativeMode)
|
||||
{
|
||||
Point4D destination = LimboProvider.getLimboSkySpawn(entityPlayer, properties);
|
||||
DDTeleporter.teleportEntity(entityPlayer, destination, false);
|
||||
this.aggro = 0;
|
||||
entityPlayer.worldObj.playSoundAtEntity(entityPlayer,mod_pocketDim.modid+":crack",13, 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void setAggroLevel(EntityPlayer player)
|
||||
{
|
||||
//aggro constantly decreases at a rate that varies with the current amount of aggro.
|
||||
if(aggro > 0)
|
||||
{
|
||||
this.aggro = this.aggro -(this.aggro/25);
|
||||
}
|
||||
// Change orientation and face a player if one is in range
|
||||
if (player != null)
|
||||
{
|
||||
//monoliths increase aggro slightly if the player is near, but slowly and to a cap.
|
||||
float distance = this.getDistanceToEntity(player);
|
||||
aggro+= 1.5-(distance/this.MAX_AGGRO_RANGE);
|
||||
this.facePlayer(player);
|
||||
this.playSounds(player);
|
||||
|
||||
//rapidly increase aggro if the monolith has line of sight to the player.
|
||||
if(player.canEntityBeSeen(this))
|
||||
if (visibility)
|
||||
{
|
||||
this.spawnParticles(player);
|
||||
|
||||
// Teleport the target player if various conditions are met
|
||||
if (aggro >= MAX_AGGRO && !this.worldObj.isRemote &&
|
||||
properties.MonolithTeleportationEnabled && !player.capabilities.isCreativeMode)
|
||||
{
|
||||
this.aggro = 0;
|
||||
Point4D destination = LimboProvider.getLimboSkySpawn(player, properties);
|
||||
DDTeleporter.teleportEntity(player, destination, false);
|
||||
player.worldObj.playSoundAtEntity(player, mod_pocketDim.modid + ":crack", 13, 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void updateAggroLevel(EntityPlayer player, boolean visibility)
|
||||
{
|
||||
// If we're working on the server side, adjust aggro level
|
||||
// If we're working on the client side, retrieve aggro level from dataWatcher
|
||||
if (!this.worldObj.isRemote)
|
||||
{
|
||||
// Server side...
|
||||
if (player != null)
|
||||
{
|
||||
// Rapidly increase the aggro level if this Monolith can see the player
|
||||
if (visibility)
|
||||
{
|
||||
//prevent monoliths from teleporting the player in limbo
|
||||
if (this.worldObj.provider instanceof LimboProvider)
|
||||
{
|
||||
aggro+=1.5;
|
||||
// Don't spawn particles in Limbo since we won't teleport the player
|
||||
aggro += 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
this.spawnParticles(player);
|
||||
aggro+=3;
|
||||
// Aggro increases faster outside of Limbo
|
||||
aggro += 2;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
// Aggro increases slightly if the player is nearby, but this increase is capped
|
||||
aggro += 2 - (this.getDistanceToEntity(player) / MAX_AGGRO_RANGE);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
// Decrease aggro over time
|
||||
aggro *= 0.98;
|
||||
}
|
||||
// Clamp the aggro level
|
||||
aggro = (byte) MathHelper.clamp_int(aggro, 0, MAX_AGGRO_RANGE);
|
||||
this.dataWatcher.updateObject(AGGRO_WATCHER_INDEX, Byte.valueOf(aggro));
|
||||
}
|
||||
else
|
||||
{
|
||||
// Client side...
|
||||
aggro = this.dataWatcher.getWatchableObjectByte(AGGRO_WATCHER_INDEX);
|
||||
}
|
||||
}
|
||||
|
||||
//convert the aggro counter to one of the texture states, and set it.
|
||||
this.textureState = (byte) ((this.TEXTURE_STATES/this.MAX_AGGRO)*this.aggro);
|
||||
if(this.textureState>TEXTURE_STATES)
|
||||
public int getTextureState()
|
||||
{
|
||||
textureState = TEXTURE_STATES;
|
||||
}
|
||||
if (!this.worldObj.isRemote)
|
||||
{
|
||||
this.dataWatcher.updateObject(16, Byte.valueOf(this.textureState));
|
||||
}
|
||||
// Determine texture state from aggro progress
|
||||
return MathHelper.clamp_int(MAX_TEXTURE_STATE * aggro / MAX_AGGRO, 0, MAX_TEXTURE_STATE);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -206,18 +221,18 @@ public class MobMonolith extends EntityFlying implements IMob
|
|||
*/
|
||||
private void playSounds(EntityPlayer entityPlayer)
|
||||
{
|
||||
float aggroPercent = (aggro/MAX_AGGRO);
|
||||
float aggroPercent = this.getAggroProgress();
|
||||
if (this.soundTime <= 0)
|
||||
{
|
||||
this.playSound(mod_pocketDim.modid + ":monk", 1F, 1F);
|
||||
this.soundTime = 100;
|
||||
}
|
||||
if ((aggroPercent>.70)&&this.soundTime<100)
|
||||
if ((aggroPercent > 0.70) && this.soundTime < 100)
|
||||
{
|
||||
this.worldObj.playSoundEffect(entityPlayer.posX, entityPlayer.posY, entityPlayer.posZ, mod_pocketDim.modid + ":tearing", 1F, (float) (1 + this.rand.nextGaussian()));
|
||||
this.soundTime = 100 + this.rand.nextInt(75);
|
||||
}
|
||||
if ((aggroPercent>.90)&&this.soundTime<200)
|
||||
if ((aggroPercent > 0.90) && this.soundTime < 200)
|
||||
{
|
||||
this.worldObj.playSoundEffect(entityPlayer.posX, entityPlayer.posY, entityPlayer.posZ, mod_pocketDim.modid + ":tearing", 7, 1F);
|
||||
this.soundTime = 250;
|
||||
|
@ -227,7 +242,8 @@ public class MobMonolith extends EntityFlying implements IMob
|
|||
|
||||
private void spawnParticles(EntityPlayer player)
|
||||
{
|
||||
for (int i = 1; i < (10*(aggro/MAX_AGGRO)); ++i)
|
||||
int count = 10 * aggro / MAX_AGGRO;
|
||||
for (int i = 1; i < count; ++i)
|
||||
{
|
||||
player.worldObj.spawnParticle("portal", player.posX + (this.rand.nextDouble() - 0.5D) * this.width,
|
||||
player.posY + this.rand.nextDouble() * player.height - 0.75D,
|
||||
|
@ -237,43 +253,38 @@ public class MobMonolith extends EntityFlying implements IMob
|
|||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void faceEntity(Entity par1Entity, float par2, float par3)
|
||||
public float getAggroProgress()
|
||||
{
|
||||
double d0 = par1Entity.posX - this.posX;
|
||||
double d1 = par1Entity.posZ - this.posZ;
|
||||
double d2 = (par1Entity.posY + par1Entity.getEyeHeight()) - (this.posY +this.getEyeHeight());
|
||||
return ((float) aggro) / MAX_AGGRO;
|
||||
}
|
||||
|
||||
private void facePlayer(EntityPlayer player)
|
||||
{
|
||||
double d0 = player.posX - this.posX;
|
||||
double d1 = player.posZ - this.posZ;
|
||||
double d2 = (player.posY + player.getEyeHeight()) - (this.posY + this.getEyeHeight());
|
||||
double d3 = MathHelper.sqrt_double(d0 * d0 + d1 * d1);
|
||||
float f2 = (float)(Math.atan2(d1, d0) * 180.0D / Math.PI) - 90.0F;
|
||||
this.pitchLevel = (float) -((Math.atan(d2/d3) )* 180.0D / Math.PI);
|
||||
|
||||
this.rotationYaw = f2;
|
||||
this.rotationYawHead = f2;
|
||||
this.renderYawOffset = this.rotationYaw;
|
||||
}
|
||||
|
||||
|
||||
|
||||
@Override
|
||||
public void writeEntityToNBT(NBTTagCompound par1NBTTagCompound)
|
||||
public void writeEntityToNBT(NBTTagCompound rootTag)
|
||||
{
|
||||
super.writeEntityToNBT(par1NBTTagCompound);
|
||||
par1NBTTagCompound.setFloat("soundTime", this.soundTime);
|
||||
par1NBTTagCompound.setFloat("aggro", this.aggro);
|
||||
par1NBTTagCompound.setInteger("aggroMax", this.aggroMax);
|
||||
par1NBTTagCompound.setByte("textureState", this.textureState);
|
||||
super.writeEntityToNBT(rootTag);
|
||||
rootTag.setInteger("Aggro", this.aggro);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void readEntityFromNBT(NBTTagCompound par1NBTTagCompound)
|
||||
public void readEntityFromNBT(NBTTagCompound rootTag)
|
||||
{
|
||||
super.readEntityFromNBT(par1NBTTagCompound);
|
||||
this.soundTime = par1NBTTagCompound.getFloat("soundTime");
|
||||
super.readEntityFromNBT(rootTag);
|
||||
|
||||
//make them load with half aggro so they dont instantly teleport players
|
||||
this.aggro = par1NBTTagCompound.getFloat("aggro")/2;
|
||||
this.aggroMax = par1NBTTagCompound.getInteger("aggroMax");
|
||||
this.textureState = par1NBTTagCompound.getByte("textureState");
|
||||
// Load Monoliths with half aggro so they don't teleport players instantly
|
||||
this.aggro = (byte) (rootTag.getInteger("Aggro") / 2);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -302,9 +313,4 @@ public class MobMonolith extends EntityFlying implements IMob
|
|||
this.worldObj.getCollidingBoundingBoxes(this, this.boundingBox).isEmpty() &&
|
||||
!this.worldObj.isAnyLiquid(this.boundingBox);
|
||||
}
|
||||
|
||||
public DataWatcher getDataWatcher()
|
||||
{
|
||||
return this.dataWatcher;
|
||||
}
|
||||
}
|
|
@ -33,7 +33,7 @@ public class RiftRegenerator implements IRegularTickReceiver {
|
|||
{
|
||||
// Regenerate rifts that have been replaced (not permanently removed) by players
|
||||
// Only do this in dimensions that are currently loaded
|
||||
List<Integer> loadedWorlds = (List<Integer>) Arrays.asList(DimensionManager.getIDs());
|
||||
List<Integer> loadedWorlds = Arrays.asList(DimensionManager.getIDs());
|
||||
for (Integer dimensionID : loadedWorlds)
|
||||
{
|
||||
NewDimData dimension = PocketManager.getDimensionData(dimensionID);
|
||||
|
|
|
@ -1,22 +1,19 @@
|
|||
package StevenDimDoors.mod_pocketDimClient;
|
||||
|
||||
import net.minecraft.client.Minecraft;
|
||||
import net.minecraft.client.renderer.OpenGlHelper;
|
||||
import net.minecraft.client.renderer.entity.RenderLiving;
|
||||
import net.minecraft.entity.Entity;
|
||||
import net.minecraft.entity.EntityLiving;
|
||||
import net.minecraft.util.ResourceLocation;
|
||||
import net.minecraftforge.client.event.RenderLivingEvent;
|
||||
import net.minecraftforge.common.MinecraftForge;
|
||||
|
||||
import org.lwjgl.opengl.GL11;
|
||||
import org.lwjgl.opengl.GL12;
|
||||
|
||||
import StevenDimDoors.mod_pocketDim.mod_pocketDim;
|
||||
import StevenDimDoors.mod_pocketDim.ticking.MobMonolith;
|
||||
import net.minecraft.client.Minecraft;
|
||||
import net.minecraft.client.renderer.OpenGlHelper;
|
||||
import net.minecraft.client.renderer.Tessellator;
|
||||
import net.minecraft.client.renderer.entity.RenderLiving;
|
||||
import net.minecraft.entity.Entity;
|
||||
import net.minecraft.entity.EntityHanging;
|
||||
import net.minecraft.entity.EntityLiving;
|
||||
import net.minecraft.entity.EntityLivingBase;
|
||||
import net.minecraft.util.MathHelper;
|
||||
import net.minecraft.util.ResourceLocation;
|
||||
import net.minecraftforge.client.event.RenderLivingEvent;
|
||||
import net.minecraftforge.common.MinecraftForge;
|
||||
import cpw.mods.fml.relauncher.Side;
|
||||
import cpw.mods.fml.relauncher.SideOnly;
|
||||
|
||||
|
@ -31,15 +28,15 @@ public class RenderMobObelisk extends RenderLiving
|
|||
this.obeliskModel = (ModelMobObelisk)this.mainModel;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void doRenderLiving(EntityLiving entity, double x, double y, double z, float par8, float par9)
|
||||
{
|
||||
final float minScaling = 0;
|
||||
final float maxScaling = 0.1f;
|
||||
final int maxAggroLevel = 500;
|
||||
MobMonolith monolith = ((MobMonolith) entity);
|
||||
|
||||
// Use linear interpolation to scale how much jitter we want for our given aggro level
|
||||
float aggroScaling = minScaling + monolith.aggro * (maxScaling - minScaling) / maxAggroLevel;
|
||||
float aggroScaling = minScaling + (maxScaling - minScaling) * monolith.getAggroProgress();
|
||||
|
||||
// Calculate jitter - include entity ID to give Monoliths individual jitters
|
||||
float time = ((Minecraft.getSystemTime() + 0xF1234568 * monolith.entityId) % 200000) / 50.0F;
|
||||
|
@ -67,8 +64,8 @@ public class RenderMobObelisk extends RenderLiving
|
|||
|
||||
try
|
||||
{
|
||||
float interpolatedYaw = this.interpolateRotation(par1EntityLivingBase.prevRenderYawOffset, par1EntityLivingBase.renderYawOffset, par9);
|
||||
float interpolatedYawHead = this.interpolateRotation(par1EntityLivingBase.prevRotationYawHead, par1EntityLivingBase.rotationYawHead, par9);
|
||||
float interpolatedYaw = interpolateRotation(par1EntityLivingBase.prevRenderYawOffset, par1EntityLivingBase.renderYawOffset, par9);
|
||||
float interpolatedYawHead = interpolateRotation(par1EntityLivingBase.prevRotationYawHead, par1EntityLivingBase.rotationYawHead, par9);
|
||||
float rotation;
|
||||
float pitch = par1EntityLivingBase.prevRotationPitch + (par1EntityLivingBase.rotationPitch - par1EntityLivingBase.prevRotationPitch) * par9;
|
||||
this.renderLivingAt(par1EntityLivingBase, x, y, z);
|
||||
|
@ -109,28 +106,24 @@ public class RenderMobObelisk extends RenderLiving
|
|||
MinecraftForge.EVENT_BUS.post(new RenderLivingEvent.Post(par1EntityLivingBase, this));
|
||||
}
|
||||
|
||||
|
||||
private float interpolateRotation(float par1, float par2, float par3)
|
||||
private static float interpolateRotation(float par1, float par2, float par3)
|
||||
{
|
||||
float f3;
|
||||
|
||||
for (f3 = par2 - par1; f3 < -180.0F; f3 += 360.0F)
|
||||
float f3 = par2 - par1;
|
||||
while (f3 < -180.0f)
|
||||
{
|
||||
;
|
||||
f3 += 360.0F;
|
||||
}
|
||||
|
||||
while (f3 >= 180.0F)
|
||||
{
|
||||
f3 -= 360.0F;
|
||||
}
|
||||
|
||||
return par1 + par3 * f3;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected ResourceLocation getEntityTexture(Entity entity)
|
||||
{
|
||||
byte b0 = entity.getDataWatcher().getWatchableObjectByte(16);
|
||||
|
||||
return new ResourceLocation(mod_pocketDim.modid+":textures/mobs/Monolith"+b0+".png");
|
||||
MobMonolith monolith = (MobMonolith) entity;
|
||||
return new ResourceLocation(mod_pocketDim.modid + ":textures/mobs/Monolith" + monolith.getTextureState() + ".png");
|
||||
}
|
||||
}
|
Loading…
Add table
Reference in a new issue