美术妹子让我给模型加个描边,我差点把Cocos卸了

引言

哈喽大家好,我是亿元程序员。

前两天美术妹子丢给我一个模型:

问我:

能不能给这个飞机加上一圈白色的描边?

我心想:不就是描边吗,小意思。

然后我就又打开了Cocos Creator……(为什么是又?)

然后就懵了。

Cocos的内置standard材质里,翻遍了所有勾选项,愣是没找到一个"OutlineColor"。

没办法,自己动手。

好在最后搞出来了两种方案一种在编辑器点点点就行,一种自定义 effect效果都很能打

言归正传,今天就把这两条路完整走一遍,看看一个 3D 模型描边到底是怎么做出来的。

本文源工程在文末获取,小伙伴们自行前往。

先看效果

效果就是这样:

  • 模型轮廓有一圈干净的描边
  • 颜色、粗细都可以在编辑器里直接调

话不多说,直接开干。

描边的本质:背面 Shell 法

在动手之前,先讲清楚一件事: 3D描边到底是怎么实现的?

最常见、也是这篇文章用的方案,叫"背面外扩 Shell 法",俗称双壳法。

思路特别朴素:

把模型沿法线方向往外推一点点,整体涂成纯白,然后只画"背面"。

为什么只画背面?因为模型的正面被原模型挡住了,看不见;而沿轮廓边缘的位置,外扩出来的"壳"会从原模型边上露出来一圈。

这一圈就是描边。

听上去有点绕,但本质就一句话:做个稍大一号的白色副本,套在原模型外面,只画背面。

接下来的两种方法,区别只在于"放大"这件事在哪一步完成。

方法一:拖两个模型叠一起(最朴素方案)

这是连 shader 都不用写的方案。

思路直接到离谱:

首先,我们先把美术妹子给的模型先拖到场景里面去:

然后,再拖一个模型到这个模型的根节点下面:

效果如下,两台一样的飞机叠在一起:

QQ20260617-235642

接着,新建一个材质球,将Shader设置成内置的builtin-unlit,描边颜色为白色,将Cull Mode设置成FRONT

然后,把材质球替换掉第二架飞机的材质球,并且适当地将第二架飞机放大(下图为2倍):

image

就能够看到白色的飞机了:

最终效果如下:

从上面的内容看来,这个方法有比较明显的有点和缺点。

优点

  • 0 行 shader 代码,纯靠预制体嵌套 + 材质设置
  • 门槛极低,美术自己都能改
  • 粗细颜色都在 Inspector 里调,可视化

缺点(也得说清楚):

  • 一个物体要渲染两次DrawCall 翻倍
  • 描边粗细随距离变化(远处变细,近处变粗)
  • 模型中心不在原点时,等比 scale 会让外层偏移,描边粗细不均

所以这种方案适合:美术快速验证效果项目里描边物体不多懒得碰 shader

但如果你要其他更好的描边方法,看下面这种方案。

方法二:自定义 Shader

一个 Pass 搞定(推荐)

还是同样的思路——背面外扩 + 只画背面,但"放大"这一步搬到 GPU 顶点着色器里做。

好处显而易见:

  • 模型只有一份,预制体干干净净
  • 描边粗细是世界空间常量,不随物体scale变化
  • 想做特殊效果(距离衰减、屏幕空间等宽)只要改顶点着色器

唯一的代价是,不要求你会创造effect,但你得会改effect

1.找模版

首先在资源管理器上搜索standard找到builtin-standard模板,复制一份到asses目录下,并且改个你喜欢的名字。

image

2. 新增pass

新增一个pass,指定顶点着色器和片元着色器,关键也是设置rasterizerStatecullModefront,同时添加两个变量(颜色和描边粗细)。

2. 描边顶点着色器

核心就一行

image

把顶点沿世界法线方向,推出去 outlineWidth 这么远。 完事。

3. 描边片元着色器(一行)

真的就一行:

没有光照、没有贴图、没有花里胡哨,直接吐出描边颜色。

**因为只有"背面外扩"的像素能进到这里来,**所以最终只看到一圈描边。

4.应用

写完之后就可以直接用了,还是新建一个材质,设置Effect,描边颜色和描边粗细,附上模型贴图:

5.效果演示

材质球替换掉模型的材质球即可看到我们片头的最终效果:

结语

那么问题来了:如果要做距离自适应描边(远处粗细看起来不变)或者屏幕空间等宽描边的话,Cocos应该怎么卸载? 欢迎小伙伴们评论区聊聊。

本文完整工程源码可通过点赞后私信发送"模型描边"获取。

更多实战完整源码包含编辑器可以通过点击Cocos商城了解更多,感谢小伙伴们对创作的支持。


我是"亿元程序员",一位有着 8 年游戏行业经验的主程。 在游戏开发中,希望能给到您帮助,也希望通过您能帮助到大家。

实不相瞒,想要个在看!请把该文章分享给你觉得有需要的其他小伙伴,谢谢!

推荐文章:

亿元Cocos小游戏实战合集2.0

亿元Cocos小游戏实战合集1.0

老板说最近这款游戏很火让我抄,可是我连玩都玩不明白…

这款值68亿的游戏,你不实战一下吗?安排!

小伙伴说我的拼图游戏用Mask不能合批…

俄罗斯方块谁不会做…啊?流沙版?

最近很火的一个拼图游戏,老板让我用Cocos3.8做一个…

老板说拼图游戏太卷了,让我用Cocos做个3d版本的…

敢不敢挑战用Cocos3.8复刻曾经很火的割绳子游戏?

11赞

大佬就是雕

大佬就是Diao!

强死了!!

大佬是吊。

这个是真有用大佬

3D模型描边眼

image
报告大佬,有个错别字!

大佬这么写有大佬的道理 :upside_down_face:

1赞

牛逼,学习了

最近那么高产的吗~

曾经做过一个需要描边的项目,然后就是被摄像机镜头影响描边的样式给折磨疯了。。 疯狂对角度。调参数。 摄像机是会360度旋转和 各种角度看这个 模型的。 还好还是绕过去了。 所以现在有办法吗

太强了,大佬,带带我

将法线变换到裁剪空间后 先乘个 w分量,防止在透视除法时 被近大远小。

:rofl: 脑子宕机 。

大佬是屌!

tql

大佬牛逼!

把toon的描边pass复制到standard也行