mirror of
https://github.com/Jozufozu/Flywheel.git
synced 2025-01-07 12:56:31 +01:00
Untyped instance types
- Add SimpleInstanceType and builder. - Remove OrientedType and TransformedType classes in favor of builder.
This commit is contained in:
parent
373097742a
commit
5a31bd5d63
5 changed files with 163 additions and 138 deletions
|
@ -2,11 +2,52 @@ package com.jozufozu.flywheel.lib.instance;
|
||||||
|
|
||||||
import org.jetbrains.annotations.ApiStatus;
|
import org.jetbrains.annotations.ApiStatus;
|
||||||
|
|
||||||
|
import com.jozufozu.flywheel.Flywheel;
|
||||||
import com.jozufozu.flywheel.api.instance.InstanceType;
|
import com.jozufozu.flywheel.api.instance.InstanceType;
|
||||||
|
import com.jozufozu.flywheel.api.layout.FloatRepr;
|
||||||
|
import com.jozufozu.flywheel.api.layout.IntegerRepr;
|
||||||
|
import com.jozufozu.flywheel.api.layout.LayoutBuilder;
|
||||||
|
import com.jozufozu.flywheel.lib.layout.BufferLayout;
|
||||||
|
import com.jozufozu.flywheel.lib.layout.CommonItems;
|
||||||
|
|
||||||
public final class InstanceTypes {
|
public final class InstanceTypes {
|
||||||
public static final InstanceType<TransformedInstance> TRANSFORMED = InstanceType.REGISTRY.registerAndGet(new TransformedType());
|
public static final InstanceType<TransformedInstance> TRANSFORMED = SimpleInstanceType.builder(TransformedInstance::new)
|
||||||
public static final InstanceType<OrientedInstance> ORIENTED = InstanceType.REGISTRY.registerAndGet(new OrientedType());
|
.bufferLayout(BufferLayout.builder()
|
||||||
|
.addItem(CommonItems.LIGHT_COORD, "light")
|
||||||
|
.addItem(CommonItems.UNORM_4x8, "color")
|
||||||
|
.addItem(CommonItems.MAT4, "pose")
|
||||||
|
.addItem(CommonItems.MAT3, "normal")
|
||||||
|
.build())
|
||||||
|
.layout(LayoutBuilder.create()
|
||||||
|
.vector("light", IntegerRepr.SHORT, 2)
|
||||||
|
.vector("color", FloatRepr.NORMALIZED_UNSIGNED_BYTE, 4)
|
||||||
|
.matrix("pose", FloatRepr.FLOAT, 4)
|
||||||
|
.matrix("normal", FloatRepr.FLOAT, 3)
|
||||||
|
.build())
|
||||||
|
.writer(TransformedWriter.INSTANCE)
|
||||||
|
.vertexShader(Flywheel.rl("instance/transformed.vert"))
|
||||||
|
.cullShader(Flywheel.rl("instance/cull/transformed.glsl"))
|
||||||
|
.register();
|
||||||
|
|
||||||
|
public static final InstanceType<OrientedInstance> ORIENTED = SimpleInstanceType.builder(OrientedInstance::new)
|
||||||
|
.bufferLayout(BufferLayout.builder()
|
||||||
|
.addItem(CommonItems.LIGHT_COORD, "light")
|
||||||
|
.addItem(CommonItems.UNORM_4x8, "color")
|
||||||
|
.addItem(CommonItems.VEC3, "position")
|
||||||
|
.addItem(CommonItems.VEC3, "pivot")
|
||||||
|
.addItem(CommonItems.VEC4, "rotation")
|
||||||
|
.build())
|
||||||
|
.layout(LayoutBuilder.create()
|
||||||
|
.vector("light", IntegerRepr.SHORT, 2)
|
||||||
|
.vector("color", FloatRepr.NORMALIZED_UNSIGNED_BYTE, 4)
|
||||||
|
.vector("position", FloatRepr.FLOAT, 3)
|
||||||
|
.vector("pivot", FloatRepr.FLOAT, 3)
|
||||||
|
.vector("rotation", FloatRepr.FLOAT, 4)
|
||||||
|
.build())
|
||||||
|
.writer(OrientedWriter.INSTANCE)
|
||||||
|
.vertexShader(Flywheel.rl("instance/oriented.vert"))
|
||||||
|
.cullShader(Flywheel.rl("instance/cull/oriented.glsl"))
|
||||||
|
.register();
|
||||||
|
|
||||||
private InstanceTypes() {
|
private InstanceTypes() {
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,67 +0,0 @@
|
||||||
package com.jozufozu.flywheel.lib.instance;
|
|
||||||
|
|
||||||
import com.jozufozu.flywheel.Flywheel;
|
|
||||||
import com.jozufozu.flywheel.api.instance.InstanceHandle;
|
|
||||||
import com.jozufozu.flywheel.api.instance.InstanceType;
|
|
||||||
import com.jozufozu.flywheel.api.instance.InstanceWriter;
|
|
||||||
import com.jozufozu.flywheel.api.layout.FloatRepr;
|
|
||||||
import com.jozufozu.flywheel.api.layout.IntegerRepr;
|
|
||||||
import com.jozufozu.flywheel.api.layout.Layout;
|
|
||||||
import com.jozufozu.flywheel.api.layout.LayoutBuilder;
|
|
||||||
import com.jozufozu.flywheel.lib.layout.BufferLayout;
|
|
||||||
import com.jozufozu.flywheel.lib.layout.CommonItems;
|
|
||||||
|
|
||||||
import net.minecraft.resources.ResourceLocation;
|
|
||||||
|
|
||||||
public class OrientedType implements InstanceType<OrientedInstance> {
|
|
||||||
@Deprecated
|
|
||||||
private static final BufferLayout OLD_LAYOUT = BufferLayout.builder()
|
|
||||||
.addItem(CommonItems.LIGHT_COORD, "light")
|
|
||||||
.addItem(CommonItems.UNORM_4x8, "color")
|
|
||||||
.addItem(CommonItems.VEC3, "position")
|
|
||||||
.addItem(CommonItems.VEC3, "pivot")
|
|
||||||
.addItem(CommonItems.VEC4, "rotation")
|
|
||||||
.build();
|
|
||||||
|
|
||||||
private static final Layout LAYOUT = LayoutBuilder.create()
|
|
||||||
.vector("light", IntegerRepr.SHORT, 2)
|
|
||||||
.vector("color", FloatRepr.NORMALIZED_UNSIGNED_BYTE, 4)
|
|
||||||
.vector("position", FloatRepr.FLOAT, 3)
|
|
||||||
.vector("pivot", FloatRepr.FLOAT, 3)
|
|
||||||
.vector("rotation", FloatRepr.FLOAT, 4)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
private static final ResourceLocation VERTEX_SHADER = Flywheel.rl("instance/oriented.vert");
|
|
||||||
private static final ResourceLocation CULL_SHADER = Flywheel.rl("instance/cull/oriented.glsl");
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public OrientedInstance create(InstanceHandle handle) {
|
|
||||||
return new OrientedInstance(this, handle);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
@Deprecated
|
|
||||||
public BufferLayout oldLayout() {
|
|
||||||
return OLD_LAYOUT;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Layout layout() {
|
|
||||||
return LAYOUT;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public InstanceWriter<OrientedInstance> writer() {
|
|
||||||
return OrientedWriter.INSTANCE;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public ResourceLocation vertexShader() {
|
|
||||||
return VERTEX_SHADER;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public ResourceLocation cullShader() {
|
|
||||||
return CULL_SHADER;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -0,0 +1,118 @@
|
||||||
|
package com.jozufozu.flywheel.lib.instance;
|
||||||
|
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
import com.jozufozu.flywheel.api.instance.Instance;
|
||||||
|
import com.jozufozu.flywheel.api.instance.InstanceHandle;
|
||||||
|
import com.jozufozu.flywheel.api.instance.InstanceType;
|
||||||
|
import com.jozufozu.flywheel.api.instance.InstanceWriter;
|
||||||
|
import com.jozufozu.flywheel.api.layout.Layout;
|
||||||
|
import com.jozufozu.flywheel.lib.layout.BufferLayout;
|
||||||
|
|
||||||
|
import net.minecraft.resources.ResourceLocation;
|
||||||
|
|
||||||
|
public class SimpleInstanceType<I extends Instance> implements InstanceType<I> {
|
||||||
|
private final Factory<I> factory;
|
||||||
|
private final BufferLayout bufferLayout;
|
||||||
|
private final Layout layout;
|
||||||
|
private final InstanceWriter<I> writer;
|
||||||
|
private final ResourceLocation vertexShader;
|
||||||
|
private final ResourceLocation cullShader;
|
||||||
|
|
||||||
|
public SimpleInstanceType(Factory<I> factory, BufferLayout bufferLayout, Layout layout, InstanceWriter<I> writer, ResourceLocation vertexShader, ResourceLocation cullShader) {
|
||||||
|
this.factory = factory;
|
||||||
|
this.bufferLayout = bufferLayout;
|
||||||
|
this.layout = layout;
|
||||||
|
this.writer = writer;
|
||||||
|
this.vertexShader = vertexShader;
|
||||||
|
this.cullShader = cullShader;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <I extends Instance> Builder<I> builder(Factory<I> factory) {
|
||||||
|
return new Builder<>(factory);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public I create(InstanceHandle handle) {
|
||||||
|
return factory.create(this, handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public BufferLayout oldLayout() {
|
||||||
|
return bufferLayout;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Layout layout() {
|
||||||
|
return layout;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public InstanceWriter<I> writer() {
|
||||||
|
return writer;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ResourceLocation vertexShader() {
|
||||||
|
return vertexShader;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ResourceLocation cullShader() {
|
||||||
|
return cullShader;
|
||||||
|
}
|
||||||
|
|
||||||
|
@FunctionalInterface
|
||||||
|
public interface Factory<I extends Instance> {
|
||||||
|
I create(InstanceType<I> type, InstanceHandle handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class Builder<I extends Instance> {
|
||||||
|
private final Factory<I> factory;
|
||||||
|
private BufferLayout bufferLayout;
|
||||||
|
private Layout layout;
|
||||||
|
private InstanceWriter<I> writer;
|
||||||
|
private ResourceLocation vertexShader;
|
||||||
|
private ResourceLocation cullShader;
|
||||||
|
|
||||||
|
public Builder(Factory<I> factory) {
|
||||||
|
this.factory = factory;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder<I> bufferLayout(BufferLayout bufferLayout) {
|
||||||
|
this.bufferLayout = bufferLayout;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder<I> layout(Layout layout) {
|
||||||
|
this.layout = layout;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder<I> writer(InstanceWriter<I> writer) {
|
||||||
|
this.writer = writer;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder<I> vertexShader(ResourceLocation vertexShader) {
|
||||||
|
this.vertexShader = vertexShader;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder<I> cullShader(ResourceLocation cullShader) {
|
||||||
|
this.cullShader = cullShader;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public SimpleInstanceType<I> register() {
|
||||||
|
Objects.requireNonNull(bufferLayout);
|
||||||
|
Objects.requireNonNull(layout);
|
||||||
|
Objects.requireNonNull(writer);
|
||||||
|
Objects.requireNonNull(vertexShader);
|
||||||
|
Objects.requireNonNull(cullShader);
|
||||||
|
|
||||||
|
var out = new SimpleInstanceType<>(factory, bufferLayout, layout, writer, vertexShader, cullShader);
|
||||||
|
return InstanceType.REGISTRY.registerAndGet(out);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -12,8 +12,6 @@ import com.mojang.blaze3d.vertex.PoseStack;
|
||||||
import net.minecraft.util.Mth;
|
import net.minecraft.util.Mth;
|
||||||
|
|
||||||
public class TransformedInstance extends ColoredLitInstance implements Transform<TransformedInstance> {
|
public class TransformedInstance extends ColoredLitInstance implements Transform<TransformedInstance> {
|
||||||
private static final Matrix4f ZERO_MATRIX_4f = new Matrix4f();
|
|
||||||
private static final Matrix3f ZERO_MATRIX_3f = new Matrix3f();
|
|
||||||
|
|
||||||
public final Matrix4f model = new Matrix4f();
|
public final Matrix4f model = new Matrix4f();
|
||||||
public final Matrix3f normal = new Matrix3f();
|
public final Matrix3f normal = new Matrix3f();
|
||||||
|
@ -83,8 +81,8 @@ public class TransformedInstance extends ColoredLitInstance implements Transform
|
||||||
* </p>
|
* </p>
|
||||||
*/
|
*/
|
||||||
public TransformedInstance setEmptyTransform() {
|
public TransformedInstance setEmptyTransform() {
|
||||||
model.set(ZERO_MATRIX_4f);
|
model.zero();
|
||||||
normal.set(ZERO_MATRIX_3f);
|
normal.zero();
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,65 +0,0 @@
|
||||||
package com.jozufozu.flywheel.lib.instance;
|
|
||||||
|
|
||||||
import com.jozufozu.flywheel.Flywheel;
|
|
||||||
import com.jozufozu.flywheel.api.instance.InstanceHandle;
|
|
||||||
import com.jozufozu.flywheel.api.instance.InstanceType;
|
|
||||||
import com.jozufozu.flywheel.api.instance.InstanceWriter;
|
|
||||||
import com.jozufozu.flywheel.api.layout.FloatRepr;
|
|
||||||
import com.jozufozu.flywheel.api.layout.IntegerRepr;
|
|
||||||
import com.jozufozu.flywheel.api.layout.Layout;
|
|
||||||
import com.jozufozu.flywheel.api.layout.LayoutBuilder;
|
|
||||||
import com.jozufozu.flywheel.lib.layout.BufferLayout;
|
|
||||||
import com.jozufozu.flywheel.lib.layout.CommonItems;
|
|
||||||
|
|
||||||
import net.minecraft.resources.ResourceLocation;
|
|
||||||
|
|
||||||
public class TransformedType implements InstanceType<TransformedInstance> {
|
|
||||||
@Deprecated
|
|
||||||
private static final BufferLayout OLD_LAYOUT = BufferLayout.builder()
|
|
||||||
.addItem(CommonItems.LIGHT_COORD, "light")
|
|
||||||
.addItem(CommonItems.UNORM_4x8, "color")
|
|
||||||
.addItem(CommonItems.MAT4, "pose")
|
|
||||||
.addItem(CommonItems.MAT3, "normal")
|
|
||||||
.build();
|
|
||||||
|
|
||||||
private static final Layout LAYOUT = LayoutBuilder.create()
|
|
||||||
.vector("light", IntegerRepr.SHORT, 2)
|
|
||||||
.vector("color", FloatRepr.NORMALIZED_UNSIGNED_BYTE, 4)
|
|
||||||
.matrix("pose", FloatRepr.FLOAT, 4)
|
|
||||||
.matrix("normal", FloatRepr.FLOAT, 3)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
private static final ResourceLocation VERTEX_SHADER = Flywheel.rl("instance/transformed.vert");
|
|
||||||
private static final ResourceLocation CULL_SHADER = Flywheel.rl("instance/cull/transformed.glsl");
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public TransformedInstance create(InstanceHandle handle) {
|
|
||||||
return new TransformedInstance(this, handle);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
@Deprecated
|
|
||||||
public BufferLayout oldLayout() {
|
|
||||||
return OLD_LAYOUT;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Layout layout() {
|
|
||||||
return LAYOUT;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public InstanceWriter<TransformedInstance> writer() {
|
|
||||||
return TransformedWriter.INSTANCE;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public ResourceLocation vertexShader() {
|
|
||||||
return VERTEX_SHADER;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public ResourceLocation cullShader() {
|
|
||||||
return CULL_SHADER;
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in a new issue