Загрузите данные czml/json из файла и сохраните их в переменной

Я использую интерфейс Sandcastle, предлагаемый Cesium, но мой вопрос может быть распространен (я думаю) на любого пользователя javascript. Моя цель состоит в том, чтобы загрузить файл czml (также может быть файлом.json) и сохранить его содержимое в переменной для простого доступа к его тегам.

Вот небольшой пример: предположим, что содержимое файла (test.czml) следующее:

[{
    "id" : "document",
    "name" : "Basic CZML billboard and label",
    "version" : "1.0"
}, {
    "id" : "Point A",
    "name" : "Point A",
    "label" : {
        "fillColor" : {
            "rgba" : [255, 255, 255, 255]
        },
        "font" : "12pt Lucida Console",
        "horizontalOrigin" : "LEFT",
        "pixelOffset" : {
            "cartesian2" : [8, 0]
        },
        "style" : "FILL",
        "text" : "Point A",
        "showBackground" : true,
        "backgroundColor" : {
            "rgba" : [112, 89, 57, 200]
        }
    },
    "position" : {
        "cartographicDegrees":[
            0, 0, 0
        ]
    }
}, {
    "id" : "Point B",
    "name" : "Point B",
    "label" : {
        "fillColor" : {
            "rgba" : [255, 255, 255, 255]
        },
        "font" : "12pt Lucida Console",
        "horizontalOrigin" : "LEFT",
        "pixelOffset" : {
            "cartesian2" : [8, 0]
        },
        "style" : "FILL",
        "text" : "Point B",
        "showBackground" : true,
        "backgroundColor" : {
            "rgba" : [112, 89, 57, 200]
        }
    },
    "position" : {
        "cartographicDegrees":[
            0, 10, 0
        ]
    }
}]

Моей конечной целью было бы получить доступ к контенту следующим образом:

var czml = function_to_load_data(test.czml)
console.log(czml[1].id)

Мне удалось загрузить данные с помощью следующих команд:

var czml = Cesium.CzmlDataSource.load('../../SampleData/simple.czml'));

Но этот подход не работает, как я хочу. Что такое умный и элегантный способ достичь моей цели?

1 ответ

Решение

Возможный способ, которым я смог достичь своего решения в Цезии:

var viewer = new Cesium.Viewer('cesiumContainer');

Cesium.loadJson('../../SampleData/test.czml').then(function(jsonData) {

    console.log(jsonData[1].id);

}).otherwise(function(error) {
    // an error occurred
});
Другие вопросы по тегам