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日

相关文章

  • Aptana调试javascript图解教程

    下面我来详细讲解“Aptana调试JavaScript图解教程”的完整攻略。 1. Aptana是什么? Aptana是一款用于web开发的开源IDE,可以提供代码编辑、调试、版本控制等功能。Aptana的调试功能可以帮助我们在调试JavaScript代码时快速定位和解决问题。 2. 如何使用Aptana调试JavaScript? 2.1 安装Aptana …

    JavaScript 2023年6月11日
    00
  • Javascript模块化编程(一)AMD规范(规范使用模块)

    那我来为您详细讲解JavaScript模块化编程(一)AMD规范(规范使用模块)的完整攻略。 简介 AMD规范(Asynchronous Module Definition)是一种针对JavaScript模块化编程的规范,它最先由Dojo Toolkit和RequireJS推广。 在AMD规范中,每个模块发起一个异步请求,等模块加载成功后再执行后续操作。因为…

    JavaScript 2023年5月28日
    00
  • 防止重复发送 Ajax 请求

    防止重复发送 Ajax 请求是一个常见的开发任务,因为在页面交互过程中,用户可能会频繁地发起相同的请求,如果每次都向服务器发起请求,不仅会增加服务器的压力,也会降低用户体验。下面是防止重复发送 Ajax 请求的完整攻略: 1. 使用防抖技术 防抖技术是一种延迟执行函数的策略,即在指定时间内如果触发多次事件,只会执行一次。在 Ajax 请求中,我们可以使用防抖…

    JavaScript 2023年6月11日
    00
  • js里取容器大小、定位、距离等属性搜集整理

    在JavaScript中,获取元素的位置、大小、距离等属性是开发中经常使用的操作,以下是获取常用属性的完整攻略: 获取元素大小 获取元素的大小(宽度和高度)有不同的方法,其中包括: 通过clientWidth和clientHeight clientWidth或clientHeight属性返回元素的可见宽度和高度(不包括滚动条)。 const element …

    JavaScript 2023年6月10日
    00
  • 详解JavaScript正则表达式之RegExp对象

    详解JavaScript正则表达式之RegExp对象 什么是正则表达式? 正则表达式是一种字符串匹配的模式。在JavaScript中,我们可以使用RegExp对象来创建和使用正则表达式。 创建RegExp对象 在JavaScript中,我们有两种方式来创建一个RegExp对象: 使用字面量方式 let regExp = /pattern/flags; 其中,…

    JavaScript 2023年6月10日
    00
  • js css+html实现简单的日历

    下面是详细讲解“js css+html实现简单的日历”的完整攻略: 简介 在网页中添加日历是非常常见的需求。我们可以通过使用 HTML、CSS 和 JavaScript 来轻松制作一个基本的日历。其中,HTML 负责构建页面结构,CSS 实现样式美化,JavaScript 则用来处理各种交互和逻辑。 实现方法 1. HTML 结构 我们先来设立一个基本的 H…

    JavaScript 2023年5月27日
    00
  • 兼容IE与firefox火狐的回车事件(js与jquery)

    为了兼容IE和Firefox的回车事件,我们可以使用原生的JavaScript或者jQuery来实现。下面我会分别提供两种实现方式的详细攻略。 1. 原生JavaScript实现回车事件 a. 监听keypress事件 我们可以通过监听keypress事件,在按下回车键时触发相应事件。 document.addEventListener("keyp…

    JavaScript 2023年6月11日
    00
  • location.hash保存页面状态的技巧

    当我们需要保存页面状态,以便于后续操作时,可以借助浏览器提供的location.hash协议来实现。下面,让我详细讲解一下“location.hash保存页面状态的技巧”的完整攻略。 什么是location.hash location.hash指的是URL中#及其后面的内容。比如,http://www.example.com/#section1中的#sect…

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