【卡通渲染】 解读Unity Chan

2023-10-17 19:50
文章标签 解读 unity 渲染 chan 卡通

本文主要是介绍【卡通渲染】 解读Unity Chan,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

啃了《unity shader 入门精要》的非真实渲染之后,对卡通渲染感兴趣了,下载了unity官网上的unit酱,看了他的衣服和皮肤的shader,虽说不复杂,但我的水平还需要慢慢理解。。。不懂的地方百度后发现冯乐乐竟然16年的时候也解读过这个渲染,哈哈,我算走对路了吗,话不多说,女神的帖子链接:https://blog.csdn.net/candycat1992/article/details/51050591

她解读的很细致了,但是东西要变成自己的要自己嚼过后吐出来 才算真正吸收了,以下仅是个人理解,如有错误的地方感谢指正~~


颜色

 

衰减的光照颜色:combinedColor 

// Falloff. Convert the angle between the normal and the camera direction into a lookup for the gradient
//衰减。将法线和相机方向之间的角度转换为梯度查找// 【漫反射系数 】n•v(实际上是n•l,这里用v代替了l)float_t normalDotEye = dot( normalVec, i.eyeDir.xyz );//【截取漫反射系数】clamp函数,截取0.02到0.98之间的漫反射系数绝对值取反float_t falloffU = clamp( 1.0 - abs( normalDotEye ), 0.02, 0.98 );//【采样衰减纹理】用截取的漫反射系数做X轴采样衰减纹理,乘以衰减度float4_t falloffSamplerColor = FALLOFF_POWER * tex2D( _FalloffSampler, float2( falloffU, 0.25f ) );//【阴影颜色】原贴图的平方作为阴影,就是加深了的原贴图颜色float3_t shadowColor = diffSamplerColor.rgb * diffSamplerColor.rgb;//【C=混合了阴影的原贴图】用采样后的梯度贴图的R通道 插值 原贴图 和 阴影颜色float3_t combinedColor = lerp( diffSamplerColor.rgb, shadowColor, falloffSamplerColor.r );//【C=有阴影,有衰减度的原贴图】带阴影的原贴图 *(1+带透明度的衰减纹理)combinedColor *= ( 1.0 + falloffSamplerColor.rgb * falloffSamplerColor.a );

 

高光:specularColor

 

// Specular  高光反射// Use the eye vector as the light vector  用视角方向作为光向量 v->l//【采样高光反射贴图】float4_t reflectionMaskColor = tex2D( _SpecularReflectionSampler, i.uv.xy );//【采样 原贴图】float4_t diffSamplerColor = tex2D( _MainTex, i.uv.xy );//【高光反射系数】 n•v(实际上应该是 n•h)float_t specularDot = dot( normalVec, i.eyeDir.xyz );// 【漫反射系数】 n•v(实际上是n•l,这里用v代替了l)float_t normalDotEye = dot( normalVec, i.eyeDir.xyz );//  【计算各个光照系数】。为了得到高光反射光照 lit(n • l, n • h, m)   返回一个光照向量(环境,漫反射,高光,1)float4_t lighting = lit( normalDotEye, specularDot, _SpecularPower );//【高光反射颜色】和原贴图颜色相乘即可得到最后的高光反射颜色float3_t specularColor = saturate( lighting.z ) * reflectionMaskColor.rgb * diffSamplerColor.rgb;//【C=带阴影,衰减度,高光的原贴图】combinedColor += specularColor;

 

 

反射 :reflection

	// Reflection 反射//【反射方向】reflect(i,n)函数  入射光线:视线,法线,返回反射方向(这里输出的是 .xzy)float3_t reflectVector = reflect( -i.eyeDir.xyz, normalVec ).xzy;//这里取了反射方向的xy,其实就是把贴图放倒了一样,具体原因。。。不清楚
//对于坐标加1乘以0.5就是把范围[-1,1]转换到[0,1]
//【坐标映射】float2_t sphereMapCoords &

这篇关于【卡通渲染】 解读Unity Chan的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

详解如何在React中执行条件渲染

《详解如何在React中执行条件渲染》在现代Web开发中,React作为一种流行的JavaScript库,为开发者提供了一种高效构建用户界面的方式,条件渲染是React中的一个关键概念,本文将深入探讨... 目录引言什么是条件渲染?基础示例使用逻辑与运算符(&&)使用条件语句列表中的条件渲染总结引言在现代

MySQL中时区参数time_zone解读

《MySQL中时区参数time_zone解读》MySQL时区参数time_zone用于控制系统函数和字段的DEFAULTCURRENT_TIMESTAMP属性,修改时区可能会影响timestamp类型... 目录前言1.时区参数影响2.如何设置3.字段类型选择总结前言mysql 时区参数 time_zon

MySQL中的锁和MVCC机制解读

《MySQL中的锁和MVCC机制解读》MySQL事务、锁和MVCC机制是确保数据库操作原子性、一致性和隔离性的关键,事务必须遵循ACID原则,锁的类型包括表级锁、行级锁和意向锁,MVCC通过非锁定读和... 目录mysql的锁和MVCC机制事务的概念与ACID特性锁的类型及其工作机制锁的粒度与性能影响多版本

Redis过期键删除策略解读

《Redis过期键删除策略解读》Redis通过惰性删除策略和定期删除策略来管理过期键,惰性删除策略在键被访问时检查是否过期并删除,节省CPU开销但可能导致过期键滞留,定期删除策略定期扫描并删除过期键,... 目录1.Redis使用两种不同的策略来删除过期键,分别是惰性删除策略和定期删除策略1.1惰性删除策略

Redis与缓存解读

《Redis与缓存解读》文章介绍了Redis作为缓存层的优势和缺点,并分析了六种缓存更新策略,包括超时剔除、先删缓存再更新数据库、旁路缓存、先更新数据库再删缓存、先更新数据库再更新缓存、读写穿透和异步... 目录缓存缓存优缺点缓存更新策略超时剔除先删缓存再更新数据库旁路缓存(先更新数据库,再删缓存)先更新数

C#反射编程之GetConstructor()方法解读

《C#反射编程之GetConstructor()方法解读》C#中Type类的GetConstructor()方法用于获取指定类型的构造函数,该方法有多个重载版本,可以根据不同的参数获取不同特性的构造函... 目录C# GetConstructor()方法有4个重载以GetConstructor(Type[]

MCU7.keil中build产生的hex文件解读

1.hex文件大致解读 闲来无事,查看了MCU6.用keil新建项目的hex文件 用FlexHex打开 给我的第一印象是:经过软件的解释之后,发现这些数据排列地十分整齐 :02000F0080FE71:03000000020003F8:0C000300787FE4F6D8FD75810702000F3D:00000001FF 把解释后的数据当作十六进制来观察 1.每一行数据

Java ArrayList扩容机制 (源码解读)

结论:初始长度为10,若所需长度小于1.5倍原长度,则按照1.5倍扩容。若不够用则按照所需长度扩容。 一. 明确类内部重要变量含义         1:数组默认长度         2:这是一个共享的空数组实例,用于明确创建长度为0时的ArrayList ,比如通过 new ArrayList<>(0),ArrayList 内部的数组 elementData 会指向这个 EMPTY_EL

Spring 源码解读:自定义实现Bean定义的注册与解析

引言 在Spring框架中,Bean的注册与解析是整个依赖注入流程的核心步骤。通过Bean定义,Spring容器知道如何创建、配置和管理每个Bean实例。本篇文章将通过实现一个简化版的Bean定义注册与解析机制,帮助你理解Spring框架背后的设计逻辑。我们还将对比Spring中的BeanDefinition和BeanDefinitionRegistry,以全面掌握Bean注册和解析的核心原理。

GPT系列之:GPT-1,GPT-2,GPT-3详细解读

一、GPT1 论文:Improving Language Understanding by Generative Pre-Training 链接:https://cdn.openai.com/research-covers/languageunsupervised/language_understanding_paper.pdf 启发点:生成loss和微调loss同时作用,让下游任务来适应预训