Unity Shader 玻璃效果
一个玻璃效果主要分为两个部分,一部分是折射效果的计算,另一部分则是反射。下面分类进行讨论:
折射:
1.利用Grass Pass对当前屏幕的渲染图像进行采样
2.得到法线贴图对折射的影响
3.对采集的屏幕图像进行关于法线方向上的扭曲和偏移,以模拟折射效果
反射:
主要利用环境贴图产生反射的残影,并和主贴图采样结果混合
得到反射和折射的结果后,以一个插值变量控制最终效果(类似于玻璃的透光率);
脚本如下:
1 // Upgrade NOTE: replaced '_Object2World' with 'unity_ObjectToWorld' 2 3 Shader "MyUnlit/GlassRefraction" 4 { 5 Properties 6 { 7 _MainTex ("Texture", 2D) = "white" {} 8 //这里的法线贴图用于计算折射产生的扭曲 9 _BumpMap("Normal Map",2D)="bump"{} 10 //这里的环境贴图用于反射周围环境的部分残影 11 _Cubemap("Environment Map",cube)="_Skybox"{} 12 _Distortion("Distortion",range(0,100))=10 13 //一个折射系数,用于控制折射和反射的占比 14 _RefractAmount("Refract Amount",range(0,1))=1 15 } 16 SubShader 17 { 18 //保证该物体渲染时,其他不透明物体都已经渲染完成 19 Tags { "RenderType"="Opaque" "Queue"="Transparent"} 20 //抓取当前屏幕的渲染图像并存入指定纹理 21 GrabPass{"_RefractionTex"} 22 23 Pass 24 { 25 CGPROGRAM 26 #pragma vertex vert 27 #pragma fragment frag 28 29 #include "UnityCG.cginc" 30 31 struct appdata 32 { 33 float4 vertex : POSITION; 34 float2 uv : TEXCOORD0; 35 float3 normal:NORMAL; 36 float4 tangent:TANGENT; 37 }; 38 39 struct v2f 40 { 41 float4 uv : TEXCOORD0; 42 float4 pos : SV_POSITION; 43 float4 scrPos : TEXCOORD4; 44 float4 TtoW0:TEXCOORD1; 45 float4 TtoW1:TEXCOORD2; 46 float4 TtoW2:TEXCOORD3; 47 }; 48 49 sampler2D _MainTex; 50 float4 _MainTex_ST; 51 sampler2D _BumpMap; 52 float4 _BumpMap_ST; 53 samplerCUBE _Cubemap; 54 float _Distortion; 55 fixed _RefractAmount; 56 sampler2D _RefractionTex; 57 float4 _RefractionTex_TexelSize; 58 59 v2f vert (appdata v) 60 { 61 v2f o; 62 63 o.pos = UnityObjectToClipPos(v.vertex); 64 65 o.uv.xy = TRANSFORM_TEX(v.uv, _MainTex); 66 o.uv.zw = TRANSFORM_TEX(v.uv, _BumpMap); 67 //得到屏幕采样坐标 68 o.scrPos = ComputeGrabScreenPos(o.pos); 69 70 float3 worldPos = mul(unity_ObjectToWorld, v.vertex).xyz; 71 float3 worldNormal = UnityObjectToWorldNormal(v.normal); 72 float3 worldTangent = UnityObjectToWorldDir(v.tangent.xyz); 73 float3 worldBinormal = cross(worldTangent, worldNormal)*v.tangent.w; 74 75 o.TtoW0 = float4(worldTangent.x, worldBinormal.x, worldNormal.x, worldPos.x); 76 o.TtoW1 = float4(worldTangent.y, worldBinormal.y, worldNormal.y, worldPos.y); 77 o.TtoW2 = float4(worldTangent.z, worldBinormal.z, worldNormal.z, worldPos.z); 78 79 return o; 80 } 81 82 fixed4 frag (v2f i) : SV_Target 83 { 84 float3 worldPos = float3(i.TtoW0.w,i.TtoW1.w,i.TtoW2.w); 85 float3x3 TtoW = float3x3(i.TtoW0.xyz, i.TtoW1.xyz, i.TtoW2.xyz); 86 87 fixed3 worldViewDir = normalize(UnityWorldSpaceViewDir(worldPos)); 88 89 fixed3 tanNormal = UnpackNormal(tex2D(_BumpMap, i.uv.zw)); 90 fixed3 worldNormal = mul(TtoW, tanNormal); 91 //对采集的屏幕图像进行关于法线方向上的扭曲和偏移,也就是模拟折射的效果 92 float2 offset = tanNormal.xy*_Distortion*_RefractionTex_TexelSize.xy; 93 i.scrPos.xy += offset; 94 fixed3 refractCol = tex2D(_RefractionTex, i.scrPos.xy / i.scrPos.w).xyz; 95 //这一块用来模拟反射的效果,反射越强,也就是透光度越低,越能看到主贴图纹理以及周围环境反射的残影 96 fixed3 reflectDir = reflect(-worldViewDir, worldNormal); 97 fixed4 mainTexCol = tex2D(_MainTex, i.uv.xy); 98 fixed4 cubemapCol = texCUBE(_Cubemap, reflectDir); 99 fixed3 reflectCol = mainTexCol.rgb*cubemapCol.rgb; 100 //最后将折射和反射进行一个综合叠加,_RefractAmount可以认为是透光率,当它为1时,就是全透过而没有反射,为0时就是全反射跟镜子一样 101 fixed3 color = refractCol * _RefractAmount + reflectCol * (1 - _RefractAmount); 102 return fixed4(color,1.0); 103 } 104 ENDCG 105 } 106 } 107 fallback "Diffuse" 108 }
效果如下:
转载于:https://www.cnblogs.com/koshio0219/p/11114659.html
Unity Shader 玻璃效果相关推荐
- [Unity Shader]凌波微步效果
[Unity Shader]凌波微步效果 相信很多人都看过天龙八部,里面的段誉有一个技能就是凌波微步:移动的时候人先到,衣角跟随其后.说白了就是移动时有一个残影跟着他.下面先看下最终效果 下面我们看如 ...
- shader 玻璃效果
玻璃效果主要是折射效果的计算和反射效果的计算. 折射: 1.利用Grass Pass对当前屏幕的渲染图像进行采样 2.得到法线贴图对折射的影响 3.对采集的屏幕图像进行关于法线方向上的扭曲和偏移,以模 ...
- Unity Shader 动画效果出现残影
问题 复现<Unity Shader入门精要>的动画效果时,我发现我的动画都出现了残影. 一开始认为是程序写错了,采样出现了问题,但是复查对比其他资料很多遍也没发现错误. 解决方法 后来反 ...
- Unity Shader放大镜效果
小菜最近看到了一篇关于Shader实现的放大镜效果,酷炫的效果让小菜倍生好奇,冲动之下还是搬来练练手,刚好巩固下自己的顶点片元着色器编码. 有没有想学习的冲动!!! 文章的开始先来介绍一款好用的vs编 ...
- Unity Shader 新手引导效果
这两天实现了下新手引导需要的遮罩镂空shader效果,记录一下. 1.圆形镂空shader代码: //计算片元世界坐标和目标中心位置的距离 float dis = distance(IN.worldP ...
- unity Shader 扭曲效果
原理 所谓扭曲就是扰动一个物体的uv坐标,表现出来就是一个扰动效果,如火焰扭曲空气,和水波对水底的影响. 1. 在shader 中我们需要一张当前渲染的纹理 2. 给一个物体渲染并使用当前纹理,用屏幕 ...
- Unity Shader - 描边效果
原文链接:http://blog.csdn.net/puppet_master/article/details/54000951 简介 描边效果是游戏里面非常常用的一种效果,一般是为了凸显游戏中的某个 ...
- Unity Shader透明效果
在实时渲染中要实现透明效果,通常会在渲染模型时控制他的透明通道.当开启透明混合后,当一个物体被渲染到屏幕上时,每个片元除了颜色值和深度值之外,它还有另一个属性--透明度.当透明度为1时表示该像素是完全 ...
- Unity Shader 贴花效果(一)
本文实现的是一个Mesh Decal方法的贴花方案,参考了本篇博文链接: unity的贴花方案.链接的文章是转载的,我并没有找到原文地址.本篇文章主要是学习和自己的理解为主. 先看未贴花之前的效果 这 ...
最新文章
- python直接执行代码漏洞_修复Python任意命令执行漏洞
- Java将弃用finalize()方法?
- Juniper SRX防火墙系统会话链接的清除
- 《数据库原理与应用》(第三版)第9章 事务与并发控制 基础 习题参考答案
- 谈谈对IOC及DI的理解与思考
- PaperNotes(2)-Generative Adversarial Nets
- PHP 循环引用的问题
- java二次排序_使用java 实现二次排序
- bwl老二吃嘲讽吗_怀旧服BWL2小时全通最简打法!时光点燃一次过
- python 嵌入式数据库_Pysqlite下载 Pysqlite for Windows v2.6.3(嵌入式数据库python api 接口) 下载-脚本之家...
- 【Python的自学之路】(八):文字游戏分享
- 计算机四级网络题型,全国计算机四级考试题型
- ubuntu查看端口
- 读《因果的真相》第八、九章摘抄笔记
- Cirium称,2020年航空公司准点率表现良好,但客运航班数只有2019年的一半
- 东北工学院 计算机 姚岚,东北的大学最强十校,工科是真强,2所211大学无缘前十...
- 【山外笔记-计算机网络·第7版】第13章:计算机网络名词缩写汇总
- (四十三)参数法与非参数法(历史模拟法)计算VaR
- android mv模式,新增MV功能 天天动听Android 7.9版体验
- 10个你未必知道的CSS技巧与14种cssdiv中基本滤镜介绍