Supermap iClient Webgl 粒子特效案例-消防场景

news2025/1/3 15:34:00

作者:Lzzzz

前言

WebGL 粒子特效的应用场景非常广泛,几乎可以在任何需要丰富视觉效果或动态表现的地方看到其身影。通过灵活运用颗粒系统,开发者可以创造出引人入胜的用户体验和视觉表现。 

一、效果展示

二、实现步骤 

1,构建粒子参数json,可以直接复制使用;
{
    "name": "smokeDense",
    "id": "smokeDense",
    "capacity": 3000,
    "disposeOnStop": false,
    "manualEmitCount": -1,
    "emitter": [
        0,
        20,
        0
    ],
    "particleEmitterType": {
        "type": "ConeParticleEmitter",
        "radius": 1.0,
        "angle": 1.05,
        "directionRandomizer": 0,
        "radiusRange": 0,
        "heightRange": 0,
        "emitFromSpawnPointOnly": true
    },
    "texture": {
        "tags": null,
        "url": "./data/particle/texture/smoke2.png",
        "uOffset": 0,
        "vOffset": 0,
        "uScale": 1,
        "vScale": 1,
        "uAng": 0,
        "vAng": 0,
        "wAng": 0,
        "uRotationCenter": 0,
        "vRotationCenter": 0,
        "wRotationCenter": 0,
        "homogeneousRotationInUVTransform": false,
        "isBlocking": true,
        "name": "rain/smoke.png",
        "hasAlpha": false,
        "getAlphaFromRGB": false,
        "level": 1,
        "coordinatesIndex": 0,
        "coordinatesMode": 0,
        "wrapU": 1,
        "wrapV": 1,
        "wrapR": 1,
        "anisotropicFilteringLevel": 4,
        "isCube": false,
        "is3D": false,
        "is2DArray": false,
        "gammaSpace": true,
        "invertZ": false,
        "lodLevelInAlpha": false,
        "lodGenerationOffset": 0,
        "lodGenerationScale": 0,
        "linearSpecularLOD": false,
        "isRenderTarget": false,
        "animations": [],
        "invertY": true,
        "samplingMode": 3,
        "_useSRGBBuffer": false
    },
    "isLocal": false,
    "animations": [],
    "startDelay": 0,
    "renderingGroupId": 0,
    "isBillboardBased": true,
    "billboardMode": 2,
    "minAngularSpeed": 0,
    "maxAngularSpeed": 0,
    "minSize": 0.8,
    "maxSize": 1,
    "minScaleX": 1,
    "maxScaleX": 1,
    "minScaleY": 1,
    "maxScaleY": 1,
    "minEmitPower": 0.2,
    "maxEmitPower": 0.4,
    "minLifeTime": 6,
    "maxLifeTime": 8,
    "emitRate": 500,
    "gravity": [
        0,
        0.3,
        0
    ],
    "noiseStrength": [
        10,
        10,
        10
    ],
    "color1": [
        1,
        1,
        1,
        1
    ],
    "color2": [
        1,
        1,
        1,
        1
    ],
    "colorDead": [
        1,
        1,
        1,
        0
    ],
    "updateSpeed": 0.034,
    "targetStopDuration": 0,
    "blendMode": 1,
    "preWarmCycles": 50,
    "preWarmStepOffset": 1,
    "minInitialRotation": 0,
    "maxInitialRotation": 0,
    "startSpriteCellID": 0,
    "spriteCellLoop": true,
    "endSpriteCellID": 3,
    "spriteCellChangeSpeed": 0,
    "spriteCellWidth": 128,
    "spriteCellHeight": 512,
    "spriteRandomStartCell": true,
    "isAnimationSheetEnabled": true,
    "colorGradients": [
        {
            "gradient": 0,
            "color1": [
                1,
                1,
                1,
                0.3
            ],
            "color2": [
                1,
                1,
                1,
                0.3
            ]
        },
        {
            "gradient": 1,
            "color1": [
                1,
                1,
                1,
                0.3
            ],
            "color2": [
                1,
                1,
                1,
                0.3
            ]
        }
    ],
    "textureMask": [
        1,
        1,
        1,
        1
    ],
    "customShader": null,
    "preventAutoStart": true
}
2,动态修改粒子对象,这里以火焰粒子为例
    function initFire(SuperMap3D, scene) {
        var multiFireUrl = './data/particle/Fire.json';

        let modelMatrix = new SuperMap3D.Matrix4();
        let posFire = SuperMap3D.Cartesian3.fromDegrees(116.458832, 39.907549, 8);
        SuperMap3D.Transforms.eastNorthUpToFixedFrame(posFire, undefined, modelMatrix);
        loadParticleFile(multiFireUrl);

        // 加载粒子文件
        function loadParticleFile(url) {
            SuperMap3D.ParticleHelper.fromJsonUrl(url, scene).then(function(particleSystem){
                fireParticleSystem = particleSystem;
                //发射速度(每帧发射的粒子数)
                particleSystem.emitRate=5;
                //最小发射速度
                particleSystem.minEmitPower=2;
                //最大发射速度
                particleSystem.maxEmitPower=3;
                //最小生命周期
                particleSystem.minLifeTime=3;
                //最大生命周期
                particleSystem.maxLifeTime=4;
                //最小粒子大小
                particleSystem.minSize=2;
                //最大粒子大小
                particleSystem.maxSize=4;
                particleSystem.updateSpeed=0.01;
                particleSystem.modelMatrix = modelMatrix;
                particleSystem.start();
            });
        }
    }

同时,也可以动态修改粒子发射器

//修改粒子发射器为点发射器
var direction1 = new SuperMap3D.Cartesian3(0, 1, 1);
var direction2 = new SuperMap3D.Cartesian3(0, 1, 1);
waterParticleSystem.createPointEmitter(direction1, direction2);

3,水粒子特效加载完成后,逐渐减弱火粒子和烟粒子数量和发射速度,直至关闭
    async function extinguish() {
        while(smokeParticleSystem.emitRate >0){
            smokeParticleSystem.emitRate -= 1;
            fireParticleSystem.emitRate = smokeParticleSystem.emitRate/100;
            fireParticleSystem.minEmitPower=smokeParticleSystem.emitRate/250;
            fireParticleSystem.maxEmitPower=smokeParticleSystem.emitRate/200;
            await sleep(20);
            if(smokeParticleSystem.emitRate < 200 && fireParticleSystem.isAlive()){
                fireParticleSystem.stop(true);
            }
        }
        smokeParticleSystem.stop();
        fireParticleSystem.stop();
        await sleep(3000);
        waterParticleSystem.stop();
    }

    function sleep(ms) {
        return new Promise(resolve => setTimeout(resolve, ms));
    }

三、源码下载

https://gitee.com/liuyabo/particle

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2268679.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

关于无线AP信道调整的优化(锐捷)

目录 一、信道优化的基本原则二、2.4G频段信道优化三、5G频段信道优化四、信道优化代码具体示例五、其他优化措施 一、信道优化的基本原则 信道优化旨在减少信道间的干扰&#xff0c;提高网络覆盖范围和信号质量。基本原则包括&#xff1a; 1. 选择合适的信道&#xff1a;根据…

Rocky9网络基本连接配置

1.修改主机名称 终端模式下&#xff1a; hostnamectl set-hostname server2执行过程中可能要输入密码 hostnamectl命令查看主机信息&#xff0c;可以查看到主机信息已经发生修改&#xff0c;之后reboot重启主机。 2.关闭防火墙 systemctl stop firewalld systemctl disable fi…

一款汽车连接器(HSD(4+2))信号完整性仿真

下面是一款汽车连接器HSD(42) 的3D外形&#xff1a; 其爆炸图如下&#xff1a; 下面是Rosenboger同款产品的2D图&#xff1a; 其信号完整性参数如下&#xff1a; 下面介绍一下如何给上面的3D模型做信号完整性仿真。 在介绍仿真前先介绍一下上面的一些参数&#xff1a;上面的参数…

动手做计算机网络仿真实验入门学习

打开软件 work1 添加串行接口模块&#xff0c;先关电源&#xff0c;添加之后再开电源 自动选择连接 所有传输介质 自动连接 串行线 绿色是通的&#xff0c;红色是不通的。 显示接口。se是serial串行的简写。 Fa是fast ethernet的简写。 为计算机配置ip地址&#xff1a; 为服…

在React中引入tailwind css(图文详解)

Tailwind CSS 是一个功能强大的 CSS 框架&#xff0c;旨在使开发者能够以更高效、灵活的方式创建现代、响应式的网页。与传统的 CSS 框架&#xff08;如 Bootstrap 或 Foundation&#xff09;不同&#xff0c;Tailwind 采取了“实用类”&#xff08;Utility-First&#xff09;的…

考公怎么安排学习顺序?

考公的学习顺序安排至关重要&#xff0c;合理规划能让备考事半功倍。以下是结合 “稳啦” 小程序的推荐学习顺序。 1. 初步了解考情&#xff08;使用稳啦的各省考情模块&#xff09; 在备考初期&#xff0c;首先要做的就是全面了解公务员考试的基本情况。通过稳啦的各省考情模…

C 语言:printf 函数详解

目录 引言 一、printf 函数的基本介绍 二、printf 的格式化输出 三、printf 的转义序列 四、printf 的返回值 五、printf 的高级用法 六、printf 的注意事项 七、总结 引言 在 C 语言的编程世界里&#xff0c;printf函数无疑是一个极为强大且常用的工具。它不仅能够输出…

计算机网络-L2TP VPN基础实验配置

一、概述 上次大概了解了L2TP的基本原理和使用场景&#xff0c;今天来模拟一个小实验&#xff0c;使用Ensp的网卡桥接到本地电脑试下L2TP拨号&#xff0c;今天主要使用标准的L2TP&#xff0c;其实在这个基础上可以加上IPSec进行加密&#xff0c;提高安全性。 网络拓扑 拓扑说明…

Postman[7] 内置动态参数及自定义的动态参数

postman 内置动态参数和自定义的动态参数 1.内置动态参数 格式&#xff1a;{{$参数名}} 1.1时间戳 {{$timestamp}} //生成当前时间的时间戳 1.2随机整数 {{$randomint}} //生成0-1000之间的随机数 1.3GUID字符串 {{$guid}} //生成随机GUID字符串 2.自定义动态参数 格式…

uniapp-vue3(下)

关联链接&#xff1a;uniapp-vue3&#xff08;上&#xff09; 文章目录 七、咸虾米壁纸项目实战7.1.咸虾米壁纸项目概述7.2.项目初始化公共目录和设计稿尺寸测量工具7.3.banner海报swiper轮播器7.4.使用swiper的纵向轮播做公告区域7.5.每日推荐滑动scroll-view布局7.6.组件具名…

STM32中断详解

STM32中断详解 NVIC 中断系统中断向量表相关寄存器中断优先级中断配置 外部中断实验EXTI框图外部中断/事件线映射中断步骤初始化代码实现 定时器中断通用定时器相关功能标号1&#xff1a;时钟源标号 2&#xff1a;控制器标号 3&#xff1a;时基单元 代码实现 NVIC 中断系统 STM…

小程序中引入echarts(保姆级教程)

hello hello~ &#xff0c;这里是 code袁~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f981;作者简介&#xff1a;一名喜欢分享和记录学习的在校大学生…

Cypress测试框架详解:轻松实现端到端自动化测试

端到端自动化测试工具市场中&#xff0c;Cypress正以其易用性和强大功能&#xff0c;迅速成为开发者和测试人员的首选工具之一。无论是前端开发还是测试&#xff0c;Cypress都能在性能和效率上脱颖而出。 那么&#xff0c;Cypress具体能为端到端测试带来哪些便利&#xff1f;它…

Nginx - 整合lua 实现对POST请求的参数拦截校验(不使用Openresty)

文章目录 概述步骤 1: 安装 Nginx 和 Lua 模块步骤 2: 创建 Lua 脚本用于参数校验步骤 3: 配置 Nginx 使用 Lua 脚本写法二&#xff1a; 状态码写法三 &#xff1a; 返回自定义JSON复杂的正则校验 步骤 4: 测试和验证ngx.HTTP_* 枚举值 概述 一个不使用 OpenResty 的 Nginx 集…

在 React 项目中安装和配置 Three.js

React 与 Three.js 的结合 &#xff1a;通过 React 管理组件化结构和应用逻辑&#xff0c;利用 Three.js 实现 3D 图形的渲染与交互。使用这种方法&#xff0c;我们可以在保持代码清晰和结构化的同时&#xff0c;实现令人惊叹的 3D 效果。 在本文中&#xff0c;我们将以一个简…

logstash 对配置文件conf敏感信息加密处理

logstash的配置文件conf经常会涉及敏感信息&#xff0c;比如ES&#xff0c;数据库的账户密码等&#xff0c;以下使用logstash导入ORACLE为例子&#xff0c;加密隐藏ORACLE的密码。 1.先创建keystore&#xff0c;可以不设置keystore密码,直接选择y 在logstash目录下&#xff0…

为什么MoE推理效率更高:精简FFN

MoE全称是“混合专家”,它由多个专家网络和一个门控网络组成……整个MoE完全复用了Transformer的结构,只是将其中的FFN层替换成了MoE层。MoE层里的门控网络其实就是个专家分类器,每次根据输入Token生成专家的概率分布,然后选择排序靠前的K个专家进行Token处理,最后再将K个…

课设CLion连接Ubuntu14makeQt项目出错解决汇总

在这之前需要注意以下几点&#xff1a; 1、需要 确保CLion能连接Ubuntu14 2、cmakelist.txt文件配置 3、知道部署路径&#xff1a; 问题一&#xff1a;/usr/bin/ld: cannot open output file GreedySnake: Is a directory 否则就会出现make以后应该生成一个可执行文件&…

第T4周:TensorFlow实现猴痘识别(Tensorboard的使用)

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 目标&#xff1a; 1、学习tensorboard的使用 具体实现&#xff1a; &#xff08;一&#xff09;环境&#xff1a; 语言环境&#xff1a;Python 3.10 编 译 器…

LeetCode:513.找二叉树左下角的

跟着carl学算法&#xff0c;本系列博客仅做个人记录&#xff0c;建议大家都去看carl本人的博客&#xff0c;写的真的很好的&#xff01; 代码随想录 LeetCode&#xff1a;513.找二叉树左下角的 给定一个二叉树的 根节点 root&#xff0c;请找出该二叉树的 最底层 最左边 节点的…