JavaScript代码

  1. viewer = new Cesium.Viewer('cesiumContainer');
  2. var gravityVector = new Cesium.Cartesian3();
  3. var gravity = -(9.8 * 9.8);
  4. function applyGravity(p, dt) {
  5. // Compute a local up vector for each particle in geocentric space.
  6. var position = p.position;
  7. Cesium.Cartesian3.normalize(position, gravityVector);
  8. Cesium.Cartesian3.multiplyByScalar(gravityVector, gravity * dt, gravityVector);
  9. p.velocity = Cesium.Cartesian3.add(p.velocity, gravityVector, p.velocity);
  10. }
  11. var entity = viewer.entities.add({
  12. model : {
  13. uri : '../Apps/SampleData/models/CesiumMilkTruck/CesiumMilkTruck.glb',
  14. minimumPixelSize : 64
  15. },
  16. position : Cesium.Cartesian3.fromDegrees(-75.15787310614596, 39.97862668312678)
  17. });
  18. viewer.trackedEntity = entity;
  19. function computeModelMatrix(entity, time) {
  20. var position = Cesium.Property.getValueOrUndefined(entity.position, time, new Cesium.Cartesian3());
  21. if (!Cesium.defined(position)) {
  22. return undefined;
  23. }
  24. var orientation = Cesium.Property.getValueOrUndefined(entity.orientation, time, new Cesium.Quaternion());
  25. if (!Cesium.defined(orientation)) {
  26. var modelMatrix = Cesium.Transforms.eastNorthUpToFixedFrame(position, undefined, new Cesium.Matrix4());
  27. } else {
  28. modelMatrix = Cesium.Matrix4.fromRotationTranslation(Cesium.Matrix3.fromQuaternion(orientation, new Cesium.Matrix3()), position, new Cesium.Matrix4());
  29. }
  30. return modelMatrix;
  31. }
  32. function computeEmitterModelMatrix() {
  33. hpr = Cesium.HeadingPitchRoll.fromDegrees(0.0, 0.0, 0.0, new Cesium.HeadingPitchRoll());
  34. var trs = new Cesium.TranslationRotationScale();
  35. trs.translation = Cesium.Cartesian3.fromElements(-4, 0.0, 1.4, new Cesium.Cartesian3());
  36. trs.rotation = Cesium.Quaternion.fromHeadingPitchRoll(hpr, new Cesium.Quaternion());
  37. return Cesium.Matrix4.fromTranslationRotationScale(trs, new Cesium.Matrix4());
  38. }
  39. var particleSystem = viewer.scene.primitives.add(new Cesium.ParticleSystem({
  40. image : '../Apps/SampleData/smoke.png',
  41. startColor : Cesium.Color.LIGHTSEAGREEN.withAlpha(0.7),
  42. endColor : Cesium.Color.WHITE.withAlpha(0.0),
  43. imageSize : new Cesium.Cartesian2(25, 25),
  44. startScale : 1.0,
  45. endScale : 4.0,
  46. particleLife : 1.0,
  47. speed : 5.0,
  48. minimumSpeed: 1.0,
  49. maximumSpeed: 10.0,
  50. emitter : new Cesium.CircleEmitter(0.5),
  51. emissionRate : 5.0,
  52. modelMatrix : computeModelMatrix(entity, Cesium.JulianDate.now()),
  53. lifetime : 16.0,
  54. bursts : [
  55. new Cesium.ParticleBurst({time : 5.0, minimum : 300, maximum : 500}),
  56. new Cesium.ParticleBurst({time : 10.0, minimum : 50, maximum : 100}),
  57. new Cesium.ParticleBurst({time : 15.0, minimum : 200, maximum : 300})
  58. ],
  59. loop: false,
  60. minimumImageSize : new Cesium.Cartesian2(30.0, 30.0),
  61. maximumImageSize : new Cesium.Cartesian2(60.0, 60.0),
  62. startScale: 1.0,
  63. endScale: 4.0,
  64. updateCallback : applyGravity,
  65. forces: applyGravity,
  66. emitterModelMatrix : computeEmitterModelMatrix(),
  67. }));

Cesium基础知识-粒子应用-汽车冒烟相关推荐

  1. Cesium 基础知识和文档记录

    Cesium开发基础 CesiumLab--系统重启 目录 • 一,关于我们 • 二,Cesium介绍 • 三,快速入门 • 四,常见问题 • 五,学习方法 一,关于我们 --系统重启 • 2008年 ...

  2. Cesium基础知识-添加天空盒

    var viewer = new Cesium.Viewer('cesiumContainer'); // 加载图层 viewer.imageryLayers.addImageryProvider( ...

  3. Cesium基础知识-加载json数据

    viewer = new Cesium.Viewer('cesiumContainer'); //加载json数据生成线 function CreateLineFromJson(params) { / ...

  4. Cesium基础知识-创建模型,动画

    viewer = new Cesium.Viewer('cesiumContainer' /* ,{ shouldAnimate : true }*/ ); //创建3d模型 function Cre ...

  5. Cesium基础知识-创建图层

    //创建一个图层 function CreateLayer() { var viewer = new Cesium.Viewer('cesiumContainer', { imageryProvide ...

  6. 关于电脑的基础知识_改装小白必看的汽车音响改装基础知识!

    汽车作为一个越来越普及的交通工具,已经占据了人类的更大时间和空间,成了不可缺少的生活物品,而原车汽车音响作为这个驾驶工具里的唯一具有娱乐功能的零配件有时候也是在满足不了一些对音乐有高水平要求的驾驶者的 ...

  7. 阡陌路-车行天下之汽车基础知识

    阡陌路-车行天下之汽车基础知识 (2013-06-29 10:37:23)转载▼ 标签: 汽车 基础 分类: 指南区 汽车基础知识 1.什么是ABS ABS是Anti-LockBrakeSystem的 ...

  8. geant4构造粒子_Geant4基础知识

    可复制.编制,期待你的好评与关注! Geant4 基础知识 G4 模拟粒子过程 : 建立一次模拟,在 G4 中称为一次 Run : Run 建立后,需要对几何结构.物理过 程进行初始化: 初始化完成后 ...

  9. 汽车数字钥匙设计02--UWB基础知识

    数字钥匙实现需包含NFC,BLE,UWB等技术,其中UWB主要用于实现精准定位,以弥补BLE定位不准确的情况,另外UWB技术可以实现其他扩展功能,如儿童存在检测CPD,脚踢检测功能等. 1.什么是UW ...

  10. 【二代示波器教程】第1章 示波器基础知识

    教程完整下载地址:http://forum.armfly.com/forum.php?mod=viewthread&tid=45785 第1章 示波器基础知识 本章的内容整理自网络,主要讲解示 ...

最新文章

  1. 《Effective C++》第8章 定制new和delete-读书笔记
  2. NHibernate.ADOException: cannot open connection
  3. Ubuntu18.04下安装RRStudio
  4. boost::callable_traits的remove_member_const_t的测试程序
  5. 插件修复数据_APP 热修复都懂了,你会 SDK 热修复吗?最全方案在这里!
  6. 【Python CheckiO 题解】Easy Unpack
  7. 【牛客 - 301哈尔滨理工大学软件与微电子学院第八届程序设计竞赛同步赛(高年级 )】小乐乐和25(模拟,技巧)
  8. Python3.x中set()集合的使用方法
  9. HDU.1005 Number Sequence
  10. 推荐Python互动艺术在线编辑器(腾讯扣叮)
  11. main函数默认参数argc和argv的详解
  12. lwip协议栈实现服务器端主动发送,lwip协议栈源码详解说明 - 全文
  13. 构建会员运营管理系统 帮助零售企业数字化转型
  14. 微信开放平台修改应用名称
  15. 三套方案7日打造骨感美人
  16. 微信小程序-更换头像
  17. 国内哪家云服务器最便宜?国内主流三大云厂商的价格差异
  18. linux命令后台执行方式
  19. 世界上最难的视觉图_看看世界上驾照最难考的国家,你还会觉得考驾照难吗?...
  20. 英特尔暂缓扩建大连芯片厂 或吞并全球最大芯片生厂商之一美光科技

热门文章

  1. 微信小程序里面嵌套的h5使用微信sdk配置踩坑
  2. 转载: WebKit介绍及总结(一)
  3. html静态测试网页,Html静态网页测试-20210531213110.pptx-原创力文档
  4. 深度学习中对神经网络的理解
  5. 【数据压缩】作业1:分析浊音清音爆破音的时域和频域特性以及RGB熵的计算
  6. 335游戏C/S登录器,补丁更新、自动登录、信息手册
  7. 如何建立一个网站(我的5年经验谈)
  8. 一个将Google Maps API与ArcGIS JavaScript API for GMaps结合的例子
  9. gmap 支持python吗_Python:地图上的标记标签使用gmap.marker_层使用hover_-tex选项不工作...
  10. linux 安装 blas,Linux下Linpack安装过程