Compare commits
6 Commits
master
...
1.19-hotfi
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
ee235d0689 | ||
|
|
84d3c34d66 | ||
|
|
ea59fef099 | ||
|
|
5e6c42d372 | ||
|
|
14460c2c01 | ||
|
|
3b31a74780 |
5
.gitattributes
vendored
Normal file
5
.gitattributes
vendored
Normal file
@@ -0,0 +1,5 @@
|
||||
# Disable autocrlf on generated files, they always generate with LF
|
||||
# Add any extra files or paths here to make git stop saying they
|
||||
# are changed when only line endings change.
|
||||
src/generated/**/.cache/cache text eol=lf
|
||||
src/generated/**/*.json text eol=lf
|
||||
89
build.gradle
89
build.gradle
@@ -1,31 +1,24 @@
|
||||
buildscript {
|
||||
repositories {
|
||||
maven { url = 'https://files.minecraftforge.net/maven' }
|
||||
mavenCentral()
|
||||
}
|
||||
dependencies {
|
||||
classpath group: 'net.minecraftforge.gradle', name: 'ForgeGradle', version: '5.1+', changing: true
|
||||
}
|
||||
plugins {
|
||||
id 'eclipse'
|
||||
id 'maven-publish'
|
||||
id 'net.minecraftforge.gradle' version '5.1.+'
|
||||
}
|
||||
apply plugin: 'net.minecraftforge.gradle'
|
||||
// Only edit below this line, the above code adds and enables the necessary things for Forge to be setup.
|
||||
apply plugin: 'eclipse'
|
||||
apply plugin: 'maven-publish'
|
||||
|
||||
version = '1.18-2.34'
|
||||
group = 'nl.requios.effortlessbuilding' // http://maven.apache.org/guides/mini/guide-naming-conventions.html
|
||||
version = '1.19-2.40'
|
||||
group = 'nl.requios.effortlessbuilding'
|
||||
archivesBaseName = 'effortlessbuilding'
|
||||
|
||||
// Mojang ships Java 17 to end users in 1.18+, so your mod should target Java 17.
|
||||
java.toolchain.languageVersion = JavaLanguageVersion.of(17)
|
||||
|
||||
println "Java: ${System.getProperty 'java.version'}, JVM: ${System.getProperty 'java.vm.version'} (${System.getProperty 'java.vendor'}), Arch: ${System.getProperty 'os.arch'}"
|
||||
minecraft {
|
||||
// The mappings can be changed at any time, and must be in the following format.
|
||||
// snapshot_YYYYMMDD Snapshot are built nightly.
|
||||
// stable_# Stables are built at the discretion of the MCP team.
|
||||
// Use non-default mappings at your own risk. they may not always work.
|
||||
// Simply re-run your setup task after changing the mappings to update your workspace.
|
||||
mappings channel: 'official', version: '1.19'
|
||||
mappings channel: 'official', version: '1.19.2'
|
||||
accessTransformer = file('src/main/resources/META-INF/accesstransformer.cfg')
|
||||
// makeObfSourceJar = false // an Srg named sources jar is made by default. uncomment this to disable.
|
||||
|
||||
@@ -41,6 +34,9 @@ minecraft {
|
||||
// Recommended logging level for the console
|
||||
property 'forge.logging.console.level', 'debug'
|
||||
|
||||
// Comma-separated list of namespaces to load gametests from. Empty = all namespaces.
|
||||
property 'forge.enabledGameTestNamespaces', 'effortlessbuilding'
|
||||
|
||||
mods {
|
||||
effortlessbuilding {
|
||||
source sourceSets.main
|
||||
@@ -51,12 +47,31 @@ minecraft {
|
||||
server {
|
||||
workingDirectory project.file('run')
|
||||
|
||||
// Recommended logging data for a userdev environment (SCAN,REGISTRIES,REGISTRYDUMP)
|
||||
property 'forge.logging.markers', 'REGISTRIES'
|
||||
|
||||
// Recommended logging level for the console
|
||||
property 'forge.logging.console.level', 'debug'
|
||||
|
||||
property 'forge.enabledGameTestNamespaces', 'effortlessbuilding'
|
||||
|
||||
mods {
|
||||
effortlessbuilding {
|
||||
source sourceSets.main
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// This run config launches GameTestServer and runs all registered gametests, then exits.
|
||||
// By default, the server will crash when no gametests are provided.
|
||||
// The gametest system is also enabled by default for other run configs under the /test command.
|
||||
gameTestServer {
|
||||
workingDirectory project.file('run')
|
||||
|
||||
property 'forge.logging.markers', 'REGISTRIES'
|
||||
|
||||
property 'forge.logging.console.level', 'debug'
|
||||
|
||||
property 'forge.enabledGameTestNamespaces', 'effortlessbuilding'
|
||||
|
||||
mods {
|
||||
effortlessbuilding {
|
||||
source sourceSets.main
|
||||
@@ -65,12 +80,10 @@ minecraft {
|
||||
}
|
||||
|
||||
data {
|
||||
workingDirectory project.file('run')
|
||||
workingDirectory project.file('run')
|
||||
|
||||
// Recommended logging data for a userdev environment (SCAN,REGISTRIES,REGISTRYDUMP)
|
||||
property 'forge.logging.markers', 'REGISTRIES'
|
||||
|
||||
// Recommended logging level for the console
|
||||
property 'forge.logging.console.level', 'debug'
|
||||
|
||||
// Specify the modid for data generation, where to output the resulting resource, and where to look for existing resources.
|
||||
@@ -85,11 +98,24 @@ minecraft {
|
||||
}
|
||||
}
|
||||
|
||||
// Include resources generated by data generators.
|
||||
sourceSets.main.resources { srcDir 'src/generated/resources' }
|
||||
|
||||
repositories {
|
||||
// Put repositories for dependencies here
|
||||
// ForgeGradle automatically adds the Forge maven and Maven Central for you
|
||||
|
||||
// If you have mod jar dependencies in ./libs, you can declare them as a repository like so:
|
||||
// flatDir {
|
||||
// dir 'libs'
|
||||
// }
|
||||
}
|
||||
|
||||
dependencies {
|
||||
// Specify the version of Minecraft to use, If this is any group other then 'net.minecraft' it is assumed
|
||||
// that the dep is a ForgeGradle 'patcher' dependency. And it's patches will be applied.
|
||||
// Specify the version of Minecraft to use. If this is any group other than 'net.minecraft', it is assumed
|
||||
// that the dep is a ForgeGradle 'patcher' dependency, and its patches will be applied.
|
||||
// The userdev artifact is a special name and will get all sorts of transformations applied to it.
|
||||
minecraft 'net.minecraftforge:forge:1.19-41.0.99'
|
||||
minecraft 'net.minecraftforge:forge:1.19.2-43.1.47'
|
||||
|
||||
// Real mod deobf dependency examples - these get remapped to your current mappings
|
||||
// compileOnly fg.deobf("mezz.jei:jei-${mc_version}:${jei_version}:api") // Adds JEI API as a compile dependency
|
||||
@@ -102,7 +128,6 @@ dependencies {
|
||||
// For more info...
|
||||
// http://www.gradle.org/docs/current/userguide/artifact_dependencies_tutorial.html
|
||||
// http://www.gradle.org/docs/current/userguide/dependency_management.html
|
||||
|
||||
}
|
||||
|
||||
// Example for how to get properties into the manifest for reading by the runtime..
|
||||
@@ -113,18 +138,18 @@ jar {
|
||||
"Specification-Vendor": "requios",
|
||||
"Specification-Version": "1", // We are version 1 of ourselves
|
||||
"Implementation-Title": project.name,
|
||||
"Implementation-Version": "${version}",
|
||||
"Implementation-Version": project.jar.archiveVersion,
|
||||
"Implementation-Vendor" :"requios",
|
||||
"Implementation-Timestamp": new Date().format("yyyy-MM-dd'T'HH:mm:ssZ")
|
||||
])
|
||||
}
|
||||
}
|
||||
|
||||
// Example configuration to allow publishing using the maven-publish task
|
||||
// Example configuration to allow publishing using the maven-publish plugin
|
||||
// This is the preferred method to reobfuscate your jar file
|
||||
jar.finalizedBy('reobfJar')
|
||||
jar.finalizedBy('reobfJar')
|
||||
// However if you are in a multi-project build, dev time needs unobfed jar files, so you can delay the obfuscation until publishing by doing
|
||||
//publish.dependsOn('reobfJar')
|
||||
// publish.dependsOn('reobfJar')
|
||||
|
||||
publishing {
|
||||
publications {
|
||||
@@ -134,7 +159,11 @@ publishing {
|
||||
}
|
||||
repositories {
|
||||
maven {
|
||||
url "file:///${project.projectDir}/mcmodsrepo"
|
||||
url "file://${project.projectDir}/mcmodsrepo"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
tasks.withType(JavaCompile).configureEach {
|
||||
options.encoding = 'UTF-8' // Use the UTF-8 charset for Java compilation
|
||||
}
|
||||
|
||||
6
settings.gradle
Normal file
6
settings.gradle
Normal file
@@ -0,0 +1,6 @@
|
||||
pluginManagement {
|
||||
repositories {
|
||||
gradlePluginPortal()
|
||||
maven { url = 'https://maven.minecraftforge.net/' }
|
||||
}
|
||||
}
|
||||
@@ -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) {
|
||||
event.setCanceled(true);
|
||||
|
||||
//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,26 +1,46 @@
|
||||
package nl.requios.effortlessbuilding;
|
||||
|
||||
import com.mojang.blaze3d.platform.InputConstants;
|
||||
import com.mojang.blaze3d.vertex.DefaultVertexFormat;
|
||||
import net.minecraft.client.Minecraft;
|
||||
import net.minecraft.client.KeyMapping;
|
||||
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.RegisterKeyMappingsEvent;
|
||||
import net.minecraftforge.client.event.RegisterShadersEvent;
|
||||
import net.minecraftforge.client.event.TextureStitchEvent;
|
||||
import net.minecraftforge.client.settings.KeyConflictContext;
|
||||
import net.minecraftforge.client.settings.KeyModifier;
|
||||
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.proxy.ClientProxy;
|
||||
import nl.requios.effortlessbuilding.render.BuildRenderTypes;
|
||||
import org.lwjgl.glfw.GLFW;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.HashMap;
|
||||
|
||||
@Mod.EventBusSubscriber(bus = Mod.EventBusSubscriber.Bus.MOD, value = {Dist.CLIENT})
|
||||
public class ModClientEventHandler {
|
||||
|
||||
@SubscribeEvent
|
||||
public static void registerKeyMappings(RegisterKeyMappingsEvent event) {
|
||||
EffortlessBuilding.log("Registering KeyMappings!");
|
||||
|
||||
// register key bindings
|
||||
ClientProxy.keyBindings = new KeyMapping[6];
|
||||
|
||||
// instantiate the key bindings
|
||||
ClientProxy.keyBindings[0] = new KeyMapping("key.effortlessbuilding.hud.desc", KeyConflictContext.IN_GAME, InputConstants.getKey(GLFW.GLFW_KEY_KP_ADD, 0), "key.effortlessbuilding.category");
|
||||
ClientProxy.keyBindings[1] = new KeyMapping("key.effortlessbuilding.replace.desc", KeyConflictContext.IN_GAME, InputConstants.getKey(GLFW.GLFW_KEY_KP_SUBTRACT, 0), "key.effortlessbuilding.category");
|
||||
ClientProxy.keyBindings[2] = new KeyMapping("key.effortlessbuilding.mode.desc", KeyConflictContext.IN_GAME, InputConstants.getKey(GLFW.GLFW_KEY_LEFT_ALT, 0), "key.effortlessbuilding.category");
|
||||
ClientProxy.keyBindings[3] = new KeyMapping("key.effortlessbuilding.undo.desc", KeyConflictContext.IN_GAME, KeyModifier.CONTROL, InputConstants.getKey(GLFW.GLFW_KEY_Z, 0), "key.effortlessbuilding.category");
|
||||
ClientProxy.keyBindings[4] = new KeyMapping("key.effortlessbuilding.redo.desc", KeyConflictContext.IN_GAME, KeyModifier.CONTROL, InputConstants.getKey(GLFW.GLFW_KEY_Y, 0), "key.effortlessbuilding.category");
|
||||
ClientProxy.keyBindings[5] = new KeyMapping("key.effortlessbuilding.altplacement.desc", KeyConflictContext.IN_GAME, InputConstants.getKey(GLFW.GLFW_KEY_LEFT_CONTROL, 0), "key.effortlessbuilding.category");
|
||||
|
||||
for (KeyMapping keyBinding : ClientProxy.keyBindings) {
|
||||
event.register(keyBinding);
|
||||
}
|
||||
}
|
||||
|
||||
@SubscribeEvent
|
||||
public static void registerShaders(RegisterShadersEvent event) throws IOException {
|
||||
event.registerShader(new ShaderInstance(event.getResourceManager(),
|
||||
|
||||
@@ -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
|
||||
@@ -275,6 +273,10 @@ public class BuildModes {
|
||||
this.category = category;
|
||||
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();
|
||||
}
|
||||
|
||||
@@ -187,7 +187,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);
|
||||
@@ -212,7 +212,7 @@ public class PlayerSettingsGui extends Screen {
|
||||
this.renderHeader(ms, k, l, tessellator);
|
||||
}
|
||||
|
||||
this.renderList(ms, k, l, p_render_1_, p_render_2_, p_render_3_);
|
||||
this.renderList(ms, p_render_1_, p_render_2_, p_render_3_);
|
||||
RenderSystem.disableDepthTest();
|
||||
// this.renderHoleBackground(0, this.y0, 255, 255);
|
||||
// this.renderHoleBackground(this.y1, this.height, 255, 255);
|
||||
|
||||
@@ -46,6 +46,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);
|
||||
@@ -57,15 +59,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;
|
||||
@@ -165,7 +166,8 @@ 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);
|
||||
@@ -174,14 +176,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
|
||||
@@ -230,6 +233,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;
|
||||
@@ -274,7 +278,8 @@ 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);
|
||||
@@ -286,7 +291,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);
|
||||
}
|
||||
|
||||
@@ -303,7 +308,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
|
||||
@@ -474,7 +479,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, RandomSource.create(), Minecraft.getInstance().player.blockPosition());
|
||||
SimpleSoundInstance sound = new SimpleSoundInstance(SoundEvents.UI_BUTTON_CLICK, SoundSource.MASTER, volume,
|
||||
1.0f, RandomSource.create(), Minecraft.getInstance().player.blockPosition());
|
||||
Minecraft.getInstance().getSoundManager().play(sound);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -24,6 +24,7 @@ import net.minecraft.ChatFormatting;
|
||||
import net.minecraft.world.level.Level;
|
||||
import net.minecraftforge.api.distmarker.Dist;
|
||||
import net.minecraftforge.client.event.InputEvent;
|
||||
import net.minecraftforge.client.event.RegisterKeyMappingsEvent;
|
||||
import net.minecraftforge.client.event.ScreenEvent;
|
||||
import net.minecraftforge.client.settings.KeyConflictContext;
|
||||
import net.minecraftforge.client.settings.KeyModifier;
|
||||
@@ -70,16 +71,7 @@ public class ClientProxy implements IProxy {
|
||||
|
||||
@Override
|
||||
public void clientSetup(FMLClientSetupEvent event) {
|
||||
// register key bindings
|
||||
keyBindings = new KeyMapping[6];
|
||||
|
||||
// instantiate the key bindings
|
||||
keyBindings[0] = new KeyMapping("key.effortlessbuilding.hud.desc", KeyConflictContext.UNIVERSAL, InputConstants.getKey(GLFW.GLFW_KEY_KP_ADD, 0), "key.effortlessbuilding.category");
|
||||
keyBindings[1] = new KeyMapping("key.effortlessbuilding.replace.desc", KeyConflictContext.IN_GAME, InputConstants.getKey(GLFW.GLFW_KEY_KP_SUBTRACT, 0), "key.effortlessbuilding.category");
|
||||
keyBindings[2] = new KeyMapping("key.effortlessbuilding.mode.desc", KeyConflictContext.IN_GAME, InputConstants.getKey(GLFW.GLFW_KEY_LEFT_ALT, 0), "key.effortlessbuilding.category");
|
||||
keyBindings[3] = new KeyMapping("key.effortlessbuilding.undo.desc", KeyConflictContext.IN_GAME, KeyModifier.CONTROL, InputConstants.getKey(GLFW.GLFW_KEY_Z, 0), "key.effortlessbuilding.category");
|
||||
keyBindings[4] = new KeyMapping("key.effortlessbuilding.redo.desc", KeyConflictContext.IN_GAME, KeyModifier.CONTROL, InputConstants.getKey(GLFW.GLFW_KEY_Y, 0), "key.effortlessbuilding.category");
|
||||
keyBindings[5] = new KeyMapping("key.effortlessbuilding.altplacement.desc", KeyConflictContext.IN_GAME, InputConstants.getKey(GLFW.GLFW_KEY_LEFT_CONTROL, 0), "key.effortlessbuilding.category");
|
||||
//Keybindings are setup and registered in ModClientEventHandler
|
||||
|
||||
MenuScreens.register(EffortlessBuilding.RANDOMIZER_BAG_CONTAINER.get(), RandomizerBagScreen::new);
|
||||
MenuScreens.register(EffortlessBuilding.GOLDEN_RANDOMIZER_BAG_CONTAINER.get(), GoldenRandomizerBagScreen::new);
|
||||
@@ -129,7 +121,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,13 @@ 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,20 +1,17 @@
|
||||
{
|
||||
"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": {
|
||||
"item": "effortlessbuilding:reach_upgrade2"
|
||||
|
||||
@@ -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