cesium-2-entity

1、四层结构


viewer --> datasources(DataSourceCollection类型) --> datasource --> entities(EntityCollection类型) --> entity


需要学习的方向是:只需要注意每个层与层之间的关系和entity实例如何创建即可

2、DataSourceCollection

增:
add(dataSource) → Promise.<DataSource>
删:(destroy一般为boolean,指是否需要直接销毁该datasource)
remove(dataSource, destroy) → boolean
removeAll(destroy)
查:
indexOf(dataSource) → number
getByName(name) → Array.<DataSource>
get(index) → DataSource
contains(dataSource) → boolean
改:
该类型数据一般是指向型,直接调出属性直接修改即可
改变层级关系(特殊):
lower(dataSource)
lowerToBottom(dataSource)
raise(dataSource)
raiseToTop(dataSource)

3、datasource

这是一个抽象类,有各种实现方式
image
一般只会用到他的三个属性:entities、name和show

4、entities(EntityCollection类型)

增:
add(entity) → Entity
getOrCreateEntity(id) → Entity
删:
removeAll()
removeById(id) → boolean
remove(entity) → boolean
查:
contains(entity) → boolean
getById(id) → Entity|undefined
改:

重要属性:

id : string
owner : DataSource|CompositeEntityCollection
show : boolean
values : Array.<Entity>  // 全部的entity

5、创建新的entity

一些实例:
https://www.jianshu.com/p/4250e822c9c8

6、代码

需要注意的是这里的add()方法得到的是<promise.类型>,后面需要使用.then(成功函数,失败函数)来得到类型
add(dataSource) → Promise.<DataSource>
这种类怎么创建和怎么用见:
https://blog.csdn.net/ABCFF12333/article/details/118188018

  // 注意add()方法得到的是<promise.类型>,后面需要使用.then(成功函数,失败函数)来得到类型
  // 注意这是异步方法
  viewer.dataSources.add(new Cesium.CustomDataSource("pointDataSource1")).then(function(value){
    var pointDataSource = value;
    pointDataSource.show = true;
    var point1 = pointDataSource.entities.add({
      id: "point1",
      name: "point1",
      position: Cesium.Cartesian3.fromDegrees(109, 34, 0),
      point: {
        pixelsize: 10,
        color: Cesium.Color.YELLOW,
        outlineWidth: 2,
        outlineColor: Cesium.Color.RED
      }
    });
    var point2 = pointDataSource.entities.add({
      id: "point2",
      name: "point2",
      position: Cesium.Cartesian3.fromDegrees(110, 35, 0),
      point: {
        pixelsize: 10,
        color: Cesium.Color.YELLOW,
        outlineWidth: 2,
        outlineColor: Cesium.Color.RED
      }
    })
  },function(error){})

  viewer.dataSources.add(new Cesium.CustomDataSource("polygonDatasource")).then(function(value){
    var polygonDatasource = value;
    polygonDatasource.show = true;
    polygonDatasource.entities.add({
      id: "polygon1",
      name: "polygon1",
      polygon: {
        hierarchy: Cesium.Cartesian3.fromDegreesArray([
          109.080842, 45.002073,
          105.91517, 45.002073,
          104.058488, 44.996596,
          104.053011, 43.002989,
          104.053011, 41.003906,
          105.728954, 40.998429,
          107.919731, 41.003906,
          109.04798, 40.998429,
          111.047063, 40.998429,
          111.047063, 42.000709,
          111.047063, 44.476286,
          111.05254, 45.002073,
          109.080842, 45.002073
        ]),
        height: 10,  // 必须要有高度,否则没有边框
        material: Cesium.Color.GREEN,
        outline: true,
        outlineColor: Cesium.Color.RED,
        outlineWidth: 2,
        fill: true
      }
    })
  },function(error){})
})

原文链接:https://www.cnblogs.com/CoderWangEx/p/17359352.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:cesium-2-entity - Python技术站

(0)
上一篇 2023年4月27日
下一篇 2023年4月28日

相关文章

  • JavaScript中你不知道的Object.entries用法

    JavaScript中你不知道的Object.entries用法 在JavaScript中,Object.entries()是一个非常实用的方法,可以用于将对象转换为可迭代的键值对数组。这个方法可以用于很多场景,例如对象的遍历、对象的特定属性操作等。 1. 基本语法 Object.entries()方法的语法非常简单,如下所示: Object.entries…

    JavaScript 2023年5月27日
    00
  • Javascript Math LN2 属性

    JavaScript中的Math.LN2属性是一个常数,表示自然对数中的2的对数值。以下是关于Math.LN2属性的完整攻略,包括两个示例。 JavaScript Math对象的LN2属性 JavaScript Math对象中的LN2属性是一个常数,表示自然对数中的2的对数值。 下面是LN2属性语法: Math.LN2 下面是一个LN2属性的示例: cons…

    JavaScript 2023年5月11日
    00
  • javascript生成大小写字母

    要生成大小写字母,可以借助JavaScript提供的字符集和Math对象中的随机数函数来实现。下面是详细的攻略步骤: 1. 定义大小写字母的字符集 JavaScript中的字符集可以用字符串表示,可以定义大小写字母的字符集如下: const lowercase = "abcdefghijklmnopqrstuvwxyz"; const u…

    JavaScript 2023年5月19日
    00
  • js获取json中key所对应的value值的简单方法

    要想获取JSON数据中某个key对应的value值,可以使用JavaScript中JSON对象的相关方法来实现。下面是两种简单的方法: 方法一:使用点语法 如果你知道JSON数据中具体的key名字,可以使用点语法(.)获取其对应的value值。例如,下面是一个包含两个key值对(name和age)的JSON对象: { "name": &q…

    JavaScript 2023年5月27日
    00
  • JS实现的系统调色板完整实例

    JS实现的系统调色板完整实例攻略 一、目标 本教程将介绍如何使用HTML、CSS和JavaScript实现一个系统调色板。该调色板将由六个滑块组成,每个滑块对应一个颜色通道。通过拖动滑块,可动态改变色彩输出。最后,我们将为该调色板添加一个显示颜色名称和十六进制代码的区域,以便用户了解当前所选颜色的相关信息。 二、步骤 1. HTML结构 首先,创建一个HTM…

    JavaScript 2023年6月10日
    00
  • javascript中setAttribute()函数使用方法及兼容性

    下面是关于JavaScript中setAttribute()函数的使用方法及兼容性的完整攻略: 一、语法概述 setAttribute()函数是一种在HTML和XML文档中设置属性的方法。它有两个参数: 属性名:要设置的属性名称 属性值:要设置的属性值 使用语法如下所示: element.setAttribute(attributeName, attribu…

    JavaScript 2023年5月27日
    00
  • JS实现网页标题栏显示当前时间和日期的完整代码

    下面我为你讲解一下 JS 实现网页标题栏显示当前时间和日期的完整代码攻略。 首先,我们需要了解两个 Javascript 方法:setInterval() 和 toLocaleTimeString()。 setInterval() 方法会以指定的时间间隔(以毫秒为单位)重复调用某个函数。可用于创建定期执行的函数(也称为时间间隔函数)。 toLocaleTim…

    JavaScript 2023年5月27日
    00
  • js函数中onmousedown和onclick的区别和联系探讨

    我们就按照以下步骤来讲解 js 函数中 onmousedown 和 onclick 的区别和联系。 1. onmousedown 和 onclick 的作用 在开始讲解 onmousedown 和 onclick 的区别之前,我们先来了解一下它们的作用。 onmousedown:当鼠标按下某个元素时触发。 onclick:当鼠标点击某个元素时触发。 这两个事…

    JavaScript 2023年5月28日
    00
合作推广
合作推广
分享本页
返回顶部