GuardHei 发表于 2020-9-27 22:45

集合啦!动物森友会渲染简析

一直看到有人说老任技术落后,干脆把我之前写的文章搬到泥潭来做个动森渲染技术的科普,原文链接:https://zhuanlan.zhihu.com/p/166114434。图片全是屏摄,请大家见谅。另外第一次在s1发长文,不知道排版会不会有问题
最近玩动森玩了不少时间,稍微研究了下动森的渲染,觉得还是挺有意思的,所以写个文章记录一下。纯肉眼看,没有用模拟器抓过帧,可能有错误,望大家指出。另外补充说明截图后面有空补。首先,遗憾的是,本作在掌机和底座模式下都是锁30fps,而其在主机上的前两作都是60fps。根据泄漏的消息来说,本作采用的是和Splatoon 2,Super Mario Maker 2以及Arms同样的引擎,而这三者都是稳60fps,所以我猜任天堂很可能最开始也是往60fps的目标去的,后来大概为了清晰度贡献了帧数(毕竟不是动作游戏)。不过考虑到底座模式1080p,掌机模式720p,以及更多本世代渲染技术的运用,我觉得这个30fps的tradeoff还是值得的。另外一提,本作的物理引擎也是接的havok。在野外的时候,动森用了一种独特的俯视角,这个视角既有好处又有坏处。好处是物体的在z轴方向非常容易被剔除,半透明物体不容易overdraw,而且很多不需要支持旋转的物体建模的时候不用建模背面(比如树)。坏处是天空这类远算量小的元素只占了屏幕很小的面积,而地上很容易平铺很多道具,且很难被剔除掉。尤其动森支持任意数量道具的随意摆放,更加重了这个问题。而在室内的时候,由于一次只渲染一个房间,渲染压力**降低,因此也允许了自由视角的相机。动森支持多光源,除了日光/月光的平行光外,各类诸如油灯,篝火的道具也有光照效果,不过点光源的光照范围一般来说都不大,可能是为了性能考虑,防止重复计算。另外游戏里的各种射灯的体积光就是一个半透明mesh。我的猜测是用2d raymarch去做体积光对多光源和射灯的支持不好而且性能差,所以任天堂就用mesh去trick。稍微感觉有点可惜吧,毕竟switch上的第一方游戏已经选择性的实装2d raymarch了(比如荒野之息和奥德赛),但是还是主要针对平行光用(像路易基的鬼屋3的手电筒光柱就还是mesh)。https://pic3.zhimg.com/80/v2-0f9913e61d87a7b365dfd4b726454350_1440w.jpg(这个场景里全是实时光:1个平息光+5个聚光灯,值得一提的是啥影子都没有)游戏里只有平行光投射阴影,诸如草之类的小物体也有阴影。阴影的话,没有发现级联阴影的痕迹,估计因为俯视角的原因,没必要做。不过阴影剔除比我想象的要激进一些,当物体和视线接**行的时候(当在屏幕上方的时候)就不会渲染阴影了,连光照似乎都不计算了。软阴影用了pcf做滤波,不过这个滤波质量做的并不高,放大看能看到条带状pattern,但是因为软阴影区本身比较细,所以倒不明显。动森里的阴影有三个层次:平行光阴影+垂直阴影投射(人和大物件有)+屏幕空间环境光遮蔽。其中垂直阴影投射对于人来说就是脚下放了个圆片,对于树这类的就是放近似形状的面片来达成遮蔽效果(怎么感觉和奥德赛这类平台跳跃做法类似)。说实话不是很懂为什么,给人物加个圆片还能解释为部分室内场景没有投射阴影的光源所以用圆片来模拟一下,但是给其他物体加就比较奇怪了,大概是为了提高阴影的层次感?不过从我目前的观察情况来看,三层阴影经常会导致画面显得有点脏,尤其对于人物来说,感觉这里没有处理的很好。说到屏幕空间环境光遮蔽,对比荒野之息和异度之刃1/2,个人觉得动森实现的精度更高一些(大概也是因为动森牺牲了其他特性而且ssao距离较窄的原因),而且对画面质量的贡献还是挺大的。目前第一、第二方switch游戏上ssao的还是不少的,前段时间的纸马也上了。https://pic4.zhimg.com/80/v2-b9302aacf5a3d1b6eb79ead797e584d8_1440w.jpg(pcf做的比较糙,这里看的不明显可能是因为图片多次压缩的原因)https://pic4.zhimg.com/80/v2-ada060362c84acb3cd1cbe48a2a1c492_1440w.jpg(四瓣叶子有垂直投影(比较淡)+平行光阴影)https://pic1.zhimg.com/80/v2-642f537426d8e0ccc13c0b5699226b06_1440w.jpg(注意此时左上角的房子是有灯光的)https://picb.zhimg.com/80/v2-a6764e7afea94e85b365b8d025db5021_1440w.jpg(离开一定距离后,左上角房子上的灯光消失了)https://pic4.zhimg.com/80/v2-8e7fa7150c31d5879158cc1004ef5030_1440w.jpg(草也有阴影,而不是只有ssao)https://pic2.zhimg.com/80/v2-ce6cef549b4742933e8a5ac93c6a449e_1440w.jpg(室内只有垂直投影+ssao的情况)https://pic4.zhimg.com/80/v2-fbefbaf2afb1c85b47ec42916c56697a_1440w.jpg(室内只有平行光阴影+ssao的情况)https://pic4.zhimg.com/80/v2-a0adb210d26ffcc5ccade83f09ddfac8_1440w.jpg(室内所有阴影都有的情况,老实说我也不知道这些阴影到底按什么规则出现的)值得一提的是,动森里的半透明物体是写入深度的(指的是玻璃这里的,至于水面我个人并不确定这是不是半透明物体),所以会ssao出现artifact。一个很明显能观测到这点的地方就是水族馆,你可以很清楚的看到水箱里的海草,鱼这些东西周围有一圈ssao。https://pic4.zhimg.com/80/v2-9ee4dadb193b62b33aa3ab6d1ed03212_1440w.jpg(黑边很明显,不是屏摄质量差导致的,就是ssao,也许是为了表示出轮廓或者水里的流动感?)https://picb.zhimg.com/80/v2-e72153315df0ec466e521b761b796d5b_1440w.jpg(多层半透明混合,效果可以看)仔细想想,奥德赛和鬼屋3里也是半透明写入深度,所以这大概是任天堂第一方惯例了?关于半透明物体叠加,除了正常的object级排序外,有时候动森也会用和奥德赛一样的做法(鬼屋我还没观察到这种场景),对于半透明内部的物体用screen door transparency或者叫dithered alpha。在奥德赛里,半透明玻璃箱子里的月亮就是这样做的;在动森里,装虫子的笼子里的虫子翅膀也是这样的。嗯,反正能看,性能也还行,要求不要太高啦,反正俯视角你也看不到多少重叠的半透明物体啦。【此处为错误内容:】反射效果并不多。室内的反射效果看上去是一个非常低分辨率的cubemap去做的,这个cubemap似乎只受墙纸的颜色影响(不确定地板影不影响,但是室内的道具是不影响的),另外不需要做成动态的,在切换墙纸的时候渲一下就行了。而且由于只有墙纸和相当低的分辨率,直接在一帧内全画好就行了(甚至可能就是直接copy 6次)。【此处为修改后内容:】cubemap受四面墙壁(窗户和门),地板和天花板的影响,并不是单纯拷贝6次墙纸图案,下图可以看到门和窗都画出来了。不过总的来说,specular reflection出现的并不多,主要还是靠打调色光+边缘光。https://pic4.zhimg.com/80/v2-5167fc6983b14c63694f6493db4d22ba_1440w.jpg(注意这个金属球,看上去是白的是因为墙纸是白的,地下有地板红色的反射)水面相当的opaque,而且高光和一般常见手游水面有很大区别。高光只有在固定光柱mesh下(可能是直接叠的特效面片)和与视角接**行的时候才会出现(屏幕上部分)。我猜这是为了钓鱼机制服务的,因为过于连续频繁的高光会影响玩家对于鱼影位置的判断,而且细节损失容易导致玩家误判鱼上钩的时机。景深是1/4分辨率。沙地上脚印的做法就是一个带法线的贴片,和荒野之息,奥德赛的做法一致。前几天烟火大会更新后周日晚上放的烟火带来的光照变化是直接改平行光的,简单粗暴。另外烟花大会送的墙纸有个视差效果,虽然没有很强的立体感,但是乍一看还是挺唬人的。这个效果我不太清楚怎么做。不是parallex map,纹理本身没有立体感,还是平面,但是贴图上面的不同区域随视角变化移动速度是不同的,也许就是一个简单的uv offset?https://picb.zhimg.com/80/v2-84e58db4a177b084f00b0a6787251afd_1440w.jpg(明显降分辨率的景深)另外,一如既往的,任天堂本家游戏从来没有抗锯齿,sharpness over alias,配上这个风格,还行吧。总结,出了这么多第一方游戏,感觉任天堂的技术选型和画面要求大概也能够猜到了:对于强竞技类游戏基本都主机模式下target 1080p 60fps。这类游戏往往场景比较小,优化起来比较方便,而且技术上除了pbr以外不会考虑本世代技术(比如smm2,splatoon2,mk8d),基本靠任天堂对于pbr材质强大的掌握能力增添画面。对于非竞技类但是强动作游戏,主机模式下target 900p 60fps。作为强调单机的游戏,场景会比较大,会考虑上一两个“本世代”画面技术,在ssao,体积光,ssr,bokeh dof里面选(比如奥德赛)。对于不那么强调的动作的游戏,主机模式下target 1080p/900p 30fps,在更多的本世代技术和分辨率里面做选择(比如鬼屋3,荒野之息,动森,另外我其实想提名新纸马,但是毕竟还是主要靠烘焙光)。对于某g开头公司做的游戏,技术方面就是shi,国产手游都能吊打;至于异度之刃,我只能说,别赶工。(btw,switch那个双击home键可以放大一部分屏幕的功能真好用,看细节非常方便。

GuardHei 发表于 2020-9-27 22:50

我才发现 近 - 平 是敏感词,被**掉了

翼宿一 发表于 2020-9-27 23:09

任天堂也不是第一天被黑了

zx2kks 发表于 2020-9-27 23:13

老任被黑的一直是机子机能吧,美工也有人黑的吗

GuardHei 发表于 2020-9-27 23:17

zx2kks 发表于 2020-9-27 23:13
老任被黑的一直是机子机能吧,美工也有人黑的吗

知乎上看见书记说任天堂画面技术落后两个世代,实在忍不住

MikawaFumika 发表于 2020-9-27 23:23

楼主牛逼,学习了

冬马总冠军 发表于 2020-9-27 23:30

这代动森比较特殊,每个地方都能放道具。应该是为了这个跑30

dragrass 发表于 2020-9-27 23:31

本帖最后由 dragrass 于 2020-9-27 23:34 编辑

老任的图形硬技术不差,就是硬件机能差,游戏里得做取舍,跟做不出来不会做还是不一样的
路易吉和鬼屋其实更能体现这个,观感上感觉比动森还好一些
老任本世代的技术比如SSAO,体积光之类的用的都挺多的

— from OnePlus IN2020, Android 10 of S1 Next Goose v2.3.0

GuardHei 发表于 2020-9-27 23:37

dragrass 发表于 2020-9-27 23:31
老任的图形硬技术不差,就是硬件机能差,游戏里得做取舍,跟做不出来不会做还是不一样的
路易吉和鬼屋其实 ...

鬼屋3确实挺惊艳的,尤其没想到整个开场动画都是实时渲染的
而且老任的pbr材质做的是真心好
可惜了2d raymarch对于射灯来说还是重了点,体积光mesh穿模还是有点影响观感

BREEEEZE 发表于 2020-9-27 23:41

看完了,虽然没看懂,如何一句话评价monolith的技术力

GuardHei 发表于 2020-9-27 23:45

BREEEEZE 发表于 2020-9-27 23:41
看完了,虽然没看懂,如何一句话评价monolith的技术力
挺强的。无缝地图加载,超远视距处理。xb2和1de的主机模式是最能体现的,720p+taa时域抗锯齿,屏幕空间反射,屏幕空间环境光遮蔽,体积光啥的都有。只能说大量人手被抽调去做botw/botw2的开发导致掌机模式来不及优化

whzfjk 发表于 2020-9-27 23:47

BREEEEZE 发表于 2020-9-27 23:49

GuardHei 发表于 2020-9-27 23:45
挺强的。无缝地图加载,超远视距处理。xb2和1de的主机模式是最能体现的,720p+taa时域抗锯齿,屏幕空间反 ...

感谢解答

尘落樱飞 发表于 2020-9-27 23:49

GuardHei 发表于 2020-9-27 23:17
知乎上看见书记说任天堂画面技术落后两个世代,实在忍不住

书记···

dragrass 发表于 2020-9-28 00:03

本帖最后由 dragrass 于 2020-9-28 00:05 编辑

GuardHei 发表于 2020-09-27 23:37:42
鬼屋3确实挺惊艳的,尤其没想到整个开场动画都是实时渲染的
而且老任的pbr材质做的是真心好
可惜了2d ray ...现在真没有哪个厂真的硬画面技术上能落后几个世代了

图形开发已经标准化了,不计较实际观感的话什么SSAO在引擎里能无脑开
开源的开放的标准和api一大堆,谁都能用,国产手游厂都用虚幻4了呢

现在说的技术力差距不是说这个公司会SSAO那个公司不会,而是技术力强的能把这些新技术用到刀刃上,在性能允许的条件下尽可能提升观感
老任其实挺擅长这个的

落后两个世代有点尬黑了

-- 来自 能搜索的 Stage1官方 Android客户端

GuardHei 发表于 2020-9-28 00:06

dragrass 发表于 2020-9-28 00:03
现在没有哪个厂真的硬画面技术上能落后几个世代了

图形开发已经标准化了,不计较实际观感的话什么SSAO在引 ...

是这个道理,基本上现在用unity这类商业引擎开发的游戏都是本世代的技术
不过隔壁书记还在说ps3的机能怎么上本世代技术

S2M2W 发表于 2020-9-28 00:10

GuardHei 发表于 2020-9-27 22:50
我才发现 近 - 平 是敏感词,被**掉了

国讳
页: [1]
查看完整版本: 集合啦!动物森友会渲染简析