diff options
| author | Alkalus <3060479+draknyte1@users.noreply.github.com> | 2018-07-18 06:42:05 +1000 | 
|---|---|---|
| committer | Alkalus <3060479+draknyte1@users.noreply.github.com> | 2018-07-18 06:42:05 +1000 | 
| commit | b44af9997bc437844a41a5736f1de85a9bd5e2ca (patch) | |
| tree | 07547d3771ccaa33b3d94ddf1f65f4f487362800 /src/Java/gtPlusPlus/xmod/gregtech/api/items | |
| parent | 243346fb454cfeb1a9313ef907243a8a39af8849 (diff) | |
| download | GT5-Unofficial-b44af9997bc437844a41a5736f1de85a9bd5e2ca.tar.gz GT5-Unofficial-b44af9997bc437844a41a5736f1de85a9bd5e2ca.tar.bz2 GT5-Unofficial-b44af9997bc437844a41a5736f1de85a9bd5e2ca.zip | |
+ Added the Base work for a Hand pump, that removes fluids from the input tanks of GT machines.
Diffstat (limited to 'src/Java/gtPlusPlus/xmod/gregtech/api/items')
| -rw-r--r-- | src/Java/gtPlusPlus/xmod/gregtech/api/items/types/ToolType_Pump.java | 150 | 
1 files changed, 150 insertions, 0 deletions
| diff --git a/src/Java/gtPlusPlus/xmod/gregtech/api/items/types/ToolType_Pump.java b/src/Java/gtPlusPlus/xmod/gregtech/api/items/types/ToolType_Pump.java new file mode 100644 index 0000000000..f62d9e5cfa --- /dev/null +++ b/src/Java/gtPlusPlus/xmod/gregtech/api/items/types/ToolType_Pump.java @@ -0,0 +1,150 @@ +package gtPlusPlus.xmod.gregtech.api.items.types; + +import java.util.Arrays; +import java.util.List; + +import net.minecraft.block.Block; +import net.minecraft.entity.item.EntityItem; +import net.minecraft.entity.player.EntityPlayer; +import net.minecraft.init.Blocks; +import net.minecraft.item.ItemStack; +import net.minecraft.tileentity.TileEntity; +import net.minecraft.world.World; + +import gregtech.api.GregTech_API; +import gregtech.api.items.GT_MetaBase_Item; +import gregtech.api.items.GT_MetaGenerated_Tool; +import gregtech.api.util.GT_LanguageManager; +import gregtech.api.util.GT_ModHandler; +import gregtech.api.util.GT_Utility; + +import ic2.api.tile.IWrenchable; +import net.minecraftforge.common.util.ForgeDirection; + +public class ToolType_Pump +extends ToolType_Base { +	private final int mCosts; +	private final String mTooltip = GT_LanguageManager.addStringLocalization("gt.behaviour.pump", "Sucks in Machine Input Fluid tank contents on Rightclick"); + +	public ToolType_Pump(final int aCosts) { +		this.mCosts = aCosts; +	} + +	public boolean onItemUseFirst(final GT_MetaBase_Item aItem, final ItemStack aStack, final EntityPlayer aPlayer, final World aWorld, final int aX, final int aY, final int aZ, final int aSide, final float hitX, final float hitY, final float hitZ) { +		if (aWorld.isRemote) { +			return false; +		} +		final Block aBlock = aWorld.getBlock(aX, aY, aZ); +		if (aBlock == null) { +			return false; +		} +		final byte aMeta = (byte) aWorld.getBlockMetadata(aX, aY, aZ); +		final byte aTargetSide = GT_Utility.determineWrenchingSide((byte) aSide, hitX, hitY, hitZ); +		final TileEntity aTileEntity = aWorld.getTileEntity(aX, aY, aZ); +		/*try { +			if ((aTileEntity != null) && ((aTileEntity instanceof IWrenchable))) { +				if (((IWrenchable) aTileEntity).wrenchCanSetFacing(aPlayer, aTargetSide)) { +					if ((aPlayer.capabilities.isCreativeMode) || (((GT_MetaGenerated_Tool) aItem).doDamage(aStack, this.mCosts))) { +						((IWrenchable) aTileEntity).setFacing(aTargetSide); +						GT_Utility.sendSoundToPlayers(aWorld, GregTech_API.sSoundList.get(Integer.valueOf(100)), 1.0F, -1.0F, aX, aY, aZ); +					} +					return true; +				} +				if (((IWrenchable) aTileEntity).wrenchCanRemove(aPlayer)) { +					final int tDamage = ((IWrenchable) aTileEntity).getWrenchDropRate() < 1.0F ? 10 : 3; +					if ((aPlayer.capabilities.isCreativeMode) || (((GT_MetaGenerated_Tool) aItem).doDamage(aStack, tDamage * this.mCosts))) { +						ItemStack tOutput = ((IWrenchable) aTileEntity).getWrenchDrop(aPlayer); +						for (final ItemStack tStack : aBlock.getDrops(aWorld, aX, aY, aZ, aMeta, 0)) { +							if (tOutput == null) { +								aWorld.spawnEntityInWorld(new EntityItem(aWorld, aX + 0.5D, aY + 0.5D, aZ + 0.5D, tStack)); +							} else { +								aWorld.spawnEntityInWorld(new EntityItem(aWorld, aX + 0.5D, aY + 0.5D, aZ + 0.5D, tOutput)); +								tOutput = null; +							} +						} +						aWorld.setBlockToAir(aX, aY, aZ); +						GT_Utility.sendSoundToPlayers(aWorld, GregTech_API.sSoundList.get(Integer.valueOf(100)), 1.0F, -1.0F, aX, aY, aZ); +					} +					return true; +				} +				return true; +			} +		} catch (final Throwable e) { +		} +		if ((aBlock == Blocks.log) || (aBlock == Blocks.log2) || (aBlock == Blocks.hay_block)) { +			if ((aPlayer.capabilities.isCreativeMode) || (((GT_MetaGenerated_Tool) aItem).doDamage(aStack, this.mCosts))) { +				aWorld.setBlockMetadataWithNotify(aX, aY, aZ, (aMeta + 4) % 12, 3); +				GT_Utility.sendSoundToPlayers(aWorld, GregTech_API.sSoundList.get(Integer.valueOf(100)), 1.0F, -1.0F, aX, aY, aZ); +			} +			return true; +		} +		if ((aBlock == Blocks.powered_repeater) || (aBlock == Blocks.unpowered_repeater)) { +			if ((aPlayer.capabilities.isCreativeMode) || (((GT_MetaGenerated_Tool) aItem).doDamage(aStack, this.mCosts))) { +				aWorld.setBlockMetadataWithNotify(aX, aY, aZ, ((aMeta / 4) * 4) + (((aMeta % 4) + 1) % 4), 3); +				GT_Utility.sendSoundToPlayers(aWorld, GregTech_API.sSoundList.get(Integer.valueOf(100)), 1.0F, -1.0F, aX, aY, aZ); +			} +			return true; +		} +		if ((aBlock == Blocks.powered_comparator) || (aBlock == Blocks.unpowered_comparator)) { +			if ((aPlayer.capabilities.isCreativeMode) || (((GT_MetaGenerated_Tool) aItem).doDamage(aStack, this.mCosts))) { +				aWorld.setBlockMetadataWithNotify(aX, aY, aZ, ((aMeta / 4) * 4) + (((aMeta % 4) + 1) % 4), 3); +				GT_Utility.sendSoundToPlayers(aWorld, GregTech_API.sSoundList.get(Integer.valueOf(100)), 1.0F, -1.0F, aX, aY, aZ); +			} +			return true; +		} +		if ((aBlock == Blocks.crafting_table) || (aBlock == Blocks.bookshelf)) { +			if ((aPlayer.capabilities.isCreativeMode) || (((GT_MetaGenerated_Tool) aItem).doDamage(aStack, this.mCosts))) { +				aWorld.spawnEntityInWorld(new EntityItem(aWorld, aX + 0.5D, aY + 0.5D, aZ + 0.5D, new ItemStack(aBlock, 1, aMeta))); +				aWorld.setBlockToAir(aX, aY, aZ); +				GT_Utility.sendSoundToPlayers(aWorld, GregTech_API.sSoundList.get(Integer.valueOf(100)), 1.0F, -1.0F, aX, aY, aZ); +			} +			return true; +		} +		if (aMeta == aTargetSide) { +			if ((aBlock == Blocks.pumpkin) || (aBlock == Blocks.lit_pumpkin) || (aBlock == Blocks.piston) || (aBlock == Blocks.sticky_piston) || (aBlock == Blocks.dispenser) || (aBlock == Blocks.dropper) || (aBlock == Blocks.furnace) || (aBlock == Blocks.lit_furnace) || (aBlock == Blocks.chest) || (aBlock == Blocks.trapped_chest) || (aBlock == Blocks.ender_chest) || (aBlock == Blocks.hopper)) { +				if ((aPlayer.capabilities.isCreativeMode) || (((GT_MetaGenerated_Tool) aItem).doDamage(aStack, this.mCosts))) { +					aWorld.spawnEntityInWorld(new EntityItem(aWorld, aX + 0.5D, aY + 0.5D, aZ + 0.5D, new ItemStack(aBlock, 1, 0))); +					aWorld.setBlockToAir(aX, aY, aZ); +					GT_Utility.sendSoundToPlayers(aWorld, GregTech_API.sSoundList.get(Integer.valueOf(100)), 1.0F, -1.0F, aX, aY, aZ); +				} +				return true; +			} +		} else { +			if ((aBlock == Blocks.piston) || (aBlock == Blocks.sticky_piston) || (aBlock == Blocks.dispenser) || (aBlock == Blocks.dropper)) { +				if ((aMeta < 6) && ((aPlayer.capabilities.isCreativeMode) || (((GT_MetaGenerated_Tool) aItem).doDamage(aStack, this.mCosts)))) { +					aWorld.setBlockMetadataWithNotify(aX, aY, aZ, aTargetSide, 3); +					GT_Utility.sendSoundToPlayers(aWorld, GregTech_API.sSoundList.get(Integer.valueOf(100)), 1.0F, -1.0F, aX, aY, aZ); +				} +				return true; +			} +			if ((aBlock == Blocks.pumpkin) || (aBlock == Blocks.lit_pumpkin) || (aBlock == Blocks.furnace) || (aBlock == Blocks.lit_furnace) || (aBlock == Blocks.chest) || (aBlock == Blocks.ender_chest) || (aBlock == Blocks.trapped_chest)) { +				if ((aTargetSide > 1) && ((aPlayer.capabilities.isCreativeMode) || (((GT_MetaGenerated_Tool) aItem).doDamage(aStack, this.mCosts)))) { +					aWorld.setBlockMetadataWithNotify(aX, aY, aZ, aTargetSide, 3); +					GT_Utility.sendSoundToPlayers(aWorld, GregTech_API.sSoundList.get(Integer.valueOf(100)), 1.0F, -1.0F, aX, aY, aZ); +				} +				return true; +			} +			if (aBlock == Blocks.hopper) { +				if ((aTargetSide != 1) && ((aPlayer.capabilities.isCreativeMode) || (((GT_MetaGenerated_Tool) aItem).doDamage(aStack, this.mCosts)))) { +					aWorld.setBlockMetadataWithNotify(aX, aY, aZ, aTargetSide, 3); +					GT_Utility.sendSoundToPlayers(aWorld, GregTech_API.sSoundList.get(Integer.valueOf(100)), 1.0F, -1.0F, aX, aY, aZ); +				} +				return true; +			} +		} +		if ((Arrays.asList(aBlock.getValidRotations(aWorld, aX, aY, aZ)).contains(ForgeDirection.getOrientation(aTargetSide))) && +				((aPlayer.capabilities.isCreativeMode) || (!GT_ModHandler.isElectricItem(aStack)) || (GT_ModHandler.canUseElectricItem(aStack, this.mCosts))) && +				(aBlock.rotateBlock(aWorld, aX, aY, aZ, ForgeDirection.getOrientation(aTargetSide)))) { +			if (!aPlayer.capabilities.isCreativeMode) { +				((GT_MetaGenerated_Tool) aItem).doDamage(aStack, this.mCosts); +			} +			GT_Utility.sendSoundToPlayers(aWorld, GregTech_API.sSoundList.get(Integer.valueOf(100)), 1.0F, -1.0F, aX, aY, aZ); +		}*/ +		return false; +	} + +	public List<String> getAdditionalToolTips(final GT_MetaBase_Item aItem, final List<String> aList, final ItemStack aStack) { +		aList.add(this.mTooltip); +		return aList; +	} +} | 
