ThingJS粒子特效如何实现雨雪效果
这篇文章主要介绍了ThingJS粒子特效如何实现雨雪效果,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
使用ThingJS可以快速编写粒子效果,比如:下雨、下雪(可以控制雨雪大小)、喷水、火焰效果等,甚至可以通过对接第三方的数据,实时控制三维场景的效果(比如:对接天气接口)。
1、粒子效果
ThingJS 提供 ParticleSystem 物体类来实现粒子效果。自己制作粒子效果需要图片处理、写代码、3D渲染, 是个很艰巨的任务,需要掌握大量 3D 算法知识,还要掌握 shader 语言。ThingJS封装了粒子效果的实现方法,减少了代码量和开发投入,更受3D开发初学者的欢迎,直接用query查询API接口,在场景中加入火焰效果。
ThingJS内置一些粒子效果可以直接调用,可点击在线开发选择代码块进行调用。
2、 加载场景
CampusBuilder(又称模模搭)搭建场景完成后,在ThingJS直接加载url进行二次开发。
//加载场景代码 varapp=newTHING.App({ url:'https://www.thingjs.com/static/models/storehouse'//场景地址 });
3、不同粒子特效实现
火焰效果
代码如下:
/** *通过创建粒子实现火焰效果 */ functioncreateFire(){ resetAll(); //创建粒子 varparticle=app.create({ id:'fire01', type:'ParticleSystem', name:'Fire', parent:app.query('car01')[0], url:'https://model.3dmomoda.com/models/19061018snbajhvuzrheq9sbgwdoefuk/0/particles', localPosition:[0,0,0]//设置粒子相对于父物体的位置 }); }
飘雪效果
代码如下:
/** *通过创建粒子实现飘雪效果 */ functioncreateSnow(){ resetAll(); //创建降雪效果 varparticleSnow=app.create({ type:'ParticleSystem', id:'No1234567', name:'Snow', url:'https://model.3dmomoda.com/models/18112014q3t8aunaabahzxbxcochavap/0/particles', position:[0,50,0] }); }
喷水效果
代码如下:
/** *通过创建粒子实现喷水效果 */ functioncreateWater(){ resetAll(); //创建喷水效果 varparticle=app.create({ id:'water01', type:'ParticleSystem', name:'Water', url:'https://model.3dmomoda.com/models/19081611ewlkh7xqy71uzixefob8uq1x/0/particles', position:[0,0,5] }); }
降雨效果
代码如下:
/** *通过创建粒子实现降雨效果 */ functioncreateByParticle(){ resetAll(); //创建粒子 varparticle=app.create({ type:'ParticleSystem', name:'Rain', url:'https://model.3dmomoda.com/models/18112113d4jcj4xcoyxecxehf3zodmvp/0/particles', position:[0,300,0], complete:function(ev){ ev.object.scale=[10,10,10]; } }); //设置粒子最大密度 particle.setGroupAttribute('maxParticleCount',1000); //设置粒子最小密度 particle.setParticleAttribute('particleCount',500); }
雨雪天气,是通过粒子图片渲染来实现的,我们可以通过控制粒子数量的最大密度和最小密度来实现降雨降雪量大小。
清除粒子效果
functionresetAll(){//获取当前已创建的粒子varparticle=app.query('.ParticleSystem');//判断当前有无创建的粒子if(particle){//存在,将已创建的粒子删除particle.destroy();}}
感谢你能够认真阅读完这篇文章,希望小编分享的“ThingJS粒子特效如何实现雨雪效果”这篇文章对大家有帮助,同时也希望大家多多支持恰卡编程网,关注恰卡编程网行业资讯频道,更多相关知识等着你来学习!
推荐阅读
-
在Python中,将K添加到列元组列表中的最小元素
处理数据集涉及识别特定列中的最小值并通过添加常量值(K)来更新它。通过实施优化的解决方案,我们可以有效地执行此操作,这对于数据...
-
使用switch case语句编写的C程序,用于计算几何图形的面积
#includevoidmain(){intfig_code;floatside,base,length,...
-
如何使 C# 代码可重用?
要在C#中使代码可重用,请使用接口。接口定义属性、方法和事件,这些成员是接口的成员。接口只包含成员的声明。派生类负责定义成员。这通...
-
C# 中的覆盖和隐藏有什么区别?
方法隐藏在C#中也称为隐藏。父类的方法可供子类使用,无需在遮蔽中使用override关键字。子类有其自己版本的相同函数。在...
-
在Java中使用示例双倍longValue()函数
Java是一种强大的面向对象语言,可以对各种数据类型进行高度的控制和精确度。其中一种功能是doublelongValue(),...
-
如何在Java中定义JSON字段名称的命名约定?
TheFieldNamingPolicycanbeusedtodefineafewstandardnaming...
-
Servlet中的HttpSession接口
在JavaWeb开发领域,了解HttpSession接口是创建动态和响应式Web应用程序的关键。在本文中,我们将探讨...
-
使用while循环查找自然数之和的Java程序
自然数之和可以使用编程语言中的不同迭代语句来计算。迭代语句是执行一组特定代码行直到循环语句中的条件失败的语句。在本文中,我们将讨论...
-
我们可以将Java数组转换为列表吗?
我们可以使用Arrays.asList()方法轻松地将Java数组转换为List。语法publicstaticLi...
-
Java中如何在不使用任何外部库的情况下读取网页内容?
TheURLclassofthejava.netpackagerepresentsaUniformResour...