71 lines
3.2 KiB
Markdown
71 lines
3.2 KiB
Markdown
|
# Unity通用渲染管线(URP)系列(一)——自定义渲染管线
|
|||
|
|
|||
|
## 逻辑分布
|
|||
|
- CustomRenderPipelineAsset.cs:定义渲染管线Asset,最后创建并且返回定义的管线实例。
|
|||
|
- CustomRenderPipeline.cs:整个渲染管线逻辑。考虑到多视图渲染的关系,还需要为摄像机类实现对应的逻辑。
|
|||
|
- CameraRenderer.cs:摄像机对应的渲染逻辑。
|
|||
|
|
|||
|
## CustomRenderPipeline
|
|||
|
重写`void Render(ScriptableRenderContext context,Camera[] cameras)`,使用自定义的`CameraRenderer`类型的变量renderer,调用`renderer.Render(context,camera)`为每个摄像机(视图)进行渲染。
|
|||
|
|
|||
|
## CameraRenderer
|
|||
|
大部分逻辑都集中在这个类中。
|
|||
|
|
|||
|
重写`void Render(ScriptableRenderContext context,Camera camera)`
|
|||
|
|
|||
|
裁剪之前会进行
|
|||
|
- `PrepareBuffer()`根据摄像机来设置缓存名称
|
|||
|
- `PrepareForSceneWindow()`绘制UI准备
|
|||
|
|
|||
|
1. [裁剪](#Cull)
|
|||
|
2. [设置初始化参数](#Setup)
|
|||
|
3. [绘制可见多边形](#DrawVisibleGeometry)
|
|||
|
4. [绘制Gizmos]()
|
|||
|
5. [提交](#Submit)
|
|||
|
|
|||
|
全代码
|
|||
|
```
|
|||
|
|
|||
|
```
|
|||
|
|
|||
|
###
|
|||
|
#### Command Buffers
|
|||
|
自定义的渲染功能需要设置Command Buffers以存储这个功能所有的渲染命令,创建新的Command Buffers需要设置名称,案例中使用“Render Camera”。
|
|||
|
|
|||
|
使用`buffer.BeginSample(bufferName)`与`buffer.EndSample(bufferName)`给Profiler与帧调试器识别到该渲染功能。
|
|||
|
|
|||
|
执行`Command Buffers`需要在`context`上调用ExecuteCommandBuffer。这会从缓冲区复制命令但并不会清除它,如果要重用它的话,就必须在之后明确地执行该操作。因为执行和清除总是一起完成的,所以添加同时执行这两种方法的方法很方便。
|
|||
|
|
|||
|
#### 编辑器相关功能
|
|||
|
使用`partial`关键字来建立局部类,将Editor相关的代码转移到另一个文件中。
|
|||
|
|
|||
|
### Cull()
|
|||
|
尝试通过Camera获取剪裁变量,之后存储裁剪后的结果。
|
|||
|
|
|||
|
### lighting.Setup(context,cullingResults)
|
|||
|
使用`CullingResults`向Shader传递`DirectionalLight`信息,支持多个方向光。
|
|||
|
|
|||
|
### Setup()
|
|||
|
设置初始变量以及做一些初始化操作:
|
|||
|
1. `SetupCameraProperties`设置摄像相关属性比如投影矩阵
|
|||
|
2. `buffer.ClearRenderTarget`清屏操作。根据清屏标志进行对应的处理。为Depth只会清空深度缓存,颜色的话会清空深度与颜色缓存,如果项目设置为线性颜色则使用线性颜色进行清屏。
|
|||
|
|
|||
|
### DrawVisibleGeometry()
|
|||
|
根据`SortingSettings`、`DrawingSettings`与`FilteringSettings`,之后调用
|
|||
|
` context.DrawRenderers(cullingResults,ref drawingSettings,ref filteringSettings)`绘制模型。
|
|||
|
|
|||
|
在`DrawinSettings`的构造函数中,`SortingSettings`起到确定基于正焦还是基于透视的应用排序,还可以用来设置绘制顺序,`criteria = SortingCriteria.CommonOpaque`设置绘制顺序为从近到远。
|
|||
|
|
|||
|
绘制还需要需要对应着色器的Id,案例中使用`static ShaderTagId unlitShaderTagId = new ShaderTagId("SRPDefaultUnlit")`获取。
|
|||
|
|
|||
|
`FilteringSettings`用于确定哪一些渲染队列是被允许渲染。
|
|||
|
|
|||
|
以及`context.DrawSkybox(camera)`来绘制天空盒。
|
|||
|
|
|||
|
#### 绘制顺序
|
|||
|
|
|||
|
### lighting.Clearup()
|
|||
|
渲染完阴影后,清理阴影图集。
|
|||
|
|
|||
|
### Submit()
|
|||
|
提交给渲染队列。
|