# HG changeset patch # User Sam # Date 1684169481 -25200 # Node ID 473e6069692d37bed5254c6dabec35b44f3f8136 # Parent a448a32f1b24f80e7ab7d5c04e7bb5dd665264c2 add: small refactoring diff -r a448a32f1b24 -r 473e6069692d src/semicongine/engine.nim --- a/src/semicongine/engine.nim Mon May 15 23:51:06 2023 +0700 +++ b/src/semicongine/engine.nim Mon May 15 23:51:21 2023 +0700 @@ -117,7 +117,8 @@ assert engine.state == Running assert engine.renderer.isSome if engine.state == Running: - engine.renderer.get.refreshMeshData(scene) + engine.renderer.get.updateMeshData(scene) + engine.renderer.get.updateUniformData(scene) engine.renderer.get.render(scene) proc updateInputs*(engine: var Engine): EngineState = diff -r a448a32f1b24 -r 473e6069692d src/semicongine/renderer.nim --- a/src/semicongine/renderer.nim Mon May 15 23:51:06 2023 +0700 +++ b/src/semicongine/renderer.nim Mon May 15 23:51:21 2023 +0700 @@ -54,6 +54,7 @@ assert not (scene in renderer.scenedata) var data = SceneData() + # when mesh transformation are handled through the scenegraph-transformation, set it up here if transformattribute != "": var hasTransformAttribute = false @@ -156,11 +157,10 @@ # setup uniforms and textures for subpass_i in 0 ..< renderer.renderPass.subpasses.len: - var subpass = renderer.renderPass.subpasses[subpass_i] - for pipeline in subpass.pipelines.mitems: + for pipeline in renderer.renderPass.subpasses[subpass_i].pipelines.mitems: var uniformBufferSize = 0'u64 for uniform in pipeline.uniforms: - uniformBufferSize += uniform.thetype.size + uniformBufferSize += uniform.size if uniformBufferSize > 0: for frame_i in 0 ..< renderer.swapchain.inFlightFrames: data.uniformBuffers.add renderer.device.createBuffer( @@ -169,7 +169,6 @@ requireMappable=true, preferVRAM=true, ) - for name, images in scene.textures.pairs: data.textures[name] = @[] let interpolation = images[1] @@ -191,7 +190,7 @@ let bindingNumber = sceneData.attributeBindingNumber[attribute] sceneData.vertexBuffers[memoryPerformanceHint].setData(pdata, size, sceneData.drawables[mesh].bufferOffsets[bindingNumber][2]) -proc refreshMeshData*(renderer: var Renderer, scene: Scene) = +proc updateMeshData*(renderer: var Renderer, scene: Scene) = assert scene in renderer.scenedata for mesh in allComponentsOfType[Mesh](scene.root): @@ -209,21 +208,21 @@ var m = mesh m.clearDataChanged() -proc updateUniforms(renderer: Renderer, scene: var Scene, currentInFlight: int) = +proc updateUniformData*(renderer: var Renderer, scene: var Scene) = assert scene in renderer.scenedata + var data = renderer.scenedata[scene] if data.uniformBuffers.len == 0: return - assert data.uniformBuffers[currentInFlight].vk.valid + assert data.uniformBuffers[renderer.swapchain.currentInFlight].vk.valid for i in 0 ..< renderer.renderPass.subpasses.len: - var subpass = renderer.renderPass.subpasses[i] - for pipeline in subpass.pipelines.mitems: + for pipeline in renderer.renderPass.subpasses[i].pipelines.mitems: var offset = 0'u64 for uniform in pipeline.uniforms: assert uniform.thetype == scene.shaderGlobals[uniform.name].thetype let (pdata, size) = scene.shaderGlobals[uniform.name].getRawData() - data.uniformBuffers[currentInFlight].setData(pdata, size, offset) + data.uniformBuffers[renderer.swapchain.currentInFlight].setData(pdata, size, offset) offset += size proc render*(renderer: var Renderer, scene: var Scene) = @@ -241,18 +240,15 @@ checkVkResult renderer.device.vk.vkDeviceWaitIdle() oldSwapchain.destroy() return + commandBuffer = commandBufferResult.get() - commandBuffer.beginRenderCommands(renderer.renderPass, renderer.swapchain.currentFramebuffer()) - renderer.updateUniforms(scene, renderer.swapchain.currentInFlight) - for i in 0 ..< renderer.renderPass.subpasses.len: - let subpass = renderer.renderPass.subpasses[i] - for pipeline in subpass.pipelines: - var mpipeline = pipeline - commandBuffer.vkCmdBindPipeline(subpass.pipelineBindPoint, mpipeline.vk) - commandBuffer.vkCmdBindDescriptorSets(subpass.pipelineBindPoint, mpipeline.layout, 0, 1, addr(mpipeline.descriptorSets[renderer.swapchain.currentInFlight].vk), 0, nil) + var subpass = renderer.renderPass.subpasses[i] + for pipeline in subpass.pipelines.mitems: + commandBuffer.vkCmdBindPipeline(subpass.pipelineBindPoint, pipeline.vk) + commandBuffer.vkCmdBindDescriptorSets(subpass.pipelineBindPoint, pipeline.layout, 0, 1, addr(pipeline.descriptorSets[renderer.swapchain.currentInFlight].vk), 0, nil) debug "Scene buffers:" for (location, buffer) in renderer.scenedata[scene].vertexBuffers.pairs: