【WebGis开发 - Cesium】如何确保Cesium场景加载完毕

devtools/2024/10/9 13:24:53/

目录

  • 引言
  • 一、监听场景加载进度
    • 1. 基础代码
    • 2. 加工代码
  • 二、进一步封装代码
    • 1. 已知存在的弊端
    • 2. 封装hooks函数
  • 三、使用hooks方法
    • 1. 先看下效果
    • 2. 如何使用该hooks方法
  • 三、总结

引言

本篇为Cesium开发的一些小技巧。

判断Cesium场景是否加载完毕这件事是非常有意义的。

  • 加载场景本身是个异步过程,然而我们经常会遇到一些业务场景是需要基于某一个模型加载完毕后再进行初始化操作,然后对模型进行操作。
  • 包含三维场景的页面和日常浏览的网页在加载效率上是不同的,人们往往对包含三维场景页面加载时长的容忍度会比较高。我们需要给出一个直观的加载过程用于安慰用户耐心等待较长的加载过程。
  • Cesium的模型加载策略是由粗到细分片加载,我们需要用户可以直接看到一个已经加载完毕的场景,而不是一点点细化的过程。

一、监听场景加载进度

这个功能要用到 CeiusmEventHelper 子类,监听 tileLoadProgressEvent 方法

1. 基础代码

javascript">  const helper = new Cesium.EventHelper();helper.add(viewer.scene.globe.tileLoadProgressEvent, (e) => {console.log(e);});

解释下代码,这里初始化了一个EventHelper实例,并监听tileLoadProgressEvent方法,他会监听每帧场景中切片加载队列的长度。回调函数入参 e 为int类型数字,代表当前场景中剩余未加载的切片数量。

2. 加工代码

javascript">  const helper = new Cesium.EventHelper();let maxTile = 0;let isLoaded = false;helper.add(viewer.scene.globe.tileLoadProgressEvent, (e) => {maxTile = Math.max(maxTile, e);const progress = Math.floor(((maxTile - e) / maxTile) * 100);isLoaded = viewer.scene.globe.tilesLoaded;console.log("progress", progress);console.log("tilesLoaded", isLoaded);

解释下代码,这里在基础代码上做了一点点加工,在外部设置个最大切片数量的变量,使用Math.max赋予最大的切片数量值,通过最大值和当前值的计算可得一个百分比进度值。此外 viewer.scene.globe.tilesLoaded 是一个Boolean值,更直观的表达了切片是否加载完成。此时我们得到了加载进度和加载完成的标志。


二、进一步封装代码

1. 已知存在的弊端

我们已经知道了如何监听场景切片的加载进度,但是它会在每一次拖动地球转动时同样监听到这个微调的过程。我们希望只有在页面初始化时、加载模型时调用一次监听事件提供进度提示,其他时候不监听。

2. 封装hooks函数

想象一下函数的使用场景,我们需要监听场景中切片的进度和完成标志,我们还需要它只监听一次就清理监听事件,额外提供销毁方法不要继续占用资源,最后需要它能够实时输出进度值和加载完成标志。

利用vue3的响应式变量方法ref,将progress 、isLoaded 包装为响应式变量。

javascript">import { ref } from "vue";export const useTileloadProgress = () => {const helper = new Cesium.EventHelper();let isLoaded = ref(false);let progress = ref(0);/*** @description: 触发监听事件* @return {*}*/const _onLoad = () => {let maxTile = 0;helper.add(viewer.scene.globe.tileLoadProgressEvent, (e) => {maxTile = Math.max(maxTile, e);progress.value = Math.floor(((maxTile - e) / maxTile) * 100);isLoaded.value = viewer.scene.globe.tilesLoaded;//   当一次加载完成后移除监听事件if (isLoaded.value) {_onRemove();}});};/*** @description: 移除监听事件* @return {*}*/const _onRemove = () => {helper.removeAll();};/*** @description: 移除监听事件,清理EventHelper实例,初始化变量值。* @return {*}*/const _onDestroy = () => {remove();helper = null;isLoaded.value = false;progress.value = 0;};return {progress,isLoaded,_onLoad,_onRemove,_onDestroy,};
};

三、使用hooks方法

1. 先看下效果

基础场景加载有点快,加载模型或者地图时,效果应该更明显些。
在这里插入图片描述

2. 如何使用该hooks方法

初始化场景请参考:【WebGis开发 - Cesium】三维可视化项目教程—初始化场景

在获取了progress和isLoaded两个变量后,可以进一步使用项目UI框架做提示,或者美化一个进度加载的界面。自由发挥

javascript"><script setup>
import { onMounted } from "vue";
import { initCesiumMap } from "@/utils/cesium/index.js";
import { useTileloadProgress } from "@/hooks/useTileloadProgress.js";
const { progress, isLoaded, _onLoad, _onRemove, _onDestroy } =useTileloadProgress();
onMounted(() => {
// 初始化地球场景initCesiumMap();
// 监听加载进度_onLoad();
});
</script>

三、总结

本篇主要介绍了如何利用 EventHelpertileLoadProgressEvent 来判断一个Cesium场景是否加载完成。解决了Cesium场景无法感知加载进度的问题,给业务场景开发提供了明确完成标志。

利用vue3.0的新特性,将以上方法封装为hooks函数,更方便业务测使用。

再接再厉~


http://www.ppmy.cn/devtools/123396.html

相关文章

【瑞昱RTL8763E】音频

1 音乐播放控制 1.1 播放列表更新 文件系统在sd卡中保存header.bin及name.bin两份文件用于歌曲名称的存储。为方便应用层进行歌曲显示及列表管理&#xff0c;可将这两个bin文件信息读取并保存到nor flash中。需要播放指定名称的歌曲时&#xff0c;将对于歌曲名称传递给文件系…

甲虫身体图像分割系统源码&数据集分享

甲虫身体图像分割系统源码&#xff06;数据集分享 [yolov8-seg-EfficientRepBiPAN&#xff06;yolov8-seg-C2f-FocusedLinearAttention等50全套改进创新点发刊_一键训练教程_Web前端展示] 1.研究背景与意义 项目参考ILSVRC ImageNet Large Scale Visual Recognition Challen…

Redis中GEO数据结构实现附近商户搜索

Redis的版本必须是6.2以上 在测试类中将数据导入Redis Testvoid loadShopData(){//1.查询店铺信息List<Shop> list shopService.list();//2.把店铺分组&#xff0c;按照typeId分组&#xff0c;typeId一致的放到一个集合Map<Long, List<Shop>> map list.s…

高等数学 4.2 换元积分法(二)第二类换元法

第二类换元法是&#xff1a;适当选择变量代换 x ψ ( t ) x \psi(t) xψ(t) &#xff0c;将积分 ∫ f ( x ) d x \int f(x) \mathrm{d}x ∫f(x)dx 化为积分 ∫ f [ ψ ( t ) ] ψ ′ ( t ) d t \int f[\psi(t)]\psi(t)\mathrm{d}t ∫f[ψ(t)]ψ′(t)dt .这是另一种形式的变…

pod管理及优化

一、k8s中的资源 1、资源介绍 [rootk8s-master ~]# kubectl --namespace timinglee get po No resources found in timinglee namespace. [rootk8s-master ~]# kubectl run testpod --image timinglee/nginx [rootk8s-master ~]# kubectl get pods -w NAME READY STATU…

2410git,git合并pr

git remote add dy https://github.com/dlang/dmd //添加远程,可以多添加几个,作为基础. git remote update //远程更新,全部拉进本地 git remote -v git branch -r //查看 git checkout -b pt dd/private-this //从某个分支拉到本地为pt分支 git checkout master //切换到主分…

Spring Boot ⽇志

目录 1.⽇志使⽤ 2.⽇志级别 3.⽇志配置 3.1配置⽇志级别 3.2⽇志持久化 3.3配置⽇志⽂件分割 4.更简单的⽇志输出 1.⽇志使⽤ 在使用之前我们先来了解一下为什么要使用&#xff1f; ⽇志的⽤途 1.系统监控 我们可以通过⽇志记录这个系统的运⾏状态&#xff0c;对数…

大数据新视界 --大数据大厂之 Presto 性能优化秘籍:加速大数据交互式查询

&#x1f496;&#x1f496;&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎你们来到 青云交的博客&#xff01;能与你们在此邂逅&#xff0c;我满心欢喜&#xff0c;深感无比荣幸。在这个瞬息万变的时代&#xff0c;我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…