mirror of
https://github.com/Jozufozu/Flywheel.git
synced 2025-01-27 21:37:56 +01:00
Introducing the Apple Pointer
- Support vertexAttribIPointer
This commit is contained in:
parent
00af8bda2e
commit
69de15d4de
18 changed files with 87 additions and 36 deletions
|
@ -1,16 +0,0 @@
|
||||||
package com.jozufozu.flywheel.backend.gl;
|
|
||||||
|
|
||||||
// TODO: support glVertexAttribIPointer
|
|
||||||
/**
|
|
||||||
* A bindable attribute in a vertex array.
|
|
||||||
*
|
|
||||||
* @param size The number of components in the attribute, e.g. 3 for a vec3.
|
|
||||||
* @param type The type of the attribute, e.g. GL_FLOAT.
|
|
||||||
* @param normalized Whether the data is normalized.
|
|
||||||
*/
|
|
||||||
public record VertexAttribute(int size, GlNumericType type, boolean normalized) {
|
|
||||||
|
|
||||||
public int getByteWidth() {
|
|
||||||
return size * type.getByteWidth();
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,8 +1,10 @@
|
||||||
package com.jozufozu.flywheel.backend.gl;
|
package com.jozufozu.flywheel.backend.gl.array;
|
||||||
|
|
||||||
import org.lwjgl.opengl.GL20;
|
import org.lwjgl.opengl.GL20;
|
||||||
import org.lwjgl.opengl.GL32;
|
import org.lwjgl.opengl.GL32;
|
||||||
|
|
||||||
|
import com.jozufozu.flywheel.backend.gl.GlObject;
|
||||||
|
import com.jozufozu.flywheel.backend.gl.GlStateTracker;
|
||||||
import com.jozufozu.flywheel.backend.gl.buffer.GlBuffer;
|
import com.jozufozu.flywheel.backend.gl.buffer.GlBuffer;
|
||||||
import com.jozufozu.flywheel.backend.gl.buffer.GlBufferType;
|
import com.jozufozu.flywheel.backend.gl.buffer.GlBufferType;
|
||||||
import com.jozufozu.flywheel.backend.gl.versioned.GlCompat;
|
import com.jozufozu.flywheel.backend.gl.versioned.GlCompat;
|
||||||
|
@ -80,14 +82,15 @@ public class GlVertexArray extends GlObject {
|
||||||
int i = startAttrib;
|
int i = startAttrib;
|
||||||
final int stride = type.getStride();
|
final int stride = type.getStride();
|
||||||
|
|
||||||
for (VertexAttribute attribute : type.getAttributes()) {
|
for (var attribute : type.getAttributes()) {
|
||||||
targets[i] = targetBuffer;
|
targets[i] = targetBuffer;
|
||||||
attributes[i] = attribute;
|
attributes[i] = attribute;
|
||||||
offsets[i] = offset;
|
offsets[i] = offset;
|
||||||
strides[i] = stride;
|
strides[i] = stride;
|
||||||
|
|
||||||
GL32.glVertexAttribPointer(i++, attribute.size(), attribute.type().getGlEnum(), attribute.normalized(), stride, offset);
|
attribute.pointer(offset, i, stride);
|
||||||
|
|
||||||
|
i++;
|
||||||
offset += attribute.getByteWidth();
|
offset += attribute.getByteWidth();
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -0,0 +1,7 @@
|
||||||
|
package com.jozufozu.flywheel.backend.gl.array;
|
||||||
|
|
||||||
|
public interface VertexAttribute {
|
||||||
|
int getByteWidth();
|
||||||
|
|
||||||
|
void pointer(long offset, int i, int stride);
|
||||||
|
}
|
|
@ -0,0 +1,25 @@
|
||||||
|
package com.jozufozu.flywheel.backend.gl.array;
|
||||||
|
|
||||||
|
import org.lwjgl.opengl.GL32;
|
||||||
|
|
||||||
|
import com.jozufozu.flywheel.backend.gl.GlNumericType;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A bindable attribute in a vertex array.
|
||||||
|
*
|
||||||
|
* @param type The type of the attribute, e.g. GL_FLOAT.
|
||||||
|
* @param size The number of components in the attribute, e.g. 3 for a vec3.
|
||||||
|
* @param normalized Whether the data is normalized.
|
||||||
|
*/
|
||||||
|
public record VertexAttributeF(GlNumericType type, int size, boolean normalized) implements VertexAttribute {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getByteWidth() {
|
||||||
|
return size * type.getByteWidth();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void pointer(long offset, int i, int stride) {
|
||||||
|
GL32.glVertexAttribPointer(i, size(), type().getGlEnum(), normalized(), stride, offset);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,24 @@
|
||||||
|
package com.jozufozu.flywheel.backend.gl.array;
|
||||||
|
|
||||||
|
import org.lwjgl.opengl.GL32;
|
||||||
|
|
||||||
|
import com.jozufozu.flywheel.backend.gl.GlNumericType;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A bindable attribute in a vertex array.
|
||||||
|
*
|
||||||
|
* @param type The type of the attribute, e.g. GL_INT.
|
||||||
|
* @param size The number of components in the attribute, e.g. 3 for a vec3.
|
||||||
|
*/
|
||||||
|
public record VertexAttributeI(GlNumericType type, int size) implements VertexAttribute {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getByteWidth() {
|
||||||
|
return size * type.getByteWidth();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void pointer(long offset, int i, int stride) {
|
||||||
|
GL32.glVertexAttribIPointer(i, size(), type().getGlEnum(), stride, offset);
|
||||||
|
}
|
||||||
|
}
|
|
@ -3,7 +3,7 @@ package com.jozufozu.flywheel.backend.instancing.instancing;
|
||||||
import com.jozufozu.flywheel.api.material.Material;
|
import com.jozufozu.flywheel.api.material.Material;
|
||||||
import com.jozufozu.flywheel.api.vertex.VertexType;
|
import com.jozufozu.flywheel.api.vertex.VertexType;
|
||||||
import com.jozufozu.flywheel.backend.gl.GlStateTracker;
|
import com.jozufozu.flywheel.backend.gl.GlStateTracker;
|
||||||
import com.jozufozu.flywheel.backend.gl.GlVertexArray;
|
import com.jozufozu.flywheel.backend.gl.array.GlVertexArray;
|
||||||
import com.jozufozu.flywheel.backend.model.MeshPool;
|
import com.jozufozu.flywheel.backend.model.MeshPool;
|
||||||
import com.jozufozu.flywheel.core.model.Mesh;
|
import com.jozufozu.flywheel.core.model.Mesh;
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,7 @@ import com.jozufozu.flywheel.Flywheel;
|
||||||
import com.jozufozu.flywheel.api.instancer.InstancedPart;
|
import com.jozufozu.flywheel.api.instancer.InstancedPart;
|
||||||
import com.jozufozu.flywheel.api.struct.StructType;
|
import com.jozufozu.flywheel.api.struct.StructType;
|
||||||
import com.jozufozu.flywheel.api.struct.StructWriter;
|
import com.jozufozu.flywheel.api.struct.StructWriter;
|
||||||
import com.jozufozu.flywheel.backend.gl.GlVertexArray;
|
import com.jozufozu.flywheel.backend.gl.array.GlVertexArray;
|
||||||
import com.jozufozu.flywheel.backend.gl.buffer.GlBuffer;
|
import com.jozufozu.flywheel.backend.gl.buffer.GlBuffer;
|
||||||
import com.jozufozu.flywheel.backend.gl.buffer.GlBufferType;
|
import com.jozufozu.flywheel.backend.gl.buffer.GlBufferType;
|
||||||
import com.jozufozu.flywheel.backend.gl.buffer.GlBufferUsage;
|
import com.jozufozu.flywheel.backend.gl.buffer.GlBufferUsage;
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
package com.jozufozu.flywheel.backend.model;
|
package com.jozufozu.flywheel.backend.model;
|
||||||
|
|
||||||
import com.jozufozu.flywheel.backend.gl.GlVertexArray;
|
import com.jozufozu.flywheel.backend.gl.array.GlVertexArray;
|
||||||
import com.jozufozu.flywheel.core.model.BlockMesh;
|
import com.jozufozu.flywheel.core.model.BlockMesh;
|
||||||
|
|
||||||
public class ArrayModelRenderer {
|
public class ArrayModelRenderer {
|
||||||
|
|
|
@ -14,7 +14,7 @@ import org.lwjgl.opengl.GL32;
|
||||||
import com.jozufozu.flywheel.Flywheel;
|
import com.jozufozu.flywheel.Flywheel;
|
||||||
import com.jozufozu.flywheel.api.vertex.VertexType;
|
import com.jozufozu.flywheel.api.vertex.VertexType;
|
||||||
import com.jozufozu.flywheel.backend.gl.GlPrimitive;
|
import com.jozufozu.flywheel.backend.gl.GlPrimitive;
|
||||||
import com.jozufozu.flywheel.backend.gl.GlVertexArray;
|
import com.jozufozu.flywheel.backend.gl.array.GlVertexArray;
|
||||||
import com.jozufozu.flywheel.backend.gl.buffer.GlBuffer;
|
import com.jozufozu.flywheel.backend.gl.buffer.GlBuffer;
|
||||||
import com.jozufozu.flywheel.backend.gl.buffer.GlBufferType;
|
import com.jozufozu.flywheel.backend.gl.buffer.GlBufferType;
|
||||||
import com.jozufozu.flywheel.backend.gl.buffer.MappedBuffer;
|
import com.jozufozu.flywheel.backend.gl.buffer.MappedBuffer;
|
||||||
|
|
|
@ -5,7 +5,7 @@ import static org.lwjgl.opengl.GL11.glDrawArrays;
|
||||||
|
|
||||||
import com.jozufozu.flywheel.Flywheel;
|
import com.jozufozu.flywheel.Flywheel;
|
||||||
import com.jozufozu.flywheel.backend.gl.GlStateTracker;
|
import com.jozufozu.flywheel.backend.gl.GlStateTracker;
|
||||||
import com.jozufozu.flywheel.backend.gl.GlVertexArray;
|
import com.jozufozu.flywheel.backend.gl.array.GlVertexArray;
|
||||||
import com.jozufozu.flywheel.backend.gl.buffer.GlBuffer;
|
import com.jozufozu.flywheel.backend.gl.buffer.GlBuffer;
|
||||||
import com.jozufozu.flywheel.backend.gl.buffer.GlBufferType;
|
import com.jozufozu.flywheel.backend.gl.buffer.GlBufferType;
|
||||||
import com.jozufozu.flywheel.backend.gl.buffer.MappedBuffer;
|
import com.jozufozu.flywheel.backend.gl.buffer.MappedBuffer;
|
||||||
|
|
|
@ -5,7 +5,8 @@ import java.util.List;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableList;
|
import com.google.common.collect.ImmutableList;
|
||||||
import com.jozufozu.flywheel.api.vertex.VertexType;
|
import com.jozufozu.flywheel.api.vertex.VertexType;
|
||||||
import com.jozufozu.flywheel.backend.gl.VertexAttribute;
|
import com.jozufozu.flywheel.backend.gl.array.VertexAttribute;
|
||||||
|
import com.jozufozu.flywheel.backend.gl.array.VertexAttributeF;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Classic Vertex Format struct with a clever name.
|
* Classic Vertex Format struct with a clever name.
|
||||||
|
@ -53,7 +54,7 @@ public class BufferLayout {
|
||||||
|
|
||||||
private static int calculateStride(List<VertexAttribute> layoutItems) {
|
private static int calculateStride(List<VertexAttribute> layoutItems) {
|
||||||
int stride = 0;
|
int stride = 0;
|
||||||
for (VertexAttribute spec : layoutItems) {
|
for (var spec : layoutItems) {
|
||||||
stride += spec.getByteWidth();
|
stride += spec.getByteWidth();
|
||||||
}
|
}
|
||||||
return stride;
|
return stride;
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package com.jozufozu.flywheel.core.layout;
|
package com.jozufozu.flywheel.core.layout;
|
||||||
|
|
||||||
import com.jozufozu.flywheel.backend.gl.GlNumericType;
|
import com.jozufozu.flywheel.backend.gl.GlNumericType;
|
||||||
|
import com.jozufozu.flywheel.backend.gl.array.VertexAttributeI;
|
||||||
|
|
||||||
public class CommonItems {
|
public class CommonItems {
|
||||||
|
|
||||||
|
@ -15,8 +16,8 @@ public class CommonItems {
|
||||||
|
|
||||||
public static final PrimitiveItem RGBA = new PrimitiveItem(GlNumericType.UBYTE, 4, true);
|
public static final PrimitiveItem RGBA = new PrimitiveItem(GlNumericType.UBYTE, 4, true);
|
||||||
public static final PrimitiveItem RGB = new PrimitiveItem(GlNumericType.UBYTE, 3, true);
|
public static final PrimitiveItem RGB = new PrimitiveItem(GlNumericType.UBYTE, 3, true);
|
||||||
public static final PrimitiveItem LIGHT = new PrimitiveItem(GlNumericType.UBYTE, 2, false);
|
public static final PrimitiveItem LIGHT = new PrimitiveItem(new VertexAttributeI(GlNumericType.UBYTE, 2));
|
||||||
public static final PrimitiveItem LIGHT_SHORT = new PrimitiveItem(GlNumericType.USHORT, 2, false);
|
public static final PrimitiveItem LIGHT_SHORT = new PrimitiveItem(new VertexAttributeI(GlNumericType.USHORT, 2));
|
||||||
|
|
||||||
public static final PrimitiveItem NORMALIZED_BYTE = new PrimitiveItem(GlNumericType.BYTE, 1, true);
|
public static final PrimitiveItem NORMALIZED_BYTE = new PrimitiveItem(GlNumericType.BYTE, 1, true);
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,7 @@ package com.jozufozu.flywheel.core.layout;
|
||||||
|
|
||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
|
|
||||||
import com.jozufozu.flywheel.backend.gl.VertexAttribute;
|
import com.jozufozu.flywheel.backend.gl.array.VertexAttribute;
|
||||||
|
|
||||||
public interface LayoutItem {
|
public interface LayoutItem {
|
||||||
|
|
||||||
|
|
|
@ -3,14 +3,15 @@ package com.jozufozu.flywheel.core.layout;
|
||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
|
|
||||||
import com.jozufozu.flywheel.backend.gl.GlNumericType;
|
import com.jozufozu.flywheel.backend.gl.GlNumericType;
|
||||||
import com.jozufozu.flywheel.backend.gl.VertexAttribute;
|
import com.jozufozu.flywheel.backend.gl.array.VertexAttribute;
|
||||||
|
import com.jozufozu.flywheel.backend.gl.array.VertexAttributeF;
|
||||||
|
|
||||||
public record MatrixItem(int rows, int cols) implements LayoutItem {
|
public record MatrixItem(int rows, int cols) implements LayoutItem {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void provideAttributes(Consumer<VertexAttribute> consumer) {
|
public void provideAttributes(Consumer<VertexAttribute> consumer) {
|
||||||
for (int i = 0; i < rows; i++) {
|
for (int i = 0; i < rows; i++) {
|
||||||
consumer.accept(new VertexAttribute(cols, GlNumericType.FLOAT, false));
|
consumer.accept(new VertexAttributeF(GlNumericType.FLOAT, cols, false));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,8 @@ package com.jozufozu.flywheel.core.layout;
|
||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
|
|
||||||
import com.jozufozu.flywheel.backend.gl.GlNumericType;
|
import com.jozufozu.flywheel.backend.gl.GlNumericType;
|
||||||
import com.jozufozu.flywheel.backend.gl.VertexAttribute;
|
import com.jozufozu.flywheel.backend.gl.array.VertexAttribute;
|
||||||
|
import com.jozufozu.flywheel.backend.gl.array.VertexAttributeF;
|
||||||
|
|
||||||
public class PrimitiveItem implements LayoutItem {
|
public class PrimitiveItem implements LayoutItem {
|
||||||
|
|
||||||
|
@ -14,7 +15,11 @@ public class PrimitiveItem implements LayoutItem {
|
||||||
}
|
}
|
||||||
|
|
||||||
public PrimitiveItem(GlNumericType type, int count, boolean normalized) {
|
public PrimitiveItem(GlNumericType type, int count, boolean normalized) {
|
||||||
attribute = new VertexAttribute(count, type, normalized);
|
this(new VertexAttributeF(type, count, normalized));
|
||||||
|
}
|
||||||
|
|
||||||
|
public PrimitiveItem(VertexAttribute attribute) {
|
||||||
|
this.attribute = attribute;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#use "flywheel:api/vertex.glsl"
|
#use "flywheel:api/vertex.glsl"
|
||||||
#use "flywheel:util/quaternion.glsl"
|
#use "flywheel:util/quaternion.glsl"
|
||||||
|
|
||||||
layout(location = 0) in vec2 oriented_light; // TODO: switch to ivec2
|
layout(location = 0) in ivec2 oriented_light;
|
||||||
layout(location = 1) in vec4 oriented_color;
|
layout(location = 1) in vec4 oriented_color;
|
||||||
layout(location = 2) in vec3 oriented_pos;
|
layout(location = 2) in vec3 oriented_pos;
|
||||||
layout(location = 3) in vec3 oriented_pivot;
|
layout(location = 3) in vec3 oriented_pivot;
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
#use "flywheel:api/vertex.glsl"
|
#use "flywheel:api/vertex.glsl"
|
||||||
|
|
||||||
layout(location = 0) in vec2 transformed_light; // TODO: switch to ivec2
|
layout(location = 0) in ivec2 transformed_light;
|
||||||
layout(location = 1) in vec4 transformed_color;
|
layout(location = 1) in vec4 transformed_color;
|
||||||
layout(location = 2) in mat4 transformed_pose;
|
layout(location = 2) in mat4 transformed_pose;
|
||||||
layout(location = 6) in mat3 transformed_normal;
|
layout(location = 6) in mat3 transformed_normal;
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
layout(location = 0) in vec3 _flw_v_pos;
|
layout(location = 0) in vec3 _flw_v_pos;
|
||||||
layout(location = 1) in vec4 _flw_v_color;
|
layout(location = 1) in vec4 _flw_v_color;
|
||||||
layout(location = 2) in vec2 _flw_v_texCoord;
|
layout(location = 2) in vec2 _flw_v_texCoord;
|
||||||
layout(location = 3) in vec2 _flw_v_light; // TODO: switch to ivec2
|
layout(location = 3) in ivec2 _flw_v_light;
|
||||||
layout(location = 4) in vec3 _flw_v_normal;
|
layout(location = 4) in vec3 _flw_v_normal;
|
||||||
|
|
||||||
void flw_layoutVertex() {
|
void flw_layoutVertex() {
|
||||||
|
|
Loading…
Reference in a new issue