前部分知识复习05

一、多级渐远贴图MipMap

 选择贴图,可以勾选贴图的多级渐远效果

[IntRange]_MipMap("MipMap",Range(0,12))=0     //多级渐远贴图的LOD调节滑杆

_MipMapTexture("MipMapTexture",2D)="white"{}   //定义多级渐远贴图

多级渐远贴图的采样:

float4 Mipmap=tex2Dlod(_MipMapTexture,float4(i.uv.xy,0,_MipMap));

二、立方体纹理 CubeMap

  利用立方体纹理制作反射效果:

反射效果的形成:

float3 R=reflect(-V,N);

reflect函数根据入射向量和法向量求反射向量

而向量V是从模型指向摄像机的方向的向量,所以此时的入射向量为-V

_CubeMap("CubeMap",Cube)="white"{}

samplerCUBE _Cubemap;       //声明立方体纹理

float4 Cubemap=texCUBE(_CubeMap,R);   //立方体纹理的采样

Shader"unity/Texture03"
{Properties{_MipMapTexture("MipMapTexture",2D)="white"{}[IntRange]_MipMap("MipMap",Range(0,12))=0_CubeMap("CubeMap",Cube)="white"{}}SubShader{Pass{CGPROGRAM#pragma vertex vert#pragma fragment frag#include "UnityCG.cginc"sampler2D _MipMapTexture;int _MipMap;samplerCUBE _CubeMap;struct appdate {float4 vertex : POSITION;float4 uv : TEXCOORD;float3 normal : NORMAL;};struct v2f {float4 pos : SV_POSITION;float4 uv : TEXCOORD;float3 worldNormal:TEXCOORD1;float3 worldPos : TEXCOORD2;};v2f vert(appdate v){v2f o;o.pos=UnityObjectToClipPos(v.vertex);o.worldNormal=UnityObjectToWorldNormal(v.normal);o.worldPos=mul(unity_ObjectToWorld,v.vertex);o.uv=v.uv;return o;}float4 frag(v2f i):SV_Target{float4 Mipmap=tex2Dlod(_MipMapTexture,float4(i.uv.xy,0,_MipMap));float3 N=normalize(i.worldNormal);float3 V =normalize(_WorldSpaceCameraPos-i.worldPos);float3 R=reflect(-V,N);float4 Cubemap=texCUBE(_CubeMap,R);return Cubemap;}ENDCG}}}

三、法线纹理

 法线贴图中存储的是每个像素点在切线空间下的法线向量信息

   所以采样法线贴图后的值为切线空间下的法线值

//采样法线贴图 (采样结果为切线空间下的法线值)  UnpackNormal函数通常用于解压纹理中压缩的法线信息,以获取其正确的法线
float3 normalTex=UnpackNormal(tex2D(_NormalTex,i.uv));

但是光照计算所需要的法线值为世界空间下的法线信息,所以就需要将采样后的法线值转换到世界空间下

这时就需要使用到切线空间变换矩阵,将法线信息由切线空间转换到世界空间


其中 切线 tangent 是一个四维的向量

flaot4 tangent ;   //tangent.w代表切线的方向,tangent.xyz代表坐标

  • 在顶点着色器中将模型顶点的切线由本地空间转换到世界空间

float3 worldTangent=UnityObjectToWorldDir(v.tangent);

  • 再计算切线的方向

float tangentSign=v.tangent.w*unity_WorldTransformParams.w;

  • 由世界空间法线向量和世界空间切线向量的叉值算法来计算副切线向量

(注意:此时的世界空间法线向量为模型上各像素点的法线向量,而非采样后的法线值)

//副切线由切线向量和法线向量的叉积所得
float3 worldBinormal=cross(worldNormal,worldTangent)*tangentSign;

  • 然后构建切线空间变换矩阵

//给切线空间变换矩阵赋值
o.tSpace0=float3(worldTangent.x,worldBinormal.x,worldNormal.x);
o.tSpace1=float3(worldTangent.y,worldBinormal.y,worldNormal.y);
o.tSpace2=float3(worldTangent.z,worldBinormal.z,worldNormal.z);

  • 最后在片元着色器中将采样后的法线值和变换矩阵进行点积操作得到世界空间下法线贴图中的法线值

fixed3 worldN=float3(dot(normalTex,i.tSpace0),dot(normalTex,i.tSpace1),dot(normalTex,i.tSpace2));

Shader"unity/Texture02"
{Properties{//定义法线纹理  [Normal]标签的作用是使得该纹理贴图的位置只能装载法线贴图[Normal]_NormalTex("NormalTex",2D)="white"{}}SubShader{Pass{CGPROGRAM#pragma vertex vert#pragma fragment frag#include "UnityCG.cginc"sampler2D _NormalTex;float4 _NormalTex_ST;struct appdate{float4 vertex:POSITION;float2 uv:TEXCOORD;float3 normal:NORMAL;//(tangent四维向量,xyz代表坐标,w代表切线的方向)float4 tangent:TANGENT;};struct v2f{float4 pos:SV_POSITION;float2 uv:TEXCOORD;//定义切线空间变换矩阵float3 tSpace0:TEXCOORD1;float3 tSpace1:TEXCOORD2;float3 tSpace2:TEXCOORD3;};v2f vert(appdate v){v2f o;o.uv=TRANSFORM_TEX(v.uv,_NormalTex);o.pos=UnityObjectToClipPos(v.vertex);//世界空间法线float3 worldNormal=UnityObjectToWorldNormal(v.normal);//将模型顶点的切线由本地空间转换为世界空间float3 worldTangent=UnityObjectToWorldDir(v.tangent);//决定切线的方向float tangentSign=v.tangent.w*unity_WorldTransformParams.w;//副切线由切线向量和法线向量的叉积所得float3 worldBinormal=cross(worldNormal,worldTangent)*tangentSign;//给切线空间变换矩阵赋值o.tSpace0=float3(worldTangent.x,worldBinormal.x,worldNormal.x);o.tSpace1=float3(worldTangent.y,worldBinormal.y,worldNormal.y);o.tSpace2=float3(worldTangent.z,worldBinormal.z,worldNormal.z);return o;}float4 frag(v2f i):SV_TARGET{	//法线纹理的采样(切线空间下的法线值)//采样法线贴图后的值为一个三维向量fixed3 normalTex=UnpackNormal(tex2D(_NormalTex,i.uv));//worldN是基于切线变换矩阵和切线空间下的法线值所计算得到的世界空间下的法线值fixed3 worldN=float3(dot(normalTex,i.tSpace0),dot(normalTex,i.tSpace1),dot(normalTex,i.tSpace2));fixed3 L=normalize(_WorldSpaceLightPos0);//lamber光照模型 max(0,dot(N,L)fixed NdotL=max(0,dot(worldN,L));return NdotL;}ENDCG}}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/13473.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[高等数学]曲率

一、知识点 (一)弧微分 设函数 f ( x ) f(x) f(x) 在区间 ( a , b ) (a,b) (a,b) 内具有连续导数。 在曲线 y f ( x ) yf(x) yf(x) 上取固定点 M 0 ( x 0 , y 0 ) M_0(x_0,y_0) M0​(x0​,y0​) 作为度量弧长的基点,并规定依 x x x 增…

openGauss 3.0 数据库在线实训课程2:学习客户端工具gsql的使用

openGauss数据库状态查看 前提 我正在参加21天养成好习惯| 第二届openGauss每日一练活动 课程详见:openGauss 3.0.0数据库在线实训课程 学习目标 学习openGauss数据库客户端工具gsql的使用。 课程作业 gsql是openGauss提供在命令行下运行的数据库连接工具&am…

模拟实现string类

目录 一.构造与析构函数 二.基础小功能的实现 1.clear 2.c_str 3外部对私有的查看 三.实现string的迭代器 四.string的增删查改 1.push_back尾插 1.1reserve扩容 1.2尾插 3.运算符重载 4.insert在任意位置插入 5.erase删除 5.1npos的处理 5.2函数的实现 6.find查…

机器学习之数学基础:线性代数、微积分、概率论 | PyTorch 深度学习实战

前一篇文章,使用线性回归模型逼近目标模型 | PyTorch 深度学习实战 本系列文章 GitHub Repo: https://github.com/hailiang-wang/pytorch-get-started 本篇文章内容来自于 强化学习必修课:引领人工智能新时代【梗直哥瞿炜】 线性代数、微积分、概率论 …

记录一下 在Mac下用pyinstallter 打包 Django项目

安装: pip install pyinstaller 在urls.py from SheepMasterOneToOne import settings from django.conf.urls.static import staticurlpatterns [path("admin/", admin.site.urls),path(generate_report/export/, ReportAdmin(models.Report, admin.site).generat…

UE求职Demo开发日志#23 线性任务系统数据层实现

1 按上期设计创建数据结构&#xff08;做了一些修改&#xff09; USTRUCT(BlueprintType) struct ARPG_CPLUS_API FQuestNode {GENERATED_USTRUCT_BODY()// 记录前置节点IDUPROPERTY(EditAnywhere, BlueprintReadWrite,Category"QuestNode")TArray<int> Prede…

mysql8安装时提示-缺少Microsoft Visual C++ 2019 x64 redistributable

MySQL8.0安装包mysql-8.0.1-winx64进行安装&#xff0c;提示&#xff1a;This application requires Visual Studio 2019 x64Redistributable, Please install the Redistributable then runthis installer again。出现这个错误是因为我们电脑缺少Microsoft Visual C 这个程序&…

K8s 分布式存储后端(K8s Distributed Storage Backend)

K8s 分布式存储后端 在 K8s 中实现分布式存储后端对于管理跨集群的持久数据、确保高可用性、可扩展性和可靠性至关重要。在 K8s 环境中&#xff0c;应用程序通常被容器化并跨多个节点部署。虽然 K8s 可以有效处理无状态应用程序&#xff0c;但有状态应用程序需要持久存储来维护…

生产环境超实用shell脚本一

生产环境超实用shell脚本一 Shell脚本作为一种强大的自动化工具&#xff0c;能够帮助运维人员轻松应对各种复杂的任务。 本文将为您介绍服务器健康检查、日志清理、备份以及监控等多个方面&#xff0c;并详细阐述每个脚本的功能和应用场景&#xff0c;助力您提升运维效率&…

IM 即时通讯系统-46-OpenIM 提供了专为开发者设计的开源即时通讯解决方案

IM 开源系列 IM 即时通讯系统-41-开源 野火IM 专注于即时通讯实时音视频技术&#xff0c;提供优质可控的IMRTC能力 IM 即时通讯系统-42-基于netty实现的IM服务端,提供客户端jar包,可集成自己的登录系统 IM 即时通讯系统-43-简单的仿QQ聊天安卓APP IM 即时通讯系统-44-仿QQ即…

spy-debugger + Charles 调试移动端/内嵌小程序H5

简介说明&#xff1a; PC端可以用F12进行console等进行调试&#xff0c;但移动端App中使用webview就无法进行实时调试&#xff0c;针对这种情况 1. 安装 全局安装 spy-debugger sudo npm install spy-debugger -g // window不用加sudo2. spy-debugger 证书 其实spy-debugg…

深度整理总结MySQL——SQL的执行顺序和流程

SQL的执行顺序和流程 SQL的执行顺序执行一条select语句,发生了什么呢连接器查询缓存解析SQL执行SQL预处理器优化器执行器 总结 SQL的执行顺序 这是一条标准的查询语句: 但实际上并不是从上到下去解析的,真实的执行顺序是: 我们先执行from,join来确定表之间的连接关系&#x…

使用 Ollama 在 Windows 环境部署 DeepSeek 大模型实战指南

文章目录 前言Ollama核心特性 实战步骤安装 Ollama验证安装结果部署 DeepSeek 模型拉取模型启动模型 交互体验命令行对话调用 REST API 总结个人简介 前言 近年来&#xff0c;大语言模型&#xff08;LLM&#xff09;的应用逐渐成为技术热点&#xff0c;而 DeepSeek 作为国产开…

Redis有哪些常用应用场景?

大家好&#xff0c;我是锋哥。今天分享关于【Redis有哪些常用应用场景?】面试题。希望对大家有帮助&#xff1b; Redis有哪些常用应用场景? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 Redis 是一个高性能的键值对存储数据库&#xff0c;它有许多应用场景&…

115,【7】 攻防世界 web fileinclude

进入靶场 试着访问了几个文件&#xff0c;都没得到信息&#xff0c;f12看看源码 还真有 <?php // 检查是否开启了错误显示功能 // ini_get 函数用于获取 PHP 配置选项的值&#xff0c;这里检查 display_errors 选项是否开启 if( !ini_get(display_errors) ) {// 如果错误…

SpringBoot开发(五)SpringBoot接收请求参数

1. SpringBoot接收请求参数 1.1. 获取参数的方式 &#xff08;1&#xff09;通过request对象获取参数   &#xff08;2&#xff09;RequestParam(针对请求头方式为x-www-form-ur lencoded)   &#xff08;3&#xff09;RequestBody(针对请求头方式为application/json)   …

如何理解多态,以及由此引出的抽象类和纯虚函数

文章目录 1. 多态2. 抽象类和纯虚函数 1. 多态 静态多态&#xff1a; 动态多态&#xff1a; #include <iostream> #include <string> using namespace std;// 动物的基类 class Animal { public:Animal(string name) : _name(name) {}virtual void bark() {} …

java基础2(黑马)

一、变量里的数据在计算机中的存储原理 1.二进制 .二进制&#xff1a;只有0、1&#xff0c; 按照逢二进一的方式表示数据。 十进制数字11转换为&#xff1a;1011 方法&#xff1a;除二取余法 计算机中表示数据的最小单元&#xff0c;一个字节&#xff08;Byte&#xff0c;简…

【算法篇】贪心算法

目录 贪心算法 贪心算法实际应用 一&#xff0c;零钱找回问题 二&#xff0c;活动选择问题 三&#xff0c;分数背包问题 将数组和减半的最小操作次数 最大数 贪心算法 贪心算法&#xff0c;是一种在每一步选择中都采取当前状态下的最优策略&#xff0c;期望得到全局最优…

数据结构与算法学习笔记----博弈论

# 数据结构与算法学习笔记----博弈论 author: 明月清了个风 first publish time: 2025.2.6 ps⭐️包含了博弈论中的两种问题Nim游戏和SG函数&#xff0c;一共四道例题&#xff0c;给出了具体公式的证明过程。 Acwing 891. Nim游戏 [原题链接](891. Nim游戏 - AcWing题库) 给…