Mirror von
https://github.com/ViaVersion/ViaVersion.git
synchronisiert 2024-12-26 16:12:42 +01:00
Handle map related data and skull owners
Co-authored-by: Drex <nicknamedrex@gmail.com>
Dieser Commit ist enthalten in:
Ursprung
908823c612
Commit
386495e168
@ -93,7 +93,7 @@ public final class StructuredDataKey<T> {
|
|||||||
public static final StructuredDataKey<Item[]> CONTAINER = new StructuredDataKey<>("container", Types1_20_5.ITEM_ARRAY);
|
public static final StructuredDataKey<Item[]> CONTAINER = new StructuredDataKey<>("container", Types1_20_5.ITEM_ARRAY);
|
||||||
public static final StructuredDataKey<BlockStateProperties> BLOCK_STATE = new StructuredDataKey<>("block_state", BlockStateProperties.TYPE);
|
public static final StructuredDataKey<BlockStateProperties> BLOCK_STATE = new StructuredDataKey<>("block_state", BlockStateProperties.TYPE);
|
||||||
public static final StructuredDataKey<Bee[]> BEES = new StructuredDataKey<>("bees", Bee.ARRAY_TYPE);
|
public static final StructuredDataKey<Bee[]> BEES = new StructuredDataKey<>("bees", Bee.ARRAY_TYPE);
|
||||||
public static final StructuredDataKey<CompoundTag> LOCK = new StructuredDataKey<>("lock", Type.COMPOUND_TAG);
|
public static final StructuredDataKey<Tag> LOCK = new StructuredDataKey<>("lock", Type.TAG);
|
||||||
public static final StructuredDataKey<CompoundTag> CONTAINER_LOOT = new StructuredDataKey<>("container_loot", Type.COMPOUND_TAG);
|
public static final StructuredDataKey<CompoundTag> CONTAINER_LOOT = new StructuredDataKey<>("container_loot", Type.COMPOUND_TAG);
|
||||||
|
|
||||||
private final String identifier;
|
private final String identifier;
|
||||||
|
@ -0,0 +1,77 @@
|
|||||||
|
/*
|
||||||
|
* This file is part of ViaVersion - https://github.com/ViaVersion/ViaVersion
|
||||||
|
* Copyright (C) 2016-2024 ViaVersion and contributors
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
package com.viaversion.viaversion.api.minecraft.item.data;
|
||||||
|
|
||||||
|
import com.viaversion.viaversion.api.type.Type;
|
||||||
|
import io.netty.buffer.ByteBuf;
|
||||||
|
|
||||||
|
public final class MapDecoration {
|
||||||
|
|
||||||
|
public static final Type<MapDecoration> TYPE = new Type<MapDecoration>(MapDecoration.class) {
|
||||||
|
@Override
|
||||||
|
public MapDecoration read(final ByteBuf buffer) throws Exception {
|
||||||
|
final String type = Type.STRING.read(buffer);
|
||||||
|
final double x = Type.DOUBLE.readPrimitive(buffer);
|
||||||
|
final double z = Type.DOUBLE.readPrimitive(buffer);
|
||||||
|
final float rotation = Type.FLOAT.readPrimitive(buffer);
|
||||||
|
return new MapDecoration(type, x, z, rotation);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void write(final ByteBuf buffer, final MapDecoration value) throws Exception {
|
||||||
|
Type.STRING.write(buffer, value.type);
|
||||||
|
buffer.writeDouble(value.x);
|
||||||
|
buffer.writeDouble(value.z);
|
||||||
|
buffer.writeFloat(value.rotation);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private final String type;
|
||||||
|
private final double x;
|
||||||
|
private final double z;
|
||||||
|
private final float rotation;
|
||||||
|
|
||||||
|
public MapDecoration(final String type, final double x, final double z, final float rotation) {
|
||||||
|
this.type = type;
|
||||||
|
this.x = x;
|
||||||
|
this.z = z;
|
||||||
|
this.rotation = rotation;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String type() {
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
|
||||||
|
public double x() {
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
|
||||||
|
public double z() {
|
||||||
|
return z;
|
||||||
|
}
|
||||||
|
|
||||||
|
public float rotation() {
|
||||||
|
return rotation;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,65 @@
|
|||||||
|
/*
|
||||||
|
* This file is part of ViaVersion - https://github.com/ViaVersion/ViaVersion
|
||||||
|
* Copyright (C) 2016-2024 ViaVersion and contributors
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
package com.viaversion.viaversion.api.minecraft.item.data;
|
||||||
|
|
||||||
|
import com.viaversion.viaversion.api.type.Type;
|
||||||
|
import io.netty.buffer.ByteBuf;
|
||||||
|
import it.unimi.dsi.fastutil.objects.Object2ObjectMap;
|
||||||
|
import it.unimi.dsi.fastutil.objects.Object2ObjectOpenHashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public final class MapDecorations {
|
||||||
|
|
||||||
|
public static final Type<MapDecorations> TYPE = new Type<MapDecorations>(MapDecorations.class) {
|
||||||
|
@Override
|
||||||
|
public MapDecorations read(final ByteBuf buffer) throws Exception {
|
||||||
|
final Object2ObjectMap<String, MapDecoration> decorations = new Object2ObjectOpenHashMap<>();
|
||||||
|
final int size = Type.VAR_INT.readPrimitive(buffer);
|
||||||
|
for (int i = 0; i < size; i++) {
|
||||||
|
final String id = Type.STRING.read(buffer);
|
||||||
|
final MapDecoration decoration = MapDecoration.TYPE.read(buffer);
|
||||||
|
decorations.put(id, decoration);
|
||||||
|
}
|
||||||
|
return new MapDecorations(decorations);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void write(final ByteBuf buffer, final MapDecorations value) throws Exception {
|
||||||
|
Type.VAR_INT.writePrimitive(buffer, value.decorations.size());
|
||||||
|
for (final Map.Entry<String, MapDecoration> entry : value.decorations.entrySet()) {
|
||||||
|
Type.STRING.write(buffer, entry.getKey());
|
||||||
|
MapDecoration.TYPE.write(buffer, entry.getValue());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private final Map<String, MapDecoration> decorations;
|
||||||
|
|
||||||
|
public MapDecorations(final Map<String, MapDecoration> decorations) {
|
||||||
|
this.decorations = decorations;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Map<String, MapDecoration> decorations() {
|
||||||
|
return decorations;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,62 @@
|
|||||||
|
/*
|
||||||
|
* This file is part of ViaVersion - https://github.com/ViaVersion/ViaVersion
|
||||||
|
* Copyright (C) 2016-2024 ViaVersion and contributors
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
package com.viaversion.viaversion.protocols.protocol1_20_5to1_20_3.data;
|
||||||
|
|
||||||
|
public final class MapDecorationMappings {
|
||||||
|
|
||||||
|
private static final String[] MAP_DECORATIONS = {
|
||||||
|
"player",
|
||||||
|
"frame",
|
||||||
|
"red_marker",
|
||||||
|
"blue_marker",
|
||||||
|
"target_x",
|
||||||
|
"target_point",
|
||||||
|
"player_off_map",
|
||||||
|
"player_off_limits",
|
||||||
|
"mansion",
|
||||||
|
"monument",
|
||||||
|
"banner_white",
|
||||||
|
"banner_orange",
|
||||||
|
"banner_magenta",
|
||||||
|
"banner_light_blue",
|
||||||
|
"banner_yellow",
|
||||||
|
"banner_lime",
|
||||||
|
"banner_pink",
|
||||||
|
"banner_gray",
|
||||||
|
"banner_light_gray",
|
||||||
|
"banner_cyan",
|
||||||
|
"banner_purple",
|
||||||
|
"banner_blue",
|
||||||
|
"banner_brown",
|
||||||
|
"banner_green",
|
||||||
|
"banner_red",
|
||||||
|
"banner_black",
|
||||||
|
"red_x",
|
||||||
|
"village_desert",
|
||||||
|
"village_plains",
|
||||||
|
"village_savanna",
|
||||||
|
"village_snowy",
|
||||||
|
"village_taiga",
|
||||||
|
"jungle_temple",
|
||||||
|
"swamp_hut"
|
||||||
|
};
|
||||||
|
|
||||||
|
public static String mapDecoration(final int index) {
|
||||||
|
return index < 0 || index >= MAP_DECORATIONS.length ? "player" : MAP_DECORATIONS[index];
|
||||||
|
}
|
||||||
|
}
|
@ -18,11 +18,13 @@
|
|||||||
package com.viaversion.viaversion.protocols.protocol1_20_5to1_20_3.rewriter;
|
package com.viaversion.viaversion.protocols.protocol1_20_5to1_20_3.rewriter;
|
||||||
|
|
||||||
import com.github.steveice10.opennbt.tag.builtin.CompoundTag;
|
import com.github.steveice10.opennbt.tag.builtin.CompoundTag;
|
||||||
|
import com.github.steveice10.opennbt.tag.builtin.IntArrayTag;
|
||||||
import com.github.steveice10.opennbt.tag.builtin.ListTag;
|
import com.github.steveice10.opennbt.tag.builtin.ListTag;
|
||||||
import com.github.steveice10.opennbt.tag.builtin.NumberTag;
|
import com.github.steveice10.opennbt.tag.builtin.NumberTag;
|
||||||
import com.github.steveice10.opennbt.tag.builtin.StringTag;
|
import com.github.steveice10.opennbt.tag.builtin.StringTag;
|
||||||
import com.github.steveice10.opennbt.tag.builtin.Tag;
|
import com.github.steveice10.opennbt.tag.builtin.Tag;
|
||||||
import com.viaversion.viaversion.api.data.ParticleMappings;
|
import com.viaversion.viaversion.api.data.ParticleMappings;
|
||||||
|
import com.viaversion.viaversion.api.minecraft.GameProfile;
|
||||||
import com.viaversion.viaversion.api.minecraft.Particle;
|
import com.viaversion.viaversion.api.minecraft.Particle;
|
||||||
import com.viaversion.viaversion.api.minecraft.data.StructuredData;
|
import com.viaversion.viaversion.api.minecraft.data.StructuredData;
|
||||||
import com.viaversion.viaversion.api.minecraft.data.StructuredDataContainer;
|
import com.viaversion.viaversion.api.minecraft.data.StructuredDataContainer;
|
||||||
@ -41,18 +43,25 @@ import com.viaversion.viaversion.protocols.protocol1_20_3to1_20_2.packet.Clientb
|
|||||||
import com.viaversion.viaversion.protocols.protocol1_20_3to1_20_2.rewriter.RecipeRewriter1_20_3;
|
import com.viaversion.viaversion.protocols.protocol1_20_3to1_20_2.rewriter.RecipeRewriter1_20_3;
|
||||||
import com.viaversion.viaversion.protocols.protocol1_20_5to1_20_3.Protocol1_20_5To1_20_3;
|
import com.viaversion.viaversion.protocols.protocol1_20_5to1_20_3.Protocol1_20_5To1_20_3;
|
||||||
import com.viaversion.viaversion.protocols.protocol1_20_5to1_20_3.data.EnchantmentMappings;
|
import com.viaversion.viaversion.protocols.protocol1_20_5to1_20_3.data.EnchantmentMappings;
|
||||||
|
import com.viaversion.viaversion.protocols.protocol1_20_5to1_20_3.data.MapDecorationMappings;
|
||||||
import com.viaversion.viaversion.protocols.protocol1_20_5to1_20_3.packet.ServerboundPacket1_20_5;
|
import com.viaversion.viaversion.protocols.protocol1_20_5to1_20_3.packet.ServerboundPacket1_20_5;
|
||||||
import com.viaversion.viaversion.protocols.protocol1_20_5to1_20_3.packet.ServerboundPackets1_20_5;
|
import com.viaversion.viaversion.protocols.protocol1_20_5to1_20_3.packet.ServerboundPackets1_20_5;
|
||||||
import com.viaversion.viaversion.rewriter.BlockRewriter;
|
import com.viaversion.viaversion.rewriter.BlockRewriter;
|
||||||
import com.viaversion.viaversion.rewriter.ItemRewriter;
|
import com.viaversion.viaversion.rewriter.ItemRewriter;
|
||||||
import com.viaversion.viaversion.util.Key;
|
import com.viaversion.viaversion.util.Key;
|
||||||
|
import com.viaversion.viaversion.util.UUIDUtil;
|
||||||
import it.unimi.dsi.fastutil.ints.Int2IntOpenHashMap;
|
import it.unimi.dsi.fastutil.ints.Int2IntOpenHashMap;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.UUID;
|
||||||
import org.checkerframework.checker.nullness.qual.Nullable;
|
import org.checkerframework.checker.nullness.qual.Nullable;
|
||||||
|
|
||||||
public final class BlockItemPacketRewriter1_20_5 extends ItemRewriter<ClientboundPacket1_20_3, ServerboundPacket1_20_5, Protocol1_20_5To1_20_3> {
|
public final class BlockItemPacketRewriter1_20_5 extends ItemRewriter<ClientboundPacket1_20_3, ServerboundPacket1_20_5, Protocol1_20_5To1_20_3> {
|
||||||
|
|
||||||
|
private final String tagMarker = "VV|" + protocol.getClass().getSimpleName();
|
||||||
|
|
||||||
public BlockItemPacketRewriter1_20_5(final Protocol1_20_5To1_20_3 protocol) {
|
public BlockItemPacketRewriter1_20_5(final Protocol1_20_5To1_20_3 protocol) {
|
||||||
super(protocol, Type.ITEM1_20_2, Type.ITEM1_20_2_ARRAY, Types1_20_5.ITEM, Types1_20_5.ITEM_ARRAY);
|
super(protocol, Type.ITEM1_20_2, Type.ITEM1_20_2_ARRAY, Types1_20_5.ITEM, Types1_20_5.ITEM_ARRAY);
|
||||||
}
|
}
|
||||||
@ -208,27 +217,25 @@ public final class BlockItemPacketRewriter1_20_5 extends ItemRewriter<Clientboun
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Rewrite nbt to new data structures
|
// Rewrite nbt to new data structures
|
||||||
|
updateDisplay(data, tag.getCompoundTag("display"));
|
||||||
|
|
||||||
final NumberTag damage = tag.getNumberTag("Damage");
|
final NumberTag damage = tag.getNumberTag("Damage");
|
||||||
if (damage != null && damage.asInt() != 0) {
|
if (damage != null && damage.asInt() != 0) {
|
||||||
tag.remove("Damage");
|
|
||||||
data.add(StructuredDataKey.DAMAGE, damage.asInt());
|
data.add(StructuredDataKey.DAMAGE, damage.asInt());
|
||||||
}
|
}
|
||||||
|
|
||||||
final NumberTag repairCost = tag.getNumberTag("RepairCost");
|
final NumberTag repairCost = tag.getNumberTag("RepairCost");
|
||||||
if (repairCost != null && repairCost.asInt() != 0) {
|
if (repairCost != null && repairCost.asInt() != 0) {
|
||||||
tag.remove("RepairCost");
|
|
||||||
data.add(StructuredDataKey.REPAIR_COST, repairCost.asInt());
|
data.add(StructuredDataKey.REPAIR_COST, repairCost.asInt());
|
||||||
}
|
}
|
||||||
|
|
||||||
final NumberTag customModelData = tag.getNumberTag("CustomModelData");
|
final NumberTag customModelData = tag.getNumberTag("CustomModelData");
|
||||||
if (customModelData != null) {
|
if (customModelData != null) {
|
||||||
tag.remove("CustomModelData");
|
|
||||||
data.add(StructuredDataKey.CUSTOM_MODEL_DATA, customModelData.asInt());
|
data.add(StructuredDataKey.CUSTOM_MODEL_DATA, customModelData.asInt());
|
||||||
}
|
}
|
||||||
|
|
||||||
final CompoundTag blockState = tag.getCompoundTag("BlockStateTag");
|
final CompoundTag blockState = tag.getCompoundTag("BlockStateTag");
|
||||||
if (blockState != null) {
|
if (blockState != null) {
|
||||||
tag.remove("BlockStateTag");
|
|
||||||
final Map<String, String> properties = new HashMap<>();
|
final Map<String, String> properties = new HashMap<>();
|
||||||
for (final Map.Entry<String, Tag> entry : blockState.entrySet()) {
|
for (final Map.Entry<String, Tag> entry : blockState.entrySet()) {
|
||||||
if (entry.getValue() instanceof StringTag) {
|
if (entry.getValue() instanceof StringTag) {
|
||||||
@ -240,7 +247,6 @@ public final class BlockItemPacketRewriter1_20_5 extends ItemRewriter<Clientboun
|
|||||||
|
|
||||||
final CompoundTag entityTag = tag.getCompoundTag("EntityTag");
|
final CompoundTag entityTag = tag.getCompoundTag("EntityTag");
|
||||||
if (entityTag != null) {
|
if (entityTag != null) {
|
||||||
tag.remove("EntityTag");
|
|
||||||
data.add(StructuredDataKey.ENTITY_DATA, entityTag);
|
data.add(StructuredDataKey.ENTITY_DATA, entityTag);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -252,11 +258,9 @@ public final class BlockItemPacketRewriter1_20_5 extends ItemRewriter<Clientboun
|
|||||||
|
|
||||||
final NumberTag hideFlags = tag.getNumberTag("HideFlags");
|
final NumberTag hideFlags = tag.getNumberTag("HideFlags");
|
||||||
final int hideFlagsValue = hideFlags != null ? hideFlags.asInt() : 0;
|
final int hideFlagsValue = hideFlags != null ? hideFlags.asInt() : 0;
|
||||||
tag.remove("HideFlags");
|
|
||||||
|
|
||||||
final NumberTag unbreakable = tag.getNumberTag("Unbreakable");
|
final NumberTag unbreakable = tag.getNumberTag("Unbreakable");
|
||||||
if (unbreakable != null && unbreakable.asBoolean()) {
|
if (unbreakable != null && unbreakable.asBoolean()) {
|
||||||
tag.remove("Unbreakable");
|
|
||||||
if ((hideFlagsValue & 0x04) != 0) {
|
if ((hideFlagsValue & 0x04) != 0) {
|
||||||
data.add(StructuredDataKey.UNBREAKABLE, true); // TODO Value is hide, should have a wrapper
|
data.add(StructuredDataKey.UNBREAKABLE, true); // TODO Value is hide, should have a wrapper
|
||||||
} else {
|
} else {
|
||||||
@ -267,6 +271,17 @@ public final class BlockItemPacketRewriter1_20_5 extends ItemRewriter<Clientboun
|
|||||||
updateEnchantments(data, tag, "Enchantments", StructuredDataKey.ENCHANTMENTS, (hideFlagsValue & 0x01) == 0);
|
updateEnchantments(data, tag, "Enchantments", StructuredDataKey.ENCHANTMENTS, (hideFlagsValue & 0x01) == 0);
|
||||||
updateEnchantments(data, tag, "StoredEnchantments", StructuredDataKey.STORED_ENCHANTMENTS, (hideFlagsValue & 0x20) == 0);
|
updateEnchantments(data, tag, "StoredEnchantments", StructuredDataKey.STORED_ENCHANTMENTS, (hideFlagsValue & 0x20) == 0);
|
||||||
|
|
||||||
|
final NumberTag map = tag.getNumberTag("map");
|
||||||
|
if (map != null) {
|
||||||
|
data.add(StructuredDataKey.MAP_ID, map.asInt());
|
||||||
|
}
|
||||||
|
|
||||||
|
updateMapDecorations(data, tag.getListTag("Decorations"));
|
||||||
|
|
||||||
|
// MAP_POST_PROCESSING is only used internally
|
||||||
|
|
||||||
|
updateProfile(data, tag.get("SkullOwner"));
|
||||||
|
|
||||||
// TODO
|
// TODO
|
||||||
// StructuredDataKey.CUSTOM_NAME
|
// StructuredDataKey.CUSTOM_NAME
|
||||||
// StructuredDataKey.LORE
|
// StructuredDataKey.LORE
|
||||||
@ -278,10 +293,6 @@ public final class BlockItemPacketRewriter1_20_5 extends ItemRewriter<Clientboun
|
|||||||
// StructuredDataKey.CREATIVE_SLOT_LOCK
|
// StructuredDataKey.CREATIVE_SLOT_LOCK
|
||||||
// StructuredDataKey.INTANGIBLE_PROJECTILE
|
// StructuredDataKey.INTANGIBLE_PROJECTILE
|
||||||
// StructuredDataKey.DYED_COLOR
|
// StructuredDataKey.DYED_COLOR
|
||||||
// StructuredDataKey.MAP_COLOR
|
|
||||||
// StructuredDataKey.MAP_ID
|
|
||||||
// StructuredDataKey.MAP_DECORATIONS
|
|
||||||
// StructuredDataKey.MAP_POST_PROCESSING
|
|
||||||
// StructuredDataKey.CHARGED_PROJECTILES
|
// StructuredDataKey.CHARGED_PROJECTILES
|
||||||
// StructuredDataKey.BUNDLE_CONTENTS
|
// StructuredDataKey.BUNDLE_CONTENTS
|
||||||
// StructuredDataKey.POTION_CONTENTS
|
// StructuredDataKey.POTION_CONTENTS
|
||||||
@ -297,7 +308,6 @@ public final class BlockItemPacketRewriter1_20_5 extends ItemRewriter<Clientboun
|
|||||||
// StructuredDataKey.LODESTONE_TARGET
|
// StructuredDataKey.LODESTONE_TARGET
|
||||||
// StructuredDataKey.FIREWORK_EXPLOSION
|
// StructuredDataKey.FIREWORK_EXPLOSION
|
||||||
// StructuredDataKey.FIREWORKS
|
// StructuredDataKey.FIREWORKS
|
||||||
// StructuredDataKey.PROFILE
|
|
||||||
// StructuredDataKey.NOTE_BLOCK_SOUND
|
// StructuredDataKey.NOTE_BLOCK_SOUND
|
||||||
// StructuredDataKey.BANNER_PATTERNS
|
// StructuredDataKey.BANNER_PATTERNS
|
||||||
// StructuredDataKey.BASE_COLOR
|
// StructuredDataKey.BASE_COLOR
|
||||||
@ -307,7 +317,8 @@ public final class BlockItemPacketRewriter1_20_5 extends ItemRewriter<Clientboun
|
|||||||
// StructuredDataKey.LOCK
|
// StructuredDataKey.LOCK
|
||||||
// StructuredDataKey.CONTAINER_LOOT
|
// StructuredDataKey.CONTAINER_LOOT
|
||||||
|
|
||||||
// Add the rest as custom data
|
// Add the original as custom data, to be re-used for creative clients as well
|
||||||
|
tag.putBoolean(tagMarker, true);
|
||||||
data.add(StructuredDataKey.CUSTOM_DATA, tag);
|
data.add(StructuredDataKey.CUSTOM_DATA, tag);
|
||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
@ -349,4 +360,93 @@ public final class BlockItemPacketRewriter1_20_5 extends ItemRewriter<Clientboun
|
|||||||
data.add(StructuredDataKey.ENCHANTMENT_GLINT_OVERRIDE, true);
|
data.add(StructuredDataKey.ENCHANTMENT_GLINT_OVERRIDE, true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void updateProfile(final StructuredDataContainer data, final Tag skullOwnerTag) {
|
||||||
|
final String name;
|
||||||
|
final List<GameProfile.Property> properties = new ArrayList<>(1);
|
||||||
|
UUID uuid = null;
|
||||||
|
if (skullOwnerTag instanceof StringTag) {
|
||||||
|
name = ((StringTag) skullOwnerTag).getValue();
|
||||||
|
} else if (skullOwnerTag instanceof CompoundTag) {
|
||||||
|
final CompoundTag skullOwner = (CompoundTag) skullOwnerTag;
|
||||||
|
final StringTag nameTag = skullOwner.getStringTag("Name");
|
||||||
|
name = nameTag != null ? nameTag.getValue() : "";
|
||||||
|
|
||||||
|
final IntArrayTag idTag = skullOwner.getIntArrayTag("Id");
|
||||||
|
if (idTag != null) {
|
||||||
|
uuid = UUIDUtil.fromIntArray(idTag.getValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
final CompoundTag propertiesTag = skullOwner.getCompoundTag("Properties");
|
||||||
|
if (propertiesTag != null) {
|
||||||
|
for (final Map.Entry<String, Tag> entry : propertiesTag.entrySet()) {
|
||||||
|
if (!(entry.getValue() instanceof ListTag)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (final Tag propertyTag : (ListTag) entry.getValue()) {
|
||||||
|
if (!(propertyTag instanceof CompoundTag)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
final StringTag valueTag = ((CompoundTag) propertyTag).getStringTag("Value");
|
||||||
|
final StringTag signatureTag = ((CompoundTag) propertyTag).getStringTag("Signature");
|
||||||
|
final GameProfile.Property property = new GameProfile.Property(
|
||||||
|
entry.getKey(),
|
||||||
|
valueTag != null ? valueTag.getValue() : "",
|
||||||
|
signatureTag != null ? signatureTag.getValue() : null
|
||||||
|
);
|
||||||
|
properties.add(property);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
data.add(StructuredDataKey.PROFILE, new GameProfile(name, uuid, properties.toArray(new GameProfile.Property[0])));
|
||||||
|
}
|
||||||
|
|
||||||
|
private void updateMapDecorations(final StructuredDataContainer data, final ListTag decorationsTag) {
|
||||||
|
if (decorationsTag == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
final CompoundTag updatedDecorationsTag = new CompoundTag();
|
||||||
|
for (final Tag decorationTag : decorationsTag) {
|
||||||
|
if (!(decorationTag instanceof CompoundTag)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
final CompoundTag decoration = (CompoundTag) decorationTag;
|
||||||
|
final StringTag idTag = decoration.getStringTag("id");
|
||||||
|
final String id = idTag != null ? idTag.asRawString() : "";
|
||||||
|
final NumberTag typeTag = decoration.getNumberTag("type");
|
||||||
|
final int type = typeTag != null ? typeTag.asInt() : 0;
|
||||||
|
final NumberTag xTag = decoration.getNumberTag("x");
|
||||||
|
final NumberTag zTag = decoration.getNumberTag("z");
|
||||||
|
final NumberTag rotationTag = decoration.getNumberTag("rot");
|
||||||
|
|
||||||
|
final CompoundTag updatedDecorationTag = new CompoundTag();
|
||||||
|
updatedDecorationTag.putString("type", MapDecorationMappings.mapDecoration(type));
|
||||||
|
updatedDecorationTag.putDouble("x", xTag != null ? xTag.asDouble() : 0);
|
||||||
|
updatedDecorationTag.putDouble("z", zTag != null ? zTag.asDouble() : 0);
|
||||||
|
updatedDecorationTag.putFloat("rotation", rotationTag != null ? rotationTag.asFloat() : 0);
|
||||||
|
updatedDecorationsTag.put(id, updatedDecorationTag);
|
||||||
|
}
|
||||||
|
|
||||||
|
data.add(StructuredDataKey.MAP_DECORATIONS, updatedDecorationsTag);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void updateDisplay(final StructuredDataContainer data, final CompoundTag displayTag) {
|
||||||
|
if (displayTag == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
final NumberTag mapColorTag = displayTag.getNumberTag("MapColor");
|
||||||
|
if (mapColorTag != null) {
|
||||||
|
data.add(StructuredDataKey.MAP_COLOR, mapColorTag.asInt());
|
||||||
|
}
|
||||||
|
// TODO other display values
|
||||||
|
}
|
||||||
}
|
}
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren