mirror of
https://github.com/Creators-of-Create/Create.git
synced 2024-12-29 08:27:03 +01:00
Assisted Placement, Part IV-c
- indicator renders again - changed the config to allow the indicator to be disabled altogether
This commit is contained in:
parent
fd98bd4976
commit
c9ba76a2d1
2 changed files with 26 additions and 41 deletions
|
@ -18,11 +18,15 @@ public class CClient extends ConfigBase {
|
||||||
|
|
||||||
public ConfigInt overlayOffsetX = i(20, Integer.MIN_VALUE, Integer.MAX_VALUE, "overlayOffsetX", "Offset the overlay from goggle- and hover- information by this many pixels on the X axis; Use /create overlay");
|
public ConfigInt overlayOffsetX = i(20, Integer.MIN_VALUE, Integer.MAX_VALUE, "overlayOffsetX", "Offset the overlay from goggle- and hover- information by this many pixels on the X axis; Use /create overlay");
|
||||||
public ConfigInt overlayOffsetY = i(0, Integer.MIN_VALUE, Integer.MAX_VALUE, "overlayOffsetY", "Offset the overlay from goggle- and hover- information by this many pixels on the Y axis; Use /create overlay");
|
public ConfigInt overlayOffsetY = i(0, Integer.MIN_VALUE, Integer.MAX_VALUE, "overlayOffsetY", "Offset the overlay from goggle- and hover- information by this many pixels on the Y axis; Use /create overlay");
|
||||||
public ConfigBool smoothPlacementIndicator = b(false, "smoothPlacementIndicator", "Use an alternative indicator when showing where the assisted placement ends up relative to your crosshair");
|
public ConfigEnum<PlacementIndicatorSetting> placementIndicator = e(PlacementIndicatorSetting.TEXTURE, "placementIndicator", "What indicator should be used when showing where the assisted placement ends up relative to your crosshair");
|
||||||
public ConfigBool ignoreFabulousWarning = b(false, "ignoreFabulousWarning", "Setting this to true will prevent Create from sending you a warning when playing with Fabulous graphics enabled");
|
public ConfigBool ignoreFabulousWarning = b(false, "ignoreFabulousWarning", "Setting this to true will prevent Create from sending you a warning when playing with Fabulous graphics enabled");
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getName() {
|
public String getName() {
|
||||||
return "client";
|
return "client";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public enum PlacementIndicatorSetting {
|
||||||
|
TEXTURE, TRIANGLE, NONE
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,6 +3,7 @@ package com.simibubi.create.foundation.utility.placement;
|
||||||
import com.mojang.blaze3d.matrix.MatrixStack;
|
import com.mojang.blaze3d.matrix.MatrixStack;
|
||||||
import com.mojang.blaze3d.systems.RenderSystem;
|
import com.mojang.blaze3d.systems.RenderSystem;
|
||||||
import com.simibubi.create.foundation.config.AllConfigs;
|
import com.simibubi.create.foundation.config.AllConfigs;
|
||||||
|
import com.simibubi.create.foundation.config.CClient;
|
||||||
import com.simibubi.create.foundation.gui.AllGuiTextures;
|
import com.simibubi.create.foundation.gui.AllGuiTextures;
|
||||||
import com.simibubi.create.foundation.gui.widgets.InterpolatedChasingAngle;
|
import com.simibubi.create.foundation.gui.widgets.InterpolatedChasingAngle;
|
||||||
import com.simibubi.create.foundation.gui.widgets.InterpolatedChasingValue;
|
import com.simibubi.create.foundation.gui.widgets.InterpolatedChasingValue;
|
||||||
|
@ -20,6 +21,7 @@ import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.util.Hand;
|
import net.minecraft.util.Hand;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.util.math.BlockRayTraceResult;
|
import net.minecraft.util.math.BlockRayTraceResult;
|
||||||
|
import net.minecraft.util.math.vector.Matrix4f;
|
||||||
import net.minecraft.util.math.vector.Vector3d;
|
import net.minecraft.util.math.vector.Vector3d;
|
||||||
import net.minecraft.util.math.vector.Vector3f;
|
import net.minecraft.util.math.vector.Vector3f;
|
||||||
import net.minecraftforge.api.distmarker.Dist;
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
|
@ -150,24 +152,12 @@ public class PlacementHelpers {
|
||||||
|
|
||||||
if (player != null && animationTick > 0) {
|
if (player != null && animationTick > 0) {
|
||||||
MainWindow res = event.getWindow();
|
MainWindow res = event.getWindow();
|
||||||
//MatrixStack matrix = event.getMatrix();
|
|
||||||
//String text = "( )";
|
|
||||||
|
|
||||||
//matrix.push();
|
|
||||||
//matrix.translate(res.getScaledWidth() / 2F, res.getScaledHeight() / 2f - 4, 0);
|
|
||||||
float screenY = res.getScaledHeight() / 2f;
|
float screenY = res.getScaledHeight() / 2f;
|
||||||
float screenX = res.getScaledWidth() / 2f;
|
float screenX = res.getScaledWidth() / 2f;
|
||||||
//float y = screenY - 3.5f;
|
|
||||||
//float x = screenX;
|
|
||||||
//x -= mc.fontRenderer.getStringWidth(text)/2f - 0.25f;
|
|
||||||
|
|
||||||
float progress = Math.min(animationTick / 10f/* + event.getPartialTicks()*/, 1f);
|
float progress = Math.min(animationTick / 10f/* + event.getPartialTicks()*/, 1f);
|
||||||
//int opacity = ((int) (255 * (progress * progress))) << 24;
|
|
||||||
|
|
||||||
//mc.fontRenderer.drawString(text, x, y, 0xFFFFFF | opacity);
|
|
||||||
|
|
||||||
drawDirectionIndicator(event.getMatrixStack(), event.getPartialTicks(), screenX, screenY, progress);
|
drawDirectionIndicator(event.getMatrixStack(), event.getPartialTicks(), screenX, screenY, progress);
|
||||||
//matrix.pop();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -205,13 +195,11 @@ public class PlacementHelpers {
|
||||||
float snappedAngle = (snapSize * Math.round(angle.get(0f) / snapSize)) % 360f;
|
float snappedAngle = (snapSize * Math.round(angle.get(0f) / snapSize)) % 360f;
|
||||||
|
|
||||||
float length = 10;
|
float length = 10;
|
||||||
//TOD O if the target is off screen, use length to show a meaningful distance
|
|
||||||
|
|
||||||
boolean flag = AllConfigs.CLIENT.smoothPlacementIndicator.get();
|
CClient.PlacementIndicatorSetting mode = AllConfigs.CLIENT.placementIndicator.get();
|
||||||
if (flag)
|
if (mode == CClient.PlacementIndicatorSetting.TRIANGLE)
|
||||||
fadedArrow(ms, centerX, centerY, r, g, b, a, length, snappedAngle);
|
fadedArrow(ms, centerX, centerY, r, g, b, a, length, snappedAngle);
|
||||||
|
else if (mode == CClient.PlacementIndicatorSetting.TEXTURE)
|
||||||
else
|
|
||||||
textured(ms, centerX, centerY, a, snappedAngle);
|
textured(ms, centerX, centerY, a, snappedAngle);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -231,15 +219,17 @@ public class PlacementHelpers {
|
||||||
BufferBuilder bufferbuilder = tessellator.getBuffer();
|
BufferBuilder bufferbuilder = tessellator.getBuffer();
|
||||||
bufferbuilder.begin(GL11.GL_POLYGON, DefaultVertexFormats.POSITION_COLOR);
|
bufferbuilder.begin(GL11.GL_POLYGON, DefaultVertexFormats.POSITION_COLOR);
|
||||||
|
|
||||||
bufferbuilder.vertex(0, - (10 + length), 0).color(r, g, b, a).endVertex();
|
Matrix4f mat = ms.peek().getModel();
|
||||||
|
|
||||||
bufferbuilder.vertex(-9, -3, 0).color(r, g, b, 0f).endVertex();
|
bufferbuilder.vertex(mat, 0, - (10 + length), 0).color(r, g, b, a).endVertex();
|
||||||
bufferbuilder.vertex(-6, -6, 0).color(r, g, b, 0f).endVertex();
|
|
||||||
bufferbuilder.vertex(-3, -8, 0).color(r, g, b, 0f).endVertex();
|
bufferbuilder.vertex(mat, -9, -3, 0).color(r, g, b, 0f).endVertex();
|
||||||
bufferbuilder.vertex(0, -8.5, 0).color(r, g, b, 0f).endVertex();
|
bufferbuilder.vertex(mat, -6, -6, 0).color(r, g, b, 0f).endVertex();
|
||||||
bufferbuilder.vertex(3, -8, 0).color(r, g, b, 0f).endVertex();
|
bufferbuilder.vertex(mat, -3, -8, 0).color(r, g, b, 0f).endVertex();
|
||||||
bufferbuilder.vertex(6, -6, 0).color(r, g, b, 0f).endVertex();
|
bufferbuilder.vertex(mat, 0, -8.5f, 0).color(r, g, b, 0f).endVertex();
|
||||||
bufferbuilder.vertex(9, -3, 0).color(r, g, b, 0f).endVertex();
|
bufferbuilder.vertex(mat, 3, -8, 0).color(r, g, b, 0f).endVertex();
|
||||||
|
bufferbuilder.vertex(mat, 6, -6, 0).color(r, g, b, 0f).endVertex();
|
||||||
|
bufferbuilder.vertex(mat, 9, -3, 0).color(r, g, b, 0f).endVertex();
|
||||||
|
|
||||||
tessellator.draw();
|
tessellator.draw();
|
||||||
RenderSystem.shadeModel(GL11.GL_FLAT);
|
RenderSystem.shadeModel(GL11.GL_FLAT);
|
||||||
|
@ -252,19 +242,13 @@ public class PlacementHelpers {
|
||||||
private static void textured(MatrixStack ms, float centerX, float centerY, float alpha, float snappedAngle) {
|
private static void textured(MatrixStack ms, float centerX, float centerY, float alpha, float snappedAngle) {
|
||||||
ms.push();
|
ms.push();
|
||||||
RenderSystem.enableTexture();
|
RenderSystem.enableTexture();
|
||||||
//RenderSystem.disableTexture();
|
|
||||||
AllGuiTextures.PLACEMENT_INDICATOR_SHEET.bind();
|
AllGuiTextures.PLACEMENT_INDICATOR_SHEET.bind();
|
||||||
RenderSystem.enableBlend();
|
RenderSystem.enableBlend();
|
||||||
//RenderSystem.disableAlphaTest();
|
|
||||||
RenderSystem.enableAlphaTest();
|
RenderSystem.enableAlphaTest();
|
||||||
RenderSystem.defaultBlendFunc();
|
RenderSystem.defaultBlendFunc();
|
||||||
RenderSystem.color4f(1f, 1f, 1f, 1f);
|
|
||||||
RenderSystem.shadeModel(GL11.GL_SMOOTH);
|
RenderSystem.shadeModel(GL11.GL_SMOOTH);
|
||||||
|
|
||||||
ms.translate(centerX, centerY, 0);
|
ms.translate(centerX, centerY, 0);
|
||||||
//RenderSystem.rotatef(angle.get(0.1f), 0, 0, -1);
|
|
||||||
//RenderSystem.translated(0, 10, 0);
|
|
||||||
//RenderSystem.rotatef(angle.get(0.1f), 0, 0, 1);
|
|
||||||
ms.scale(12, 12, 0);
|
ms.scale(12, 12, 0);
|
||||||
|
|
||||||
float index = snappedAngle / 22.5f;
|
float index = snappedAngle / 22.5f;
|
||||||
|
@ -279,19 +263,16 @@ public class PlacementHelpers {
|
||||||
BufferBuilder buffer = tessellator.getBuffer();
|
BufferBuilder buffer = tessellator.getBuffer();
|
||||||
buffer.begin(GL11.GL_QUADS, DefaultVertexFormats.POSITION_COLOR_TEXTURE);
|
buffer.begin(GL11.GL_QUADS, DefaultVertexFormats.POSITION_COLOR_TEXTURE);
|
||||||
|
|
||||||
|
Matrix4f mat = ms.peek().getModel();
|
||||||
buffer.vertex(-1, -1, 0).color(1f, 1f, 1f, alpha).texture(tx, ty).endVertex();
|
buffer.vertex(mat, -1, -1, 0).color(1f, 1f, 1f, alpha).texture(tx, ty).endVertex();
|
||||||
buffer.vertex(-1, 1, 0).color(1f, 1f, 1f, alpha).texture(tx, ty + th).endVertex();
|
buffer.vertex(mat, -1, 1, 0).color(1f, 1f, 1f, alpha).texture(tx, ty + th).endVertex();
|
||||||
buffer.vertex(1, 1, 0).color(1f, 1f, 1f, alpha).texture(tx + tw, ty + th).endVertex();
|
buffer.vertex(mat, 1, 1, 0).color(1f, 1f, 1f, alpha).texture(tx + tw, ty + th).endVertex();
|
||||||
buffer.vertex(1, -1, 0).color(1f, 1f, 1f, alpha).texture(tx + tw, ty).endVertex();
|
buffer.vertex(mat, 1, -1, 0).color(1f, 1f, 1f, alpha).texture(tx + tw, ty).endVertex();
|
||||||
|
|
||||||
tessellator.draw();
|
tessellator.draw();
|
||||||
|
|
||||||
RenderSystem.shadeModel(GL11.GL_FLAT);
|
RenderSystem.shadeModel(GL11.GL_FLAT);
|
||||||
|
|
||||||
//RenderSystem.enableTexture();
|
|
||||||
|
|
||||||
RenderSystem.disableBlend();
|
RenderSystem.disableBlend();
|
||||||
//RenderSystem.enableAlphaTest();
|
|
||||||
ms.pop();
|
ms.pop();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue