Compare commits
3 Commits
1.19-hotfi
...
1.18
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9115254afb | ||
|
|
22644195f0 | ||
|
|
1cefbde37e |
@@ -12,7 +12,7 @@ apply plugin: 'net.minecraftforge.gradle'
|
||||
apply plugin: 'eclipse'
|
||||
apply plugin: 'maven-publish'
|
||||
|
||||
version = '1.18-2.34'
|
||||
version = '1.18-2.40'
|
||||
group = 'nl.requios.effortlessbuilding' // http://maven.apache.org/guides/mini/guide-naming-conventions.html
|
||||
archivesBaseName = 'effortlessbuilding'
|
||||
|
||||
|
||||
@@ -1,5 +1,8 @@
|
||||
package nl.requios.effortlessbuilding;
|
||||
|
||||
import net.minecraft.world.InteractionHand;
|
||||
import net.minecraft.world.item.BlockItem;
|
||||
import net.minecraft.world.item.ItemStack;
|
||||
import net.minecraft.world.level.block.Blocks;
|
||||
import net.minecraft.world.entity.Entity;
|
||||
import net.minecraft.world.entity.player.Player;
|
||||
@@ -19,6 +22,7 @@ import nl.requios.effortlessbuilding.buildmodifier.ModifierSettingsManager;
|
||||
import nl.requios.effortlessbuilding.buildmodifier.UndoRedo;
|
||||
import nl.requios.effortlessbuilding.capability.ModeCapabilityManager;
|
||||
import nl.requios.effortlessbuilding.capability.ModifierCapabilityManager;
|
||||
import nl.requios.effortlessbuilding.compatibility.CompatHelper;
|
||||
import nl.requios.effortlessbuilding.helper.ReachHelper;
|
||||
import nl.requios.effortlessbuilding.network.AddUndoMessage;
|
||||
import nl.requios.effortlessbuilding.network.ClearUndoMessage;
|
||||
@@ -51,7 +55,15 @@ public class EventHandler {
|
||||
ModifierSettingsManager.ModifierSettings modifierSettings = ModifierSettingsManager.getModifierSettings(player);
|
||||
|
||||
if (buildMode != BuildModes.BuildModeEnum.NORMAL) {
|
||||
|
||||
//Only cancel if itemblock in hand
|
||||
//Fixed issue with e.g. Create Wrench shift-rightclick disassembling being cancelled.
|
||||
ItemStack currentItemStack = player.getItemInHand(InteractionHand.MAIN_HAND);
|
||||
if (currentItemStack.getItem() instanceof BlockItem ||
|
||||
(CompatHelper.isItemBlockProxy(currentItemStack) && !player.isShiftKeyDown())) {
|
||||
event.setCanceled(true);
|
||||
}
|
||||
|
||||
} else if (modifierSettings.doQuickReplace()) {
|
||||
//Cancel event and send message if QuickReplace
|
||||
event.setCanceled(true);
|
||||
|
||||
@@ -1,22 +1,15 @@
|
||||
package nl.requios.effortlessbuilding;
|
||||
|
||||
import com.mojang.blaze3d.vertex.DefaultVertexFormat;
|
||||
import net.minecraft.client.Minecraft;
|
||||
import net.minecraft.client.renderer.ShaderInstance;
|
||||
import net.minecraft.client.renderer.texture.TextureAtlas;
|
||||
import net.minecraft.client.renderer.texture.TextureAtlasSprite;
|
||||
import net.minecraft.resources.ResourceLocation;
|
||||
import net.minecraftforge.api.distmarker.Dist;
|
||||
import net.minecraftforge.client.event.RegisterShadersEvent;
|
||||
import net.minecraftforge.client.event.TextureStitchEvent;
|
||||
import net.minecraftforge.eventbus.api.SubscribeEvent;
|
||||
import net.minecraftforge.fml.common.Mod;
|
||||
import nl.requios.effortlessbuilding.buildmode.BuildModes;
|
||||
import nl.requios.effortlessbuilding.buildmode.ModeOptions;
|
||||
import nl.requios.effortlessbuilding.render.BuildRenderTypes;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.HashMap;
|
||||
|
||||
@Mod.EventBusSubscriber(bus = Mod.EventBusSubscriber.Bus.MOD, value = {Dist.CLIENT})
|
||||
public class ModClientEventHandler {
|
||||
|
||||
@@ -53,7 +53,6 @@ public class BuildModes {
|
||||
startPos = message.getBlockPos();
|
||||
|
||||
//Offset in direction of sidehit if not quickreplace and not replaceable
|
||||
//TODO 1.13 replaceable
|
||||
boolean replaceable = player.level.getBlockState(startPos).getMaterial().isReplaceable();
|
||||
boolean becomesDoubleSlab = SurvivalHelper.doesBecomeDoubleSlab(player, startPos, message.getSideHit());
|
||||
if (!modifierSettings.doQuickReplace() && !replaceable && !becomesDoubleSlab) {
|
||||
@@ -99,7 +98,6 @@ public class BuildModes {
|
||||
//Only works when finishing a buildmode is equal to placing some blocks
|
||||
//No intermediate blocks allowed
|
||||
currentlyBreaking.remove(player);
|
||||
|
||||
}
|
||||
|
||||
//Use a network message to break blocks in the distance using clientside mouse input
|
||||
@@ -276,6 +274,10 @@ public class BuildModes {
|
||||
this.options = options;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
|
||||
public String getNameKey() {
|
||||
return "effortlessbuilding.mode." + name;
|
||||
}
|
||||
|
||||
@@ -31,7 +31,7 @@ public class ModeSettingsManager {
|
||||
return capability.getModeData();
|
||||
}
|
||||
|
||||
EffortlessBuilding.logger.warn("Player does not have modeCapability: " + player);
|
||||
// EffortlessBuilding.logger.warn("Player does not have modeCapability: " + player);
|
||||
//Return dummy settings
|
||||
return new ModeSettings();
|
||||
}
|
||||
|
||||
@@ -33,7 +33,7 @@ public class ModifierSettingsManager {
|
||||
return capability.getModifierData();
|
||||
}
|
||||
|
||||
EffortlessBuilding.logger.warn("Player does not have modifierCapability: " + player);
|
||||
// EffortlessBuilding.logger.warn("Player does not have modifierCapability: " + player);
|
||||
//Return dummy settings
|
||||
return new ModifierSettings();
|
||||
}
|
||||
|
||||
@@ -191,7 +191,7 @@ public class PlayerSettingsGui extends Screen {
|
||||
return right - 6;
|
||||
}
|
||||
|
||||
//From AbstractList, disabled parts
|
||||
//From AbstractSelectionList, disabled parts
|
||||
@Override
|
||||
public void render(PoseStack ms, int p_render_1_, int p_render_2_, float p_render_3_) {
|
||||
this.renderBackground(ms);
|
||||
|
||||
@@ -45,6 +45,8 @@ import nl.requios.effortlessbuilding.buildmode.ModeOptions.OptionEnum;
|
||||
@MethodsReturnNonnullByDefault
|
||||
public class RadialMenu extends Screen {
|
||||
|
||||
public static final RadialMenu instance = new RadialMenu();
|
||||
|
||||
private final Vector4f radialButtonColor = new Vector4f(0f, 0f, 0f, .5f);
|
||||
private final Vector4f sideButtonColor = new Vector4f(.5f, .5f, .5f, .5f);
|
||||
private final Vector4f highlightColor = new Vector4f(.6f, .8f, 1f, .6f);
|
||||
@@ -56,15 +58,14 @@ public class RadialMenu extends Screen {
|
||||
private final int descriptionTextColor = 0xdd888888;
|
||||
private final int optionTextColor = 0xeeeeeeff;
|
||||
|
||||
private final double ringInnerEdge = 40;
|
||||
private final double ringOuterEdge = 80;
|
||||
private final double categoryLineOuterEdge = 42;
|
||||
private final double textDistance = 90;
|
||||
private final double buttonDistance = 120;
|
||||
private final double ringInnerEdge = 30;
|
||||
private final double ringOuterEdge = 65;
|
||||
private final double categoryLineWidth = 1;
|
||||
private final double textDistance = 75;
|
||||
private final double buttonDistance = 105;
|
||||
private final float fadeSpeed = 0.3f;
|
||||
private final int descriptionHeight = 100;
|
||||
|
||||
public static final RadialMenu instance = new RadialMenu();
|
||||
public BuildModeEnum switchTo = null;
|
||||
public ActionEnum doAction = null;
|
||||
public boolean performedActionUsingMouse;
|
||||
@@ -164,7 +165,7 @@ public class RadialMenu extends Screen {
|
||||
doAction = null;
|
||||
|
||||
//Draw buildmode backgrounds
|
||||
drawRadialButtonBackgrounds(currentBuildMode, buffer, middleX, middleY, mouseXCenter, mouseYCenter, mouseRadians, ringInnerEdge, ringOuterEdge, quarterCircle, modes);
|
||||
drawRadialButtonBackgrounds(currentBuildMode, buffer, middleX, middleY, mouseXCenter, mouseYCenter, mouseRadians, quarterCircle, modes);
|
||||
|
||||
//Draw action backgrounds
|
||||
drawSideButtonBackgrounds(buffer, middleX, middleY, mouseXCenter, mouseYCenter, buttons);
|
||||
@@ -173,14 +174,15 @@ public class RadialMenu extends Screen {
|
||||
RenderSystem.disableBlend();
|
||||
RenderSystem.enableTexture();
|
||||
|
||||
drawIcons(ms, tessellator, buffer, middleX, middleY, ringInnerEdge, ringOuterEdge, modes, buttons);
|
||||
drawIcons(ms, middleX, middleY, modes, buttons);
|
||||
|
||||
drawTexts(ms, currentBuildMode, middleX, middleY, textDistance, buttonDistance, modes, buttons, options);
|
||||
drawTexts(ms, currentBuildMode, middleX, middleY, modes, buttons, options);
|
||||
|
||||
ms.popPose();
|
||||
}
|
||||
|
||||
private void drawRadialButtonBackgrounds(BuildModeEnum currentBuildMode, BufferBuilder buffer, double middleX, double middleY, double mouseXCenter, double mouseYCenter, double mouseRadians, double ringInnerEdge, double ringOuterEdge, double quarterCircle, ArrayList<MenuRegion> modes) {
|
||||
private void drawRadialButtonBackgrounds(BuildModeEnum currentBuildMode, BufferBuilder buffer, double middleX, double middleY,
|
||||
double mouseXCenter, double mouseYCenter, double mouseRadians, double quarterCircle, ArrayList<MenuRegion> modes) {
|
||||
if (!modes.isEmpty()) {
|
||||
final int totalModes = Math.max(3, modes.size());
|
||||
final double fragment = Math.PI * 0.005; //gap between buttons in radians at inner edge
|
||||
@@ -229,6 +231,7 @@ public class RadialMenu extends Screen {
|
||||
|
||||
//Category line
|
||||
color = menuRegion.mode.category.color;
|
||||
final double categoryLineOuterEdge = ringInnerEdge + categoryLineWidth;
|
||||
|
||||
final double x1m3 = Math.cos(beginRadians + fragment) * categoryLineOuterEdge;
|
||||
final double x2m3 = Math.cos(endRadians - fragment) * categoryLineOuterEdge;
|
||||
@@ -273,7 +276,7 @@ public class RadialMenu extends Screen {
|
||||
}
|
||||
}
|
||||
|
||||
private void drawIcons(PoseStack ms, Tesselator tessellator, BufferBuilder buffer, double middleX, double middleY, double ringInnerEdge, double ringOuterEdge, ArrayList<MenuRegion> modes, ArrayList<MenuButton> buttons) {
|
||||
private void drawIcons(PoseStack ms, double middleX, double middleY, ArrayList<MenuRegion> modes, ArrayList<MenuButton> buttons) {
|
||||
ms.pushPose();
|
||||
RenderSystem.enableTexture();
|
||||
RenderSystem.setShader(GameRenderer::getPositionColorTexShader);
|
||||
@@ -285,7 +288,7 @@ public class RadialMenu extends Screen {
|
||||
final double x = (menuRegion.x1 + menuRegion.x2) * 0.5 * (ringOuterEdge * 0.55 + 0.45 * ringInnerEdge);
|
||||
final double y = (menuRegion.y1 + menuRegion.y2) * 0.5 * (ringOuterEdge * 0.55 + 0.45 * ringInnerEdge);
|
||||
|
||||
RenderSystem.setShaderTexture(0, new ResourceLocation(EffortlessBuilding.MODID, "textures/icons/" + menuRegion.mode.name().toLowerCase() + ".png"));
|
||||
RenderSystem.setShaderTexture(0, new ResourceLocation(EffortlessBuilding.MODID, "textures/icons/" + menuRegion.mode.getName() + ".png"));
|
||||
blit(ms, (int) (middleX + x - 8), (int) (middleY + y - 8), 16, 16, 0, 0, 18, 18, 18, 18);
|
||||
}
|
||||
|
||||
@@ -302,7 +305,7 @@ public class RadialMenu extends Screen {
|
||||
ms.popPose();
|
||||
}
|
||||
|
||||
private void drawTexts(PoseStack ms, BuildModeEnum currentBuildMode, double middleX, double middleY, double textDistance, double buttonDistance, ArrayList<MenuRegion> modes, ArrayList<MenuButton> buttons, OptionEnum[] options) {
|
||||
private void drawTexts(PoseStack ms, BuildModeEnum currentBuildMode, double middleX, double middleY, ArrayList<MenuRegion> modes, ArrayList<MenuButton> buttons, OptionEnum[] options) {
|
||||
//font.drawStringWithShadow("Actions", (int) (middleX - buttonDistance - 13) - font.getStringWidth("Actions") * 0.5f, (int) middleY - 38, 0xffffffff);
|
||||
|
||||
//Draw option strings
|
||||
@@ -473,7 +476,8 @@ public class RadialMenu extends Screen {
|
||||
public static void playRadialMenuSound() {
|
||||
final float volume = 0.1f;
|
||||
if (volume >= 0.0001f) {
|
||||
SimpleSoundInstance sound = new SimpleSoundInstance(SoundEvents.UI_BUTTON_CLICK, SoundSource.MASTER, volume, 1.0f, Minecraft.getInstance().player.blockPosition());
|
||||
SimpleSoundInstance sound = new SimpleSoundInstance(SoundEvents.UI_BUTTON_CLICK, SoundSource.MASTER, volume,
|
||||
1.0f, Minecraft.getInstance().player.blockPosition());
|
||||
Minecraft.getInstance().getSoundManager().play(sound);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -135,7 +135,7 @@ public class ClientProxy implements IProxy {
|
||||
if (player == null) return;
|
||||
BuildModes.BuildModeEnum buildMode = ModeSettingsManager.getModeSettings(player).getBuildMode();
|
||||
|
||||
if (Minecraft.getInstance().screen != null ||
|
||||
if (mc.screen != null ||
|
||||
buildMode == BuildModes.BuildModeEnum.NORMAL ||
|
||||
RadialMenu.instance.isVisible()) {
|
||||
return;
|
||||
|
||||
@@ -76,7 +76,7 @@ public class BlockPreviewRenderer {
|
||||
lookingAt = Minecraft.getInstance().hitResult;
|
||||
|
||||
ItemStack mainhand = player.getMainHandItem();
|
||||
boolean toolInHand = !(!mainhand.isEmpty() && CompatHelper.isItemBlockProxy(mainhand));
|
||||
boolean noBlockInHand = !(!mainhand.isEmpty() && CompatHelper.isItemBlockProxy(mainhand));
|
||||
|
||||
BlockPos startPos = null;
|
||||
Direction sideHit = null;
|
||||
@@ -91,12 +91,12 @@ public class BlockPreviewRenderer {
|
||||
//TODO 1.13 replaceable
|
||||
boolean replaceable = player.level.getBlockState(startPos).getMaterial().isReplaceable();
|
||||
boolean becomesDoubleSlab = SurvivalHelper.doesBecomeDoubleSlab(player, startPos, blockLookingAt.getDirection());
|
||||
if (!modifierSettings.doQuickReplace() && !toolInHand && !replaceable && !becomesDoubleSlab) {
|
||||
if (!modifierSettings.doQuickReplace() && !noBlockInHand && !replaceable && !becomesDoubleSlab) {
|
||||
startPos = startPos.relative(blockLookingAt.getDirection());
|
||||
}
|
||||
|
||||
//Get under tall grass and other replaceable blocks
|
||||
if (modifierSettings.doQuickReplace() && !toolInHand && replaceable) {
|
||||
if (modifierSettings.doQuickReplace() && !noBlockInHand && replaceable) {
|
||||
startPos = startPos.below();
|
||||
}
|
||||
|
||||
@@ -236,12 +236,12 @@ public class BlockPreviewRenderer {
|
||||
|
||||
}
|
||||
|
||||
VertexConsumer buffer = RenderHandler.beginLines(renderTypeBuffer);
|
||||
//Draw outlines if tool in hand
|
||||
//Draw outlines if no block in hand
|
||||
//Find proper raytrace: either normal range or increased range depending on canBreakFar
|
||||
VertexConsumer buffer = RenderHandler.beginLines(renderTypeBuffer);
|
||||
HitResult objectMouseOver = Minecraft.getInstance().hitResult;
|
||||
HitResult breakingRaytrace = ReachHelper.canBreakFar(player) ? lookingAt : objectMouseOver;
|
||||
if (toolInHand && breakingRaytrace != null && breakingRaytrace.getType() == HitResult.Type.BLOCK) {
|
||||
if (player.isCreative() && noBlockInHand && breakingRaytrace != null && breakingRaytrace.getType() == HitResult.Type.BLOCK) {
|
||||
BlockHitResult blockBreakingRaytrace = (BlockHitResult) breakingRaytrace;
|
||||
List<BlockPos> breakCoordinates = BuildModifiers.findCoordinates(player, blockBreakingRaytrace.getBlockPos());
|
||||
|
||||
|
||||
79
src/main/resources/assets/effortlessbuilding/lang/ru_ru.json
Normal file
79
src/main/resources/assets/effortlessbuilding/lang/ru_ru.json
Normal file
@@ -0,0 +1,79 @@
|
||||
{
|
||||
"efortlessbuilding.screen.modifier_settings": "Настройки модификатора",
|
||||
"efortlessbuilding.screen.radial_menu": "Режимы строительства",
|
||||
"efortlessbuilding.screen.player_settings": "Настройки игрока",
|
||||
|
||||
"key.efortlessbuilding.category": "Строительство без усилий",
|
||||
"key.efortlessbuilding.hud.desc": "Меню модификаторов",
|
||||
"key.effortlessbuilding.replace.desc": "Переключить быструю замену",
|
||||
"key.efortlessbuilding.mode.desc": "Круговое меню",
|
||||
"key.efortlessbuilding.undo.desc": "Отменить",
|
||||
"key.effortlessbuilding.redo.desc": "Повторить",
|
||||
"key.efortlessbuilding.altplacement.desc": "Альтернативное размещение",
|
||||
|
||||
"efortlessbuilding:randomizer_bag": "Кожаная сумка рандомизатора",
|
||||
"efortlessbuilding:golden_randomizer_bag": "Золотой мешок рандомизатора",
|
||||
"efortlessbuilding:diamond_randomizer_bag": "Бриллиантовый рандомизатор",
|
||||
"efortlessbuilding:reach_upgrade1": "Достичь улучшения 1",
|
||||
"efortlessbuilding:reach_upgrade2": "Достичь улучшения 2",
|
||||
"efortlessbuilding:reach_upgrade3": "Достичь улучшения 3",
|
||||
|
||||
"efortlessbuilding.mode.normal": "Отключить",
|
||||
"efortlessbuilding.mode.normal_plus": "Одиночный",
|
||||
"efortlessbuilding.mode.line": "Линия",
|
||||
"efortlessbuilding.mode.wall": "Стена",
|
||||
"efortlessbuilding.mode.floor": "Этаж",
|
||||
"efortlessbuilding.mode.diagonal_line": "Диагональная линия",
|
||||
"efortlessbuilding.mode.diagonal_wall": "Диагональная стена",
|
||||
"effortlessbuilding.mode.slope_floor": "Наклонный этаж",
|
||||
"effortlessbuilding.mode.cube": "Куб",
|
||||
"efortlessbuilding.mode.circle": "Круг",
|
||||
"efortlessbuilding.mode.cylinder": "Цилиндр",
|
||||
"efortlessbuilding.mode.sphere": "Сфера",
|
||||
"efortlessbuilding.mode.pyramid": "Пирамида",
|
||||
"effortlessbuilding.mode.cone": "Конус",
|
||||
"efortlessbuilding.mode.dome": "Купол",
|
||||
|
||||
"effortlessbuilding.modedescription.normal": "Отключить мод и использовать ванильные правила размещения",
|
||||
"effortlessbuilding.modedescription.normal_plus": "Как и ваниль, но с увеличенным охватом и предварительным просмотром места размещения",
|
||||
"efortlessbuilding.modedescription.line": "",
|
||||
"efortlessbuilding.modedescription.wall": "",
|
||||
"efortlessbuilding.modedescription.floor": "",
|
||||
"efortlessbuilding.modedescription.diagonal_line": "",
|
||||
"efortlessbuilding.modedescription.diagonal_wall": "",
|
||||
"effortlessbuilding.modedescription.slope_floor": "",
|
||||
"efortlessbuilding.modedescription.cube": "",
|
||||
"efortlessbuilding.modedescription.circle": "",
|
||||
"efortlessbuilding.modedescription.cylinder": "",
|
||||
"efortlessbuilding.modedescription.sphere": "",
|
||||
"efortlessbuilding.modedescription.pyramid": "",
|
||||
"efortlessbuilding.modedescription.cone": "",
|
||||
"efortlessbuilding.modedescription.dome": "",
|
||||
|
||||
"efortlessbuilding.action.undo": "Отменить",
|
||||
"efortlessbuilding.action.redo": "Повторить",
|
||||
"efortlessbuilding.action.replace": "Заменить",
|
||||
"efortlessbuilding.action.open_modifier_settings": "Открыть настройки модификатора",
|
||||
"efortlessbuilding.action.open_player_settings": "Открыть настройки",
|
||||
|
||||
"efortlessbuilding.action.build_speed": "Скорость сборки",
|
||||
"efortlessbuilding.action.filling": "Заполнение",
|
||||
"efortlessbuilding.action.raised_edge": "Приподнятый край",
|
||||
"efortlessbuilding.action.thickness": "Толщина линии",
|
||||
"efortlessbuilding.action.circle_start": "Начальная точка",
|
||||
|
||||
"efortlessbuilding.action.normal_speed": "Нормальный",
|
||||
"efortlessbuilding.action.fast_speed": "Быстро",
|
||||
"efortlessbuilding.action.full": "Заполнено",
|
||||
"efortlessbuilding.action.hollow": "Пустой",
|
||||
"efortlessbuilding.action.skeleton": "Скелет",
|
||||
"efortlessbuilding.action.short_edge": "Короткая кромка",
|
||||
"efortlessbuilding.action.long_edge": "Длинный край",
|
||||
"efortlessbuilding.action.thickness_1": "Толщиной 1 блок",
|
||||
"efortlessbuilding.action.thickness_3": "Толщиной 3 блока",
|
||||
"efortlessbuilding.action.thickness_5": "Толщиной 5 блоков",
|
||||
"efortlessbuilding.action.start_center": "Посередине",
|
||||
"efortlessbuilding.action.start_corner": "Угол",
|
||||
|
||||
"commands.reach.usage": "/reach <уровень>"
|
||||
}
|
||||
Binary file not shown.
|
Before Width: | Height: | Size: 319 B After Width: | Height: | Size: 4.9 KiB |
Binary file not shown.
|
Before Width: | Height: | Size: 603 B After Width: | Height: | Size: 625 B |
Binary file not shown.
|
Before Width: | Height: | Size: 625 B After Width: | Height: | Size: 603 B |
@@ -10,7 +10,7 @@
|
||||
"item": "minecraft:ender_pearl"
|
||||
},
|
||||
"#": {
|
||||
"item": "minecraft:prismarine_crystals"
|
||||
"item": "minecraft:slime_ball"
|
||||
}
|
||||
},
|
||||
"result": {
|
||||
|
||||
@@ -1,19 +1,16 @@
|
||||
{
|
||||
"type": "minecraft:crafting_shaped",
|
||||
"pattern": [
|
||||
"x#x",
|
||||
" # ",
|
||||
"#O#",
|
||||
"x#x"
|
||||
" # "
|
||||
],
|
||||
"key": {
|
||||
"O": {
|
||||
"item": "minecraft:ender_pearl"
|
||||
},
|
||||
"#": {
|
||||
"item": "minecraft:slime_ball"
|
||||
},
|
||||
"x": {
|
||||
"item": "minecraft:chorus_fruit"
|
||||
"item": "minecraft:blaze_powder"
|
||||
}
|
||||
},
|
||||
"result": {
|
||||
|
||||
@@ -7,13 +7,13 @@
|
||||
],
|
||||
"key": {
|
||||
"O": {
|
||||
"item": "minecraft:nether_star"
|
||||
"item": "minecraft:end_crystal"
|
||||
},
|
||||
"#": {
|
||||
"item": "minecraft:diamond"
|
||||
"item": "minecraft:chorus_fruit"
|
||||
},
|
||||
"x": {
|
||||
"item": "minecraft:amethyst_shard"
|
||||
"item": "minecraft:ghast_tear"
|
||||
}
|
||||
},
|
||||
"result": {
|
||||
|
||||
Reference in New Issue
Block a user