Compare commits
3 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9115254afb | ||
|
|
22644195f0 | ||
|
|
1cefbde37e |
@@ -12,7 +12,7 @@ apply plugin: 'net.minecraftforge.gradle'
|
|||||||
apply plugin: 'eclipse'
|
apply plugin: 'eclipse'
|
||||||
apply plugin: 'maven-publish'
|
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
|
group = 'nl.requios.effortlessbuilding' // http://maven.apache.org/guides/mini/guide-naming-conventions.html
|
||||||
archivesBaseName = 'effortlessbuilding'
|
archivesBaseName = 'effortlessbuilding'
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,8 @@
|
|||||||
package nl.requios.effortlessbuilding;
|
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.level.block.Blocks;
|
||||||
import net.minecraft.world.entity.Entity;
|
import net.minecraft.world.entity.Entity;
|
||||||
import net.minecraft.world.entity.player.Player;
|
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.buildmodifier.UndoRedo;
|
||||||
import nl.requios.effortlessbuilding.capability.ModeCapabilityManager;
|
import nl.requios.effortlessbuilding.capability.ModeCapabilityManager;
|
||||||
import nl.requios.effortlessbuilding.capability.ModifierCapabilityManager;
|
import nl.requios.effortlessbuilding.capability.ModifierCapabilityManager;
|
||||||
|
import nl.requios.effortlessbuilding.compatibility.CompatHelper;
|
||||||
import nl.requios.effortlessbuilding.helper.ReachHelper;
|
import nl.requios.effortlessbuilding.helper.ReachHelper;
|
||||||
import nl.requios.effortlessbuilding.network.AddUndoMessage;
|
import nl.requios.effortlessbuilding.network.AddUndoMessage;
|
||||||
import nl.requios.effortlessbuilding.network.ClearUndoMessage;
|
import nl.requios.effortlessbuilding.network.ClearUndoMessage;
|
||||||
@@ -51,7 +55,15 @@ public class EventHandler {
|
|||||||
ModifierSettingsManager.ModifierSettings modifierSettings = ModifierSettingsManager.getModifierSettings(player);
|
ModifierSettingsManager.ModifierSettings modifierSettings = ModifierSettingsManager.getModifierSettings(player);
|
||||||
|
|
||||||
if (buildMode != BuildModes.BuildModeEnum.NORMAL) {
|
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);
|
event.setCanceled(true);
|
||||||
|
}
|
||||||
|
|
||||||
} else if (modifierSettings.doQuickReplace()) {
|
} else if (modifierSettings.doQuickReplace()) {
|
||||||
//Cancel event and send message if QuickReplace
|
//Cancel event and send message if QuickReplace
|
||||||
event.setCanceled(true);
|
event.setCanceled(true);
|
||||||
|
|||||||
@@ -1,22 +1,15 @@
|
|||||||
package nl.requios.effortlessbuilding;
|
package nl.requios.effortlessbuilding;
|
||||||
|
|
||||||
import com.mojang.blaze3d.vertex.DefaultVertexFormat;
|
import com.mojang.blaze3d.vertex.DefaultVertexFormat;
|
||||||
import net.minecraft.client.Minecraft;
|
|
||||||
import net.minecraft.client.renderer.ShaderInstance;
|
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.minecraft.resources.ResourceLocation;
|
||||||
import net.minecraftforge.api.distmarker.Dist;
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
import net.minecraftforge.client.event.RegisterShadersEvent;
|
import net.minecraftforge.client.event.RegisterShadersEvent;
|
||||||
import net.minecraftforge.client.event.TextureStitchEvent;
|
|
||||||
import net.minecraftforge.eventbus.api.SubscribeEvent;
|
import net.minecraftforge.eventbus.api.SubscribeEvent;
|
||||||
import net.minecraftforge.fml.common.Mod;
|
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 nl.requios.effortlessbuilding.render.BuildRenderTypes;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.HashMap;
|
|
||||||
|
|
||||||
@Mod.EventBusSubscriber(bus = Mod.EventBusSubscriber.Bus.MOD, value = {Dist.CLIENT})
|
@Mod.EventBusSubscriber(bus = Mod.EventBusSubscriber.Bus.MOD, value = {Dist.CLIENT})
|
||||||
public class ModClientEventHandler {
|
public class ModClientEventHandler {
|
||||||
|
|||||||
@@ -53,7 +53,6 @@ public class BuildModes {
|
|||||||
startPos = message.getBlockPos();
|
startPos = message.getBlockPos();
|
||||||
|
|
||||||
//Offset in direction of sidehit if not quickreplace and not replaceable
|
//Offset in direction of sidehit if not quickreplace and not replaceable
|
||||||
//TODO 1.13 replaceable
|
|
||||||
boolean replaceable = player.level.getBlockState(startPos).getMaterial().isReplaceable();
|
boolean replaceable = player.level.getBlockState(startPos).getMaterial().isReplaceable();
|
||||||
boolean becomesDoubleSlab = SurvivalHelper.doesBecomeDoubleSlab(player, startPos, message.getSideHit());
|
boolean becomesDoubleSlab = SurvivalHelper.doesBecomeDoubleSlab(player, startPos, message.getSideHit());
|
||||||
if (!modifierSettings.doQuickReplace() && !replaceable && !becomesDoubleSlab) {
|
if (!modifierSettings.doQuickReplace() && !replaceable && !becomesDoubleSlab) {
|
||||||
@@ -99,7 +98,6 @@ public class BuildModes {
|
|||||||
//Only works when finishing a buildmode is equal to placing some blocks
|
//Only works when finishing a buildmode is equal to placing some blocks
|
||||||
//No intermediate blocks allowed
|
//No intermediate blocks allowed
|
||||||
currentlyBreaking.remove(player);
|
currentlyBreaking.remove(player);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Use a network message to break blocks in the distance using clientside mouse input
|
//Use a network message to break blocks in the distance using clientside mouse input
|
||||||
@@ -276,6 +274,10 @@ public class BuildModes {
|
|||||||
this.options = options;
|
this.options = options;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
public String getNameKey() {
|
public String getNameKey() {
|
||||||
return "effortlessbuilding.mode." + name;
|
return "effortlessbuilding.mode." + name;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -31,7 +31,7 @@ public class ModeSettingsManager {
|
|||||||
return capability.getModeData();
|
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 dummy settings
|
||||||
return new ModeSettings();
|
return new ModeSettings();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -33,7 +33,7 @@ public class ModifierSettingsManager {
|
|||||||
return capability.getModifierData();
|
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 dummy settings
|
||||||
return new ModifierSettings();
|
return new ModifierSettings();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -191,7 +191,7 @@ public class PlayerSettingsGui extends Screen {
|
|||||||
return right - 6;
|
return right - 6;
|
||||||
}
|
}
|
||||||
|
|
||||||
//From AbstractList, disabled parts
|
//From AbstractSelectionList, disabled parts
|
||||||
@Override
|
@Override
|
||||||
public void render(PoseStack ms, int p_render_1_, int p_render_2_, float p_render_3_) {
|
public void render(PoseStack ms, int p_render_1_, int p_render_2_, float p_render_3_) {
|
||||||
this.renderBackground(ms);
|
this.renderBackground(ms);
|
||||||
|
|||||||
@@ -45,6 +45,8 @@ import nl.requios.effortlessbuilding.buildmode.ModeOptions.OptionEnum;
|
|||||||
@MethodsReturnNonnullByDefault
|
@MethodsReturnNonnullByDefault
|
||||||
public class RadialMenu extends Screen {
|
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 radialButtonColor = new Vector4f(0f, 0f, 0f, .5f);
|
||||||
private final Vector4f sideButtonColor = new Vector4f(.5f, .5f, .5f, .5f);
|
private final Vector4f sideButtonColor = new Vector4f(.5f, .5f, .5f, .5f);
|
||||||
private final Vector4f highlightColor = new Vector4f(.6f, .8f, 1f, .6f);
|
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 descriptionTextColor = 0xdd888888;
|
||||||
private final int optionTextColor = 0xeeeeeeff;
|
private final int optionTextColor = 0xeeeeeeff;
|
||||||
|
|
||||||
private final double ringInnerEdge = 40;
|
private final double ringInnerEdge = 30;
|
||||||
private final double ringOuterEdge = 80;
|
private final double ringOuterEdge = 65;
|
||||||
private final double categoryLineOuterEdge = 42;
|
private final double categoryLineWidth = 1;
|
||||||
private final double textDistance = 90;
|
private final double textDistance = 75;
|
||||||
private final double buttonDistance = 120;
|
private final double buttonDistance = 105;
|
||||||
private final float fadeSpeed = 0.3f;
|
private final float fadeSpeed = 0.3f;
|
||||||
private final int descriptionHeight = 100;
|
private final int descriptionHeight = 100;
|
||||||
|
|
||||||
public static final RadialMenu instance = new RadialMenu();
|
|
||||||
public BuildModeEnum switchTo = null;
|
public BuildModeEnum switchTo = null;
|
||||||
public ActionEnum doAction = null;
|
public ActionEnum doAction = null;
|
||||||
public boolean performedActionUsingMouse;
|
public boolean performedActionUsingMouse;
|
||||||
@@ -164,7 +165,7 @@ public class RadialMenu extends Screen {
|
|||||||
doAction = null;
|
doAction = null;
|
||||||
|
|
||||||
//Draw buildmode backgrounds
|
//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
|
//Draw action backgrounds
|
||||||
drawSideButtonBackgrounds(buffer, middleX, middleY, mouseXCenter, mouseYCenter, buttons);
|
drawSideButtonBackgrounds(buffer, middleX, middleY, mouseXCenter, mouseYCenter, buttons);
|
||||||
@@ -173,14 +174,15 @@ public class RadialMenu extends Screen {
|
|||||||
RenderSystem.disableBlend();
|
RenderSystem.disableBlend();
|
||||||
RenderSystem.enableTexture();
|
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();
|
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()) {
|
if (!modes.isEmpty()) {
|
||||||
final int totalModes = Math.max(3, modes.size());
|
final int totalModes = Math.max(3, modes.size());
|
||||||
final double fragment = Math.PI * 0.005; //gap between buttons in radians at inner edge
|
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
|
//Category line
|
||||||
color = menuRegion.mode.category.color;
|
color = menuRegion.mode.category.color;
|
||||||
|
final double categoryLineOuterEdge = ringInnerEdge + categoryLineWidth;
|
||||||
|
|
||||||
final double x1m3 = Math.cos(beginRadians + fragment) * categoryLineOuterEdge;
|
final double x1m3 = Math.cos(beginRadians + fragment) * categoryLineOuterEdge;
|
||||||
final double x2m3 = Math.cos(endRadians - 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();
|
ms.pushPose();
|
||||||
RenderSystem.enableTexture();
|
RenderSystem.enableTexture();
|
||||||
RenderSystem.setShader(GameRenderer::getPositionColorTexShader);
|
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 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);
|
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);
|
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();
|
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);
|
//font.drawStringWithShadow("Actions", (int) (middleX - buttonDistance - 13) - font.getStringWidth("Actions") * 0.5f, (int) middleY - 38, 0xffffffff);
|
||||||
|
|
||||||
//Draw option strings
|
//Draw option strings
|
||||||
@@ -473,7 +476,8 @@ public class RadialMenu extends Screen {
|
|||||||
public static void playRadialMenuSound() {
|
public static void playRadialMenuSound() {
|
||||||
final float volume = 0.1f;
|
final float volume = 0.1f;
|
||||||
if (volume >= 0.0001f) {
|
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);
|
Minecraft.getInstance().getSoundManager().play(sound);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -135,7 +135,7 @@ public class ClientProxy implements IProxy {
|
|||||||
if (player == null) return;
|
if (player == null) return;
|
||||||
BuildModes.BuildModeEnum buildMode = ModeSettingsManager.getModeSettings(player).getBuildMode();
|
BuildModes.BuildModeEnum buildMode = ModeSettingsManager.getModeSettings(player).getBuildMode();
|
||||||
|
|
||||||
if (Minecraft.getInstance().screen != null ||
|
if (mc.screen != null ||
|
||||||
buildMode == BuildModes.BuildModeEnum.NORMAL ||
|
buildMode == BuildModes.BuildModeEnum.NORMAL ||
|
||||||
RadialMenu.instance.isVisible()) {
|
RadialMenu.instance.isVisible()) {
|
||||||
return;
|
return;
|
||||||
|
|||||||
@@ -76,7 +76,7 @@ public class BlockPreviewRenderer {
|
|||||||
lookingAt = Minecraft.getInstance().hitResult;
|
lookingAt = Minecraft.getInstance().hitResult;
|
||||||
|
|
||||||
ItemStack mainhand = player.getMainHandItem();
|
ItemStack mainhand = player.getMainHandItem();
|
||||||
boolean toolInHand = !(!mainhand.isEmpty() && CompatHelper.isItemBlockProxy(mainhand));
|
boolean noBlockInHand = !(!mainhand.isEmpty() && CompatHelper.isItemBlockProxy(mainhand));
|
||||||
|
|
||||||
BlockPos startPos = null;
|
BlockPos startPos = null;
|
||||||
Direction sideHit = null;
|
Direction sideHit = null;
|
||||||
@@ -91,12 +91,12 @@ public class BlockPreviewRenderer {
|
|||||||
//TODO 1.13 replaceable
|
//TODO 1.13 replaceable
|
||||||
boolean replaceable = player.level.getBlockState(startPos).getMaterial().isReplaceable();
|
boolean replaceable = player.level.getBlockState(startPos).getMaterial().isReplaceable();
|
||||||
boolean becomesDoubleSlab = SurvivalHelper.doesBecomeDoubleSlab(player, startPos, blockLookingAt.getDirection());
|
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());
|
startPos = startPos.relative(blockLookingAt.getDirection());
|
||||||
}
|
}
|
||||||
|
|
||||||
//Get under tall grass and other replaceable blocks
|
//Get under tall grass and other replaceable blocks
|
||||||
if (modifierSettings.doQuickReplace() && !toolInHand && replaceable) {
|
if (modifierSettings.doQuickReplace() && !noBlockInHand && replaceable) {
|
||||||
startPos = startPos.below();
|
startPos = startPos.below();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -236,12 +236,12 @@ public class BlockPreviewRenderer {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
VertexConsumer buffer = RenderHandler.beginLines(renderTypeBuffer);
|
//Draw outlines if no block in hand
|
||||||
//Draw outlines if tool in hand
|
|
||||||
//Find proper raytrace: either normal range or increased range depending on canBreakFar
|
//Find proper raytrace: either normal range or increased range depending on canBreakFar
|
||||||
|
VertexConsumer buffer = RenderHandler.beginLines(renderTypeBuffer);
|
||||||
HitResult objectMouseOver = Minecraft.getInstance().hitResult;
|
HitResult objectMouseOver = Minecraft.getInstance().hitResult;
|
||||||
HitResult breakingRaytrace = ReachHelper.canBreakFar(player) ? lookingAt : objectMouseOver;
|
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;
|
BlockHitResult blockBreakingRaytrace = (BlockHitResult) breakingRaytrace;
|
||||||
List<BlockPos> breakCoordinates = BuildModifiers.findCoordinates(player, blockBreakingRaytrace.getBlockPos());
|
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:ender_pearl"
|
||||||
},
|
},
|
||||||
"#": {
|
"#": {
|
||||||
"item": "minecraft:prismarine_crystals"
|
"item": "minecraft:slime_ball"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"result": {
|
"result": {
|
||||||
|
|||||||
@@ -1,19 +1,16 @@
|
|||||||
{
|
{
|
||||||
"type": "minecraft:crafting_shaped",
|
"type": "minecraft:crafting_shaped",
|
||||||
"pattern": [
|
"pattern": [
|
||||||
"x#x",
|
" # ",
|
||||||
"#O#",
|
"#O#",
|
||||||
"x#x"
|
" # "
|
||||||
],
|
],
|
||||||
"key": {
|
"key": {
|
||||||
"O": {
|
"O": {
|
||||||
"item": "minecraft:ender_pearl"
|
"item": "minecraft:ender_pearl"
|
||||||
},
|
},
|
||||||
"#": {
|
"#": {
|
||||||
"item": "minecraft:slime_ball"
|
"item": "minecraft:blaze_powder"
|
||||||
},
|
|
||||||
"x": {
|
|
||||||
"item": "minecraft:chorus_fruit"
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"result": {
|
"result": {
|
||||||
|
|||||||
@@ -7,13 +7,13 @@
|
|||||||
],
|
],
|
||||||
"key": {
|
"key": {
|
||||||
"O": {
|
"O": {
|
||||||
"item": "minecraft:nether_star"
|
"item": "minecraft:end_crystal"
|
||||||
},
|
},
|
||||||
"#": {
|
"#": {
|
||||||
"item": "minecraft:diamond"
|
"item": "minecraft:chorus_fruit"
|
||||||
},
|
},
|
||||||
"x": {
|
"x": {
|
||||||
"item": "minecraft:amethyst_shard"
|
"item": "minecraft:ghast_tear"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"result": {
|
"result": {
|
||||||
|
|||||||
Reference in New Issue
Block a user