From 18ed201c930b05d2210d8262967b1c92b2663493 Mon Sep 17 00:00:00 2001 From: Jozufozu Date: Tue, 28 Sep 2021 17:54:47 -0700 Subject: [PATCH] Rename/refactor many interfaces - Drop I prefix - Inline IMultiProgram - Remove unused method in InstanceRendered --- .../jozufozu/flywheel/backend/Backend.java | 10 +++---- ...IFlywheelWorld.java => FlywheelWorld.java} | 2 +- .../com/jozufozu/flywheel/backend/Loader.java | 2 +- ...IShaderContext.java => ShaderContext.java} | 2 +- .../{IAttribSpec.java => AttribSpec.java} | 2 +- .../backend/gl/attrib/MatrixAttributes.java | 2 +- .../backend/gl/attrib/VertexAttribSpec.java | 2 +- .../backend/gl/attrib/VertexFormat.java | 12 ++++---- .../backend/instancing/AbstractInstance.java | 14 ++++----- ...amicInstance.java => DynamicInstance.java} | 4 +-- .../backend/instancing/GPUInstancer.java | 6 ++-- .../{IInstance.java => Instance.java} | 2 +- .../backend/instancing/InstanceManager.java | 18 +++++------ ...nceRendered.java => InstanceRendered.java} | 6 +--- .../backend/instancing/InstanceWorld.java | 4 +-- .../instancing/InstancedRenderRegistry.java | 30 ++++++++++--------- ...bleInstance.java => TickableInstance.java} | 6 ++-- .../instancing/entity/EntityInstance.java | 8 ++--- ...actory.java => EntityInstanceFactory.java} | 2 +- .../instancing/tile/TileEntityInstance.java | 8 ++--- ...eFactory.java => TileInstanceFactory.java} | 2 +- .../flywheel/backend/material/Material.java | 4 +-- .../backend/material/MaterialImpl.java | 4 +-- .../backend/material/MaterialManager.java | 1 + .../backend/model/ArrayModelRenderer.java | 6 ++-- .../flywheel/backend/model/BufferedModel.java | 6 ++-- .../backend/model/ImmediateAllocator.java | 4 +-- .../flywheel/backend/model/IndexedModel.java | 4 +-- .../backend/model/ModelAllocator.java | 4 +-- .../flywheel/backend/model/ModelPool.java | 8 ++--- .../flywheel/backend/model/ModelRenderer.java | 8 ++--- ...haderPipeline.java => ShaderCompiler.java} | 8 ++--- ...Pipeline.java => WorldShaderCompiler.java} | 9 +++--- .../backend/source/FileResolution.java | 2 +- .../flywheel/backend/source/Resolver.java | 2 +- .../backend/source/ShaderSources.java | 2 +- .../{ISourceHolder.java => SourceHolder.java} | 2 +- .../flywheel/backend/state/IRenderState.java | 4 +++ .../com/jozufozu/flywheel/core/Contexts.java | 8 ++--- .../jozufozu/flywheel/core/WorldContext.java | 18 +++++------ .../flywheel/core/materials/BasicData.java | 4 +-- .../{IFlatLight.java => FlatLight.java} | 8 ++--- .../flywheel/core/model/BakedModelModel.java | 2 +- .../flywheel/core/model/BlockModel.java | 4 +-- .../core/model/{IModel.java => Model.java} | 2 +- .../flywheel/core/model/ModelPart.java | 2 +- .../flywheel/core/model/WorldModel.java | 2 +- .../core/shader/GameStateProgram.java | 12 ++++++-- .../flywheel/core/shader/IMultiProgram.java | 26 ---------------- .../flywheel/vanilla/BellInstance.java | 4 +-- .../flywheel/vanilla/ChestInstance.java | 4 +-- .../flywheel/vanilla/MinecartInstance.java | 10 +++---- .../flywheel/vanilla/ShulkerBoxInstance.java | 4 +-- 53 files changed, 154 insertions(+), 178 deletions(-) rename src/main/java/com/jozufozu/flywheel/backend/{IFlywheelWorld.java => FlywheelWorld.java} (90%) rename src/main/java/com/jozufozu/flywheel/backend/{IShaderContext.java => ShaderContext.java} (90%) rename src/main/java/com/jozufozu/flywheel/backend/gl/attrib/{IAttribSpec.java => AttribSpec.java} (83%) rename src/main/java/com/jozufozu/flywheel/backend/instancing/{IDynamicInstance.java => DynamicInstance.java} (89%) rename src/main/java/com/jozufozu/flywheel/backend/instancing/{IInstance.java => Instance.java} (80%) rename src/main/java/com/jozufozu/flywheel/backend/instancing/{IInstanceRendered.java => InstanceRendered.java} (76%) rename src/main/java/com/jozufozu/flywheel/backend/instancing/{ITickableInstance.java => TickableInstance.java} (88%) rename src/main/java/com/jozufozu/flywheel/backend/instancing/entity/{IEntityInstanceFactory.java => EntityInstanceFactory.java} (80%) rename src/main/java/com/jozufozu/flywheel/backend/instancing/tile/{ITileInstanceFactory.java => TileInstanceFactory.java} (81%) rename src/main/java/com/jozufozu/flywheel/backend/pipeline/{IShaderPipeline.java => ShaderCompiler.java} (54%) rename src/main/java/com/jozufozu/flywheel/backend/pipeline/{WorldShaderPipeline.java => WorldShaderCompiler.java} (83%) rename src/main/java/com/jozufozu/flywheel/backend/source/{ISourceHolder.java => SourceHolder.java} (86%) rename src/main/java/com/jozufozu/flywheel/core/materials/{IFlatLight.java => FlatLight.java} (77%) rename src/main/java/com/jozufozu/flywheel/core/model/{IModel.java => Model.java} (98%) delete mode 100644 src/main/java/com/jozufozu/flywheel/core/shader/IMultiProgram.java diff --git a/src/main/java/com/jozufozu/flywheel/backend/Backend.java b/src/main/java/com/jozufozu/flywheel/backend/Backend.java index a6b40f781..aa1525cfe 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/Backend.java +++ b/src/main/java/com/jozufozu/flywheel/backend/Backend.java @@ -42,7 +42,7 @@ public class Backend { private boolean enabled; public boolean chunkCachingEnabled; - private final List> contexts = new ArrayList<>(); + private final List> contexts = new ArrayList<>(); private final Map> materialRegistry = new HashMap<>(); private final Map programSpecRegistry = new HashMap<>(); @@ -83,7 +83,7 @@ public class Backend { /** * Register a shader context. */ - public > C register(C spec) { + public > C register(C spec) { contexts.add(spec); return spec; } @@ -154,7 +154,7 @@ public class Backend { return programSpecRegistry.values(); } - public Collection> allContexts() { + public Collection> allContexts() { return contexts; } @@ -164,7 +164,7 @@ public class Backend { public static boolean isFlywheelWorld(@Nullable LevelAccessor world) { if (world == null) return false; - if (world instanceof IFlywheelWorld && ((IFlywheelWorld) world).supportsFlywheel()) return true; + if (world instanceof FlywheelWorld && ((FlywheelWorld) world).supportsFlywheel()) return true; return world == Minecraft.getInstance().level; } @@ -183,7 +183,7 @@ public class Backend { public void _clearContexts() { SpecMetaRegistry.clear(); programSpecRegistry.clear(); - contexts.forEach(IShaderContext::delete); + contexts.forEach(ShaderContext::delete); contexts.clear(); materialRegistry.clear(); } diff --git a/src/main/java/com/jozufozu/flywheel/backend/IFlywheelWorld.java b/src/main/java/com/jozufozu/flywheel/backend/FlywheelWorld.java similarity index 90% rename from src/main/java/com/jozufozu/flywheel/backend/IFlywheelWorld.java rename to src/main/java/com/jozufozu/flywheel/backend/FlywheelWorld.java index 52f1712ed..6adfd1b6e 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/IFlywheelWorld.java +++ b/src/main/java/com/jozufozu/flywheel/backend/FlywheelWorld.java @@ -6,7 +6,7 @@ package com.jozufozu.flywheel.backend; * * Minecraft.getInstance().world is special cased and will support Flywheel by default. */ -public interface IFlywheelWorld { +public interface FlywheelWorld { default boolean supportsFlywheel() { return true; } diff --git a/src/main/java/com/jozufozu/flywheel/backend/Loader.java b/src/main/java/com/jozufozu/flywheel/backend/Loader.java index 363dcff13..a55f8da18 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/Loader.java +++ b/src/main/java/com/jozufozu/flywheel/backend/Loader.java @@ -82,7 +82,7 @@ public class Loader implements ResourceManagerReloadListener { Resolver.INSTANCE.resolve(sources); - for (IShaderContext context : backend.allContexts()) { + for (ShaderContext context : backend.allContexts()) { context.load(); } diff --git a/src/main/java/com/jozufozu/flywheel/backend/IShaderContext.java b/src/main/java/com/jozufozu/flywheel/backend/ShaderContext.java similarity index 90% rename from src/main/java/com/jozufozu/flywheel/backend/IShaderContext.java rename to src/main/java/com/jozufozu/flywheel/backend/ShaderContext.java index 0d24963f2..66585908e 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/IShaderContext.java +++ b/src/main/java/com/jozufozu/flywheel/backend/ShaderContext.java @@ -6,7 +6,7 @@ import com.jozufozu.flywheel.backend.gl.shader.GlProgram; import net.minecraft.resources.ResourceLocation; -public interface IShaderContext

{ +public interface ShaderContext

{ default P getProgram(ResourceLocation loc) { return this.getProgramSupplier(loc) diff --git a/src/main/java/com/jozufozu/flywheel/backend/gl/attrib/IAttribSpec.java b/src/main/java/com/jozufozu/flywheel/backend/gl/attrib/AttribSpec.java similarity index 83% rename from src/main/java/com/jozufozu/flywheel/backend/gl/attrib/IAttribSpec.java rename to src/main/java/com/jozufozu/flywheel/backend/gl/attrib/AttribSpec.java index 04a8daf00..ba23e6f0b 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/gl/attrib/IAttribSpec.java +++ b/src/main/java/com/jozufozu/flywheel/backend/gl/attrib/AttribSpec.java @@ -1,6 +1,6 @@ package com.jozufozu.flywheel.backend.gl.attrib; -public interface IAttribSpec { +public interface AttribSpec { void vertexAttribPointer(int stride, int index, int offset); diff --git a/src/main/java/com/jozufozu/flywheel/backend/gl/attrib/MatrixAttributes.java b/src/main/java/com/jozufozu/flywheel/backend/gl/attrib/MatrixAttributes.java index aef66036c..b92c1b46c 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/gl/attrib/MatrixAttributes.java +++ b/src/main/java/com/jozufozu/flywheel/backend/gl/attrib/MatrixAttributes.java @@ -4,7 +4,7 @@ import org.lwjgl.opengl.GL20; import com.jozufozu.flywheel.backend.gl.GlNumericType; -public enum MatrixAttributes implements IAttribSpec { +public enum MatrixAttributes implements AttribSpec { MAT3(3, 3), MAT4(4, 4), ; diff --git a/src/main/java/com/jozufozu/flywheel/backend/gl/attrib/VertexAttribSpec.java b/src/main/java/com/jozufozu/flywheel/backend/gl/attrib/VertexAttribSpec.java index 7219ddb20..ce22cc01e 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/gl/attrib/VertexAttribSpec.java +++ b/src/main/java/com/jozufozu/flywheel/backend/gl/attrib/VertexAttribSpec.java @@ -4,7 +4,7 @@ import org.lwjgl.opengl.GL20; import com.jozufozu.flywheel.backend.gl.GlNumericType; -public class VertexAttribSpec implements IAttribSpec { +public class VertexAttribSpec implements AttribSpec { private final GlNumericType type; private final int count; diff --git a/src/main/java/com/jozufozu/flywheel/backend/gl/attrib/VertexFormat.java b/src/main/java/com/jozufozu/flywheel/backend/gl/attrib/VertexFormat.java index 9d48fd142..a772e583f 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/gl/attrib/VertexFormat.java +++ b/src/main/java/com/jozufozu/flywheel/backend/gl/attrib/VertexFormat.java @@ -5,16 +5,16 @@ import java.util.Collections; public class VertexFormat { - private final ArrayList allAttributes; + private final ArrayList allAttributes; private final int numAttributes; private final int stride; - public VertexFormat(ArrayList allAttributes) { + public VertexFormat(ArrayList allAttributes) { this.allAttributes = allAttributes; int numAttributes = 0, stride = 0; - for (IAttribSpec spec : allAttributes) { + for (AttribSpec spec : allAttributes) { numAttributes += spec.getAttributeCount(); stride += spec.getSize(); } @@ -32,7 +32,7 @@ public class VertexFormat { public void vertexAttribPointers(int index) { int offset = 0; - for (IAttribSpec spec : this.allAttributes) { + for (AttribSpec spec : this.allAttributes) { spec.vertexAttribPointer(stride, index, offset); index += spec.getAttributeCount(); offset += spec.getSize(); @@ -44,12 +44,12 @@ public class VertexFormat { } public static class Builder { - private final ArrayList allAttributes = new ArrayList<>(); + private final ArrayList allAttributes = new ArrayList<>(); public Builder() { } - public Builder addAttributes(IAttribSpec... attributes) { + public Builder addAttributes(AttribSpec... attributes) { Collections.addAll(allAttributes, attributes); return this; } diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/AbstractInstance.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/AbstractInstance.java index b17051c50..3ddaf416c 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/AbstractInstance.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/AbstractInstance.java @@ -5,7 +5,7 @@ import java.util.stream.Stream; import com.jozufozu.flywheel.backend.instancing.tile.TileInstanceManager; import com.jozufozu.flywheel.backend.material.MaterialManager; -import com.jozufozu.flywheel.core.materials.IFlatLight; +import com.jozufozu.flywheel.core.materials.FlatLight; import com.jozufozu.flywheel.light.ILightUpdateListener; import com.jozufozu.flywheel.light.ImmutableBox; import com.jozufozu.flywheel.light.LightProvider; @@ -19,7 +19,7 @@ import net.minecraft.world.level.Level; * A general interface providing information about any type of thing that could use Flywheel's instanced rendering. * Right now, that's only {@link TileInstanceManager}, but there could be an entity equivalent in the future. */ -public abstract class AbstractInstance implements IInstance, ILightUpdateListener { +public abstract class AbstractInstance implements Instance, ILightUpdateListener { protected final MaterialManager materialManager; public final Level world; @@ -38,7 +38,7 @@ public abstract class AbstractInstance implements IInstance, ILightUpdateListene * Update instance data here. Good for when data doesn't change very often and when animations are GPU based. * Don't query lighting data here, that's handled separately in {@link #updateLight()}. * - *

If your animations are complex or more CPU driven, see {@link IDynamicInstance} or {@link ITickableInstance}. + *

If your animations are complex or more CPU driven, see {@link DynamicInstance} or {@link TickableInstance}. */ public void update() { } @@ -77,19 +77,19 @@ public abstract class AbstractInstance implements IInstance, ILightUpdateListene updateLight(); } - protected void relight(BlockPos pos, IFlatLight... models) { + protected void relight(BlockPos pos, FlatLight... models) { relight(world.getBrightness(LightLayer.BLOCK, pos), world.getBrightness(LightLayer.SKY, pos), models); } - protected > void relight(BlockPos pos, Stream models) { + protected void relight(BlockPos pos, Stream models) { relight(world.getBrightness(LightLayer.BLOCK, pos), world.getBrightness(LightLayer.SKY, pos), models); } - protected void relight(int block, int sky, IFlatLight... models) { + protected void relight(int block, int sky, FlatLight... models) { relight(block, sky, Arrays.stream(models)); } - protected > void relight(int block, int sky, Stream models) { + protected void relight(int block, int sky, Stream models) { models.forEach(model -> model.setBlockLight(block) .setSkyLight(sky)); } diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/IDynamicInstance.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/DynamicInstance.java similarity index 89% rename from src/main/java/com/jozufozu/flywheel/backend/instancing/IDynamicInstance.java rename to src/main/java/com/jozufozu/flywheel/backend/instancing/DynamicInstance.java index e801d16f8..d371a0c25 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/IDynamicInstance.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/DynamicInstance.java @@ -4,14 +4,14 @@ import com.jozufozu.flywheel.backend.instancing.tile.TileEntityInstance; /** * An interface giving {@link TileEntityInstance}s a hook to have a function called at - * the start of a frame. By implementing {@link IDynamicInstance}, a {@link TileEntityInstance} + * the start of a frame. By implementing {@link DynamicInstance}, a {@link TileEntityInstance} * can animate its models in ways that could not be easily achieved by shader attribute * parameterization. * *

If your goal is offloading work to shaders, but you're unsure exactly how you need * to parameterize the instances, you're encouraged to implement this for prototyping. */ -public interface IDynamicInstance extends IInstance { +public interface DynamicInstance extends Instance { /** * Called every frame. *
diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/GPUInstancer.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/GPUInstancer.java index 1e9d85dcd..7f477e750 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/GPUInstancer.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/GPUInstancer.java @@ -13,13 +13,13 @@ import com.jozufozu.flywheel.backend.model.IBufferedModel; import com.jozufozu.flywheel.backend.model.ModelAllocator; import com.jozufozu.flywheel.backend.struct.StructType; import com.jozufozu.flywheel.backend.struct.StructWriter; -import com.jozufozu.flywheel.core.model.IModel; +import com.jozufozu.flywheel.core.model.Model; import com.jozufozu.flywheel.util.AttribUtil; public class GPUInstancer implements Instancer { private final ModelAllocator modelAllocator; - private final IModel modelData; + private final Model modelData; private final VertexFormat instanceFormat; private final StructType type; @@ -36,7 +36,7 @@ public class GPUInstancer implements Instancer { boolean anyToRemove; boolean anyToUpdate; - public GPUInstancer(ModelAllocator modelAllocator, IModel model, StructType type) { + public GPUInstancer(ModelAllocator modelAllocator, Model model, StructType type) { this.modelAllocator = modelAllocator; this.modelData = model; this.type = type; diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/IInstance.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/Instance.java similarity index 80% rename from src/main/java/com/jozufozu/flywheel/backend/instancing/IInstance.java rename to src/main/java/com/jozufozu/flywheel/backend/instancing/Instance.java index 9514740d8..4a6d5f1c1 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/IInstance.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/Instance.java @@ -2,6 +2,6 @@ package com.jozufozu.flywheel.backend.instancing; import net.minecraft.core.BlockPos; -public interface IInstance { +public interface Instance { BlockPos getWorldPosition(); } diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/InstanceManager.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/InstanceManager.java index 573d3fac2..014b31665 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/InstanceManager.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/InstanceManager.java @@ -27,8 +27,8 @@ public abstract class InstanceManager implements MaterialManagerImpl.OriginSh private final Set queuedUpdates; protected final Map instances; - protected final Object2ObjectOpenHashMap tickableInstances; - protected final Object2ObjectOpenHashMap dynamicInstances; + protected final Object2ObjectOpenHashMap tickableInstances; + protected final Object2ObjectOpenHashMap dynamicInstances; protected int frame; protected int tick; @@ -70,7 +70,7 @@ public abstract class InstanceManager implements MaterialManagerImpl.OriginSh * Ticks the InstanceManager. * *

- * {@link ITickableInstance}s get ticked. + * {@link TickableInstance}s get ticked. *
* Queued updates are processed. *

@@ -86,7 +86,7 @@ public abstract class InstanceManager implements MaterialManagerImpl.OriginSh if (tickableInstances.size() > 0) { tickableInstances.object2ObjectEntrySet().parallelStream().forEach(e -> { - ITickableInstance instance = e.getValue(); + TickableInstance instance = e.getValue(); if (!instance.decreaseTickRateWithDistance()) { instance.tick(); return; @@ -121,7 +121,7 @@ public abstract class InstanceManager implements MaterialManagerImpl.OriginSh dynamicInstances.object2ObjectEntrySet() .parallelStream() .forEach(e -> { - IDynamicInstance dyn = e.getValue(); + DynamicInstance dyn = e.getValue(); if (!dyn.decreaseFramerateWithDistance() || shouldFrameUpdate(dyn.getWorldPosition(), lookX, lookY, lookZ, cX, cY, cZ)) dyn.beginFrame(); }); @@ -159,8 +159,8 @@ public abstract class InstanceManager implements MaterialManagerImpl.OriginSh * *

* By default this is the only hook an IInstance has to change its internal state. This is the lowest frequency - * update hook IInstance gets. For more frequent updates, see {@link ITickableInstance} and - * {@link IDynamicInstance}. + * update hook IInstance gets. For more frequent updates, see {@link TickableInstance} and + * {@link DynamicInstance}. *

* * @param obj the object to update. @@ -291,9 +291,9 @@ public abstract class InstanceManager implements MaterialManagerImpl.OriginSh .addListener(renderer); instances.put(obj, renderer); - if (renderer instanceof IDynamicInstance) dynamicInstances.put(obj, (IDynamicInstance) renderer); + if (renderer instanceof DynamicInstance) dynamicInstances.put(obj, (DynamicInstance) renderer); - if (renderer instanceof ITickableInstance) tickableInstances.put(obj, ((ITickableInstance) renderer)); + if (renderer instanceof TickableInstance) tickableInstances.put(obj, ((TickableInstance) renderer)); } return renderer; diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/IInstanceRendered.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/InstanceRendered.java similarity index 76% rename from src/main/java/com/jozufozu/flywheel/backend/instancing/IInstanceRendered.java rename to src/main/java/com/jozufozu/flywheel/backend/instancing/InstanceRendered.java index 50073b868..68009ed94 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/IInstanceRendered.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/InstanceRendered.java @@ -1,11 +1,9 @@ package com.jozufozu.flywheel.backend.instancing; -import net.minecraft.world.level.Level; - /** * Something (a BlockEntity or Entity) that can be rendered using the instancing API. */ -public interface IInstanceRendered { +public interface InstanceRendered { /** * @return true if there are parts of the renderer that cannot be implemented with Flywheel. @@ -13,6 +11,4 @@ public interface IInstanceRendered { default boolean shouldRenderNormally() { return false; } - - Level getWorld(); } diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/InstanceWorld.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/InstanceWorld.java index 9c9d94e1e..c292b9ae6 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/InstanceWorld.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/InstanceWorld.java @@ -71,7 +71,7 @@ public class InstanceWorld { *

* Check and shift the origin coordinate. *
- * Call {@link IDynamicInstance#beginFrame()} on all instances in this world. + * Call {@link DynamicInstance#beginFrame()} on all instances in this world. *

*/ public void beginFrame(BeginFrameEvent event) { @@ -84,7 +84,7 @@ public class InstanceWorld { /** * Tick the renderers after the game has ticked: *

- * Call {@link ITickableInstance#tick()} on all instances in this world. + * Call {@link TickableInstance#tick()} on all instances in this world. *

*/ public void tick() { diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/InstancedRenderRegistry.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/InstancedRenderRegistry.java index cbafe6398..ba797eda3 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/InstancedRenderRegistry.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/InstancedRenderRegistry.java @@ -6,8 +6,8 @@ import javax.annotation.Nullable; import com.google.common.collect.Maps; import com.jozufozu.flywheel.backend.instancing.entity.EntityInstance; -import com.jozufozu.flywheel.backend.instancing.entity.IEntityInstanceFactory; -import com.jozufozu.flywheel.backend.instancing.tile.ITileInstanceFactory; +import com.jozufozu.flywheel.backend.instancing.entity.EntityInstanceFactory; +import com.jozufozu.flywheel.backend.instancing.tile.TileInstanceFactory; import com.jozufozu.flywheel.backend.instancing.tile.TileEntityInstance; import com.jozufozu.flywheel.backend.material.MaterialManager; @@ -26,19 +26,21 @@ public class InstancedRenderRegistry { } private final Object2BooleanMap skipRender = new Object2BooleanLinkedOpenHashMap<>(); - private final Map, ITileInstanceFactory> tiles = Maps.newHashMap(); - private final Map, IEntityInstanceFactory> entities = Maps.newHashMap(); + private final Map, TileInstanceFactory> tiles = Maps.newHashMap(); + private final Map, EntityInstanceFactory> entities = Maps.newHashMap(); protected InstancedRenderRegistry() { skipRender.defaultReturnValue(false); } public boolean shouldSkipRender(T type) { - return _skipRender(type.getType()) || ((type instanceof IInstanceRendered) && !((IInstanceRendered) type).shouldRenderNormally()); + // _skipRender is faster than instanceof and cast, take advantage of short-circuiting + return _skipRender(type.getType()) || ((type instanceof InstanceRendered) && !((InstanceRendered) type).shouldRenderNormally()); } public boolean shouldSkipRender(T type) { - return _skipRender(type.getType()) || ((type instanceof IInstanceRendered) && !((IInstanceRendered) type).shouldRenderNormally()); + // _skipRender is faster than instanceof and cast, take advantage of short-circuiting + return _skipRender(type.getType()) || ((type instanceof InstanceRendered) && !((InstanceRendered) type).shouldRenderNormally()); } public boolean canInstance(BlockEntityType type) { @@ -61,7 +63,7 @@ public class InstancedRenderRegistry { * @deprecated will be removed in 0.3.0, use {@link #tile} */ @Deprecated - public void register(BlockEntityType type, ITileInstanceFactory rendererFactory) { + public void register(BlockEntityType type, TileInstanceFactory rendererFactory) { this.tile(type) .factory(rendererFactory); } @@ -70,7 +72,7 @@ public class InstancedRenderRegistry { * @deprecated will be removed in 0.3.0, use {@link #entity} */ @Deprecated - public void register(EntityType type, IEntityInstanceFactory rendererFactory) { + public void register(EntityType type, EntityInstanceFactory rendererFactory) { this.entity(type) .factory(rendererFactory); } @@ -79,7 +81,7 @@ public class InstancedRenderRegistry { @Nullable public TileEntityInstance create(MaterialManager manager, T tile) { BlockEntityType type = tile.getType(); - ITileInstanceFactory factory = (ITileInstanceFactory) this.tiles.get(type); + TileInstanceFactory factory = (TileInstanceFactory) this.tiles.get(type); if (factory == null) return null; else return factory.create(manager, tile); @@ -90,7 +92,7 @@ public class InstancedRenderRegistry { @Nullable public EntityInstance create(MaterialManager manager, T tile) { EntityType type = tile.getType(); - IEntityInstanceFactory factory = (IEntityInstanceFactory) this.entities.get(type); + EntityInstanceFactory factory = (EntityInstanceFactory) this.entities.get(type); if (factory == null) return null; else return factory.create(manager, tile); @@ -107,7 +109,7 @@ public class InstancedRenderRegistry { CONFIG setSkipRender(boolean skipRender); } - public class TileConfig implements Config, ITileInstanceFactory> { + public class TileConfig implements Config, TileInstanceFactory> { private final BlockEntityType type; @@ -116,7 +118,7 @@ public class InstancedRenderRegistry { this.type = type; } - public TileConfig factory(ITileInstanceFactory rendererFactory) { + public TileConfig factory(TileInstanceFactory rendererFactory) { tiles.put(type, rendererFactory); return this; } @@ -126,7 +128,7 @@ public class InstancedRenderRegistry { } } - public class EntityConfig implements Config, IEntityInstanceFactory> { + public class EntityConfig implements Config, EntityInstanceFactory> { private final EntityType type; @@ -135,7 +137,7 @@ public class InstancedRenderRegistry { this.type = type; } - public EntityConfig factory(IEntityInstanceFactory rendererFactory) { + public EntityConfig factory(EntityInstanceFactory rendererFactory) { entities.put(type, rendererFactory); return this; } diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/ITickableInstance.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/TickableInstance.java similarity index 88% rename from src/main/java/com/jozufozu/flywheel/backend/instancing/ITickableInstance.java rename to src/main/java/com/jozufozu/flywheel/backend/instancing/TickableInstance.java index 71e5e1d8d..f6906b41c 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/ITickableInstance.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/TickableInstance.java @@ -4,9 +4,9 @@ import com.jozufozu.flywheel.backend.instancing.tile.TileEntityInstance; /** * An interface giving {@link TileEntityInstance}s a hook to have a function called at - * the end of every tick. By implementing {@link ITickableInstance}, a {@link TileEntityInstance} + * the end of every tick. By implementing {@link TickableInstance}, a {@link TileEntityInstance} * can update frequently, but not every frame. - *
There are a few cases in which this should be considered over {@link IDynamicInstance}: + *
There are a few cases in which this should be considered over {@link DynamicInstance}: *
    *
  • * You'd like to change something about the instance every now and then. @@ -18,7 +18,7 @@ import com.jozufozu.flywheel.backend.instancing.tile.TileEntityInstance; *
  • *
*/ -public interface ITickableInstance extends IInstance { +public interface TickableInstance extends Instance { /** * Called every tick. diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/entity/EntityInstance.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/entity/EntityInstance.java index 64e92c3ee..94851e9da 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/entity/EntityInstance.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/entity/EntityInstance.java @@ -1,8 +1,8 @@ package com.jozufozu.flywheel.backend.instancing.entity; import com.jozufozu.flywheel.backend.instancing.AbstractInstance; -import com.jozufozu.flywheel.backend.instancing.IDynamicInstance; -import com.jozufozu.flywheel.backend.instancing.ITickableInstance; +import com.jozufozu.flywheel.backend.instancing.DynamicInstance; +import com.jozufozu.flywheel.backend.instancing.TickableInstance; import com.jozufozu.flywheel.backend.instancing.tile.TileInstanceManager; import com.jozufozu.flywheel.backend.material.MaterialManager; import com.jozufozu.flywheel.light.GridAlignedBB; @@ -24,8 +24,8 @@ import net.minecraft.core.Vec3i; * * *

There are a few additional features that overriding classes can opt in to: *
    - *
  • {@link IDynamicInstance}
  • - *
  • {@link ITickableInstance}
  • + *
  • {@link DynamicInstance}
  • + *
  • {@link TickableInstance}
  • *
* See the interfaces' documentation for more information about each one. * diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/entity/IEntityInstanceFactory.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/entity/EntityInstanceFactory.java similarity index 80% rename from src/main/java/com/jozufozu/flywheel/backend/instancing/entity/IEntityInstanceFactory.java rename to src/main/java/com/jozufozu/flywheel/backend/instancing/entity/EntityInstanceFactory.java index 67d5a0257..2ff5bcaa7 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/entity/IEntityInstanceFactory.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/entity/EntityInstanceFactory.java @@ -5,6 +5,6 @@ import com.jozufozu.flywheel.backend.material.MaterialManager; import net.minecraft.world.entity.Entity; @FunctionalInterface -public interface IEntityInstanceFactory { +public interface EntityInstanceFactory { EntityInstance create(MaterialManager manager, E te); } diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/tile/TileEntityInstance.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/tile/TileEntityInstance.java index b51e9fddb..08f2412b2 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/tile/TileEntityInstance.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/tile/TileEntityInstance.java @@ -1,8 +1,8 @@ package com.jozufozu.flywheel.backend.instancing.tile; import com.jozufozu.flywheel.backend.instancing.AbstractInstance; -import com.jozufozu.flywheel.backend.instancing.IDynamicInstance; -import com.jozufozu.flywheel.backend.instancing.ITickableInstance; +import com.jozufozu.flywheel.backend.instancing.DynamicInstance; +import com.jozufozu.flywheel.backend.instancing.TickableInstance; import com.jozufozu.flywheel.backend.material.Material; import com.jozufozu.flywheel.backend.material.MaterialManager; import com.jozufozu.flywheel.core.Materials; @@ -22,8 +22,8 @@ import net.minecraft.core.BlockPos; * *

There are a few additional features that overriding classes can opt in to: *
    - *
  • {@link IDynamicInstance}
  • - *
  • {@link ITickableInstance}
  • + *
  • {@link DynamicInstance}
  • + *
  • {@link TickableInstance}
  • *
* See the interfaces' documentation for more information about each one. * diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/tile/ITileInstanceFactory.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/tile/TileInstanceFactory.java similarity index 81% rename from src/main/java/com/jozufozu/flywheel/backend/instancing/tile/ITileInstanceFactory.java rename to src/main/java/com/jozufozu/flywheel/backend/instancing/tile/TileInstanceFactory.java index 3f8cdd1b8..e4803ce04 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/tile/ITileInstanceFactory.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/tile/TileInstanceFactory.java @@ -5,6 +5,6 @@ import com.jozufozu.flywheel.backend.material.MaterialManager; import net.minecraft.world.level.block.entity.BlockEntity; @FunctionalInterface -public interface ITileInstanceFactory { +public interface TileInstanceFactory { TileEntityInstance create(MaterialManager manager, T te); } diff --git a/src/main/java/com/jozufozu/flywheel/backend/material/Material.java b/src/main/java/com/jozufozu/flywheel/backend/material/Material.java index a7a68133d..33cfb823b 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/material/Material.java +++ b/src/main/java/com/jozufozu/flywheel/backend/material/Material.java @@ -6,7 +6,7 @@ import com.jozufozu.flywheel.backend.instancing.InstanceData; import com.jozufozu.flywheel.backend.instancing.Instancer; import com.jozufozu.flywheel.core.PartialModel; import com.jozufozu.flywheel.core.model.BlockModel; -import com.jozufozu.flywheel.core.model.IModel; +import com.jozufozu.flywheel.core.model.Model; import com.jozufozu.flywheel.util.Pair; import com.jozufozu.flywheel.util.RenderUtil; import com.mojang.blaze3d.vertex.PoseStack; @@ -22,7 +22,7 @@ public interface Material { * @param modelSupplier A factory that creates the IModel that you want to render. * @return An instancer for the given model, capable of rendering many copies for little cost. */ - Instancer model(Object key, Supplier modelSupplier); + Instancer model(Object key, Supplier modelSupplier); default Instancer getModel(PartialModel partial, BlockState referenceState) { return model(partial, () -> new BlockModel(partial.get(), referenceState)); diff --git a/src/main/java/com/jozufozu/flywheel/backend/material/MaterialImpl.java b/src/main/java/com/jozufozu/flywheel/backend/material/MaterialImpl.java index ce3fa98d0..8582d5a2c 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/material/MaterialImpl.java +++ b/src/main/java/com/jozufozu/flywheel/backend/material/MaterialImpl.java @@ -10,7 +10,7 @@ import com.jozufozu.flywheel.backend.instancing.GPUInstancer; import com.jozufozu.flywheel.backend.instancing.InstanceData; import com.jozufozu.flywheel.backend.instancing.Instancer; import com.jozufozu.flywheel.backend.model.ModelPool; -import com.jozufozu.flywheel.core.model.IModel; +import com.jozufozu.flywheel.core.model.Model; /** * A collection of Instancers that all have the same format. @@ -42,7 +42,7 @@ public class MaterialImpl implements Material { * @return An instancer for the given model, capable of rendering many copies for little cost. */ @Override - public Instancer model(Object key, Supplier modelSupplier) { + public Instancer model(Object key, Supplier modelSupplier) { try { return models.get(key, () -> new GPUInstancer<>(modelPool, modelSupplier.get(), spec.getInstanceType())); } catch (ExecutionException e) { diff --git a/src/main/java/com/jozufozu/flywheel/backend/material/MaterialManager.java b/src/main/java/com/jozufozu/flywheel/backend/material/MaterialManager.java index 74f17e702..15f2e3fd5 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/material/MaterialManager.java +++ b/src/main/java/com/jozufozu/flywheel/backend/material/MaterialManager.java @@ -4,6 +4,7 @@ import com.jozufozu.flywheel.backend.state.IRenderState; import com.jozufozu.flywheel.backend.state.RenderLayer; import com.jozufozu.flywheel.backend.state.TextureRenderState; +import net.minecraft.client.renderer.RenderStateShard; import net.minecraft.world.inventory.InventoryMenu; import net.minecraft.core.Vec3i; diff --git a/src/main/java/com/jozufozu/flywheel/backend/model/ArrayModelRenderer.java b/src/main/java/com/jozufozu/flywheel/backend/model/ArrayModelRenderer.java index 48359821c..533033680 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/model/ArrayModelRenderer.java +++ b/src/main/java/com/jozufozu/flywheel/backend/model/ArrayModelRenderer.java @@ -3,14 +3,14 @@ package com.jozufozu.flywheel.backend.model; import java.util.function.Supplier; import com.jozufozu.flywheel.backend.gl.GlVertexArray; -import com.jozufozu.flywheel.core.model.IModel; +import com.jozufozu.flywheel.core.model.Model; import com.jozufozu.flywheel.util.AttribUtil; public class ArrayModelRenderer extends ModelRenderer { protected GlVertexArray vao; - public ArrayModelRenderer(Supplier model) { + public ArrayModelRenderer(Supplier model) { super(model); } @@ -29,7 +29,7 @@ public class ArrayModelRenderer extends ModelRenderer { @Override protected void init() { initialized = true; - IModel model = modelSupplier.get(); + Model model = modelSupplier.get(); if (model.empty()) return; diff --git a/src/main/java/com/jozufozu/flywheel/backend/model/BufferedModel.java b/src/main/java/com/jozufozu/flywheel/backend/model/BufferedModel.java index 5b5b5026d..05c14f7eb 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/model/BufferedModel.java +++ b/src/main/java/com/jozufozu/flywheel/backend/model/BufferedModel.java @@ -9,17 +9,17 @@ import com.jozufozu.flywheel.backend.gl.buffer.GlBuffer; import com.jozufozu.flywheel.backend.gl.buffer.GlBufferType; import com.jozufozu.flywheel.backend.gl.buffer.MappedBuffer; import com.jozufozu.flywheel.backend.gl.buffer.MappedGlBuffer; -import com.jozufozu.flywheel.core.model.IModel; +import com.jozufozu.flywheel.core.model.Model; import com.jozufozu.flywheel.util.AttribUtil; public class BufferedModel implements IBufferedModel { - protected final IModel model; + protected final Model model; protected final GlPrimitive primitiveMode; protected GlBuffer vbo; protected boolean deleted; - public BufferedModel(GlPrimitive primitiveMode, IModel model) { + public BufferedModel(GlPrimitive primitiveMode, Model model) { this.model = model; this.primitiveMode = primitiveMode; diff --git a/src/main/java/com/jozufozu/flywheel/backend/model/ImmediateAllocator.java b/src/main/java/com/jozufozu/flywheel/backend/model/ImmediateAllocator.java index 7da671ca0..e290549e4 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/model/ImmediateAllocator.java +++ b/src/main/java/com/jozufozu/flywheel/backend/model/ImmediateAllocator.java @@ -1,13 +1,13 @@ package com.jozufozu.flywheel.backend.model; -import com.jozufozu.flywheel.core.model.IModel; +import com.jozufozu.flywheel.core.model.Model; public class ImmediateAllocator implements ModelAllocator { public static final ImmediateAllocator INSTANCE = new ImmediateAllocator(); @Override - public IBufferedModel alloc(IModel model, Callback allocationCallback) { + public IBufferedModel alloc(Model model, Callback allocationCallback) { IndexedModel out = new IndexedModel(model); allocationCallback.onAlloc(out); return out; diff --git a/src/main/java/com/jozufozu/flywheel/backend/model/IndexedModel.java b/src/main/java/com/jozufozu/flywheel/backend/model/IndexedModel.java index ab0de034f..8008b74c6 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/model/IndexedModel.java +++ b/src/main/java/com/jozufozu/flywheel/backend/model/IndexedModel.java @@ -4,7 +4,7 @@ import org.lwjgl.opengl.GL20; import com.jozufozu.flywheel.backend.Backend; import com.jozufozu.flywheel.backend.gl.GlPrimitive; -import com.jozufozu.flywheel.core.model.IModel; +import com.jozufozu.flywheel.core.model.Model; /** * An indexed triangle model. Just what the driver ordered. @@ -15,7 +15,7 @@ public class IndexedModel extends BufferedModel { protected ElementBuffer ebo; - public IndexedModel(IModel model) { + public IndexedModel(Model model) { super(GlPrimitive.TRIANGLES, model); this.ebo = model.createEBO(); diff --git a/src/main/java/com/jozufozu/flywheel/backend/model/ModelAllocator.java b/src/main/java/com/jozufozu/flywheel/backend/model/ModelAllocator.java index afa45904a..8756f9427 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/model/ModelAllocator.java +++ b/src/main/java/com/jozufozu/flywheel/backend/model/ModelAllocator.java @@ -1,6 +1,6 @@ package com.jozufozu.flywheel.backend.model; -import com.jozufozu.flywheel.core.model.IModel; +import com.jozufozu.flywheel.core.model.Model; public interface ModelAllocator { /** @@ -9,7 +9,7 @@ public interface ModelAllocator { * @param model The model to allocate. * @return A handle to the allocated model. */ - IBufferedModel alloc(IModel model, Callback allocationCallback); + IBufferedModel alloc(Model model, Callback allocationCallback); @FunctionalInterface interface Callback { diff --git a/src/main/java/com/jozufozu/flywheel/backend/model/ModelPool.java b/src/main/java/com/jozufozu/flywheel/backend/model/ModelPool.java index c905ca44f..61eab6fed 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/model/ModelPool.java +++ b/src/main/java/com/jozufozu/flywheel/backend/model/ModelPool.java @@ -10,7 +10,7 @@ import com.jozufozu.flywheel.backend.gl.buffer.GlBuffer; import com.jozufozu.flywheel.backend.gl.buffer.GlBufferType; import com.jozufozu.flywheel.backend.gl.buffer.MappedBuffer; import com.jozufozu.flywheel.backend.gl.buffer.MappedGlBuffer; -import com.jozufozu.flywheel.core.model.IModel; +import com.jozufozu.flywheel.core.model.Model; import com.jozufozu.flywheel.util.AttribUtil; public class ModelPool implements ModelAllocator { @@ -47,7 +47,7 @@ public class ModelPool implements ModelAllocator { * @return A handle to the allocated model. */ @Override - public PooledModel alloc(IModel model, Callback callback) { + public PooledModel alloc(Model model, Callback callback) { PooledModel bufferedModel = new PooledModel(model, vertices); bufferedModel.callback = callback; vertices += model.vertexCount(); @@ -153,12 +153,12 @@ public class ModelPool implements ModelAllocator { private final ElementBuffer ebo; private Callback callback; - private final IModel model; + private final Model model; private int first; private boolean remove; - public PooledModel(IModel model, int first) { + public PooledModel(Model model, int first) { this.model = model; this.first = first; ebo = model.createEBO(); diff --git a/src/main/java/com/jozufozu/flywheel/backend/model/ModelRenderer.java b/src/main/java/com/jozufozu/flywheel/backend/model/ModelRenderer.java index 72a11d601..b6802caad 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/model/ModelRenderer.java +++ b/src/main/java/com/jozufozu/flywheel/backend/model/ModelRenderer.java @@ -2,16 +2,16 @@ package com.jozufozu.flywheel.backend.model; import java.util.function.Supplier; -import com.jozufozu.flywheel.core.model.IModel; +import com.jozufozu.flywheel.core.model.Model; public class ModelRenderer { - protected Supplier modelSupplier; + protected Supplier modelSupplier; protected IBufferedModel model; protected boolean initialized; - public ModelRenderer(Supplier modelSupplier) { + public ModelRenderer(Supplier modelSupplier) { this.modelSupplier = modelSupplier; } @@ -34,7 +34,7 @@ public class ModelRenderer { protected void init() { initialized = true; - IModel model = modelSupplier.get(); + Model model = modelSupplier.get(); if (model.empty()) return; diff --git a/src/main/java/com/jozufozu/flywheel/backend/pipeline/IShaderPipeline.java b/src/main/java/com/jozufozu/flywheel/backend/pipeline/ShaderCompiler.java similarity index 54% rename from src/main/java/com/jozufozu/flywheel/backend/pipeline/IShaderPipeline.java rename to src/main/java/com/jozufozu/flywheel/backend/pipeline/ShaderCompiler.java index 370281fcd..4a559519a 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/pipeline/IShaderPipeline.java +++ b/src/main/java/com/jozufozu/flywheel/backend/pipeline/ShaderCompiler.java @@ -1,15 +1,15 @@ package com.jozufozu.flywheel.backend.pipeline; -import com.jozufozu.flywheel.core.shader.IMultiProgram; -import com.jozufozu.flywheel.core.shader.WorldProgram; +import com.jozufozu.flywheel.backend.gl.shader.GlProgram; +import com.jozufozu.flywheel.core.shader.GameStateProgram; import com.jozufozu.flywheel.core.shader.spec.ProgramSpec; /** * The main interface for compiling usable shaders from program specs. * @param

the type of the program that this pipeline compiles. */ -public interface IShaderPipeline

{ +public interface ShaderCompiler

{ - IMultiProgram

compile(ProgramSpec spec); + GameStateProgram

compile(ProgramSpec spec); } diff --git a/src/main/java/com/jozufozu/flywheel/backend/pipeline/WorldShaderPipeline.java b/src/main/java/com/jozufozu/flywheel/backend/pipeline/WorldShaderCompiler.java similarity index 83% rename from src/main/java/com/jozufozu/flywheel/backend/pipeline/WorldShaderPipeline.java rename to src/main/java/com/jozufozu/flywheel/backend/pipeline/WorldShaderCompiler.java index f26126c23..e3e6486b4 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/pipeline/WorldShaderPipeline.java +++ b/src/main/java/com/jozufozu/flywheel/backend/pipeline/WorldShaderCompiler.java @@ -9,34 +9,33 @@ import com.jozufozu.flywheel.backend.source.FileResolution; import com.jozufozu.flywheel.backend.source.SourceFile; import com.jozufozu.flywheel.core.shader.ExtensibleGlProgram; import com.jozufozu.flywheel.core.shader.GameStateProgram; -import com.jozufozu.flywheel.core.shader.IMultiProgram; import com.jozufozu.flywheel.core.shader.WorldProgram; import com.jozufozu.flywheel.core.shader.spec.ProgramSpec; import com.jozufozu.flywheel.core.shader.spec.ProgramState; import net.minecraft.resources.ResourceLocation; -public class WorldShaderPipeline

implements IShaderPipeline

{ +public class WorldShaderCompiler

implements ShaderCompiler

{ private final ExtensibleGlProgram.Factory

factory; private final Template template; private final FileResolution header; - public WorldShaderPipeline(ExtensibleGlProgram.Factory

factory, Template template, FileResolution header) { + public WorldShaderCompiler(ExtensibleGlProgram.Factory

factory, Template template, FileResolution header) { this.factory = factory; this.template = template; this.header = header; } - public IMultiProgram

compile(ProgramSpec spec) { + public GameStateProgram

compile(ProgramSpec spec) { SourceFile file = spec.getSource().getFile(); return compile(spec.name, file, spec.getStates()); } - public IMultiProgram

compile(ResourceLocation name, SourceFile file, List variants) { + public GameStateProgram

compile(ResourceLocation name, SourceFile file, List variants) { WorldShader shader = new WorldShader(name, template, header) .setMainSource(file); diff --git a/src/main/java/com/jozufozu/flywheel/backend/source/FileResolution.java b/src/main/java/com/jozufozu/flywheel/backend/source/FileResolution.java index ba4e5f343..471d5b0c8 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/source/FileResolution.java +++ b/src/main/java/com/jozufozu/flywheel/backend/source/FileResolution.java @@ -62,7 +62,7 @@ public class FileResolution { * Called after all files are loaded. If we can't find the file here, it doesn't exist. *

*/ - void resolve(ISourceHolder sources) { + void resolve(SourceHolder sources) { try { file = sources.findSource(fileLoc); diff --git a/src/main/java/com/jozufozu/flywheel/backend/source/Resolver.java b/src/main/java/com/jozufozu/flywheel/backend/source/Resolver.java index 185fcd4af..4377d8496 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/source/Resolver.java +++ b/src/main/java/com/jozufozu/flywheel/backend/source/Resolver.java @@ -28,7 +28,7 @@ public class Resolver { /** * Try and resolve all referenced source files, printing errors if any aren't found. */ - public void resolve(ISourceHolder sources) { + public void resolve(SourceHolder sources) { for (FileResolution resolution : resolutions.values()) { resolution.resolve(sources); } diff --git a/src/main/java/com/jozufozu/flywheel/backend/source/ShaderSources.java b/src/main/java/com/jozufozu/flywheel/backend/source/ShaderSources.java index b53893a76..d6c291fde 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/source/ShaderSources.java +++ b/src/main/java/com/jozufozu/flywheel/backend/source/ShaderSources.java @@ -17,7 +17,7 @@ import net.minecraft.resources.ResourceLocation; /** * The main object for loading and parsing source files. */ -public class ShaderSources implements ISourceHolder { +public class ShaderSources implements SourceHolder { public static final String SHADER_DIR = "flywheel/shaders/"; public static final ArrayList EXTENSIONS = Lists.newArrayList(".vert", ".vsh", ".frag", ".fsh", ".glsl"); diff --git a/src/main/java/com/jozufozu/flywheel/backend/source/ISourceHolder.java b/src/main/java/com/jozufozu/flywheel/backend/source/SourceHolder.java similarity index 86% rename from src/main/java/com/jozufozu/flywheel/backend/source/ISourceHolder.java rename to src/main/java/com/jozufozu/flywheel/backend/source/SourceHolder.java index df209dcf7..9d25cbaea 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/source/ISourceHolder.java +++ b/src/main/java/com/jozufozu/flywheel/backend/source/SourceHolder.java @@ -6,7 +6,7 @@ import net.minecraft.resources.ResourceLocation; * A minimal source file lookup function. */ @FunctionalInterface -public interface ISourceHolder { +public interface SourceHolder { SourceFile findSource(ResourceLocation name); } diff --git a/src/main/java/com/jozufozu/flywheel/backend/state/IRenderState.java b/src/main/java/com/jozufozu/flywheel/backend/state/IRenderState.java index b24a755f8..d488a08ca 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/state/IRenderState.java +++ b/src/main/java/com/jozufozu/flywheel/backend/state/IRenderState.java @@ -6,6 +6,10 @@ import com.jozufozu.flywheel.backend.gl.GlTextureUnit; import net.minecraft.resources.ResourceLocation; +/** + * @deprecated TODO: Rework this to be more in-line/convertable with vanilla + */ +@Deprecated public interface IRenderState { void bind(); diff --git a/src/main/java/com/jozufozu/flywheel/core/Contexts.java b/src/main/java/com/jozufozu/flywheel/core/Contexts.java index 99eb438de..908b39b71 100644 --- a/src/main/java/com/jozufozu/flywheel/core/Contexts.java +++ b/src/main/java/com/jozufozu/flywheel/core/Contexts.java @@ -3,9 +3,9 @@ package com.jozufozu.flywheel.core; import com.jozufozu.flywheel.Flywheel; import com.jozufozu.flywheel.backend.Backend; import com.jozufozu.flywheel.backend.SpecMetaRegistry; -import com.jozufozu.flywheel.backend.pipeline.IShaderPipeline; +import com.jozufozu.flywheel.backend.pipeline.ShaderCompiler; import com.jozufozu.flywheel.backend.pipeline.InstancingTemplate; -import com.jozufozu.flywheel.backend.pipeline.WorldShaderPipeline; +import com.jozufozu.flywheel.backend.pipeline.WorldShaderCompiler; import com.jozufozu.flywheel.backend.source.FileResolution; import com.jozufozu.flywheel.backend.source.Resolver; import com.jozufozu.flywheel.core.crumbling.CrumblingProgram; @@ -32,8 +32,8 @@ public class Contexts { FileResolution crumblingBuiltins = Resolver.INSTANCE.findShader(ResourceUtil.subPath(Names.CRUMBLING, ".glsl")); FileResolution worldBuiltins = Resolver.INSTANCE.findShader(ResourceUtil.subPath(Names.WORLD, ".glsl")); - IShaderPipeline crumblingPipeline = new WorldShaderPipeline<>(CrumblingProgram::new, InstancingTemplate.INSTANCE, crumblingBuiltins); - IShaderPipeline worldPipeline = new WorldShaderPipeline<>(WorldProgram::new, InstancingTemplate.INSTANCE, worldBuiltins); + ShaderCompiler crumblingPipeline = new WorldShaderCompiler<>(CrumblingProgram::new, InstancingTemplate.INSTANCE, crumblingBuiltins); + ShaderCompiler worldPipeline = new WorldShaderCompiler<>(WorldProgram::new, InstancingTemplate.INSTANCE, worldBuiltins); CRUMBLING = backend.register(WorldContext.builder(backend, Names.CRUMBLING).build(crumblingPipeline)); WORLD = backend.register(WorldContext.builder(backend, Names.WORLD).build(worldPipeline)); diff --git a/src/main/java/com/jozufozu/flywheel/core/WorldContext.java b/src/main/java/com/jozufozu/flywheel/core/WorldContext.java index 063d8d27a..1b995f1a5 100644 --- a/src/main/java/com/jozufozu/flywheel/core/WorldContext.java +++ b/src/main/java/com/jozufozu/flywheel/core/WorldContext.java @@ -6,24 +6,24 @@ import java.util.function.Supplier; import java.util.stream.Stream; import com.jozufozu.flywheel.backend.Backend; -import com.jozufozu.flywheel.backend.IShaderContext; +import com.jozufozu.flywheel.backend.ShaderContext; import com.jozufozu.flywheel.backend.material.MaterialSpec; -import com.jozufozu.flywheel.backend.pipeline.IShaderPipeline; -import com.jozufozu.flywheel.core.shader.IMultiProgram; +import com.jozufozu.flywheel.backend.pipeline.ShaderCompiler; +import com.jozufozu.flywheel.core.shader.GameStateProgram; import com.jozufozu.flywheel.core.shader.WorldProgram; import com.jozufozu.flywheel.core.shader.spec.ProgramSpec; import net.minecraft.resources.ResourceLocation; -public class WorldContext

implements IShaderContext

{ +public class WorldContext

implements ShaderContext

{ public final Backend backend; - protected final Map> programs = new HashMap<>(); + protected final Map> programs = new HashMap<>(); protected final ResourceLocation name; protected final Supplier> specStream; - public final IShaderPipeline

pipeline; + public final ShaderCompiler

pipeline; - public WorldContext(Backend backend, ResourceLocation name, Supplier> specStream, IShaderPipeline

pipeline) { + public WorldContext(Backend backend, ResourceLocation name, Supplier> specStream, ShaderCompiler

pipeline) { this.backend = backend; this.name = name; this.specStream = specStream; @@ -61,7 +61,7 @@ public class WorldContext

implements IShaderContext

{ @Override public void delete() { programs.values() - .forEach(IMultiProgram::delete); + .forEach(GameStateProgram::delete); programs.clear(); } @@ -84,7 +84,7 @@ public class WorldContext

implements IShaderContext

{ return this; } - public

WorldContext

build(IShaderPipeline

pipeline) { + public

WorldContext

build(ShaderCompiler

pipeline) { if (specStream == null) { specStream = () -> backend.allMaterials() .stream() diff --git a/src/main/java/com/jozufozu/flywheel/core/materials/BasicData.java b/src/main/java/com/jozufozu/flywheel/core/materials/BasicData.java index e6e9c537a..e697bfe50 100644 --- a/src/main/java/com/jozufozu/flywheel/core/materials/BasicData.java +++ b/src/main/java/com/jozufozu/flywheel/core/materials/BasicData.java @@ -1,11 +1,9 @@ package com.jozufozu.flywheel.core.materials; -import org.lwjgl.system.MemoryUtil; - import com.jozufozu.flywheel.backend.gl.buffer.VecBuffer; import com.jozufozu.flywheel.backend.instancing.InstanceData; -public abstract class BasicData extends InstanceData implements IFlatLight { +public abstract class BasicData extends InstanceData implements FlatLight { public byte blockLight; public byte skyLight; diff --git a/src/main/java/com/jozufozu/flywheel/core/materials/IFlatLight.java b/src/main/java/com/jozufozu/flywheel/core/materials/FlatLight.java similarity index 77% rename from src/main/java/com/jozufozu/flywheel/core/materials/IFlatLight.java rename to src/main/java/com/jozufozu/flywheel/core/materials/FlatLight.java index 93c90dbea..53be55243 100644 --- a/src/main/java/com/jozufozu/flywheel/core/materials/IFlatLight.java +++ b/src/main/java/com/jozufozu/flywheel/core/materials/FlatLight.java @@ -7,21 +7,19 @@ import com.jozufozu.flywheel.backend.instancing.InstanceData; * if they wish to make use of Flywheel's provided light update methods. *

* This only covers flat lighting, smooth lighting is still TODO. - * - * @param The name of the class that implements this interface. */ -public interface IFlatLight> { +public interface FlatLight { /** * @param blockLight An integer in the range [0, 15] representing the * amount of block light this instance should receive. * @return this */ - D setBlockLight(int blockLight); + FlatLight setBlockLight(int blockLight); /** * @param skyLight An integer in the range [0, 15] representing the * amount of sky light this instance should receive. * @return this */ - D setSkyLight(int skyLight); + FlatLight setSkyLight(int skyLight); } diff --git a/src/main/java/com/jozufozu/flywheel/core/model/BakedModelModel.java b/src/main/java/com/jozufozu/flywheel/core/model/BakedModelModel.java index 314cf9092..a5cd7d888 100644 --- a/src/main/java/com/jozufozu/flywheel/core/model/BakedModelModel.java +++ b/src/main/java/com/jozufozu/flywheel/core/model/BakedModelModel.java @@ -25,7 +25,7 @@ import net.minecraft.core.Direction; import com.mojang.math.Vector3f; import net.minecraft.core.Vec3i; -public class BakedModelModel implements IModel { +public class BakedModelModel implements Model { // DOWN, UP, NORTH, SOUTH, WEST, EAST, null private static final Direction[] dirs; diff --git a/src/main/java/com/jozufozu/flywheel/core/model/BlockModel.java b/src/main/java/com/jozufozu/flywheel/core/model/BlockModel.java index 7cd27db3b..1ecab0eda 100644 --- a/src/main/java/com/jozufozu/flywheel/core/model/BlockModel.java +++ b/src/main/java/com/jozufozu/flywheel/core/model/BlockModel.java @@ -2,8 +2,6 @@ package com.jozufozu.flywheel.core.model; import java.util.Arrays; -import org.lwjgl.opengl.GL11; - import com.jozufozu.flywheel.backend.gl.attrib.VertexFormat; import com.jozufozu.flywheel.backend.gl.buffer.VecBuffer; import com.jozufozu.flywheel.core.Formats; @@ -25,7 +23,7 @@ import net.minecraft.core.BlockPos; /** * A model of a single block. */ -public class BlockModel implements IModel { +public class BlockModel implements Model { private static final PoseStack IDENTITY = new PoseStack(); private final BufferBuilderReader reader; diff --git a/src/main/java/com/jozufozu/flywheel/core/model/IModel.java b/src/main/java/com/jozufozu/flywheel/core/model/Model.java similarity index 98% rename from src/main/java/com/jozufozu/flywheel/core/model/IModel.java rename to src/main/java/com/jozufozu/flywheel/core/model/Model.java index b7ffd1a1b..e9f92ed95 100644 --- a/src/main/java/com/jozufozu/flywheel/core/model/IModel.java +++ b/src/main/java/com/jozufozu/flywheel/core/model/Model.java @@ -25,7 +25,7 @@ import com.jozufozu.flywheel.core.QuadConverter; * assert model.size() == final - initial; * } */ -public interface IModel { +public interface Model { /** * Copy this model into the given buffer. diff --git a/src/main/java/com/jozufozu/flywheel/core/model/ModelPart.java b/src/main/java/com/jozufozu/flywheel/core/model/ModelPart.java index 6ccb583e3..9606d2e25 100644 --- a/src/main/java/com/jozufozu/flywheel/core/model/ModelPart.java +++ b/src/main/java/com/jozufozu/flywheel/core/model/ModelPart.java @@ -6,7 +6,7 @@ import com.jozufozu.flywheel.backend.gl.attrib.VertexFormat; import com.jozufozu.flywheel.backend.gl.buffer.VecBuffer; import com.jozufozu.flywheel.core.Formats; -public class ModelPart implements IModel { +public class ModelPart implements Model { private final List cuboids; private int vertices; diff --git a/src/main/java/com/jozufozu/flywheel/core/model/WorldModel.java b/src/main/java/com/jozufozu/flywheel/core/model/WorldModel.java index 938d5cdca..b01c3c788 100644 --- a/src/main/java/com/jozufozu/flywheel/core/model/WorldModel.java +++ b/src/main/java/com/jozufozu/flywheel/core/model/WorldModel.java @@ -12,7 +12,7 @@ import net.minecraft.client.renderer.RenderType; import net.minecraft.world.level.BlockAndTintGetter; import net.minecraft.world.level.levelgen.structure.templatesystem.StructureTemplate; -public class WorldModel implements IModel { +public class WorldModel implements Model { private final BufferBuilderReader reader; diff --git a/src/main/java/com/jozufozu/flywheel/core/shader/GameStateProgram.java b/src/main/java/com/jozufozu/flywheel/core/shader/GameStateProgram.java index 9b67fdf37..bd9742928 100644 --- a/src/main/java/com/jozufozu/flywheel/core/shader/GameStateProgram.java +++ b/src/main/java/com/jozufozu/flywheel/core/shader/GameStateProgram.java @@ -2,13 +2,14 @@ package com.jozufozu.flywheel.core.shader; import java.util.ArrayList; import java.util.List; +import java.util.function.Supplier; import com.google.common.collect.ImmutableList; import com.jozufozu.flywheel.backend.gl.shader.GlProgram; import com.jozufozu.flywheel.core.shader.spec.IGameStateCondition; import com.jozufozu.flywheel.util.Pair; -public class GameStateProgram

implements IMultiProgram

{ +public class GameStateProgram

implements Supplier

{ private final List> variants; private final P fallback; @@ -18,6 +19,9 @@ public class GameStateProgram

implements IMultiProgram

{ this.fallback = fallback; } + /** + * Get the shader program most suited for the current game state. + */ @Override public P get() { for (Pair variant : variants) { @@ -28,7 +32,9 @@ public class GameStateProgram

implements IMultiProgram

{ return fallback; } - @Override + /** + * Delete all associated programs. + */ public void delete() { for (Pair variant : variants) { variant.getSecond() @@ -55,7 +61,7 @@ public class GameStateProgram

implements IMultiProgram

{ return this; } - public IMultiProgram

build() { + public GameStateProgram

build() { return new GameStateProgram<>(ImmutableList.copyOf(variants), fallback); } } diff --git a/src/main/java/com/jozufozu/flywheel/core/shader/IMultiProgram.java b/src/main/java/com/jozufozu/flywheel/core/shader/IMultiProgram.java deleted file mode 100644 index 924a989a5..000000000 --- a/src/main/java/com/jozufozu/flywheel/core/shader/IMultiProgram.java +++ /dev/null @@ -1,26 +0,0 @@ -package com.jozufozu.flywheel.core.shader; - -import java.util.function.Supplier; - -import com.jozufozu.flywheel.backend.gl.shader.GlProgram; - -/** - * Encapsulates any number of shader programs for use in similar contexts. - * Allows the implementor to choose which shader program to use based on arbitrary state. - * - * @param

- */ -public interface IMultiProgram

extends Supplier

{ - - /** - * Get the shader program most suited for the current game state. - * - * @return The one true program. - */ - P get(); - - /** - * Delete all shader programs encapsulated by your implementation. - */ - void delete(); -} diff --git a/src/main/java/com/jozufozu/flywheel/vanilla/BellInstance.java b/src/main/java/com/jozufozu/flywheel/vanilla/BellInstance.java index cddfddec7..418575abf 100644 --- a/src/main/java/com/jozufozu/flywheel/vanilla/BellInstance.java +++ b/src/main/java/com/jozufozu/flywheel/vanilla/BellInstance.java @@ -1,6 +1,6 @@ package com.jozufozu.flywheel.vanilla; -import com.jozufozu.flywheel.backend.instancing.IDynamicInstance; +import com.jozufozu.flywheel.backend.instancing.DynamicInstance; import com.jozufozu.flywheel.backend.instancing.tile.TileEntityInstance; import com.jozufozu.flywheel.backend.material.MaterialManager; import com.jozufozu.flywheel.core.Materials; @@ -14,7 +14,7 @@ import net.minecraft.util.Mth; import com.mojang.math.Quaternion; import com.mojang.math.Vector3f; -public class BellInstance extends TileEntityInstance implements IDynamicInstance { +public class BellInstance extends TileEntityInstance implements DynamicInstance { private final OrientedData bell; diff --git a/src/main/java/com/jozufozu/flywheel/vanilla/ChestInstance.java b/src/main/java/com/jozufozu/flywheel/vanilla/ChestInstance.java index 905f86fee..8737b7dee 100644 --- a/src/main/java/com/jozufozu/flywheel/vanilla/ChestInstance.java +++ b/src/main/java/com/jozufozu/flywheel/vanilla/ChestInstance.java @@ -4,7 +4,7 @@ import java.util.Calendar; import javax.annotation.Nonnull; -import com.jozufozu.flywheel.backend.instancing.IDynamicInstance; +import com.jozufozu.flywheel.backend.instancing.DynamicInstance; import com.jozufozu.flywheel.backend.instancing.tile.TileEntityInstance; import com.jozufozu.flywheel.backend.material.MaterialManager; import com.jozufozu.flywheel.backend.state.TextureRenderState; @@ -29,7 +29,7 @@ import net.minecraft.world.level.block.DoubleBlockCombiner; import com.mojang.math.Quaternion; import com.mojang.math.Vector3f; -public class ChestInstance extends TileEntityInstance implements IDynamicInstance { +public class ChestInstance extends TileEntityInstance implements DynamicInstance { private final MatrixTransformStack stack = new MatrixTransformStack(); private final OrientedData body; diff --git a/src/main/java/com/jozufozu/flywheel/vanilla/MinecartInstance.java b/src/main/java/com/jozufozu/flywheel/vanilla/MinecartInstance.java index 820b4d364..c3da45544 100644 --- a/src/main/java/com/jozufozu/flywheel/vanilla/MinecartInstance.java +++ b/src/main/java/com/jozufozu/flywheel/vanilla/MinecartInstance.java @@ -1,13 +1,13 @@ package com.jozufozu.flywheel.vanilla; -import com.jozufozu.flywheel.backend.instancing.IDynamicInstance; -import com.jozufozu.flywheel.backend.instancing.ITickableInstance; +import com.jozufozu.flywheel.backend.instancing.DynamicInstance; +import com.jozufozu.flywheel.backend.instancing.TickableInstance; import com.jozufozu.flywheel.backend.instancing.entity.EntityInstance; import com.jozufozu.flywheel.backend.material.MaterialManager; import com.jozufozu.flywheel.backend.state.TextureRenderState; import com.jozufozu.flywheel.core.Materials; import com.jozufozu.flywheel.core.materials.model.ModelData; -import com.jozufozu.flywheel.core.model.IModel; +import com.jozufozu.flywheel.core.model.Model; import com.jozufozu.flywheel.core.model.ModelPart; import com.jozufozu.flywheel.util.AnimationTickHolder; import com.jozufozu.flywheel.util.transform.MatrixTransformStack; @@ -21,7 +21,7 @@ import net.minecraft.util.Mth; import net.minecraft.world.phys.Vec3; import com.mojang.math.Vector3f; -public class MinecartInstance extends EntityInstance implements IDynamicInstance, ITickableInstance { +public class MinecartInstance extends EntityInstance implements DynamicInstance, TickableInstance { private static final ResourceLocation MINECART_LOCATION = new ResourceLocation("textures/entity/minecart.png"); @@ -153,7 +153,7 @@ public class MinecartInstance extends EntityInstance .createInstance(); } - private IModel getBodyModel() { + private Model getBodyModel() { int y = -3; return ModelPart.builder(64, 32) .cuboid().invertYZ().start(-10, -8, -y).size(20, 16, 2).textureOffset(0, 10).rotateX(((float)Math.PI / 2F)).endCuboid() diff --git a/src/main/java/com/jozufozu/flywheel/vanilla/ShulkerBoxInstance.java b/src/main/java/com/jozufozu/flywheel/vanilla/ShulkerBoxInstance.java index 334778b89..1397dded1 100644 --- a/src/main/java/com/jozufozu/flywheel/vanilla/ShulkerBoxInstance.java +++ b/src/main/java/com/jozufozu/flywheel/vanilla/ShulkerBoxInstance.java @@ -1,6 +1,6 @@ package com.jozufozu.flywheel.vanilla; -import com.jozufozu.flywheel.backend.instancing.IDynamicInstance; +import com.jozufozu.flywheel.backend.instancing.DynamicInstance; import com.jozufozu.flywheel.backend.instancing.tile.TileEntityInstance; import com.jozufozu.flywheel.backend.material.MaterialManager; import com.jozufozu.flywheel.core.Materials; @@ -18,7 +18,7 @@ import net.minecraft.core.Direction; import com.mojang.math.Quaternion; import com.mojang.math.Vector3f; -public class ShulkerBoxInstance extends TileEntityInstance implements IDynamicInstance { +public class ShulkerBoxInstance extends TileEntityInstance implements DynamicInstance { private final TextureAtlasSprite texture;