高德地图3D菱形 区域点击搜索
更新一波吧
<!doctype html>
<html lang="zh-CN"> <head>
<!-- 原始地址://webapi.amap.com/ui/1.0/ui/geo/DistrictExplorer/examples/index.html -->
<!-- <base href="//webapi.amap.com/ui/1.0/ui/geo/DistrictExplorer/examples/" target="_top"/> -->
<meta charset="utf-8">
<meta name="viewport" content="initial-scale=1.0, user-scalable=no, width=device-width">
<title>行政区浏览</title>
<link rel="stylesheet" type="text/css" href="//webapi.amap.com/ui/1.0/ui/geo/DistrictExplorer/examples/area.css">
<style type="text/css">
#btn_list {
width: 326px;
height: 60px;
padding: 10px 0 0 10px;
position: fixed;
top: 10px;
left: 10px;
background: rgba(11,11,13,0.2);
overflow-y: auto;
padding-right: 0;
}
.list_ul {
width: 100%;
height: 100%;
}
.list_li{
width: 86px;
height: 20px;
float: left;
border: 1px solid #252D30;
background: #0D1011;
margin-right: 15px;
margin-bottom: 20px;
cursor: pointer;
color: #CFCFD1;
font-size: 12px;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
text-align: center;
line-height: 20px;
}
.list_li_select{
border: 1px solid #58D9DC;
}
</style>
</head>
<script src="//webapi.amap.com/maps?v=1.4.15&key=741a28e4b11880dfa0d6673f7c26f32d"></script>
<script src="//webapi.amap.com/loca?v=1.3.0&key=741a28e4b11880dfa0d6673f7c26f32d"></script>
<script src="//a.amap.com/Loca/static/mock/bj_heat_grid.js"></script>
<script src="https://code.jquery.com/jquery-3.1.1.min.js"></script>
<script src="//a.amap.com/Loca/static/manual/example/script/demo.js"></script>
<!-- UI组件库 1.0 -->
<script src="//webapi.amap.com/ui/1.0/main.js?v=1.0.11"></script>
<body>
<div id="outer-box">
<div id="container" tabindex="0"></div>
<div id="panel" class="scrollbar1">
<ul id="area-tree">
</ul>
</div>
</div>
<div id="btn_list">
<ul class="list_ul">
<!-- <li class="list_li">西安市雁塔医院</li>
<li class="list_li">西安市雁塔医院</li>
<li class="list_li">西安市雁塔医院</li> -->
</ul>
</div>
<script type="text/javascript">
//创建地图
var map = new AMap.Map('container', {
mapStyle:"amap://styles/95dcdef6e6578530f59300980f588add",
resizeEnable: true,
rotateEnable:true,
pitchEnable:true,
zoom: 17.8,
pitch:75,
rotation:-15,
viewMode:'3D',//开启3D视图,默认为关闭
buildingAnimation:true,//楼块出现是否带动画
expandZoomRange:true,
// zooms:[3,20],
center:[108.925622,34.282085] ,// 108.907941,34.2463 });
debugger;
//just some colors
var colors = [
"#3366cc", "#dc3912", "#ff9900", "#109618", "#990099", "#0099c6", "#dd4477", "#66aa00",
"#b82e2e", "#316395", "#994499", "#22aa99", "#aaaa11", "#6633cc", "#e67300", "#8b0707",
"#651067", "#329262", "#5574a6", "#3b3eac"
]; AMapUI.load(['ui/geo/DistrictExplorer', 'lib/$'], function(DistrictExplorer, $) { //创建一个实例
var districtExplorer = window.districtExplorer = new DistrictExplorer({
eventSupport: true, //打开事件支持
map: map
}); //当前聚焦的区域
var currentAreaNode = null; //鼠标hover提示内容
var $tipMarkerContent = $('<div class="tipMarker top"></div>'); var tipMarker = new AMap.Marker({
content: $tipMarkerContent.get(0),
offset: new AMap.Pixel(0, 0),
bubble: true
}); //根据Hover状态设置相关样式
function toggleHoverFeature(feature, isHover, position) { tipMarker.setMap(isHover ? map : null); if (!feature) {
return;
} var props = feature.properties; if (isHover) { //更新提示内容
$tipMarkerContent.html(props.adcode + ': ' + props.name);
//更新位置
tipMarker.setPosition(position || props.center);
} $('#area-tree').find('h2[data-adcode="' + props.adcode + '"]').toggleClass('hover', isHover); //更新相关多边形的样式
var polys = districtExplorer.findFeaturePolygonsByAdcode(props.adcode);
for (var i = 0, len = polys.length; i < len; i++) { polys[i].setOptions({
// fillOpacity: isHover ? 0.5 : 0.2
});
}
} //监听feature的hover事件
districtExplorer.on('featureMouseout featureMouseover', function(e, feature) {
toggleHoverFeature(feature, e.type === 'featureMouseover',
e.originalEvent ? e.originalEvent.lnglat : null);
}); //监听鼠标在feature上滑动
districtExplorer.on('featureMousemove', function(e, feature) {
//更新提示位置
tipMarker.setPosition(e.originalEvent.lnglat);
}); //feature被点击
districtExplorer.on('featureClick', function(e, feature) {
debugger;
var props = feature.properties;
var area = feature.properties.name;
var nodeList=[];
AMap.service(["AMap.PlaceSearch"], function() {
//构造地点查询类
var placeSearch = new AMap.PlaceSearch({ city: "029", // 兴趣点城市
citylimit: true, //是否强制限制在设置的城市内搜索
map: map, // 展现结果的地图实例
// panel: "panel", // 结果列表将在此容器中进行展示。
autoFitView: false // 是否自动调整地图视野使绘制的 Marker点都处于视口的可见范围
});
//关键字查询
placeSearch.search(''+area+'医院',function(status,result){
nodeList = result.poiList.pois;
console.log(result.poiList.pois);
var x= nodeList[0].location.lng;// 108
var y= nodeList[0].location.lat;// 34
map.setZoomAndCenter(18, [x,y]);
creatHtml(nodeList);
});
}); //如果存在子节点
if (props.childrenNum > 0) {
//切换聚焦区域
switch2AreaNode(props.adcode);
}
}); //绘制区域面板的节点
function renderAreaPanelNode(ele, props, color) { var $box = $('<li/>').addClass('lv_' + props.level); var $h2 = $('<h2/>').addClass('lv_' + props.level).attr({
'data-adcode': props.adcode,
'data-level': props.level,
'data-children-num': props.childrenNum || void(0),
'data-center': props.center.join(',')
}).html(props.name).appendTo($box); if (color) {
$h2.css('borderColor', color);
} //如果存在子节点
if (props.childrenNum > 0) { //显示隐藏
$('<div class="showHideBtn"></div>').appendTo($box); //子区域列表
$('<ul/>').addClass('sublist lv_' + props.level).appendTo($box); $('<div class="clear"></div>').appendTo($box); if (props.level !== 'country') {
$box.addClass('hide-sub');
}
} $box.appendTo(ele);
} //填充某个节点的子区域列表
function renderAreaPanel(areaNode) { var props = areaNode.getProps(); var $subBox = $('#area-tree').find('h2[data-adcode="' + props.adcode + '"]').siblings('ul.sublist'); if (!$subBox.length) {
//父节点不存在,先创建
renderAreaPanelNode($('#area-tree'), props);
$subBox = $('#area-tree').find('ul.sublist');
} if ($subBox.attr('data-loaded') === 'rendered') {
return;
} $subBox.attr('data-loaded', 'rendered'); var subFeatures = areaNode.getSubFeatures(); //填充子区域
for (var i = 0, len = subFeatures.length; i < len; i++) {
renderAreaPanelNode($subBox, areaNode.getPropsOfFeature(subFeatures[i]), colors[i % colors.length]);
}
} //绘制某个区域的边界
function renderAreaPolygons(areaNode) { //更新地图视野
map.setBounds(areaNode.getBounds(), null, null, true); //清除已有的绘制内容
districtExplorer.clearFeaturePolygons(); //绘制子区域 districtExplorer.renderSubFeatures(areaNode, function(feature, i) { var fillColor = colors[i % colors.length];
var strokeColor = colors[colors.length - 1 - i % colors.length]; return {
cursor: 'default',
bubble: true,
strokeColor: strokeColor, //线颜色
strokeOpacity: 1, //线透明度
strokeWeight: 3, //线宽
fillColor: fillColor, //填充色
fillOpacity: 0, //填充透明度
};
}); //绘制父区域
districtExplorer.renderParentFeature(areaNode, {
cursor: 'default',
bubble: true,
strokeColor: 'black', //线颜色
strokeOpacity: 1, //线透明度
strokeWeight: 1, //线宽
fillColor: null, //填充色
fillOpacity: 0, //填充透明度
});
} //切换区域后刷新显示内容
function refreshAreaNode(areaNode) { districtExplorer.setHoverFeature(null); renderAreaPolygons(areaNode); //更新选中节点的class
var $nodeEles = $('#area-tree').find('h2'); $nodeEles.removeClass('selected'); var $selectedNode = $nodeEles.filter('h2[data-adcode=' + areaNode.getAdcode() + ']').addClass('selected'); //展开下层节点
$selectedNode.closest('li').removeClass('hide-sub'); //折叠下层的子节点
$selectedNode.siblings('ul.sublist').children().addClass('hide-sub');
} //切换区域
function switch2AreaNode(adcode, callback) { if (currentAreaNode && ('' + currentAreaNode.getAdcode() === '' + adcode)) {
return;
} loadAreaNode(adcode, function(error, areaNode) { if (error) { if (callback) {
callback(error);
} return;
} currentAreaNode = window.currentAreaNode = areaNode; //设置当前使用的定位用节点
districtExplorer.setAreaNodesForLocating([currentAreaNode]); refreshAreaNode(areaNode); if (callback) {
callback(null, areaNode);
}
});
} //加载区域
function loadAreaNode(adcode, callback) { districtExplorer.loadAreaNode(adcode, function(error, areaNode) { if (error) { if (callback) {
callback(error);
} console.error(error); return;
} renderAreaPanel(areaNode); if (callback) {
callback(null, areaNode);
}
});
} //西安
switch2AreaNode(610100);
var layer = new Loca.ScatterPointLayer({
map: map,
eventSupport: true
}); var list = heatGrid.map(function (value) { var val = value.split('$');
return {
// coord: val[1].replace("116.","108.").replace("40.","34."),
coord: val[1],
value: +val[0]
}
}); layer.setData(list.slice(0, 5000), {
lnglat: 'coord'
}); var colorArr = [
'#2c7bb6',
'#abd9e9',
'#ffffbf',
'#fdae61',
'#d7191c'
]; layer.setOptions({
// 设定棱柱体顶点数量
vertex: 4,
// 单位米
unit: 'meter',
light: {
// 环境光
ambient: {
// 光照颜色
color: '#ffffff',
// 光照强度,范围 [0, 1]
intensity: 0.5
},
// 平行光
directional: {
color: '#ffffff',
// 光照方向,是指从地面原点起,光指向的方向。
// 数组分别表示 X 轴、Y 轴、Z 轴。
// 其中 X 正向朝东、Y 正向朝南、Z 正向朝地下。
direction: [1, -1.5, 2],
intensity: 0.6
}
},
style: {
// 正多边形半径
radius: 500,
height: {
key: 'value',
value: [0, 50000]
},
// 顶边颜色
color: {
key: 'value',
scale: 'quantile',
value: colorArr
},
opacity: 0.9,
// 旋转角度,单位弧度
rotate: Math.PI / 180 * 45
},
selectStyle: {
color: '#fcff19',
opacity: 0.9
}
}); layer.on('mousemove', (ev) => {
openInfoWin(map, ev.originalEvent, {
'位置': ev.rawData.coord,
'热度': ev.rawData.value
});
}); });
// 创建区医院html
function creatHtml(dataArr){
var html = '';
if(!dataArr){
return false;
}
for(var i=0;i<dataArr.length;i++){
html+="<li class='list_li' onClick='changePosition("+dataArr[i].location.lng+","+dataArr[i].location.lat+")' title="+dataArr[i].name+">"+dataArr[i].name+"</li>"
}
$('.list_ul').empty().append(html);
}
function changePosition (x,y){
map.setZoomAndCenter(18, [x,y]);
}
</script>
</body> </html>
高德地图3D菱形 区域点击搜索的更多相关文章
- 小程序Echarts 构建中国地图并锚定区域点击事件
小程序Echarts 构建中国地图并锚定区域点击事件 Step1 效果展示 使用的绘图框架为 Echarts for Wexin 具体API文档地址请点击 ----> Step2 条件准备 1. ...
- 高德地图markers生成和点击
因为自己平时上班也是比较忙,遇到什么写什么,希望能给现在的你一些帮助,都是自己在工作中遇到的问题,给自己一个提醒,也是分享 相信很多人在做高德地图开发的时候,对于新手,官方的demo解读单个marke ...
- iOS高德地图让指定区域或者点显示在屏幕中间
对于高德地图也是一个新手,很多功能看文档,问技术 或者高德群里讨论 群号:204668425 在我们需求中绘制的有 圆 折线 不规则图形 方式,打开地图指定的绘制图形置于屏幕中间 1.首先创建一个数 ...
- 高德地图3D版的使用方法
坐标拾取器: http://lbs.amap.com/console/show/picker 其经纬度与LatLng()方法中的经纬度是对调的 SDK和实例下载: http://lbs.amap.co ...
- 【高德地图SDK】如何实现轨迹平滑移动?
很多人应该都有类似的经历,叫完车,想看看车离我还有多远距离?但手机屏幕上的车不是一动不动,就是一跳一跳的漂移. 目前市面上大多产品“轨迹平滑移动”做的并不好. 市面上只有快的打车和一号专车实现了平滑移 ...
- JS高德地图应用 ---- 鼠标点击加入标记 & POI搜索
代码如下 (填入Key值) : <!DOCTYPE html> <html> <head> <meta charset="utf-8"&g ...
- iOS高德地图使用-搜索,路径规划
项目中想加入地图功能,使用高德地图第三方,想要实现确定一个位置,搜索路线并且显示的方法.耗了一番功夫,总算实现了. 效果 WeChat_1462507820.jpeg 一.配置工作 1.申请key 访 ...
- 高德地图搜索提示获取信息回传activity刷新ui(二)
应用场景: 在主activity中点击进入到另一个activity搜索提示,获取经纬度,点确定返回到主activity,虽然说需求很奇葩,但是遇到了没办法.. 主要包含两部分,搜索提示+activit ...
- 【高德地图API】从零开始学高德JS API(四)搜索服务——POI搜索|自动完成|输入提示|行政区域|交叉路口|自有数据检索
原文:[高德地图API]从零开始学高德JS API(四)搜索服务——POI搜索|自动完成|输入提示|行政区域|交叉路口|自有数据检索 摘要:地图服务,大家能想到哪些?POI搜素,输入提示,地址解析,公 ...
随机推荐
- 超实用的mysql分库分表策略,轻松解决亿级数据问题
一.分库分表的背景 在数据爆炸的年代,单表数据达到千万级别,甚至过亿的量,都是很常见的情景.这时候再对数据库进行操作就是非常吃力的事情了,select个半天都出不来数据,这时候业务已经难以维系.不得已 ...
- CSS中的各种单位
单位 描述 ...
- Windows常用操作
目录 查询IP地址 常用快捷键 显示文件后缀名 查询IP地址 1.进入到dos界面 2.输入命令: ipconfig 常用快捷键 快捷键 作用 win+E 打开计算机 win+R 打开运行 win+R ...
- POWERSPLOIT-Exfiltration(信息收集)脚本渗透实战
Exfiltration模块 a) 调用Get-Keystrokes记录用户的键盘输入. 1)通过IEX下载并调用Get-Keystrokes. PS C:\Users\Administrator&g ...
- 关于seaJs合并压缩(gulp-seajs-combine )路径与文件ID匹配问题。
前段时间和有大家介绍过用 gulp-seajs-combine 来打包seaJs文件.大家会发现合并seaJs一个很奇怪的现象,那就是它的 ID和路径匹配原则.使得有些文件已经合并过去了,但还是会提示 ...
- [NOIp2012] luogu P1083 借教室
该*的英语,这么长还要背. 题目描述 你有 nnn 个数 ai{a_i}ai,mmm 次操作,每次操作将 [l,r][l,r][l,r] 区间的每个数减去 ccc.要求任何时刻 ∀x∈[1,n]\f ...
- CF401D Roman and Numbers 状压DP
CF401D 题意翻译 将n(n<=10^18)的各位数字重新排列(不允许有前导零) 求 可以构造几个mod m等于0的数字 题目描述 Roman is a young mathematicia ...
- 百万年薪python之路 -- 面向对象之三大特性
1.面向对象之三大特性 1.1封装 封装:就是把一堆代码和数据,放在一个空间,并且可以使用 对于面向对象的封装来说,其实就是使用构造方法将内容封装到 对象 中,然后通过对象直接或者self间接获取被封 ...
- 基于STM32F103和Cube的输入捕获例程
1.开发环境 (1)Cube5.24 (2)Keil5 (3)STM32F103 2.Cube配置 Cube配置很简单,只要打开TIM4通道1的引脚,设置为输入捕获模式,在配置是高或低电平沿触发 TI ...
- 你的 Java 并发程序 Bug,100% 是这几个原因造成的
可见性问题 可见性是指一个线程对共享变量进行了修改,其他线程能够立马看到该共享变量更新后的值,这视乎是一个合情合理的要求,但是在多线程的情况下,可能就要让你失望了,由于每个 CPU 都有自己的缓存,每 ...