国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

UnityShader3實現彩光效果

2020-01-24 00:07:54
字體:
來源:轉載
供稿:網友

本文實例為大家分享了UnityShader3實現彩光效果展示的具體代碼,供大家參考,具體內容如下

參考鏈接: 【OpenGL】Shader實例分析(八)- 彩色光圈

效果圖:

這里我把它分三部分實現:1.彩色 2.光圈 3.動畫

1.先實現彩色效果。分析一下那張彩色圖,它是以中心為原點的,然后顏色分為三部分,如下圖。當角度為90度時,藍色最多;當角度為-150度時,紅色最多;當角度為-30度時,綠色最多。然后其他地方就是三色混合。

Shader "Custom/Colors"{ Properties { _AngleRange ("AngleRange", Range(60, 120)) = 60 } SubShader { Pass { CGPROGRAM #pragma vertex vert #pragma fragment frag #include "UnityCG.cginc"  #define PI 3.142  struct appdata { float4 vertex : POSITION; };  struct v2f {  float4 vertex : SV_POSITION; float4 scrPos : TEXCOORD0; };  half _AngleRange;  v2f vert (appdata v) { v2f o; o.vertex = mul(UNITY_MATRIX_MVP, v.vertex); o.scrPos = ComputeScreenPos(o.vertex);  return o; }  fixed4 frag (v2f i) : SV_Target { //范圍在(0, 1)  float2 wcoord = i.scrPos.xy / i.scrPos.w;  //映射到(-1, 1),即屏幕中心為(0, 0)  wcoord = wcoord * 2 - 1;  //atan2(y, x):反正切,y/x的反正切范圍在[-π, π]內  float radian = atan2(wcoord.y, wcoord.x);  //1度(°)=0.017弧度(rad) //1弧度(rad)=57.29578度(°) float angle = radian * 57.3; //映射到(0, 360) if(angle < 0) angle = 360 + angle;  fixed b = 1 - saturate(abs(angle - 90) / _AngleRange); fixed g; if(angle > 180) g = 1 - saturate(abs(angle - 330) / _AngleRange);  else g = 1 - saturate((angle + 30) / _AngleRange); fixed r = 1 - saturate(abs(angle - 210) / _AngleRange);  return fixed4(r, g, b, 1); } ENDCG } }}

2.先說一下1 / (xxx)這個式子的強大,它實現的效果,往往會帶有光暈效果。其中第六個就是我們想要實現的光圈效果。

Shader "Custom/Test"{ Properties { _Value ("Value", Range(1, 50)) = 1 } SubShader { Pass { CGPROGRAM #pragma vertex vert #pragma fragment frag #include "UnityCG.cginc"  struct appdata { float4 vertex : POSITION; float2 uv : TEXCOORD0; };  struct v2f {  float4 vertex : SV_POSITION; float2 uv : TEXCOORD0; };  half _Value;  v2f vert (appdata v) { v2f o; o.vertex = mul(UNITY_MATRIX_MVP, v.vertex); o.uv = v.uv; return o; }  fixed4 frag (v2f i) : SV_Target { //映射到(-1, 1),使其中心點為原點 float2 uv = i.uv * 2 - float2(1, 1); float v;  //v = 1 / abs(_Value * uv.y);//1 //v = 1 / abs(_Value * (uv.y + uv.x));//2 //v = 1 / abs(_Value * (uv.y + 2 * uv.x));//3 //v = 1 / abs(_Value * (abs(uv.y) + abs(uv.x)));//4 //v = 1 / abs(_Value * length(uv));//5 //v = 1 / abs(_Value * abs(length(uv) - 0.5));//6 v = 1 / abs(_Value * abs(uv.x / uv.y));//7 x越小y越大,則越亮  return fixed4(v, v, v, 1); } ENDCG } }}

3.動畫。這里我做的效果是基于角度的光線間隔效果,首先當然就是計算角度了,間隔的實現就是fmod和step的使用。

Shader "Custom/Test"{ Properties { _Width ("Width", Range(30, 90)) = 45 } SubShader { Pass { CGPROGRAM #pragma vertex vert #pragma fragment frag #include "UnityCG.cginc"  struct appdata { float4 vertex : POSITION; float2 uv : TEXCOORD0; };  struct v2f {  float4 vertex : SV_POSITION; float2 uv : TEXCOORD0; };  half _Width;  v2f vert (appdata v) { v2f o; o.vertex = mul(UNITY_MATRIX_MVP, v.vertex); o.uv = v.uv; return o; }  fixed4 frag (v2f i) : SV_Target { //映射到(-1, 1),使其中心點為原點 float2 uv = i.uv * 2 - float2(1, 1);  float a = atan2(uv.y, uv.x); a *= 57.3; if(a < 0) a += 360;  float b = fmod(a + _Time.y * 20, _Width); b = step(0.5 * _Width, b);  return fixed4(b, b, b, 1); } ENDCG } }}

>

4.最后當然就是將它們揉在一起了。

Shader "Custom/Colors"{ Properties { _AngleRange ("AngleRange", Range(60, 120)) = 60 _Width ("Width", Range(30, 90)) = 45  } SubShader { Pass { CGPROGRAM #pragma vertex vert #pragma fragment frag #include "UnityCG.cginc"  #define PI 3.142  struct appdata { float4 vertex : POSITION; float2 uv : TEXCOORD0; };  struct v2f {  float4 vertex : SV_POSITION; float4 scrPos : TEXCOORD0; float2 uv : TEXCOORD1; };  half _AngleRange; half _Width;   v2f vert (appdata v) { v2f o; o.vertex = mul(UNITY_MATRIX_MVP, v.vertex); o.scrPos = ComputeScreenPos(o.vertex); o.uv = v.uv;   return o; }  fixed4 frag (v2f i) : SV_Target { //1.彩色  //范圍在(0, 1)  float2 wcoord = i.scrPos.xy / i.scrPos.w;  //映射到(-1, 1),即屏幕中心為(0, 0)  wcoord = wcoord * 2 - 1;  //atan2(y, x):反正切,y/x的反正切范圍在[-π, π]內  float radian = atan2(wcoord.y, wcoord.x);  //1度(°)=0.017弧度(rad) //1弧度(rad)=57.29578度(°) float angle = radian * 57.3; //映射到(0, 360) if(angle < 0) angle = 360 + angle;  fixed b = 1 - saturate(abs(angle - 90) / _AngleRange); fixed g; if(angle > 180) g = 1 - saturate(abs(angle - 330) / _AngleRange);  else g = 1 - saturate((angle + 30) / _AngleRange); fixed r = 1 - saturate(abs(angle - 210) / _AngleRange);  //2.光圈  //映射到(-1, 1),使其中心點為原點  float2 uv = i.uv * 2 - float2(1, 1);  float v = 1 / abs(30 * abs(length(uv) - 0.3));  //3.轉動  float a = atan2(uv.y, uv.x);  a *= 57.3;  if(a < 0) a += 360;   float aa = fmod(a + _Time.y * 20, _Width);  aa = step(0.5 * _Width, aa);   ////////////////////// ////////////////////// if(length(uv) < 0.3) return fixed4(0, 0, 0, 1); return fixed4(r, g, b, 1) * aa + fixed4(v, v, v, 1); } ENDCG } }}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 鄂托克前旗| 鱼台县| 连江县| 和林格尔县| 海门市| 诸暨市| 汽车| 酒泉市| 长武县| 保定市| 安岳县| 晋城| 呼和浩特市| 公主岭市| 长泰县| 浙江省| 盖州市| 田阳县| 即墨市| 河津市| 茌平县| 铜山县| 当雄县| 乌海市| 翁牛特旗| 古蔺县| 永清县| 瑞金市| 衡南县| 通海县| 长岭县| 常熟市| 仪征市| 凌源市| 嵩明县| 偏关县| 阿拉尔市| 肇庆市| 临猗县| 阿城市| 萝北县|