来源 | OSCHINA 社区
作者 | ClownFish
原文链接:https://my.oschina.net/clownfish/blog/5560923
七夕来咯!又到了给重要的人送惊喜的时刻。
今年,除了将心意融入花和礼物,作为程序员,用自己的代码本事手搓一个技术感十足 “七夕限定” 惊喜,我觉得,这是不亚于车马慢时代手写信的古典主义浪漫。
那么,应该怎样创作出具有自我身份属性的浪漫七夕惊喜呢?
玩法很多,今天给大家介绍一个不出错的技术控浪漫实操方式 —— 烟花粒子动画,在虚拟空间为对方造一个漫天烟花,平行时空的浪漫,多酷。
必须的,烟花粒子动画效果除了炫浪漫,还有多种切实的应用场景,比如,游戏应用中,玩家得胜后的页面呈现、春节等特定节假日的游戏内氛围打造等。
看个示例:
从粒子动画走向更多精彩
烟花粒子动画是搭载 HMS Core 3D Engine 实现的视觉效果,借助 3D Engine,还能开启虚拟视界的更多精彩可能。 3D Engine 为开发者提供高性能、高画质、高扩展性的实时 3D 引擎,以及便捷高效的可视化开发工具,帮助开发者制作高品质的 3D 应用。
如果你是游戏开发或者对游戏开发感兴趣,那么你用 3D Engine 能耍得不只是浪漫。
1、高清渲染与视觉特效,高度还原逼真光影效果;
2、多线程 PBR 渲染,实现高性能实时 3D 渲染效果;
3、CPU/GPU 粒子渲染,模拟爆炸、火焰、雨雪等视觉特效;
4、3D 角色及流畅动画轻松造,支持实时骨骼动画、表情动画、全身 IK、动画重定向、多重动画状态机融合;
5、提供自动导航网格生成,多目标的路径规划,NPC 智能寻路及智能避障功能;
6、3D Studio 提供便捷开发工具,支持场景编辑、材质编辑、动画编辑、地形编辑、脚本编辑等核心功能
总之,3D Engine 在手,品质 3D 游戏场面轻松有,不服来试!
实操指南 —— 用 3D Engine 实现粒子动画烟花效果
创建关卡
1、您需要创建一个新的关卡:在引擎首页菜单栏中,选择 “文件> 新建关卡”。
![](http://dingyue.ws.126.net/2022/0804/cf5a9d16j00rg3g0h000gd2007700aog007700ao.jpg)
2、输入 Level 名称,比如 “Fireworks” 后,点击 “确认” 创建成功。完成后您将进入到玄天引擎的 Level 界面。
![](http://dingyue.ws.126.net/2022/0804/a4003e13j00rg3g0h0008d2008w005yg008w005y.jpg)
![](http://dingyue.ws.126.net/2022/0804/cf1f5c35j00rg3g0j00aud200sv00fjg00sv00fj.jpg)
环境搭建
1、在场景烟花效果之前,我们需要适当调整关卡中的环境,首先去除我们用不到的实体:在引擎首页 “实体大纲” 窗口中的默认环境找到着色球和地面网格实体,鼠标右键点击删除。
![](http://dingyue.ws.126.net/2022/0804/4c1df649j00rg3g0k000ld200ak00bmg00ak00bm.jpg)
2、我们需要模拟一个较暗的环境:选中 “实体大纲” 窗口默认环境组中的天空,在引擎首页右侧的 “组件属性” 窗口中找到高动态范围天空盒组件,并调整曝光度属性至 - 3.2。
![](http://dingyue.ws.126.net/2022/0804/2cd86d3fp00rg3g0k0008d200ah002zg00ah002z.png)
3、选中 “实体大纲” 窗口默认环境组中的太阳,在引擎首页右侧的 “组件属性” 窗口中找到定向光源组件,并鼠标右击该组件,点击 “禁用组件”。
![](http://dingyue.ws.126.net/2022/0804/ad4ce5caj00rg3g0l001cd200ah00gsg00ah00gs.jpg)
4、在 “实体大纲” 窗口中鼠标右击选择 “创建实体”。
![](http://dingyue.ws.126.net/2022/0804/110de21ej00rg3g0l000bd200am00c1g00am00c1.jpg)
5、在 “实体大纲” 窗口中选中新创建的实体,在组件属性中重命名为 “Bloom”,并添加一个 “光晕” 组件和 “后处理盒” 组件来加强烟花粒子的光效。
![](http://dingyue.ws.126.net/2022/0804/25ffdd65j00rg3g0l0012d200aq00hpg00aq00hp.jpg)
6、设置光晕组件的参数如下图。
![](http://dingyue.ws.126.net/2022/0804/c878f0fdj00rg3g0m000kd200a900aag00a900aa.jpg)
完成以上步骤后你将得到以下效果
![](http://dingyue.ws.126.net/2022/0804/efc12896j00rg3g0n00asd200u000jhg00vx00kp.jpg)
材质编辑
1、接下来我们需要为烟花粒子创建一些光效材质,首先在引擎首页的全局菜单栏中点击 “工具> 材质编辑器” 打开材质编辑器。
![](http://dingyue.ws.126.net/2022/0804/704d43b6j00rg3g0o000jd2005600cug005600cu.jpg)
![](http://dingyue.ws.126.net/2022/0804/15623611j00rg3g0p009wd200u000g6g00yn00in.jpg)
2、在材质编辑器的菜单栏中点击 “文件> 新建”,创建一个新的材质文件。
![](http://dingyue.ws.126.net/2022/0804/c3ba1062j00rg3g0p000dd20055008fg0055008f.jpg)
3、在弹出的窗口中选择材质类型为 “ParticleMesh”,并在工程目录中的 Assets 文件夹中新建一个 “Material” 文件夹,将材质保持到此文件夹中,重命名为 “Particle”。
![](http://dingyue.ws.126.net/2022/0804/303f340ej00rg3g0q0013d200cd009og00cd009o.jpg)
4、材质编辑器的 “材质属性” 窗口中展示当前材质类型及可输入参数配置,您可以在此修改其相应的参数设置,参数设置如下图。
・基础颜色:使用基础颜色中的颜色,可以在输入栏中直接输入 RGB 值,也可以点击颜色方块打开 “选择颜色” 窗口调整颜色。
・自发光:使用自发光属性,需要先打开 “开启” 开关。颜色使用方式与基础颜色属性类似,强度决定了自发光的强度。
![](http://dingyue.ws.126.net/2022/0804/9d4b43fej00rg3g0q0010d200ay00iwg00ay00iw.jpg)
5、为了丰富我们的粒子光效,我们需要重复 2~4 步骤,重新创建两个不同颜色的光效材质,并命名为 “Particle_02” 和 “Particle_03”,参数设置如下图。
![](http://dingyue.ws.126.net/2022/0804/d59e27dbj00rg3g0r000zd200b700iug00b700iu.jpg)
![](http://dingyue.ws.126.net/2022/0804/28d05d0ej00rg3g0s000zd200b600ixg00b600ix.jpg)
粒子编辑
1、返回引擎首页,在全局菜单栏中点击 “工具> 粒子编辑器” 打开粒子编辑器。
![](http://dingyue.ws.126.net/2022/0804/f1a4bde8j00rg3g0s000jd2005900cxg005900cx.jpg)
![](http://dingyue.ws.126.net/2022/0804/abb59929j00rg3g0t0099d200sv00fjg00sv00fj.jpg)
2、在粒子编辑器中的 “资源浏览” 窗口中找到工程目录中的 “Assets” 文件夹,点击选中后在浏览模板中鼠标右击并点击 “新建文件夹”,命名为 “Particle”。
![](http://dingyue.ws.126.net/2022/0804/e955fb2dj00rg3g0u000gd200ib009sg00ib009s.jpg)
3、在我们步骤 2 中创建的 “Particle” 文件夹中鼠标右击并点击 “新建粒子系统”,命名为 “Fireworks.particle”。
![](http://dingyue.ws.126.net/2022/0804/14331c10j00rg3g0v000md200go009wg00go009w.jpg)
4、双击浏览面板创建的粒子进入编辑,在 “发射器” 窗口中会显示一个默认效果:精灵粒子使用黄色材质,以每秒 10 个粒子的速度向上发射,粒子的生命周期为 1 秒。
![](http://dingyue.ws.126.net/2022/0804/0eb3e7a4j00rg3g0w00dxd200u000fwg00wh00h7.jpg)
5、我们需要创建一个向上发射的粒子部分和一个爆发的粒子部分组成发射和绽放的烟花效果,让我们先编辑一个向上发射的粒子发射器。
点击发射器节点中的 “发射器属性” 属性分类后,您可在 “细节” 面板查看该属性分类下的属性模块,按照下图设置粒子最大发射数量和发射器时长。
![](http://dingyue.ws.126.net/2022/0804/04c310f4j00rg3g0x000xd200la00h7g00la00h7.jpg)
点击发射器节点中的 “生成方式” 属性分类,勾选使用 “爆发列表” 生成方式,并在爆发列表中添加一个元素设置粒子数量为 4。
![](http://dingyue.ws.126.net/2022/0804/df5dae36j00rg3g0y001ed200ld00h8g00ld00h8.jpg)
点击发射器节点中的 “粒子基础属性” 属性分类,设置粒子的生命周期为 1.5。
![](http://dingyue.ws.126.net/2022/0804/2d450467j00rg3g0z0015d200lk00h5g00lk00h5.jpg)
点击发射器节点中的 “发射器形状” 属性分类,在发射器形状中选择为长方形,并按照下图设置尺寸。
![](http://dingyue.ws.126.net/2022/0804/2169fe08j00rg3g10000ud200ll00h5g00ll00h5.jpg)
点击发射器节点中的 “速度” 属性分类,设置 Z 轴速度为 7.0。
![](http://dingyue.ws.126.net/2022/0804/14627e5bj00rg3g10000yd200ln00h6g00ln00h6.jpg)
点击发射器节点中的 “尺寸” 属性分类,勾选 “尺寸随时间变化”,选择类型为曲线值,并按照下图设置 X、Y、Z 的最大值和曲线。
![](http://dingyue.ws.126.net/2022/0804/189c55d5j00rg3g12001cd200lr00h5g00lr00h5.jpg)
点击发射器节点中的 “外力” 属性分类,勾选加速度,并按下图进行设置。
![](http://dingyue.ws.126.net/2022/0804/3c4f7a58j00rg3g12000td200ly00h3g00ly00h3.jpg)
点击发射器节点中的 “光照” 属性分类,勾选光照,并按照下图参数进行设置。
![](http://dingyue.ws.126.net/2022/0804/faec5317j00rg3g13000td200lt00h6g00lt00h6.jpg)
点击发射器节点中的 “渲染器” 属性分类,选择渲染器为 “网格体渲染器”,并在 “Assets > Material > Particle.material” 目录中找到我们在材质编辑章节中保存的材质进行指定。
![](http://dingyue.ws.126.net/2022/0804/8f45c4baj00rg3g140011d200k800h7g00k800h7.jpg)
在网格体中指定 “sphere.fbx”。
![](http://dingyue.ws.126.net/2022/0804/1f2e26fdj00rg3g14000vd200kt00epg00kt00ep.jpg)
6、此时,我们已经完成了一个向上发射的粒子发射器,接下来我们需要再对爆发的烟花粒子进行编辑。
首先我们在 “发射器” 窗口中鼠标右击,点击 “添加发射器” 添加一个新的发射器。
![](http://dingyue.ws.126.net/2022/0804/e98e67f3j00rg3g15000pd200l100h7g00l100h7.jpg)
点击发射器节点中的 “发射器属性” 属性分类后,按照下图设置发射器属性参数。
![](http://dingyue.ws.126.net/2022/0804/52e53733j00rg3g16000wd200lj00h8g00lj00h8.jpg)
点击发射器节点中的 “生成方式” 属性分类后,按照下图设置生成方式参数。
![](http://dingyue.ws.126.net/2022/0804/3abb6b2bj00rg3g17001ed200kz00h6g00kz00h6.jpg)
点击发射器节点中的 “粒子基本属性” 属性分类后,按照下图设置粒子基本属性参数。
![](http://dingyue.ws.126.net/2022/0804/a1c6de11j00rg3g180017d200le00h9g00le00h9.jpg)
点击发射器节点中的 “发射器形状” 属性分类后,按照下图设置发射器形状参数。
![](http://dingyue.ws.126.net/2022/0804/186648c2j00rg3g18000sd200l500h3g00l500h3.jpg)
点击发射器节点中的 “速度” 属性分类后,按照下图设置速度参数。
![](http://dingyue.ws.126.net/2022/0804/f9547954j00rg3g19000yd200ks00h6g00ks00h6.jpg)
点击发射器节点中的 “尺寸” 属性分类后,按照下图设置尺寸参数。
![](http://dingyue.ws.126.net/2022/0804/13132f88j00rg3g19001cd200l200h7g00l200h7.jpg)
点击发射器节点中的 “外力” 属性分类后,按照下图设置外力参数。
![](http://dingyue.ws.126.net/2022/0804/61e57aafj00rg3g1a000yd200l900h4g00l900h4.jpg)
点击发射器节点中的 “光照” 属性分类后,按照下图设置光照参数。
![](http://dingyue.ws.126.net/2022/0804/a35328faj00rg3g1b000sd200l500h8g00l500h8.jpg)
点击发射器节点中的 “渲染器” 属性分类后,按照下图设置渲染器参数。
![](http://dingyue.ws.126.net/2022/0804/50515d61j00rg3g1c0012d200ky00h8g00ky00h8.jpg)
7、重复步骤 6,创建两个新的发射器,丰富烟花的粒子效果。要注意的是,你可以在新建的两个发射器中设置不同的 “速度> 球形速度” 参数和 “粒子基本属性 > 粒子生命 > 生命周期” 参数来丰富烟花效果,当然你也可以根据你的理解设置其他属性的参数值。
![](http://dingyue.ws.126.net/2022/0804/971d83faj00rg3g1c000yd200l800hbg00l800hb.jpg)
8、此时我们已经完成了一个烟花粒子的设置,为了达到更加丰富的效果,我们可以将该粒子文件进行复制,得到两个新的拥有相同属性参数的粒子效果,我们将其命名为 “Fireworks_02” 和 “Fireworks_03”。
![](http://dingyue.ws.126.net/2022/0804/4968e6b5j00rg3g1d0012d200mc00d4g00mc00d4.jpg)
9、在粒子编辑器中打开 “Fireworks_02” 粒子文件,分别点击四个发射器节点中的 “渲染器” 属性分类,将材质指定为我们在 “材质编辑” 章节中保存的其他颜色的材质文件 “Particle_02” 来丰富我们的烟花效果并保存我们的编辑。同理我们在 “Fireworks_03” 粒子文件中可以指定新的材质文件 “Particle_03”。
![](http://dingyue.ws.126.net/2022/0804/4e6a5f77j00rg3g1e002dd200u000hkg011c00lu.jpg)
放置粒子
1、返回引擎首页,在 “实体大纲” 窗口中鼠标右击点击 “创建实体”,创建 7 个空白实体,并在 “组件属性” 窗口中为其重命名,可参考下图。
![](http://dingyue.ws.126.net/2022/0804/6d6b1acbj00rg3g1f000id200al00bzg00al00bz.jpg)
2、在 “实体大纲” 窗口中多选新建的 7 个实体后,在 “组件属性” 窗口在为其添加 “粒子组件”。
![](http://dingyue.ws.126.net/2022/0804/88deceffj00rg3g1f000kd200ar00ckg00ar00ck.jpg)
3、在 “粒子” 组件中,指定我们保存的粒子文件,并打开 “开启” 按钮,这里我们可以为每个实体随机指定 “Fireworks”、“Fireworks_02” 和 “Fireworks_03” 粒子文件。
![](http://dingyue.ws.126.net/2022/0804/589bb1d1j00rg3g1g0023d200u000e1g00w900f2.jpg)
5、使用视口的控件随机摆放 7 个实体的位置和旋转,这将决定烟花发射的角度和位置。
![](http://dingyue.ws.126.net/2022/0804/66756254j00rg3g1i00aid200u000jgg00vx00ko.jpg)
6、最后我们还需要调整一下相机的角度和位置,我们在 “实体大纲” 窗口默认环境中选中 “相机” 实体。
![](http://dingyue.ws.126.net/2022/0804/5da4171ej00rg3g1i000jd200al00bxg00al00bx.jpg)
7、在 “组件属性” 窗口中找到 “飞行摄像机输入” 组件,鼠标右击该组件,并将其删除。
![](http://dingyue.ws.126.net/2022/0804/942d55f1j00rg3g1j0010d200ao00dlg00ao00dl.jpg)
8、在相机组件中,点击进入摄像机视角后,你的视口将会呈现相机视角,你可以在视口中使用鼠标和键盘移动视角。
![](http://dingyue.ws.126.net/2022/0804/4678501ej00rg3g1k000ed200ac005qg00ac005q.jpg)
9、选定好最佳的观赏位置后,点击 “返回默认编辑器相机视角”。
![](http://dingyue.ws.126.net/2022/0804/bc869fabj00rg3g1k000gd200ai005ug00ai005u.jpg)
最终效果
![](http://dingyue.ws.126.net/2022/0804/c9619a25p00rg3g1k0003d2007w0031g007w0031.png)
完成上述步骤后,点击运行按钮的下拉菜单,选择 “Play (Maximized)” 全屏运行,您就可运行此场景了。
了解更多详情 >>
访问 3D Engine 开发者联盟官网 :https://developer.huawei.com/consumer/cn/hms/3d-engine/?ha_source=hms1
华为移动服务开源仓库地址: GitHub :http://github.com/HMS-Core、 Gitee : https://gitee.com/hms-core
热门跟贴