zoukankan      html  css  js  c++  java
  • 流光shader 和 流光+扭曲shader

    我认为这种shader能通过简单的方式呈现出不错的效果。

    1.流光shader:

    Shader "Unlit/StreamShader"
    {
        //流光shader
        Properties
        {
            _MainTex ("Texture", 2D) = "white" {}
            _StreamTex("StreamTexture", 2D) = "white" {}
            _StreamColor("StreamColor", Color) = (1,1,1,1)
            _StreamStrength("StreamStrength", Float) = 1
            _StreamSpeed("StreamSpeed", Range(0,1)) = 0.5
            _EnvTex("EnvTex (CubeMap)", Cube) = "_SkyBox" {}
            _EnvStrength("EnvStrength", Range(0,1)) = 0.8
    
        }
        SubShader
        {
            Tags { "RenderType"="Opaque" }
            LOD 100
    
            Pass
            {
                CGPROGRAM
                #pragma vertex vert
                #pragma fragment frag
                
                #include "UnityCG.cginc"
    
                struct appdata
                {
                    float4 vertex : POSITION;
                    float4 normal : NORMAL;
                    float2 uv0 : TEXCOORD0;
                    float2 uv1 : TEXCOORD1;
                };
    
                struct v2f
                {
                    float2 uv0 : TEXCOORD0;
                    float2 uv1 : TEXCOORD1;
                    float4 vertex : SV_POSITION;
                    float3 RefDir : TEXCOORD2;
                };
    
                sampler2D _MainTex;
                float4 _MainTex_ST;
                sampler2D _StreamTex;
                float4 _StreamTex_ST;
                half4 _StreamColor;
                float _StreamStrength;
                float _StreamSpeed;
                samplerCUBE _EnvTex;
                half _EnvStrength;
    
                v2f vert (appdata v)
                {
                    v2f o;
                    o.vertex = mul(UNITY_MATRIX_MVP, v.vertex);
                    o.uv0 = TRANSFORM_TEX(v.uv0, _MainTex);
                    o.uv1 = v.uv1;
    
                    float3 worldN = UnityObjectToWorldNormal(v.normal);
                    o.RefDir = reflect(-WorldSpaceViewDir(v.vertex), worldN);
                    return o;
                }
                
                fixed4 frag (v2f i) : SV_Target
                {
                    // sample the texture
                    fixed4 col = tex2D(_MainTex, i.uv0);
                    //流光
                    float2 streamUV = i.uv1 + _Time.y * float2(_StreamSpeed, 0);//缩放时间控制速度
                    fixed4 steamCol = tex2D(_StreamTex, TRANSFORM_TEX(streamUV, _StreamTex));
                    float3 steam = _StreamColor * steamCol.r * _StreamStrength;
                    //环境贴图反射
                    float3 reflection = texCUBE(_EnvTex, i.RefDir).rgb * _EnvStrength;
                    float3 o = col.rgb + steam + reflection;
                    return fixed4(o, 1);
                }
                ENDCG
            }
        }
    }

    效果:

    2.流光+扭曲shader:

    Shader "Unlit/SteamAndWrapShader"
    {
        //流光+纹理扭曲shader
        Properties
        {
            _MainTex("Texture", 2D) = "white" {}
            _StreamTex("StreamTexture", 2D) = "white" {}
            _StreamColor("StreamColor", Color) = (1,1,1,1)
            _StreamStrength("StreamStrength", Float) = 1
            _StreamSpeed("StreamSpeed", Range(0,1)) = 0.5
            _EnvTex("EnvTex (CubeMap)", Cube) = "_SkyBox" {}
            _EnvStrength("EnvStrength", Range(0,1)) = 0.8
            _WrapSpeed("WrapSpeed", Float) = 1
            _WrapStrength("WrapStrength", Float) = 1
        }
        SubShader
        {
            Tags{ "RenderType" = "Opaque" }
            LOD 100
    
            Pass
            {
                CGPROGRAM
                #pragma vertex vert
                #pragma fragment frag
    
                #include "UnityCG.cginc"
    
                struct appdata
                {
                    float4 vertex : POSITION;
                    float3 normal : NORMAL;
                    float2 uv0 : TEXCOORD0;
                    float2 uv1 : TEXCOORD1;
                };
    
                struct v2f
                {
                    float2 uv0 : TEXCOORD0;
                    float2 uv1 : TEXCOORD1;
                    float4 vertex : SV_POSITION;
                    float3 RefDir : TEXCOORD2;
                };
    
                sampler2D _MainTex;
                float4 _MainTex_ST;
                sampler2D _StreamTex;
                float4 _StreamTex_ST;
                half4 _StreamColor;
                float _StreamStrength;
                float _StreamSpeed;
                samplerCUBE _EnvTex;
                half _EnvStrength;
                half _WrapSpeed;
                half _WrapStrength;
    
                v2f vert(appdata v)
                {
                    v2f o;
                    o.vertex = mul(UNITY_MATRIX_MVP, v.vertex);
                    o.uv0 = TRANSFORM_TEX(v.uv0, _MainTex);
                    o.uv1 = v.uv1;
    
                    float3 worldN = UnityObjectToWorldNormal(v.normal);
                    o.RefDir = reflect(-WorldSpaceViewDir(v.vertex), worldN);
                    return o;
                }
    
                fixed4 frag(v2f i) : SV_Target
                {
                    // sample the texture
                    fixed4 col = tex2D(_MainTex, i.uv0);
                    //流光
                    float2 streamUV = i.uv1 + _Time.y * float2(_StreamSpeed, 0);//缩放时间控制速度
                    fixed4 steamCol = tex2D(_StreamTex, TRANSFORM_TEX(streamUV, _StreamTex));
                    float3 steam = _StreamColor * steamCol.r * _StreamStrength;
    
                    //扭曲,是在主tex上呈现扭曲,所以用uv0,但扭曲所用的纹理是_SteamTex,所以采样_SteamTex
                    float2 wrapUV = i.uv0 + _Time.y * float2(-_WrapSpeed, _WrapSpeed);//缩放时间控制速度并扭曲uv
                    fixed4 wrapCol = tex2D(_StreamTex, TRANSFORM_TEX(wrapUV, _StreamTex));
                    float3 wrap = _StreamColor * wrapCol.r * _WrapStrength;
    
                    //环境贴图反射
                    float3 reflection = texCUBE(_EnvTex, i.RefDir).rgb * _EnvStrength;
                    float3 o = col.rgb + steam + wrap + reflection;
                    return fixed4(o,1);
                }
                ENDCG
            }
        }
    }

    效果:

    总结:因为图片是我自己网上找的,所以流光和扭曲效果不好看,如果能针对性的做一些流光底图,会好看很多,结合扭曲就有流光溢彩之效了。

  • 相关阅读:
    团队冲刺03
    梦断代码 阅读笔记02
    团队冲刺02
    团队冲刺01
    周总结
    团队工作任务
    阅读笔记3
    梦断代码阅读笔记01
    周总结
    NABCD项目分析
  • 原文地址:https://www.cnblogs.com/Tearix/p/6877733.html
Copyright © 2011-2022 走看看