原創文章如需轉載請註明:轉載自風宇衝Unity3D教程學院
Blur
Blur模糊其實理解了以後非常簡單。核心原理就是 1個點的顏色 並不用該點的顏色,而是用該點周圍所有點的均值 (1)確定取點範圍, 例如周圍3個畫素 或者周圍10個畫素 (2)確定各點權重,這也是高斯模糊的由來,主要顏色分配的比重為正態分佈,即高斯分佈。
例子1:最簡單的模糊 (1)新場景,plane上面放一張貼圖 (2)plane上的shader如下
原圖
模糊後的效果
參考文章
Blur模糊其實理解了以後非常簡單。核心原理就是 1個點的顏色 並不用該點的顏色,而是用該點周圍所有點的均值 (1)確定取點範圍, 例如周圍3個畫素 或者周圍10個畫素 (2)確定各點權重,這也是高斯模糊的由來,主要顏色分配的比重為正態分佈,即高斯分佈。
例子1:最簡單的模糊 (1)新場景,plane上面放一張貼圖 (2)plane上的shader如下
- Shader "Custom/ObjectBlur" {
- Properties {
- _MainTex ("Base (RGB)", 2D) = "white" {}
- }
- SubShader
- {
- Tags{"Queue"="Transparent"}
- pass
- {
- CGPROGRAM
- #pragma vertex vert
- #pragma fragment frag
- #include "UnityCG.cginc"
- sampler2D _MainTex;
- float4 _MainTex_ST;
- float uvOffset;
- struct v2f {
- float4 pos : SV_POSITION;
- float2 uv : TEXCOORD0;
- } ;
- v2f vert (appdata_base v)
- {
- v2f o;
- o.pos = mul(UNITY_MATRIX_MVP,v.vertex);
- o.uv = TRANSFORM_TEX(v.texcoord,_MainTex);
- return o;
- }
- float4 frag (v2f i) : COLOR
- {
- float4 s1 = tex2D(_MainTex,i.uv + float2(uvOffset,0.00));
- float4 s2 = tex2D(_MainTex,i.uv + float2(-uvOffset,0.00));
- float4 s3 = tex2D(_MainTex,i.uv + float2(0.00,uvOffset));
- float4 s4 = tex2D(_MainTex,i.uv + float2(0.00,-uvOffset));
- float4 texCol = tex2D(_MainTex,i.uv);
- float4 outp;
- float pct=0.2;
- outp = texCol* (1- pct*4) + s1* pct + s2* pct+ s3* pct + s4* pct;
- return outp;
- }
- ENDCG
- }
- }
- }
- using UnityEngine;
- using System.Collections;
- public class BlurManager : MonoBehaviour {
- private float length =3f;
- private float showTime = -100;
- private float hideTime = -100;
- void Update () {
- if(showTime >0)
- {
- showTime -= Time.deltaTime;
- Shader.SetGlobalFloat("uvOffset", (showTime/length) * 0.005f);
- }
- if(hideTime >0)
- {
- hideTime -= Time.deltaTime;
- Shader.SetGlobalFloat("uvOffset", (1- hideTime/length) * 0.005f);
- }
- }
- void OnGUI()
- {
- if(GUI.Button(new Rect(0,0,100,50),"Show"))
- {
- showTime = length;
- }
- if(GUI.Button(new Rect(100,0,100,50),"Hide"))
- {
- hideTime = length;
- }
- }
- }
原圖
模糊後的效果
參考文章