From af56417d236d4a6158bb494c122cfa65356d9860 Mon Sep 17 00:00:00 2001 From: Jozufozu Date: Thu, 18 Jan 2024 17:07:10 -0800 Subject: [PATCH] Update uniform providers (again) - Remove uniform api. - Do not generate uniform interface blocks. - Move uniform shader into internal/ and manually include it in the api impl headers. - Add flw_ prefix to existing uniforms. - Separate fog uniforms into their own UBO, uploaded in FogUpdateMixin. - Drastically simplify UniformBuffer. - Do not poll for uniform buffer updates. Instead, do the upload at the beginning of a frame when the engine is flushing. --- .../java/com/jozufozu/flywheel/Flywheel.java | 4 +- .../flywheel/api/uniform/ShaderUniforms.java | 33 ----- .../flywheel/backend/compile/FlwPrograms.java | 16 +-- .../backend/compile/IndirectPrograms.java | 12 +- .../backend/compile/InstancingPrograms.java | 5 +- .../backend/compile/PipelineCompiler.java | 8 +- .../compile/component/UniformComponent.java | 85 ----------- .../backend/engine/UniformBuffer.java | 129 ----------------- .../engine/indirect/IndirectCullingGroup.java | 9 +- .../engine/indirect/IndirectEngine.java | 4 +- .../engine/instancing/InstancedCrumbling.java | 4 +- .../engine/instancing/InstancingEngine.java | 7 +- .../backend/engine/uniform/FogUniforms.java | 27 ++++ .../backend/engine/uniform/FrameUniforms.java | 61 ++++++++ .../backend/engine/uniform/UniformBuffer.java | 38 +++++ .../engine/uniform/UniformProvider.java | 7 + .../backend/engine/uniform/Uniforms.java | 60 ++++++++ .../jozufozu/flywheel/config/FlwCommands.java | 10 +- .../jozufozu/flywheel/impl/RegistryImpl.java | 16 --- .../lib/uniform/FlwShaderUniforms.java | 134 ------------------ .../flywheel/mixin/FogUpdateMixin.java | 8 +- .../assets/flywheel/flywheel/fog/linear.glsl | 2 +- .../flywheel/flywheel/fog/linear_fade.glsl | 2 +- .../flywheel/flywheel/internal/common.frag | 2 +- .../flywheel/flywheel/internal/common.vert | 4 +- .../flywheel/internal/common_api_impl.frag | 2 + .../flywheel/internal/common_api_impl.vert | 2 + .../flywheel/internal/indirect/cull.glsl | 5 +- .../flywheel/internal/uniforms/fog.glsl | 5 + .../flywheel/internal/uniforms/frame.glsl | 17 +++ .../flywheel/flywheel/uniform/flywheel.glsl | 20 --- 31 files changed, 265 insertions(+), 473 deletions(-) delete mode 100644 src/main/java/com/jozufozu/flywheel/api/uniform/ShaderUniforms.java delete mode 100644 src/main/java/com/jozufozu/flywheel/backend/compile/component/UniformComponent.java delete mode 100644 src/main/java/com/jozufozu/flywheel/backend/engine/UniformBuffer.java create mode 100644 src/main/java/com/jozufozu/flywheel/backend/engine/uniform/FogUniforms.java create mode 100644 src/main/java/com/jozufozu/flywheel/backend/engine/uniform/FrameUniforms.java create mode 100644 src/main/java/com/jozufozu/flywheel/backend/engine/uniform/UniformBuffer.java create mode 100644 src/main/java/com/jozufozu/flywheel/backend/engine/uniform/UniformProvider.java create mode 100644 src/main/java/com/jozufozu/flywheel/backend/engine/uniform/Uniforms.java delete mode 100644 src/main/java/com/jozufozu/flywheel/lib/uniform/FlwShaderUniforms.java create mode 100644 src/main/resources/assets/flywheel/flywheel/internal/uniforms/fog.glsl create mode 100644 src/main/resources/assets/flywheel/flywheel/internal/uniforms/frame.glsl delete mode 100644 src/main/resources/assets/flywheel/flywheel/uniform/flywheel.glsl diff --git a/src/main/java/com/jozufozu/flywheel/Flywheel.java b/src/main/java/com/jozufozu/flywheel/Flywheel.java index 811d3f168..dd8e80fb0 100644 --- a/src/main/java/com/jozufozu/flywheel/Flywheel.java +++ b/src/main/java/com/jozufozu/flywheel/Flywheel.java @@ -10,7 +10,7 @@ import com.jozufozu.flywheel.api.visualization.VisualizationManager; import com.jozufozu.flywheel.backend.Backends; import com.jozufozu.flywheel.backend.ShaderIndices; import com.jozufozu.flywheel.backend.compile.FlwPrograms; -import com.jozufozu.flywheel.backend.engine.UniformBuffer; +import com.jozufozu.flywheel.backend.engine.uniform.Uniforms; import com.jozufozu.flywheel.config.BackendArgument; import com.jozufozu.flywheel.config.FlwCommands; import com.jozufozu.flywheel.config.FlwConfig; @@ -95,7 +95,7 @@ public class Flywheel { forgeEventBus.addListener(FlwCommands::registerClientCommands); - forgeEventBus.addListener(UniformBuffer::onReloadLevelRenderer); + forgeEventBus.addListener(Uniforms::onReloadLevelRenderer); forgeEventBus.addListener(LightUpdater::onClientTick); forgeEventBus.addListener((LevelEvent.Unload e) -> LevelAttached.onUnloadLevel(e)); diff --git a/src/main/java/com/jozufozu/flywheel/api/uniform/ShaderUniforms.java b/src/main/java/com/jozufozu/flywheel/api/uniform/ShaderUniforms.java deleted file mode 100644 index 723ddda93..000000000 --- a/src/main/java/com/jozufozu/flywheel/api/uniform/ShaderUniforms.java +++ /dev/null @@ -1,33 +0,0 @@ -package com.jozufozu.flywheel.api.uniform; - -import com.jozufozu.flywheel.api.registry.Registry; -import com.jozufozu.flywheel.impl.RegistryImpl; - -import net.minecraft.resources.ResourceLocation; - -public interface ShaderUniforms { - static Registry REGISTRY = RegistryImpl.createForShaderUniforms(); - - Provider activate(long ptr); - - ResourceLocation uniformShader(); - - int byteSize(); - - interface Provider { - /** - * Delete this provider.

- *

- * Do not free the ptr passed to {@link #activate(long)}.
- * Clean up other resources, and unsubscribe from events. - */ - void delete(); - - /** - * Poll the provider for changes. - * - * @return {@code true} if the provider updated its backing store. - */ - boolean poll(); - } -} diff --git a/src/main/java/com/jozufozu/flywheel/backend/compile/FlwPrograms.java b/src/main/java/com/jozufozu/flywheel/backend/compile/FlwPrograms.java index 488948964..ad7463e18 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/compile/FlwPrograms.java +++ b/src/main/java/com/jozufozu/flywheel/backend/compile/FlwPrograms.java @@ -6,10 +6,8 @@ import com.google.common.collect.ImmutableList; import com.jozufozu.flywheel.Flywheel; import com.jozufozu.flywheel.api.context.Context; import com.jozufozu.flywheel.api.instance.InstanceType; -import com.jozufozu.flywheel.api.uniform.ShaderUniforms; import com.jozufozu.flywheel.backend.ShaderIndices; import com.jozufozu.flywheel.backend.compile.component.UberShaderComponent; -import com.jozufozu.flywheel.backend.compile.component.UniformComponent; import com.jozufozu.flywheel.backend.compile.core.CompilerStats; import com.jozufozu.flywheel.backend.compile.core.SourceLoader; import com.jozufozu.flywheel.backend.glsl.ShaderSources; @@ -30,12 +28,11 @@ public final class FlwPrograms { var loadChecker = new SourceLoader(sources, preLoadStats); var pipelineKeys = createPipelineKeys(); - var uniformComponent = createUniformComponent(loadChecker); List vertexComponents = List.of(createVertexMaterialComponent(loadChecker)); List fragmentComponents = List.of(createFragmentMaterialComponent(loadChecker), createFogComponent(loadChecker), createCutoutComponent(loadChecker)); - InstancingPrograms.reload(sources, pipelineKeys, uniformComponent, vertexComponents, fragmentComponents); - IndirectPrograms.reload(sources, pipelineKeys, uniformComponent, vertexComponents, fragmentComponents); + InstancingPrograms.reload(sources, pipelineKeys, vertexComponents, fragmentComponents); + IndirectPrograms.reload(sources, pipelineKeys, vertexComponents, fragmentComponents); if (preLoadStats.errored()) { Flywheel.LOGGER.error(preLoadStats.generateErrorLog()); @@ -96,15 +93,6 @@ public final class FlwPrograms { .build(loadChecker); } - private static UniformComponent createUniformComponent(SourceLoader loadChecker) { - return UniformComponent.builder(Flywheel.rl("uniforms")) - .sources(ShaderUniforms.REGISTRY.getAll() - .stream() - .map(ShaderUniforms::uniformShader) - .toList()) - .build(loadChecker); - } - public static class ResourceReloadListener implements ResourceManagerReloadListener { public static final ResourceReloadListener INSTANCE = new ResourceReloadListener(); diff --git a/src/main/java/com/jozufozu/flywheel/backend/compile/IndirectPrograms.java b/src/main/java/com/jozufozu/flywheel/backend/compile/IndirectPrograms.java index 1ee103788..efe310bcc 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/compile/IndirectPrograms.java +++ b/src/main/java/com/jozufozu/flywheel/backend/compile/IndirectPrograms.java @@ -10,7 +10,6 @@ import com.jozufozu.flywheel.Flywheel; import com.jozufozu.flywheel.api.context.Context; import com.jozufozu.flywheel.api.instance.InstanceType; import com.jozufozu.flywheel.backend.compile.component.IndirectComponent; -import com.jozufozu.flywheel.backend.compile.component.UniformComponent; import com.jozufozu.flywheel.backend.compile.core.CompilationHarness; import com.jozufozu.flywheel.backend.compile.core.Compile; import com.jozufozu.flywheel.backend.gl.GlCompat; @@ -45,11 +44,11 @@ public class IndirectPrograms extends AbstractPrograms { this.scatter = scatter; } - static void reload(ShaderSources sources, ImmutableList pipelineKeys, UniformComponent uniformComponent, List vertexComponents, List fragmentComponents) { + static void reload(ShaderSources sources, ImmutableList pipelineKeys, List vertexComponents, List fragmentComponents) { IndirectPrograms newInstance = null; - var pipelineCompiler = PipelineCompiler.create(sources, Pipelines.INDIRECT, uniformComponent, vertexComponents, fragmentComponents); - var cullingCompiler = createCullingCompiler(uniformComponent, sources); + var pipelineCompiler = PipelineCompiler.create(sources, Pipelines.INDIRECT, vertexComponents, fragmentComponents); + var cullingCompiler = createCullingCompiler(sources); var applyCompiler = createUtilCompiler(sources); try { @@ -71,15 +70,14 @@ public class IndirectPrograms extends AbstractPrograms { setInstance(newInstance); } - private static CompilationHarness> createCullingCompiler(UniformComponent uniformComponent, ShaderSources sources) { + private static CompilationHarness> createCullingCompiler(ShaderSources sources) { return CULL.program() .link(CULL.shader(GlslVersion.V460, ShaderType.COMPUTE) .define("_FLW_SUBGROUP_SIZE", GlCompat.SUBGROUP_SIZE) - .withComponent(uniformComponent) .withComponent(IndirectComponent::create) .withResource(InstanceType::cullShader) .withResource(CULL_SHADER_MAIN)) - .then((key, program) -> program.setUniformBlockBinding("FlwUniforms", 0)) + .then((key, program) -> program.setUniformBlockBinding("_FlwFrameUniforms", 0)) .harness(sources); } diff --git a/src/main/java/com/jozufozu/flywheel/backend/compile/InstancingPrograms.java b/src/main/java/com/jozufozu/flywheel/backend/compile/InstancingPrograms.java index ff55b0ee9..9c9ca9168 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/compile/InstancingPrograms.java +++ b/src/main/java/com/jozufozu/flywheel/backend/compile/InstancingPrograms.java @@ -9,7 +9,6 @@ import com.google.common.collect.ImmutableList; import com.jozufozu.flywheel.Flywheel; import com.jozufozu.flywheel.api.context.Context; import com.jozufozu.flywheel.api.instance.InstanceType; -import com.jozufozu.flywheel.backend.compile.component.UniformComponent; import com.jozufozu.flywheel.backend.gl.shader.GlProgram; import com.jozufozu.flywheel.backend.glsl.ShaderSources; import com.jozufozu.flywheel.backend.glsl.SourceComponent; @@ -24,10 +23,10 @@ public class InstancingPrograms extends AbstractPrograms { this.pipeline = pipeline; } - static void reload(ShaderSources sources, ImmutableList pipelineKeys, UniformComponent uniformComponent, List vertexComponents, List fragmentComponents) { + static void reload(ShaderSources sources, ImmutableList pipelineKeys, List vertexComponents, List fragmentComponents) { InstancingPrograms newInstance = null; - var pipelineCompiler = PipelineCompiler.create(sources, Pipelines.INSTANCED_ARRAYS, uniformComponent, vertexComponents, fragmentComponents); + var pipelineCompiler = PipelineCompiler.create(sources, Pipelines.INSTANCED_ARRAYS, vertexComponents, fragmentComponents); try { var pipelineResult = pipelineCompiler.compileAndReportErrors(pipelineKeys); diff --git a/src/main/java/com/jozufozu/flywheel/backend/compile/PipelineCompiler.java b/src/main/java/com/jozufozu/flywheel/backend/compile/PipelineCompiler.java index 75841470a..d7338c6ed 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/compile/PipelineCompiler.java +++ b/src/main/java/com/jozufozu/flywheel/backend/compile/PipelineCompiler.java @@ -3,7 +3,6 @@ package com.jozufozu.flywheel.backend.compile; import java.util.List; import com.jozufozu.flywheel.backend.InternalVertex; -import com.jozufozu.flywheel.backend.compile.component.UniformComponent; import com.jozufozu.flywheel.backend.compile.core.CompilationHarness; import com.jozufozu.flywheel.backend.compile.core.Compile; import com.jozufozu.flywheel.backend.gl.shader.ShaderType; @@ -13,10 +12,9 @@ import com.jozufozu.flywheel.backend.glsl.SourceComponent; public class PipelineCompiler { private static final Compile PIPELINE = new Compile<>(); - static CompilationHarness create(ShaderSources sources, Pipeline pipeline, UniformComponent uniformComponent, List vertexComponents, List fragmentComponents) { + static CompilationHarness create(ShaderSources sources, Pipeline pipeline, List vertexComponents, List fragmentComponents) { return PIPELINE.program() .link(PIPELINE.shader(pipeline.glslVersion(), ShaderType.VERTEX) - .withComponent(uniformComponent) .withResource(pipeline.vertexApiImpl()) .withResource(InternalVertex.LAYOUT_SHADER) .withComponent(key -> pipeline.assembler() @@ -29,7 +27,6 @@ public class PipelineCompiler { .withResource(pipeline.vertexMain())) .link(PIPELINE.shader(pipeline.glslVersion(), ShaderType.FRAGMENT) .enableExtension("GL_ARB_conservative_depth") - .withComponent(uniformComponent) .withResource(pipeline.fragmentApiImpl()) .withComponents(fragmentComponents) .withResource(key -> key.contextShader() @@ -38,7 +35,8 @@ public class PipelineCompiler { .then((key, program) -> { key.contextShader() .onProgramLink(program); - program.setUniformBlockBinding("FlwUniforms", 0); + program.setUniformBlockBinding("_FlwFrameUniforms", 0); + program.setUniformBlockBinding("_FlwFogUniforms", 1); }) .harness(sources); } diff --git a/src/main/java/com/jozufozu/flywheel/backend/compile/component/UniformComponent.java b/src/main/java/com/jozufozu/flywheel/backend/compile/component/UniformComponent.java deleted file mode 100644 index 3002bb7ab..000000000 --- a/src/main/java/com/jozufozu/flywheel/backend/compile/component/UniformComponent.java +++ /dev/null @@ -1,85 +0,0 @@ -package com.jozufozu.flywheel.backend.compile.component; - -import java.util.ArrayList; -import java.util.Collection; -import java.util.List; - -import com.google.common.collect.ImmutableList; -import com.jozufozu.flywheel.backend.compile.core.SourceLoader; -import com.jozufozu.flywheel.backend.glsl.SourceComponent; -import com.jozufozu.flywheel.backend.glsl.SourceFile; -import com.jozufozu.flywheel.backend.glsl.generate.GlslBuilder; - -import net.minecraft.resources.ResourceLocation; - -public class UniformComponent implements SourceComponent { - private final ResourceLocation name; - private final ImmutableList uniformShaders; - - public static Builder builder(ResourceLocation uniforms) { - return new Builder(uniforms); - } - - private UniformComponent(ResourceLocation name, ImmutableList uniformShaders) { - this.name = name; - this.uniformShaders = uniformShaders; - } - - @Override - public Collection included() { - return uniformShaders; - } - - @Override - public String source() { - var builder = new GlslBuilder(); - - builder.uniformBlock() - .layout("std140") - .name("FlwUniforms") - .member("FlywheelUniforms", "flywheel"); - - builder.blankLine(); - - return builder.build(); - } - - @Override - public ResourceLocation name() { - return name; - } - - public static class Builder { - private final ResourceLocation name; - private final List uniformShaders = new ArrayList<>(); - - public Builder(ResourceLocation name) { - this.name = name; - } - - public Builder sources(List sources) { - this.uniformShaders.addAll(sources); - return this; - } - - public UniformComponent build(SourceLoader sources) { - var out = ImmutableList.builder(); - - boolean errored = false; - for (ResourceLocation uniformShader : uniformShaders) { - SourceFile sourceFile = sources.find(uniformShader); - if (sourceFile != null) { - out.add(sourceFile); - } else { - errored = true; - } - } - - if (errored) { - return null; - } - - return new UniformComponent(name, out.build()); - } - } -} diff --git a/src/main/java/com/jozufozu/flywheel/backend/engine/UniformBuffer.java b/src/main/java/com/jozufozu/flywheel/backend/engine/UniformBuffer.java deleted file mode 100644 index 519da9681..000000000 --- a/src/main/java/com/jozufozu/flywheel/backend/engine/UniformBuffer.java +++ /dev/null @@ -1,129 +0,0 @@ -package com.jozufozu.flywheel.backend.engine; - -import java.util.List; -import java.util.Set; - -import org.lwjgl.opengl.GL32; - -import com.google.common.collect.ImmutableList; -import com.jozufozu.flywheel.api.event.ReloadLevelRendererEvent; -import com.jozufozu.flywheel.api.uniform.ShaderUniforms; -import com.jozufozu.flywheel.backend.gl.buffer.GlBuffer; -import com.jozufozu.flywheel.lib.math.MoreMath; -import com.jozufozu.flywheel.lib.memory.MemoryBlock; - -public class UniformBuffer { -// private static final int OFFSET_ALIGNMENT = GL32.glGetInteger(GL32.GL_UNIFORM_BUFFER_OFFSET_ALIGNMENT); -// private static final int MAX_SIZE = GL32.glGetInteger(GL32.GL_MAX_UNIFORM_BLOCK_SIZE); -// private static final int MAX_BINDINGS = GL32.glGetInteger(GL32.GL_MAX_UNIFORM_BUFFER_BINDINGS); -// private static final boolean PO2_ALIGNMENT = Mth.isPowerOfTwo(OFFSET_ALIGNMENT); - - private static UniformBuffer instance; - - private final GlBuffer buffer; - private final ProviderSet providerSet; - - private UniformBuffer() { - buffer = new GlBuffer(); - providerSet = new ProviderSet(ShaderUniforms.REGISTRY.getAll()); - } - - public static UniformBuffer get() { - if (instance == null) { - instance = new UniformBuffer(); - } - return instance; - } - - public void sync() { - if (providerSet.pollUpdates()) { - buffer.upload(providerSet.data); - } - - GL32.glBindBufferRange(GL32.GL_UNIFORM_BUFFER, 0, buffer.handle(), 0, providerSet.data.size()); - } - - private void delete() { - providerSet.delete(); - buffer.delete(); - } - - public static void onReloadLevelRenderer(ReloadLevelRendererEvent event) { - if (instance != null) { - instance.delete(); - instance = null; - } - } - -// // https://stackoverflow.com/questions/3407012/rounding-up-to-the-nearest-multiple-of-a-number -// private static int alignUniformBuffer(int numToRound) { -// if (PO2_ALIGNMENT) { -// return (numToRound + OFFSET_ALIGNMENT - 1) & -OFFSET_ALIGNMENT; -// } else { -// return ((numToRound + OFFSET_ALIGNMENT - 1) / OFFSET_ALIGNMENT) * OFFSET_ALIGNMENT; -// } -// } - - private static class LiveProvider { - private final ShaderUniforms shaderUniforms; - private final int offset; - private final int size; - private ShaderUniforms.Provider provider; - - private LiveProvider(ShaderUniforms shaderUniforms, int offset, int size) { - this.shaderUniforms = shaderUniforms; - this.offset = offset; - this.size = size; - } - - private void updatePtr(MemoryBlock bufferBase) { - if (provider != null) { - provider.delete(); - } - provider = shaderUniforms.activate(bufferBase.ptr() + offset); - } - - public boolean maybePoll() { - return provider != null && provider.poll(); - } - } - - private static class ProviderSet { - private final List allocatedProviders; - - private final MemoryBlock data; - - private ProviderSet(final Set providers) { - var builder = ImmutableList.builder(); - int totalBytes = 0; - for (ShaderUniforms provider : providers) { - int size = MoreMath.align16(provider.byteSize()); - - builder.add(new LiveProvider(provider, totalBytes, size)); - - totalBytes += size; - } - - allocatedProviders = builder.build(); - - data = MemoryBlock.mallocTracked(totalBytes); - - for (LiveProvider p : allocatedProviders) { - p.updatePtr(data); - } - } - - public boolean pollUpdates() { - boolean changed = false; - for (LiveProvider p : allocatedProviders) { - changed |= p.maybePoll(); - } - return changed; - } - - public void delete() { - allocatedProviders.forEach(p -> p.provider.delete()); - data.free(); - } - } -} diff --git a/src/main/java/com/jozufozu/flywheel/backend/engine/indirect/IndirectCullingGroup.java b/src/main/java/com/jozufozu/flywheel/backend/engine/indirect/IndirectCullingGroup.java index a9cdea09c..286ee0ee0 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/engine/indirect/IndirectCullingGroup.java +++ b/src/main/java/com/jozufozu/flywheel/backend/engine/indirect/IndirectCullingGroup.java @@ -24,7 +24,7 @@ import com.jozufozu.flywheel.api.model.Mesh; import com.jozufozu.flywheel.api.model.Model; import com.jozufozu.flywheel.backend.compile.IndirectPrograms; import com.jozufozu.flywheel.backend.engine.MaterialRenderState; -import com.jozufozu.flywheel.backend.engine.UniformBuffer; +import com.jozufozu.flywheel.backend.engine.uniform.Uniforms; import com.jozufozu.flywheel.backend.gl.Driver; import com.jozufozu.flywheel.backend.gl.GlCompat; import com.jozufozu.flywheel.backend.gl.shader.GlProgram; @@ -100,7 +100,7 @@ public class IndirectCullingGroup { return; } - UniformBuffer.get().sync(); + Uniforms.bindFrame(); cullProgram.bind(); buffers.bindForCompute(); glMemoryBarrier(GL_SHADER_STORAGE_BARRIER_BIT); @@ -184,7 +184,7 @@ public class IndirectCullingGroup { return; } - UniformBuffer.get().sync(); + Uniforms.bindForDraw(); drawProgram.bind(); meshPool.bindForDraw(); buffers.bindForDraw(); @@ -204,8 +204,7 @@ public class IndirectCullingGroup { program.bind(); - UniformBuffer.get() - .sync(); + Uniforms.bindForDraw(); meshPool.bindForDraw(); buffers.bindForCrumbling(); diff --git a/src/main/java/com/jozufozu/flywheel/backend/engine/indirect/IndirectEngine.java b/src/main/java/com/jozufozu/flywheel/backend/engine/indirect/IndirectEngine.java index ebec341a9..6b0a8bb58 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/engine/indirect/IndirectEngine.java +++ b/src/main/java/com/jozufozu/flywheel/backend/engine/indirect/IndirectEngine.java @@ -11,6 +11,7 @@ import com.jozufozu.flywheel.backend.engine.AbstractEngine; import com.jozufozu.flywheel.backend.engine.AbstractInstancer; import com.jozufozu.flywheel.backend.engine.InstancerStorage; import com.jozufozu.flywheel.backend.engine.MaterialRenderState; +import com.jozufozu.flywheel.backend.engine.uniform.Uniforms; import com.jozufozu.flywheel.backend.gl.GlStateTracker; import com.jozufozu.flywheel.backend.gl.GlTextureUnit; import com.jozufozu.flywheel.lib.task.Flag; @@ -39,8 +40,9 @@ public class IndirectEngine extends AbstractEngine { return SyncedPlan.of(this::flushDrawManager); } - private void flushDrawManager() { + private void flushDrawManager(RenderContext ctx) { try (var state = GlStateTracker.getRestoreState()) { + Uniforms.updateContext(ctx); drawManager.flush(); } flushFlag.raise(); diff --git a/src/main/java/com/jozufozu/flywheel/backend/engine/instancing/InstancedCrumbling.java b/src/main/java/com/jozufozu/flywheel/backend/engine/instancing/InstancedCrumbling.java index 28ce76ff7..e82f5301c 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/engine/instancing/InstancedCrumbling.java +++ b/src/main/java/com/jozufozu/flywheel/backend/engine/instancing/InstancedCrumbling.java @@ -13,7 +13,7 @@ import com.jozufozu.flywheel.backend.compile.InstancingPrograms; import com.jozufozu.flywheel.backend.engine.CommonCrumbling; import com.jozufozu.flywheel.backend.engine.InstanceHandleImpl; import com.jozufozu.flywheel.backend.engine.MaterialRenderState; -import com.jozufozu.flywheel.backend.engine.UniformBuffer; +import com.jozufozu.flywheel.backend.engine.uniform.Uniforms; import com.jozufozu.flywheel.backend.gl.GlStateTracker; import com.jozufozu.flywheel.lib.context.Contexts; import com.jozufozu.flywheel.lib.material.SimpleMaterial; @@ -51,7 +51,7 @@ public class InstancedCrumbling { var program = programs.get(shader.instanceType(), Contexts.CRUMBLING); program.bind(); - UniformBuffer.get().sync(); + Uniforms.bindForDraw(); InstancingEngine.uploadMaterialUniform(program, crumblingMaterial); for (Int2ObjectMap.Entry> progressEntry : byProgress.int2ObjectEntrySet()) { diff --git a/src/main/java/com/jozufozu/flywheel/backend/engine/instancing/InstancingEngine.java b/src/main/java/com/jozufozu/flywheel/backend/engine/instancing/InstancingEngine.java index 62c83ab4f..a83be2852 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/engine/instancing/InstancingEngine.java +++ b/src/main/java/com/jozufozu/flywheel/backend/engine/instancing/InstancingEngine.java @@ -16,7 +16,7 @@ import com.jozufozu.flywheel.backend.engine.AbstractInstancer; import com.jozufozu.flywheel.backend.engine.InstancerStorage; import com.jozufozu.flywheel.backend.engine.MaterialEncoder; import com.jozufozu.flywheel.backend.engine.MaterialRenderState; -import com.jozufozu.flywheel.backend.engine.UniformBuffer; +import com.jozufozu.flywheel.backend.engine.uniform.Uniforms; import com.jozufozu.flywheel.backend.gl.GlStateTracker; import com.jozufozu.flywheel.backend.gl.GlTextureUnit; import com.jozufozu.flywheel.backend.gl.shader.GlProgram; @@ -46,8 +46,9 @@ public class InstancingEngine extends AbstractEngine { return SyncedPlan.of(this::flushDrawManager); } - private void flushDrawManager() { + private void flushDrawManager(RenderContext ctx) { try (var restoreState = GlStateTracker.getRestoreState()) { + Uniforms.updateContext(ctx); drawManager.flush(); } flushFlag.raise(); @@ -118,7 +119,7 @@ public class InstancingEngine extends AbstractEngine { var program = programs.get(shader.instanceType(), Contexts.DEFAULT); program.bind(); - UniformBuffer.get().sync(); + Uniforms.bindForDraw(); uploadMaterialUniform(program, shader.material()); MaterialRenderState.setup(shader.material()); diff --git a/src/main/java/com/jozufozu/flywheel/backend/engine/uniform/FogUniforms.java b/src/main/java/com/jozufozu/flywheel/backend/engine/uniform/FogUniforms.java new file mode 100644 index 000000000..ea4f3e9a6 --- /dev/null +++ b/src/main/java/com/jozufozu/flywheel/backend/engine/uniform/FogUniforms.java @@ -0,0 +1,27 @@ +package com.jozufozu.flywheel.backend.engine.uniform; + +import org.lwjgl.system.MemoryUtil; + +import com.mojang.blaze3d.systems.RenderSystem; + +public class FogUniforms implements UniformProvider { + public static final int SIZE = 28; + + public int byteSize() { + return SIZE; + } + + @Override + public void write(long ptr) { + var color = RenderSystem.getShaderFogColor(); + + MemoryUtil.memPutFloat(ptr, color[0]); + MemoryUtil.memPutFloat(ptr + 4, color[1]); + MemoryUtil.memPutFloat(ptr + 8, color[2]); + MemoryUtil.memPutFloat(ptr + 12, color[3]); + MemoryUtil.memPutFloat(ptr + 16, RenderSystem.getShaderFogStart()); + MemoryUtil.memPutFloat(ptr + 20, RenderSystem.getShaderFogEnd()); + MemoryUtil.memPutInt(ptr + 24, RenderSystem.getShaderFogShape() + .getIndex()); + } +} diff --git a/src/main/java/com/jozufozu/flywheel/backend/engine/uniform/FrameUniforms.java b/src/main/java/com/jozufozu/flywheel/backend/engine/uniform/FrameUniforms.java new file mode 100644 index 000000000..bfab239e3 --- /dev/null +++ b/src/main/java/com/jozufozu/flywheel/backend/engine/uniform/FrameUniforms.java @@ -0,0 +1,61 @@ +package com.jozufozu.flywheel.backend.engine.uniform; + +import org.joml.Matrix4f; +import org.lwjgl.system.MemoryUtil; + +import com.jozufozu.flywheel.api.event.RenderContext; +import com.jozufozu.flywheel.api.visualization.VisualizationManager; +import com.jozufozu.flywheel.lib.math.MatrixMath; + +import net.minecraft.core.Vec3i; +import net.minecraft.world.phys.Vec3; + +public class FrameUniforms implements UniformProvider { + public static final int SIZE = 192; + + private RenderContext context; + + public int byteSize() { + return SIZE; + } + + private final Matrix4f viewProjection = new Matrix4f(); + + public void setContext(RenderContext context) { + this.context = context; + } + + @Override + public void write(long ptr) { + Vec3i renderOrigin = VisualizationManager.getOrThrow(context.level()) + .getRenderOrigin(); + Vec3 camera = context.camera() + .getPosition(); + + var camX = (float) (camera.x - renderOrigin.getX()); + var camY = (float) (camera.y - renderOrigin.getY()); + var camZ = (float) (camera.z - renderOrigin.getZ()); + + viewProjection.set(context.viewProjection()); + viewProjection.translate(-camX, -camY, -camZ); + + MatrixMath.writeUnsafe(viewProjection, ptr); + MemoryUtil.memPutFloat(ptr + 64, camX); + MemoryUtil.memPutFloat(ptr + 68, camY); + MemoryUtil.memPutFloat(ptr + 72, camZ); + MemoryUtil.memPutFloat(ptr + 76, 0f); // vec4 alignment + MemoryUtil.memPutInt(ptr + 80, getConstantAmbientLightFlag(context)); + + if (!Uniforms.frustumPaused || Uniforms.frustumCapture) { + MatrixMath.writePackedFrustumPlanes(ptr + 96, viewProjection); + Uniforms.frustumCapture = false; + } + } + + private static int getConstantAmbientLightFlag(RenderContext context) { + var constantAmbientLight = context.level() + .effects() + .constantAmbientLight(); + return constantAmbientLight ? 1 : 0; + } +} diff --git a/src/main/java/com/jozufozu/flywheel/backend/engine/uniform/UniformBuffer.java b/src/main/java/com/jozufozu/flywheel/backend/engine/uniform/UniformBuffer.java new file mode 100644 index 000000000..c21865799 --- /dev/null +++ b/src/main/java/com/jozufozu/flywheel/backend/engine/uniform/UniformBuffer.java @@ -0,0 +1,38 @@ +package com.jozufozu.flywheel.backend.engine.uniform; + +import org.lwjgl.opengl.GL32; + +import com.jozufozu.flywheel.backend.gl.buffer.GlBuffer; +import com.jozufozu.flywheel.backend.gl.buffer.GlBufferUsage; +import com.jozufozu.flywheel.lib.memory.MemoryBlock; + +public class UniformBuffer { + // private static final int MAX_SIZE = GL32.glGetInteger(GL32.GL_MAX_UNIFORM_BLOCK_SIZE); + + private final int index; + private final GlBuffer buffer; + public final T provider; + private final MemoryBlock data; + + public UniformBuffer(int index, T provider) { + this.index = index; + this.buffer = new GlBuffer(GlBufferUsage.DYNAMIC_DRAW); + this.provider = provider; + + this.data = MemoryBlock.mallocTracked(provider.byteSize()); + } + + public void update() { + provider.write(data.ptr()); + buffer.upload(data); + } + + public void bind() { + GL32.glBindBufferRange(GL32.GL_UNIFORM_BUFFER, index, buffer.handle(), 0, data.size()); + } + + public void delete() { + data.free(); + buffer.delete(); + } +} diff --git a/src/main/java/com/jozufozu/flywheel/backend/engine/uniform/UniformProvider.java b/src/main/java/com/jozufozu/flywheel/backend/engine/uniform/UniformProvider.java new file mode 100644 index 000000000..2f65f126a --- /dev/null +++ b/src/main/java/com/jozufozu/flywheel/backend/engine/uniform/UniformProvider.java @@ -0,0 +1,7 @@ +package com.jozufozu.flywheel.backend.engine.uniform; + +public interface UniformProvider { + void write(long ptr); + + int byteSize(); +} diff --git a/src/main/java/com/jozufozu/flywheel/backend/engine/uniform/Uniforms.java b/src/main/java/com/jozufozu/flywheel/backend/engine/uniform/Uniforms.java new file mode 100644 index 000000000..523c3a25b --- /dev/null +++ b/src/main/java/com/jozufozu/flywheel/backend/engine/uniform/Uniforms.java @@ -0,0 +1,60 @@ +package com.jozufozu.flywheel.backend.engine.uniform; + +import com.jozufozu.flywheel.api.event.ReloadLevelRendererEvent; +import com.jozufozu.flywheel.api.event.RenderContext; + +public class Uniforms { + public static boolean frustumPaused = false; + public static boolean frustumCapture = false; + private static UniformBuffer frame; + private static UniformBuffer fog; + + public static UniformBuffer frame() { + if (frame == null) { + frame = new UniformBuffer<>(0, new FrameUniforms()); + } + return frame; + } + + public static UniformBuffer fog() { + if (fog == null) { + fog = new UniformBuffer<>(1, new FogUniforms()); + } + return fog; + } + + public static void bindForDraw() { + bindFrame(); + bindFog(); + } + + public static void bindFog() { + if (fog != null) { + fog.bind(); + } + } + + public static void bindFrame() { + if (frame != null) { + frame.bind(); + } + } + + public static void updateContext(RenderContext ctx) { + var ubo = frame(); + ubo.provider.setContext(ctx); + ubo.update(); + } + + public static void onReloadLevelRenderer(ReloadLevelRendererEvent event) { + if (frame != null) { + frame.delete(); + frame = null; + } + + if (fog != null) { + fog.delete(); + fog = null; + } + } +} diff --git a/src/main/java/com/jozufozu/flywheel/config/FlwCommands.java b/src/main/java/com/jozufozu/flywheel/config/FlwCommands.java index 7290b7f67..58e4584c3 100644 --- a/src/main/java/com/jozufozu/flywheel/config/FlwCommands.java +++ b/src/main/java/com/jozufozu/flywheel/config/FlwCommands.java @@ -4,7 +4,7 @@ import java.util.function.BiConsumer; import com.jozufozu.flywheel.api.backend.Backend; import com.jozufozu.flywheel.api.backend.BackendManager; -import com.jozufozu.flywheel.lib.uniform.FlwShaderUniforms; +import com.jozufozu.flywheel.backend.engine.uniform.Uniforms; import com.mojang.brigadier.Command; import com.mojang.brigadier.arguments.IntegerArgumentType; import com.mojang.brigadier.builder.LiteralArgumentBuilder; @@ -135,18 +135,18 @@ public class FlwCommands { command.then(Commands.literal("debugFrustum") .then(Commands.literal("pause") .executes(context -> { - FlwShaderUniforms.frustumPaused = true; + Uniforms.frustumPaused = true; return 1; })) .then(Commands.literal("unpause") .executes(context -> { - FlwShaderUniforms.frustumPaused = false; + Uniforms.frustumPaused = false; return 1; })) .then(Commands.literal("capture") .executes(context -> { - FlwShaderUniforms.frustumPaused = true; - FlwShaderUniforms.frustumCapture = true; + Uniforms.frustumPaused = true; + Uniforms.frustumCapture = true; return 1; }))); diff --git a/src/main/java/com/jozufozu/flywheel/impl/RegistryImpl.java b/src/main/java/com/jozufozu/flywheel/impl/RegistryImpl.java index 9e9ae7656..45512c8c7 100644 --- a/src/main/java/com/jozufozu/flywheel/impl/RegistryImpl.java +++ b/src/main/java/com/jozufozu/flywheel/impl/RegistryImpl.java @@ -6,14 +6,12 @@ import java.util.Set; import org.jetbrains.annotations.Unmodifiable; import com.jozufozu.flywheel.api.registry.Registry; -import com.jozufozu.flywheel.api.uniform.ShaderUniforms; import it.unimi.dsi.fastutil.objects.ObjectArrayList; import it.unimi.dsi.fastutil.objects.ObjectList; import it.unimi.dsi.fastutil.objects.ObjectOpenHashSet; import it.unimi.dsi.fastutil.objects.ObjectSet; import it.unimi.dsi.fastutil.objects.ObjectSets; -import net.minecraft.resources.ResourceLocation; public class RegistryImpl implements Registry { private static final ObjectList> ALL = new ObjectArrayList<>(); @@ -31,20 +29,6 @@ public class RegistryImpl implements Registry { return new RegistryImpl<>(); } - public static Registry createForShaderUniforms() { - return new RegistryImpl<>() { - private final ObjectSet files = new ObjectOpenHashSet<>(); - - @Override - public void register(T object) { - if (!files.add(object.uniformShader())) { - throw new IllegalArgumentException(); - } - super.register(object); - } - }; - } - @Override public void register(T object) { if (frozen) { diff --git a/src/main/java/com/jozufozu/flywheel/lib/uniform/FlwShaderUniforms.java b/src/main/java/com/jozufozu/flywheel/lib/uniform/FlwShaderUniforms.java deleted file mode 100644 index e1ca16006..000000000 --- a/src/main/java/com/jozufozu/flywheel/lib/uniform/FlwShaderUniforms.java +++ /dev/null @@ -1,134 +0,0 @@ -package com.jozufozu.flywheel.lib.uniform; - -import java.util.function.Consumer; - -import org.joml.Matrix4f; -import org.lwjgl.system.MemoryUtil; - -import com.jozufozu.flywheel.Flywheel; -import com.jozufozu.flywheel.api.event.BeginFrameEvent; -import com.jozufozu.flywheel.api.event.RenderContext; -import com.jozufozu.flywheel.api.uniform.ShaderUniforms; -import com.jozufozu.flywheel.api.visualization.VisualizationManager; -import com.jozufozu.flywheel.lib.math.MatrixMath; -import com.mojang.blaze3d.systems.RenderSystem; - -import net.minecraft.core.Vec3i; -import net.minecraft.resources.ResourceLocation; -import net.minecraft.world.phys.Vec3; -import net.minecraftforge.common.MinecraftForge; - -public class FlwShaderUniforms implements ShaderUniforms { - public static final FlwShaderUniforms INSTANCE = ShaderUniforms.REGISTRY.registerAndGet(new FlwShaderUniforms()); - - public static final ResourceLocation FILE = Flywheel.rl("uniform/flywheel.glsl"); - public static final int SIZE = 224; - - public static boolean frustumPaused = false; - public static boolean frustumCapture = false; - public static boolean fogUpdate = true; - - @Override - public int byteSize() { - return SIZE; - } - - @Override - public ResourceLocation uniformShader() { - return FILE; - } - - @Override - public Provider activate(long ptr) { - return new Active(ptr); - } - - public static class Active implements Provider, Consumer { - private final long ptr; - - private boolean dirty; - - private final Matrix4f viewProjection = new Matrix4f(); - - public Active(long ptr) { - this.ptr = ptr; - MinecraftForge.EVENT_BUS.addListener(this); - } - - @Override - public void delete() { - MinecraftForge.EVENT_BUS.unregister(this); - } - - @Override - public boolean poll() { - boolean updated = maybeUpdateFog(); - updated |= dirty; - dirty = false; - return updated; - } - - @Override - public void accept(BeginFrameEvent event) { - if (ptr == MemoryUtil.NULL) { - return; - } - RenderContext context = event.getContext(); - - Vec3i renderOrigin = VisualizationManager.getOrThrow(context.level()) - .getRenderOrigin(); - Vec3 camera = context.camera() - .getPosition(); - - var camX = (float) (camera.x - renderOrigin.getX()); - var camY = (float) (camera.y - renderOrigin.getY()); - var camZ = (float) (camera.z - renderOrigin.getZ()); - - viewProjection.set(context.viewProjection()); - viewProjection.translate(-camX, -camY, -camZ); - - MatrixMath.writeUnsafe(viewProjection, ptr + 32); - MemoryUtil.memPutFloat(ptr + 96, camX); - MemoryUtil.memPutFloat(ptr + 100, camY); - MemoryUtil.memPutFloat(ptr + 104, camZ); - MemoryUtil.memPutFloat(ptr + 108, 0f); // vec4 alignment - MemoryUtil.memPutInt(ptr + 112, getConstantAmbientLightFlag(context)); - - if (!frustumPaused || frustumCapture) { - MatrixMath.writePackedFrustumPlanes(ptr + 128, viewProjection); - frustumCapture = false; - } - - dirty = true; - } - - private static int getConstantAmbientLightFlag(RenderContext context) { - var constantAmbientLight = context.level() - .effects() - .constantAmbientLight(); - return constantAmbientLight ? 1 : 0; - } - - private boolean maybeUpdateFog() { - if (!fogUpdate || ptr == MemoryUtil.NULL) { - return false; - } - - var color = RenderSystem.getShaderFogColor(); - - MemoryUtil.memPutFloat(ptr, color[0]); - MemoryUtil.memPutFloat(ptr + 4, color[1]); - MemoryUtil.memPutFloat(ptr + 8, color[2]); - MemoryUtil.memPutFloat(ptr + 12, color[3]); - MemoryUtil.memPutFloat(ptr + 16, RenderSystem.getShaderFogStart()); - MemoryUtil.memPutFloat(ptr + 20, RenderSystem.getShaderFogEnd()); - MemoryUtil.memPutInt(ptr + 24, RenderSystem.getShaderFogShape() - .getIndex()); - - fogUpdate = false; - - return true; - } - - } -} diff --git a/src/main/java/com/jozufozu/flywheel/mixin/FogUpdateMixin.java b/src/main/java/com/jozufozu/flywheel/mixin/FogUpdateMixin.java index 43e8f6059..92e50e5dc 100644 --- a/src/main/java/com/jozufozu/flywheel/mixin/FogUpdateMixin.java +++ b/src/main/java/com/jozufozu/flywheel/mixin/FogUpdateMixin.java @@ -6,7 +6,8 @@ import org.spongepowered.asm.mixin.injection.At; import org.spongepowered.asm.mixin.injection.Inject; import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; -import com.jozufozu.flywheel.lib.uniform.FlwShaderUniforms; +import com.jozufozu.flywheel.backend.engine.uniform.Uniforms; +import com.jozufozu.flywheel.backend.gl.GlStateTracker; import net.minecraft.client.renderer.FogRenderer; @@ -14,7 +15,10 @@ import net.minecraft.client.renderer.FogRenderer; abstract class FogUpdateMixin { @Unique private static void flywheel$updateFog() { - FlwShaderUniforms.fogUpdate = true; + try (var restoreState = GlStateTracker.getRestoreState()) { + Uniforms.fog() + .update(); + } } @Inject(method = "setupNoFog()V", at = @At("RETURN")) diff --git a/src/main/resources/assets/flywheel/flywheel/fog/linear.glsl b/src/main/resources/assets/flywheel/flywheel/fog/linear.glsl index 0b774aee8..9c03c6791 100644 --- a/src/main/resources/assets/flywheel/flywheel/fog/linear.glsl +++ b/src/main/resources/assets/flywheel/flywheel/fog/linear.glsl @@ -8,5 +8,5 @@ vec4 linearFog(vec4 color, float distance, float fogStart, float fogEnd, vec4 fo } vec4 flw_fogFilter(vec4 color) { - return linearFog(color, flw_distance, flywheel.fogRange.x, flywheel.fogRange.y, flywheel.fogColor); + return linearFog(color, flw_distance, flw_fogRange.x, flw_fogRange.y, flw_fogColor); } diff --git a/src/main/resources/assets/flywheel/flywheel/fog/linear_fade.glsl b/src/main/resources/assets/flywheel/flywheel/fog/linear_fade.glsl index 0adf99a10..6eaffb176 100644 --- a/src/main/resources/assets/flywheel/flywheel/fog/linear_fade.glsl +++ b/src/main/resources/assets/flywheel/flywheel/fog/linear_fade.glsl @@ -9,5 +9,5 @@ vec4 linearFogFade(vec4 color, float distance, float fogStart, float fogEnd) { } vec4 flw_fogFilter(vec4 color) { - return linearFogFade(color, flw_distance, flywheel.fogRange.x, flywheel.fogRange.y); + return linearFogFade(color, flw_distance, flw_fogRange.x, flw_fogRange.y); } diff --git a/src/main/resources/assets/flywheel/flywheel/internal/common.frag b/src/main/resources/assets/flywheel/flywheel/internal/common.frag index 8016b7691..66fb0fc77 100644 --- a/src/main/resources/assets/flywheel/flywheel/internal/common.frag +++ b/src/main/resources/assets/flywheel/flywheel/internal/common.frag @@ -31,7 +31,7 @@ void _flw_main() { if (flw_fragDiffuse) { float diffuseFactor; - if (flywheel.constantAmbientLight == 1) { + if (flw_constantAmbientLight == 1) { diffuseFactor = diffuseNether(flw_vertexNormal); } else { diffuseFactor = diffuse(flw_vertexNormal); diff --git a/src/main/resources/assets/flywheel/flywheel/internal/common.vert b/src/main/resources/assets/flywheel/flywheel/internal/common.vert index cbbcef458..e7045f810 100644 --- a/src/main/resources/assets/flywheel/flywheel/internal/common.vert +++ b/src/main/resources/assets/flywheel/flywheel/internal/common.vert @@ -15,6 +15,6 @@ void _flw_main(in FlwInstance instance) { _flw_vertexDiffuse = uint(flw_vertexDiffuse); - flw_distance = fogDistance(flw_vertexPos.xyz, flywheel.cameraPos.xyz, flywheel.fogShape); - gl_Position = flywheel.viewProjection * flw_vertexPos; + flw_distance = fogDistance(flw_vertexPos.xyz, flw_cameraPos.xyz, flw_fogShape); + gl_Position = flw_viewProjection * flw_vertexPos; } diff --git a/src/main/resources/assets/flywheel/flywheel/internal/common_api_impl.frag b/src/main/resources/assets/flywheel/flywheel/internal/common_api_impl.frag index e8d20c7c5..dea3ab9a2 100644 --- a/src/main/resources/assets/flywheel/flywheel/internal/common_api_impl.frag +++ b/src/main/resources/assets/flywheel/flywheel/internal/common_api_impl.frag @@ -1,4 +1,6 @@ #include "flywheel:internal/material.glsl" +#include "flywheel:internal/uniforms/frame.glsl" +#include "flywheel:internal/uniforms/fog.glsl" in vec4 flw_vertexPos; in vec4 flw_vertexColor; diff --git a/src/main/resources/assets/flywheel/flywheel/internal/common_api_impl.vert b/src/main/resources/assets/flywheel/flywheel/internal/common_api_impl.vert index 1c082e55d..e17c0084f 100644 --- a/src/main/resources/assets/flywheel/flywheel/internal/common_api_impl.vert +++ b/src/main/resources/assets/flywheel/flywheel/internal/common_api_impl.vert @@ -1,4 +1,6 @@ #include "flywheel:internal/material.glsl" +#include "flywheel:internal/uniforms/frame.glsl" +#include "flywheel:internal/uniforms/fog.glsl" // TODO: can we combine some of these internally to use fewer in/out slots? out vec4 flw_vertexPos; diff --git a/src/main/resources/assets/flywheel/flywheel/internal/indirect/cull.glsl b/src/main/resources/assets/flywheel/flywheel/internal/indirect/cull.glsl index 8df09c308..8b4e46268 100644 --- a/src/main/resources/assets/flywheel/flywheel/internal/indirect/cull.glsl +++ b/src/main/resources/assets/flywheel/flywheel/internal/indirect/cull.glsl @@ -1,6 +1,7 @@ #include "flywheel:internal/indirect/buffers.glsl" #include "flywheel:internal/indirect/model_descriptor.glsl" #include "flywheel:internal/indirect/object.glsl" +#include "flywheel:internal/uniforms/frame.glsl" layout(local_size_x = _FLW_SUBGROUP_SIZE) in; @@ -23,8 +24,8 @@ layout(std430, binding = _FLW_MODEL_BUFFER_BINDING) restrict buffer ModelBuffer // com.jozufozu.flywheel.lib.math.MatrixMath.writePackedFrustumPlanes // org.joml.FrustumIntersection.testSphere bool _flw_testSphere(vec3 center, float radius) { - bvec4 xyInside = greaterThanEqual(fma(flywheel.planes.xyX, center.xxxx, fma(flywheel.planes.xyY, center.yyyy, fma(flywheel.planes.xyZ, center.zzzz, flywheel.planes.xyW))), -radius.xxxx); - bvec2 zInside = greaterThanEqual(fma(flywheel.planes.zX, center.xx, fma(flywheel.planes.zY, center.yy, fma(flywheel.planes.zZ, center.zz, flywheel.planes.zW))), -radius.xx); + bvec4 xyInside = greaterThanEqual(fma(flw_frustumPlanes.xyX, center.xxxx, fma(flw_frustumPlanes.xyY, center.yyyy, fma(flw_frustumPlanes.xyZ, center.zzzz, flw_frustumPlanes.xyW))), -radius.xxxx); + bvec2 zInside = greaterThanEqual(fma(flw_frustumPlanes.zX, center.xx, fma(flw_frustumPlanes.zY, center.yy, fma(flw_frustumPlanes.zZ, center.zz, flw_frustumPlanes.zW))), -radius.xx); return all(xyInside) && all(zInside); } diff --git a/src/main/resources/assets/flywheel/flywheel/internal/uniforms/fog.glsl b/src/main/resources/assets/flywheel/flywheel/internal/uniforms/fog.glsl new file mode 100644 index 000000000..877c1aa16 --- /dev/null +++ b/src/main/resources/assets/flywheel/flywheel/internal/uniforms/fog.glsl @@ -0,0 +1,5 @@ +layout(std140) uniform _FlwFogUniforms { + vec4 flw_fogColor; + vec2 flw_fogRange; + int flw_fogShape; +}; diff --git a/src/main/resources/assets/flywheel/flywheel/internal/uniforms/frame.glsl b/src/main/resources/assets/flywheel/flywheel/internal/uniforms/frame.glsl new file mode 100644 index 000000000..5f975a838 --- /dev/null +++ b/src/main/resources/assets/flywheel/flywheel/internal/uniforms/frame.glsl @@ -0,0 +1,17 @@ +struct FrustumPlanes { + vec4 xyX;// + vec4 xyY;// + vec4 xyZ;// + vec4 xyW;// + vec2 zX;// + vec2 zY;// + vec2 zZ;// + vec2 zW;// +}; + +layout(std140) uniform _FlwFrameUniforms { + mat4 flw_viewProjection; + vec4 flw_cameraPos; + int flw_constantAmbientLight; + FrustumPlanes flw_frustumPlanes; +}; diff --git a/src/main/resources/assets/flywheel/flywheel/uniform/flywheel.glsl b/src/main/resources/assets/flywheel/flywheel/uniform/flywheel.glsl deleted file mode 100644 index 70ff97abd..000000000 --- a/src/main/resources/assets/flywheel/flywheel/uniform/flywheel.glsl +++ /dev/null @@ -1,20 +0,0 @@ -struct FrustumPlanes { - vec4 xyX; // - vec4 xyY; // - vec4 xyZ; // - vec4 xyW; // - vec2 zX; // - vec2 zY; // - vec2 zZ; // - vec2 zW; // -}; - -struct FlywheelUniforms { - vec4 fogColor; - vec2 fogRange; - int fogShape; - mat4 viewProjection; - vec4 cameraPos; - int constantAmbientLight; - FrustumPlanes planes; -};