UnityShader 植物被风吹弯效果

csharp 复制代码
// Upgrade NOTE: replaced 'mul(UNITY_MATRIX_MVP,*)' with 'UnityObjectToClipPos(*)'

Shader "AchonorShader/Plant"
{
    Properties
    {
        _MainTex ("Texture", 2D) = "white" {}
        _BaseColor ("Base Color", Color) = (1, 1, 1, 1)
        _WindDirectionX("WindDirectionX", Range(-1,1)) = 0
        _WindDirectionZ("WindDirectionZ", Range(-1,1)) = 0
        //模型高度
        _ModelHeight("ModelHeight", Float) = 1
        //根的世界坐标
        _RootPosition("RootPosition", vector) = (0, 0, 0, 1)
    }
    SubShader
    {
        Tags { "RenderType"="Opaque" }
        LOD 100

        Pass
        {
            CGPROGRAM
            #pragma vertex vert
            #pragma fragment frag
            // make fog work
            #pragma multi_compile_fog
            #pragma enable_d3d11_debug_symbols
            
            #include "UnityCG.cginc"

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

            struct v2f
            {
                float2 uv : TEXCOORD0;
                UNITY_FOG_COORDS(1)
                float4 vertex : SV_POSITION;
            };

            sampler2D _MainTex;
            float4 _MainTex_ST;
            float4 _BaseColor;
            float _WindDirectionX;
            float _WindDirectionZ;
            float _ModelHeight;
            float4 _RootPosition;

            v2f vert (appdata v)
            {
                v2f o;
                //_Matrix_M = UNITY_MATRIX_M;
                float4 worldPos = mul(UNITY_MATRIX_M, v.vertex);
                float4 rootWorldPos = _RootPosition;//mul(_Matrix_M, _RootOffset);
                float weight = (worldPos.y - rootWorldPos.y) / _ModelHeight;
                float weightX = (weight * _WindDirectionX) + 0.5 * 3.1415926f;
                float weightZ = -1 * ((weight * _WindDirectionZ) + 1.5 * 3.1415926f);
                float3x3 matrixX = float3x3(
                                        float3(sin(weightX), -cos(weightX), 0),
                                        float3(cos(weightX), sin(weightX), 0),
                                        float3(0, 0, 1));
                float3x3 matrixZ = float3x3(
                                        float3(1, 0, 0),
                                        float3(0, sin(weightZ), -cos(weightZ)),
                                        float3(0, cos(weightZ), sin(weightZ)));
                float3 offsetPos = worldPos - rootWorldPos;
                float4 newWorldPos = float4(mul(matrixZ, mul(matrixX, offsetPos)) + rootWorldPos, 1);
                
                o.vertex = mul(UNITY_MATRIX_VP, newWorldPos);
                o.uv = TRANSFORM_TEX(v.uv, _MainTex);
                UNITY_TRANSFER_FOG(o,o.vertex);
                return o;
            }

            fixed4 frag (v2f i) : SV_Target
            {
                // sample the texture
                fixed4 col = tex2D(_MainTex, i.uv) * _BaseColor;
                // apply fog
                UNITY_APPLY_FOG(i.fogCoord, col);
                return col;
            }
            ENDCG
        }
    }
}
相关推荐
mxwin3 小时前
Unity Shader 半透明物体为什么不能写入深度缓冲?
unity·游戏引擎·shader
晚枫歌F4 小时前
三层时间轮的实现
网络·unity·游戏引擎
咸鱼永不翻身5 小时前
Lua脚本事件检查工具
unity·lua·工具
leo__5207 小时前
单载波中继系统资源分配算法MATLAB仿真程序
算法·matlab·unity
努力长头发的程序猿8 小时前
Unity使用ScriptableObject序列化资源
unity·游戏引擎
mxwin8 小时前
Unity Shader 手写基于 PBR 的 URP Lit Shader 核心光照计算
unity·游戏引擎·shader
小贺儿开发9 小时前
Unity3D 智能云端数字标牌系统
unity·阿里云·人机交互·视频·oss·广告·互动
魔士于安9 小时前
Unity windows 同步 异步 打开文件文件夹工具
游戏·unity·游戏引擎·贴图·模型
魔士于安10 小时前
unity lowpoly 风格 城市 建筑 道路 交通标志
游戏·unity·游戏引擎·贴图·模型
mxwin10 小时前
Unity GPU Shader 性能优化指南
unity·游戏引擎·shader