(笔记) RealTimeRender[实时渲染] C2
@author: 白袍小道
@来源:RealTime Render
@建议书籍:龙书、RealTimeR第四版、GPUGem和PRO

(来源:暗影不解释)
引点
这一章关注的管线中的管道功能,而非实现。
(这里开头一句话非常有意思:链条的坚固程度取决于它最薄弱的环节。切记,嘿嘿)
注点
1、视椎体裁剪,需要在装配之前(或者构建顶点缓冲区前)
2、基础管道图

说明:
管道的处理并行或串行的,管道的数据是串行的,流水线(货物一个是一部部来,但可以多个货物都在处理)
每一个阶段都是一个管道,当然管道中可以划分出子阶段
3、FPS 和 HertZ
帧每秒用来表示要么是特定帧的速率,要么是某段时间内的平均性能使用。
赫兹用于硬件,例如显示器,它被设置为一个轴速率。
四大基础管道
、应用程序阶段
|
该阶段是可以(记得GPU也可以做运算的哦)在CPU上,那就是你想做什么就做什么(物理,动画,碰撞等等)。 |
|
|
为了下一步的输入或者说有效输入 ( 点,线,和 三角形 ) 可以对数据(比如场景,模型,顶点,索引做一些有效的查询操作),或者说做一些延时处理(只是为了提高效率),再或者做一些统计(如有多少顶点要处理,有多少边要处理,等等) |
|
|
下一阶段是几何处理(不是几何着色) |
、几何处理
每个三角形和每个顶点的大部分操作
2.0 图元装配

.1 |
顶点着色处理 |
顶点着色有两个主要任务,即计算位置、计算程序想要的顶点输出数据(如正常坐标和纹理坐标,可能还会包含关联骨骼信息)。
目的:确定模型上顶点处材质的光照效果
关键词:模型空间,坐标系及其转换,顶点颜色,法线,视野空间,

2.2 |
投影和裁剪 |
视图卷转换为一个单位立方体
投影:【矩阵转换】
注意因为投影,Z坐标不会放在生成的图像中(二维),而放在深度缓冲区。

裁剪坐标: (注意一点是在 处理单元前,所以是除W前】

2.3 |
屏幕空间映射 |
前面计算输出的坐标映射到对应的屏幕坐标系。

注意:只有视图卷中的(剪切的)基元被传递到屏幕映射的进入这个阶段,坐标仍然是三维的。就是裁剪后。
2.4 |
选项(额外能力) |
当处理完顶点着色操作后,是可以进入到曲面细分,几何着色,输出流(依赖硬件)
3 光栅化阶段
光珊化rasterization:

a\在经过几何阶段处理得到的数据(顶点,颜色以及纹理坐标)基础上给每个像素(Pixel)正确配色,以便正确绘制整幅图像的过程
b\从二维顶点所处的屏幕空间(所有顶点都包含Z值即深度值,及各种与相关的着色信息)到屏幕上的像素的转换。
3.1 |
三角形设定:Triangle Steup |
在这一阶段,将计算三角表面差异和相关数据,在为其设计的硬件上执行。
3.2 |
三角形遍历:Triangle Traversal |
目的:采样点或像素在三角形中
通过逐像素进行判断(改像素的像素中心是否被三角形覆盖,若部分重合,将重合的部分生成片段),片段的属性来源于顶点数据的插值。
3.3 |
像素着色:Pixel Shading |

目的:将插值的数据,通过计算,得到颜色信息。
可编程GPU内执行、计算所有需逐像素操作的过程。
|
3.4 |
合并/融合 Mergin |
目的:合并/融合 当前储存于缓冲器中的由之前的像素着色阶段产生的 片段颜色
a\ GPU子单元执行,并非完全可编程
b\可配置(就是可根据需要调整参数,如半透处理,交叉)
c\可见性问题的处理( Z-buffer用起来)
d\缓冲区:模版缓冲区,深度缓冲区、累计缓冲区(卷积,来处一些特殊效果:软阴影,景深)
光栅化阶段:从相机视点处看到的东西就可以在荧幕上显示出来,但入DX交换链处理(就是双缓冲机制),先到BackBuffer,然后交换(不影响显示的时候)到前置缓冲区。
(笔记) RealTimeRender[实时渲染] C2的更多相关文章
- (笔记) RealTimeRender[实时渲染] C3
@author: 白袍小道 转载表明,查看随缘 前言: 从历史上看,图形加速始于每个像素扫描线上的插值颜色重叠一个三角形,然后显示这些值.包括访问图像数据允许纹理应用于表面.添加硬件 插入和测试z深度 ...
- 【原】实时渲染中常用的几种Rendering Path
[原]实时渲染中常用的几种Rendering Path 本文转载请注明出处 —— polobymulberry-博客园 本文为我的图形学大作业的论文部分,介绍了一些Rendering Path,比较简 ...
- 利用GPU实现无尽草地的实时渲染
0x00 前言 在游戏中展现一个写实的田园场景时,草地的渲染是必不可少的,而一提到高效率的渲染草地,很多人都会想起GPU Gems第七章 <Chapter 7. Rendering Countl ...
- 画面渲染:实时渲染(Real-time Rendering)、离线渲染(Offline Rendering)[转]
实时渲染(Real-time Rendering) 实时渲染的本质就是图形数据的实时计算和输出.最典型的图形数据源是顶点.顶点包括了位置.法向.颜色.纹理坐标.顶点的权重等.在第一代渲染技术中(198 ...
- 封装CIImage实现实时渲染
封装CIImage实现实时渲染 CIImage属于CoreImage里面的东东,用来渲染图片的,为什么要封装它呢?其实很简单,封装好之后使用更加方便. 如果直接使用CIImage渲染图片,使用的流程如 ...
- 如何实现最佳的跨平台游戏体验?Unity成亮解密实时渲染
7月31日,2018云创大会游戏论坛在杭州国际博览中心103B圆满举行.本场游戏论坛聚焦探讨了可能对游戏行业发展有重大推动的新技术.新实践,如AR.区块链.安全.大数据等. Unity大中华区技术经理 ...
- DirectX11笔记(十一)--Direct3D渲染7--RENDER STATES
原文:DirectX11笔记(十一)--Direct3D渲染7--RENDER STATES 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u010 ...
- DirectX11笔记(十)--Direct3D渲染6--PIXEL SHADER
原文:DirectX11笔记(十)--Direct3D渲染6--PIXEL SHADER 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u01033 ...
- DirectX11笔记(九)--Direct3D渲染5--CONSTANT BUFFERS
原文:DirectX11笔记(九)--Direct3D渲染5--CONSTANT BUFFERS 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u0 ...
随机推荐
- Poj(1125),Floyd,
题目链接:http://poj.org/problem?id=1125 多源点最短路中的,最长路的,最短路. 看到这里就懵逼了,解释一下,找到一个源点,使得路最短,(遍历源点),路最短怎么求呢? 就是 ...
- 数长方形有多少个?POJ(1693)
题目链接:http://poj.org/problem?id=1693 解题报告: 随机选两根横的,再找一下与这两根横线相交的竖线有多少根,m,那么就有(m-1)*m/2个长方形. #include ...
- 计算最大矩形面积,POJ(2082)
题目链接:http://poj.org/problem?id=2082 把矩形按照高度一次递增的循序排列,当违反这一规则的时候,更新ans,用新的data替换之前的矩形.然后最后扫一遍. #inclu ...
- Breaking Biscuits(模板题-求凸边形的宽)
Breaking Biscuits 时间限制: 1 Sec 内存限制: 128 MB Special Judge提交: 70 解决: 26[提交] [状态] [讨论版] [命题人:admin] ...
- python-一切事物都是对象
python:一切事物都是对象 开始接触python,在里面有一句话“一切事物都是对象”,那么如何来理解这句话呢,下面举简单的例子: a=1 b='hello't=(11,22,33) list1=[ ...
- CUDA三维数组
http://hpcbbs.it168.com/forum.php?mod=viewthread&tid=1643 根据上面链接的帖子研究了下三维数组,就像他自己说的一样是有问题的,我自己修改 ...
- shell编程中的vim命令说明
vim命令模式: 1.一般命令模式 2.编辑模式 3.底行命令行命令模式 一般命令模式 直接用字符操作编辑模式 可以写文档(跟txt有点像)底行命令模式 先按'ESC',在按下“:”,之后在输出命令 ...
- MySQL-常用的存储引擎
MySQL-常用的存储引擎 存储引擎 事务 锁粒度 主要应用 忌用 MyISAM 不支持 支持并发插入的表级锁 select,insert 读写操作频繁 MRG_MYISAM 不支持 支持并发插入的表 ...
- java TCP通信 socket 套接字 用图片上传轰炸服务器
客户端 package com.swift.jinji; import java.io.FileInputStream; import java.io.IOException; import java ...
- c++ 11 线程池的简单封装
#include <condition_variable> #include <queue> #include <thread> #include <vect ...