- Visuals must manually call setChanged on Instances.
- Decreases the extent of resource contention and makes what's going on
  more explicit.
- Remove self type parameter from FlatLit, I don't think it was ever
  needed.
This commit is contained in:
Jozufozu 2023-12-08 14:35:25 -08:00
parent cbbd2bfdf8
commit f98b8e11b8
9 changed files with 45 additions and 55 deletions

View file

@ -5,7 +5,7 @@ import com.jozufozu.flywheel.api.instance.InstanceType;
import net.minecraft.client.renderer.LightTexture; import net.minecraft.client.renderer.LightTexture;
public abstract class ColoredLitInstance extends AbstractInstance implements FlatLit<ColoredLitInstance> { public abstract class ColoredLitInstance extends AbstractInstance implements FlatLit {
public byte blockLight; public byte blockLight;
public byte skyLight; public byte skyLight;
@ -21,14 +21,12 @@ public abstract class ColoredLitInstance extends AbstractInstance implements Fla
@Override @Override
public ColoredLitInstance setBlockLight(int blockLight) { public ColoredLitInstance setBlockLight(int blockLight) {
this.blockLight = (byte) blockLight; this.blockLight = (byte) blockLight;
setChanged();
return this; return this;
} }
@Override @Override
public ColoredLitInstance setSkyLight(int skyLight) { public ColoredLitInstance setSkyLight(int skyLight) {
this.skyLight = (byte) skyLight; this.skyLight = (byte) skyLight;
setChanged();
return this; return this;
} }
@ -62,7 +60,6 @@ public abstract class ColoredLitInstance extends AbstractInstance implements Fla
this.r = r; this.r = r;
this.g = g; this.g = g;
this.b = b; this.b = b;
setChanged();
return this; return this;
} }
@ -71,7 +68,6 @@ public abstract class ColoredLitInstance extends AbstractInstance implements Fla
this.g = g; this.g = g;
this.b = b; this.b = b;
this.a = a; this.a = a;
setChanged();
return this; return this;
} }
} }

View file

@ -11,29 +11,27 @@ import net.minecraft.world.level.LightLayer;
* if they wish to make use of Flywheel's provided light update methods. * if they wish to make use of Flywheel's provided light update methods.
* <p> * <p>
* This only covers flat lighting, smooth lighting is still TODO. * This only covers flat lighting, smooth lighting is still TODO.
*
* @param <I> The name of the class that implements this interface.
*/ */
public interface FlatLit<I extends Instance & FlatLit<I>> { public interface FlatLit extends Instance {
/** /**
* @param blockLight An integer in the range [0, 15] representing the * @param blockLight An integer in the range [0, 15] representing the
* amount of block light this instance should receive. * amount of block light this instance should receive.
* @return {@code this} * @return {@code this}
*/ */
I setBlockLight(int blockLight); FlatLit setBlockLight(int blockLight);
/** /**
* @param skyLight An integer in the range [0, 15] representing the * @param skyLight An integer in the range [0, 15] representing the
* amount of sky light this instance should receive. * amount of sky light this instance should receive.
* @return {@code this} * @return {@code this}
*/ */
I setSkyLight(int skyLight); FlatLit setSkyLight(int skyLight);
default I setLight(int blockLight, int skyLight) { default FlatLit setLight(int blockLight, int skyLight) {
return setBlockLight(blockLight).setSkyLight(skyLight); return setBlockLight(blockLight).setSkyLight(skyLight);
} }
default I updateLight(BlockAndTintGetter level, BlockPos pos) { default FlatLit updateLight(BlockAndTintGetter level, BlockPos pos) {
return setLight(level.getBrightness(LightLayer.BLOCK, pos), level.getBrightness(LightLayer.SKY, pos)); return setLight(level.getBrightness(LightLayer.BLOCK, pos), level.getBrightness(LightLayer.SKY, pos));
} }

View file

@ -26,25 +26,21 @@ public class OrientedInstance extends ColoredLitInstance implements Rotate<Orien
@Override @Override
public OrientedInstance rotate(Quaternionf quaternion) { public OrientedInstance rotate(Quaternionf quaternion) {
rotation.mul(quaternion); rotation.mul(quaternion);
setChanged();
return this; return this;
} }
public OrientedInstance setRotation(Quaternionf q) { public OrientedInstance setRotation(Quaternionf q) {
rotation.set(q); rotation.set(q);
setChanged();
return this; return this;
} }
public OrientedInstance setRotation(float x, float y, float z, float w) { public OrientedInstance setRotation(float x, float y, float z, float w) {
rotation.set(x, y, z, w); rotation.set(x, y, z, w);
setChanged();
return this; return this;
} }
public OrientedInstance resetRotation() { public OrientedInstance resetRotation() {
rotation.identity(); rotation.identity();
setChanged();
return this; return this;
} }
@ -52,7 +48,6 @@ public class OrientedInstance extends ColoredLitInstance implements Rotate<Orien
pivotX = x; pivotX = x;
pivotY = y; pivotY = y;
pivotZ = z; pivotZ = z;
setChanged();
return this; return this;
} }
@ -68,7 +63,6 @@ public class OrientedInstance extends ColoredLitInstance implements Rotate<Orien
posX += x; posX += x;
posY += y; posY += y;
posZ += z; posZ += z;
setChanged();
return this; return this;
} }
@ -76,7 +70,6 @@ public class OrientedInstance extends ColoredLitInstance implements Rotate<Orien
posX = x; posX = x;
posY = y; posY = y;
posZ = z; posZ = z;
setChanged();
return this; return this;
} }

View file

@ -25,14 +25,12 @@ public class TransformedInstance extends ColoredLitInstance implements Transform
@Override @Override
public TransformedInstance mulPose(Matrix4f pose) { public TransformedInstance mulPose(Matrix4f pose) {
this.model.mul(pose); this.model.mul(pose);
setChanged();
return this; return this;
} }
@Override @Override
public TransformedInstance mulNormal(Matrix3f normal) { public TransformedInstance mulNormal(Matrix3f normal) {
this.normal.mul(normal); this.normal.mul(normal);
setChanged();
return this; return this;
} }
@ -53,7 +51,6 @@ public class TransformedInstance extends ColoredLitInstance implements Transform
float invZ = 1.0f / z; float invZ = 1.0f / z;
float f = Mth.fastInvCubeRoot(Math.abs(invX * invY * invZ)); float f = Mth.fastInvCubeRoot(Math.abs(invX * invY * invZ));
normal.scale(f * invX, f * invY, f * invZ); normal.scale(f * invX, f * invY, f * invZ);
setChanged();
return this; return this;
} }
@ -61,14 +58,12 @@ public class TransformedInstance extends ColoredLitInstance implements Transform
public TransformedInstance rotate(Quaternionf quaternion) { public TransformedInstance rotate(Quaternionf quaternion) {
model.rotate(quaternion); model.rotate(quaternion);
normal.rotate(quaternion); normal.rotate(quaternion);
setChanged();
return this; return this;
} }
@Override @Override
public TransformedInstance translate(double x, double y, double z) { public TransformedInstance translate(double x, double y, double z) {
model.translate((float) x, (float) y, (float) z); model.translate((float) x, (float) y, (float) z);
setChanged();
return this; return this;
} }
@ -77,7 +72,6 @@ public class TransformedInstance extends ColoredLitInstance implements Transform
.pose()); .pose());
this.normal.set(stack.last() this.normal.set(stack.last()
.normal()); .normal());
setChanged();
return this; return this;
} }
@ -91,14 +85,12 @@ public class TransformedInstance extends ColoredLitInstance implements Transform
public TransformedInstance setEmptyTransform() { public TransformedInstance setEmptyTransform() {
model.set(ZERO_MATRIX_4f); model.set(ZERO_MATRIX_4f);
normal.set(ZERO_MATRIX_3f); normal.set(ZERO_MATRIX_3f);
setChanged();
return this; return this;
} }
public TransformedInstance loadIdentity() { public TransformedInstance loadIdentity() {
model.identity(); model.identity();
normal.identity(); normal.identity();
setChanged();
return this; return this;
} }
} }

View file

@ -45,8 +45,8 @@ public abstract class AbstractVisual implements Visual, LightListener {
/** /**
* Called after initialization and when a light update occurs in the world. * Called after initialization and when a light update occurs in the world.
* * <br>
* <br> If your instances need it, update light here. * If your instances need it, update light here.
*/ */
public void updateLight() { public void updateLight() {
} }
@ -73,21 +73,25 @@ public abstract class AbstractVisual implements Visual, LightListener {
return deleted; return deleted;
} }
protected void relight(BlockPos pos, FlatLit<?>... instances) { protected void relight(BlockPos pos, FlatLit... instances) {
relight(level.getBrightness(LightLayer.BLOCK, pos), level.getBrightness(LightLayer.SKY, pos), instances); relight(level.getBrightness(LightLayer.BLOCK, pos), level.getBrightness(LightLayer.SKY, pos), instances);
} }
protected void relight(int block, int sky, FlatLit<?>... instances) { protected void relight(int block, int sky, FlatLit... instances) {
for (FlatLit<?> instance : instances) { for (FlatLit instance : instances) {
instance.setLight(block, sky); instance.setLight(block, sky);
instance.handle()
.setChanged();
} }
} }
protected <L extends FlatLit<?>> void relight(BlockPos pos, Stream<L> instances) { protected void relight(BlockPos pos, Stream<? extends FlatLit> instances) {
relight(level.getBrightness(LightLayer.BLOCK, pos), level.getBrightness(LightLayer.SKY, pos), instances); relight(level.getBrightness(LightLayer.BLOCK, pos), level.getBrightness(LightLayer.SKY, pos), instances);
} }
protected <L extends FlatLit<?>> void relight(int block, int sky, Stream<L> instances) { protected void relight(int block, int sky, Stream<? extends FlatLit> instances) {
instances.forEach(model -> model.setLight(block, sky)); instances.forEach(model -> model.setLight(block, sky)
.handle()
.setChanged());
} }
} }

View file

@ -79,6 +79,8 @@ public class BellVisual extends AbstractBlockEntityVisual<BellBlockEntity> imple
} else { } else {
bell.setRotation(new Quaternionf()); bell.setRotation(new Quaternionf());
} }
bell.setChanged();
} }
@Override @Override

View file

@ -59,7 +59,6 @@ public class ChestVisual<T extends BlockEntity & LidBlockEntity> extends Abstrac
private TransformedInstance lock; private TransformedInstance lock;
private ChestType chestType; private ChestType chestType;
private Material texture;
private final Quaternionf baseRotation = new Quaternionf(); private final Quaternionf baseRotation = new Quaternionf();
private Float2FloatFunction lidProgress; private Float2FloatFunction lidProgress;
@ -72,11 +71,11 @@ public class ChestVisual<T extends BlockEntity & LidBlockEntity> extends Abstrac
@Override @Override
public void init(float partialTick) { public void init(float partialTick) {
chestType = blockState.hasProperty(ChestBlock.TYPE) ? blockState.getValue(ChestBlock.TYPE) : ChestType.SINGLE; chestType = blockState.hasProperty(ChestBlock.TYPE) ? blockState.getValue(ChestBlock.TYPE) : ChestType.SINGLE;
texture = Sheets.chooseMaterial(blockEntity, chestType, isChristmas()); Material texture = Sheets.chooseMaterial(blockEntity, chestType, isChristmas());
bottom = createBottomInstance().setPosition(getVisualPosition()); bottom = createBottomInstance(texture).setPosition(getVisualPosition());
lid = createLidInstance(); lid = createLidInstance(texture);
lock = createLockInstance(); lock = createLockInstance(texture);
Block block = blockState.getBlock(); Block block = blockState.getBlock();
if (block instanceof AbstractChestBlock<?> chestBlock) { if (block instanceof AbstractChestBlock<?> chestBlock) {
@ -97,17 +96,17 @@ public class ChestVisual<T extends BlockEntity & LidBlockEntity> extends Abstrac
super.init(partialTick); super.init(partialTick);
} }
private OrientedInstance createBottomInstance() { private OrientedInstance createBottomInstance(Material texture) {
return instancerProvider.instancer(InstanceTypes.ORIENTED, BOTTOM_MODELS.get(Pair.of(chestType, texture)), RenderStage.AFTER_BLOCK_ENTITIES) return instancerProvider.instancer(InstanceTypes.ORIENTED, BOTTOM_MODELS.get(Pair.of(chestType, texture)), RenderStage.AFTER_BLOCK_ENTITIES)
.createInstance(); .createInstance();
} }
private TransformedInstance createLidInstance() { private TransformedInstance createLidInstance(Material texture) {
return instancerProvider.instancer(InstanceTypes.TRANSFORMED, LID_MODELS.get(Pair.of(chestType, texture)), RenderStage.AFTER_BLOCK_ENTITIES) return instancerProvider.instancer(InstanceTypes.TRANSFORMED, LID_MODELS.get(Pair.of(chestType, texture)), RenderStage.AFTER_BLOCK_ENTITIES)
.createInstance(); .createInstance();
} }
private TransformedInstance createLockInstance() { private TransformedInstance createLockInstance(Material texture) {
return instancerProvider.instancer(InstanceTypes.TRANSFORMED, LOCK_MODELS.get(Pair.of(chestType, texture)), RenderStage.AFTER_BLOCK_ENTITIES) return instancerProvider.instancer(InstanceTypes.TRANSFORMED, LOCK_MODELS.get(Pair.of(chestType, texture)), RenderStage.AFTER_BLOCK_ENTITIES)
.createInstance(); .createInstance();
} }
@ -143,14 +142,16 @@ public class ChestVisual<T extends BlockEntity & LidBlockEntity> extends Abstrac
.rotateCentered(baseRotation) .rotateCentered(baseRotation)
.translate(0, 9f / 16f, 1f / 16f) .translate(0, 9f / 16f, 1f / 16f)
.rotateX(angleX) .rotateX(angleX)
.translate(0, -9f / 16f, -1f / 16f); .translate(0, -9f / 16f, -1f / 16f)
.setChanged();
lock.loadIdentity() lock.loadIdentity()
.translate(getVisualPosition()) .translate(getVisualPosition())
.rotateCentered(baseRotation) .rotateCentered(baseRotation)
.translate(0, 8f / 16f, 0) .translate(0, 8f / 16f, 0)
.rotateX(angleX) .rotateX(angleX)
.translate(0, -8f / 16f, 0); .translate(0, -8f / 16f, 0)
.setChanged();
} }
@Override @Override

View file

@ -163,12 +163,14 @@ public class MinecartVisual<T extends AbstractMinecart> extends AbstractEntityVi
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(Axis.YP.rotationDegrees(90)); stack.mulPose(Axis.YP.rotationDegrees(90));
contents.setTransform(stack); contents.setTransform(stack)
.setChanged();
stack.popPose(); stack.popPose();
} }
stack.scale(-1.0F, -1.0F, 1.0F); stack.scale(-1.0F, -1.0F, 1.0F);
body.setTransform(stack); body.setTransform(stack)
.setChanged();
} }
@Override @Override

View file

@ -39,7 +39,6 @@ public class ShulkerBoxVisual extends AbstractBlockEntityVisual<ShulkerBoxBlockE
private TransformedInstance base; private TransformedInstance base;
private TransformedInstance lid; private TransformedInstance lid;
private Material texture;
private final PoseStack stack = new PoseStack(); private final PoseStack stack = new PoseStack();
private float lastProgress = Float.NaN; private float lastProgress = Float.NaN;
@ -51,6 +50,7 @@ public class ShulkerBoxVisual extends AbstractBlockEntityVisual<ShulkerBoxBlockE
@Override @Override
public void init(float partialTick) { public void init(float partialTick) {
DyeColor color = blockEntity.getColor(); DyeColor color = blockEntity.getColor();
Material texture;
if (color == null) { if (color == null) {
texture = Sheets.DEFAULT_SHULKER_TEXTURE_LOCATION; texture = Sheets.DEFAULT_SHULKER_TEXTURE_LOCATION;
} else { } else {
@ -59,26 +59,27 @@ public class ShulkerBoxVisual extends AbstractBlockEntityVisual<ShulkerBoxBlockE
var rotation = getDirection().getRotation(); var rotation = getDirection().getRotation();
TransformStack tstack = TransformStack.of(stack); stack.setIdentity();
tstack.translate(getVisualPosition()) TransformStack.of(stack)
.translate(getVisualPosition())
.translate(0.5) .translate(0.5)
.scale(0.9995f) .scale(0.9995f)
.rotate(rotation) .rotate(rotation)
.scale(1, -1, -1) .scale(1, -1, -1)
.translateY(-1); .translateY(-1);
base = createBaseInstance().setTransform(stack); base = createBaseInstance(texture).setTransform(stack);
lid = createLidInstance().setTransform(stack); lid = createLidInstance(texture).setTransform(stack);
super.init(partialTick); super.init(partialTick);
} }
private TransformedInstance createBaseInstance() { private TransformedInstance createBaseInstance(Material texture) {
return instancerProvider.instancer(InstanceTypes.TRANSFORMED, BASE_MODELS.get(texture), RenderStage.AFTER_BLOCK_ENTITIES) return instancerProvider.instancer(InstanceTypes.TRANSFORMED, BASE_MODELS.get(texture), RenderStage.AFTER_BLOCK_ENTITIES)
.createInstance(); .createInstance();
} }
private TransformedInstance createLidInstance() { private TransformedInstance createLidInstance(Material texture) {
return instancerProvider.instancer(InstanceTypes.TRANSFORMED, LID_MODELS.get(texture), RenderStage.AFTER_BLOCK_ENTITIES) return instancerProvider.instancer(InstanceTypes.TRANSFORMED, LID_MODELS.get(texture), RenderStage.AFTER_BLOCK_ENTITIES)
.createInstance(); .createInstance();
} }
@ -110,7 +111,8 @@ public class ShulkerBoxVisual extends AbstractBlockEntityVisual<ShulkerBoxBlockE
.translateY(-progress * 0.5f) .translateY(-progress * 0.5f)
.rotate(spin); .rotate(spin);
lid.setTransform(stack); lid.setTransform(stack)
.setChanged();
stack.popPose(); stack.popPose();
} }