diff options
author | Detrav <witalyezep@gmail.com> | 2016-04-07 23:22:24 +0300 |
---|---|---|
committer | Detrav <witalyezep@gmail.com> | 2016-04-07 23:22:24 +0300 |
commit | 0213c1280a70e157dcbad104afc83c8a3058ae10 (patch) | |
tree | 1bd58d7dad79260347ac34a711445ec3e3b1659c /src/main/java/com/detrav/net/DetravProPickPacket00.java | |
parent | 7f8cf963b3755a6afdc00e4a6fc4a7cf00c54209 (diff) | |
download | GT5-Unofficial-0213c1280a70e157dcbad104afc83c8a3058ae10.tar.gz GT5-Unofficial-0213c1280a70e157dcbad104afc83c8a3058ae10.tar.bz2 GT5-Unofficial-0213c1280a70e157dcbad104afc83c8a3058ae10.zip |
Refactor wrong names
Diffstat (limited to 'src/main/java/com/detrav/net/DetravProPickPacket00.java')
-rw-r--r-- | src/main/java/com/detrav/net/DetravProPickPacket00.java | 179 |
1 files changed, 179 insertions, 0 deletions
diff --git a/src/main/java/com/detrav/net/DetravProPickPacket00.java b/src/main/java/com/detrav/net/DetravProPickPacket00.java new file mode 100644 index 0000000000..d2e9ed57b6 --- /dev/null +++ b/src/main/java/com/detrav/net/DetravProPickPacket00.java @@ -0,0 +1,179 @@ +package com.detrav.net; + +import com.detrav.DetravScannerMod; +import com.detrav.gui.DetravGuiProPick; +import com.detrav.gui.textures.DetravMapTexture; +import com.google.common.io.ByteArrayDataInput; +import com.google.common.io.ByteArrayDataOutput; +import com.google.common.io.ByteStreams; +import gregtech.api.GregTech_API; +import gregtech.api.enums.Materials; +import gregtech.api.util.GT_LanguageManager; + +import java.awt.image.BufferedImage; +import java.awt.image.WritableRaster; +import java.util.HashMap; + + +/** + * Created by wital_000 on 20.03.2016. + */ +public class DetravProPickPacket00 extends DetravPacket { + public int chunkX; + public int chunkZ; + public int size; + HashMap<Byte,Short>[][] map = null; + + @Override + public int getPacketID() { + return 0; + } + + public int level = -1; + + @Override + public byte[] encode() { + ByteArrayDataOutput tOut = ByteStreams.newDataOutput(1); + tOut.writeInt(level); + tOut.writeInt(chunkX); + tOut.writeInt(chunkZ); + tOut.writeInt(size); + int aSize = (size*2+1)*16; + int checkOut = 0; + for(int i =0; i<aSize; i++) + for(int j =0; j<aSize; j++) + { + if(map[i][j]==null) + tOut.writeByte(0); + else + { + tOut.writeByte(map[i][j].keySet().size()); + for(byte key : map[i][j].keySet()) + { + tOut.writeByte(key); + tOut.writeShort(map[i][j].get(key)); + checkOut++; + } + } + } + tOut.writeInt(checkOut); + return tOut.toByteArray(); + } + + @Override + public Object decode(ByteArrayDataInput aData) { + DetravProPickPacket00 packet = new DetravProPickPacket00(); + packet.level = aData.readInt(); + packet.chunkX = aData.readInt(); + packet.chunkZ = aData.readInt(); + packet.size = aData.readInt(); + packet.map = new HashMap[(packet.size * 2 + 1) * 16][(packet.size * 2 + 1) * 16]; + int aSize = (packet.size * 2 + 1) * 16; + int checkOut = 0; + for (int i = 0; i < aSize; i++) + for (int j = 0; j < aSize; j++) { + byte kSize = aData.readByte(); + if(kSize == 0) continue; + packet.map[i][j] = new HashMap<Byte, Short>(); + for (int k = 0; k < kSize; k++) { + packet.map[i][j].put(aData.readByte(),aData.readShort()); + checkOut++; + } + } + int checkOut2 = aData.readInt(); + if(checkOut != checkOut2) return new DetravProPickPacket00(); + return packet; + } + + + @Override + public void process() { + DetravGuiProPick.newMap(new DetravMapTexture(this)); + DetravScannerMod.proxy.openProPickGui(); + } + + public void addBlock(int x, int y, int z, short metaData) { + if(map == null) map = new HashMap[(size*2+1)*16][(size*2+1)*16]; + int aX = x - (chunkX-size)*16; + int aZ = z - (chunkZ-size)*16; + if(map[aX][aZ] == null) map[aX][aZ] = new HashMap<Byte, Short>(); + map[aX][aZ].put((byte)y,metaData); + //String key = String.format(("x_y")) + } + + private HashMap<String,Integer> ores = null; + + public BufferedImage getImage(int posX,int posZ) { + int wh = (size*2+1)*16; + //int aWh = 1024; + //while (aWh<wh) aWh*=2; + BufferedImage image = new BufferedImage(wh,wh,BufferedImage.TYPE_INT_ARGB ); + WritableRaster raster = image.getRaster(); + + int playerI = posX - (chunkX-size)*16; + int playerJ = posZ - (chunkZ-size)*16; + + if(ores == null) ores = new HashMap<String, Integer>(); + + for(int i =0; i<wh; i++) + for(int j =0; j<wh; j++) { + if (map[i][j] == null) + { + raster.setSample(i,j,0,255); + raster.setSample(i,j,1,255); + raster.setSample(i,j,2,255); + raster.setSample(i,j,3,255); + } + else + { + for(short meta : map[i][j].values()) { + //Пока только по одному буду + Materials tMaterial = GregTech_API.sGeneratedMaterials[meta% 1000]; + short[] rgba = tMaterial.getRGBA(); + raster.setSample(i,j,0,rgba[0]); + raster.setSample(i,j,1,rgba[1]); + raster.setSample(i,j,2,rgba[2]); + raster.setSample(i,j,3,255); + //ores.put(GT_Ore) + String name = GT_LanguageManager.getTranslation("gt.blockores." + meta + ".name"); + if(!ores.containsKey(name)) + ores.put(name,(0xFF << 24) + ((rgba[0]&0xFF)<<16)+((rgba[1]&0xFF)<<8)+((rgba[2]&0xFF))); + } + } + if(playerI == i || playerJ == j) + { + raster.setSample(i,j,0,(raster.getSample(i,j,0)+255)/2); + raster.setSample(i,j,1,raster.getSample(i,j,1)/2); + raster.setSample(i,j,2,raster.getSample(i,j,2)/2); + } + if((i-15)%16 == 0 || (j-15)%16 == 0) + { + raster.setSample(i,j,0,raster.getSample(i,j,0)/2); + raster.setSample(i,j,1,raster.getSample(i,j,1)/2); + raster.setSample(i,j,2,raster.getSample(i,j,2)/2); + } + } + /*try { + File outputfile = new File("saved.png"); + ImageIO.write(image, "png", outputfile); + } + catch (Exception e) {}*/ + + return image; + + + //image.set + //return null; + } + + public HashMap<String,Integer> getOres() + { + if(ores == null) return new HashMap<String, Integer>(); + return ores; + } + + + public int getSize() { + return (size*2+1)*16; + } +} |