smooth sailing on conveyor belts
8
src/main/java/api/hbm/conveyor/IConveyorItem.java
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
package api.hbm.conveyor;
|
||||||
|
|
||||||
|
import net.minecraft.item.ItemStack;
|
||||||
|
|
||||||
|
public interface IConveyorItem {
|
||||||
|
|
||||||
|
public ItemStack getItemStack();
|
||||||
|
}
|
||||||
9
src/main/java/api/hbm/conveyor/IEnterableBlock.java
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
package api.hbm.conveyor;
|
||||||
|
|
||||||
|
import net.minecraftforge.common.util.ForgeDirection;
|
||||||
|
|
||||||
|
public interface IEnterableBlock {
|
||||||
|
|
||||||
|
public boolean canEnter(IConveyorItem entity, ForgeDirection dir);
|
||||||
|
public void onEnter(IConveyorItem entity, ForgeDirection dir);
|
||||||
|
}
|
||||||
@ -2,6 +2,9 @@ package com.hbm.entity.item;
|
|||||||
|
|
||||||
import com.hbm.blocks.ModBlocks;
|
import com.hbm.blocks.ModBlocks;
|
||||||
|
|
||||||
|
import api.hbm.conveyor.IConveyorItem;
|
||||||
|
import cpw.mods.fml.relauncher.Side;
|
||||||
|
import cpw.mods.fml.relauncher.SideOnly;
|
||||||
import net.minecraft.entity.Entity;
|
import net.minecraft.entity.Entity;
|
||||||
import net.minecraft.entity.item.EntityItem;
|
import net.minecraft.entity.item.EntityItem;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
@ -12,138 +15,179 @@ import net.minecraft.util.DamageSource;
|
|||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
import net.minecraftforge.common.util.ForgeDirection;
|
import net.minecraftforge.common.util.ForgeDirection;
|
||||||
|
|
||||||
public class EntityMovingItem extends Entity {
|
public class EntityMovingItem extends Entity implements IConveyorItem {
|
||||||
|
|
||||||
|
private int turnProgress;
|
||||||
|
private double syncPosX;
|
||||||
|
private double syncPosY;
|
||||||
|
private double syncPosZ;
|
||||||
|
@SideOnly(Side.CLIENT)
|
||||||
|
private double velocityX;
|
||||||
|
@SideOnly(Side.CLIENT)
|
||||||
|
private double velocityY;
|
||||||
|
@SideOnly(Side.CLIENT)
|
||||||
|
private double velocityZ;
|
||||||
|
|
||||||
public EntityMovingItem(World p_i1582_1_) {
|
public EntityMovingItem(World p_i1582_1_) {
|
||||||
super(p_i1582_1_);
|
super(p_i1582_1_);
|
||||||
this.setSize(0.5F, 0.25F);
|
this.setSize(0.5F, 0.5F);
|
||||||
this.noClip = true;
|
this.noClip = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setItemStack(ItemStack stack) {
|
public void setItemStack(ItemStack stack) {
|
||||||
|
|
||||||
this.getDataWatcher().updateObject(10, stack);
|
this.getDataWatcher().updateObject(10, stack);
|
||||||
this.getDataWatcher().setObjectWatched(10);
|
this.getDataWatcher().setObjectWatched(10);
|
||||||
}
|
}
|
||||||
|
|
||||||
public ItemStack getItemStack() {
|
public ItemStack getItemStack() {
|
||||||
|
|
||||||
ItemStack stack = this.getDataWatcher().getWatchableObjectItemStack(10);
|
ItemStack stack = this.getDataWatcher().getWatchableObjectItemStack(10);
|
||||||
return stack == null ? new ItemStack(Blocks.stone) : stack;
|
return stack == null ? new ItemStack(Blocks.stone) : stack;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean canBeCollidedWith() {
|
public boolean canBeCollidedWith() {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean interactFirst(EntityPlayer player) {
|
public boolean interactFirst(EntityPlayer player) {
|
||||||
|
|
||||||
if(!worldObj.isRemote && player.inventory.addItemStackToInventory(this.getItemStack().copy())) {
|
if(!worldObj.isRemote && player.inventory.addItemStackToInventory(this.getItemStack().copy())) {
|
||||||
this.setDead();
|
this.setDead();
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean attackEntityFrom(DamageSource source, float amount) {
|
public boolean attackEntityFrom(DamageSource source, float amount) {
|
||||||
|
|
||||||
if(!worldObj.isRemote) {
|
if(!worldObj.isRemote) {
|
||||||
this.setDead();
|
this.setDead();
|
||||||
worldObj.spawnEntityInWorld(new EntityItem(worldObj, posX, posY, posZ, this.getItemStack()));
|
worldObj.spawnEntityInWorld(new EntityItem(worldObj, posX, posY, posZ, this.getItemStack()));
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean canAttackWithItem() {
|
public boolean canAttackWithItem() {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean hitByEntity(Entity attacker) {
|
public boolean hitByEntity(Entity attacker) {
|
||||||
|
|
||||||
if(attacker instanceof EntityPlayer) {
|
if(attacker instanceof EntityPlayer) {
|
||||||
}
|
}
|
||||||
|
|
||||||
this.setDead();
|
this.setDead();
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected boolean canTriggerWalking() {
|
protected boolean canTriggerWalking() {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
private int schedule = 0;
|
private int schedule = 0;
|
||||||
|
|
||||||
public void onUpdate() {
|
public void onUpdate() {
|
||||||
|
|
||||||
if(!worldObj.isRemote) {
|
if(worldObj.isRemote) {
|
||||||
|
if(this.turnProgress > 0) {
|
||||||
|
double interpX = this.posX + (this.syncPosX - this.posX) / (double) this.turnProgress;
|
||||||
|
double interpY = this.posY + (this.syncPosY - this.posY) / (double) this.turnProgress;
|
||||||
|
double interpZ = this.posZ + (this.syncPosZ - this.posZ) / (double) this.turnProgress;
|
||||||
|
--this.turnProgress;
|
||||||
|
this.setPosition(interpX, interpY, interpZ);
|
||||||
|
} else {
|
||||||
|
this.setPosition(this.posX, this.posY, this.posZ);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if(worldObj.getBlock((int)Math.floor(posX), (int)Math.floor(posY), (int)Math.floor(posZ)) != ModBlocks.conveyor) {
|
if(!worldObj.isRemote) {
|
||||||
this.setDead();
|
|
||||||
EntityItem item = new EntityItem(worldObj, posX, posY, posZ, this.getItemStack());
|
|
||||||
item.motionX = this.motionX * 3;
|
|
||||||
item.motionY = 0.1;
|
|
||||||
item.motionZ = this.motionZ * 3;
|
|
||||||
item.velocityChanged = true;
|
|
||||||
worldObj.spawnEntityInWorld(item);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(worldObj.getBlock((int)Math.floor(posX), (int)Math.floor(posY), (int)Math.floor(posZ)) == ModBlocks.conveyor) {
|
if(worldObj.getBlock((int) Math.floor(posX), (int) Math.floor(posY), (int) Math.floor(posZ)) != ModBlocks.conveyor) {
|
||||||
|
this.setDead();
|
||||||
|
EntityItem item = new EntityItem(worldObj, posX, posY, posZ, this.getItemStack());
|
||||||
|
item.motionX = this.motionX * 3;
|
||||||
|
item.motionY = 0.1;
|
||||||
|
item.motionZ = this.motionZ * 3;
|
||||||
|
item.velocityChanged = true;
|
||||||
|
worldObj.spawnEntityInWorld(item);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if(schedule <= 0) {
|
if(worldObj.getBlock((int) Math.floor(posX), (int) Math.floor(posY), (int) Math.floor(posZ)) == ModBlocks.conveyor) {
|
||||||
ForgeDirection dir = ForgeDirection.getOrientation(worldObj.getBlockMetadata((int)Math.floor(posX), (int)Math.floor(posY), (int)Math.floor(posZ)));
|
|
||||||
|
|
||||||
if(worldObj.getBlock((int)Math.floor(posX), (int)Math.floor(posY) + 1, (int)Math.floor(posZ)) == ModBlocks.conveyor && motionY >= 0) {
|
if(schedule <= 0) {
|
||||||
dir = ForgeDirection.DOWN;
|
ForgeDirection dir = ForgeDirection.getOrientation(worldObj.getBlockMetadata((int) Math.floor(posX), (int) Math.floor(posY), (int) Math.floor(posZ)));
|
||||||
}
|
|
||||||
|
|
||||||
if(worldObj.getBlock((int)Math.floor(posX), (int)Math.floor(posY) - 1, (int)Math.floor(posZ)) == ModBlocks.conveyor && motionY <= 0) {
|
if(worldObj.getBlock((int) Math.floor(posX), (int) Math.floor(posY) + 1, (int) Math.floor(posZ)) == ModBlocks.conveyor && motionY >= 0) {
|
||||||
dir = ForgeDirection.UP;
|
dir = ForgeDirection.DOWN;
|
||||||
}
|
}
|
||||||
|
|
||||||
double speed = 0.0625;
|
if(worldObj.getBlock((int) Math.floor(posX), (int) Math.floor(posY) - 1, (int) Math.floor(posZ)) == ModBlocks.conveyor && motionY <= 0) {
|
||||||
|
dir = ForgeDirection.UP;
|
||||||
|
}
|
||||||
|
|
||||||
schedule = (int) (1 / speed);
|
double speed = 0.0625;
|
||||||
motionX = -speed * dir.offsetX;
|
|
||||||
motionY = -speed * dir.offsetY;
|
|
||||||
motionZ = -speed * dir.offsetZ;
|
|
||||||
|
|
||||||
this.velocityChanged = true;
|
schedule = (int) (1 / speed);
|
||||||
}
|
motionX = -speed * dir.offsetX;
|
||||||
|
motionY = -speed * dir.offsetY;
|
||||||
|
motionZ = -speed * dir.offsetZ;
|
||||||
|
|
||||||
schedule--;
|
this.velocityChanged = true;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
this.moveEntity(motionX, motionY, motionZ);
|
schedule--;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.moveEntity(motionX, motionY, motionZ);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SideOnly(Side.CLIENT)
|
||||||
|
public void setVelocity(double p_70016_1_, double p_70016_3_, double p_70016_5_) {
|
||||||
|
this.velocityX = this.motionX = p_70016_1_;
|
||||||
|
this.velocityY = this.motionY = p_70016_3_;
|
||||||
|
this.velocityZ = this.motionZ = p_70016_5_;
|
||||||
|
}
|
||||||
|
|
||||||
|
@SideOnly(Side.CLIENT)
|
||||||
|
public void setPositionAndRotation2(double x, double y, double z, float yaw, float pitch, int theNumberThree) {
|
||||||
|
this.syncPosX = x;
|
||||||
|
this.syncPosY = y;
|
||||||
|
this.syncPosZ = z;
|
||||||
|
this.turnProgress = theNumberThree + 7; //use 4-ply for extra smoothness
|
||||||
|
this.motionX = this.velocityX;
|
||||||
|
this.motionY = this.velocityY;
|
||||||
|
this.motionZ = this.velocityZ;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void entityInit() {
|
protected void entityInit() {
|
||||||
this.getDataWatcher().addObjectByDataType(10, 5);
|
this.getDataWatcher().addObjectByDataType(10, 5);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void readEntityFromNBT(NBTTagCompound nbt) {
|
protected void readEntityFromNBT(NBTTagCompound nbt) {
|
||||||
|
|
||||||
NBTTagCompound compound = nbt.getCompoundTag("Item");
|
NBTTagCompound compound = nbt.getCompoundTag("Item");
|
||||||
this.setItemStack(ItemStack.loadItemStackFromNBT(compound));
|
this.setItemStack(ItemStack.loadItemStackFromNBT(compound));
|
||||||
|
|
||||||
ItemStack stack = getDataWatcher().getWatchableObjectItemStack(10);
|
ItemStack stack = getDataWatcher().getWatchableObjectItemStack(10);
|
||||||
|
|
||||||
schedule = nbt.getInteger("schedule");
|
schedule = nbt.getInteger("schedule");
|
||||||
|
|
||||||
if (stack == null || stack.stackSize <= 0)
|
if(stack == null || stack.stackSize <= 0)
|
||||||
this.setDead();
|
this.setDead();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void writeEntityToNBT(NBTTagCompound nbt) {
|
protected void writeEntityToNBT(NBTTagCompound nbt) {
|
||||||
|
|
||||||
if (this.getItemStack() != null)
|
if(this.getItemStack() != null)
|
||||||
nbt.setTag("Item", this.getItemStack().writeToNBT(new NBTTagCompound()));
|
nbt.setTag("Item", this.getItemStack().writeToNBT(new NBTTagCompound()));
|
||||||
|
|
||||||
nbt.setInteger("schedule", schedule);
|
nbt.setInteger("schedule", schedule);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 246 B After Width: | Height: | Size: 239 B |
|
Before Width: | Height: | Size: 256 B After Width: | Height: | Size: 199 B |
|
Before Width: | Height: | Size: 177 B After Width: | Height: | Size: 176 B |
|
Before Width: | Height: | Size: 134 B After Width: | Height: | Size: 162 B |