[ArcGIS API for JavaScript 4.8] Sample Code-Get Started-popups简介

时间:2022-09-10 08:48:52

【官方文档:https://developers.arcgis.com/javascript/latest/sample-code/intro-popup/index.html


一、Intro to popups

popups(弹出框)是一种用户与地图之间的交互方式,用户点击相关要素,会弹出对应的popup以查看所选要素的相关信息。每一个view(视图)都有一个popup,其要展示的内容可以来自layers、graphics或者仅仅是鼠标的点击信息。

popup用于展示layer或者graphic的相关字段信息,也可以用来表现query(查询)或者其他一些和layer、graphic无关的动作。比如,可以展现鼠标点击处的经纬信息。

这个例子实现弹出popup以展现鼠标点击处的经纬度信息和地址信息。需要实例化Locator类,并使用World Geocoding Service(世界地理编码服务)提供的reverse geocode(反解地理位置工具)计算出鼠标点击处的经纬度和地址信息。

1.代码骨架

 <!doctype html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="initial-scale=1,maximum-scale=1,user-scalable=no">
<title>Intro to popups</title> <!-- 在线JS API的引入 -->
<link rel="stylesheet" href="https://js.arcgis.com/4.8/esri/css/main.css">
<script src="https://js.arcgis.com/4.8/"></script> <!-- 设置样式,正确显示地图 -->
<style>
html,body,#viewDiv{
padding:0;
margin:0;
height:100%;
width:100%;
}
</style> <script> </script>
</head> <body>
<div id="viewDiv"></div>
</body>
</html>

其中包括JS API的引入、style样式的设置等等。

2.加载模块并实例化

 <script>
  require([
  "esri/Map",
"esri/views/MapView",
"esri/tasks/Locator",
"dojo/domReady!"
],function(Map,MapView,Locator){
//使用world geocoding service,创建位置解析器
var locatorTask=new Locator({
url:"https://geocode.arcgis.com/arcgis/rest/services/World/GeocodeServer"
}); //创建Map
var map=new Map({
basemap:"streets-navigation-vector"
}); //创建MapView
var view=new MapView({
container:"viewDiv",
map:map,
center:[118.79647,32.05838],
zoom:10
});
25 });
26 </script>

Map是创建地图的类,MapView是创建视图的类。具体请查看:https://www.cnblogs.com/wangmengdx/p/9385033.html

Locator类通过使用世界地理编码服务(World Geocoding Service)创建了一个位置解析器。在Locator类的构造函数中需传入url:"https://geocode.arcgis.com/arcgis/rest/services/World/GeocodeServer"。世界地理编码服务提供了解决方法将地址与坐标互相转换,更多信息请查看:https://geocode.arcgis.com/arcgis/index.html

3.监听view的click事件并在点击处弹出popup

当鼠标点击view时将触发view的click事件,弹出popup,将点击处的经纬信息展示出来。

 //监听view的click事件
2 view.on("click",function(event){
//停止派发事件,阻止它被分配到其他document节点
4 event.stopPropagation(); //获取点击处的经纬度
//保留3位小数
var lon=Math.round(event.mapPoint.longitude*1000)/1000;
var lat=Math.round(event.mapPoint.latitude*1000)/1000; //配置popup弹出框
view.popup.open({
title:"Reverse geocode:["+lon+","+lat+"]", //经纬度信息在popup的标题处显示
location:event.mapPoint //在鼠标点击处弹出popup
});
16 });

当view的click事件被触发时先调用event.stopPropagation(),是为了停止派发事件,阻止这个事件被分配到其他document节点,具体信息请查看:http://www.w3school.com.cn/jsref/event_stoppropagation.asp

event.mapPoint是一个对象,表示鼠标点击的那个地方。event.mapPoint.longitude是鼠标点击处所对应的实地经度值,默认小数点后14位左右。现在想输出小数点后3位,先将原经度值乘以1000,Math.round()方法四舍五入后,再除以1000,就可以起到输出小数点后3位的效果。注意下图中的点不是准确的同一个点,所以数值会有不同。

[ArcGIS API for JavaScript 4.8] Sample Code-Get Started-popups简介  [ArcGIS API for JavaScript 4.8] Sample Code-Get Started-popups简介  [ArcGIS API for JavaScript 4.8] Sample Code-Get Started-popups简介  [ArcGIS API for JavaScript 4.8] Sample Code-Get Started-popups简介

view.popup.open()方法配置popup弹出框,在title处配置经纬度信息。设置popup弹出在鼠标点击处。

4.在popup弹出框中添加位置信息(address)

当鼠标点击view时,触发locatorTask.locationToAddress()方法,传入鼠标点击处信息对象,以获得这一点所对应的实地地址。如果成功找到了鼠标点击处所对应的地址,就把这个地址信息在popup中显示;如果没有找到,就显示错误信息。

注意这个方法locatorTask.locationToAddress()还是写在前面view的click事件的监听函数中。

 //查找鼠标点击处所对应的实地地址
2 locatorTask.locationToAddress(event.mapPoint).then(function(response){
//将鼠标点击处的信息对象event.mapPoint传入函数locationToAddress()
//传入完成后,调用匿名函数,传入参数是locationToAddress()返回的地址信息对象
//如果成功找到地址,将其在popup中显示出来
view.popup.content=response.address;
7 }).catch(function(error){
//如果没找到,则在popup中显示错误信息
view.popup.content="找不到地址"
10 });

locatorTask是前面创建的位置解析器(Locator类的实例),将鼠标点击处的信息对象event.mapPoint传入locatorTask的locationToAddress()函数。参数传入完成后,调用匿名函数,这时要传入的参数是之前locationToAddress()返回的地址信息对象response。

如果查找地址成功,将地址信息在popup中展示出来;之后的catch()函数的意思是,如果前面的代码发生错误即地址信息没有找到,就执行catch()里的匿名函数,在popup里输出错误信息。JavaScript的promise.then().catch()语法请查看相关资料。

5.最终代码及运行效果

 <!doctype html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="initial-scale=1,maximum-scale=1,user-scalable=no">
<title>Intro to popups</title> <!-- 在线JS API的引入 -->
<link rel="stylesheet" href="https://js.arcgis.com/4.8/esri/css/main.css">
<script src="https://js.arcgis.com/4.8/"></script> <!-- 设置样式,正确显示地图 -->
<style>
html,body,#viewDiv{
padding:0;
margin:0;
height:100%;
width:100%;
}
</style> <script>
require([
"esri/Map",
"esri/views/MapView",
"esri/tasks/Locator",
"dojo/domReady!"
],function(Map,MapView,Locator){
//使用world geocoding service
var locatorTask=new Locator({
url:"https://geocode.arcgis.com/arcgis/rest/services/World/GeocodeServer"
}); //创建Map
var map=new Map({
basemap:"streets-navigation-vector"
}); //创建MapView
var view=new MapView({
container:"viewDiv",
map:map,
center:[118.79647,32.05838],
zoom:10
}); //监听view的click事件
view.on("click",function(event){
//停止派发事件,阻止它被分配到其他document节点
event.stopPropagation(); //获取点击处的经纬度
//保留3位小数
var lon=Math.round(event.mapPoint.longitude*1000)/1000;
var lat=Math.round(event.mapPoint.latitude*1000)/1000; //配置popup弹出框
view.popup.open({
title:"Reverse geocode:["+lon+","+lat+"]", //经纬度信息在popup的标题处显示
location:event.mapPoint //在鼠标点击处弹出popup
}); //查找鼠标点击处所对应的实地地址
locatorTask.locationToAddress(event.mapPoint).then(function(response){
//将鼠标点击处的信息对象event.mapPoint传入函数locationToAddress()
//传入完成后,调用匿名函数,传入参数是locationToAddress()返回的地址信息对象
//如果成功找到地址,将其在popup中显示出来
view.popup.content=response.address;
}).catch(function(error){
//如果没找到,则在popup中显示错误信息
view.popup.content="找不到地址"
});
});
});
</script>
</head> <body>
<div id="viewDiv"></div>
</body>
</html>

  [ArcGIS API for JavaScript 4.8] Sample Code-Get Started-popups简介

[ArcGIS API for JavaScript 4.8] Sample Code-Get Started-popups简介的更多相关文章

  1. &lbrack;ArcGIS API for JavaScript 4&period;8&rsqb; Sample Code-Get Started-MapView&comma;SceneView简介

    [官方文档:https://developers.arcgis.com/javascript/latest/sample-code/index.html]  一.Intro to MapView(2D ...

  2. &lbrack;ArcGIS API for JavaScript 4&period;8&rsqb; Sample Code-Get Started-widgets简介

    [官方文档:https://developers.arcgis.com/javascript/latest/sample-code/intro-widgets/index.html] 一.Intro ...

  3. &lbrack;ArcGIS API for JavaScript 4&period;8&rsqb; Sample Code-Popups-1-popupTemplate的概念和popup中属性字段值的多种表现形式

    [官方文档:https://developers.arcgis.com/javascript/latest/sample-code/intro-popuptemplate/index.html] 一. ...

  4. &lbrack;ArcGIS API for JavaScript 4&period;8&rsqb; Sample Code-Get Started-layers简介

    [官方文档:https://developers.arcgis.com/javascript/latest/sample-code/intro-layers/index.html] 一.Intro t ...

  5. 下载并部署 ArcGIS API for JavaScript 4&period;10

    学习ArcGIS API for JavaScript 4.10 的第一步就是下载并部署该文件. 有的读者由于之间没接触过,不知道怎么下载和部署文件.这些读者要求作者详细的写一篇关于下载和部署的文章( ...

  6. ArcGIS API for JavaScript 4&period;2学习笔记&lbrack;1&rsqb; 显示地图

    ArcGIS API for JavaScript 4.2直接从官网的Sample中学习,API Reference也是从官网翻译理解过来,鉴于网上截稿前还没有人发布过4.2的学习笔记,我就试试吧. ...

  7. ArcGIS API for JavaScript 4&period;4 版本加载谷歌地图

    ArcGIS API for JavaScript 4.X 版本升级后,API发生了很大的变化. 其中就支持了WebEarth展示,主要是通过 esri/views/SceneView 实现的. 在新 ...

  8. 转:ArcGIS API For JavaScript官方文档(二十)之图形和要素图层——①Graphics概述

    原文地址:ArcGIS API For JavaScript官方文档(二十)之图形和要素图层——①Graphics概述 ArcGIS JavaScript API允许在地图上绘制graphic(图形) ...

  9. arcgis api for JavaScript &lowbar;加载三维图层&lpar;scene layer&rpar;

    arcgis api for JavaScript _加载三维图层(scene layer) arcgis api for JavaScript  4.x 版本增加对三维的支持. 关于三维图层(sce ...

随机推荐

  1. UIwebView 和 H5交互详情

    背景: 最近公司准备上一个只有原生登录界面 + H5网页 ,并且支持ios7.0 以上系统的混合app;这可把我难住了,原生的UI界面我可以正写反写各种style把界面搭建起来.而要这个app的难点在 ...

  2. 更新chrom遇到flash过期解决办法

    更新chrom遇到flash过期解决办法 百度最新adobe flash player ppapi最新版 下载并安装,重启浏览器即可

  3. ar技术序章-SDK介绍和选择

    转自: http://blog.csdn.net/kun1234567/article/details/10402535 ar技术序章-SDK介绍和选择 分类: Augmented Reality20 ...

  4. poj 3678 Katu Puzzle&lpar;Two Sat&rpar;

    题目链接:http://poj.org/problem?id=3678 代码: #include<cstdio> #include<cstring> #include<i ...

  5. 分别基于TensorFlow、PyTorch、Keras的深度学习动手练习项目

    ×下面资源个人全都跑了一遍,不会出现仅是字符而无法运行的状况,运行环境: Geoffrey Hinton在多次访谈中讲到深度学习研究人员不要仅仅只停留在理论上,要多编程.个人在学习中也体会到单单的看理 ...

  6. 405 Method Not Allowed error with PUT or DELETE Request on IIS Server

    昨天手贱去一台服务器上装了Webdav. 一开始以为这个报错是跨域问题, 最近一直遇到用自动的publish发布到FTP出问题也就没想到是Webdav的问题 而且这东西装了还不能删除 处理办法 IIS ...

  7. WPF编程宝典&lpar;Pro wpf in c&num; 2012&rpar;(文摘)

    第一部分 基础知识 第1章 WPF概述 第2章 XAML 第3章 布局 第4章 依赖项属性 第5章 路由事件 第二部分 进一步研究WPF 第6章 控件 第7章 Application类 第8章 元素绑 ...

  8. Azure 虚拟机诊断设置问题排查

    Azure 为用户提供了可以自己配置的性能监控功能:Azure 诊断扩展.但是在具体配置中,经常会遇到各种各样的问题.不了解监控的工作机制常常给排查带来一定难度.这里我们整理了关于 Azure 虚拟机 ...

  9. C&num;使用ICSharpCode&period;SharpZipLib压缩后进行web批量下载文件

    参考:http://blog.csdn.net/kongwei521/article/details/51167903#

  10. cv程序员的日常&lowbar;1

    某天pom文件粘贴报红 然后我就问我同事 然后我就百度 https://blog.csdn.net/guoyiyun_tz/article/details/82115024 看完之后…emmmm没错啊 ...