Shaders 102 - Basics of Image Effects

Shaders 102 - Basics of Image Effects

整體對屏幕效果進行處理
Screen = Mega Quad

image.png

OnRenderImage(src,dst);
制作腳本掛在Camera下,

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
[ExecuteInEditMode]
public class CustomImageEffect : MonoBehaviour
{
    public Material EffectMat;
    private void OnRenderImage(RenderTexture source, RenderTexture destination)
    {
        if (EffectMat != null) {
            Graphics.Blit(source, destination, EffectMat);
        }
    }   
}

不要把texture想成一些一定是可視化的東西,實際上對于shader來說,texture就是數(shù)據(jù),可以是任何噪聲Noise貼圖,混亂的等等。


image.png

使用一個Noise貼圖去進行變化,需要把這個貼圖設(shè)置為Repeat。

Shader "Hidden/BasicImageEffect"
{
    Properties
    {
        _MainTex ("Texture", 2D) = "white" {}
        _DisplaceTex("Displacement Texture",2D) = "white"{}
        _Magnitude("Magnitude",Range(0,0.1))=1
    }
    SubShader
    {
        // No culling or depth
        Cull Off ZWrite Off ZTest Always

        Pass
        {
            CGPROGRAM
            #pragma vertex vert
            #pragma fragment frag

            #include "UnityCG.cginc"

            struct appdata
            {
                float4 vertex : POSITION;
                float2 uv : TEXCOORD0;
            };

            struct v2f
            {
                float2 uv : TEXCOORD0;
                float4 vertex : SV_POSITION;
            };

            v2f vert (appdata v)
            {
                v2f o;
                o.vertex = UnityObjectToClipPos(v.vertex);
                o.uv = v.uv;
                return o;
            }

            sampler2D _MainTex;
            sampler2D _DisplaceTex;
            float _Magnitude;



            fixed4 frag(v2f i) : SV_Target
            {
                float2 disp = tex2D(_DisplaceTex, i.uv).xy;
                disp = ((disp * 2) - 1) * _Magnitude;

                fixed4 col = tex2D(_MainTex,i.uv+disp);
                
                // just invert the colors
                //col.rgb = 1 - col.rgb;
                return col;
            }
            ENDCG
        }
    }
}

Box Blur
通過多次blur自己的rendertexture
并且使用低分辨率的設(shè)置方法來提高效率

using System.Collections.Generic;
using UnityEngine;

[ExecuteInEditMode]
public class BoxBlur : MonoBehaviour
{
    public Material blurMat;
    [Range(0,10)]
    public int Iterations;
    [Range(0, 4)]
    public int DownRes;

    private void OnRenderImage(RenderTexture source, RenderTexture destination)
    {
        int width = source.width >> DownRes;
        int height = source.height >> DownRes;

        RenderTexture rt = RenderTexture.GetTemporary(width, height);
        Graphics.Blit(source, rt);

        for (int i = 0; i < Iterations; i++)
        {
            RenderTexture rt2 = RenderTexture.GetTemporary(width, height);
            Graphics.Blit(rt, rt2, blurMat);
            RenderTexture.ReleaseTemporary(rt);
            rt = rt2;
        }
        Graphics.Blit(rt, destination);
        RenderTexture.ReleaseTemporary(rt);
    }
}


通過_Time.x的變量將波紋動起來
time指的是時間
Time (t/20, t, t2, t3), use to animate things inside the shaders.

Shader "Shader102/AnimatedDisplacement"
{
    Properties
    {
        _MainTex ("Texture", 2D) = "white" {}
        _DisplaceTex("Displacement Texture",2D) = "white"{}
        _Magnitude("Magnitude",Range(0,0.1)) = 1
    }
    SubShader
    {
        // No culling or depth
        Cull Off ZWrite Off ZTest Always

        Pass
        {
            CGPROGRAM
            #pragma vertex vert
            #pragma fragment frag

            #include "UnityCG.cginc"

            struct appdata
            {
                float4 vertex : POSITION;
                float2 uv : TEXCOORD0;
            };

            struct v2f
            {
                float2 uv : TEXCOORD0;
                float4 vertex : SV_POSITION;
            };

            v2f vert (appdata v)
            {
                v2f o;
                o.vertex = UnityObjectToClipPos(v.vertex);
                o.uv = v.uv;
                return o;
            }

            sampler2D _MainTex;
            sampler2D _DisplaceTex;
            float _Magnitude;

            fixed4 frag(v2f i) : SV_Target
            {
                // 用滾動的uv拿到滾動的noise的值,再用這個噪音顏色的值,去加上maintex的uv值...
                float2 distuv = float2(i.uv.x + _Time.x * 2,i.uv.y + _Time.x * 2);
                float2 disp = tex2D(_DisplaceTex,distuv).xy;
                disp = ((disp * 2) - 1)* _Magnitude;
                float4 col = tex2D(_MainTex, i.uv+disp);          
                return col;
            }
            ENDCG
        }
    }
}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容