【Cesium】Cesium图层请求完成的回调

有一个业务需要用到cesium图层请求完成的回调,翻了好久的文档终于给我找到🌶️。

Cesium.ImageryProvider类的一个属性readyPromise

效果如下:

Cesium图层请求完成的回调

完整代码如下:

html 复制代码
<html lang="en">

<head>
    <meta charset="utf-8">
    <!-- Include the CesiumJS JavaScript and CSS files -->
    <script src="https://cesium.com/downloads/cesiumjs/releases/1.95/Build/Cesium/Cesium.js"></script>
    <link href="https://cesium.com/downloads/cesiumjs/releases/1.95/Build/Cesium/Widgets/widgets.css" rel="stylesheet">
    <style>
        .button {
            width: 80px;
            height: 30px;
            background-color: rgba(92, 38, 116, 0.818);
            cursor: pointer;
            padding: 10px;
            color: #fff;
            text-align: center;
            line-height: 50px;
            border-radius: 10px;
        }
    </style>
</head>

<body>
    <div id="cesiumContainer">
        <span id="addLayer" class="button">添加图层</span>
        <span id="removeLayer" class="button">移除图层</span>
    </div>
    <script type="module">
        Cesium.Ion.defaultAccessToken = ';

        const viewer = new Cesium.Viewer('cesiumContainer', {
        });

        viewer.camera.setView({
            destination: Cesium.Cartesian3.fromDegrees(105, 35, 3456789),
            orientation: {
                heading: Cesium.Math.toRadians(360), //方向
                pitch: Cesium.Math.toRadians(-90), //俯仰角
                roll: Cesium.Math.toRadians(0),
            },
        });

        let layer = null;

        // 添加图层(async/await语法糖)
        async function addLayer() {
            let url = './assets/lyy.jpg';
            let rectangleArr = [100.0, 30.0, 110.0, 40.0]

            const singleTileImageryProvider = new Cesium.SingleTileImageryProvider({
                url: url,
                rectangle: new Cesium.Rectangle(
                    ...rectangleArr.map(item => Cesium.Math.toRadians(item))
                ),
            });

            console.log("开始请求图层");

            try {
                // ⭐关键代码⭐
                const res = await singleTileImageryProvider.readyPromise;
                if (res) {
                    console.log("图层请求成功");
                } else {
                    console.log("图层请求失败");
                }
            } catch (error) {
                console.error("图层请求时发生错误:", error);
            }

            // 将imageryProvider添加到地图的图层列表中,使得图层可以在地图上显示
            return viewer.imageryLayers.addImageryProvider(
                singleTileImageryProvider
            );
        }

        /*
        // 添加图层(Promise)
        function addLayer() {
            return new Promise((resolve, reject) => {
                let url = './assets/lyy.jpg';
                let rectangleArr = [100.0, 30.0, 110.0, 40.0];

                const singleTileImageryProvider = new Cesium.SingleTileImageryProvider({
                    url: url,
                    rectangle: new Cesium.Rectangle(
                        ...rectangleArr.map(item => Cesium.Math.toRadians(item))
                    ),
                });

                console.log("开始请求图层");

                singleTileImageryProvider.readyPromise.then(res => {
                    if (res) {
                        console.log("图层请求成功");
                        resolve(viewer.imageryLayers.addImageryProvider(singleTileImageryProvider));
                    } else {
                        console.log("图层请求失败");
                        reject(new Error("图层请求失败"));
                    }
                }).catch(error => {
                    console.error("图层请求时发生错误:", error);
                    reject(error);
                });
            });
        }
        */

        // 移除图层
        function removeLayer() {
            viewer.imageryLayers.remove(layer)
        }

        // 给按钮添加点击事件
        document.getElementById("addLayer").onclick = async () => {
            layer = await addLayer()
        };
        document.getElementById("removeLayer").onclick = () => {
            removeLayer()
        };

    </script>
    </div>
</body>

</html>
相关推荐
hh随便起个名6 小时前
力扣二叉树的三种遍历
javascript·数据结构·算法·leetcode
小浣熊熊熊熊熊熊熊丶6 小时前
《Effective Java》第25条:限制源文件为单个顶级类
java·开发语言·effective java
啃火龙果的兔子6 小时前
JDK 安装配置
java·开发语言
星哥说事6 小时前
应用程序监控:Java 与 Web 应用的实践
java·开发语言
我是小路路呀7 小时前
element级联选择器:已选中一个二级节点,随后又点击了一个一级节点(仅浏览,未确认选择),此时下拉框失去焦点并关闭
javascript·vue.js·elementui
程序员爱钓鱼7 小时前
Node.js 编程实战:文件读写操作
前端·后端·node.js
PineappleCoder7 小时前
工程化必备!SVG 雪碧图的最佳实践:ID 引用 + 缓存友好,无需手动算坐标
前端·性能优化
等....7 小时前
Miniconda使用
开发语言·python
zfj3217 小时前
go为什么设计成源码依赖,而不是二进制依赖
开发语言·后端·golang
醇氧7 小时前
org.jetbrains.annotations的@Nullable 学习
java·开发语言·学习·intellij-idea