GAMES101图形学之光栅化(上)

前提

可以先看这个 《计算机图形学基础》之图像的光栅化,不看的话要记住以下几件事:

  • 屏幕是由很多个像素组成的,分辨率就是指像素的数量
  • 先把一些 3D 物体在场景中摆放好,光栅化就是从一个角度看这些物体,把看到的画面显示在由很多像素组成的屏幕上的过程。
  • 一个像素只能显示一种颜色,你可以理解为一个像素就是一个正方形的小格子。
  • 一个像素里面有 RGB 三种颜色的强度,一般都是用的 8bit 寄存器,也就是每个通道是 0-255 的强度。(2^8 = 256)

定义像素坐标

《计算机图形学基础》中定义的方式不同,这门课程的定义方式如下:


从 0 开始,蓝色格子的坐标为 (2,1),蓝色格子中心点坐标为 (2.5,1.5)。

视口变换

设定屏幕的宽为 weight 像素,高为 height 像素。前面经历了 模型变换摄像机变换投影变换(MVP)之后,得到了一个 [-1,1]^3 的立方体之后,需要将该立方体变换到屏幕上,也就是先放大 [weight/2,height/2],再往右上移动 [weight/2,height/2],就可以使得立方体原来 (-1,-1,0) 的点变换到屏幕坐标的 (0,0) 点。这里的深度,也就是 z 轴先不用管。

把标准立方体映射到屏幕

变换矩阵为:
大框框控制缩放,小框框控制平移

光栅化

因为模型是由很多三角形组成的,所以此时,这个画面也依然是由很多三角形构成,我们要把它变成一个个小方块(像素)。(至于为什么是三角形,是因为三角形有良好的性质,比如可以根据三个角对内部进行插值等)

要把左边由三角形构成的图变成右边,也就是使得右边每一个像素都是单一的颜色

对于完全是橘色的像素,和完全是白色的像素很好上色,但对于一半是橘色,一半是白色的如何给像素上色就是一个问题。
这就涉及到图形学中一个常见的方法:采样。如何上色取决于某个位置是否在三角形内部,最简单的方法就是把这个位置定在像素中心点,那么问题就转换成了每个像素中心点是否在三角形内部,如果我们有一个 Inside=F(x,y) (0≤x≤weight,0≤y≤height) 的连续函数,那么只需要令 (x,y) 等于一个像素的中心点,得到一个 bool 值,代表了该点是否在三角形内部。这就是采样,就是使连续函数离散化的过程。上述是在二维空间的采样,在三维空间也可以采样,比如对一个 SDF 3D 贴图进行采样得到其表示的模型。
回到如何给一半橘,一半白的像素上色的问题,对像素中心点采样之后,如果该点在内部,则整体都是橘色,反之整体都是白色。
使用像素中心点采样

确定是否在三角形内

添完色

很明显的锯齿,光栅化图形学的问题之一,下一章讨论优化办法。

Inside 函数的实现

如何实现这个函数呢?看下面,判断 Q 是否在三角形内部。



使用三次叉乘(右手定则)即可:

  • P1P2 X P1Q > 0
  • P2P0 X P2PQ < 0
  • P0P1 X P0Q > 0

三个大小不一样,所以 Q 不是在三条线的同一侧,所以 Q 在三角形外部。
那是否所有的像素中心点都要采样一次呢?也不是,对于一个三角形而言,只会覆盖一个有限的矩形区域:


只需要遍历蓝色部分即可

进一步可能的优化是每一行都取最左和最右,对于那种瘦瘦长长斜斜的三角形来说会优化很多:


指路

https://www.bilibili.com/video/BV1X7411F744?p=5

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,293评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,604评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,958评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,729评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,719评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,630评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,000评论 3 397
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,665评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,909评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,646评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,726评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,400评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,986评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,959评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,996评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,481评论 2 342

推荐阅读更多精彩内容