Unity Shader實現模糊效果
本文實例為大傢分享瞭Unity Shader實現模糊效果的具體代碼,供大傢參考,具體內容如下
今天分享一個超簡單實現模糊效果的方法,先上圖:
核心代碼就這句:
註意要在3.0以上的版本才能使用
在采樣後做偏移采樣再疊加,效果與下面的代碼類似:
float4 frag(v2f o):SV_TARGET{ fixed4 color = tex2D(_MainTex,o.uv);//,float2(_Scale,_Scale),float2(_Scale,_Scale) float2 uv1= o.uv +float2(_Scale,_Scale); fixed4 color2 = tex2D(_MainTex,uv1); float2 uv2= o.uv -float2(_Scale,_Scale); fixed4 color3 = tex2D(_MainTex,uv2); return (color+color2+color3)/3; }
下面的完整代碼:
Shader "Custom/TestShader40" { Properties{ _MainTex("MainTex",2D)="White"{} _Scale("Scale",Range(0,0.1))=0 } SubShader{ Tags { "RenderType"="Opaque" } Pass{ CGPROGRAM #pragma vertex vert #pragma fragment frag #pragma target 3.0 #include "Lighting.cginc" sampler2D _MainTex; float4 _MainTex_ST; float _Scale; struct a2v{ float4 pos:POSITION; float4 uv:TEXCOORD0; }; struct v2f{ float4 wPos:SV_POSITION; float2 uv:TEXCOORD0; }; v2f vert(a2v v){ v2f o; o.wPos = UnityObjectToClipPos(v.pos); o.uv=TRANSFORM_TEX(v.uv,_MainTex); return o; } float4 frag(v2f o):SV_TARGET{ fixed4 color = tex2D(_MainTex,o.uv,float2(_Scale,_Scale),float2(_Scale,_Scale)); return color; } ENDCG } } }
以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。
推薦閱讀:
- unity置灰處理的實現
- Unity Shader實現動態過場切換圖片效果
- Unity Shader實現徑向模糊效果
- Unity Shader實現3D翻頁效果
- Unity Shader實現線框效果的制作步驟