shader调色板

介绍

在用shader程序作画的时候,经常需要颜色的变化描绘物体的细节,使得物体更加的逼真和生动。通常情况下,我们需要把颜色向量从RGB空间映射到HSV空间,然后进行调整。这里介绍一种简单的方法,可以在RGB空间直接进行调节。

方法

我们只需要一个公式就可以完成调色。
color(t) = a + b * cos[2\pi(c*t+d)]
因为得到的color是一个三维向量,所以 a,b,c,d 四个参量都是三维向量(vec3)。在shader中,采样坐标的取值范围是0到1,输出颜色通道的取值范围也是0到1。因此在写shader效果时经常把变量的范围限定或者归一化到0到1。所以取值范围是0到1的变量在shader中很容易获取构造以及分析。因此,这边三角函数的横坐标t也令其为0到1取值。那么根据上述公式,c代表的就是cos函数在2\pi范围内的振动次数,简称频率。d是相位偏移。b是cos的振幅,a是相对于color值(因变量轴)的平移。了解了每个参数的意义,也就知道它们在控制颜色中发挥的作用。
从c开始。c的三个通道分别对应的r(红色),g(绿色),b(蓝色)三个通道。分别代表了r,g,b三个通道颜色在2\pi范围内变化频率。也就是在t取值从0到1过程中,每个通道颜色的变换次数。
举例说明:
如果c是(1.0, 0.0, 0.0),则结果代表红色值在t的取值范围内(这里是0到1)对应从1.0到0.0到1.0变化一次。如下图:

红色通道变化一次

如果c是(2.0, 0.0, 0.0),则代表红色值在t从0到1的范围内振动两次。即从1.0到0.0到1.0后再从1.0到0.0到1.0。如下图:

红色通道变化两次

d是用来改变相位用的。即在t轴方向上进行平移。还是以红色通道为例。如果c.r = 1.0的情况下,d.r = 0.5。则代表着r通道的值向左移动0.5(在t轴方向)。结果如下图:


红色通达值向左移动0.5

b和a参数都比较好理解。b是scale三个通道值的乘数。而a就是直接增减三个通道的值。

//palatte
vec3 pal( in float t, in vec3 a, in vec3 b, in vec3 c, in vec3 d )
{
    return a + b*cos( 6.28318*(c*t+d) );
}

下面举例:当a,b,c,d分别为 vec3(0.5,0.5,0.5), vec3(0.5,0.5,0.5), vec3(1.0,1.0,1.0), vec3(0.0,0.33,0.67) 时的代码和效果图。

varying vec2 v_texCoord;

vec3 pal( in float t, in vec3 a, in vec3 b, in vec3 c, in vec3 d )
{
    return a + b*cos( 6.28318*(c*t+d) );
}

void main()
{   
    vec3 col = pal(v_texCoord.x, vec3(0.5,0.5,0.5), vec3(0.5,0.5,0.5), vec3(1.0,1.0,1.0), vec3(0.0,0.33,0.67));

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

推荐阅读更多精彩内容

  • 曾经,我的第一台电脑找不到显卡驱动,常年只有16色。 1. 调色板是干什么的 旧社会的时候以前机能不好的时候,同屏...
    maAya阅读 1,969评论 1 1
  • 选择题部分 1.(),只有在发生短路事故时或者在负荷电流较大时,变流器中才会有足够的二次电流作为继电保护跳闸之用。...
    skystarwuwei阅读 12,917评论 0 7
  • 高级钳工应知鉴定题库(858题) ***单选题*** 1. 000003难易程度:较难知识范围:相关4 01答案:...
    开源时代阅读 5,780评论 1 9
  • 1. 关于诊断X线机准直器的作用,错误的是()。 (6.0 分) A. 显示照射野 B. 显示中心线 C. 屏蔽多...
    我们村我最帅阅读 10,415评论 0 5
  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 3,343评论 0 2