1
0
mirror of https://github.com/SquidDev-CC/CC-Tweaked synced 2025-10-25 19:07:39 +00:00

Remove QuadEmitter

And remove EMI support. I'm not sure it survived the 1.21.4 recipe
changes :(.
This commit is contained in:
Jonathan Coates
2025-10-14 22:10:00 +01:00
parent 91b3b60ca2
commit d0d4df367f
15 changed files with 59 additions and 144 deletions

View File

@@ -50,7 +50,6 @@ repositories {
includeGroup("com.simibubi.create") includeGroup("com.simibubi.create")
includeGroup("net.commoble.morered") includeGroup("net.commoble.morered")
includeGroup("dev.architectury") includeGroup("dev.architectury")
includeGroup("dev.emi")
includeGroup("maven.modrinth") includeGroup("maven.modrinth")
includeGroup("me.shedaniel.cloth") includeGroup("me.shedaniel.cloth")
includeGroup("me.shedaniel") includeGroup("me.shedaniel")

View File

@@ -36,7 +36,6 @@ kotlin-coroutines = "1.10.1"
nightConfig = "3.8.1" nightConfig = "3.8.1"
# Minecraft mods # Minecraft mods
emi = "1.1.7+1.21"
fabricPermissions = "0.3.3" fabricPermissions = "0.3.3"
iris-fabric = "1.9.1+1.21.7-fabric" iris-fabric = "1.9.1+1.21.7-fabric"
iris-forge = "1.9.1+1.21.7-neoforge" iris-forge = "1.9.1+1.21.7-neoforge"
@@ -106,7 +105,6 @@ slf4j = { module = "org.slf4j:slf4j-api", version.ref = "slf4j" }
# Minecraft mods # Minecraft mods
create-fabric = { module = "com.simibubi.create:create-fabric-1.20.1", version.ref = "create-fabric" } create-fabric = { module = "com.simibubi.create:create-fabric-1.20.1", version.ref = "create-fabric" }
create-forge = { module = "com.simibubi.create:create-1.21.1", version.ref = "create-forge" } create-forge = { module = "com.simibubi.create:create-1.21.1", version.ref = "create-forge" }
emi = { module = "dev.emi:emi-xplat-mojmap", version.ref = "emi" }
fabric-api = { module = "net.fabricmc.fabric-api:fabric-api", version.ref = "fabric-api" } fabric-api = { module = "net.fabricmc.fabric-api:fabric-api", version.ref = "fabric-api" }
fabric-junit = { module = "net.fabricmc:fabric-loader-junit", version.ref = "fabric-loader" } fabric-junit = { module = "net.fabricmc:fabric-loader-junit", version.ref = "fabric-loader" }
fabric-loader = { module = "net.fabricmc:fabric-loader", version.ref = "fabric-loader" } fabric-loader = { module = "net.fabricmc:fabric-loader", version.ref = "fabric-loader" }

View File

@@ -11,12 +11,6 @@ plugins {
id("cc-tweaked.publishing") id("cc-tweaked.publishing")
} }
sourceSets.client {
java {
exclude("dan200/computercraft/client/integration/emi")
}
}
minecraft { minecraft {
accessWideners( accessWideners(
"src/main/resources/computercraft.accesswidener", "src/main/resources/computercraft.accesswidener",
@@ -45,7 +39,6 @@ dependencies {
compileOnly(libs.mixin) compileOnly(libs.mixin)
compileOnly(libs.mixinExtra) compileOnly(libs.mixinExtra)
compileOnly(libs.bundles.externalMods.common) compileOnly(libs.bundles.externalMods.common)
clientCompileOnly(variantOf(libs.emi) { classifier("api") })
annotationProcessorEverywhere(libs.autoService) annotationProcessorEverywhere(libs.autoService)
testFixturesAnnotationProcessor(libs.autoService) testFixturesAnnotationProcessor(libs.autoService)

View File

@@ -189,7 +189,6 @@ public final class PrintoutScreen extends AbstractContainerScreen<PrintoutMenu>
var buffer = bufferSource.getBuffer(PrintoutRenderer.BACKGROUND); var buffer = bufferSource.getBuffer(PrintoutRenderer.BACKGROUND);
drawBorder(pose.last().pose(), buffer, 0, 0, 0, state.page(), state.printout().pages(), state.printout().book(), LightTexture.FULL_BRIGHT); drawBorder(pose.last().pose(), buffer, 0, 0, 0, state.page(), state.printout().pages(), state.printout().book(), LightTexture.FULL_BRIGHT);
// TODO: This can probably be shifted into a separate one now.
drawText( drawText(
pose, bufferSource, X_TEXT_MARGIN, Y_TEXT_MARGIN, PrintoutData.LINES_PER_PAGE * state.page(), LightTexture.FULL_BRIGHT, pose, bufferSource, X_TEXT_MARGIN, Y_TEXT_MARGIN, PrintoutData.LINES_PER_PAGE * state.page(), LightTexture.FULL_BRIGHT,
state.printout().text(), state.printout().colour() state.printout().text(), state.printout().colour()

View File

@@ -310,9 +310,8 @@ public class TerminalWidget extends AbstractWidget {
@Nullable ScreenRectangle scissorArea @Nullable ScreenRectangle scissorArea
) implements GuiElementRenderState { ) implements GuiElementRenderState {
@Override @Override
public void buildVertices(VertexConsumer vertexConsumer) { public void buildVertices(VertexConsumer buffer) {
var quads = new FixedWidthFontRenderer.QuadEmitter(new Matrix4f().mul(pose), vertexConsumer); FixedWidthFontRenderer.drawTerminalBackground(new Matrix4f().mul(pose), buffer, x, y, terminal, MARGIN, MARGIN, MARGIN, MARGIN);
FixedWidthFontRenderer.drawTerminalBackground(quads, x, y, terminal, MARGIN, MARGIN, MARGIN, MARGIN);
} }
@Override @Override
@@ -326,14 +325,14 @@ public class TerminalWidget extends AbstractWidget {
@Nullable ScreenRectangle bounds, @Nullable ScreenRectangle scissorArea @Nullable ScreenRectangle bounds, @Nullable ScreenRectangle scissorArea
) implements GuiElementRenderState { ) implements GuiElementRenderState {
@Override @Override
public void buildVertices(VertexConsumer vertexConsumer) { public void buildVertices(VertexConsumer buffer) {
var quads = new FixedWidthFontRenderer.QuadEmitter(new Matrix4f().mul(pose), vertexConsumer); var transform = new Matrix4f().mul(pose);
FixedWidthFontRenderer.drawTerminalForeground(quads, x, y, terminal); FixedWidthFontRenderer.drawTerminalForeground(transform, buffer, x, y, terminal);
FixedWidthFontRenderer.drawCursor(quads, x, y, terminal); FixedWidthFontRenderer.drawCursor(transform, buffer, x, y, terminal);
// The GUI renderer requires that the buffer is non-empty. Add a zero-size vertex so we always have something. // The GUI renderer requires that the buffer is non-empty. Add a zero-size vertex so we always have something.
for (var i = 0; i < 4; i++) { for (var i = 0; i < 4; i++) {
vertexConsumer.addVertex(0, 0, 0).setColor(0x00ffffff).setUv(0, 0).setLight(LightTexture.FULL_BRIGHT); buffer.addVertex(0, 0, 0).setColor(0x00ffffff).setUv(0, 0).setLight(LightTexture.FULL_BRIGHT);
} }
} }

View File

@@ -1,49 +0,0 @@
// SPDX-FileCopyrightText: 2023 The CC: Tweaked Developers
//
// SPDX-License-Identifier: MPL-2.0
package dan200.computercraft.client.integration.emi;
import dan200.computercraft.api.turtle.TurtleSide;
import dan200.computercraft.shared.ModRegistry;
import dan200.computercraft.shared.integration.RecipeModHelpers;
import dan200.computercraft.shared.pocket.items.PocketComputerItem;
import dan200.computercraft.shared.turtle.items.TurtleItem;
import dev.emi.emi.api.EmiEntrypoint;
import dev.emi.emi.api.EmiPlugin;
import dev.emi.emi.api.EmiRegistry;
import dev.emi.emi.api.stack.Comparison;
import dev.emi.emi.api.stack.EmiStack;
import net.minecraft.client.Minecraft;
import net.minecraft.world.item.ItemStack;
import java.util.function.BiPredicate;
@EmiEntrypoint
public class EMIComputerCraft implements EmiPlugin {
@Override
public void register(EmiRegistry registry) {
registry.setDefaultComparison(ModRegistry.Items.TURTLE_NORMAL.get(), turtleComparison);
registry.setDefaultComparison(ModRegistry.Items.TURTLE_ADVANCED.get(), turtleComparison);
registry.setDefaultComparison(ModRegistry.Items.POCKET_COMPUTER_NORMAL.get(), pocketComparison);
registry.setDefaultComparison(ModRegistry.Items.POCKET_COMPUTER_ADVANCED.get(), pocketComparison);
for (var stack : RecipeModHelpers.getExtraStacks(Minecraft.getInstance().level.registryAccess())) {
registry.addEmiStack(EmiStack.of(stack));
}
}
private static final Comparison turtleComparison = compareStacks((left, right)
-> TurtleItem.getUpgrade(left, TurtleSide.LEFT) == TurtleItem.getUpgrade(right, TurtleSide.LEFT)
&& TurtleItem.getUpgrade(left, TurtleSide.RIGHT) == TurtleItem.getUpgrade(right, TurtleSide.RIGHT));
private static final Comparison pocketComparison = compareStacks((left, right) -> PocketComputerItem.getUpgrade(left) == PocketComputerItem.getUpgrade(right));
private static Comparison compareStacks(BiPredicate<ItemStack, ItemStack> test) {
return Comparison.of((left, right) -> {
ItemStack leftStack = left.getItemStack(), rightStack = right.getItemStack();
return leftStack.getItem() == rightStack.getItem() && test.test(leftStack, rightStack);
});
}
}

View File

@@ -142,10 +142,8 @@ public class CustomLecternRenderer implements BlockEntityRenderer<CustomLecternB
var marginX = ((LecternPocketModel.TERM_WIDTH / scale) - width) / 2; var marginX = ((LecternPocketModel.TERM_WIDTH / scale) - width) / 2;
var marginY = ((LecternPocketModel.TERM_HEIGHT / scale) - height) / 2; var marginY = ((LecternPocketModel.TERM_HEIGHT / scale) - height) / 2;
collector.submitCustomGeometry(poseStack, FixedWidthFontRenderer.TERMINAL_TEXT, (pose, buffer) -> { collector.submitCustomGeometry(poseStack, FixedWidthFontRenderer.TERMINAL_TEXT, (pose, buffer) ->
var quadEmitter = new FixedWidthFontRenderer.QuadEmitter(pose.pose(), buffer); FixedWidthFontRenderer.drawTerminal(pose.pose(), buffer, marginX, marginY, terminal, marginY, marginY, marginX, marginX));
FixedWidthFontRenderer.drawTerminal(quadEmitter, marginX, marginY, terminal, marginY, marginY, marginX, marginX);
});
} }
private enum Type { private enum Type {

View File

@@ -85,10 +85,8 @@ public final class PocketItemRenderer extends ItemMapLikeRenderer {
if (terminal == null) { if (terminal == null) {
FixedWidthFontRenderer.drawEmptyTerminal(transform, collector, 0, 0, width, height); FixedWidthFontRenderer.drawEmptyTerminal(transform, collector, 0, 0, width, height);
} else { } else {
collector.submitCustomGeometry(transform, FixedWidthFontRenderer.TERMINAL_TEXT, (pose, buffer) -> { collector.submitCustomGeometry(transform, FixedWidthFontRenderer.TERMINAL_TEXT, (pose, buffer) ->
var quadEmitter = new FixedWidthFontRenderer.QuadEmitter(pose.pose(), buffer); FixedWidthFontRenderer.drawTerminal(pose.pose(), buffer, MARGIN, MARGIN, terminal, MARGIN, MARGIN, MARGIN, MARGIN));
FixedWidthFontRenderer.drawTerminal(quadEmitter, MARGIN, MARGIN, terminal, MARGIN, MARGIN, MARGIN, MARGIN);
});
} }
transform.popPose(); transform.popPose();
@@ -162,7 +160,7 @@ public final class PocketItemRenderer extends ItemMapLikeRenderer {
private static void renderLight(PoseStack transform, SubmitNodeCollector render, int colour, int width, int height) { private static void renderLight(PoseStack transform, SubmitNodeCollector render, int colour, int width, int height) {
render.submitCustomGeometry(transform, FixedWidthFontRenderer.TERMINAL_TEXT, (pose, buffer) -> FixedWidthFontRenderer.drawQuad( render.submitCustomGeometry(transform, FixedWidthFontRenderer.TERMINAL_TEXT, (pose, buffer) -> FixedWidthFontRenderer.drawQuad(
new FixedWidthFontRenderer.QuadEmitter(pose.pose(), buffer), pose.pose(), buffer,
width - LIGHT_HEIGHT * 2, height + BORDER / 2.0f, 0.001f, LIGHT_HEIGHT * 2, LIGHT_HEIGHT, width - LIGHT_HEIGHT * 2, height + BORDER / 2.0f, 0.001f, LIGHT_HEIGHT * 2, LIGHT_HEIGHT,
ARGB.opaque(colour), LightTexture.FULL_BRIGHT ARGB.opaque(colour), LightTexture.FULL_BRIGHT
)); ));

View File

@@ -74,9 +74,9 @@ public final class PrintoutRenderer {
public static void drawText(PoseStack transform, MultiBufferSource bufferSource, int x, int y, int start, int light, TextBuffer[] text, TextBuffer[] colours) { public static void drawText(PoseStack transform, MultiBufferSource bufferSource, int x, int y, int start, int light, TextBuffer[] text, TextBuffer[] colours) {
var buffer = bufferSource.getBuffer(FixedWidthFontRenderer.TERMINAL_TEXT); var buffer = bufferSource.getBuffer(FixedWidthFontRenderer.TERMINAL_TEXT);
var emitter = FixedWidthFontRenderer.toVertexConsumer(transform, buffer);
for (var line = 0; line < LINES_PER_PAGE && line < text.length; line++) { for (var line = 0; line < LINES_PER_PAGE && line < text.length; line++) {
FixedWidthFontRenderer.drawString(emitter, FixedWidthFontRenderer.drawString(
transform.last().pose(), buffer,
x, y + line * FONT_HEIGHT, text[start + line], colours[start + line], x, y + line * FONT_HEIGHT, text[start + line], colours[start + line],
Palette.DEFAULT, light Palette.DEFAULT, light
); );
@@ -84,10 +84,10 @@ public final class PrintoutRenderer {
} }
public static void drawText(Matrix4f matrix4f, VertexConsumer buffer, int x, int y, int start, int light, List<PrintoutData.Line> lines) { public static void drawText(Matrix4f matrix4f, VertexConsumer buffer, int x, int y, int start, int light, List<PrintoutData.Line> lines) {
var emitter = new FixedWidthFontRenderer.QuadEmitter(matrix4f, buffer);
for (var line = 0; line < LINES_PER_PAGE && line < lines.size(); line++) { for (var line = 0; line < LINES_PER_PAGE && line < lines.size(); line++) {
var lineContents = lines.get(start + line); var lineContents = lines.get(start + line);
FixedWidthFontRenderer.drawString(emitter, FixedWidthFontRenderer.drawString(
matrix4f, buffer,
x, y + line * FONT_HEIGHT, x, y + line * FONT_HEIGHT,
new TextBuffer(lineContents.text()), new TextBuffer(lineContents.foreground()), new TextBuffer(lineContents.text()), new TextBuffer(lineContents.foreground()),
Palette.DEFAULT, light Palette.DEFAULT, light

View File

@@ -88,18 +88,14 @@ public class MonitorBlockEntityRenderer implements BlockEntityRenderer<MonitorBl
transform.scale((float) xScale, (float) -yScale, 1.0f); transform.scale((float) xScale, (float) -yScale, 1.0f);
var xMargin = (float) (MARGIN / xScale); var xMargin = (float) (MARGIN / xScale);
var yMagin = (float) (MARGIN / yScale); var yMargin = (float) (MARGIN / yScale);
collector.submitCustomGeometry(transform, FixedWidthFontRenderer.TERMINAL_TEXT, (pose, consumer) -> { collector.submitCustomGeometry(transform, FixedWidthFontRenderer.TERMINAL_TEXT, (pose, buffer) -> {
FixedWidthFontRenderer.drawTerminalBackground( FixedWidthFontRenderer.drawTerminalBackground(pose.pose(), buffer, 0, 0, terminal, yMargin, yMargin, xMargin, xMargin);
new FixedWidthFontRenderer.QuadEmitter(pose.pose(), consumer),
0, 0, terminal, yMagin, yMagin, xMargin, xMargin
);
}); });
collector.submitCustomGeometry(transform, FixedWidthFontRenderer.TERMINAL_TEXT_OFFSET, (pose, consumer) -> { collector.submitCustomGeometry(transform, FixedWidthFontRenderer.TERMINAL_TEXT_OFFSET, (pose, buffer) -> {
var sink = new FixedWidthFontRenderer.QuadEmitter(pose.pose(), consumer); FixedWidthFontRenderer.drawTerminalForeground(pose.pose(), buffer, 0, 0, terminal);
FixedWidthFontRenderer.drawTerminalForeground(sink, 0, 0, terminal); FixedWidthFontRenderer.drawCursor(pose.pose(), buffer, 0, 0, terminal);
FixedWidthFontRenderer.drawCursor(sink, 0, 0, terminal);
}); });
transform.popPose(); transform.popPose();

View File

@@ -68,7 +68,7 @@ public final class FixedWidthFontRenderer {
return 15 - Terminal.getColour(c, def); return 15 - Terminal.getColour(c, def);
} }
private static void drawChar(QuadEmitter emitter, float x, float y, int index, int colour, int light) { private static void drawChar(Matrix4f matrix, VertexConsumer buffer, float x, float y, int index, int colour, int light) {
// Short circuit to avoid the common case - the texture should be blank here after all. // Short circuit to avoid the common case - the texture should be blank here after all.
if (index == '\0' || index == ' ') return; if (index == '\0' || index == ' ') return;
@@ -79,30 +79,30 @@ public final class FixedWidthFontRenderer {
var yStart = 1 + row * (FONT_HEIGHT + 2); var yStart = 1 + row * (FONT_HEIGHT + 2);
quad( quad(
emitter, x, y, x + FONT_WIDTH, y + FONT_HEIGHT, 0, colour, matrix, buffer, x, y, x + FONT_WIDTH, y + FONT_HEIGHT, 0, colour,
xStart / WIDTH, yStart / WIDTH, (xStart + FONT_WIDTH) / WIDTH, (yStart + FONT_HEIGHT) / WIDTH, light xStart / WIDTH, yStart / WIDTH, (xStart + FONT_WIDTH) / WIDTH, (yStart + FONT_HEIGHT) / WIDTH, light
); );
} }
public static void drawQuad(QuadEmitter emitter, float x, float y, float z, float width, float height, int colour, int light) { public static void drawQuad(Matrix4f matrix, VertexConsumer buffer, float x, float y, float z, float width, float height, int colour, int light) {
quad(emitter, x, y, x + width, y + height, z, colour, BACKGROUND_START, BACKGROUND_START, BACKGROUND_END, BACKGROUND_END, light); quad(matrix, buffer, x, y, x + width, y + height, z, colour, BACKGROUND_START, BACKGROUND_START, BACKGROUND_END, BACKGROUND_END, light);
} }
private static void drawQuad(QuadEmitter emitter, float x, float y, float width, float height, Palette palette, char colourIndex, int light) { private static void drawQuad(Matrix4f matrix, VertexConsumer buffer, float x, float y, float width, float height, Palette palette, char colourIndex, int light) {
var colour = palette.getRenderColours(getColour(colourIndex, Colour.BLACK)); var colour = palette.getRenderColours(getColour(colourIndex, Colour.BLACK));
drawQuad(emitter, x, y, 0, width, height, colour, light); drawQuad(matrix, buffer, x, y, 0, width, height, colour, light);
} }
private static void drawBackground( private static void drawBackground(
QuadEmitter emitter, float x, float y, TextBuffer backgroundColour, Palette palette, Matrix4f matrix, VertexConsumer buffer, float x, float y, TextBuffer backgroundColour, Palette palette,
float leftMarginSize, float rightMarginSize, float height, int light float leftMarginSize, float rightMarginSize, float height, int light
) { ) {
if (leftMarginSize > 0) { if (leftMarginSize > 0) {
drawQuad(emitter, x - leftMarginSize, y, leftMarginSize, height, palette, backgroundColour.charAt(0), light); drawQuad(matrix, buffer, x - leftMarginSize, y, leftMarginSize, height, palette, backgroundColour.charAt(0), light);
} }
if (rightMarginSize > 0) { if (rightMarginSize > 0) {
drawQuad(emitter, x + backgroundColour.length() * FONT_WIDTH, y, rightMarginSize, height, palette, backgroundColour.charAt(backgroundColour.length() - 1), light); drawQuad(matrix, buffer, x + backgroundColour.length() * FONT_WIDTH, y, rightMarginSize, height, palette, backgroundColour.charAt(backgroundColour.length() - 1), light);
} }
// Batch together runs of identical background cells. // Batch together runs of identical background cells.
@@ -113,7 +113,7 @@ public final class FixedWidthFontRenderer {
if (colourIndex == blockColour) continue; if (colourIndex == blockColour) continue;
if (blockColour != '\0') { if (blockColour != '\0') {
drawQuad(emitter, x + blockStart * FONT_WIDTH, y, FONT_WIDTH * (i - blockStart), height, palette, blockColour, light); drawQuad(matrix, buffer, x + blockStart * FONT_WIDTH, y, FONT_WIDTH * (i - blockStart), height, palette, blockColour, light);
} }
blockColour = colourIndex; blockColour = colourIndex;
@@ -121,22 +121,22 @@ public final class FixedWidthFontRenderer {
} }
if (blockColour != '\0') { if (blockColour != '\0') {
drawQuad(emitter, x + blockStart * FONT_WIDTH, y, FONT_WIDTH * (backgroundColour.length() - blockStart), height, palette, blockColour, light); drawQuad(matrix, buffer, x + blockStart * FONT_WIDTH, y, FONT_WIDTH * (backgroundColour.length() - blockStart), height, palette, blockColour, light);
} }
} }
public static void drawString(QuadEmitter emitter, float x, float y, TextBuffer text, TextBuffer textColour, Palette palette, int light) { public static void drawString(Matrix4f matrix, VertexConsumer buffer, float x, float y, TextBuffer text, TextBuffer textColour, Palette palette, int light) {
for (var i = 0; i < text.length(); i++) { for (var i = 0; i < text.length(); i++) {
var colour = palette.getRenderColours(getColour(textColour.charAt(i), Colour.BLACK)); var colour = palette.getRenderColours(getColour(textColour.charAt(i), Colour.BLACK));
int index = text.charAt(i); int index = text.charAt(i);
if (index > 255) index = '?'; if (index > 255) index = '?';
drawChar(emitter, x + i * FONT_WIDTH, y, index, colour, light); drawChar(matrix, buffer, x + i * FONT_WIDTH, y, index, colour, light);
} }
} }
public static void drawTerminalForeground(QuadEmitter emitter, float x, float y, Terminal terminal) { public static void drawTerminalForeground(Matrix4f matrix, VertexConsumer buffer, float x, float y, Terminal terminal) {
var palette = terminal.getPalette(); var palette = terminal.getPalette();
var height = terminal.getHeight(); var height = terminal.getHeight();
@@ -144,14 +144,14 @@ public final class FixedWidthFontRenderer {
for (var i = 0; i < height; i++) { for (var i = 0; i < height; i++) {
var rowY = y + FONT_HEIGHT * i; var rowY = y + FONT_HEIGHT * i;
drawString( drawString(
emitter, x, rowY, terminal.getLine(i), terminal.getTextColourLine(i), matrix, buffer, x, rowY, terminal.getLine(i), terminal.getTextColourLine(i),
palette, LightTexture.FULL_BRIGHT palette, LightTexture.FULL_BRIGHT
); );
} }
} }
public static void drawTerminalBackground( public static void drawTerminalBackground(
QuadEmitter emitter, float x, float y, Terminal terminal, Matrix4f matrix, VertexConsumer buffer, float x, float y, Terminal terminal,
float topMarginSize, float bottomMarginSize, float leftMarginSize, float rightMarginSize float topMarginSize, float bottomMarginSize, float leftMarginSize, float rightMarginSize
) { ) {
var palette = terminal.getPalette(); var palette = terminal.getPalette();
@@ -159,12 +159,12 @@ public final class FixedWidthFontRenderer {
// Top and bottom margins // Top and bottom margins
drawBackground( drawBackground(
emitter, x, y - topMarginSize, terminal.getBackgroundColourLine(0), palette, matrix, buffer, x, y - topMarginSize, terminal.getBackgroundColourLine(0), palette,
leftMarginSize, rightMarginSize, topMarginSize, LightTexture.FULL_BRIGHT leftMarginSize, rightMarginSize, topMarginSize, LightTexture.FULL_BRIGHT
); );
drawBackground( drawBackground(
emitter, x, y + height * FONT_HEIGHT, terminal.getBackgroundColourLine(height - 1), palette, matrix, buffer, x, y + height * FONT_HEIGHT, terminal.getBackgroundColourLine(height - 1), palette,
leftMarginSize, rightMarginSize, bottomMarginSize, LightTexture.FULL_BRIGHT leftMarginSize, rightMarginSize, bottomMarginSize, LightTexture.FULL_BRIGHT
); );
@@ -172,7 +172,7 @@ public final class FixedWidthFontRenderer {
for (var i = 0; i < height; i++) { for (var i = 0; i < height; i++) {
var rowY = y + FONT_HEIGHT * i; var rowY = y + FONT_HEIGHT * i;
drawBackground( drawBackground(
emitter, x, rowY, terminal.getBackgroundColourLine(i), palette, matrix, buffer, x, rowY, terminal.getBackgroundColourLine(i), palette,
leftMarginSize, rightMarginSize, FONT_HEIGHT, LightTexture.FULL_BRIGHT leftMarginSize, rightMarginSize, FONT_HEIGHT, LightTexture.FULL_BRIGHT
); );
} }
@@ -186,55 +186,40 @@ public final class FixedWidthFontRenderer {
return cursorX >= 0 && cursorX < terminal.getWidth() && cursorY >= 0 && cursorY < terminal.getHeight(); return cursorX >= 0 && cursorX < terminal.getWidth() && cursorY >= 0 && cursorY < terminal.getHeight();
} }
public static void drawCursor(QuadEmitter emitter, float x, float y, Terminal terminal) { public static void drawCursor(Matrix4f matrix, VertexConsumer buffer, float x, float y, Terminal terminal) {
if (isCursorVisible(terminal) && FrameInfo.getGlobalCursorBlink()) { if (isCursorVisible(terminal) && FrameInfo.getGlobalCursorBlink()) {
var colour = terminal.getPalette().getRenderColours(15 - terminal.getTextColour()); var colour = terminal.getPalette().getRenderColours(15 - terminal.getTextColour());
drawChar(emitter, x + terminal.getCursorX() * FONT_WIDTH, y + terminal.getCursorY() * FONT_HEIGHT, '_', colour, LightTexture.FULL_BRIGHT); drawChar(matrix, buffer, x + terminal.getCursorX() * FONT_WIDTH, y + terminal.getCursorY() * FONT_HEIGHT, '_', colour, LightTexture.FULL_BRIGHT);
} }
} }
public static void drawTerminal( public static void drawTerminal(
QuadEmitter emitter, float x, float y, Terminal terminal, Matrix4f matrix, VertexConsumer buffer, float x, float y, Terminal terminal,
float topMarginSize, float bottomMarginSize, float leftMarginSize, float rightMarginSize float topMarginSize, float bottomMarginSize, float leftMarginSize, float rightMarginSize
) { ) {
drawTerminalBackground( drawTerminalBackground(
emitter, x, y, terminal, matrix, buffer, x, y, terminal,
topMarginSize, bottomMarginSize, leftMarginSize, rightMarginSize topMarginSize, bottomMarginSize, leftMarginSize, rightMarginSize
); );
// Render the foreground with a slight offset. By calling .translate() on the matrix itself, we're translating // Render the foreground with a slight offset. By calling .translate() on the matrix itself, we're translating
// in screen space, rather than in model/view space. // in screen space, rather than in model/view space.
// It's definitely not perfect, but better than z fighting! // It's definitely not perfect, but better than z fighting!
var transformBackup = new Matrix4f(emitter.poseMatrix()); var offsetMatrix = new Matrix4f(matrix).translate(new Vector3f(0, 0, Z_OFFSET));
emitter.poseMatrix().translate(new Vector3f(0, 0, Z_OFFSET));
drawTerminalForeground(emitter, x, y, terminal); drawTerminalForeground(offsetMatrix, buffer, x, y, terminal);
drawCursor(emitter, x, y, terminal); drawCursor(offsetMatrix, buffer, x, y, terminal);
emitter.poseMatrix().set(transformBackup);
} }
public static void drawEmptyTerminal(PoseStack transform, SubmitNodeCollector collector, float x, float y, float width, float height) { public static void drawEmptyTerminal(PoseStack transform, SubmitNodeCollector collector, float x, float y, float width, float height) {
collector.submitCustomGeometry(transform, FixedWidthFontRenderer.TERMINAL_TEXT, (pose, buffer) -> { collector.submitCustomGeometry(transform, FixedWidthFontRenderer.TERMINAL_TEXT, (pose, buffer) ->
var quadEmitter = new FixedWidthFontRenderer.QuadEmitter(pose.pose(), buffer); drawQuad(pose.pose(), buffer, x, y, 0, width, height, BLACK, LightTexture.FULL_BRIGHT));
drawQuad(quadEmitter, x, y, 0, width, height, BLACK, LightTexture.FULL_BRIGHT);
});
} }
public record QuadEmitter(Matrix4f poseMatrix, VertexConsumer consumer) { private static void quad(Matrix4f matrix, VertexConsumer buffer, float x1, float y1, float x2, float y2, float z, int colour, float u1, float v1, float u2, float v2, int light) {
} buffer.addVertex(matrix, x1, y1, z).setColor(colour).setUv(u1, v1).setLight(light);
buffer.addVertex(matrix, x1, y2, z).setColor(colour).setUv(u1, v2).setLight(light);
public static QuadEmitter toVertexConsumer(PoseStack transform, VertexConsumer consumer) { buffer.addVertex(matrix, x2, y2, z).setColor(colour).setUv(u2, v2).setLight(light);
return new QuadEmitter(transform.last().pose(), consumer); buffer.addVertex(matrix, x2, y1, z).setColor(colour).setUv(u2, v1).setLight(light);
}
private static void quad(QuadEmitter c, float x1, float y1, float x2, float y2, float z, int colour, float u1, float v1, float u2, float v2, int light) {
var poseMatrix = c.poseMatrix();
var consumer = c.consumer();
consumer.addVertex(poseMatrix, x1, y1, z).setColor(colour).setUv(u1, v1).setLight(light);
consumer.addVertex(poseMatrix, x1, y2, z).setColor(colour).setUv(u1, v2).setLight(light);
consumer.addVertex(poseMatrix, x2, y2, z).setColor(colour).setUv(u2, v2).setLight(light);
consumer.addVertex(poseMatrix, x2, y1, z).setColor(colour).setUv(u2, v1).setLight(light);
} }
} }

View File

@@ -74,7 +74,6 @@ configurations {
} }
dependencies { dependencies {
clientCompileOnly(variantOf(libs.emi) { classifier("api") })
modCompileOnly(libs.bundles.externalMods.fabric.compile) { modCompileOnly(libs.bundles.externalMods.fabric.compile) {
exclude("net.fabricmc", "fabric-loader") exclude("net.fabricmc", "fabric-loader")
exclude("net.fabricmc.fabric-api") exclude("net.fabricmc.fabric-api")

View File

@@ -31,9 +31,6 @@
], ],
"rei_client": [ "rei_client": [
"dan200.computercraft.client.integration.rei.REIComputerCraftClient" "dan200.computercraft.client.integration.rei.REIComputerCraftClient"
],
"emi": [
"dan200.computercraft.client.integration.emi.EMIComputerCraft"
] ]
}, },
"mixins": [ "mixins": [

View File

@@ -148,7 +148,6 @@ dependencies {
compileOnly(libs.jetbrainsAnnotations) compileOnly(libs.jetbrainsAnnotations)
annotationProcessorEverywhere(libs.autoService) annotationProcessorEverywhere(libs.autoService)
clientCompileOnly(variantOf(libs.emi) { classifier("api") })
compileOnly(libs.bundles.externalMods.forge.compile) compileOnly(libs.bundles.externalMods.forge.compile)
clientRuntimeOnly(libs.bundles.externalMods.forge.runtime) clientRuntimeOnly(libs.bundles.externalMods.forge.runtime)
compileOnly(libs.create.forge) { isTransitive = false } compileOnly(libs.create.forge) { isTransitive = false }

View File

@@ -11,6 +11,7 @@ import net.minecraft.world.MenuProvider;
import net.minecraft.world.entity.EntityDimensions; import net.minecraft.world.entity.EntityDimensions;
import net.minecraft.world.entity.Pose; import net.minecraft.world.entity.Pose;
import net.minecraft.world.entity.player.Player; import net.minecraft.world.entity.player.Player;
import net.minecraft.world.level.GameType;
import net.neoforged.neoforge.common.util.FakePlayer; import net.neoforged.neoforge.common.util.FakePlayer;
import org.jspecify.annotations.Nullable; import org.jspecify.annotations.Nullable;
@@ -22,6 +23,9 @@ class FakePlayerExt extends FakePlayer {
FakePlayerExt(ServerLevel serverLevel, GameProfile profile) { FakePlayerExt(ServerLevel serverLevel, GameProfile profile) {
super(serverLevel, profile); super(serverLevel, profile);
refreshDimensions(); refreshDimensions();
// Force the player to be in survival. Only needed for NF, as Fabric does this by default.
// TODO: Remove once https://github.com/neoforged/NeoForge/pull/2730 is merged.
gameMode.changeGameModeForPlayer(GameType.SURVIVAL);
} }
@Override @Override