- Add Axes class to (temporarily?) replace old mojmath Vector3f.$axis.
- Add helper for getting a random float between 2 values.
- Implement diffuse light formula.
- Fix debug overlay event.
- Try and fix ChunkRebuildHooksMixin but the first parameter isn't
  visible. Hopefully stubbing in Object will compile later.
This commit is contained in:
Jozufozu 2023-11-23 11:42:11 -08:00
parent 99be0ad281
commit 7bc6a7559a
11 changed files with 91 additions and 50 deletions

View file

@ -36,10 +36,12 @@ import com.jozufozu.flywheel.vanilla.VanillaVisuals;
import com.mojang.logging.LogUtils; import com.mojang.logging.LogUtils;
import net.minecraft.client.Minecraft; import net.minecraft.client.Minecraft;
import net.minecraft.commands.synchronization.ArgumentTypeInfos;
import net.minecraft.commands.synchronization.SingletonArgumentInfo;
import net.minecraft.core.Vec3i; import net.minecraft.core.Vec3i;
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.RenderGameOverlayEvent; import net.minecraftforge.client.event.CustomizeGuiOverlayEvent;
import net.minecraftforge.common.MinecraftForge; import net.minecraftforge.common.MinecraftForge;
import net.minecraftforge.event.level.LevelEvent; import net.minecraftforge.event.level.LevelEvent;
import net.minecraftforge.eventbus.api.IEventBus; import net.minecraftforge.eventbus.api.IEventBus;
@ -72,8 +74,8 @@ public class Flywheel {
FlwConfig.get().registerSpecs(modLoadingContext); FlwConfig.get().registerSpecs(modLoadingContext);
modLoadingContext.registerExtensionPoint(IExtensionPoint.DisplayTest.class, () -> new IExtensionPoint.DisplayTest( modLoadingContext.registerExtensionPoint(IExtensionPoint.DisplayTest.class, () -> new IExtensionPoint.DisplayTest(
() -> NetworkConstants.IGNORESERVERONLY, () -> "any",
(serverVersion, isNetwork) -> isNetwork (serverVersion, isNetwork) -> true
)); ));
DistExecutor.unsafeRunWhenOn(Dist.CLIENT, () -> () -> Flywheel.clientInit(forgeEventBus, modEventBus)); DistExecutor.unsafeRunWhenOn(Dist.CLIENT, () -> () -> Flywheel.clientInit(forgeEventBus, modEventBus));
@ -128,14 +130,15 @@ public class Flywheel {
RegistryImpl.freezeAll(); RegistryImpl.freezeAll();
IdRegistryImpl.freezeAll(); IdRegistryImpl.freezeAll();
ArgumentTypes.register(rl("backend").toString(), BackendArgument.class, new EmptyArgumentSerializer<>(() -> BackendArgument.INSTANCE)); ArgumentTypeInfos.registerByClass(BackendArgument.class, SingletonArgumentInfo.contextFree(() -> BackendArgument.INSTANCE));
} }
private static void addDebugInfo(RenderGameOverlayEvent.Text event) { private static void addDebugInfo(CustomizeGuiOverlayEvent.DebugText event) {
Minecraft mc = Minecraft.getInstance(); Minecraft mc = Minecraft.getInstance();
if (!mc.options.renderDebug) { // FIXME: do we need this check anymore?
return; // if (!mc.options.renderDebug) {
} // return;
// }
ArrayList<String> info = event.getRight(); ArrayList<String> info = event.getRight();
info.add(""); info.add("");

View file

@ -166,7 +166,7 @@ public final class Materials {
return new GlStateShard( return new GlStateShard(
() -> { () -> {
GlTextureUnit.T0.makeActive(); GlTextureUnit.T0.makeActive();
RenderSystem.enableTexture(); // FIXME: I think it got removed RenderSystem.enableTexture();
AbstractTexture texture = Minecraft.getInstance().getTextureManager().getTexture(loc); AbstractTexture texture = Minecraft.getInstance().getTextureManager().getTexture(loc);
texture.setFilter(blur, mipmap); texture.setFilter(blur, mipmap);
RenderSystem.setShaderTexture(0, texture.getId()); RenderSystem.setShaderTexture(0, texture.getId());

View file

@ -4,6 +4,8 @@ import org.joml.Math;
import org.joml.Matrix4f; import org.joml.Matrix4f;
import org.lwjgl.system.MemoryUtil; import org.lwjgl.system.MemoryUtil;
import net.minecraft.util.RandomSource;
public final class MoreMath { public final class MoreMath {
public static int align16(int numToRound) { public static int align16(int numToRound) {
return (numToRound + 16 - 1) & -16; return (numToRound + 16 - 1) & -16;
@ -50,6 +52,10 @@ public final class MoreMath {
} }
} }
public static float nextFloat(RandomSource rs, float min, float max) {
return rs.nextFloat() * (max - min) + min;
}
/** /**
* Writes the frustum planes of the given projection matrix to the given buffer.<p> * Writes the frustum planes of the given projection matrix to the given buffer.<p>
* Uses a different format that is friendly towards an optimized instruction-parallel * Uses a different format that is friendly towards an optimized instruction-parallel

View file

@ -1,7 +1,5 @@
package com.jozufozu.flywheel.lib.math; package com.jozufozu.flywheel.lib.math;
import net.minecraftforge.client.model.pipeline.LightUtil;
public final class RenderMath { public final class RenderMath {
/** /**
* Convert a signed byte into a signed, normalized float. * Convert a signed byte into a signed, normalized float.
@ -40,7 +38,8 @@ public final class RenderMath {
if (!shaded) { if (!shaded) {
return 1f; return 1f;
} }
return LightUtil.diffuseLight(x, y, z); // FIXME: once we compile make sure this is correct.
return Math.min(x * x + y * y * (3f + y) + z, 1f);
} }
public static float diffuseLightNether(float x, float y, float z, boolean shaded) { public static float diffuseLightNether(float x, float y, float z, boolean shaded) {

View file

@ -2,7 +2,9 @@ package com.jozufozu.flywheel.lib.transform;
import org.joml.AxisAngle4f; import org.joml.AxisAngle4f;
import org.joml.Quaternionf; import org.joml.Quaternionf;
import org.joml.Vector3f; import org.joml.Vector3fc;
import com.jozufozu.flywheel.lib.util.Axes;
import net.minecraft.core.Direction; import net.minecraft.core.Direction;
@ -17,44 +19,47 @@ public interface Rotate<Self> {
} }
default Self rotate(double angle, Direction.Axis axis) { default Self rotate(double angle, Direction.Axis axis) {
Vector3f vec = Axes.Axis vec = switch (axis) {
axis == Direction.Axis.X ? Vector3f.XP : axis == Direction.Axis.Y ? Vector3f.YP : Vector3f.ZP; case X -> Axes.XP;
return multiply(vec, angle); case Y -> Axes.YP;
case Z -> Axes.ZP;
};
return multiply(vec.vec(), angle);
} }
default Self rotateX(double angle) { default Self rotateX(double angle) {
return multiply(Vector3f.XP, angle); return multiply(Axes.XP.vec(), angle);
} }
default Self rotateY(double angle) { default Self rotateY(double angle) {
return multiply(Vector3f.YP, angle); return multiply(Axes.YP.vec(), angle);
} }
default Self rotateZ(double angle) { default Self rotateZ(double angle) {
return multiply(Vector3f.ZP, angle); return multiply(Axes.ZP.vec(), angle);
} }
default Self rotateXRadians(double angle) { default Self rotateXRadians(double angle) {
return multiplyRadians(Vector3f.XP, angle); return multiplyRadians(Axes.XP.vec(), angle);
} }
default Self rotateYRadians(double angle) { default Self rotateYRadians(double angle) {
return multiplyRadians(Vector3f.YP, angle); return multiplyRadians(Axes.YP.vec(), angle);
} }
default Self rotateZRadians(double angle) { default Self rotateZRadians(double angle) {
return multiplyRadians(Vector3f.ZP, angle); return multiplyRadians(Axes.ZP.vec(), angle);
} }
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
default Self multiply(Vector3f axis, double angle) { default Self multiply(Vector3fc axis, double angle) {
if (angle == 0) if (angle == 0)
return (Self) this; return (Self) this;
return multiply(axis.rotationDegrees((float) angle)); return multiplyRadians(axis, Math.toRadians(angle));
} }
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
default Self multiplyRadians(Vector3f axis, double angle) { default Self multiplyRadians(Vector3fc axis, double angle) {
if (angle == 0) if (angle == 0)
return (Self) this; return (Self) this;
return multiply(new Quaternionf(new AxisAngle4f((float) angle, axis))); return multiply(new Quaternionf(new AxisAngle4f((float) angle, axis)));
@ -63,12 +68,12 @@ public interface Rotate<Self> {
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
default Self rotateToFace(Direction facing) { default Self rotateToFace(Direction facing) {
switch (facing) { switch (facing) {
case SOUTH -> multiply(Vector3f.YP.rotationDegrees(180)); case SOUTH -> multiply(Axes.YP.rotationDegrees(180));
case WEST -> multiply(Vector3f.YP.rotationDegrees(90)); case WEST -> multiply(Axes.YP.rotationDegrees(90));
case NORTH -> multiply(Vector3f.YP.rotationDegrees(0)); case NORTH -> multiply(Axes.YP.rotationDegrees(0));
case EAST -> multiply(Vector3f.YP.rotationDegrees(270)); case EAST -> multiply(Axes.YP.rotationDegrees(270));
case UP -> multiply(Vector3f.XP.rotationDegrees(90)); case UP -> multiply(Axes.XP.rotationDegrees(90));
case DOWN -> multiply(Vector3f.XN.rotationDegrees(90)); case DOWN -> multiply(Axes.XN.rotationDegrees(90));
} }
return (Self) this; return (Self) this;
} }

View file

@ -0,0 +1,25 @@
package com.jozufozu.flywheel.lib.util;
import org.joml.Quaternionf;
import org.joml.Vector3f;
import org.joml.Vector3fc;
public class Axes {
public static Axis XP = new Axis(new Vector3f(1, 0, 0));
public static Axis YP = new Axis(new Vector3f(0, 1, 0));
public static Axis ZP = new Axis(new Vector3f(0, 0, 1));
public static Axis XN = new Axis(new Vector3f(-1, 0, 0));
public static Axis YN = new Axis(new Vector3f(0, -1, 0));
public static Axis ZN = new Axis(new Vector3f(0, 0, -1));
public record Axis(Vector3fc vec) {
public Quaternionf rotation(float radians) {
return new Quaternionf().setAngleAxis(radians, vec.x(), vec.y(), vec.z());
}
public Quaternionf rotationDegrees(float degrees) {
return rotation((float) Math.toRadians(degrees));
}
}
}

View file

@ -9,14 +9,13 @@ import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
import com.jozufozu.flywheel.impl.visualization.VisualizationHelper; import com.jozufozu.flywheel.impl.visualization.VisualizationHelper;
import net.minecraft.client.renderer.chunk.ChunkRenderDispatcher;
import net.minecraft.world.level.block.entity.BlockEntity; import net.minecraft.world.level.block.entity.BlockEntity;
@Mixin(targets = "net.minecraft.client.renderer.chunk.ChunkRenderDispatcher$RenderChunk$RebuildTask") @Mixin(targets = "net.minecraft.client.renderer.chunk.SectionRenderDispatcher$RenderSection$RebuildTask")
public class ChunkRebuildHooksMixin { public class ChunkRebuildHooksMixin {
@Inject(method = "handleBlockEntity(Lnet/minecraft/client/renderer/chunk/ChunkRenderDispatcher$CompiledChunk;Ljava/util/Set;Lnet/minecraft/world/level/block/entity/BlockEntity;)V", at = @At("HEAD"), cancellable = true) @Inject(method = "handleBlockEntity(Lnet/minecraft/client/renderer/chunk/SectionRenderDispatcher$RenderSection$RebuildTask$CompileResults;Lnet/minecraft/world/level/block/entity/BlockEntity;)V", at = @At("HEAD"), cancellable = true)
private void flywheel$tryAddBlockEntity(ChunkRenderDispatcher.CompiledChunk compiledChunk, Set<BlockEntity> globalBlockEntities, BlockEntity blockEntity, CallbackInfo ci) { private <E extends BlockEntity> void flywheel$tryAddBlockEntity(Object pCompileResults, E pBlockEntity, CallbackInfo ci) {
if (VisualizationHelper.tryAddBlockEntity(blockEntity)) { if (VisualizationHelper.tryAddBlockEntity(pBlockEntity)) {
ci.cancel(); ci.cancel();
} }
} }

View file

@ -19,6 +19,7 @@ import com.jozufozu.flywheel.lib.material.Materials;
import com.jozufozu.flywheel.lib.model.ModelCache; import com.jozufozu.flywheel.lib.model.ModelCache;
import com.jozufozu.flywheel.lib.model.SimpleModel; import com.jozufozu.flywheel.lib.model.SimpleModel;
import com.jozufozu.flywheel.lib.model.part.ModelPartConverter; import com.jozufozu.flywheel.lib.model.part.ModelPartConverter;
import com.jozufozu.flywheel.lib.util.Axes;
import com.jozufozu.flywheel.lib.util.Pair; import com.jozufozu.flywheel.lib.util.Pair;
import com.jozufozu.flywheel.lib.visual.AbstractBlockEntityVisual; import com.jozufozu.flywheel.lib.visual.AbstractBlockEntityVisual;
@ -60,7 +61,7 @@ public class ChestVisual<T extends BlockEntity & LidBlockEntity> extends Abstrac
private ChestType chestType; private ChestType chestType;
private Material texture; private Material texture;
private Quaternionf baseRotation; private final Quaternionf baseRotation = new Quaternionf();
private Float2FloatFunction lidProgress; private Float2FloatFunction lidProgress;
private float lastProgress = Float.NaN; private float lastProgress = Float.NaN;
@ -81,13 +82,13 @@ public class ChestVisual<T extends BlockEntity & LidBlockEntity> extends Abstrac
Block block = blockState.getBlock(); Block block = blockState.getBlock();
if (block instanceof AbstractChestBlock<?> chestBlock) { if (block instanceof AbstractChestBlock<?> chestBlock) {
float horizontalAngle = blockState.getValue(ChestBlock.FACING).toYRot(); float horizontalAngle = blockState.getValue(ChestBlock.FACING).toYRot();
baseRotation = Vector3f.YP.rotationDegrees(-horizontalAngle); baseRotation.setAngleAxis(Math.toRadians(-horizontalAngle), 0, 1, 0);
bottom.setRotation(baseRotation); bottom.setRotation(baseRotation);
DoubleBlockCombiner.NeighborCombineResult<? extends ChestBlockEntity> wrapper = chestBlock.combine(blockState, level, pos, true); DoubleBlockCombiner.NeighborCombineResult<? extends ChestBlockEntity> wrapper = chestBlock.combine(blockState, level, pos, true);
lidProgress = wrapper.apply(ChestBlock.opennessCombiner(blockEntity)); lidProgress = wrapper.apply(ChestBlock.opennessCombiner(blockEntity));
} else { } else {
baseRotation = Quaternion.ONE; baseRotation.identity();
lidProgress = $ -> 0f; lidProgress = $ -> 0f;
} }

View file

@ -13,6 +13,7 @@ import com.jozufozu.flywheel.lib.model.ModelHolder;
import com.jozufozu.flywheel.lib.model.Models; import com.jozufozu.flywheel.lib.model.Models;
import com.jozufozu.flywheel.lib.model.SimpleModel; import com.jozufozu.flywheel.lib.model.SimpleModel;
import com.jozufozu.flywheel.lib.model.part.ModelPartConverter; import com.jozufozu.flywheel.lib.model.part.ModelPartConverter;
import com.jozufozu.flywheel.lib.util.Axes;
import com.jozufozu.flywheel.lib.visual.AbstractEntityVisual; import com.jozufozu.flywheel.lib.visual.AbstractEntityVisual;
import com.mojang.blaze3d.vertex.PoseStack; import com.mojang.blaze3d.vertex.PoseStack;
@ -142,8 +143,8 @@ public class MinecartVisual<T extends AbstractMinecart> extends AbstractEntityVi
} }
stack.translate(0.0D, 0.375D, 0.0D); stack.translate(0.0D, 0.375D, 0.0D);
stack.mulPose(Vector3f.YP.rotationDegrees(180 - yaw)); stack.mulPose(Axes.YP.rotationDegrees(180 - yaw));
stack.mulPose(Vector3f.ZP.rotationDegrees(-pitch)); stack.mulPose(Axes.ZP.rotationDegrees(-pitch));
float hurtTime = entity.getHurtTime() - partialTick; float hurtTime = entity.getHurtTime() - partialTick;
float damage = entity.getDamage() - partialTick; float damage = entity.getDamage() - partialTick;
@ -153,7 +154,7 @@ public class MinecartVisual<T extends AbstractMinecart> extends AbstractEntityVi
} }
if (hurtTime > 0) { if (hurtTime > 0) {
stack.mulPose(Vector3f.XP.rotationDegrees(Mth.sin(hurtTime) * hurtTime * damage / 10.0F * (float) entity.getHurtDir())); stack.mulPose(Axes.XP.rotationDegrees(Mth.sin(hurtTime) * hurtTime * damage / 10.0F * (float) entity.getHurtDir()));
} }
int displayOffset = entity.getDisplayOffset(); int displayOffset = entity.getDisplayOffset();
@ -161,7 +162,7 @@ public class MinecartVisual<T extends AbstractMinecart> extends AbstractEntityVi
stack.pushPose(); stack.pushPose();
stack.scale(0.75F, 0.75F, 0.75F); stack.scale(0.75F, 0.75F, 0.75F);
stack.translate(-0.5D, (float) (displayOffset - 8) / 16, 0.5D); stack.translate(-0.5D, (float) (displayOffset - 8) / 16, 0.5D);
stack.mulPose(Vector3f.YP.rotationDegrees(90)); stack.mulPose(Axes.YP.rotationDegrees(90));
contents.setTransform(stack); contents.setTransform(stack);
stack.popPose(); stack.popPose();
} }

View file

@ -16,6 +16,7 @@ import com.jozufozu.flywheel.lib.model.ModelCache;
import com.jozufozu.flywheel.lib.model.SimpleModel; import com.jozufozu.flywheel.lib.model.SimpleModel;
import com.jozufozu.flywheel.lib.model.part.ModelPartConverter; import com.jozufozu.flywheel.lib.model.part.ModelPartConverter;
import com.jozufozu.flywheel.lib.transform.TransformStack; import com.jozufozu.flywheel.lib.transform.TransformStack;
import com.jozufozu.flywheel.lib.util.Axes;
import com.jozufozu.flywheel.lib.visual.AbstractBlockEntityVisual; import com.jozufozu.flywheel.lib.visual.AbstractBlockEntityVisual;
import com.mojang.blaze3d.vertex.PoseStack; import com.mojang.blaze3d.vertex.PoseStack;
@ -102,7 +103,7 @@ public class ShulkerBoxVisual extends AbstractBlockEntityVisual<ShulkerBoxBlockE
} }
lastProgress = progress; lastProgress = progress;
Quaternionf spin = Vector3f.YP.rotationDegrees(270.0f * progress); Quaternionf spin = Axes.YP.rotationDegrees(270.0f * progress);
TransformStack.cast(stack) TransformStack.cast(stack)
.pushPose() .pushPose()

View file

@ -17,6 +17,7 @@ import com.jozufozu.flywheel.api.visualization.VisualizationContext;
import com.jozufozu.flywheel.api.visualization.VisualizationManager; import com.jozufozu.flywheel.api.visualization.VisualizationManager;
import com.jozufozu.flywheel.lib.instance.InstanceTypes; import com.jozufozu.flywheel.lib.instance.InstanceTypes;
import com.jozufozu.flywheel.lib.instance.TransformedInstance; import com.jozufozu.flywheel.lib.instance.TransformedInstance;
import com.jozufozu.flywheel.lib.math.MoreMath;
import com.jozufozu.flywheel.lib.model.Models; import com.jozufozu.flywheel.lib.model.Models;
import com.jozufozu.flywheel.lib.task.ForEachPlan; import com.jozufozu.flywheel.lib.task.ForEachPlan;
@ -88,9 +89,9 @@ public class ExampleEffect implements Effect {
Vec3 playerPos = player.position(); Vec3 playerPos = player.position();
var x = (float) (playerPos.x + level.random.nextFloat(-20, 20)); var x = (float) (playerPos.x + MoreMath.nextFloat(level.random, -20, 20));
var y = (float) (playerPos.y + level.random.nextFloat(0, 5)); var y = (float) (playerPos.y + MoreMath.nextFloat(level.random, 0, 5));
var z = (float) (playerPos.z + level.random.nextFloat(-20, 20)); var z = (float) (playerPos.z + MoreMath.nextFloat(level.random, -20, 20));
ExampleEffect effect = new ExampleEffect(level, new Vector3f(x, y, z)); ExampleEffect effect = new ExampleEffect(level, new Vector3f(x, y, z));
ALL_EFFECTS.add(effect); ALL_EFFECTS.add(effect);
@ -111,9 +112,9 @@ public class ExampleEffect implements Effect {
this.boids = new ArrayList<>(VISUAL_COUNT); this.boids = new ArrayList<>(VISUAL_COUNT);
for (int i = 0; i < VISUAL_COUNT; i++) { for (int i = 0; i < VISUAL_COUNT; i++) {
var x = targetPoint.x + level.random.nextFloat(-SPAWN_RADIUS, SPAWN_RADIUS); var x = targetPoint.x + MoreMath.nextFloat(level.random, -SPAWN_RADIUS, SPAWN_RADIUS);
var y = targetPoint.y + level.random.nextFloat(-SPAWN_RADIUS, SPAWN_RADIUS); var y = targetPoint.y + MoreMath.nextFloat(level.random, -SPAWN_RADIUS, SPAWN_RADIUS);
var z = targetPoint.z + level.random.nextFloat(-SPAWN_RADIUS, SPAWN_RADIUS); var z = targetPoint.z + MoreMath.nextFloat(level.random, -SPAWN_RADIUS, SPAWN_RADIUS);
Boid boid = new Boid(x, y, z); Boid boid = new Boid(x, y, z);
boids.add(boid); boids.add(boid);