[UnityShader]Blending

具体的可以查看官方api:

还有一些不错的文章:

Blending主要用于实现半透明效果,类似于玻璃,学习Blending之前,首先要了解源和目标。

源:已经计算过的颜色,形象地说,就是Blending操作之前,经过各种操作计算后的颜色。

目标:已经在屏幕的颜色,因为要实现半透明效果,要把渲染队列设为Transparent,这里的"已经在屏幕的颜色"指的是在Transparent之前渲染的像素颜色,其中包含相机的背景颜色,这里可以通过测试来证明一下,看不懂的可以先跳过这个shader。其中赋值给_MainTex的是一个rgb为(1,1,1),a为0.5的tex。

Shader "Custom/NewShader 1" {Properties{_MainTex("Base (RGB)", 2D) = "white" {}}SubShader{Tags{ "Queue" = "Transparent" }Blend DstColor ZeroPass{SetTexture[_MainTex] {}}}FallBack "Diffuse"}比较常用的语句:Blend SrcFactor DstFactor

SrcFactor:源因子

DstFactor:目标因子

两者可以取得值为:

经过Blending操作后,最终的颜色=源颜色*SrcFactor+目标颜色*DstFactor,从而达到像玻璃那样的,,混合颜色的效果。

以下讲解一下一个极其简单的玻璃shader:

Shader "Custom/NewShader 1" {Properties{_MainTex("Base (RGB)", 2D) = "white" {}}SubShader{Tags{ "Queue" = "Transparent" }Blend SrcAlpha OneMinusSrcAlphaPass{SetTexture[_MainTex] {}}}FallBack "Diffuse"}效果图:

可以看到,大方块挡住了红球,但是透过大方块却看到了红球,因为Blending关闭了深度缓存。其中赋值给_MainTex的是一个rgb为(1,1,1),a为0.5的tex。这里我们不想被光照模型影响,所以就不使用表面着色器了。

其中核心就是那个Blending语句了,这里是怎么计算的呢?

结果=(1,1,1)*0.5+(1-0.5)*目标颜色,整理一下就是:灰色+0.5*目标颜色(这里的目标颜色有两种:红球的红色以及相机背景的蓝色),在球的地方,大方块的颜色与红球的颜色进行混合,于是就产生了半透明的效果。

这里我们改变相机的背景颜色为黑色:

可以看到这里大方块变成了真正的灰色了。

只需勇敢前行,梦想自会引路,有多远,走多远,把足迹连成生命线。

[UnityShader]Blending

相关文章:

你感兴趣的文章:

标签云: