diff options
author | Detrav <witalyezep@gmail.com> | 2016-03-21 01:53:15 +0300 |
---|---|---|
committer | Detrav <witalyezep@gmail.com> | 2016-03-21 01:53:15 +0300 |
commit | c46134e58f5d02b3b9220526df0e92918a718f53 (patch) | |
tree | 614cfab8fe3d9b4b459e9eba14c133a870efc074 /src/main/java/com/detrav/items/behaviours | |
parent | 6f3306ee5bc69011d4c655bd9fb1fd47c3523523 (diff) | |
download | GT5-Unofficial-c46134e58f5d02b3b9220526df0e92918a718f53.tar.gz GT5-Unofficial-c46134e58f5d02b3b9220526df0e92918a718f53.tar.bz2 GT5-Unofficial-c46134e58f5d02b3b9220526df0e92918a718f53.zip |
Complete network logic
Diffstat (limited to 'src/main/java/com/detrav/items/behaviours')
-rw-r--r-- | src/main/java/com/detrav/items/behaviours/BehaviourDetravToolElectricProPick.java | 59 | ||||
-rw-r--r-- | src/main/java/com/detrav/items/behaviours/BehaviourDetravToolProPick.java | 2 |
2 files changed, 53 insertions, 8 deletions
diff --git a/src/main/java/com/detrav/items/behaviours/BehaviourDetravToolElectricProPick.java b/src/main/java/com/detrav/items/behaviours/BehaviourDetravToolElectricProPick.java index 42faadd8ea..9fa0f06fe5 100644 --- a/src/main/java/com/detrav/items/behaviours/BehaviourDetravToolElectricProPick.java +++ b/src/main/java/com/detrav/items/behaviours/BehaviourDetravToolElectricProPick.java @@ -3,18 +3,28 @@ package com.detrav.items.behaviours; import com.detrav.items.DetravMetaGeneratedTool01; import com.detrav.utils.DetravNetwork; import com.detrav.utils.DetravProPickPacket01; +import gregtech.api.GregTech_API; import gregtech.api.items.GT_MetaBase_Item; +import gregtech.api.util.GT_LanguageManager; +import gregtech.common.blocks.GT_TileEntity_Ores; +import net.minecraft.block.Block; import net.minecraft.entity.player.EntityPlayer; import net.minecraft.entity.player.EntityPlayerMP; import net.minecraft.item.ItemStack; +import net.minecraft.tileentity.TileEntity; import net.minecraft.util.ChatComponentText; import net.minecraft.world.World; +import net.minecraft.world.chunk.Chunk; +import net.minecraft.world.chunk.storage.ChunkLoader; +import net.minecraftforge.common.ForgeChunkManager; + +import java.util.ArrayList; +import java.util.List; /** * Created by wital_000 on 19.03.2016. */ -public class BehaviourDetravToolElectricProPick extends BehaviourDetravToolProPick -{ +public class BehaviourDetravToolElectricProPick extends BehaviourDetravToolProPick { public BehaviourDetravToolElectricProPick(int aCosts) { super(aCosts); @@ -24,12 +34,47 @@ public class BehaviourDetravToolElectricProPick extends BehaviourDetravToolProPi if (!aWorld.isRemote) { //aPlayer.openGui(); - - aPlayer.addChatMessage(new ChatComponentText("Scanning Begin")); + DetravMetaGeneratedTool01 tool = (DetravMetaGeneratedTool01) aItem; + //aWorld.getChunkFromBlockCoords() + int cX = ((int) aPlayer.posX) >> 4; + int cZ = ((int) aPlayer.posZ) >> 4; + int size = aItem.getHarvestLevel(aStack, "") + 1; + List<Chunk> chunks = new ArrayList<Chunk>(); + //aPlayer.addChatMessage(new ChatComponentText("Scanning Begin, wait!")); + //DetravProPickPacket01 packet = new DetravProPickPacket01(); + for (int i = -size; i <= size; i++) + for (int j = -size; j <= size; j++) + if (i != -size && i != size && j != -size && j != size) + chunks.add(aWorld.getChunkFromChunkCoords(cX + i, cZ + j)); + size = size - 1; + //c.gene DetravProPickPacket01 packet = new DetravProPickPacket01(); - packet.level = ((DetravMetaGeneratedTool01) aItem).getHarvestLevel(aStack,""); - DetravNetwork.INSTANCE.sendToPlayer(packet,(EntityPlayerMP)aPlayer); + packet.chunkX = cX; + packet.chunkZ = cZ; + packet.size = size; + for (Chunk c : chunks) { + for (int x = 0; x < 16; x++) + for (int z = 0; z < 16; z++) { + int ySize = c.getHeightValue(x, z); + for (int y = 1; y < ySize; y++) { + Block b = c.getBlock(x, y, z); + if (b == GregTech_API.sBlockOres1) { + TileEntity entity = c.getTileEntityUnsafe(x, y, z); + if (entity != null && entity instanceof GT_TileEntity_Ores) { + GT_TileEntity_Ores gt_entity = (GT_TileEntity_Ores) entity; + String name = GT_LanguageManager.getTranslation( + b.getUnlocalizedName() + "." + gt_entity.getMetaData() + ".name"); + if (name.startsWith("Small")) continue; + packet.addBlock(c.xPosition * 16 + x, y, c.zPosition * 16 + z, gt_entity.getMetaData()); + } + } + } + } + } + packet.level = ((DetravMetaGeneratedTool01) aItem).getHarvestLevel(aStack, ""); + DetravNetwork.INSTANCE.sendToPlayer(packet, (EntityPlayerMP) aPlayer); + tool.doDamage(aStack, this.mCosts * chunks.size()); } - return super.onItemRightClick(aItem,aStack,aWorld,aPlayer); + return super.onItemRightClick(aItem, aStack, aWorld, aPlayer); } }
\ No newline at end of file diff --git a/src/main/java/com/detrav/items/behaviours/BehaviourDetravToolProPick.java b/src/main/java/com/detrav/items/behaviours/BehaviourDetravToolProPick.java index 5c5b64d53c..2669c1a541 100644 --- a/src/main/java/com/detrav/items/behaviours/BehaviourDetravToolProPick.java +++ b/src/main/java/com/detrav/items/behaviours/BehaviourDetravToolProPick.java @@ -32,7 +32,7 @@ public class BehaviourDetravToolProPick extends Behaviour_None { "Found a very large sample of ", //100-** "Found " }; - private final int mCosts; + protected final int mCosts; public BehaviourDetravToolProPick(int aCosts) { |