您的位置:首页 > 移动开发 > Swift

Metal学习(2)

2016-12-24 21:41 591 查看
MTKView 是NSView/UIView的子类,它有一个嵌入式的Metal层,负责管理framebuffer,渲染目标和draw循环。

•device - 是GPU的抽象,处理command queue的命令,进行渲染等

•command queue - 是一系列的command buffer,它存储着命令的执行顺序,把这个想象成是一个列表装载着你告诉GPU一次要执行的命令。

•command buffer - 存储着command encoder转换后的命令。你可以把它想象为一系列这一帧想要执行的渲染命令。在你提交command
buffer之前,没有事情会真正发生,这样给你对事物在何时发生有一个很好的控制。

•command encoder - 把API命令转换成GPU命令,有3种类型的encoder:render(图形渲染),compute(数据并行处理),blit(资源复制操作)。

Render Command Encoder (RCE) 是渲染命令,当你完成后,你只要调用
endEncoding()。MTLRenderPassDescriptor,它能配置什么纹理会被渲染到、什么是clear color,以及其他的配置。

1.创建cocoa应用,只选择swift和use storyboards。

2. 创建一个类型为NSView的MetalView.swift,在storyboard的view controller里选择View,如下图所示,在Identity Inspector里设置它的类为MetalView

import MetalKit

class MetalView: MTKView {

required init(coder: NSCoder) {
super.init(coder: coder)
device = MTLCreateSystemDefaultDevice()
}
//必须override draw函数
override func draw(_ dirtyRect: NSRect) {
if let drawable = currentDrawable, let rpd = currentRenderPassDescriptor {
rpd.colorAttachments[0].texture = currentDrawable!.texture
rpd.colorAttachments[0].clearColor = MTLClearColor(red: 0, green: 0.5, blue: 0.5, alpha: 1)
rpd.colorAttachments[0].loadAction = .clear //在绘制之前,清空纹理
let commandBuffer = device!.makeCommandQueue().makeCommandBuffer()
let commandEncoder = commandBuffer.makeRenderCommandEncoder(descriptor: rpd)
commandEncoder.endEncoding()
commandBuffer.present(drawable) //保证新纹理会在绘制完成后立即出现
commandBuffer.commit() //把事务提交,把任务交给GPU
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  swift Metal