微信号:Unity-GreaterChina

介绍:Unity官方开发者平台,分享最前沿的技术文章和开发经验,精彩的Unity活动和社区相关信息.

使用粒子实现Logo消融效果

2018-10-30 12:12 Unity

本文将由游戏开发者Mirza分享使用Unity的默认Shuriken粒子系统,在不使用插件或编写脚本的情况下,实现Logo消融效果。



这是一个Unity中运行的实时效果,你可以使用任意图片实现该效果,无论图片是否是彩色的。本教程将使用纯白色纹理来制作,根据该纹理调整设置,你可以改变部分粒子颜色,使其更符合自己使用的图片。


Part 1:Logo浅入淡出效果

我们首先处理粒子系统,实现整个Logo图片的浅入淡出效果。


                          

创建一个新材质,将Logo贴图赋予此材质。将其设置为使用Particles/Alpha Blended着色器。



我们需要确保纹理拥有读写权限。如果没有权限,基于纹理的粒子发射效果将只能在编辑器中可用,无法在游戏中实现。



创建一个新的粒子系统。每次创建时,请重置Transform属性,这样游戏对象不会出现平移或旋转,除非打算使其以某种方式移动和旋转。

 

                                             

打开Renderer模块,并将粒子材质设置为刚刚创建的材质。如果想提高亮度,并且正使用着后期处理的泛光效果,我们可以将颜色调为纯白色,并将Alpha调到最大。


如下图对材质Tint Color进行的处理,将Render Alignment设为Local。我们不会让Logo的基础纹理粒子面向摄像机,这样能确保粒子面向本地变换的方向。



我们只打算发射一个粒子,所以查看Emission模块并按照下图进行设置。



现在我们可以进行Main模块设置。我们不需要循环播放该效果中的任何粒子系统,所以取消勾选Looping属性来禁用循环过程。

 

为了能通过脚本轻松地调整模拟时间,我们将Start Lifetime设为1。如果你不打算处理该数值,应该将它设为更合适的值。你可以将其设为较大数值,使观看者有足够时间看到Logo,再让Logo爆炸为精美的粒子。

 

如果我们不使用正方形纹理,则可能需要启用3D Start Size并处理参数。我们发射的是2D粒子,所以只要处理X和Y值。图像分辨率为1024*512,宽高比为2:1,所以将X值设为2,Y值设为1,使它匹配宽高比,避免使图片变形。

 

我们还降低了Start Color的Alpha值,因为使用后期处理设置的泛光效果时,图像的亮度会过高。

      

                   

现在,我们需要使用Color over Lifetime模块来设置Alpha动画。下图是处理Logo浅入淡出效果的设置。


Alpha入时间为总时间的25%,从25%~75%的时间显示Logo,然后再完全淡出。因为我们将该粒子持续时间设为1,所以分别设定的时间为0.25和0.75。

 

Part 2:Logo爆裂效果

在这一部分,我们将使用的粒子系统制作Logo分散的爆裂效果。

 

                                             

首先创建新粒子系统。我们有三种方法可以选择:

  • 为点精灵图片创建简单的粒子纹理,将其指定给附加材质。

  • 使用Ultimate VFX资源的点材质。

  • 使用Inferno VFX中的附加发光球体材质。

 

这三种方法均可用于本文教程,Ultimate VFX和Inferno VFX都是由本文作者Mirza所创作,如果你不想自己制作纹理和材质,也不打算付费购买资源,可以下载免费的Inferno VFX。


打开新建粒子系统的Renderer模块并设置材质,不必修改其它设置。



请按照下面的内容设置Main模块和Emission模块。

 

Start Delay会按指定时间推迟发射过程,以秒为单位。我们希望该效果在Logo淡出时发生,也就是从前面粒子系统的透明动画开始,即整个过程的第0.75秒。


这些粒子会很小,因此我们将Start Size设为单位大小的1/8,即0.125。粒子不用太亮,所以需要大幅降低Start Colour的Alpha值。

 

因为会有大量微小粒子,我们需要将Max Particles设为10,000,并将Emission模块中Bursts属性的Count数值也设为10,000。



现在让这些粒子从Logo纹理的形状发射出来,请按下面内容设置。

 

将Shape设为Box,指定Logo图片到Texture字段。如果想让粒子继承Logo的颜色,请勾选Color affects Particles。

 

类似之前的粒子系统Start Size设置,我们调整了发射器边界,通过设置Scale为[2, 1, 0],使其匹配图片的宽高比。Z值为0,因为希望让发射器在平面上发射。



此时,当粒子在Start Delay后发射时,我们会看到类似下图的效果。现在有了在纹理形状发射的基础,我们可以实现任何想要的效果。



现在处理分散的文字。启用Velocity over Lifetime模块。

 

点击该属性最右侧箭头设置Linear属性,选择Random Between Two Curves。指定相似曲线到所有轴,范围从-1~1。曲线会随时间慢慢增强分散效果,而不是立即分散,因此它能更好地融合前面的粒子系统,并提供过渡转变为噪声分散粒子系统。

 

为方便起见,这里使用了Speed Modifer来调整数值,但是为每个轴直接设置数值会更好,这样粒子系统可以自动剔除。本示例是一个Logo动画效果,所以这样处理意义不大。



最后,按下图启用并编辑Color over Lifetime模块和Size over Lifetime模块。


Part 3:Logo噪声分散效果

接下来,我们将会制作第一个噪声分散效果,如下图所示。该效果需要一个新的粒子系统,我们可以将刚制作好的粒子系统复制过来,因为许多设置是相同的。

 

                               

我们需要修改部分设置,在Main模块和Emission模块中有一些区别。


Start Delay和Start Lifetime的数值会在1到2秒之间随机选取,Start Size较小,Max Particles设为20000,Burst中的Count值也设为20000。为了随机选取Start Lifetime数值,点击下拉箭头,选择Random Between Two Constants。

 

 

Color over Lifetime模块也有不同。

 

 

引入噪声后,就变得有趣了,现在启用Noise模块,按下面内容进行设置。


我们将Strength改为使用曲线,这样粒子不会立即以噪声方式分散,从而更好地与其它效果融合。右键点击曲线的控制点,选择Edit Key… 来直接控制并编辑点在视图上的位置,使用Broken切线模式允许你修改左边或右边的切线,而不改变另一侧的曲线。

 

通过使用这二个方法,我们将控制点设在0.25秒,该点左边为直线,右边为曲线。得到的结果是0.25秒前不使用噪声,之后会突然上升为1。


频率为1.5时效果看起来不错,它能控制“混乱”等级,因为粒子由渐变场操控。Scroll Speed设为1会使噪声在粒子生命周期生成动画。

 

我们使用了大量粒子,如果将Quality设为Medium (2D)会加速模拟效果,且不会与最终效果有太大区别。



我们将Render Mode改为Stretched Billboard,设置Speed Scale为0.1,Length Scale设为1,这样会稍微根据当前的移动速度和方向拉伸粒子,产生近似运动模糊的效果。

 

                                   

其它设置可以保留原样,因为我们重用了之前粒子系统的设置。


Part 4:Logo噪声分散2

复制我们刚刚制作的粒子系统,开始制作最后一个粒子系统,它或许是该效果中最精美的部分。

 

                                             

我们需要修改Main模块和Emission模块中的部分设置。

 

Duration设为0.75,这是因为这里不会在一次爆炸中发射粒子,而是会使用Rate over Time。我们还修改了Start Delay和Start Lifetime数值,并提高了Start Color的Alpha值。

 

 

按下图设置Color over Lifetime模块和Size over Lifetime模块。让粒子从蓝色变为桔红色,每个粒子的大小会快速增大然后缓慢减小。

 

 

最后,修改Noise模块的设置,将Strength和Frequency设为1。你可以将Quality改为Medium (2D)。


Part 5:组合所有效果

到这里就差不多完成了,让我们重新看一遍已经制作做好的独立粒子系统,然后将所有效果结合成一个可播放对象。



我们可以将这些粒子系统命名并分组为另一个粒子系统,将所有模块禁用,这样它们会在你选择其中任一对象时一起播放。如果禁用Looping并设置Stop Action为Destroy,可以将其用作可实例化效果,它会在Duration时间(以秒为单位)结束后自毁。



本文到此结束,结合所有粒子系统后,精美Logo消融效果就制作完成了,最后的效果如下图所示。


小结

使用粒子实现Logo消融效果,你学会了吗?是不是制作特效非常简单。更多Unity教程尽在Unity官方中文论坛(UnityChina.cn) !


推荐阅读

官方活动

优惠活动|Unity订阅新起航,开启您的创作之旅

现在访问Unity在线商店(store.unity.com),成功订阅Unity Pro专业版、Unity Plus加强版即可享受全新增值服务组合。11月18日之前订阅,更有指定插件资源限时赠送。[了解详情...]

活动地址:https://store.unity.com/cn


点击“阅读原文”访问Unity官方中文论坛

 
Unity官方平台 更多文章 Unity FPS示例项目介绍 Unite LA精彩回顾:Visual Effect Graph、CineCast和FPS&nbs 创作经验 | 使用Unity创建高保真建筑VR项目 全新变现解决方案Unity Monetization SDK 3.0 Unite Los Angeles Keynote演讲视频
猜您喜欢 华为发布全球首款移动端AI芯片,它将如何打开手机新世界? windows添加python环境变量脚本 【每周一坑】暴力计算圆周率 +【解答】生成\/识别二维码 计算机到底是怎么识别人脸的? Tensorflow 指南[译]