Compare commits
7 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
028976577c | ||
|
|
4114f89584 | ||
|
|
292f362092 | ||
|
|
ea59fef099 | ||
|
|
5e6c42d372 | ||
|
|
14460c2c01 | ||
|
|
3b31a74780 |
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
@@ -1,31 +1,24 @@
|
|||||||
buildscript {
|
plugins {
|
||||||
repositories {
|
id 'eclipse'
|
||||||
maven { url = 'https://files.minecraftforge.net/maven' }
|
id 'maven-publish'
|
||||||
mavenCentral()
|
id 'net.minecraftforge.gradle' version '5.1.+'
|
||||||
}
|
|
||||||
dependencies {
|
|
||||||
classpath group: 'net.minecraftforge.gradle', name: 'ForgeGradle', version: '5.1+', changing: true
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
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'
|
version = '1.19.3-2.40'
|
||||||
group = 'nl.requios.effortlessbuilding' // http://maven.apache.org/guides/mini/guide-naming-conventions.html
|
group = 'nl.requios.effortlessbuilding'
|
||||||
archivesBaseName = 'effortlessbuilding'
|
archivesBaseName = 'effortlessbuilding'
|
||||||
|
|
||||||
// Mojang ships Java 17 to end users in 1.18+, so your mod should target Java 17.
|
// Mojang ships Java 17 to end users in 1.18+, so your mod should target Java 17.
|
||||||
java.toolchain.languageVersion = JavaLanguageVersion.of(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 {
|
minecraft {
|
||||||
// The mappings can be changed at any time, and must be in the following format.
|
// The mappings can be changed at any time, and must be in the following format.
|
||||||
// snapshot_YYYYMMDD Snapshot are built nightly.
|
// snapshot_YYYYMMDD Snapshot are built nightly.
|
||||||
// stable_# Stables are built at the discretion of the MCP team.
|
// stable_# Stables are built at the discretion of the MCP team.
|
||||||
// Use non-default mappings at your own risk. they may not always work.
|
// 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.
|
// 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.3'
|
||||||
accessTransformer = file('src/main/resources/META-INF/accesstransformer.cfg')
|
accessTransformer = file('src/main/resources/META-INF/accesstransformer.cfg')
|
||||||
// makeObfSourceJar = false // an Srg named sources jar is made by default. uncomment this to disable.
|
// 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
|
// Recommended logging level for the console
|
||||||
property 'forge.logging.console.level', 'debug'
|
property 'forge.logging.console.level', 'debug'
|
||||||
|
|
||||||
|
// Comma-separated list of namespaces to load gametests from. Empty = all namespaces.
|
||||||
|
property 'forge.enabledGameTestNamespaces', 'effortlessbuilding'
|
||||||
|
|
||||||
mods {
|
mods {
|
||||||
effortlessbuilding {
|
effortlessbuilding {
|
||||||
source sourceSets.main
|
source sourceSets.main
|
||||||
@@ -51,12 +47,31 @@ minecraft {
|
|||||||
server {
|
server {
|
||||||
workingDirectory project.file('run')
|
workingDirectory project.file('run')
|
||||||
|
|
||||||
// Recommended logging data for a userdev environment (SCAN,REGISTRIES,REGISTRYDUMP)
|
|
||||||
property 'forge.logging.markers', 'REGISTRIES'
|
property 'forge.logging.markers', 'REGISTRIES'
|
||||||
|
|
||||||
// Recommended logging level for the console
|
|
||||||
property 'forge.logging.console.level', 'debug'
|
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 {
|
mods {
|
||||||
effortlessbuilding {
|
effortlessbuilding {
|
||||||
source sourceSets.main
|
source sourceSets.main
|
||||||
@@ -65,12 +80,10 @@ minecraft {
|
|||||||
}
|
}
|
||||||
|
|
||||||
data {
|
data {
|
||||||
workingDirectory project.file('run')
|
workingDirectory project.file('run')
|
||||||
|
|
||||||
// Recommended logging data for a userdev environment (SCAN,REGISTRIES,REGISTRYDUMP)
|
|
||||||
property 'forge.logging.markers', 'REGISTRIES'
|
property 'forge.logging.markers', 'REGISTRIES'
|
||||||
|
|
||||||
// Recommended logging level for the console
|
|
||||||
property 'forge.logging.console.level', 'debug'
|
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.
|
// 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 {
|
dependencies {
|
||||||
// Specify the version of Minecraft to use, If this is any group other then 'net.minecraft' it is assumed
|
// 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 it's patches will be applied.
|
// 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.
|
// 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.3-44.1.0'
|
||||||
|
|
||||||
// Real mod deobf dependency examples - these get remapped to your current mappings
|
// 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
|
// 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...
|
// For more info...
|
||||||
// http://www.gradle.org/docs/current/userguide/artifact_dependencies_tutorial.html
|
// http://www.gradle.org/docs/current/userguide/artifact_dependencies_tutorial.html
|
||||||
// http://www.gradle.org/docs/current/userguide/dependency_management.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..
|
// Example for how to get properties into the manifest for reading by the runtime..
|
||||||
@@ -113,18 +138,18 @@ jar {
|
|||||||
"Specification-Vendor": "requios",
|
"Specification-Vendor": "requios",
|
||||||
"Specification-Version": "1", // We are version 1 of ourselves
|
"Specification-Version": "1", // We are version 1 of ourselves
|
||||||
"Implementation-Title": project.name,
|
"Implementation-Title": project.name,
|
||||||
"Implementation-Version": "${version}",
|
"Implementation-Version": project.jar.archiveVersion,
|
||||||
"Implementation-Vendor" :"requios",
|
"Implementation-Vendor" :"requios",
|
||||||
"Implementation-Timestamp": new Date().format("yyyy-MM-dd'T'HH:mm:ssZ")
|
"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
|
// 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
|
// 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 {
|
publishing {
|
||||||
publications {
|
publications {
|
||||||
@@ -134,7 +159,11 @@ publishing {
|
|||||||
}
|
}
|
||||||
repositories {
|
repositories {
|
||||||
maven {
|
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
@@ -0,0 +1,6 @@
|
|||||||
|
pluginManagement {
|
||||||
|
repositories {
|
||||||
|
gradlePluginPortal()
|
||||||
|
maven { url = 'https://maven.minecraftforge.net/' }
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -4,8 +4,10 @@ import net.minecraft.network.chat.Component;
|
|||||||
import net.minecraft.world.entity.player.Player;
|
import net.minecraft.world.entity.player.Player;
|
||||||
import net.minecraft.world.inventory.AbstractContainerMenu;
|
import net.minecraft.world.inventory.AbstractContainerMenu;
|
||||||
import net.minecraft.world.inventory.MenuType;
|
import net.minecraft.world.inventory.MenuType;
|
||||||
|
import net.minecraft.world.item.CreativeModeTabs;
|
||||||
import net.minecraft.world.item.Item;
|
import net.minecraft.world.item.Item;
|
||||||
import net.minecraftforge.common.capabilities.RegisterCapabilitiesEvent;
|
import net.minecraftforge.common.capabilities.RegisterCapabilitiesEvent;
|
||||||
|
import net.minecraftforge.event.CreativeModeTabEvent;
|
||||||
import net.minecraftforge.eventbus.api.SubscribeEvent;
|
import net.minecraftforge.eventbus.api.SubscribeEvent;
|
||||||
import net.minecraftforge.fml.DistExecutor;
|
import net.minecraftforge.fml.DistExecutor;
|
||||||
import net.minecraftforge.fml.ModLoadingContext;
|
import net.minecraftforge.fml.ModLoadingContext;
|
||||||
@@ -89,11 +91,25 @@ public class EffortlessBuilding {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@SubscribeEvent
|
@SubscribeEvent
|
||||||
public void registerCapabilities(RegisterCapabilitiesEvent event){
|
public void registerCapabilities(RegisterCapabilitiesEvent event) {
|
||||||
event.register(ModifierCapabilityManager.IModifierCapability.class);
|
event.register(ModifierCapabilityManager.IModifierCapability.class);
|
||||||
event.register(ModeCapabilityManager.IModeCapability.class);
|
event.register(ModeCapabilityManager.IModeCapability.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@SubscribeEvent
|
||||||
|
public void registerCreativeModeTabs(CreativeModeTabEvent.BuildContents event) {
|
||||||
|
if (event.getTab() == CreativeModeTabs.TOOLS_AND_UTILITIES){
|
||||||
|
event.accept(RANDOMIZER_BAG_ITEM);
|
||||||
|
event.accept(GOLDEN_RANDOMIZER_BAG_ITEM);
|
||||||
|
event.accept(DIAMOND_RANDOMIZER_BAG_ITEM);
|
||||||
|
event.accept(REACH_UPGRADE_1_ITEM);
|
||||||
|
event.accept(REACH_UPGRADE_2_ITEM);
|
||||||
|
event.accept(REACH_UPGRADE_3_ITEM);
|
||||||
|
}
|
||||||
|
|
||||||
|
//To create custom tab see https://gist.github.com/ChampionAsh5357/c21724bafbc630da2ed8899fe0c1d226
|
||||||
|
}
|
||||||
|
|
||||||
public static void log(String msg) {
|
public static void log(String msg) {
|
||||||
logger.info(msg);
|
logger.info(msg);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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;
|
||||||
@@ -7,7 +10,6 @@ import net.minecraft.server.level.ServerPlayer;
|
|||||||
import net.minecraft.resources.ResourceLocation;
|
import net.minecraft.resources.ResourceLocation;
|
||||||
import net.minecraftforge.common.util.FakePlayer;
|
import net.minecraftforge.common.util.FakePlayer;
|
||||||
import net.minecraftforge.event.AttachCapabilitiesEvent;
|
import net.minecraftforge.event.AttachCapabilitiesEvent;
|
||||||
import net.minecraftforge.event.RegisterCommandsEvent;
|
|
||||||
import net.minecraftforge.event.entity.player.PlayerEvent;
|
import net.minecraftforge.event.entity.player.PlayerEvent;
|
||||||
import net.minecraftforge.event.level.BlockEvent;
|
import net.minecraftforge.event.level.BlockEvent;
|
||||||
import net.minecraftforge.eventbus.api.SubscribeEvent;
|
import net.minecraftforge.eventbus.api.SubscribeEvent;
|
||||||
@@ -19,6 +21,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;
|
||||||
@@ -26,7 +29,7 @@ import nl.requios.effortlessbuilding.network.PacketHandler;
|
|||||||
import nl.requios.effortlessbuilding.network.RequestLookAtMessage;
|
import nl.requios.effortlessbuilding.network.RequestLookAtMessage;
|
||||||
|
|
||||||
@Mod.EventBusSubscriber(modid = EffortlessBuilding.MODID, bus = Mod.EventBusSubscriber.Bus.FORGE)
|
@Mod.EventBusSubscriber(modid = EffortlessBuilding.MODID, bus = Mod.EventBusSubscriber.Bus.FORGE)
|
||||||
public class EventHandler {
|
public class ForgeEventHandler {
|
||||||
|
|
||||||
@SubscribeEvent
|
@SubscribeEvent
|
||||||
public static void attachCapabilities(AttachCapabilitiesEvent<Entity> event) {
|
public static void attachCapabilities(AttachCapabilitiesEvent<Entity> event) {
|
||||||
@@ -51,7 +54,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) {
|
||||||
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()) {
|
} 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,29 +1,49 @@
|
|||||||
package nl.requios.effortlessbuilding;
|
package nl.requios.effortlessbuilding;
|
||||||
|
|
||||||
|
import com.mojang.blaze3d.platform.InputConstants;
|
||||||
import com.mojang.blaze3d.vertex.DefaultVertexFormat;
|
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.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.RegisterKeyMappingsEvent;
|
||||||
import net.minecraftforge.client.event.RegisterShadersEvent;
|
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.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.proxy.ClientProxy;
|
||||||
import nl.requios.effortlessbuilding.buildmode.ModeOptions;
|
|
||||||
import nl.requios.effortlessbuilding.render.BuildRenderTypes;
|
import nl.requios.effortlessbuilding.render.BuildRenderTypes;
|
||||||
|
import org.lwjgl.glfw.GLFW;
|
||||||
|
|
||||||
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 {
|
||||||
|
|
||||||
|
@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
|
@SubscribeEvent
|
||||||
public static void registerShaders(RegisterShadersEvent event) throws IOException {
|
public static void registerShaders(RegisterShadersEvent event) throws IOException {
|
||||||
event.registerShader(new ShaderInstance(event.getResourceManager(),
|
event.registerShader(new ShaderInstance(event.getResourceProvider(),
|
||||||
new ResourceLocation(EffortlessBuilding.MODID, "dissolve"),
|
new ResourceLocation(EffortlessBuilding.MODID, "dissolve"),
|
||||||
DefaultVertexFormat.BLOCK),
|
DefaultVertexFormat.BLOCK),
|
||||||
shaderInstance -> BuildRenderTypes.dissolveShaderInstance = shaderInstance);
|
shaderInstance -> BuildRenderTypes.dissolveShaderInstance = shaderInstance);
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
package nl.requios.effortlessbuilding.buildmode;
|
package nl.requios.effortlessbuilding.buildmode;
|
||||||
|
|
||||||
import com.mojang.math.Vector4f;
|
|
||||||
import net.minecraft.world.entity.player.Player;
|
import net.minecraft.world.entity.player.Player;
|
||||||
import net.minecraft.core.Direction;
|
import net.minecraft.core.Direction;
|
||||||
import net.minecraft.core.BlockPos;
|
import net.minecraft.core.BlockPos;
|
||||||
@@ -15,6 +14,7 @@ import nl.requios.effortlessbuilding.helper.ReachHelper;
|
|||||||
import nl.requios.effortlessbuilding.helper.SurvivalHelper;
|
import nl.requios.effortlessbuilding.helper.SurvivalHelper;
|
||||||
import nl.requios.effortlessbuilding.network.BlockBrokenMessage;
|
import nl.requios.effortlessbuilding.network.BlockBrokenMessage;
|
||||||
import nl.requios.effortlessbuilding.network.BlockPlacedMessage;
|
import nl.requios.effortlessbuilding.network.BlockPlacedMessage;
|
||||||
|
import org.joml.Vector4f;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Dictionary;
|
import java.util.Dictionary;
|
||||||
@@ -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
|
||||||
@@ -275,6 +273,10 @@ public class BuildModes {
|
|||||||
this.category = category;
|
this.category = category;
|
||||||
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();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -187,7 +187,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);
|
||||||
@@ -212,7 +212,7 @@ public class PlayerSettingsGui extends Screen {
|
|||||||
this.renderHeader(ms, k, l, tessellator);
|
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();
|
RenderSystem.disableDepthTest();
|
||||||
// this.renderHoleBackground(0, this.y0, 255, 255);
|
// this.renderHoleBackground(0, this.y0, 255, 255);
|
||||||
// this.renderHoleBackground(this.y1, this.height, 255, 255);
|
// this.renderHoleBackground(this.y1, this.height, 255, 255);
|
||||||
|
|||||||
@@ -2,7 +2,6 @@ package nl.requios.effortlessbuilding.gui.buildmode;
|
|||||||
|
|
||||||
import com.mojang.blaze3d.vertex.*;
|
import com.mojang.blaze3d.vertex.*;
|
||||||
import com.mojang.blaze3d.systems.RenderSystem;
|
import com.mojang.blaze3d.systems.RenderSystem;
|
||||||
import com.mojang.math.Vector4f;
|
|
||||||
import net.minecraft.MethodsReturnNonnullByDefault;
|
import net.minecraft.MethodsReturnNonnullByDefault;
|
||||||
import net.minecraft.client.Minecraft;
|
import net.minecraft.client.Minecraft;
|
||||||
import net.minecraft.client.gui.screens.Screen;
|
import net.minecraft.client.gui.screens.Screen;
|
||||||
@@ -26,6 +25,7 @@ import nl.requios.effortlessbuilding.network.ModeSettingsMessage;
|
|||||||
import nl.requios.effortlessbuilding.network.PacketHandler;
|
import nl.requios.effortlessbuilding.network.PacketHandler;
|
||||||
import nl.requios.effortlessbuilding.proxy.ClientProxy;
|
import nl.requios.effortlessbuilding.proxy.ClientProxy;
|
||||||
import org.apache.commons.lang3.text.WordUtils;
|
import org.apache.commons.lang3.text.WordUtils;
|
||||||
|
import org.joml.Vector4f;
|
||||||
import org.lwjgl.opengl.GL11;
|
import org.lwjgl.opengl.GL11;
|
||||||
|
|
||||||
import javax.annotation.ParametersAreNonnullByDefault;
|
import javax.annotation.ParametersAreNonnullByDefault;
|
||||||
@@ -46,6 +46,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);
|
||||||
@@ -57,15 +59,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;
|
||||||
@@ -165,7 +166,8 @@ 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);
|
||||||
@@ -174,14 +176,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
|
||||||
@@ -230,6 +233,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;
|
||||||
@@ -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();
|
ms.pushPose();
|
||||||
RenderSystem.enableTexture();
|
RenderSystem.enableTexture();
|
||||||
RenderSystem.setShader(GameRenderer::getPositionColorTexShader);
|
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 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);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -303,7 +308,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
|
||||||
@@ -474,7 +479,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, RandomSource.create(), Minecraft.getInstance().player.blockPosition());
|
SimpleSoundInstance sound = new SimpleSoundInstance(SoundEvents.UI_BUTTON_CLICK.get(), SoundSource.MASTER, volume,
|
||||||
|
1.0f, RandomSource.create(), Minecraft.getInstance().player.blockPosition());
|
||||||
Minecraft.getInstance().getSoundManager().play(sound);
|
Minecraft.getInstance().getSoundManager().play(sound);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
package nl.requios.effortlessbuilding.gui.buildmodifier;
|
package nl.requios.effortlessbuilding.gui.buildmodifier;
|
||||||
|
|
||||||
import com.mojang.blaze3d.vertex.PoseStack;
|
import com.mojang.blaze3d.vertex.PoseStack;
|
||||||
import net.minecraft.client.gui.components.Widget;
|
import net.minecraft.client.gui.components.Renderable;
|
||||||
import net.minecraft.client.gui.screens.Screen;
|
import net.minecraft.client.gui.screens.Screen;
|
||||||
import net.minecraft.core.BlockPos;
|
import net.minecraft.core.BlockPos;
|
||||||
import net.minecraft.network.chat.Component;
|
import net.minecraft.network.chat.Component;
|
||||||
@@ -33,7 +33,7 @@ public class ArraySettingsGui extends GuiCollapsibleScrollEntry {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void init(List<Widget> renderables) {
|
public void init(List<Renderable> renderables) {
|
||||||
super.init(renderables);
|
super.init(renderables);
|
||||||
|
|
||||||
int y = top;
|
int y = top;
|
||||||
@@ -93,7 +93,7 @@ public class ArraySettingsGui extends GuiCollapsibleScrollEntry {
|
|||||||
|
|
||||||
buttonArrayEnabled.render(ms, mouseX, mouseY, partialTicks);
|
buttonArrayEnabled.render(ms, mouseX, mouseY, partialTicks);
|
||||||
if (buttonArrayEnabled.isChecked()) {
|
if (buttonArrayEnabled.isChecked()) {
|
||||||
buttonArrayEnabled.y = yy;
|
buttonArrayEnabled.setY(yy);
|
||||||
font.draw(ms, "Array enabled", left + offset, yy + 2, 0xFFFFFF);
|
font.draw(ms, "Array enabled", left + offset, yy + 2, 0xFFFFFF);
|
||||||
|
|
||||||
yy = y + 20;
|
yy = y + 20;
|
||||||
@@ -117,7 +117,7 @@ public class ArraySettingsGui extends GuiCollapsibleScrollEntry {
|
|||||||
|
|
||||||
arrayNumberFieldList.forEach(numberField -> numberField.drawNumberField(ms, mouseX, mouseY, partialTicks));
|
arrayNumberFieldList.forEach(numberField -> numberField.drawNumberField(ms, mouseX, mouseY, partialTicks));
|
||||||
} else {
|
} else {
|
||||||
buttonArrayEnabled.y = yy;
|
buttonArrayEnabled.setY(yy);
|
||||||
font.draw(ms, "Array disabled", left + offset, yy + 2, 0x999999);
|
font.draw(ms, "Array disabled", left + offset, yy + 2, 0x999999);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
package nl.requios.effortlessbuilding.gui.buildmodifier;
|
package nl.requios.effortlessbuilding.gui.buildmodifier;
|
||||||
|
|
||||||
import com.mojang.blaze3d.vertex.PoseStack;
|
import com.mojang.blaze3d.vertex.PoseStack;
|
||||||
import net.minecraft.client.gui.components.Widget;
|
import net.minecraft.client.gui.components.Renderable;
|
||||||
import net.minecraft.client.gui.screens.Screen;
|
import net.minecraft.client.gui.screens.Screen;
|
||||||
import net.minecraft.client.gui.components.Button;
|
import net.minecraft.client.gui.components.Button;
|
||||||
import net.minecraft.network.chat.Component;
|
import net.minecraft.network.chat.Component;
|
||||||
@@ -40,7 +40,7 @@ public class MirrorSettingsGui extends GuiCollapsibleScrollEntry {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void init(List<Widget> renderables) {
|
public void init(List<Renderable> renderables) {
|
||||||
super.init(renderables);
|
super.init(renderables);
|
||||||
|
|
||||||
int y = top - 2;
|
int y = top - 2;
|
||||||
@@ -181,7 +181,7 @@ public class MirrorSettingsGui extends GuiCollapsibleScrollEntry {
|
|||||||
|
|
||||||
buttonMirrorEnabled.render(ms, mouseX, mouseY, partialTicks);
|
buttonMirrorEnabled.render(ms, mouseX, mouseY, partialTicks);
|
||||||
if (buttonMirrorEnabled.isChecked()) {
|
if (buttonMirrorEnabled.isChecked()) {
|
||||||
buttonMirrorEnabled.y = yy;
|
buttonMirrorEnabled.setY(yy);
|
||||||
font.draw(ms, "Mirror enabled", left + offset, yy + 2, 0xFFFFFF);
|
font.draw(ms, "Mirror enabled", left + offset, yy + 2, 0xFFFFFF);
|
||||||
|
|
||||||
yy = y + 18;
|
yy = y + 18;
|
||||||
@@ -195,23 +195,23 @@ public class MirrorSettingsGui extends GuiCollapsibleScrollEntry {
|
|||||||
|
|
||||||
yy = y + 50;
|
yy = y + 50;
|
||||||
font.draw(ms, "Direction", left + offset, yy + 2, 0xFFFFFF);
|
font.draw(ms, "Direction", left + offset, yy + 2, 0xFFFFFF);
|
||||||
buttonMirrorX.y = yy;
|
buttonMirrorX.setY(yy);
|
||||||
buttonMirrorY.y = yy;
|
buttonMirrorY.setY(yy);
|
||||||
buttonMirrorZ.y = yy;
|
buttonMirrorZ.setY(yy);
|
||||||
font.draw(ms, "Radius", left + 176 + offset, yy + 2, 0xFFFFFF);
|
font.draw(ms, "Radius", left + 176 + offset, yy + 2, 0xFFFFFF);
|
||||||
textMirrorRadius.y = yy - 3;
|
textMirrorRadius.y = yy - 3;
|
||||||
|
|
||||||
yy = y + 72;
|
yy = y + 72;
|
||||||
buttonCurrentPosition.y = yy;
|
buttonCurrentPosition.setY(yy);
|
||||||
buttonToggleOdd.y = yy;
|
buttonToggleOdd.setY(yy);
|
||||||
buttonDrawLines.y = yy;
|
buttonDrawLines.setY(yy);
|
||||||
buttonDrawPlanes.y = yy;
|
buttonDrawPlanes.setY(yy);
|
||||||
|
|
||||||
mirrorButtonList.forEach(button -> button.render(ms, mouseX, mouseY, partialTicks));
|
mirrorButtonList.forEach(button -> button.render(ms, mouseX, mouseY, partialTicks));
|
||||||
mirrorIconButtonList.forEach(button -> button.render(ms, mouseX, mouseY, partialTicks));
|
mirrorIconButtonList.forEach(button -> button.render(ms, mouseX, mouseY, partialTicks));
|
||||||
mirrorNumberFieldList.forEach(numberField -> numberField.drawNumberField(ms, mouseX, mouseY, partialTicks));
|
mirrorNumberFieldList.forEach(numberField -> numberField.drawNumberField(ms, mouseX, mouseY, partialTicks));
|
||||||
} else {
|
} else {
|
||||||
buttonMirrorEnabled.y = yy;
|
buttonMirrorEnabled.setY(yy);
|
||||||
font.draw(ms, "Mirror disabled", left + offset, yy + 2, 0x999999);
|
font.draw(ms, "Mirror disabled", left + offset, yy + 2, 0x999999);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -7,6 +7,7 @@ import net.minecraft.client.gui.components.Button;
|
|||||||
import net.minecraft.network.chat.Component;
|
import net.minecraft.network.chat.Component;
|
||||||
import net.minecraftforge.api.distmarker.Dist;
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
import net.minecraftforge.api.distmarker.OnlyIn;
|
import net.minecraftforge.api.distmarker.OnlyIn;
|
||||||
|
import net.minecraftforge.client.gui.widget.ExtendedButton;
|
||||||
import nl.requios.effortlessbuilding.EffortlessBuilding;
|
import nl.requios.effortlessbuilding.EffortlessBuilding;
|
||||||
import nl.requios.effortlessbuilding.buildmodifier.Array;
|
import nl.requios.effortlessbuilding.buildmodifier.Array;
|
||||||
import nl.requios.effortlessbuilding.buildmodifier.Mirror;
|
import nl.requios.effortlessbuilding.buildmodifier.Mirror;
|
||||||
@@ -50,7 +51,7 @@ public class ModifierSettingsGui extends Screen {
|
|||||||
|
|
||||||
//Close button
|
//Close button
|
||||||
int y = height - 26;
|
int y = height - 26;
|
||||||
buttonClose = new Button(width / 2 - 100, y, 200, 20, Component.literal("Close"), (button) -> {
|
buttonClose = new ExtendedButton(width / 2 - 100, y, 200, 20, Component.literal("Close"), (button) -> {
|
||||||
Minecraft.getInstance().player.closeContainer();
|
Minecraft.getInstance().player.closeContainer();
|
||||||
});
|
});
|
||||||
addRenderableOnly(buttonClose);
|
addRenderableOnly(buttonClose);
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
package nl.requios.effortlessbuilding.gui.buildmodifier;
|
package nl.requios.effortlessbuilding.gui.buildmodifier;
|
||||||
|
|
||||||
import com.mojang.blaze3d.vertex.PoseStack;
|
import com.mojang.blaze3d.vertex.PoseStack;
|
||||||
import net.minecraft.client.gui.components.Widget;
|
import net.minecraft.client.gui.components.Renderable;
|
||||||
import net.minecraft.client.gui.screens.Screen;
|
import net.minecraft.client.gui.screens.Screen;
|
||||||
import net.minecraft.client.gui.components.Button;
|
import net.minecraft.client.gui.components.Button;
|
||||||
import net.minecraft.network.chat.Component;
|
import net.minecraft.network.chat.Component;
|
||||||
@@ -40,7 +40,7 @@ public class RadialMirrorSettingsGui extends GuiCollapsibleScrollEntry {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void init(List<Widget> renderables) {
|
public void init(List<Renderable> renderables) {
|
||||||
super.init(renderables);
|
super.init(renderables);
|
||||||
|
|
||||||
int y = top - 2;
|
int y = top - 2;
|
||||||
@@ -178,7 +178,7 @@ public class RadialMirrorSettingsGui extends GuiCollapsibleScrollEntry {
|
|||||||
|
|
||||||
buttonRadialMirrorEnabled.render(ms, mouseX, mouseY, partialTicks);
|
buttonRadialMirrorEnabled.render(ms, mouseX, mouseY, partialTicks);
|
||||||
if (buttonRadialMirrorEnabled.isChecked()) {
|
if (buttonRadialMirrorEnabled.isChecked()) {
|
||||||
buttonRadialMirrorEnabled.y = yy;
|
buttonRadialMirrorEnabled.setY(yy);
|
||||||
font.draw(ms, "Radial mirror enabled", left + offset, yy + 2, 0xFFFFFF);
|
font.draw(ms, "Radial mirror enabled", left + offset, yy + 2, 0xFFFFFF);
|
||||||
|
|
||||||
yy = y + 18;
|
yy = y + 18;
|
||||||
@@ -197,20 +197,20 @@ public class RadialMirrorSettingsGui extends GuiCollapsibleScrollEntry {
|
|||||||
textRadialMirrorRadius.y = yy - 3;
|
textRadialMirrorRadius.y = yy - 3;
|
||||||
|
|
||||||
yy = y + 72;
|
yy = y + 72;
|
||||||
buttonCurrentPosition.y = yy;
|
buttonCurrentPosition.setY(yy);
|
||||||
buttonToggleOdd.y = yy;
|
buttonToggleOdd.setY(yy);
|
||||||
buttonDrawLines.y = yy;
|
buttonDrawLines.setY(yy);
|
||||||
buttonDrawPlanes.y = yy;
|
buttonDrawPlanes.setY(yy);
|
||||||
|
|
||||||
yy = y + 76;
|
yy = y + 76;
|
||||||
buttonRadialMirrorAlternate.y = yy;
|
buttonRadialMirrorAlternate.setY(yy);
|
||||||
|
|
||||||
radialMirrorButtonList.forEach(button -> button.render(ms, mouseX, mouseY, partialTicks));
|
radialMirrorButtonList.forEach(button -> button.render(ms, mouseX, mouseY, partialTicks));
|
||||||
radialMirrorIconButtonList.forEach(button -> button.render(ms, mouseX, mouseY, partialTicks));
|
radialMirrorIconButtonList.forEach(button -> button.render(ms, mouseX, mouseY, partialTicks));
|
||||||
radialMirrorNumberFieldList
|
radialMirrorNumberFieldList
|
||||||
.forEach(numberField -> numberField.drawNumberField(ms, mouseX, mouseY, partialTicks));
|
.forEach(numberField -> numberField.drawNumberField(ms, mouseX, mouseY, partialTicks));
|
||||||
} else {
|
} else {
|
||||||
buttonRadialMirrorEnabled.y = yy;
|
buttonRadialMirrorEnabled.setY(yy);
|
||||||
font.draw(ms, "Radial mirror disabled", left + offset, yy + 2, 0x999999);
|
font.draw(ms, "Radial mirror disabled", left + offset, yy + 2, 0x999999);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ import net.minecraft.client.Minecraft;
|
|||||||
import net.minecraft.client.gui.components.Button;
|
import net.minecraft.client.gui.components.Button;
|
||||||
import net.minecraft.network.chat.Component;
|
import net.minecraft.network.chat.Component;
|
||||||
import net.minecraftforge.client.gui.ScreenUtils;
|
import net.minecraftforge.client.gui.ScreenUtils;
|
||||||
|
import net.minecraftforge.client.gui.widget.ExtendedButton;
|
||||||
|
|
||||||
import javax.annotation.ParametersAreNonnullByDefault;
|
import javax.annotation.ParametersAreNonnullByDefault;
|
||||||
|
|
||||||
@@ -12,13 +13,13 @@ import javax.annotation.ParametersAreNonnullByDefault;
|
|||||||
* This class provides a checkbox style control.
|
* This class provides a checkbox style control.
|
||||||
*/
|
*/
|
||||||
@ParametersAreNonnullByDefault
|
@ParametersAreNonnullByDefault
|
||||||
public class GuiCheckBoxFixed extends Button {
|
public class GuiCheckBoxFixed extends ExtendedButton {
|
||||||
private final int boxWidth;
|
private final int boxWidth;
|
||||||
private boolean isChecked;
|
private boolean isChecked;
|
||||||
|
|
||||||
public GuiCheckBoxFixed(int xPos, int yPos, String displayString, boolean isChecked) {
|
public GuiCheckBoxFixed(int xPos, int yPos, String displayString, boolean isChecked) {
|
||||||
super(xPos, yPos, Minecraft.getInstance().font.width(displayString) + 2 + 11, 11, Component.literal(displayString), b -> {
|
super(xPos, yPos, Minecraft.getInstance().font.width(displayString) + 2 + 11, 11,
|
||||||
});
|
Component.literal(displayString), b -> {}, DEFAULT_NARRATION);
|
||||||
this.isChecked = isChecked;
|
this.isChecked = isChecked;
|
||||||
this.boxWidth = 11;
|
this.boxWidth = 11;
|
||||||
this.height = 11;
|
this.height = 11;
|
||||||
@@ -29,8 +30,8 @@ public class GuiCheckBoxFixed extends Button {
|
|||||||
public void renderButton(PoseStack ms, int mouseX, int mouseY, float partial) {
|
public void renderButton(PoseStack ms, int mouseX, int mouseY, float partial) {
|
||||||
if (this.visible) {
|
if (this.visible) {
|
||||||
Minecraft mc = Minecraft.getInstance();
|
Minecraft mc = Minecraft.getInstance();
|
||||||
this.isHovered = mouseX >= this.x && mouseY >= this.y && mouseX < this.x + this.boxWidth && mouseY < this.y + this.height;
|
this.isHovered = mouseX >= this.getX() && mouseY >= this.getY() && mouseX < this.getX() + this.boxWidth && mouseY < this.getY() + this.height;
|
||||||
ScreenUtils.blitWithBorder(ms, WIDGETS_LOCATION, this.x, this.y, 0, 46, this.boxWidth, this.height, 200, 20, 2, 3, 2, 2, this.getBlitOffset());
|
ScreenUtils.blitWithBorder(ms, WIDGETS_LOCATION, this.getX(), this.getY(), 0, 46, this.boxWidth, this.height, 200, 20, 2, 3, 2, 2, this.getBlitOffset());
|
||||||
this.renderBg(ms, mc, mouseX, mouseY);
|
this.renderBg(ms, mc, mouseX, mouseY);
|
||||||
int color = 14737632;
|
int color = 14737632;
|
||||||
|
|
||||||
@@ -41,9 +42,9 @@ public class GuiCheckBoxFixed extends Button {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (this.isChecked)
|
if (this.isChecked)
|
||||||
drawCenteredString(ms, mc.font, "x", this.x + this.boxWidth / 2 + 1, this.y + 1, 14737632);
|
drawCenteredString(ms, mc.font, "x", this.getX() + this.boxWidth / 2 + 1, this.getY() + 1, 14737632);
|
||||||
|
|
||||||
drawString(ms, mc.font, getMessage(), this.x + this.boxWidth + 2, this.y + 2, color);
|
drawString(ms, mc.font, getMessage(), this.getX() + this.boxWidth + 2, this.getY() + 2, color);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ package nl.requios.effortlessbuilding.gui.elements;
|
|||||||
import com.mojang.blaze3d.vertex.PoseStack;
|
import com.mojang.blaze3d.vertex.PoseStack;
|
||||||
import net.minecraft.client.Minecraft;
|
import net.minecraft.client.Minecraft;
|
||||||
import net.minecraft.client.gui.Font;
|
import net.minecraft.client.gui.Font;
|
||||||
import net.minecraft.client.gui.components.Widget;
|
import net.minecraft.client.gui.components.Renderable;
|
||||||
import net.minecraft.client.gui.screens.Screen;
|
import net.minecraft.client.gui.screens.Screen;
|
||||||
import net.minecraft.client.gui.components.AbstractWidget;
|
import net.minecraft.client.gui.components.AbstractWidget;
|
||||||
import net.minecraftforge.api.distmarker.Dist;
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
@@ -28,7 +28,7 @@ public abstract class GuiCollapsibleScrollEntry implements GuiScrollPane.IScroll
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void init(List<Widget> renderables) {
|
public void init(List<Renderable> renderables) {
|
||||||
left = scrollPane.getWidth() / 2 - 140;
|
left = scrollPane.getWidth() / 2 - 140;
|
||||||
right = scrollPane.getWidth() / 2 + 140;
|
right = scrollPane.getWidth() / 2 + 140;
|
||||||
top = scrollPane.getHeight() / 2 - 100;
|
top = scrollPane.getHeight() / 2 - 100;
|
||||||
|
|||||||
@@ -8,6 +8,7 @@ import net.minecraft.resources.ResourceLocation;
|
|||||||
import net.minecraft.network.chat.Component;
|
import net.minecraft.network.chat.Component;
|
||||||
import net.minecraftforge.api.distmarker.Dist;
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
import net.minecraftforge.api.distmarker.OnlyIn;
|
import net.minecraftforge.api.distmarker.OnlyIn;
|
||||||
|
import net.minecraftforge.client.gui.widget.ExtendedButton;
|
||||||
|
|
||||||
import javax.annotation.ParametersAreNonnullByDefault;
|
import javax.annotation.ParametersAreNonnullByDefault;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
@@ -16,7 +17,7 @@ import java.util.List;
|
|||||||
|
|
||||||
@OnlyIn(Dist.CLIENT)
|
@OnlyIn(Dist.CLIENT)
|
||||||
@ParametersAreNonnullByDefault
|
@ParametersAreNonnullByDefault
|
||||||
public class GuiIconButton extends Button {
|
public class GuiIconButton extends ExtendedButton {
|
||||||
|
|
||||||
private final ResourceLocation resourceLocation;
|
private final ResourceLocation resourceLocation;
|
||||||
private final int iconX, iconY, iconWidth, iconHeight, iconAltX, iconAltY;
|
private final int iconX, iconY, iconWidth, iconHeight, iconAltX, iconAltY;
|
||||||
@@ -28,7 +29,7 @@ public class GuiIconButton extends Button {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public GuiIconButton(int x, int y, int width, int height, int iconX, int iconY, int iconWidth, int iconHeight, int iconAltX, int iconAltY, ResourceLocation resourceLocation, Button.OnPress onPress) {
|
public GuiIconButton(int x, int y, int width, int height, int iconX, int iconY, int iconWidth, int iconHeight, int iconAltX, int iconAltY, ResourceLocation resourceLocation, Button.OnPress onPress) {
|
||||||
super(x, y, width, height, Component.empty(), onPress);
|
super(x, y, width, height, Component.empty(), onPress, DEFAULT_NARRATION);
|
||||||
this.iconX = iconX;
|
this.iconX = iconX;
|
||||||
this.iconY = iconY;
|
this.iconY = iconY;
|
||||||
this.iconWidth = iconWidth;
|
this.iconWidth = iconWidth;
|
||||||
@@ -54,7 +55,7 @@ public class GuiIconButton extends Button {
|
|||||||
public void render(PoseStack ms, int mouseX, int mouseY, float partialTicks) {
|
public void render(PoseStack ms, int mouseX, int mouseY, float partialTicks) {
|
||||||
super.render(ms, mouseX, mouseY, partialTicks);
|
super.render(ms, mouseX, mouseY, partialTicks);
|
||||||
if (this.visible) {
|
if (this.visible) {
|
||||||
this.isHovered = mouseX >= this.x && mouseY >= this.y && mouseX < this.x + this.width && mouseY < this.y + this.height;
|
this.isHovered = mouseX >= this.getX() && mouseY >= this.getY() && mouseX < this.getX() + this.width && mouseY < this.getY() + this.height;
|
||||||
RenderSystem.setShaderTexture(0, this.resourceLocation);
|
RenderSystem.setShaderTexture(0, this.resourceLocation);
|
||||||
int currentIconX = this.iconX;
|
int currentIconX = this.iconX;
|
||||||
int currentIconY = this.iconY;
|
int currentIconY = this.iconY;
|
||||||
@@ -65,12 +66,12 @@ public class GuiIconButton extends Button {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//Draws a textured rectangle at the current z-value. Used to be drawTexturedModalRect in Gui.
|
//Draws a textured rectangle at the current z-value. Used to be drawTexturedModalRect in Gui.
|
||||||
this.blit(ms, this.x, this.y, currentIconX, currentIconY, this.iconWidth, this.iconHeight);
|
this.blit(ms, this.getX(), this.getY(), currentIconX, currentIconY, this.iconWidth, this.iconHeight);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void drawTooltip(PoseStack ms, Screen screen, int mouseX, int mouseY) {
|
public void drawTooltip(PoseStack ms, Screen screen, int mouseX, int mouseY) {
|
||||||
boolean flag = mouseX >= x && mouseX < x + width && mouseY >= y && mouseY < y + height;
|
boolean flag = mouseX >= this.getX() && mouseX < this.getX() + width && mouseY >= this.getY() && mouseY < this.getY() + height;
|
||||||
|
|
||||||
if (flag) {
|
if (flag) {
|
||||||
screen.renderComponentTooltip(ms, tooltip, mouseX - 10, mouseY + 25);
|
screen.renderComponentTooltip(ms, tooltip, mouseX - 10, mouseY + 25);
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ import com.mojang.blaze3d.vertex.PoseStack;
|
|||||||
import net.minecraft.MethodsReturnNonnullByDefault;
|
import net.minecraft.MethodsReturnNonnullByDefault;
|
||||||
import net.minecraft.client.gui.GuiComponent;
|
import net.minecraft.client.gui.GuiComponent;
|
||||||
import net.minecraft.client.gui.Font;
|
import net.minecraft.client.gui.Font;
|
||||||
import net.minecraft.client.gui.components.Widget;
|
import net.minecraft.client.gui.components.Renderable;
|
||||||
import net.minecraft.client.gui.screens.Screen;
|
import net.minecraft.client.gui.screens.Screen;
|
||||||
import net.minecraft.client.gui.components.EditBox;
|
import net.minecraft.client.gui.components.EditBox;
|
||||||
import net.minecraft.client.gui.components.Button;
|
import net.minecraft.client.gui.components.Button;
|
||||||
@@ -12,6 +12,7 @@ import net.minecraft.network.chat.Component;
|
|||||||
import net.minecraft.ChatFormatting;
|
import net.minecraft.ChatFormatting;
|
||||||
import net.minecraftforge.api.distmarker.Dist;
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
import net.minecraftforge.api.distmarker.OnlyIn;
|
import net.minecraftforge.api.distmarker.OnlyIn;
|
||||||
|
import net.minecraftforge.client.gui.widget.ExtendedButton;
|
||||||
|
|
||||||
import javax.annotation.ParametersAreNonnullByDefault;
|
import javax.annotation.ParametersAreNonnullByDefault;
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
@@ -34,21 +35,21 @@ public class GuiNumberField extends GuiComponent {
|
|||||||
|
|
||||||
List<Component> tooltip = new ArrayList<>();
|
List<Component> tooltip = new ArrayList<>();
|
||||||
|
|
||||||
public GuiNumberField(Font font, List<Widget> renderables, int x, int y, int width, int height) {
|
public GuiNumberField(Font font, List<Renderable> renderables, int x, int y, int width, int height) {
|
||||||
this.x = x;
|
this.x = x;
|
||||||
this.y = y;
|
this.y = y;
|
||||||
this.width = width;
|
this.width = width;
|
||||||
this.height = height;
|
this.height = height;
|
||||||
|
|
||||||
textField = new EditBox(font, x + buttonWidth + 1, y + 1, width - 2 * buttonWidth - 2, height - 2, Component.empty());
|
textField = new EditBox(font, x + buttonWidth + 1, y + 1, width - 2 * buttonWidth - 2, height - 2, Component.empty());
|
||||||
minusButton = new Button(x, y - 1, buttonWidth, height + 2, Component.literal("-"), button -> {
|
minusButton = new ExtendedButton(x, y - 1, buttonWidth, height + 2, Component.literal("-"), button -> {
|
||||||
float valueChanged = 1f;
|
float valueChanged = 1f;
|
||||||
if (Screen.hasControlDown()) valueChanged = 5f;
|
if (Screen.hasControlDown()) valueChanged = 5f;
|
||||||
if (Screen.hasShiftDown()) valueChanged = 10f;
|
if (Screen.hasShiftDown()) valueChanged = 10f;
|
||||||
|
|
||||||
setNumber(getNumber() - valueChanged);
|
setNumber(getNumber() - valueChanged);
|
||||||
});
|
});
|
||||||
plusButton = new Button(x + width - buttonWidth, y - 1, buttonWidth, height + 2, Component.literal("+"), button -> {
|
plusButton = new ExtendedButton(x + width - buttonWidth, y - 1, buttonWidth, height + 2, Component.literal("+"), button -> {
|
||||||
float valueChanged = 1f;
|
float valueChanged = 1f;
|
||||||
if (Screen.hasControlDown()) valueChanged = 5f;
|
if (Screen.hasControlDown()) valueChanged = 5f;
|
||||||
if (Screen.hasShiftDown()) valueChanged = 10f;
|
if (Screen.hasShiftDown()) valueChanged = 10f;
|
||||||
@@ -98,9 +99,9 @@ public class GuiNumberField extends GuiComponent {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void drawNumberField(PoseStack ms, int mouseX, int mouseY, float partialTicks) {
|
public void drawNumberField(PoseStack ms, int mouseX, int mouseY, float partialTicks) {
|
||||||
textField.y = y + 1;
|
textField.setY(y + 1);
|
||||||
minusButton.y = y - 1;
|
minusButton.setY(y - 1);
|
||||||
plusButton.y = y - 1;
|
plusButton.setY(y - 1);
|
||||||
|
|
||||||
textField.render(ms, mouseX, mouseY, partialTicks);
|
textField.render(ms, mouseX, mouseY, partialTicks);
|
||||||
minusButton.render(ms, mouseX, mouseY, partialTicks);
|
minusButton.render(ms, mouseX, mouseY, partialTicks);
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ import com.mojang.blaze3d.systems.RenderSystem;
|
|||||||
import net.minecraft.MethodsReturnNonnullByDefault;
|
import net.minecraft.MethodsReturnNonnullByDefault;
|
||||||
import net.minecraft.client.Minecraft;
|
import net.minecraft.client.Minecraft;
|
||||||
import net.minecraft.client.gui.Font;
|
import net.minecraft.client.gui.Font;
|
||||||
import net.minecraft.client.gui.components.Widget;
|
import net.minecraft.client.gui.components.Renderable;
|
||||||
import net.minecraft.client.gui.components.events.GuiEventListener;
|
import net.minecraft.client.gui.components.events.GuiEventListener;
|
||||||
import net.minecraft.client.gui.screens.Screen;
|
import net.minecraft.client.gui.screens.Screen;
|
||||||
import net.minecraft.client.gui.components.AbstractWidget;
|
import net.minecraft.client.gui.components.AbstractWidget;
|
||||||
@@ -398,7 +398,7 @@ public class GuiScrollPane extends SlotGui {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//PASSTHROUGHS
|
//PASSTHROUGHS
|
||||||
public void init(List<Widget> renderables) {
|
public void init(List<Renderable> renderables) {
|
||||||
for (IScrollEntry entry : this.listEntries) {
|
for (IScrollEntry entry : this.listEntries) {
|
||||||
entry.init(renderables);
|
entry.init(renderables);
|
||||||
}
|
}
|
||||||
@@ -436,7 +436,7 @@ public class GuiScrollPane extends SlotGui {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public interface IScrollEntry {
|
public interface IScrollEntry {
|
||||||
void init(List<Widget> renderables);
|
void init(List<Renderable> renderables);
|
||||||
|
|
||||||
void updateScreen();
|
void updateScreen();
|
||||||
|
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ import net.minecraft.MethodsReturnNonnullByDefault;
|
|||||||
import net.minecraft.client.Minecraft;
|
import net.minecraft.client.Minecraft;
|
||||||
import net.minecraft.client.gui.components.events.AbstractContainerEventHandler;
|
import net.minecraft.client.gui.components.events.AbstractContainerEventHandler;
|
||||||
import net.minecraft.client.gui.components.events.GuiEventListener;
|
import net.minecraft.client.gui.components.events.GuiEventListener;
|
||||||
import net.minecraft.client.gui.components.Widget;
|
import net.minecraft.client.gui.components.Renderable;
|
||||||
import net.minecraft.util.Mth;
|
import net.minecraft.util.Mth;
|
||||||
import net.minecraftforge.api.distmarker.Dist;
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
import net.minecraftforge.api.distmarker.OnlyIn;
|
import net.minecraftforge.api.distmarker.OnlyIn;
|
||||||
@@ -19,7 +19,7 @@ import java.util.List;
|
|||||||
@ParametersAreNonnullByDefault
|
@ParametersAreNonnullByDefault
|
||||||
@MethodsReturnNonnullByDefault
|
@MethodsReturnNonnullByDefault
|
||||||
@SuppressWarnings("deprecation")
|
@SuppressWarnings("deprecation")
|
||||||
public abstract class SlotGui extends AbstractContainerEventHandler implements Widget {
|
public abstract class SlotGui extends AbstractContainerEventHandler implements Renderable {
|
||||||
protected final Minecraft minecraft;
|
protected final Minecraft minecraft;
|
||||||
protected final int itemHeight;
|
protected final int itemHeight;
|
||||||
protected int width;
|
protected int width;
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ import net.minecraft.advancements.CriteriaTriggers;
|
|||||||
import net.minecraft.core.BlockPos;
|
import net.minecraft.core.BlockPos;
|
||||||
import net.minecraft.core.Direction;
|
import net.minecraft.core.Direction;
|
||||||
import net.minecraft.core.Registry;
|
import net.minecraft.core.Registry;
|
||||||
|
import net.minecraft.core.registries.Registries;
|
||||||
import net.minecraft.server.level.ServerPlayer;
|
import net.minecraft.server.level.ServerPlayer;
|
||||||
import net.minecraft.sounds.SoundSource;
|
import net.minecraft.sounds.SoundSource;
|
||||||
import net.minecraft.tags.BlockTags;
|
import net.minecraft.tags.BlockTags;
|
||||||
@@ -239,7 +240,8 @@ public class SurvivalHelper {
|
|||||||
} else {
|
} else {
|
||||||
//Adventure mode
|
//Adventure mode
|
||||||
BlockInWorld blockinworld = new BlockInWorld(world, pos, false);
|
BlockInWorld blockinworld = new BlockInWorld(world, pos, false);
|
||||||
return stack.hasAdventureModePlaceTagForBlock(world.registryAccess().registryOrThrow(Registry.BLOCK_REGISTRY), blockinworld);
|
Registry<Block> registry = world.registryAccess().registryOrThrow(Registries.BLOCK);
|
||||||
|
return stack.hasAdventureModePlaceTagForBlock(registry, blockinworld);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -50,7 +50,7 @@ public abstract class AbstractRandomizerBagItem extends Item {
|
|||||||
private static final Random rand = new Random(currentSeed);
|
private static final Random rand = new Random(currentSeed);
|
||||||
|
|
||||||
public AbstractRandomizerBagItem() {
|
public AbstractRandomizerBagItem() {
|
||||||
super(new Item.Properties().tab(CreativeModeTab.TAB_TOOLS).stacksTo(1));
|
super(new Item.Properties().stacksTo(1));
|
||||||
}
|
}
|
||||||
|
|
||||||
public abstract int getInventorySize();
|
public abstract int getInventorySize();
|
||||||
|
|||||||
@@ -33,7 +33,7 @@ public class DiamondRandomizerBagItem extends AbstractRandomizerBagItem{
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Component getDisplayName() {
|
public Component getDisplayName() {
|
||||||
return Component.translatable("effortlessbuilding:diamond_randomizer_bag");
|
return Component.translatable("item.effortlessbuilding.diamond_randomizer_bag");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
|
|||||||
@@ -33,7 +33,7 @@ public class GoldenRandomizerBagItem extends AbstractRandomizerBagItem{
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Component getDisplayName() {
|
public Component getDisplayName() {
|
||||||
return Component.translatable("effortlessbuilding:golden_randomizer_bag");
|
return Component.translatable("item.effortlessbuilding.golden_randomizer_bag");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
|
|||||||
@@ -33,7 +33,7 @@ public class RandomizerBagItem extends AbstractRandomizerBagItem {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Component getDisplayName() {
|
public Component getDisplayName() {
|
||||||
return Component.translatable("effortlessbuilding:randomizer_bag");
|
return Component.translatable("item.effortlessbuilding.randomizer_bag");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ import net.minecraft.world.InteractionResultHolder;
|
|||||||
public class ReachUpgrade1Item extends Item {
|
public class ReachUpgrade1Item extends Item {
|
||||||
|
|
||||||
public ReachUpgrade1Item() {
|
public ReachUpgrade1Item() {
|
||||||
super(new Item.Properties().tab(CreativeModeTab.TAB_TOOLS).stacksTo(1));
|
super(new Item.Properties().stacksTo(1));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -48,14 +48,14 @@ public class ReachUpgrade1Item extends Item {
|
|||||||
if (world.isClientSide) EffortlessBuilding.log(player, "Upgraded reach to " + ReachHelper.getMaxReach(player));
|
if (world.isClientSide) EffortlessBuilding.log(player, "Upgraded reach to " + ReachHelper.getMaxReach(player));
|
||||||
player.setItemInHand(hand, ItemStack.EMPTY);
|
player.setItemInHand(hand, ItemStack.EMPTY);
|
||||||
|
|
||||||
SoundEvent soundEvent = new SoundEvent(new ResourceLocation("entity.player.levelup"));
|
SoundEvent soundEvent = SoundEvent.createVariableRangeEvent(new ResourceLocation("entity.player.levelup"));
|
||||||
player.playSound(soundEvent, 1f, 1f);
|
player.playSound(soundEvent, 1f, 1f);
|
||||||
} else if (currentLevel > 0) {
|
} else if (currentLevel > 0) {
|
||||||
if (world.isClientSide)
|
if (world.isClientSide)
|
||||||
EffortlessBuilding.log(player, "Already used this upgrade! Current reach is " + ReachHelper
|
EffortlessBuilding.log(player, "Already used this upgrade! Current reach is " + ReachHelper
|
||||||
.getMaxReach(player) + ".");
|
.getMaxReach(player) + ".");
|
||||||
|
|
||||||
SoundEvent soundEvent = new SoundEvent(new ResourceLocation("item.armor.equip_leather"));
|
SoundEvent soundEvent = SoundEvent.createVariableRangeEvent(new ResourceLocation("item.armor.equip_leather"));
|
||||||
player.playSound(soundEvent, 1f, 1f);
|
player.playSound(soundEvent, 1f, 1f);
|
||||||
}
|
}
|
||||||
return new InteractionResultHolder<>(InteractionResult.PASS, player.getItemInHand(hand));
|
return new InteractionResultHolder<>(InteractionResult.PASS, player.getItemInHand(hand));
|
||||||
|
|||||||
@@ -30,7 +30,7 @@ import net.minecraft.world.InteractionResultHolder;
|
|||||||
public class ReachUpgrade2Item extends Item {
|
public class ReachUpgrade2Item extends Item {
|
||||||
|
|
||||||
public ReachUpgrade2Item() {
|
public ReachUpgrade2Item() {
|
||||||
super(new Item.Properties().tab(CreativeModeTab.TAB_TOOLS).stacksTo(1));
|
super(new Item.Properties().stacksTo(1));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -48,19 +48,19 @@ public class ReachUpgrade2Item extends Item {
|
|||||||
if (world.isClientSide) EffortlessBuilding.log(player, "Upgraded reach to " + ReachHelper.getMaxReach(player));
|
if (world.isClientSide) EffortlessBuilding.log(player, "Upgraded reach to " + ReachHelper.getMaxReach(player));
|
||||||
player.setItemInHand(hand, ItemStack.EMPTY);
|
player.setItemInHand(hand, ItemStack.EMPTY);
|
||||||
|
|
||||||
SoundEvent soundEvent = new SoundEvent(new ResourceLocation("entity.player.levelup"));
|
SoundEvent soundEvent = SoundEvent.createVariableRangeEvent(new ResourceLocation("entity.player.levelup"));
|
||||||
player.playSound(soundEvent, 1f, 1f);
|
player.playSound(soundEvent, 1f, 1f);
|
||||||
} else if (currentLevel < 1) {
|
} else if (currentLevel < 1) {
|
||||||
if (world.isClientSide) EffortlessBuilding.log(player, "Use Reach Upgrade 1 first.");
|
if (world.isClientSide) EffortlessBuilding.log(player, "Use Reach Upgrade 1 first.");
|
||||||
|
|
||||||
SoundEvent soundEvent = new SoundEvent(new ResourceLocation("item.armor.equip_leather"));
|
SoundEvent soundEvent = SoundEvent.createVariableRangeEvent(new ResourceLocation("item.armor.equip_leather"));
|
||||||
player.playSound(soundEvent, 1f, 1f);
|
player.playSound(soundEvent, 1f, 1f);
|
||||||
} else if (currentLevel > 1) {
|
} else if (currentLevel > 1) {
|
||||||
if (world.isClientSide)
|
if (world.isClientSide)
|
||||||
EffortlessBuilding.log(player, "Already used this upgrade! Current reach is " + ReachHelper
|
EffortlessBuilding.log(player, "Already used this upgrade! Current reach is " + ReachHelper
|
||||||
.getMaxReach(player) + ".");
|
.getMaxReach(player) + ".");
|
||||||
|
|
||||||
SoundEvent soundEvent = new SoundEvent(new ResourceLocation("item.armor.equip_leather"));
|
SoundEvent soundEvent = SoundEvent.createVariableRangeEvent(new ResourceLocation("item.armor.equip_leather"));
|
||||||
player.playSound(soundEvent, 1f, 1f);
|
player.playSound(soundEvent, 1f, 1f);
|
||||||
}
|
}
|
||||||
return new InteractionResultHolder<>(InteractionResult.PASS, player.getItemInHand(hand));
|
return new InteractionResultHolder<>(InteractionResult.PASS, player.getItemInHand(hand));
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ import net.minecraft.world.InteractionResultHolder;
|
|||||||
public class ReachUpgrade3Item extends Item {
|
public class ReachUpgrade3Item extends Item {
|
||||||
|
|
||||||
public ReachUpgrade3Item() {
|
public ReachUpgrade3Item() {
|
||||||
super(new Item.Properties().tab(CreativeModeTab.TAB_TOOLS).stacksTo(1));
|
super(new Item.Properties().stacksTo(1));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -47,7 +47,7 @@ public class ReachUpgrade3Item extends Item {
|
|||||||
if (world.isClientSide) EffortlessBuilding.log(player, "Upgraded reach to " + ReachHelper.getMaxReach(player));
|
if (world.isClientSide) EffortlessBuilding.log(player, "Upgraded reach to " + ReachHelper.getMaxReach(player));
|
||||||
player.setItemInHand(hand, ItemStack.EMPTY);
|
player.setItemInHand(hand, ItemStack.EMPTY);
|
||||||
|
|
||||||
SoundEvent soundEvent = new SoundEvent(new ResourceLocation("entity.player.levelup"));
|
SoundEvent soundEvent = SoundEvent.createVariableRangeEvent(new ResourceLocation("entity.player.levelup"));
|
||||||
player.playSound(soundEvent, 1f, 1f);
|
player.playSound(soundEvent, 1f, 1f);
|
||||||
} else if (currentLevel < 2) {
|
} else if (currentLevel < 2) {
|
||||||
if (currentLevel == 0)
|
if (currentLevel == 0)
|
||||||
@@ -55,14 +55,14 @@ public class ReachUpgrade3Item extends Item {
|
|||||||
if (currentLevel == 1)
|
if (currentLevel == 1)
|
||||||
if (world.isClientSide) EffortlessBuilding.log(player, "Use Reach Upgrade 2 first.");
|
if (world.isClientSide) EffortlessBuilding.log(player, "Use Reach Upgrade 2 first.");
|
||||||
|
|
||||||
SoundEvent soundEvent = new SoundEvent(new ResourceLocation("item.armor.equip_leather"));
|
SoundEvent soundEvent = SoundEvent.createVariableRangeEvent(new ResourceLocation("item.armor.equip_leather"));
|
||||||
player.playSound(soundEvent, 1f, 1f);
|
player.playSound(soundEvent, 1f, 1f);
|
||||||
} else if (currentLevel > 2) {
|
} else if (currentLevel > 2) {
|
||||||
if (world.isClientSide)
|
if (world.isClientSide)
|
||||||
EffortlessBuilding.log(player, "Already used this upgrade! Current reach is " + ReachHelper
|
EffortlessBuilding.log(player, "Already used this upgrade! Current reach is " + ReachHelper
|
||||||
.getMaxReach(player) + ".");
|
.getMaxReach(player) + ".");
|
||||||
|
|
||||||
SoundEvent soundEvent = new SoundEvent(new ResourceLocation("item.armor.equip_leather"));
|
SoundEvent soundEvent = SoundEvent.createVariableRangeEvent(new ResourceLocation("item.armor.equip_leather"));
|
||||||
player.playSound(soundEvent, 1f, 1f);
|
player.playSound(soundEvent, 1f, 1f);
|
||||||
}
|
}
|
||||||
return new InteractionResultHolder<>(InteractionResult.PASS, player.getItemInHand(hand));
|
return new InteractionResultHolder<>(InteractionResult.PASS, player.getItemInHand(hand));
|
||||||
|
|||||||
@@ -24,6 +24,7 @@ import net.minecraft.ChatFormatting;
|
|||||||
import net.minecraft.world.level.Level;
|
import net.minecraft.world.level.Level;
|
||||||
import net.minecraftforge.api.distmarker.Dist;
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
import net.minecraftforge.client.event.InputEvent;
|
import net.minecraftforge.client.event.InputEvent;
|
||||||
|
import net.minecraftforge.client.event.RegisterKeyMappingsEvent;
|
||||||
import net.minecraftforge.client.event.ScreenEvent;
|
import net.minecraftforge.client.event.ScreenEvent;
|
||||||
import net.minecraftforge.client.settings.KeyConflictContext;
|
import net.minecraftforge.client.settings.KeyConflictContext;
|
||||||
import net.minecraftforge.client.settings.KeyModifier;
|
import net.minecraftforge.client.settings.KeyModifier;
|
||||||
@@ -70,16 +71,7 @@ public class ClientProxy implements IProxy {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void clientSetup(FMLClientSetupEvent event) {
|
public void clientSetup(FMLClientSetupEvent event) {
|
||||||
// register key bindings
|
//Keybindings are setup and registered in ModClientEventHandler
|
||||||
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");
|
|
||||||
|
|
||||||
MenuScreens.register(EffortlessBuilding.RANDOMIZER_BAG_CONTAINER.get(), RandomizerBagScreen::new);
|
MenuScreens.register(EffortlessBuilding.RANDOMIZER_BAG_CONTAINER.get(), RandomizerBagScreen::new);
|
||||||
MenuScreens.register(EffortlessBuilding.GOLDEN_RANDOMIZER_BAG_CONTAINER.get(), GoldenRandomizerBagScreen::new);
|
MenuScreens.register(EffortlessBuilding.GOLDEN_RANDOMIZER_BAG_CONTAINER.get(), GoldenRandomizerBagScreen::new);
|
||||||
@@ -129,7 +121,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,13 @@ 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());
|
||||||
|
|
||||||
|
|||||||
@@ -3,13 +3,13 @@ package nl.requios.effortlessbuilding.render;
|
|||||||
import com.mojang.blaze3d.vertex.PoseStack;
|
import com.mojang.blaze3d.vertex.PoseStack;
|
||||||
import com.mojang.blaze3d.vertex.VertexConsumer;
|
import com.mojang.blaze3d.vertex.VertexConsumer;
|
||||||
import net.minecraft.client.renderer.MultiBufferSource;
|
import net.minecraft.client.renderer.MultiBufferSource;
|
||||||
import com.mojang.math.Matrix4f;
|
|
||||||
import net.minecraft.world.phys.Vec3;
|
import net.minecraft.world.phys.Vec3;
|
||||||
import net.minecraftforge.api.distmarker.Dist;
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
import net.minecraftforge.api.distmarker.OnlyIn;
|
import net.minecraftforge.api.distmarker.OnlyIn;
|
||||||
import nl.requios.effortlessbuilding.buildmodifier.Mirror;
|
import nl.requios.effortlessbuilding.buildmodifier.Mirror;
|
||||||
import nl.requios.effortlessbuilding.buildmodifier.ModifierSettingsManager;
|
import nl.requios.effortlessbuilding.buildmodifier.ModifierSettingsManager;
|
||||||
import nl.requios.effortlessbuilding.buildmodifier.RadialMirror;
|
import nl.requios.effortlessbuilding.buildmodifier.RadialMirror;
|
||||||
|
import org.joml.Matrix4f;
|
||||||
|
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
|
|
||||||
|
|||||||
@@ -11,12 +11,12 @@
|
|||||||
"key.effortlessbuilding.redo.desc": "Redo",
|
"key.effortlessbuilding.redo.desc": "Redo",
|
||||||
"key.effortlessbuilding.altplacement.desc": "Alternative placement",
|
"key.effortlessbuilding.altplacement.desc": "Alternative placement",
|
||||||
|
|
||||||
"effortlessbuilding:randomizer_bag": "Leather Randomizer Bag",
|
"item.effortlessbuilding.randomizer_bag": "Leather Randomizer Bag",
|
||||||
"effortlessbuilding:golden_randomizer_bag": "Golden Randomizer Bag",
|
"item.effortlessbuilding.golden_randomizer_bag": "Golden Randomizer Bag",
|
||||||
"effortlessbuilding:diamond_randomizer_bag": "Diamond Randomizer Bag",
|
"item.effortlessbuilding.diamond_randomizer_bag": "Diamond Randomizer Bag",
|
||||||
"effortlessbuilding:reach_upgrade1": "Reach Upgrade 1",
|
"item.effortlessbuilding.reach_upgrade1": "Reach Upgrade 1",
|
||||||
"effortlessbuilding:reach_upgrade2": "Reach Upgrade 2",
|
"item.effortlessbuilding.reach_upgrade2": "Reach Upgrade 2",
|
||||||
"effortlessbuilding:reach_upgrade3": "Reach Upgrade 3",
|
"item.effortlessbuilding.reach_upgrade3": "Reach Upgrade 3",
|
||||||
|
|
||||||
"effortlessbuilding.mode.normal": "Disable",
|
"effortlessbuilding.mode.normal": "Disable",
|
||||||
"effortlessbuilding.mode.normal_plus": "Single",
|
"effortlessbuilding.mode.normal_plus": "Single",
|
||||||
|
|||||||
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 <уровень>"
|
||||||
|
}
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"parent": "item/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "effortlessbuilding:items/diamondrandomizerbag"
|
"layer0": "effortlessbuilding:item/diamondrandomizerbag"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"parent": "item/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "effortlessbuilding:items/goldenrandomizerbag"
|
"layer0": "effortlessbuilding:item/goldenrandomizerbag"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"parent": "item/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "effortlessbuilding:items/randomizerbag"
|
"layer0": "effortlessbuilding:item/randomizerbag"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"parent": "item/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "effortlessbuilding:items/reachupgrade1"
|
"layer0": "effortlessbuilding:item/reachupgrade1"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"parent": "item/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "effortlessbuilding:items/reachupgrade2"
|
"layer0": "effortlessbuilding:item/reachupgrade2"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"parent": "item/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "effortlessbuilding:items/reachupgrade3"
|
"layer0": "effortlessbuilding:item/reachupgrade3"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 319 B After Width: | Height: | Size: 4.9 KiB |
|
Before Width: | Height: | Size: 6.0 KiB After Width: | Height: | Size: 6.0 KiB |
|
Before Width: | Height: | Size: 5.8 KiB After Width: | Height: | Size: 5.8 KiB |
|
Before Width: | Height: | Size: 394 B After Width: | Height: | Size: 394 B |
|
Before Width: | Height: | Size: 625 B After Width: | Height: | Size: 625 B |
|
Before Width: | Height: | Size: 603 B After Width: | Height: | Size: 603 B |
|
Before Width: | Height: | Size: 618 B After Width: | Height: | Size: 618 B |
@@ -10,7 +10,7 @@
|
|||||||
"item": "minecraft:ender_pearl"
|
"item": "minecraft:ender_pearl"
|
||||||
},
|
},
|
||||||
"#": {
|
"#": {
|
||||||
"item": "minecraft:prismarine_crystals"
|
"item": "minecraft:slime_ball"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"result": {
|
"result": {
|
||||||
|
|||||||
@@ -1,20 +1,17 @@
|
|||||||
{
|
{
|
||||||
"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": {
|
||||||
"item": "effortlessbuilding:reach_upgrade2"
|
"item": "effortlessbuilding:reach_upgrade2"
|
||||||
|
|||||||
@@ -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": {
|
||||||
|
|||||||