位置: 编程技术 - 正文

【猫猫的Unity Shader之旅】之法线贴图的运用(猫咪的testflight)

编辑:rootadmin

推荐整理分享【猫猫的Unity Shader之旅】之法线贴图的运用(猫咪的testflight),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:猫猫的游戏,猫的所有视频,猫的合集,猫的猫的视频,猫的好玩视频,猫的猫的视频,猫的游戏解说,猫的游戏视频,内容如对您有帮助,希望把文章链接给更多的朋友!

  前几篇文章都在讲原理性的东西,不知道大家有没有烦。其实,当对Shader了解越来越多之后,就会越来越发现原理的重要性。建议大家学了一些Unity Shader的用法之后,多了解一点图形学知识,勿筑台于浮沙。

为什么需要法线贴图

  在实际的开发过程中,我们经常会遇到这样的矛盾:一方面希望模型的显示效果好,另一方面又希望模型具有较少的面数,节省开发成本和运行效率。例如我们现在要做一面砖墙,思路可能是这样的:

  1、创建一个立方体,调整各方向缩放使其看上去像一面墙。如图。

  

  2、创建一个默认材质和Shader,材质附加到立方体上,材质的Shader选择我们创建的Shder。

  3、为材质选择一幅石砖的贴图。为了更好地观察效果我们可以再添加一个方向光。

  

  当我们仔细观察这面墙时,会发现它不那么真实,尤其是旋转灯光或者墙时,墙的明暗是统一变化的,砖之间没有明暗变化,看上去就像平整的墙面上贴了一层墙纸一样。那么为什么会这样呢,这还需要从光照说起。

  回想一下我们上回说到的光照模型,对于默认的Unity Shader,我们用的Lambert光照模型,也就是LightingLambert方法(可以在Lighting.cginc文件中找到),Lambert模型是这样的:

  下面我们来简单分析下这段代码。上回我们说到,光照模型的任务是返回一个颜色(准确说经过处理的片段颜色,片段是模型经过顶点变换后形成的与屏幕坐标一一对应的部分)。可以看到最终返回的颜色c,它的rgb是光照颜色乘以反射率后又乘了一个系数。光照颜色乘以反射率容易理解,物体的颜色就是光的颜色经过衰减后得到的,比如白光(颜色为(1.0, 1.0, 1.0))照射在红色物体(反射率为(1.0, 0.0, 0.0),反射全部红光,不反射绿蓝光)上时,产生的颜色为红色(1.0, 0.0, 0.0)。那么系数diff是什么呢?

  从代码fixed diff = max (0, dot (s.Normal, lightDir));这句可以看到,diff是光照方向(lightDir)和片段的法线(s.Normal)经过点乘后得到的。回想一下中学学过的物理知识:

【猫猫的Unity Shader之旅】之法线贴图的运用(猫咪的testflight)

  

  法线垂直于平面,入射光与法线的夹角称作入射角,反射光和法线夹角成为反射角,入射角等于反射角,对吧。OK,这么多就够了,毕竟不是物理课…对于Lambert光照模型,由于入射光方向(lightDir)和法线方向(s.Normal)都是规范化过的(长度为1),所以点乘的结果就是入射角的余弦值,由于余弦值的取值范围是[-1, 1],经过和0进行最大值比较后,diff得到的就是个[0, 1]范围内的值,而且入射角越小,diff的值越小。

  到现在情况就明朗很多了,这个光照先是通过折射率对光照颜色进行衰减,又通过diff这个随着入射角增大而减小的[0,1]之间的值进行衰减,通俗点说就是光线越正着照,颜色就越亮。

  这就是为什么我们的墙没有那么多明暗变化了,我们这个墙是个简单的立方体,模型中只包含八个顶点信息,顶点之间的片段是通过差值产生的。想要实现我们想要的真正的墙壁的感觉,需要从以下两个方面入手:

  1、增加模型顶点信息,用模型自带法线信息增加表面细节。

  2、在Shader中修改片段的法线。

  我想不用我说大家也知道第二种方式更好一些。但是问题是,我们如何知道应该把法线改成多少呢?这就需要贴图来提供信息了。之前我们用贴图的颜色去修改片段的颜色,同样也可以通过法线贴图去修改片段的法线。这种用rgb值表示对应法线的xyz值得贴图,就叫法线贴图。

在Shader中使用法线贴图

  猫猫本来打算少说一些理论呢,结果不知不觉又说了一大堆…不过好在,猫猫感觉已经解释的很清楚啦,下面的代码就显得灰常简单了,不说了,直接上代码了:

  我们在代码中定义了一幅新的贴图,在surf方法中通过tex2D取得贴图的信息,UnpackNormal方法将其转换为对应的法线值。这里我把Lambert模型放进来,方便大家看到一个完整的过程。

  为我们的材质选择一个合适的法线贴图,再次移动光源,就可以看到砖墙表面出现了更多的细节效果。

  

  需要完整工程的童鞋请戳这里。

结束语

  从这篇开始,猫猫打算讲一些具体的渲染技术,那些无聊的理论终于要退居二线了。目前的打算是只说下最常用的和比较关键的渲染技巧和方法,毕竟猫猫觉得一种好的渲染效果更多靠的是对图形学的理解和…审美…好吧,咱们下回见。

雷爵代理游戏风云Unity休闲养成页游《宠物派对》 雷爵网络近日宣布与上海游戏风云文化传媒合作,取得可爱休闲养成游戏营运代理权,并正式命名为《宠物派对》,将预计于今年Q4在台湾推出,《宠物

Unity UGUI UnityUGUI的教程好少,幸亏找到一个UGUI的Demo,看了几个例子,以下是一些简单的学习笔记:1.导入UI图片资源2.设置参数:TextureType(纹理类型)精灵2DandUISpri

【Unity】NGUI插件核心脚本类的继承关系 虽说目前(年3月日)Unity4.6版本之后推出的UGUI系统替代NGUI已是大势所趋,但作为被长久且广泛使用的优秀插件之一,NGUI的代码和架构依然有很多

标签: 猫咪的testflight

本文链接地址:https://www.jiuchutong.com/biancheng/383515.html 转载请保留说明!

上一篇:Unity_制作小地图——利用遮挡(unity2d小地图)

下一篇:雷爵代理游戏风云Unity休闲养成页游《宠物派对》(雷爵电动车官网)

  • 第三方代付款的账务处理
  • 采购暂估的处理方式
  • 待认证进项税额是什么情况下用的
  • 附加税减半征收会计分录
  • 发票验证码和校验码是一样的吗
  • 资产评估增值的会计科目
  • 企业营改增后的会计处理有何变化
  • 存出的保证金
  • 品种法在制造企业中的运用
  • 当期免抵税额和当期免抵退税额
  • 应交增值税减免税款账务处理
  • 出口退税备案信息
  • 汇算清缴需要调增的费用
  • 递延所得税资产怎么计算
  • 人工智能对财务人员的挑战与机遇
  • 新个税劳务报酬怎么算
  • 个人独资企业租车缴纳税金
  • 房租收入如何结转成本
  • 万份收益是什么意思0.6
  • 账外资产评估入账固定资产折旧可以税前扣除吗?
  • 如何编辑受保护的word文档
  • 退付手续费核对过期没处理怎么办
  • 商业支付时使用
  • 关于幼儿园会没课程的会刊
  • post-secondary program
  • 删除桌面上的图标用什么键
  • 苹果推送ios15
  • vue 高德地图 窗体
  • 不需要认证的进项税额怎么处理
  • 金鱼草的养殖方法和注意事项有哪些
  • 在laravel中,界面文件应该放在以下哪个路径下
  • 房地产项目如何通过抖音宣传
  • 如何做好记账会计
  • 长期借款科目的期末余额反映尚未偿还的借款本金
  • 免施工许可证
  • PHP:imagecolorresolve()的用法_GD库图像处理函数
  • c语言 cmd
  • 生产性生物资产折旧计入什么科目
  • 银行提取现金会查征信吗
  • 如何使用vue
  • 安装elipse教程
  • php投票系统代码
  • 数据集介绍
  • 期初成本和期末成本
  • html5+css3web前端设计基础教程
  • 以前年度损益调整怎么做账
  • 企业年度报告包括哪些内容
  • 公司借调员工
  • 一般纳税人只有进项怎么报税
  • mysql的查询缓存与redis的区别
  • okhttp源码
  • 小规模劳务派遣公司税率
  • 作废发票要不回来了怎么办
  • 职工薪酬属于收益性支出
  • 个人所得税申报退税能退多少
  • 个体工商户要做账报税吗
  • 银行利息支出税率是多少
  • 普票不能抵扣为什么有税率
  • 行政事业单位非税收入管理办法
  • 销售商品该如何改进服务
  • 研发费用的台账由谁做
  • 购买材料如何计提折旧
  • 过路费油费计入什么费用
  • 老项目简易征收税率
  • 营业执照注册资金变更
  • sql server不可用或不存在什么意思
  • mssql server 2012(SQL2012)各版本功能对比
  • centos6.9 yum
  • macos 备份
  • win10系统无法进入
  • win7自动休眠怎么取消
  • opengll
  • opengl编程宝典
  • nodejs获取post数据
  • nodejs怎么在服务器运行
  • [置顶] 《借.住.情.缘》
  • js用于
  • android自定义权限申请弹窗
  • 新疆中国邮政投诉电话
  • 保险公司的人可以查到买保险的人都买了什么保险吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设