JavaScript实现加载导出CZML文件详解

 更新时间:2025年02月14日 09:57:36   作者:还是大剑师兰特  
CZML是一种基于 JSON 的文件格式,用于描述地理空间数据和时间动态场景,这篇文章为大家详细介绍了如何使用JavaScript实现CZML文件的加载与导出,需要的可以了解下

CZML 格式详解

1. 什么是 CZML

CZML(Cesium Zipped Markup Language)是一种基于 JSON 的文件格式,用于描述地理空间数据和时间动态场景。它专为 Cesium 平台设计,支持复杂的几何、属性和时间序列数据的表达。

2. CZML 文件结构

CZML 文件是一个 JSON 数组,其中每个元素称为一个“packet”(包)。每个 packet 包含一组属性,用于描述特定的对象或场景。

基本结构:

[
  {
    "id": "document", // 必须的根节点,标识整个 CZML 文件
    "version": "1.0"  // CZML 版本号
  },
  {
    "id": "object1",  // 对象的唯一标识符
    "position": {     // 定义对象的位置
      "cartesian": [0, 0, 0] // 使用笛卡尔坐标表示位置
    },
    "point": {        // 定义点的样式
      "pixelSize": 10 // 点的大小(像素)
    }
  }
]

JavaScript 加载 CZML 文件示例

加载 CZML 文件

使用 Cesium 提供的 Cesium.CzmlDataSource 类来加载 CZML 文件。

代码示例:

// 初始化 Cesium Viewer
var viewer = new Cesium.Viewer('cesiumContainer');

// 创建 CZML 数据源
var dataSourcePromise = Cesium.CzmlDataSource.load('path/to/your.czml');

// 将 CZML 数据添加到 Viewer 中
dataSourcePromise.then(function(dataSource) {
    viewer.dataSources.add(dataSource);
    // 自动调整相机视角以聚焦于 CZML 数据
    viewer.zoomTo(dataSource);
}).catch(function(error) {
    console.log('Error loading CZML file: ' + error);
});

说明:

  • Cesium.CzmlDataSource.load 方法用于加载 CZML 文件。
  • viewer.dataSources.add 方法将 CZML 数据源添加到 Cesium 场景中。
  • viewer.zoomTo 方法自动调整相机视角以聚焦于加载的数据。

JavaScript 导出 CZML 文件示例

创建 CZML 数据

可以通过 JavaScript 动态生成 CZML 数据。

代码示例:

// 创建一个 CZML 数据数组
var czml = [
    {
        "id": "document",
        "version": "1.0"
    },
    {
        "id": "point1",
        "name": "Example Point",
        "description": "This is an example point.",
        "position": {
            "cartesian": [0, 0, 0] // 地球中心点
        },
        "point": {
            "pixelSize": 10,
            "color": {
                "rgba": [255, 0, 0, 255] // 红色
            }
        }
    }
];

// 将 CZML 数据转换为 JSON 字符串
var czmlString = JSON.stringify(czml, null, 2);

// 创建一个下载链接并触发下载
function downloadCZML(data, filename) {
    var blob = new Blob([data], { type: 'application/json' });
    var url = URL.createObjectURL(blob);
    var a = document.createElement('a');
    a.href = url;
    a.download = filename;
    document.body.appendChild(a);
    a.click();
    a.remove();
}

// 调用下载函数
downloadCZML(czmlString, 'example.czml');

说明:

  • czml 是一个包含 CZML 数据的数组。
  • JSON.stringify 方法将 CZML 数据转换为 JSON 字符串。
  • downloadCZML 函数创建一个临时的下载链接,并触发浏览器下载 CZML 文件。

完整示例:加载和导出 CZML 文件

以下是一个完整的示例,展示如何加载和导出 CZML 文件。

HTML 部分:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Cesium CZML Example</title>
    <script src="https://cesium.com/downloads/cesiumjs/releases/1.94/Build/Cesium/Cesium.js"></script>
    <link href="https://cesium.com/downloads/cesiumjs/releases/1.94/Build/Cesium/Widgets/widgets.css" rel="stylesheet">
    <style>
        #cesiumContainer {
            width: 100%;
            height: 100vh;
            margin: 0;
            padding: 0;
            overflow: hidden;
        }
    </style>
</head>
<body>
    <div id="cesiumContainer"></div>
    <button onclick="exportCZML()">Export CZML</button>

    <script src="app.js"></script>
</body>
</html>

JavaScript 部分(app.js):

// 初始化 Cesium Viewer
var viewer = new Cesium.Viewer('cesiumContainer');

// 加载 CZML 文件
var dataSourcePromise = Cesium.CzmlDataSource.load('path/to/your.czml');
dataSourcePromise.then(function(dataSource) {
    viewer.dataSources.add(dataSource);
    viewer.zoomTo(dataSource);
}).catch(function(error) {
    console.log('Error loading CZML file: ' + error);
});

// 导出 CZML 文件
function exportCZML() {
    // 创建 CZML 数据
    var czml = [
        {
            "id": "document",
            "version": "1.0"
        },
        {
            "id": "point1",
            "name": "Exported Point",
            "description": "This point was exported from the application.",
            "position": {
                "cartesian": [0, 0, 0]
            },
            "point": {
                "pixelSize": 10,
                "color": {
                    "rgba": [0, 255, 0, 255] // 绿色
                }
            }
        }
    ];

    // 将 CZML 数据转换为 JSON 字符串
    var czmlString = JSON.stringify(czml, null, 2);

    // 下载 CZML 文件
    function downloadCZML(data, filename) {
        var blob = new Blob([data], { type: 'application/json' });
        var url = URL.createObjectURL(blob);
        var a = document.createElement('a');
        a.href = url;
        a.download = filename;
        document.body.appendChild(a);
        a.click();
        a.remove();
    }

    downloadCZML(czmlString, 'exported.czml');
}

总结

通过上述示例,您可以:

使用 Cesium 加载 CZML 文件并将其可视化。

动态生成 CZML 数据并通过浏览器导出为文件。

CZML 是一种灵活且强大的文件格式,适用于各种地理空间数据的可视化和分析任务。

以上就是JavaScript实现加载导出CZML文件详解的详细内容,更多关于JavaScript加载导出文件的资料请关注脚本之家其它相关文章!

相关文章

  • JS设置cookie、读取cookie、删除cookie

    JS设置cookie、读取cookie、删除cookie

    Js操作Cookie总结(设置,读取,删除),工作中经常会用到的哦!下面是详细代码,如有错误,请留言指正!
    2015-04-04
  • 详解微信小程序开发之formId使用(模板消息)

    详解微信小程序开发之formId使用(模板消息)

    这篇文章主要介绍了详解微信小程序开发之formId使用(模板消息),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-08-08
  • 浅谈javascript原型链与继承

    浅谈javascript原型链与继承

    这篇文章主要介绍了浅谈javascript原型链与继承的相关资料,需要的朋友可以参考下
    2015-07-07
  • 通过JS判断联网类型和连接状态的实现代码

    通过JS判断联网类型和连接状态的实现代码

    这篇文章主要介绍了通过JS判断联网类型和连接状态的实现代码,需要的朋友可以参考下
    2015-04-04
  • 页面版文本框智能提示JS代码

    页面版文本框智能提示JS代码

    首先说下背景,该code用于一个多条件查询界面,原本该查询条件由一个下拉列表提供,但是由于下拉列表数据量过大,用户使用不方便,便希望在页面给出一个智能提示的功能,但搜索的数据来自下拉列表
    2009-11-11
  • js 匿名调用实现代码

    js 匿名调用实现代码

    js中定义函数的方式有多种,函数直接量就是其中一种。如var fun = function(){},这里function如果不赋值给fun那么它就是一个匿名函数。
    2009-06-06
  • jQuery ajax(复习)—Baidu ajax request分离版

    jQuery ajax(复习)—Baidu ajax request分离版

    你没有看错标题,本文的确是在讲Baidu ajax,不过是很久很久以前的版本了,我们先分析一段简单的ajax代码,来自早期的百度七巧板项目通过这个来先复习一遍ajax的知识
    2013-01-01
  • js实现验证码案例

    js实现验证码案例

    这篇文章主要为大家详细介绍了js实现验证码案例,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • 原生JS实现列表子元素顺序反转的方法分析

    原生JS实现列表子元素顺序反转的方法分析

    这篇文章主要介绍了原生JS实现列表子元素顺序反转的方法,结合实例形式分析了javascript针对dom元素、数组reverse方法、innerHTML方法等列表元素顺序翻转相关操作技巧,需要的朋友可以参考下
    2018-07-07
  • event.x,event.clientX,event.offsetX区别

    event.x,event.clientX,event.offsetX区别

    event.x,event.clientX,event.offsetX区别,需要的朋友可以参考下。
    2006-11-11

最新评论