1. 对于Graphic对象,在初始化Graphic对象时设置popupTemplate属性,即可实现点击Graphic时显示弹窗。

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no">
<title>Intro to SceneView - Create a 3D map</title>
<style type="text/css">
html, body, .map-container { margin: 0; padding: 0; width: 100%; height: 100%; overflow-x: hidden; overflow-y: hidden; position: relative; }
#map-container .esri-popup__main-container { width: 480px; }
#map-container .esri-popup__header { border-bottom: 1px solid #a9a9a9; }
#map-container .esri-popup__content { margin: 0; }
#map-container .esri-popup__content > div { display: block; width: 450px; margin: 0 15px; }
#map-container .popup-con-title { margin: 1.2em 0; font-weight: bold; }
#map-container .popup-con-con { width: 450px; margin-bottom: 1em; }
</style>
</head>
<body>
<div class="map-container" id="map-container"></div>
<link rel="stylesheet" href="https://js.arcgis.com/4.5/esri/css/main.css">
<script src="https://js.arcgis.com/4.5/"></script>
<script type="text/javascript">
require(["esri/Map", "esri/views/SceneView", "esri/Graphic", "dojo/domReady!"], function (Map, SceneView, Graphic) {
_map = new Map({
"basemap": "satellite",
"ground": "world-elevation"
});
_view = new SceneView({
"map": _map,
"container": "map-container"
});
//_view.ui.empty("top-left"); //清空左上角区域按钮 var lng = 116.46, lat = 39.92;
_view.then(function () {
_view.goTo({ "zoom": 11, "tilt": 45, "center": [lng, lat] });
var g = new Graphic({
"geometry": { "type": "point", "latitude": lat, "longitude": lng, "spatialReference": { "wkid": 4326 } },
"symbol": { "type": "simple-marker", "color": [226, 119, 40], },
"attributes": { "id": 1, "name": "名称XXXXX", "value": "结果YYYYY" },
"popupTemplate": {
"title": "信息提示",
"content": "<p class='popup-con-title'>这是一个模拟火情点</p>"
+ "<div class='popup-con-con'>"
+ "<div>坐标位置.经度:" + lng + "</div>"
+ "<div>坐标位置.纬度:" + lat + "</div>"
+ "<div>还可以显示其他的属性信息,并且这些信息可以自定义布局</div>"
+ "</div>"
}
});
_view.graphics.add(g);
});
});
</script>
</body>
</html>

2. 上面设置Graphic的popupTemplate属性只有在点击对象时才会显示弹窗。如果有这样一个需求,点击页面上某个按钮显示弹窗,则需要采用SceneView对象的popup属性来实现。

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no">
<title>Intro to SceneView - Create a 3D map</title>
<style type="text/css">
html, body, .map-container { margin: 0; padding: 0; width: 100%; height: 100%; overflow-x: hidden; overflow-y: hidden; position: relative; }
#map-container .esri-popup__main-container { width: 480px; }
#map-container .esri-popup__header { border-bottom: 1px solid #a9a9a9; }
#map-container .esri-popup__content { margin: 0; }
#map-container .esri-popup__content > div { display: block; width: 450px; margin: 0 15px; }
#map-container .popup-con-title { margin: 1.2em 0; font-weight: bold; }
#map-container .popup-con-con { width: 450px; margin-bottom: 1em; }
.btn-container { position: absolute; top: 25px; right: 25px; }
</style>
</head>
<body>
<div class="map-container" id="map-container"></div>
<div class="btn-container">
<button id="btn-show">显示弹窗</button>
</div>
<link rel="stylesheet" href="https://js.arcgis.com/4.5/esri/css/main.css">
<script src="https://js.arcgis.com/4.5/"></script>
<script type="text/javascript">
require(["esri/Map", "esri/views/SceneView", "esri/Graphic", "dojo/domReady!"], function (Map, SceneView, Graphic) {
_map = new Map({
"basemap": "satellite",
"ground": "world-elevation"
});
_view = new SceneView({
"map": _map,
"container": "map-container"
});
//_view.ui.empty("top-left"); //清空左上角区域按钮 var lng = 116.46, lat = 39.92;
_view.then(function () {
_view.goTo({ "zoom": 11, "tilt": 45, "center": [lng, lat] });
var g = new Graphic({
"geometry": { "type": "point", "latitude": lat, "longitude": lng, "spatialReference": { "wkid": 4326 } },
"symbol": { "type": "simple-marker", "color": [226, 119, 40], },
"attributes": { "id": 1, "name": "名称XXXXX", "value": "结果YYYYY" }
});
_view.graphics.add(g);
dojo.connect(dojo.byId("btn-show"), "onclick", function () {
console.info(g);
_view.popup.visible = false;
_view.popup.title = g.attributes.name;
_view.popup.location = g.geometry;
_view.popup.content =
"<p class='popup-con-title'>这是一个模拟火情点</p>"
+ "<div class='popup-con-con'>"
+ "<div>坐标位置.经度:" + g.geometry.x + "</div>"
+ "<div>坐标位置.纬度:" + g.geometry.y + "</div>"
+ "<div>还可以显示其他的属性信息,并且这些信息可以自定义布局</div>"
+ "</div>";
_view.popup.visible = true;
});
});
});
</script>
</body>
</html>

3.当页面中存在对Graphic连线或移动等其他操作,此时需要暂时禁用Graphic弹窗。当未进行此操作时,要显示弹窗。需要SceneView对象的popup属性和hitTest函数配合来使用。

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no">
<title>Intro to SceneView - Create a 3D map</title>
<style type="text/css">
html, body, .map-container { margin: 0; padding: 0; width: 100%; height: 100%; overflow-x: hidden; overflow-y: hidden; position: relative; }
#map-container .esri-popup__main-container { width: 480px; }
#map-container .esri-popup__header { border-bottom: 1px solid #a9a9a9; }
#map-container .esri-popup__content { margin: 0; }
#map-container .esri-popup__content > div { display: block; width: 450px; margin: 0 15px; }
#map-container .popup-con-title { margin: 1.2em 0; font-weight: bold; }
#map-container .popup-con-con { width: 450px; margin-bottom: 1em; }
.btn-container { position: absolute; top: 25px; right: 25px; color:#fff }
</style>
</head>
<body>
<div class="map-container" id="map-container"></div>
<div class="btn-container">
<input type="checkbox" id="chk_disable"/>禁用弹窗
</div>
<link rel="stylesheet" href="https://js.arcgis.com/4.5/esri/css/main.css">
<script src="https://js.arcgis.com/4.5/"></script>
<script type="text/javascript">
require(["esri/Map", "esri/views/SceneView", "esri/Graphic", "dojo/domReady!"], function (Map, SceneView, Graphic) {
_map = new Map({
"basemap": "satellite",
"ground": "world-elevation"
});
_view = new SceneView({
"map": _map,
"container": "map-container"
});
//_view.ui.empty("top-left"); //清空左上角区域按钮 var lng = 116.46, lat = 39.92;
_view.then(function () {
_view.goTo({ "zoom": 5, "tilt": 5, "center": [lng, lat] });
var g = new Graphic({
"geometry": { "type": "point", "latitude": lat, "longitude": lng, "spatialReference": { "wkid": 4326 } },
"symbol": { "type": "simple-marker", "color": [226, 119, 40], },
"attributes": { "id": 1, "name": "名称XXXXX", "value": "结果YYYYY" }
});
_view.graphics.add(g);
_view.on("click", function (event) {
_view.hitTest({ x: event.x, y: event.y }).then(function (response) {
if (document.getElementById("chk_disable").checked) {
return;
}
var gCurr = response.results[0].graphic;
_view.popup.open();
_view.popup.title = gCurr.attributes.name;
_view.popup.location = gCurr.geometry;
_view.popup.content =
"<p class='popup-con-title'>这是一个模拟火情点</p>"
+ "<div class='popup-con-con'>"
+ "<div>坐标位置.经度:" + gCurr.geometry.x + "</div>"
+ "<div>坐标位置.纬度:" + gCurr.geometry.y + "</div>"
+ "<div>还可以显示其他的属性信息,并且这些信息可以自定义布局</div>"
+ "</div>";
_view.popup.visible = true;
});
});
});
});
</script>
</body>
</html>

Arcgis api for javascript学习笔记(4.5版本)-三维地图实现弹窗功能的更多相关文章

  1. Arcgis api for javascript学习笔记(4.5版本)-三维地图并叠加天地图标注

    1.三维地图实现 在官网的demo中就有三维地图的实现,如下图所示 <!DOCTYPE html> <html> <head> <meta charset=& ...

  2. Arcgis api for javascript学习笔记(4.5版本)-三维地图的飞行效果

    其实就只是用到了 view.goTo()  函数,再利用 window.setInterval()  函数(定时器)定时执行goTo().代码如下: <!DOCTYPE html> < ...

  3. Arcgis api for javascript学习笔记(4.5版本) - 获取FeatureLayer中的graphics集合

    在Arcgis api for javascript 3.x 版本中,我们可以直接通过某个FeatureLayer对象中的graphics属性获取要素集合. graphics属性 但是在4.x版本中, ...

  4. Arcgis api for javascript学习笔记(4.5版本) - 本地部署及代理配置

    在开发过程中,由于api的文件比较多,没必要每个项目都将api加入到解决方案中.况且在VS中如果将api加入解决方案,在编写css或js代码时,由于智能提示需要扫描脚本等文件,会导致VS很卡.所以个人 ...

  5. Arcgis api for javascript学习笔记(3.2X版本)-初步尝试

    Arcgis api for javascript(3.22版本)官方地址 :https://developers.arcgis.com/javascript/3/ 1. 根据官方示例实现一个简单地图 ...

  6. Arcgis api for javascript学习笔记(4.5版本) - 点击多边形(Polygon)并高亮显示

    在现在的 arcgis_js_v45_api 版本中并没有直接提供点击Polygon对象高亮显示.需要实现如下几个步骤: 1.点击地图时,获取Polygon的Graphic对象: 2.对获取到的Gra ...

  7. Arcgis api for javascript学习笔记(4.6版本) - 二维MapView中的FeatureLayer显示标注

    4.6版本api的FeatureLayer中有提供 labelsVisible 和 labelingInfo 两个属性,设置这两个属性可以实现显示将属性中某个字段作为标注.但是这两个属性只针对三维Sc ...

  8. Arcgis api for javascript学习笔记(3.2X版本)-Map图层叠加以及基本操作

    1. 不设置默认底图,第一个图层作为底图,然后叠加另外一个图层 先添加图层1,第一个图层1作为默认底图,然后在图层1上叠加图层2,并设置图层2的透明度为50%. <!DOCTYPE html&g ...

  9. Arcgis api for javascript学习笔记(3.2版本) - 匀速行驶轨迹动画效果

    一.前言 有这样一个需求:已知某条线上的n个点的经纬度数组 ,实现物体运行轨迹. 如果这些点中两个距离很近,那么我们可以用一个定时器在地图上每次重新画一个点,这样肉眼看到这个点上的运动效果,如下图代码 ...

随机推荐

  1. PyCharm下载主题以及个性化设置(详细)

    说明:该篇博客是博主一字一码编写的,实属不易,请尊重原创,谢谢大家! 一.下载主题 1.在http://www.themesmap.com/theme.html上选择自己喜欢的主题点进去后进行下载. ...

  2. 应用Python来计算排列中的逆序数个数

    在一个排列中,如果一对数的前后位置与大小顺序相反,即前面的数大于后面的数,那么它们就称为一个逆序.一个排列中逆序的总数就称为这个排列的逆序数.一个排列中所有逆序总数叫做这个排列的逆序数.也就是说,对于 ...

  3. 【Codeforces Round #445 (Div. 2) C】 Petya and Catacombs

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 看看时间戳为i的点有哪些. 每次优先用已经访问过的点. 如果不行就新创一个点. 注意新创点的时间戳也是i. [代码] #includ ...

  4. TTS-零基础入门之语音模板化

    上篇介绍了TTS的一个简单样例http://blog.csdn.net/u010176014/article/details/47326413 本篇咱们进一步聊聊 语音怎样读模板. 比方 公交车上的模 ...

  5. (转)利用openfiler实现iSCSI

    转自:http://czmmiao.iteye.com/blog/1735417 openfiler openfiler是一个基于浏览器的网络存储管理工具.来自于Linux系统.openfiler在一 ...

  6. iOS INVALID_USER_SCODE 定位 用户安全码未通过

    iOS 高德地图API不能定位及INVALID_USER_SCODE问题,有需要的朋友可以参考下. 一.在使用高德地图的API的时候,没有办法实现定位,在这里说一下在真机测试的时候出现没法定位应该注意 ...

  7. [Nuxt] Display Vuex Data Differently in Each Page of Nuxt and Vue.js

    You often use the same data in different ways across pages. This lesson walks you through setting up ...

  8. 浅浅的分析下es6箭头函数

    原文链接:http://damobing.com/?p=589 前言 箭头函数作为es6重点的语法内容之一,很多开发者对其爱不释手,当也要注意其可能存在的问题,其正确的使用场景,否则会引起不必要的bu ...

  9. [PReact] Handle Simple Routing with preact-router

    Some applications only need a very minimal routing solution. This lesson will cover a practical exam ...

  10. [Angular] Show a loading indicator in Angular using *ngIf/else, the as keyword and the async pipe

    The network may be unreliable and loading data may take time. Thus it is important to give the user ...