forked from GeyserMC/Geyser
Fix most all metadatable items not showing up (for the most part)
The actual block data translation (like stair rotation) all needs to be done still, but this is a huge step toward getting that complete.
This commit is contained in:
parent
610ccbdc62
commit
b6d4bf5147
6 changed files with 46234 additions and 3127 deletions
|
@ -0,0 +1,46 @@
|
|||
/*
|
||||
* Copyright (c) 2019 GeyserMC. http://geysermc.org
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
* of this software and associated documentation files (the "Software"), to deal
|
||||
* in the Software without restriction, including without limitation the rights
|
||||
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
* copies of the Software, and to permit persons to whom the Software is
|
||||
* furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
* THE SOFTWARE.
|
||||
*
|
||||
* @author GeyserMC
|
||||
* @link https://github.com/GeyserMC/Geyser
|
||||
*/
|
||||
|
||||
package org.geysermc.connector.network.translators.block;
|
||||
|
||||
import lombok.Getter;
|
||||
import org.geysermc.connector.network.translators.item.JavaItem;
|
||||
|
||||
@Getter
|
||||
public class JavaBlock extends JavaItem {
|
||||
|
||||
private String data;
|
||||
|
||||
public JavaBlock(String identifier, String data, int id) {
|
||||
super(identifier, id);
|
||||
|
||||
this.data = data;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equals(Object obj) {
|
||||
return obj == this || (obj instanceof JavaBlock && ((JavaBlock) obj).id == this.id && ((JavaBlock) obj).identifier.equals(this.identifier));
|
||||
}
|
||||
}
|
|
@ -25,17 +25,20 @@
|
|||
|
||||
package org.geysermc.connector.network.translators.item;
|
||||
|
||||
import lombok.AllArgsConstructor;
|
||||
import lombok.Getter;
|
||||
|
||||
@Getter
|
||||
@AllArgsConstructor
|
||||
public class JavaItem {
|
||||
|
||||
public static JavaItem AIR = new JavaItem("minecraft:air", 0);
|
||||
|
||||
private String identifier;
|
||||
private int id;
|
||||
protected String identifier;
|
||||
protected int id;
|
||||
|
||||
public JavaItem(String identifier, int id) {
|
||||
this.identifier = identifier;
|
||||
this.id = id;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int hashCode() {
|
||||
|
|
|
@ -2,6 +2,7 @@ package org.geysermc.connector.utils;
|
|||
|
||||
import com.github.steveice10.mc.protocol.data.game.entity.metadata.ItemStack;
|
||||
import com.nukkitx.protocol.bedrock.data.ItemData;
|
||||
import org.geysermc.connector.network.translators.block.JavaBlock;
|
||||
import org.geysermc.connector.network.translators.item.BedrockItem;
|
||||
import org.geysermc.connector.network.translators.item.JavaItem;
|
||||
import org.geysermc.connector.network.translators.block.type.ColoredBlock;
|
||||
|
@ -29,7 +30,7 @@ public class Remapper {
|
|||
}
|
||||
|
||||
// Registers the conversions for bedrock <-> java
|
||||
public void registerConversions(Map<String, BedrockItem> bedrockItems, Map<String, JavaItem> javaItems) {
|
||||
public void registerConversions(Map<String, BedrockItem> bedrockItems, Map<Integer, ? extends JavaItem> javaItems) {
|
||||
for (Map.Entry<String, BedrockItem> bedrockItemEntry : bedrockItems.entrySet()) {
|
||||
BedrockItem bedrockItem = bedrockItemEntry.getValue();
|
||||
String identifier = bedrockItem.getIdentifier();
|
||||
|
@ -96,8 +97,8 @@ public class Remapper {
|
|||
identifier = MINECRAFT + "coarse_dirt";
|
||||
}
|
||||
|
||||
for (Map.Entry<String, JavaItem> javaItemEntry : javaItems.entrySet()) {
|
||||
if (identifier.equalsIgnoreCase(javaItemEntry.getKey())) {
|
||||
for (Map.Entry<Integer, ? extends JavaItem> javaItemEntry : javaItems.entrySet()) {
|
||||
if (identifier.equalsIgnoreCase(javaItemEntry.getValue().getIdentifier())) {
|
||||
bedrockToJava.put(bedrockItemEntry.getValue(), javaItemEntry.getValue());
|
||||
javaToBedrock.put(javaItemEntry.getValue(), bedrockItemEntry.getValue());
|
||||
}
|
||||
|
@ -117,7 +118,7 @@ public class Remapper {
|
|||
}
|
||||
|
||||
public BedrockItem convertToBedrock(ItemStack item) {
|
||||
for (Map.Entry<String, JavaItem> javaItem : Toolbox.JAVA_ITEMS.entrySet()) {
|
||||
for (Map.Entry<Integer, JavaItem> javaItem : Toolbox.JAVA_ITEMS.entrySet()) {
|
||||
if (javaItem.getValue().getId() != item.getId())
|
||||
continue;
|
||||
|
||||
|
@ -128,7 +129,7 @@ public class Remapper {
|
|||
}
|
||||
|
||||
public BedrockItem convertToBedrockB(ItemStack block) {
|
||||
for (Map.Entry<String, JavaItem> javaItem : Toolbox.JAVA_BLOCKS.entrySet()) {
|
||||
for (Map.Entry<Integer, JavaBlock> javaItem : Toolbox.JAVA_BLOCKS.entrySet()) {
|
||||
if (javaItem.getValue().getId() != block.getId())
|
||||
continue;
|
||||
|
||||
|
|
|
@ -8,6 +8,7 @@ import com.nukkitx.protocol.bedrock.v361.BedrockUtils;
|
|||
import io.netty.buffer.ByteBuf;
|
||||
import io.netty.buffer.Unpooled;
|
||||
import org.geysermc.connector.console.GeyserLogger;
|
||||
import org.geysermc.connector.network.translators.block.JavaBlock;
|
||||
import org.geysermc.connector.network.translators.item.BedrockItem;
|
||||
import org.geysermc.connector.network.translators.item.JavaItem;
|
||||
import org.geysermc.connector.world.GlobalBlockPalette;
|
||||
|
@ -35,8 +36,8 @@ public class Toolbox {
|
|||
VarInts.writeUnsignedInt(b, entries.size());
|
||||
for (Map<String, Object> e : entries) {
|
||||
BedrockItem bedrockItem = new BedrockItem((String) e.get("name"), (int) e.get("id"), (int) e.get("data"));
|
||||
bedrockItems.put(bedrockItem.getIdentifier() + ":" + bedrockItem.getData(), bedrockItem);
|
||||
bedrockBlocks.put(bedrockItem.getIdentifier() + ":" + bedrockItem.getData(), bedrockItem);
|
||||
bedrockItems.put(bedrockItem.getId() + ":" + bedrockItem.getData(), bedrockItem);
|
||||
bedrockBlocks.put(bedrockItem.getId() + ":" + bedrockItem.getData(), bedrockItem);
|
||||
|
||||
GlobalBlockPalette.registerMapping((int) e.get("id") << 4 | (int) e.get("data"));
|
||||
BedrockUtils.writeString(b, (String) e.get("name"));
|
||||
|
@ -62,9 +63,9 @@ public class Toolbox {
|
|||
List<StartGamePacket.ItemEntry> l = new ArrayList<>();
|
||||
for (HashMap e : s) {
|
||||
l.add(new StartGamePacket.ItemEntry((String) e.get("name"), (short) ((int) e.get("id"))));
|
||||
if (!bedrockItems.containsKey(e.get("name"))) {
|
||||
if (!bedrockItems.containsKey(e.get("id"))) {
|
||||
BedrockItem bedrockItem = new BedrockItem((String) e.get("name"), ((int) e.get("id")), 0);
|
||||
bedrockItems.put(bedrockItem.getIdentifier(), bedrockItem);
|
||||
bedrockItems.put(String.valueOf(bedrockItem.getId()), bedrockItem);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -81,10 +82,10 @@ public class Toolbox {
|
|||
ex.printStackTrace();
|
||||
}
|
||||
|
||||
Map<String, JavaItem> javaItems = new HashMap<String, JavaItem>();
|
||||
Map<Integer, JavaItem> javaItems = new HashMap<>();
|
||||
|
||||
for (String str : javaItemList.keySet()) {
|
||||
javaItems.put(str, new JavaItem(str, (int) javaItemList.get(str).get("protocol_id")));
|
||||
javaItems.put(Integer.parseInt(str), new JavaItem((String) javaItemList.get(str).get("identifier"), Integer.parseInt(str)));
|
||||
}
|
||||
|
||||
JAVA_ITEMS = javaItems;
|
||||
|
@ -98,10 +99,11 @@ public class Toolbox {
|
|||
ex.printStackTrace();
|
||||
}
|
||||
|
||||
Map<String, JavaItem> javaBlocks = new HashMap<String, JavaItem>();
|
||||
Map<Integer, JavaBlock> javaBlocks = new HashMap<>();
|
||||
|
||||
for (String str : javaItemList2.keySet()) {
|
||||
javaBlocks.put(str, new JavaItem(str, (int) javaItemList2.get(str).get("protocol_id")));
|
||||
javaBlocks.put(Integer.parseInt(str), new JavaBlock((String) javaItemList2.get(str).get("identifier"),
|
||||
(String) javaItemList2.get(str).get("data"), Integer.parseInt(str)));
|
||||
}
|
||||
|
||||
JAVA_BLOCKS = javaBlocks;
|
||||
|
@ -111,6 +113,7 @@ public class Toolbox {
|
|||
Remapper.ITEM_REMAPPER.registerConversions(bedrockItems, javaItems);
|
||||
GeyserLogger.DEFAULT.info("Item remap complete!");
|
||||
|
||||
// TODO: Implement support for block data
|
||||
GeyserLogger.DEFAULT.info("Remapping blocks...");
|
||||
Remapper.BLOCK_REMAPPER.registerConversions(bedrockBlocks, javaBlocks);
|
||||
GeyserLogger.DEFAULT.info("Block remap complete!");
|
||||
|
@ -121,10 +124,8 @@ public class Toolbox {
|
|||
public static final ByteBuf CACHED_PALLETE;
|
||||
|
||||
public static final Map<String, BedrockItem> BEDROCK_ITEMS;
|
||||
public static final Map<String, JavaItem> JAVA_ITEMS;
|
||||
public static final Map<Integer, JavaItem> JAVA_ITEMS;
|
||||
|
||||
public static final Map<String, BedrockItem> BEDROCK_BLOCKS;
|
||||
public static final Map<String, JavaItem> JAVA_BLOCKS;
|
||||
|
||||
//public static final byte[] EMPTY_CHUNK;
|
||||
public static final Map<Integer, JavaBlock> JAVA_BLOCKS;
|
||||
}
|
File diff suppressed because it is too large
Load diff
File diff suppressed because it is too large
Load diff
Loading…
Reference in a new issue