颜色空间:伽马与线性

全局思维导图

伽马颜色空间

为什么会有伽马颜色空间?这是由于早期的CRT显示设备输入的电压与显示的亮度并非线性关系,显示设备内部会进行伽马校正,于是造成了显示出来的图片颜色偏暗的效果。

Gamma曲线
输入、输出对比

观察上图,左边的图片更加接近人眼实际看到的样子,但显示器真正显示出来的却是右边图片的样子。为了确保我们看到的图片与显示器显示出来的一样,就需要显示器去进行伽马校正计算来中和抵消输入信号与输出亮度的非线性关系。伽马校正的通用公式,可以表达成:

Output = Input ^ \gamma

\gamma 值小于1的时候,我们称为 伽马编码(Gamma Encoding)

\gamma 值大于1的时候,我们称为 伽马解码(Gamma Decoding)

由于没有一个很好的时机可以在显示器校正输出前对数据进行伽马编码,于是普遍的做法是,我们会在图片存储的时候进行伽马编码,它的公式如下:

Output = Input ^ \frac{1}{Gamma}

因此实际图片存储的颜色会偏亮一些,等到在显示器输出时,再通过伽马校正(解码)得到更接近我们人眼识别到的图像。

存储图片(Gamma Encoding) 、 输出屏幕(Gamma Decoding)

但是这样又引发了另一个问题,如果显示设备的Gamma值与图片存储时输入的Gamma值不同,这该如何正确地进行伽马校正呢?
聪明的人们又发明了 Color Profile 这个东西,这里有篇文章 ,建议大家阅读一下:
What is a Color Profile

在我们最常使用的RGB颜色模型下,假设每个通道用8bit来表示,这样最多能表示的颜色种类也就 255 * 255 * 255 = 16581375 种而已,这是远远低于我们人眼所能识别的颜色的。因此 Color Profile 就是为了解释映射颜色数值到光谱波长的对应关系而建立的一套折中方案。

在存储图片的时候,记录 Color Profile 去描述如何将RGB颜色值转成光谱波长。当显示器需要显示图片时,先根据图片的 Color Profile 来将颜色变换成波长,再通过显示器自己的 Color Profile 来得到该波长对应的RGB颜色值。这样就保证了同一张图片在不同的显示设备上看起来都是相同的,即使图片存储时的Gamma值与显示器显示图片时的Gamma值不相同。

为了避免这样转来转去过于繁琐,微软和惠普联合制定了一个规范,也就是目前我们最最常用的 Color Profile : sRGB 。除了在某些特殊的专业领域,你基本上可以将 sRGB 等同于唯一的 Color Profile 了。既然图片存储和设备显示都用的一套规范,自然也就省去了转换的操作。

线性颜色空间

既然使用伽马颜色空间能够方便在显示器上显示出更接近人眼感知的颜色,为什么还要用线性颜色空间呢?

答案就是 光照计算

假设我们在shader中定义 输出颜色 = 贴图颜色 * 光照系数 ,其中这里的贴图颜色是经过Gamma Encoding 过的,所以就需要我们再乘上 Gamma 系数。这样公式就变成了:

FinalColor = rgb ^ {Gamma} * Light

但实际上,我们并不希望在这里做伽马校正,而是应该在输出到屏幕的时候。在shader中仅直接操作贴图的颜色,于是公式又变成:

FinalColor = (rgb * Light) ^{Gamma}

显而易见

rgb^{Gamma} * Light \ne (rgb * Light)^{Gamma}

因此,当需要模拟逼真的物理写实光照,就得转换到线性空间下进行计算。而实际游戏开发过程中,在伽马颜色空间下也是调出来一些看起来还“不错”的光照效果的。不过需要注意的是,颜色计算一定要统一在同一个颜色空间下,否则还是会遇到一些怪异的表现。

最后,推荐阅读下面的两篇文章

浅谈伽马与线性颜色空间

线性空间与Gamma校正

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