Finished ItemRiftBlade.

This commit is contained in:
zangamj 2016-08-03 15:44:21 -04:00
parent 1fd82190b5
commit 6f2d0a9018
3 changed files with 71 additions and 117 deletions

View file

@ -3,22 +3,16 @@ package com.zixiken.dimdoors.items;
import java.util.List; import java.util.List;
import com.zixiken.dimdoors.DimDoors; import com.zixiken.dimdoors.DimDoors;
import com.zixiken.dimdoors.config.DDProperties;
import com.zixiken.dimdoors.core.PocketManager; import com.zixiken.dimdoors.core.PocketManager;
import net.minecraft.client.renderer.texture.IIconRegister;
import net.minecraft.entity.Entity; import net.minecraft.entity.Entity;
import net.minecraft.entity.EntityLiving; import net.minecraft.entity.EntityLiving;
import net.minecraft.entity.player.EntityPlayer; import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.entity.player.EntityPlayerMP;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import net.minecraft.item.ItemSword; import net.minecraft.item.ItemSword;
import net.minecraft.util.AxisAlignedBB; import net.minecraft.util.*;
import net.minecraft.util.MathHelper;
import net.minecraft.util.MovingObjectPosition;
import net.minecraft.util.Vec3;
import net.minecraft.world.World; import net.minecraft.world.World;
import cpw.mods.fml.relauncher.Side; import net.minecraftforge.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly; import net.minecraftforge.fml.relauncher.SideOnly;
public class ItemRiftBlade extends ItemSword { public class ItemRiftBlade extends ItemSword {
public static final String ID = "itemRiftBlade"; public static final String ID = "itemRiftBlade";
@ -31,85 +25,48 @@ public class ItemRiftBlade extends ItemSword {
@Override @Override
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
public boolean hasEffect(ItemStack par1ItemStack) public boolean hasEffect(ItemStack stack) {return true;}
{
return true;
}
@Override private boolean teleportToEntity(ItemStack item, Entity entity, EntityPlayer player) {
public MovingObjectPosition getMovingObjectPositionFromPlayer(World par1World, EntityPlayer par2EntityPlayer, boolean par3) Vec3 vec1 = new Vec3(player.posX-entity.posX,
{ player.getEntityBoundingBox().minY+player.height / 2.0F-entity.posY+entity.getEyeHeight(),
float var4 = 1.0F; player.posZ-entity.posZ);
float var5 = par2EntityPlayer.prevRotationPitch + (par2EntityPlayer.rotationPitch - par2EntityPlayer.prevRotationPitch) * var4;
float var6 = par2EntityPlayer.prevRotationYaw + (par2EntityPlayer.rotationYaw - par2EntityPlayer.prevRotationYaw) * var4;
double var7 = par2EntityPlayer.prevPosX + (par2EntityPlayer.posX - par2EntityPlayer.prevPosX) * var4;
double var9 = par2EntityPlayer.prevPosY + (par2EntityPlayer.posY - par2EntityPlayer.prevPosY) * var4 + 1.62D - par2EntityPlayer.yOffset;
double var11 = par2EntityPlayer.prevPosZ + (par2EntityPlayer.posZ - par2EntityPlayer.prevPosZ) * var4;
Vec3 var13 = Vec3.createVectorHelper(var7, var9, var11);
float var14 = MathHelper.cos(-var6 * 0.017453292F - (float)Math.PI);
float var15 = MathHelper.sin(-var6 * 0.017453292F - (float)Math.PI);
float var16 = -MathHelper.cos(-var5 * 0.017453292F);
float var17 = MathHelper.sin(-var5 * 0.017453292F);
float var18 = var15 * var16;
float var20 = var14 * var16;
double var21 = 5.0D;
if (par2EntityPlayer instanceof EntityPlayerMP)
{
var21 = 7;
}
Vec3 var23 = var13.addVector(var18 * var21, var17 * var21, var20 * var21);
return par1World.rayTraceBlocks(var13, var23, true);
}
private boolean teleportToEntity(ItemStack item, Entity par1Entity, EntityPlayer holder) double coef = (vec1.lengthVector()-2.5) / vec1.lengthVector();
{ Vec3 vec2 = new Vec3(vec1.xCoord*coef, vec1.yCoord*coef, vec1.zCoord*coef);
Vec3 var2 = Vec3.createVectorHelper(holder.posX - par1Entity.posX, holder.boundingBox.minY + holder.height / 2.0F - par1Entity.posY + par1Entity.getEyeHeight(), holder.posZ - par1Entity.posZ);
double cooef =( var2.lengthVector()-2.5)/var2.lengthVector(); double x = player.posX - vec2.xCoord;
var2.xCoord*=cooef; double y = player.posY - vec2.yCoord;
var2.yCoord*=cooef; double z = player.posZ - vec2.zCoord;
var2.zCoord*=cooef;
double var5 = holder.posX - var2.xCoord;
double var9 = holder.posZ - var2.zCoord;
BlockPos pos = new BlockPos(MathHelper.floor_double(x),
MathHelper.floor_double(y),
MathHelper.floor_double(z));
while(!player.worldObj.isAirBlock(pos)) {pos = pos.up();}
double var7 = MathHelper.floor_double(holder.posY - var2.yCoord) ; y = pos.getY();
player.setPositionAndUpdate(x, y, z);
int var14 = MathHelper.floor_double(var5); player.playSound("mob.endermen.portal", 1.0F, 1.0F);
int var15 = MathHelper.floor_double(var7); player.worldObj.playSoundEffect(player.posX, player.posY, player.posZ, "mob.endermen.portal", 1.0F, 1.0F);
int var16 = MathHelper.floor_double(var9);
while(!holder.worldObj.isAirBlock(var14, var15, var16))
{
var15++;
}
var7=var15;
holder.setPositionAndUpdate(var5, var7, var9);
holder.playSound("mob.endermen.portal", 1.0F, 1.0F);
holder.worldObj.playSoundEffect(holder.posX, holder.posY, holder.posZ, "mob.endermen.portal", 1.0F, 1.0F);
return true; return true;
} }
@Override @Override
public ItemStack onItemRightClick(ItemStack stack, World world, EntityPlayer player) public ItemStack onItemRightClick(ItemStack stack, World world, EntityPlayer player) {
{ if (!world.isRemote) {
if (!world.isRemote) List<EntityLiving> list = world.getEntitiesWithinAABB(EntityLiving.class, new AxisAlignedBB(
{ player.posX-10, player.posY-10, player.posZ-10, player.posX+10, player.posY+10, player.posZ+10));
@SuppressWarnings("unchecked")
List<EntityLiving> list = world.getEntitiesWithinAABB(EntityLiving.class, AxisAlignedBB.getBoundingBox(player.posX-10,player.posY-10, player.posZ-10, player.posX+10,player.posY+10, player.posZ+10));
list.remove(player);
for (EntityLiving ent : list) for (EntityLiving ent : list) {
{ Vec3 vec1 = player.getLook(1.0F).normalize();
Vec3 var3 = player.getLook(1.0F).normalize(); Vec3 vec2 = new Vec3(ent.posX-player.posX,
Vec3 var4 = Vec3.createVectorHelper(ent.posX - player.posX, ent.boundingBox.minY + (ent.height) / 2.0F - ( player.posY + player.getEyeHeight()), ent.posZ - player.posZ); ent.getEntityBoundingBox().minY+(ent.height) / 2.0F-(player.posY+player.getEyeHeight()),
double var5 = var4.lengthVector(); ent.posZ-player.posZ);
var4 = var4.normalize(); double length = vec2.lengthVector();
double var7 = var3.dotProduct(var4); vec2 = vec2.normalize();
if( (var7+.1) > 1.0D - 0.025D / var5 ? player.canEntityBeSeen(ent) : false) double dotProduct = vec1.dotProduct(vec2);
{ if((dotProduct+0.1) > 1.0D - 0.025D/length && player.canEntityBeSeen(ent)) {
teleportToEntity(stack, ent, player); teleportToEntity(stack, ent, player);
stack.damageItem(3, player); stack.damageItem(3, player);
return stack; return stack;
@ -117,63 +74,41 @@ public class ItemRiftBlade extends ItemSword {
} }
MovingObjectPosition hit = this.getMovingObjectPositionFromPlayer(world, player, false); MovingObjectPosition hit = this.getMovingObjectPositionFromPlayer(world, player, false);
if (hit != null) if (hit != null) {
{ BlockPos up = hit.getBlockPos(), down = up.down();
int x = hit.blockX; if (world.getBlockState(up).getBlock() == DimDoors.blockRift &&
int y = hit.blockY; PocketManager.getLink(up, world) != null &&
int z = hit.blockZ; player.canPlayerEdit(up, hit.sideHit, stack) &&
if (world.getBlock(x, y, z) == DimDoors.blockRift) player.canPlayerEdit(down, hit.sideHit, stack) &&
{ BaseItemDoor.canPlace(world, up) &&
if (PocketManager.getLink(x, y, z, world) != null) BaseItemDoor.canPlace(world, down)) {
{ ItemDimensionalDoor.placeDoor(world, down, EnumFacing.fromAngle(player.rotationYaw), DimDoors.transientDoor);
if (player.canPlayerEdit(x, y, z, hit.sideHit, stack) && player.worldObj.playSoundAtEntity(player, DimDoors.MODID + ":riftDoor", 0.6f, 1);
player.canPlayerEdit(x, y + 1, z, hit.sideHit, stack))
{
int orientation = MathHelper.floor_double((player.rotationYaw + 180.0F) * 4.0F / 360.0F - 0.5D) & 3;
if (BaseItemDoor.canPlace(world, x, y, z) &&
BaseItemDoor.canPlace(world, x, y - 1, z))
{
ItemDimensionalDoor.placeDoorBlock(world, x, y - 1, z, orientation, DimDoors.transientDoor);
player.worldObj.playSoundAtEntity(player, DimDoors.modid+":riftDoor", 0.6f, 1);
stack.damageItem(3, player); stack.damageItem(3, player);
return stack; return stack;
} }
} }
}
}
}
player.setItemInUse(stack, this.getMaxItemUseDuration(stack)); player.setItemInUse(stack, this.getMaxItemUseDuration(stack));
} }
return stack; return stack;
} }
@Override
public void registerIcons(IIconRegister par1IconRegister)
{
this.itemIcon = par1IconRegister.registerIcon(DimDoors.modid + ":" + this.getUnlocalizedName().replace("item.", ""));
}
/** /**
* Return whether this item is repairable in an anvil. * Return whether this item is repairable in an anvil.
*/ */
@Override @Override
public boolean getIsRepairable(ItemStack par1ItemStack, ItemStack par2ItemStack) public boolean getIsRepairable(ItemStack toRepair, ItemStack repair) {
{
//Don't include a call to super.getIsRepairable()! //Don't include a call to super.getIsRepairable()!
//That would cause this sword to accept diamonds as a repair material (since we set material = Diamond). //That would cause this sword to accept diamonds as a repair material (since we set material = Diamond).
return DimDoors.itemStableFabric == par2ItemStack.getItem() ? true : false; return DimDoors.itemStableFabric == repair.getItem();
} }
/** /**
* allows items to add custom lines of information to the mouseover description * allows items to add custom lines of information to the mouseover description
*/ */
@Override @Override
@SuppressWarnings({ "unchecked", "rawtypes" })
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
public void addInformation(ItemStack par1ItemStack, EntityPlayer par2EntityPlayer, List par3List, boolean par4) public void addInformation(ItemStack stack, EntityPlayer playerIn, List tooltip, boolean advanced) {
{ DimDoors.translateAndAdd("info.riftblade", tooltip);
DimDoors.translateAndAdd("info.riftblade", par3List);
} }
} }

View file

@ -29,6 +29,7 @@ public class ItemRenderManager {
register(DimDoors.itemGoldenDoor); register(DimDoors.itemGoldenDoor);
register(DimDoors.itemPersonalDoor); register(DimDoors.itemPersonalDoor);
register(DimDoors.itemQuartzDoor); register(DimDoors.itemQuartzDoor);
register(DimDoors.itemRiftBlade);
} }
public static void addModelVariants() { public static void addModelVariants() {

View file

@ -0,0 +1,18 @@
{
"parent": "builtin/generated",
"textures": {
"layer0": "dimdoors:items/itemRiftBlade"
},
"display": {
"thirdperson": {
"rotation": [ -90, 0, 0 ],
"translation": [ 0, 1, -3 ],
"scale": [ 0.55, 0.55, 0.55 ]
},
"firstperson": {
"rotation": [ 0, -135, 25 ],
"translation": [ 0, 4, 2 ],
"scale": [ 1.7, 1.7, 1.7 ]
}
}
}