Update to recent Geyser

This commit is contained in:
Eclipse 2024-06-18 08:24:54 +00:00
parent ac4d543069
commit 6819d2b4c6
No known key found for this signature in database
GPG key ID: 441A0B7FDD01D03A

View file

@ -207,7 +207,7 @@ public class CustomItemRegistryPopulator {
if (mapping.isEdible() || customItemData.isEdible()) { if (mapping.isEdible() || customItemData.isEdible()) {
computeConsumableProperties(itemProperties, componentBuilder, 1, computeConsumableProperties(itemProperties, componentBuilder, 1,
customItemData.canAlwaysEat(), protocolVersion); customItemData.canAlwaysEat());
} }
if (mapping.isEntityPlacer()) { if (mapping.isEntityPlacer()) {
@ -221,7 +221,7 @@ public class CustomItemRegistryPopulator {
switch (mapping.getBedrockIdentifier()) { switch (mapping.getBedrockIdentifier()) {
case "minecraft:fire_charge", "minecraft:flint_and_steel" -> computeBlockItemProperties("minecraft:fire", componentBuilder); case "minecraft:fire_charge", "minecraft:flint_and_steel" -> computeBlockItemProperties("minecraft:fire", componentBuilder);
case "minecraft:bow", "minecraft:crossbow", "minecraft:trident" -> computeChargeableProperties(itemProperties, componentBuilder, mapping.getBedrockIdentifier(), protocolVersion); case "minecraft:bow", "minecraft:crossbow", "minecraft:trident" -> computeChargeableProperties(itemProperties, componentBuilder, mapping.getBedrockIdentifier(), protocolVersion);
case "minecraft:honey_bottle", "minecraft:milk_bucket", "minecraft:potion" -> computeConsumableProperties(itemProperties, componentBuilder, 2, true, protocolVersion); case "minecraft:honey_bottle", "minecraft:milk_bucket", "minecraft:potion" -> computeConsumableProperties(itemProperties, componentBuilder, 2, true);
case "minecraft:experience_bottle", "minecraft:egg", "minecraft:ender_pearl", "minecraft:ender_eye", "minecraft:lingering_potion", "minecraft:snowball", "minecraft:splash_potion" -> case "minecraft:experience_bottle", "minecraft:egg", "minecraft:ender_pearl", "minecraft:ender_eye", "minecraft:lingering_potion", "minecraft:snowball", "minecraft:splash_potion" ->
computeThrowableProperties(componentBuilder); computeThrowableProperties(componentBuilder);
} }
@ -258,7 +258,7 @@ public class CustomItemRegistryPopulator {
} }
if (customItemData.isEdible()) { if (customItemData.isEdible()) {
computeConsumableProperties(itemProperties, componentBuilder, 1, customItemData.canAlwaysEat(), protocolVersion); computeConsumableProperties(itemProperties, componentBuilder, 1, customItemData.canAlwaysEat());
} }
if (customItemData.isChargeable()) { if (customItemData.isChargeable()) {
@ -501,7 +501,7 @@ public class CustomItemRegistryPopulator {
} }
private static void computeConsumableProperties(NbtMapBuilder itemProperties, NbtMapBuilder componentBuilder, private static void computeConsumableProperties(NbtMapBuilder itemProperties, NbtMapBuilder componentBuilder,
int useAnimation, boolean canAlwaysEat, int protocolVersion) { int useAnimation, boolean canAlwaysEat) {
// this is the duration of the use animation in ticks; note that in behavior packs this is set as a float in seconds, but over the network it is an int in ticks // this is the duration of the use animation in ticks; note that in behavior packs this is set as a float in seconds, but over the network it is an int in ticks
itemProperties.putInt("use_duration", 32); itemProperties.putInt("use_duration", 32);
// this dictates that the item will use the eat or drink animation (in the first person) and play eat or drink sounds // this dictates that the item will use the eat or drink animation (in the first person) and play eat or drink sounds
@ -509,13 +509,6 @@ public class CustomItemRegistryPopulator {
itemProperties.putInt("use_animation", useAnimation); itemProperties.putInt("use_animation", useAnimation);
// this component is required to allow the eat animation to play // this component is required to allow the eat animation to play
componentBuilder.putCompound("minecraft:food", NbtMap.builder().putBoolean("can_always_eat", canAlwaysEat).build()); componentBuilder.putCompound("minecraft:food", NbtMap.builder().putBoolean("can_always_eat", canAlwaysEat).build());
if (GameProtocol.is1_20_60orHigher(protocolVersion)) {
componentBuilder.putCompound("minecraft:use_modifiers", NbtMap.builder()
.putFloat("use_duration", 100F)
.putFloat("movement_modifier", 0.35F)
.build());
}
} }
private static void computeEntityPlacerProperties(NbtMapBuilder componentBuilder) { private static void computeEntityPlacerProperties(NbtMapBuilder componentBuilder) {