我是金属新手,我感到困惑......
我有一组顶点,我是"平铺"从主纹理出来。我使用顶点着色器和片段采样着色器来执行此操作。
我想使用不同的纹理覆盖第一个绘图过程和另一个绘图过程。我对于必须执行加载/存储操作等问题感到非常紧张。唉,不 - 下面是我在Swift的渲染循环中所做的。我应该说,覆盖层中的绘图量不到第一遍中的5%。
这很有效。 这真的很容易吗?
我只是有这种唠叨的感觉,我错过了一些东西。另一方面,我可能错误地认为只有一个机会在渲染循环中,比如说,设置渲染编码器的顶点缓冲区。
let renderEncoder : MTLRenderCommandEncoder = (commandBuffer?.makeRenderCommandEncoder(descriptor: renderPassDescriptor!))!
renderEncoder.label = "MyRenderEncoder"
renderEncoder.setViewport(MTLViewport.init(originX: 0.0, originY: 0.0, width: Double(self.drawableSize.width), height: Double(self.drawableSize.height), znear: -1.0, zfar: 1.0))
renderEncoder.setRenderPipelineState(self.pipelineState)
// draw main content
let vertices = ...
let vCount = vertices?.count
let vSize = vCount!*MemoryLayout.size(ofValue: vertices?[0])
let mBuff = self.device!.makeBuffer(bytes: vertices!, length: vSize, options: [])
renderEncoder.setVertexBuffer(mBuff, offset: 0, at: 0)
renderEncoder.setVertexBytes(&self.viewportSize, length: MemoryLayout.size(ofValue: self.viewportSize), at: 1)
renderEncoder.setFragmentTexture(inputTexture, at: 0)
renderEncoder.drawPrimitives(type: MTLPrimitiveType.triangle, vertexStart: 0, vertexCount: vCount!)
// draw overlaying content
let vertices2 = ...
let vCount2 = vertices2?.count
let vSize2 = vCount2!*MemoryLayout.size(ofValue: vertices2?[0])
let mBuff2 = self.device!.makeBuffer(bytes: vertices2!, length: vSize2, options: [])
renderEncoder.setVertexBuffer(mBuff2, offset: 0, at: 0)
renderEncoder.setVertexBytes(&self.viewportSize, length: MemoryLayout.size(ofValue: self.viewportSize), at: 1)
renderEncoder.setFragmentTexture(inputTexture2, at: 0)
renderEncoder.drawPrimitives(type: MTLPrimitiveType.triangle, vertexStart: 0, vertexCount: vCount2!)
// done drawing
renderEncoder.endEncoding()
commandBuffer?.present(view.currentDrawable!)
commandBuffer?.commit()

答案 0 :(得分:3)
你不清楚哪个部分你担心,但是,是的,这有效。您可以更改渲染命令编码器的任何属性,其中包含" set"方法在任何一点,并做一些绘图。您不仅限于每个编码器一次绘制,甚至一次绘制配置。在渲染命令编码器的生命周期中唯一固定的东西是用于创建它的渲染过程描述符描述的属性。
您甚至可以更改使用的渲染管道状态。但是,请记住渲染过程描述符是固定的,并且渲染管道状态的附件像素格式必须与渲染过程描述符的附件纹理匹配。
当然,如果需要,您可以使用多个命令编码器,并且设置加载和存储操作并不困难。