unity 3d 水效果

shader 代码

// Upgrade NOTE: replaced 'mul(UNITY_MATRIX_MVP,*)' with 'UnityObjectToClipPos(*)'

// Upgrade NOTE: replaced '_Object2World' with 'unity_ObjectToWorld'

// Upgrade NOTE: replaced '_World2Object' with 'unity_WorldToObject'

// Upgrade NOTE: replaced '_Object2World' with 'unity_ObjectToWorld'

 Shader "FX/FlatShadedWaterWithEdgeBlend" {

Properties {

    _BaseColor ("Base color", COLOR)  = ( .54, .95, .99, 0.5)

    _SpecColor ("Specular Material Color", Color) = (1,1,1,1)

    _Shininess ("Shininess", Float) = 10

    _ShoreTex ("Shore & Foam texture ", 2D) = "white" {}


    _InvFadeParemeter ("Auto blend parameter (Edge, Shore, Distance scale)", Vector) = (0.2 ,0.39, 0.5, 1.0)

    _BumpTiling ("Foam Tiling", Vector) = (1.0 ,1.0, -2.0, 3.0)

    _BumpDirection ("Foam movement", Vector) = (1.0 ,1.0, -1.0, 1.0)

    _Foam ("Foam (intensity, cutoff)", Vector) = (0.1, 0.375, 0.0, 0.0)

    [MaterialToggle] _isInnerAlphaBlendOrColor("Fade inner to color or alpha?", Float) = 0

}

CGINCLUDE

    #include "UnityCG.cginc"

    #include "UnityLightingCommon.cginc" // for _LightColor0

    sampler2D _ShoreTex;

    sampler2D_float _CameraDepthTexture;


    uniform float4 _BaseColor;  

    uniform float _Shininess;


    uniform float4 _InvFadeParemeter;


    uniform float4 _BumpTiling;

    uniform float4 _BumpDirection;


    uniform float4 _Foam;

    float _isInnerAlphaBlendOrColor;

    #define VERTEX_WORLD_NORMAL i.normalInterpolator.xyz

    struct appdata

    {

        float4 vertex : POSITION;

        float3 normal : NORMAL;

    };



    struct v2f

    {

        float4 pos : SV_POSITION;

        float4 normalInterpolator : TEXCOORD0;

        float4 viewInterpolator : TEXCOORD1;

        float4 bumpCoords : TEXCOORD2;

        float4 screenPos : TEXCOORD3;

        float4 grabPassPos : TEXCOORD4;

        half3 worldRefl : TEXCOORD6;

        float4 posWorld : TEXCOORD7;

        float3 normalDir : TEXCOORD8;

        UNITY_FOG_COORDS(5)

    };



    inline half4 Foam(sampler2D shoreTex, half4 coords)

    {

        half4 foam = (tex2D(shoreTex, coords.xy) * tex2D(shoreTex,coords.zw)) - 0.125;

        return foam;

    }

    v2f vert(appdata_full v)

    {

        v2f o;


        half3 worldSpaceVertex = mul(unity_ObjectToWorld,(v.vertex)).xyz;

        half3 vtxForAni = (worldSpaceVertex).xzz;


        half3   offsets = half3(0,0,0);

        half3   nrml = half3(0,1,0);


        v.vertex.xyz += offsets;


        half2 tileableUv = mul(unity_ObjectToWorld,(v.vertex)).xz;


        o.bumpCoords.xyzw = (tileableUv.xyxy + _Time.xxxx * _BumpDirection.xyzw) * _BumpTiling.xyzw;

        o.viewInterpolator.xyz = worldSpaceVertex - _WorldSpaceCameraPos;

        o.pos = UnityObjectToClipPos(v.vertex);

        o.screenPos=ComputeScreenPos(o.pos);

        o.normalInterpolator.xyz = nrml;

        o.viewInterpolator.w = saturate(offsets.y);

        o.normalInterpolator.w = 1;


        UNITY_TRANSFER_FOG(o,o.pos);

        half3 worldNormal = UnityObjectToWorldNormal(v.normal);

        float4x4 modelMatrix = unity_ObjectToWorld;

        float4x4 modelMatrixInverse = unity_WorldToObject;

        o.posWorld = mul(modelMatrix, v.vertex);

        o.normalDir = normalize( mul(float4(v.normal, 0.0), modelMatrixInverse).xyz);

        float3 worldPos = mul(unity_ObjectToWorld, v.vertex).xyz;

        float3 worldViewDir = normalize(UnityWorldSpaceViewDir(worldPos));

        o.worldRefl = reflect(-worldViewDir, worldNormal);

        return o;

    }


     half4 calculateBaseColor(v2f input)  

         {

            float3 normalDirection = normalize(input.normalDir);


            float3 viewDirection = normalize(

               _WorldSpaceCameraPos - input.posWorld.xyz);

            float3 lightDirection;

            float attenuation;


            if (0.0 == _WorldSpaceLightPos0.w) // directional light?

            {

               attenuation = 1.0; // no attenuation

               lightDirection = normalize(_WorldSpaceLightPos0.xyz);

            }

            else // point or spot light

            {

               float3 vertexToLightSource =

                  _WorldSpaceLightPos0.xyz - input.posWorld.xyz;

               float distance = length(vertexToLightSource);

               attenuation = 1.0 / distance; // linear attenuation

               lightDirection = normalize(vertexToLightSource);

            }


            float3 ambientLighting =

               UNITY_LIGHTMODEL_AMBIENT.rgb * _BaseColor.rgb;


            float3 diffuseReflection =

               attenuation * _LightColor0.rgb * _BaseColor.rgb

               * max(0.0, dot(normalDirection, lightDirection));


            float3 specularReflection;

            if (dot(normalDirection, lightDirection) < 0.0)

               // light source on the wrong side?

            {

               specularReflection = float3(0.0, 0.0, 0.0);

                  // no specular reflection

            }

            else  

            {

               specularReflection = attenuation * _LightColor0.rgb  * _SpecColor.rgb * pow(max(0.0, dot(reflect(-lightDirection, normalDirection), viewDirection)), _Shininess);

            }

            return half4(ambientLighting + diffuseReflection  + specularReflection, 1.0);

            // return float4(0.5f, 0.115f, 0.5f, 1);

         }

    half4 frag( v2f i ) : SV_Target

    {


        half4 edgeBlendFactors = half4(1.0, 0.0, 0.0, 0.0);


        #ifdef WATER_EDGEBLEND_ON

            half depth = SAMPLE_DEPTH_TEXTURE_PROJ(_CameraDepthTexture, UNITY_PROJ_COORD(i.screenPos));

            depth = LinearEyeDepth(depth);

            edgeBlendFactors = saturate(_InvFadeParemeter * (depth-i.screenPos.w));

            edgeBlendFactors.y = 1.0-edgeBlendFactors.y;

        #endif



        half4 baseColor = calculateBaseColor(i);



        half4 foam = Foam(_ShoreTex, i.bumpCoords * 2.0);

        baseColor.rgb += foam.rgb * _Foam.x * (edgeBlendFactors.y + saturate(i.viewInterpolator.w - _Foam.y));

        if( _isInnerAlphaBlendOrColor==0)

            baseColor.rgb += 1.0-edgeBlendFactors.x;

        if(  _isInnerAlphaBlendOrColor==1.0)

            baseColor.a  =  edgeBlendFactors.x;

        UNITY_APPLY_FOG(i.fogCoord, baseColor);

        return baseColor;

    }


ENDCG

Subshader

{

    Tags {"RenderType"="Transparent" "Queue"="Transparent"}


    Lod 500

    ColorMask RGB


    GrabPass { "_RefractionTex" }


    Pass {

            Blend SrcAlpha OneMinusSrcAlpha

            ZTest LEqual

            ZWrite Off

            Cull Off


            CGPROGRAM


            #pragma target 3.0


            #pragma vertex vert

            #pragma fragment frag

            #pragma multi_compile_fog


            #pragma multi_compile WATER_EDGEBLEND_ON WATER_EDGEBLEND_OFF


            ENDCG

    }

}

Fallback "Transparent/Diffuse"

}



c#代码


using UnityEngine;

using System.Collections;



public class Water : MonoBehaviour

{

    Vector3 waveSource1 = new Vector3 (2.0f, 0.0f, 2.0f);

    public float waveFrequency = 0.53f;

    public float waveHeight = 0.48f;

    public float waveLength = 0.71f;

    public bool edgeBlend=true;

    public bool forceFlatShading =true;

    Mesh mesh;

    Vector3[] verts;


    void Start ()

    {

        Camera.main.depthTextureMode |= DepthTextureMode.Depth;

        MeshFilter mf = GetComponent<MeshFilter> ();  

        makeMeshLowPoly (mf);


    }

    MeshFilter makeMeshLowPoly (MeshFilter mf)

    {

        mesh = mf.sharedMesh;

        verts = mesh.vertices;

        return mf;

    }

    void setEdgeBlend ()

    {

        if (!SystemInfo.SupportsRenderTextureFormat (RenderTextureFormat.Depth)) {

            edgeBlend = false;

        }

        if (edgeBlend) {

            Shader.EnableKeyword ("WATER_EDGEBLEND_ON");

            if (Camera.main) {

                Camera.main.depthTextureMode |= DepthTextureMode.Depth;

            }

        }

        else {

            Shader.DisableKeyword ("WATER_EDGEBLEND_ON");

        }

    }

    // Update is called once per frame

    void Update ()

    {

        CalcWave ();

        setEdgeBlend ();

    }

    void CalcWave ()

    {

        for (int i = 0; i < verts.Length; i++) {

            Vector3 v = verts [i];

            v.y = 0.0f;

            float dist = Vector3.Distance (v, waveSource1);

            dist = (dist % waveLength) / waveLength;

            v.y = waveHeight * Mathf.Sin (Time.time * Mathf.PI * 2.0f * waveFrequency

            + (Mathf.PI * 2.0f * dist));

            verts [i] = v;

        }

        mesh.vertices = verts;

        mesh.RecalculateNormals ();

        mesh.MarkDynamic ();


        GetComponent<MeshFilter> ().mesh = mesh;

    }

}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,366评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,521评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,689评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,925评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,942评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,727评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,447评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,349评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,820评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,990评论 3 337
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,127评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,812评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,471评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,017评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,142评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,388评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,066评论 2 355

推荐阅读更多精彩内容