ArcGIS Maps SDK for JavaScript系列之四:添加自定义底图

news/2024/7/10 1:52:58 标签: arcgis, javascript, 前端, vue, 3d

目录

  • Basemap类介绍
    • Basemap类的常用属性
    • Basemap类的常用方法
  • 使用Basemap添加自定义底图
    • 引用Basemap
    • 引用切片图层
    • 创建一个新的Basemap对象
    • 将自定义图层应用到地图视图中
    • 引入并创建Camera对象
    • 引入并创建SceneView对象

Basemap类介绍

Basemap类是ArcGIS Maps SDK for JavaScript中用于表示地图底图的核心类之一。底图是地图应用程序中用于显示地理数据的背景图层。它提供了基础地理信息,如道路、河流、地貌和地名等。Basemap类提供了一种将地图图层组织成可供用户选择的底图选项的方式。

Basemap类的常用属性

  1. id:底图的唯一标识符,用于识别底图对象。
  2. title:底图的标题。
  3. thumbnailUrl:底图的缩略图URL。
  4. baseLayers:包含底图的图层数组。可以通过add()remove()方法来添加或移除底图的图层。
  5. referenceLayers:包含底图的参考图层数组。参考图层是不可见的图层,用于提供地图上的参考信息。
  6. loadError:一个布尔值,表示底图是否加载失败。
  7. loaded:一个布尔值,表示底图是否已加载。
  8. loadStatus:一个字符串,表示加载操作的状态。状态值包括四类:not-loaded(未加载)、loading(加载中)、loaded(已加载)、failed(加载失败)
  9. spatialReference:底图的空间参考
    10.portalItem :portalItem实例,底图关联的ArcGIS Online或Portal for ArcGIS项目的对象。该属性提供了与底图相关的更多信息,如标题、描述、缩略图、标签等。

Basemap类的常用方法

  1. cancelLoad()方法:用于取消正在进行中的load()操作。当你在加载底图时需要取消加载操作时,可以使用cancelLoad()方法。如果load()方法正在进行中,调用cancelLoad()方法将取消加载操作。
  2. clone()方法:用于创建一个对象的深度克隆。当调用clone()方法时,它会创建一个原始对象的精确副本,包括所有的属性和相关资源。通过在对象上调用clone()方法,我们可以创建一个具有相同配置的对象副本。当我们想要创建一个Basemap实例的副本,同时保留原始对象以供进一步使用或修改时,这会非常有用。
  3. destroy()方法:用于销毁Basemap对象以及与之相关的资源,包括它的图层和portalItem(如果有)。调用destroy()方法后,Basemap对象将不再可用,并且释放其所占用的内存和其他系统资源。这个方法在我们不再需要使用Basemap对象时非常有用,它可以帮助我们释放内存并清理相关资源,从而提高应用程序的性能和效率。
  4. fromId()方法:用于根据一个已知的基础地图ID创建一个新的Basemap实例。基础地图ID可以是预定义的常见基础地图,如街道地图、卫星影像地图或地形图,也可以是自定义的基础地图。通过调用fromId()方法并提供基础地图ID作为参数,可以很方便地创建一个特定的基础地图实例,而无需手动配置其属性和资源。这对于快速获取特定类型的基础地图非常有用。
  5. load()方法:异步加载底图。返回一个Promise对象,可以使用then()方法来处理加载完成后的回调。
  6. when()方法:返回一个Promise对象。when()方法允许我们在实例创建后执行操作或处理进一步的操作。它接受一个回调函数作为参数,当实例可用时将执行该函数。可以使用when()来链接额外的操作或执行依赖于实例创建的特定任务。

使用Basemap添加自定义底图

引用Basemap

前面一节我们在vue3中使用ArcGIS API实现了三维地球的加载,这一节我们在此基础上来添加自定义底图,要使用Basemap,我们需要先引入,使用下面的语句引入Basemap
import Basemap from "@arcgis/core/Basemap.js";

引用切片图层

这里我们调用一个在线的地图服务地址http://map.geoq.cn/arcgis/rest/services/ChinaOnlineStreetPurplishBlue/MapServer,这个地图服务提供的是一个切片服务,因此,我们需要引入切片服务
import TileLayer from "@arcgis/core/layers/TileLayer.js";

创建一个新的Basemap对象

在代码中使用new关键字创建一个Basemap对象,

let basemap = new Basemap({
    baseLayers: [
      new TileLayer({
        url: "http://map.geoq.cn/arcgis/rest/services/ChinaOnlineStreetPurplishBlue/MapServer",
        title: "Basemap"
      })
    ],
    title: "basemap",
    id: "basemap"
  });

上面的代码中,我们使用new方法创建了一个TileLayer对象,该对象表示一个Web切片图层。给TileLayer中的url属性设置我们发布的地图服务的URL字符串,作为底图的图层数据源。
然后,将这个TileLayer对象放入baseLayers数组中,并将该数组作为参数传递给Basemap。这样,我们就创建了一个包含一个图层的底图对象。同时,为这个底图对象设置了标题和ID,标题和ID都设置为"basemap"。

将自定义图层应用到地图视图中

使用new方法创建Map对象,并将其中的basemap属性设置为上面创建的basemap对象

 const map = new Map({
    basemap: basemap
  });

引入并创建Camera对象

如果使用二维地图,这里不需要引入Camera对象,因为这里我们是使用的三维地图,所以需要引入并创建Camera对象
引入Camera
import Camera from "@arcgis/core/Camera.js";
创建Camera对象,并设置初始值

var camera = new Camera({
    position: { // 相机位置
      x: -123.12,
      y: 40.57,
      z: 2000 // 高度
    },
    tilt: 60, // 相机俯仰角
    heading: 0 // 相机偏航角
  });

引入并创建SceneView对象

SceneView对象是ArcGIS API为我们提供的三维视图场景,使用之前,我们需要先引入
import SceneView from "@arcgis/core/views/SceneView.js";
创建SceneView对象

view = new SceneView({
    center: [-118.80500, 34.02700],
    zoom: 4,
    container: "viewDiv",
    map: map,
    camera: camera // 设置相机
  });
  view.ui.components = [];
}

至此,我们已经实现了自定义底图,并创建了三维场景,
运行程序,刷新浏览器,查看效果
在这里插入图片描述
好了,今天就先到这里吧,喜欢的小伙伴点赞关注加收藏哦!


http://www.niftyadmin.cn/n/5032793.html

相关文章

【送书活动】大模型赛道如何实现华丽的弯道超车

文章目录 导读模型训练01 具备对海量小文件的频繁数据访问的 I/O 效率02 提高 GPU 利用率,降低成本并提高投资回报率03 支持各种存储系统的原生接口04 支持单云、混合云和多云部署 Alluxio01 通过数据抽象化统一数据孤岛02 通过分布式缓存实现数据本地性03 优化整个…

[JAVEee]SpringBoot项目的创建

SpringBoot可以更好的开发Spring项目,本文章将使用idea社区版来演示创建项目的过程与注意事项. SpringBoot的优点 SpringBoot中内置快速添加依赖的功能,能够便捷的集成各种框架,帮助开发.内置运行容器,无需配置Tomcat容器等其他web容器,可直接进行项目的部署与运行.更好的使用…

第十章 数据库恢复技术

第十章 数据库恢复技术 10.1 事务的基本概念 事务 事务是用户定义的一个数据库操作序列,这些操作要么全做,要么全不做,是一个不可分割的工作单位。例事务的特性(ACID特性(ACID properties)) 原…

华为智慧搜索,下一片流量蓝海的“入海口”

几年前开始,TMT业界就发出了一类质疑的声音:移动互联网的各个APP彼此割裂,是在“孤岛炼油”。 大量的应用程序和服务互不打通,形成了严重的数据孤岛,用户只能进行站内搜索,很难穿透APP壁垒,进行…

全局引入的js如何只让部分页面有效

目录 问题: 解决方案: 问题: 我不想让所有页面都有这个js效果,只想让部分页面有,应该怎么办?(不改变全局引入的情况下) 解决方案: 1、使用条件语句判断当前页面是否需要应…

驱动开发--字符设备驱动的实现

一、字符设备驱动内部注册过程 通过对register_chrdev内部的实现过程进行分析,其实注册字符设备驱动的过程就是下面几步: 1.分配struct cdev对象空间 2.初始化struct cdev对象 3.注册cdev对象 完成上面的三步,就完成了字符设备驱动的注册…

Android Kotlin 基础详解

1,基础语法 1.1 可变变量与不可变变量 可以多次赋值的变量是可变变量&#xff0c;用关键字var表示&#xff1a; var <标识符> : <类型> <初始化值> 注意&#xff0c;在kotlin中成员变量不会赋默认值&#xff0c;不像java一样&#xff0c;必须手动添加默…

竞赛 基于机器学习与大数据的糖尿病预测

文章目录 1 前言1 课题背景2 数据导入处理3 数据可视化分析4 特征选择4.1 通过相关性进行筛选4.2 多重共线性4.3 RFE&#xff08;递归特征消除法&#xff09;4.4 正则化 5 机器学习模型建立与评价5.1 评价方式的选择5.2 模型的建立与评价5.3 模型参数调优5.4 将调参过后的模型重…