CZML 是一种用来描述动态场景的JSON架构的语言,主要用于 Cesium 在浏览器中的展示。它可以用来描述点、线、布告板、模型以及其他的图元,同时定义他们是怎样随时间变化的。
加载点
'use strict';
var czml = [{
"id": "document",
"name": "CZML Point",
"version": "1.0"
}, {
"id": "point 1",
"name": "point",
"position": {
"cartographicDegrees": [-111.0, 40.0, 0]
},
"point": {
"color": {
"rgba": [255, 255, 255, 255]
},
"outlineColor": {
"rgba": [255, 0, 0, 255]
},
"outlineWidth": 4,
"pixelSize": 20
}
}];
var viewer = new Cesium.Viewer('cesiumContainer');
var dataSourcePromise = Cesium.CzmlDataSource.load(czml);
viewer.dataSources.add(dataSourcePromise);
viewer.zoomTo(dataSourcePromise);
加载线
/**
* CZML数据源创建线
* @param {Object} polyLinePositions 经纬度坐标点数据集合(多个坐标点组成一条线):[109.740, 19.997, 500, 109.860, 19.997, 500]
*/
function creatLine(polyLinePositions){
// 创建czml文件;得到czml数据源
var czmlLine = getCzmlLine(polyLinePositions);
// 加载提供的URL或CZML对象,替换任何现有数据。
var dataSourcePromise = Cesium.CzmlDataSource.load(czmlLine);
viewer.dataSources.add(dataSourcePromise);
// 添加czml数据到三维球上
viewer.zoomTo(dataSourcePromise);
}
/**
* 定义并封装CZML数据源
* @param {Object} cartographicDegrees 经纬度坐标点数据集合(多个坐标点组成一条线):[109.740, 19.997, 500, 109.860, 19.997, 500]
*/
function getCzmlLine(cartographicDegrees){
var czmlLine = [{
"id": "document",
"name": "CZML Geometries: Polyline",
"version": "1.0"
}, {
"id": "fullLine",
"name": "Yellow full line",
"polyline": {
"positions": {
"cartographicDegrees": cartographicDegrees
},
"material": {
"solidColor": {
"color": {
"rgba": [255,255,0,255]
}
}
}
}
}];
return czmlLine;
}
加载布告牌
var czml = [{
"id" : "document",
"name" : "CZML Point - Time Dynamic",
"version" : "1.0"
},{
"id" : "point",
"availability" :"2012-08-04T16:00:00Z/2012-08-04T16:05:00Z",
"position" : {
"epoch" : "2012-08-04T16:00:00Z",
"cartographicDegrees" : [
0, 70, 20, 150000,
100, -80, 44, 150000,
200, -90, 18, 150000,
300, -98, 52, 150000,
]
},
"billboard" : {
"image" : "",
"scale" : 0.5,
},
path : {
resolution : 1,
material : new Cesium.PolylineGlowMaterialProperty({
glowPower : 0.1,
color : Cesium.Color.YELLOW
}),
width :3
},
}];
var viewer = new Cesium.Viewer('cesiumContainer', {
shouldAnimate : true,
sceneMode: 2,
});
viewer.dataSources.add(Cesium.CzmlDataSource.load(czml)).then(function(ds){
var s = ds.entities.getById("point");
s.orientation =new Cesium.VelocityOrientationProperty(s.position);
s.billboard.alignedAxis=new Cesium.VelocityVectorProperty(s.position, true)
});
加载模型
var czml = [
{
id: "document",
name: "CZML Path",
version: "1.0",
clock: {
interval: "2020-09-30T10:00:00Z/2020-09-30T10:01:20Z",
currentTime: "2012-08-04T10:00:00Z",
multiplier: 10,
},
},
{
id: "path",
name: "path with GPS flight data",
description: "Created by wangyu",
availability: "2020-09-30T10:00:00Z/2020-09-30T10:01:20Z",
path: {
material: {
polylineOutline: {
color: {
rgba: [255, 0, 255, 127],
},
outlineColor: {
rgba: [255, 0, 255, 127],
},
outlineWidth: 3,
},
},
width: 5,
leadTime: 10,
trailTime: 1000,
resolution: 5,
},
model: {
gltf: "Assets/SampleData/models/CesiumAir/Cesium_Air.glb",
scale: 2.0,
minimumPixelSize: 128,
},
position: {
epoch: "2020-09-30T10:00:00Z",
cartographicDegrees: [
0, 102.23404378554466, 27.825736605050523, 2500,
10, 102.23691954070244, 27.82887625908256, 2500,
20, 102.23908610745147, 27.830920963237897, 2500,
30, 102.24222708893987, 27.834251845778994, 2500,
40, 102.24483684219396, 27.837156939755058, 2500,
50, 102.24821756517042, 27.838973119832243, 2500,
60, 102.2497304631213, 27.843805668815058, 2500,
70, 102.25017946873977, 27.849726810753346, 2500,
80, 102.24597936406548, 27.852179959795592, 2500
],
},
},
];
var airModel;
viewer.dataSources.add(Cesium.CzmlDataSource.load(czml)).then(function (ds) {
airModel = ds.entities.getById("path");
// 设置模型可以随路径方向转向
airModel.orientation = new Cesium.VelocityOrientationProperty(airModel.position);
airModel.model.alignedAxis = new Cesium.VelocityVectorProperty(airModel.position, true)
});