aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/com/detrav/net/DetravProPickPacket00.java
diff options
context:
space:
mode:
authorDetrav <witalyezep@gmail.com>2016-04-07 23:22:24 +0300
committerDetrav <witalyezep@gmail.com>2016-04-07 23:22:24 +0300
commit0213c1280a70e157dcbad104afc83c8a3058ae10 (patch)
tree1bd58d7dad79260347ac34a711445ec3e3b1659c /src/main/java/com/detrav/net/DetravProPickPacket00.java
parent7f8cf963b3755a6afdc00e4a6fc4a7cf00c54209 (diff)
downloadGT5-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.java179
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;
+ }
+}