当前位置: 首页 > article >正文

UnityShader:IBL

 效果:

实现:

Shader "MyShader/IBL"
{
    Properties
    {
        _CubeMap ("环境贴图", Cube) = "white" {}
          _Exposure("曝光",float)=1.0
        _Color("颜色",color)=(1,1,1,1)
        _NormalMap("法线贴图",2d)="bump"{}
        _AOMap("环境遮蔽",2d)="white"{}    
        _RoughnessMap("粗糙度贴图",2d)="black"{}
        _RoughnessContrast("粗糙度对比度",Range(0,10))=1
        _RoughnessLight("粗糙度亮度",float)=1
        _Roughness("粗糙度",Range(0,1))=1

    }
    SubShader
    {
        Tags { "RenderType"="Opaque" }
        LOD 100

        Pass
        {
            CGPROGRAM
            #pragma vertex vert
            #pragma fragment frag

            #include "UnityCG.cginc"

           inline float3 ACES_ToneMapping(float3 v)
            {
                v *= 0.6f;
                float a = 2.51f;
                float b = 0.03f;
                float c = 2.43f;
                float d = 0.59f;
                float e = 0.14f;
                return saturate((v*(a*v+b))/(v*(c*v+d)+e));
            }   

            struct appdata
            {
                float4 vertex : POSITION;
                float2 texcoord : TEXCOORD0;
                float3 normal : NORMAL;
                float3 tangent : TANGENT;
            };

            struct v2f
            {
                float4 pos : SV_POSITION;
                float2 uv : TEXCOORD0;
                float3 normal_world : TEXCOORD1;
                float3 tangent_dir : TEXCOORD2;
                float3 binormal_dir : TEXCOORD3;
                float3 pos_world : TEXCOORD4;
            };

            samplerCUBE _CubeMap;
            float4 _CubeMap_HDR;
            sampler2D _NormalMap;
            float4 _NormalMap_ST;
            sampler2D _AOMap;
            float _Exposure;
            float4 _Color;
            float _RoughnessContrast;
            sampler2D _RoughnessMap;
            float _RoughnessLight;
            float _Roughness;

            v2f vert (appdata v)
            {
                v2f o = (v2f)0;
                o.pos = UnityObjectToClipPos(v.vertex);
                o.uv = TRANSFORM_TEX(v.texcoord,_NormalMap);
                o.normal_world = normalize(mul(v.vertex,unity_WorldToObject).xyz);
                o.tangent_dir = normalize(mul(unity_ObjectToWorld,v.tangent).xyz);
                o.binormal_dir = normalize(cross(o.normal_world,o.tangent_dir));
                o.pos_world = mul(unity_ObjectToWorld,v.vertex);
                return o;
            }

            fixed4 frag (v2f i) : SV_Target
            {
               half3 normal_world = normalize(i.normal_world);
               half3 tangent_dir = normalize(i.tangent_dir);
               half3 binormal_dir = normalize(i.binormal_dir);
               half3 normal_data = UnpackNormal(tex2D(_NormalMap,i.uv));
               float3x3 TBN = float3x3(tangent_dir,binormal_dir,normal_world);
               normal_world = normalize(mul(normal_data,TBN));

               half3 view_dir = normalize(_WorldSpaceCameraPos.xyz-i.pos_world);
               half3 hdr_reflect_dir = normalize(reflect(-view_dir,normal_world));

               half roughness = tex2D(_RoughnessMap,i.uv);
               roughness = saturate(pow(roughness,_RoughnessContrast)*_RoughnessLight+_Roughness);
               roughness = roughness*(1.7-0.7*roughness);
               float mip_level = roughness*6;
               half4 cube_color = texCUBElod(_CubeMap,float4(hdr_reflect_dir,mip_level));
               half3 env_color = DecodeHDR(cube_color,_CubeMap_HDR);
               half ao_color = tex2D(_AOMap,i.uv);
               half3 final_color = env_color*ao_color*_Color.rgb*_Exposure;
               half3 final_color_liner = pow(final_color,2.2);
               half3 final_color_gamma = pow(ACES_ToneMapping(final_color_liner),1.0/2.2);
               return fixed4(final_color_gamma,1.0);
            }
            ENDCG
        }
    }
}


http://www.kler.cn/a/272283.html

相关文章:

  • 【技术总结类】2024,一场关于海量数据治理以及合理建模的系列写作
  • 美特CRM mcc_login.jsp存在SQL注入漏洞
  • Python绘制数据地图-MovingPandas
  • 学习ASP.NET Core的身份认证(基于JwtBearer的身份认证6)
  • Python_CUDA入门教程学习记录
  • pthread_exit函数
  • 【洛谷 P9242】[蓝桥杯 2023 省 B] 接龙数列 题解(线性DP+二维数组)
  • -bash-4.2$
  • Lua中文语言编程源码-第六节,更改lmathlib.c 数学库函数, 使Lua加载中文库关键词(与数学库相关)
  • docker-compose是什么
  • 【PyTorch】进阶学习:一文详细介绍 torch.load() 的应用场景、实战代码示例
  • 指南:在各主流操作系统上安装与配置Apache Tomcat
  • git问题列表(一)(持续更新中~~~)
  • day11-栈与队列02
  • C语言快速入门之内存函数的使用和模拟实现
  • 大数据 - Spark系列《十四》- spark集群部署模式
  • 物联网终端telegraf采集设备信息
  • 实战!wsl 与主机网络通信,在 wsl 中搭建服务器。学了计算机网络,但只能刷刷面试题?那也太无聊了!这篇文章可以让你检测你的计网知识!
  • 7.Java整合MongoDB—项目创建
  • 学习python笔记:8,随机数
  • 【XML】xml转Freemind思维导图
  • 【Java】十大排序
  • 【Unity入门】详解Unity中的射线与射线检测
  • 流媒体学习之路(WebRTC)——FEC逻辑分析(6)
  • 51单片机与ARM单片机的区别
  • Jest:JavaScript的单元测试利器