UnityShader3實現(xiàn)彩光效果
本文實例為大家分享了UnityShader3實現(xiàn)彩光效果展示的具體代碼,供大家參考,具體內(nèi)容如下
參考鏈接: 【OpenGL】Shader實例分析(八)- 彩色光圈
效果圖:
這里我把它分三部分實現(xiàn):1.彩色 2.光圈 3.動畫
1.先實現(xiàn)彩色效果。分析一下那張彩色圖,它是以中心為原點的,然后顏色分為三部分,如下圖。當(dāng)角度為90度時,藍(lán)色最多;當(dāng)角度為-150度時,紅色最多;當(dāng)角度為-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的反正切范圍在[-π, π]內(nèi) 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)這個式子的強(qiáng)大,它實現(xiàn)的效果,往往會帶有光暈效果。其中第六個就是我們想要實現(xiàn)的光圈效果。
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.動畫。這里我做的效果是基于角度的光線間隔效果,首先當(dāng)然就是計算角度了,間隔的實現(xiàn)就是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.最后當(dāng)然就是將它們?nèi)嘣谝黄鹆恕?/p>
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的反正切范圍在[-π, π]內(nèi) 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.轉(zhuǎn)動 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 } } }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。
您可能感興趣的文章
- 01-10C#實現(xiàn)txt定位指定行完整實例
- 01-10WinForm實現(xiàn)仿視頻播放器左下角滾動新聞效果的方法
- 01-10C#實現(xiàn)清空回收站的方法
- 01-10C#實現(xiàn)讀取注冊表監(jiān)控當(dāng)前操作系統(tǒng)已安裝軟件變化的方法
- 01-10C#實現(xiàn)多線程下載文件的方法
- 01-10C#實現(xiàn)Winform中打開網(wǎng)頁頁面的方法
- 01-10C#實現(xiàn)遠(yuǎn)程關(guān)閉計算機(jī)或重啟計算機(jī)的方法
- 01-10C#自定義簽名章實現(xiàn)方法
- 01-10C#文件斷點續(xù)傳實現(xiàn)方法
- 01-10winform實現(xiàn)創(chuàng)建最前端窗體的方法


閱讀排行
本欄相關(guān)
- 01-10C#通過反射獲取當(dāng)前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁無法打開的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實現(xiàn)txt定位指定行完整實例
- 01-10WinForm實現(xiàn)仿視頻播放器左下角滾動新
- 01-10C#停止線程的方法
- 01-10C#實現(xiàn)清空回收站的方法
- 01-10C#通過重寫Panel改變邊框顏色與寬度的
- 01-10C#實現(xiàn)讀取注冊表監(jiān)控當(dāng)前操作系統(tǒng)已
隨機(jī)閱讀
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 04-02jquery與jsp,用jquery
- 01-11ajax實現(xiàn)頁面的局部加載
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10delphi制作wav文件的方法
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10C#中split用法實例總結(jié)