庄懂着色器_L12_大作业分析与还原

2023-12-04 14:38

本文主要是介绍庄懂着色器_L12_大作业分析与还原,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

庄懂-BoyanTata的个人空间_哔哩哔哩_Bilibili


答疑
文档分析
照射进来的光是白色,那么非金属反射的也是白色,它不会去改造光的成分
照射进来的光是白色,金属反射的自身金属的颜色
资源分析
资源优化
光照模型分析
菲涅尔:越平行你视线方向的表面,它对环境反射的越多
代码部分
nDirWS 世界空间下得法线方向
vDirWS 世界空间下得观察方向
vrDirWS 世界空间下得观察方向的反射
lDirWS 世界空间下得灯光方向
lrDirWS 世界空间下得灯光方向的反射
ndotl 半兰伯特或者兰伯特
ndotv 菲涅尔效果
vdotlr Phong的高光
Cubemap的texCUBElod
它采样的坐标是一个float4_四维的,前三维xyz坐标是一个观察方向的反射方向,第四位w是它的lod的Mipmap级数,这个是控制反射环境的清晰与模糊程度的
表面越光滑时候越清晰,表面越粗糙时候越模糊
高光次幂(可以理解为光滑度图),这张图越白,说明
高光次幂值越高,它的高光点越集中,就越光滑
高光次幂值越低,它的高光点越发散,就越粗糙
half3(0.3,0.3,0.3)是一个经验值
BaseColor和Diffuse在非金属部分是没有区别的
但是在金属部分,Diffuse金属部分是非常黑的, BaseColor金属部分是亮的
非金属有菲涅尔效果,金属度越高,菲涅尔效果越低
透明剪切
Clip(不透明度-透明剪切阈值)
透明剪切阈值,越大剪得越多,越小剪得越少
透明度是从零到灰的一张Mask;透明阈值代表相当于小于这个阈值给它透掉,大于这个阈值通通给它保留
投影需要ShadowCaster
Shader "AP01/L12/Dota2"
{Properties{[Header(Texture)]_MainTex        ("RGB:颜色 A:透贴", 2d) = "white"{}_MaskTex        ("R:高光强度 G:边缘光强度 B:高光染色 A:高光次幂", 2d) = "black"{}_NormTex        ("RGB:法线贴图", 2d) = "bump"{}_MatelnessMask  ("金属度遮罩", 2d) = "black"{}_EmissionMask   ("自发光遮罩", 2d) = "black"{}_DiffWarpTex    ("颜色Warp图", 2d) = "gray"{}_FresWarpTex    ("菲涅尔Warp图", 2d) = "gray"{}_Cubemap        ("环境球", cube) = "_Skybox"{}[Header(DirDiff)]_LightCol       ("光颜色", color) = (1.0, 1.0, 1.0, 1.0)[Header(DirSpec)]_SpecPow        ("高光次幂", range(0.0, 99.0)) = 5_SpecInt        ("高光强度", range(0.0, 10.0)) = 5[Header(EnvDiff)]_EnvCol         ("环境光颜色", color) = (1.0, 1.0, 1.0, 1.0)[Header(EnvSpec)]_EnvSpecInt     ("环境镜面反射强度", range(0.0, 30.0)) = 0.5[Header(RimLight)][HDR]_RimCol    ("轮廓光颜色", color) = (1.0, 1.0, 1.0, 1.0)[Header(Emission)]_EmitInt        ("自发光强度", range(0.0, 10.0)) = 1.0[HideInInspector]_Cutoff         ("Alpha cutoff", Range(0,1)) = 0.5[HideInInspector]_Color          ("Main Color", Color) = (1.0, 1.0, 1.0, 1.0)}SubShader{Tags {  "RenderType"="Opaque" }Pass{Name "FORWARD"Tags { "LightMode"="ForwardBase" }Cull OffCGPROGRAM#pragma vertex vert#pragma fragment frag#include "UnityCG.cginc"#include "AutoLight.cginc"#include "Lighting.cginc"#pragma multi_compile_fwdbase_fullshadows#pragma target 3.0// 输入参数uniform sampler2D _MainTex;uniform sampler2D _MaskTex;uniform sampler2D _NormTex;uniform sampler2D _MatelnessMask;uniform sampler2D _EmissionMask;uniform sampler2D _DiffWarpTex;uniform sampler2D _FresWarpTex;uniform samplerCUBE _Cubemap;// DirDiffuniform half3 _LightCol;// DirSpecuniform half _SpecPow;uniform half _SpecInt;// EnvDiffuniform half3 _EnvCol;// EnvSpecuniform half _EnvSpecInt;// RimLightuniform half3 _RimCol;// Emissionuniform half _EmitInt;// Otheruniform half _Cutoff;// 输入结构struct VertexInput{float4 vertex   : POSITION;   // 顶点信息 Get✔float2 uv0      : TEXCOORD0;  // UV信息 Get✔float4 normal   : NORMAL;     // 法线信息 Get✔float4 tangent  : TANGENT;    // 切线信息 Get✔};// 输出结构struct VertexOutput{float4 pos    : SV_POSITION;  // 屏幕顶点位置float2 uv0      : TEXCOORD0;  // UV0float4 posWS    : TEXCOORD1;  // 世界空间顶点位置float3 nDirWS   : TEXCOORD2;  // 世界空间法线方向float3 tDirWS   : TEXCOORD3;  // 世界空间切线方向float3 bDirWS   : TEXCOORD4;  // 世界空间副切线方向LIGHTING_COORDS(5,6)          // 投影相关};// 输入结构>>>顶点Shader>>>输出结构VertexOutput vert (VertexInput v){VertexOutput o = (VertexOutput)0;                   // 新建输出结构o.pos = UnityObjectToClipPos( v.vertex );       // 顶点位置 OS>CSo.uv0 = v.uv0;                                  // 传递UVo.posWS = mul(unity_ObjectToWorld, v.vertex);   // 顶点位置 OS>WSo.nDirWS = UnityObjectToWorldNormal(v.normal);  // 法线方向 OS>WSo.tDirWS = normalize(mul(unity_ObjectToWorld, float4(v.tangent.xyz, 0.0)).xyz); // 切线方向 OS>WSo.bDirWS = normalize(cross(o.nDirWS, o.tDirWS) * v.tangent.w);  // 副切线方向TRANSFER_VERTEX_TO_FRAGMENT(o)                  // 投影相关return o;                                           // 返回输出结构}// 输出结构>>>像素float4 frag(VertexOutput i) : COLOR{// 向量准备half3 nDirTS = UnpackNormal(tex2D(_NormTex, i.uv0));half3x3 TBN = half3x3(i.tDirWS, i.bDirWS, i.nDirWS);half3 nDirWS = normalize(mul(nDirTS, TBN));half3 vDirWS = normalize(_WorldSpaceCameraPos.xyz - i.posWS);half3 vrDirWS = reflect(-vDirWS, nDirWS);half3 lDirWS = _WorldSpaceLightPos0.xyz;half3 lrDirWS = reflect(-lDirWS, nDirWS);// 中间量准备half ndotl = dot(nDirWS, lDirWS);half ndotv = dot(nDirWS, vDirWS);half vdotr = dot(vDirWS, lrDirWS);// 采样纹理half4 var_MainTex = tex2D(_MainTex, i.uv0);half4 var_MaskTex = tex2D(_MaskTex, i.uv0);half var_MatelnessMask = tex2D(_MatelnessMask, i.uv0).r;half var_EmissionMask = tex2D(_EmissionMask, i.uv0).r;half3 var_FresWarpTex = tex2D(_FresWarpTex, ndotv);half3 var_Cubemap = texCUBElod(_Cubemap, float4(vrDirWS, lerp(8.0, 0.0, var_MaskTex.a))).rgb;// 提取信息half3 baseCol = var_MainTex.rgb;half opacity = var_MainTex.a;half specInt = var_MaskTex.r;half rimInt = var_MaskTex.g;half specTint = var_MaskTex.b;half specPow = var_MaskTex.a;half matellic = var_MatelnessMask;half emitInt = var_EmissionMask;half3 envCube = var_Cubemap;half shadow = LIGHT_ATTENUATION(i);// 光照模型// 漫反射颜色 镜面反射颜色half3 diffCol = lerp(baseCol, half3(0.0, 0.0, 0.0), matellic);half3 specCol = lerp(baseCol, half3(0.3, 0.3, 0.3), specTint) * specInt;// 菲涅尔half3 fresnel = lerp(var_FresWarpTex, 0.0, matellic);half fresnelCol = fresnel.r;    // 无实际用途half fresnelRim = fresnel.g;half fresnelSpec = fresnel.b;// 光源漫反射half halfLambert = ndotl * 0.5 + 0.5;half3 var_DiffWarpTex = tex2D(_DiffWarpTex, half2(halfLambert, 0.2));half3 dirDiff = diffCol * var_DiffWarpTex * _LightCol;// 光源镜面反射half phong = pow(max(0.0, vdotr), specPow * _SpecPow);half spec = phong * max(0.0, ndotl);spec = max(spec, fresnelSpec);spec = spec * _SpecInt;half3 dirSpec = specCol * spec * _LightCol;// 环境漫反射half3 envDiff = diffCol * _EnvCol;// 环境镜面反射half reflectInt = max(fresnelSpec, matellic) * specInt;half3 envSpec = specCol * reflectInt * envCube * _EnvSpecInt;// 轮廓光half3 rimLight = _RimCol * fresnelRim * rimInt * max(0.0, nDirWS.g);// 自发光half3 emission = diffCol * emitInt * _EmitInt;// 混合half3 finalRGB = (dirDiff + dirSpec) * shadow + envDiff + envSpec + rimLight + emission;// 透明剪切clip(opacity - _Cutoff);// 返回值return float4(finalRGB, 1.0);}ENDCG}}// 声明回退ShaderFallBack "Legacy Shaders/Transparent/Cutout/VertexLit"
}
SD,SP源代码

这篇关于庄懂着色器_L12_大作业分析与还原的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/453828

相关文章

作业提交过程之HDFSMapReduce

作业提交全过程详解 (1)作业提交 第1步:Client调用job.waitForCompletion方法,向整个集群提交MapReduce作业。 第2步:Client向RM申请一个作业id。 第3步:RM给Client返回该job资源的提交路径和作业id。 第4步:Client提交jar包、切片信息和配置文件到指定的资源提交路径。 第5步:Client提交完资源后,向RM申请运行MrAp

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者

MOLE 2.5 分析分子通道和孔隙

软件介绍 生物大分子通道和孔隙在生物学中发挥着重要作用,例如在分子识别和酶底物特异性方面。 我们介绍了一种名为 MOLE 2.5 的高级软件工具,该工具旨在分析分子通道和孔隙。 与其他可用软件工具的基准测试表明,MOLE 2.5 相比更快、更强大、功能更丰富。作为一项新功能,MOLE 2.5 可以估算已识别通道的物理化学性质。 软件下载 https://pan.quark.cn/s/57

衡石分析平台使用手册-单机安装及启动

单机安装及启动​ 本文讲述如何在单机环境下进行 HENGSHI SENSE 安装的操作过程。 在安装前请确认网络环境,如果是隔离环境,无法连接互联网时,请先按照 离线环境安装依赖的指导进行依赖包的安装,然后按照本文的指导继续操作。如果网络环境可以连接互联网,请直接按照本文的指导进行安装。 准备工作​ 请参考安装环境文档准备安装环境。 配置用户与安装目录。 在操作前请检查您是否有 sud

线性因子模型 - 独立分量分析(ICA)篇

序言 线性因子模型是数据分析与机器学习中的一类重要模型,它们通过引入潜变量( latent variables \text{latent variables} latent variables)来更好地表征数据。其中,独立分量分析( ICA \text{ICA} ICA)作为线性因子模型的一种,以其独特的视角和广泛的应用领域而备受关注。 ICA \text{ICA} ICA旨在将观察到的复杂信号

【软考】希尔排序算法分析

目录 1. c代码2. 运行截图3. 运行解析 1. c代码 #include <stdio.h>#include <stdlib.h> void shellSort(int data[], int n){// 划分的数组,例如8个数则为[4, 2, 1]int *delta;int k;// i控制delta的轮次int i;// 临时变量,换值int temp;in

三相直流无刷电机(BLDC)控制算法实现:BLDC有感启动算法思路分析

一枚从事路径规划算法、运动控制算法、BLDC/FOC电机控制算法、工控、物联网工程师,爱吃土豆。如有需要技术交流或者需要方案帮助、需求:以下为联系方式—V 方案1:通过霍尔传感器IO中断触发换相 1.1 整体执行思路 霍尔传感器U、V、W三相通过IO+EXIT中断的方式进行霍尔传感器数据的读取。将IO口配置为上升沿+下降沿中断触发的方式。当霍尔传感器信号发生发生信号的变化就会触发中断在中断

kubelet组件的启动流程源码分析

概述 摘要: 本文将总结kubelet的作用以及原理,在有一定基础认识的前提下,通过阅读kubelet源码,对kubelet组件的启动流程进行分析。 正文 kubelet的作用 这里对kubelet的作用做一个简单总结。 节点管理 节点的注册 节点状态更新 容器管理(pod生命周期管理) 监听apiserver的容器事件 容器的创建、删除(CRI) 容器的网络的创建与删除

PostgreSQL核心功能特性与使用领域及场景分析

PostgreSQL有什么优点? 开源和免费 PostgreSQL是一个开源的数据库管理系统,可以免费使用和修改。这降低了企业的成本,并为开发者提供了一个活跃的社区和丰富的资源。 高度兼容 PostgreSQL支持多种操作系统(如Linux、Windows、macOS等)和编程语言(如C、C++、Java、Python、Ruby等),并提供了多种接口(如JDBC、ODBC、ADO.NET等