【高德地图API】从零开始学高德JS API(一)地图展现——仙剑地图,麻点图,街景,室内图
摘要:关于地图的显示,我想大家最关心的就是麻点图,自定义底图的解决方案了吧。在过去,marker大于500之后,浏览器开始逐渐卡死,大家都开始寻找解决方案,比如聚合marker啊,比如麻点图啊。聚合marker里面还有一些复杂的算法,而麻点图,最让大家头疼的,就是如何生成麻点图,如何切图,如何把图片贴到地图上,还有如何定位图片的位置吧。以前那么复杂的一系列操作,居然让云图的可视化操作一下子解决了。现在只要点一点鼠标,麻点图就自动生成了。真是广大LBS开发者的福音。
以前写过从零开始学百度地图API系列,写得比较浅显。如今,自己在LBS领域成长了几年,学到比较多的专业知识,所以此次再次写到”从零系列”,希望加上更多功能,更多想法。比如这期的地图展现,不单单只是告诉大家,一张2D地图如何用代码写出来,同时,还会加上3D地图,卫星图,街景,交通流量图,麻点图,仙剑奇侠传地图等。也希望借此可以和大家更多的交流。
-----------------------------------------------------------------------
一、万物的首先第一步,当然是申请一个key。
申请key:http://yuntu.amap.com/datamanager/index.html
登录之后,点新建地图,就有一个自动的key了。
key在右上角密钥管理处
二、 2D地图
2D地图,就是一张普通的高德地图。只需要简单几句话就可以实现。
var mapObj;
var point = new AMap.LngLat(120.148373,30.290422);
function mapInit(){ //初始化地图对象,加载地图。mapObj = new AMap.Map("iCenter",{center : point, //地图中心点level : 15 //地图显示的缩放级别});
}
其中,level指的是地图级别,默认为[3,18]。3为世界地图,18为街道级地图。
center指的是地图的中心点,可以用坐标拾取工具来取点。坐标拾取工具:http://zhaoziang.com/amap/picpoint.html
2D效果图:
三、实时路况
添加实时路况,只需要两句话
var trafficLayer = new AMap.TileLayer.Traffic({zIndex:10}); //实时路况图层
trafficLayer.setMap(mapObj); //添加实时路况图层
消除实时路况有2种方法,一是隐藏hide方法,二是重置地图setMap(null)
trafficLayer.setMap(null); //隐藏实时路况图层
trafficLayer.hide(); //隐藏实时路况图层
实时路况效果:
四、路网,卫星图
路网、卫星图,都跟实时路况路况差不多,只是换了个类名。
添加路网、卫星图,只需要两句话
var roadNetLayer = new AMap.TileLayer.RoadNet({zIndex:10}); //实例化路网图层
roadNetLayer.setMap(mapObj); //在map中添加路网图层var satellLayer = new AMap.TileLayer.Satellite({zIndex:10}); //实例化卫星图
satellLayer.setMap(mapObj); //在map中添加卫星图
消除路网、卫星图,有2种方法,一是隐藏hide方法,二是重置地图setMap(null)
roadNetLayer.setMap(null); //隐藏路网
roadNetLayer.hide(); //隐藏路网satellLayer.setMap(null); //隐藏卫星图
satellLayer.hide(); //隐藏卫星图
路网、卫星图效果:
五、3D地图
3D地图,是在地图比较详细的级别17-18的时候,有三维楼块效果的地图。
所以,要看到3D效果,必须把地图级别调整到17-18才可以看到。
var buildingLayer = new AMap.Buildings(); //实例化3D地图图层
buildingLayer.setMap(mapObj); //在map中添加3D图层
mapObj.setZoom(18); //改变地图级别到17-18
3D地图没有hide方法,所以隐藏他,需要重置地图。
buildingLayer.setMap(null);
3D地图效果:
六、麻点图
(记得以前研究百度地图API的时候,麻点图的制作很苦难,要自己去对准坐标,自己生成麻点图,然后自己切片……实在费力……)
高德地图API最好用的就是麻点图。不用自己生成麻点图,不用自己切图。只需要在云图上点一点,就可以完成所有操作。
打开云图管理台:http://yuntu.amap.com/datamanager/index.html
新建或打开已有的地图:
点右上角的按钮,可以手工一个一个标注你自己的麻点。
当然也可以批量导入你的数据。
数据填充完毕后,记录下你的tableid。这就是你的云图层(麻点图)的id,放到下面的代码里。
//加载云图层插件 mapObj.plugin('AMap.CloudDataLayer', function () { var layerOptions = { query:{keywords: ''}, clickable:true }; var cloudDataLayer = new AMap.CloudDataLayer('【您的tableid】', layerOptions); //实例化云图层类 cloudDataLayer.setMap(mapObj); //叠加云图层到地图 });
云图层,就是麻点图,是实时渲染的,你在云图管理台操作之后,立马在你的前台得到显示。
这真是我用过最好用的麻点图了。marker大于500之后,终于有如此方便的解决方案了。
更多关于云图的教程,可以看我以前发过的教程
云存储:http://www.cnblogs.com/milkmap/p/3623775.html
三甲医院例子:http://www.cnblogs.com/milkmap/p/3637899.html
东莞酒店例子:http://www.cnblogs.com/milkmap/p/3657829.html
七、仙剑地图
这个算是投机取巧,将仙剑地图直接覆盖在高德地图上,属于图片覆盖物。
图片覆盖物需要指定一个显示范围,取左下角和右上角。
显示范围设定后,不管地图放大缩小,图片都只在这个范围中显示。
这样的图片覆盖物,比较适合制作校园地图,厂区地图,小区地图等。
而且,跟云图一样,图片覆盖物不需要切图。
(又想感叹一句!真真是开发者的福音!为何高德API做得那么好,之前我都不知道!!)
var bounds = new AMap.Bounds(new AMap.LngLat(120.120993,30.271596), new AMap.LngLat(120.184593,30.309171)), groundImageOpts = { opacity: 1, //图片透明度 clickable: true,//图片相应鼠标点击事件,默认:false map: mapObj //图片叠加的地图对象 }; //实例化一个图片覆盖物对象 var groundImage = new AMap.GroundImage('xianjian.jpg', bounds, groundImageOpts);
仙剑地图效果:
八、自定义地图
这里用谷歌的底图作为例子,将高德底图直接换为谷歌底图。跟上一段的内容不一样,不是图片覆盖物那么简单哦。
高德的切图方式,和谷歌的一样。所以,在网上找的谷歌地图的切图工具,都可以适用于高德地图。
google = new AMap.TileLayer({ tileUrl:"http://mt{1,2,3,0}.google.cn/vt/lyrs=m@142&hl=zh-CN&gl=cn&x=[x]&y=[y]&z=[z]&s=Galil"//图块取图地址 }); google.setMap(mapObj);
谷歌地图:
九、街景
高德地图街景覆盖城市共33个,分别为:杭州,南京,成都,西安,拉萨,昆明,烟台,沈阳,哈尔滨,长春,常州,南通,林芝,泰安,日照,那曲,东营,日喀则,德州,滨州,聊城,莱芜,郑州,洛阳,平顶山,开封,安阳,信阳,新乡,焦作,商丘,周口,驻马店。
使用街景,必须将您的网页文件传到服务器上。
var opts = { pov: { heading:270, pitch:0 }, position: point };
var panorama = new AMap.Panorama('iCenter',opts);
position,就是街景的位置,必须在33个城市有街景的范围内,才能看到街景哦。
可以先到amap上看一眼,哪里有街景,然后再设置您的街景位置。高德地图 http://www.amap.com/
街景效果:
十、全部源代码,请点击这里:
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>地图展示</title>
<link rel="stylesheet" type="text/css" href="zero.css" />
<script language="javascript" src="http://webapi.amap.com/maps?v=1.2&key=【您的key】"></script>
</head>
<body onLoad="mapInit()"><div id="iCenter"></div><div id="iControlbox"><p id="lnglat"></p><ul><li><button onclick="to2D();">2D地图</button><p>是一张普通的地图,地图级别是13。</p></li><li><button onclick="addTraffic();">实时路况</button><p>叠加上实时交通,路况信息。红色最堵。</p></li><li><button onclick="addRoadNetLayer();">路网</button><p>叠加上路网</p></li> <li><button onclick="yunLayer();">麻点图</button><p>麻点图,就是云图的云图层显示。</p></li> <li><button onclick="addsatellLayer();">卫星图</button><p>换上卫星图</p></li><li><button onclick="addBuildingLayer();">3D地图</button><p>显示3D楼块,只有地图级别在会显示。</p></li> <li><button onclick="googlMap();">自定义底图</button><p>自定义底图,是需要自己切图的。这里展示了谷歌的底图。</p></li><li><button onclick="xianjianLayer();">仙剑地图</button><p>显示的仙剑地图,感觉很帅。其实这是一个图片覆盖物,而不是图层。</p></li><li><button onclick="jiejing();">街景</button><p>显示街景,点了这个要刷新才能回来,哈哈。</p></li></ul></div>
</body>
<script language="javascript">
var mapObj;
var point = new AMap.LngLat(120.148373,30.290422);
var buildingLayer = new AMap.Buildings(); //实例化3D地图图层
var trafficLayer = new AMap.TileLayer.Traffic({zIndex:10}); //实时路况图层
var roadNetLayer = new AMap.TileLayer.RoadNet({zIndex:10}); //实例化路网图层
var satellLayer = new AMap.TileLayer.Satellite({zIndex:10}); //实例化卫星图
function mapInit(){ //初始化地图对象,加载地图。mapObj = new AMap.Map("iCenter",{center : point, //地图中心点level : 15 //地图显示的缩放级别});AMap.event.addListener(mapObj,'click',getLnglat); //点击事件
}
//鼠标点击,获取经纬度坐标
function getLnglat(e){ var x = e.lnglat.getLng();var y = e.lnglat.getLat(); document.getElementById("lnglat").innerHTML = x + "," + y;
}
function addBuildingLayer(){ //3D网buildingLayer.setMap(mapObj); //在map中添加3D图层satellLayer.setMap(null); //隐藏卫星图//cloudDataLayer.setMap(null);mapObj.setZoom(18);
}
function addTraffic(){ //交通,实时路况trafficLayer.setMap(mapObj); //添加实时路况图层roadNetLayer.setMap(null); //隐藏路网图层satellLayer.setMap(null); //隐藏卫星图//cloudDataLayer.setMap(null);mapObj.setZoom(15);
}
function addRoadNetLayer(){ //路网roadNetLayer.setMap(mapObj); //在map中添加路网图层trafficLayer.setMap(null); //隐藏实时路况图层satellLayer.setMap(null); //隐藏卫星图//cloudDataLayer.setMap(null);mapObj.setZoom(15);
}
function to2D(){buildingLayer.setMap(null);roadNetLayer.setMap(null);trafficLayer.setMap(null);mapObj.setZoom(15);groundImage.hide();google.setMap(null); //cloudDataLayer.setMap(null);
}
function addsatellLayer(){satellLayer.setMap(mapObj); //在map中添加卫星图buildingLayer.setMap(null);roadNetLayer.setMap(null);trafficLayer.setMap(null);//cloudDataLayer.setMap(null);mapObj.setZoom(18);
}function yunLayer(){buildingLayer.setMap(null);roadNetLayer.setMap(null);trafficLayer.setMap(null);mapObj.setZoom(15);//groundImage.hide();//加载云图层插件 mapObj.plugin('AMap.CloudDataLayer', function () { var layerOptions = { query:{keywords: ''}, clickable:true }; var cloudDataLayer = new AMap.CloudDataLayer('5358f853e4b01214f369d851', layerOptions); //实例化云图层类 cloudDataLayer.setMap(mapObj); //叠加云图层到地图 });
}
function xianjianLayer(){var bounds = new AMap.Bounds(new AMap.LngLat(120.120993,30.271596), new AMap.LngLat(120.184593,30.309171)), groundImageOpts = { opacity: 1, //图片透明度 clickable: true,//图片相应鼠标点击事件,默认:false map: mapObj //图片叠加的地图对象 }; //实例化一个图片覆盖物对象 var groundImage = new AMap.GroundImage('xianjian.jpg', bounds, groundImageOpts); //mapObj.setBounds(bounds); mapObj.setZoom(15);
}
function googlMap(){buildingLayer.setMap(null);//mapObj.setZoom(15);google = new AMap.TileLayer({ tileUrl:"http://mt{1,2,3,0}.google.cn/vt/lyrs=m@142&hl=zh-CN&gl=cn&x=[x]&y=[y]&z=[z]&s=Galil"//图块取图地址 }); google.setMap(mapObj);
}
function jiejing(){var opts = { pov: { heading:270, pitch:0 }, position: point }; var panorama = new AMap.Panorama('iCenter',opts);
}
</script>
</html>
示例demo在线看:
http://zhaoziang.com/amap/zero_1_1.html
效果预览:
【高德地图API】从零开始学高德JS API(一)地图展现——仙剑地图,麻点图,街景,室内图相关推荐
- 【高德地图API】从零开始学高德JS API(一)地图展现——仙剑地图,麻点图,街景,室内图...
原文:[高德地图API]从零开始学高德JS API(一)地图展现--仙剑地图,麻点图,街景,室内图 摘要:关于地图的显示,我想大家最关心的就是麻点图,自定义底图的解决方案了吧.在过去,marker大于 ...
- 转载:高德地图API学习 从零开始学高德JS API(一)地图展现
原文地址:https://www.cnblogs.com/milkmap/p/3687855.html [高德地图API]从零开始学高德JS API(一)地图展现--仙剑地图,麻点图,街景,室内图 摘 ...
- 【高德地图API】从零开始学高德JS API(四)搜索服务——POI搜索|自动完成|输入提示|行政区域|交叉路口|自有数据检索
原文地址为: [高德地图API]从零开始学高德JS API(四)搜索服务--POI搜索|自动完成|输入提示|行政区域|交叉路口|自有数据检索 摘要:地图服务,大家能想到哪些?POI搜素,输入提示,地址 ...
- 【高德地图API】从零开始学高德JS API(三)覆盖物——标注|折线|多边形|信息窗口|聚合marker|麻点图|图片覆盖物
原文地址为: [高德地图API]从零开始学高德JS API(三)覆盖物--标注|折线|多边形|信息窗口|聚合marker|麻点图|图片覆盖物 摘要:覆盖物,是一张地图的灵魂.有覆盖物的地图,才是完整的 ...
- java高德地图api开发平台_【高德地图API】从零开始学高德JS API(一)地图展现...
摘要:关于地图的显示,我想大家最关心的就是麻点图,自定义底图的解决方案了吧.在过去,marker大于500之后,浏览器开始逐渐卡死,大家都开始寻找解决方案,比如聚合marker啊,比如麻点图啊.聚合m ...
- 【高德地图API】从零开始学高德JS API(二)地图控件与插件——测距、圆形编辑器、鼠标工具、地图类型切换、鹰眼鱼骨
无论是控件还是插件,都是在一级API接口的基础上,进行二次开发,封装的一系列更加便于开发者使用,减少开发者工作量的二级API接口.除了官方通用的鱼骨.鹰眼控件,还有大量官方开发的地图插件,类似谷歌的l ...
- 【高德地图API】从零开始学高德JS API(六)坐标转换
摘要:如何从GPS转到谷歌?如何从百度转到高德?这些都是小case.我们还提供,如何将基站cell_id转换为GPS坐标? -------------------------------------- ...
- 【高德地图API】从零开始学高德JS API(六)——坐标转换
摘要:如何从GPS转到谷歌?如何从百度转到高德?这些都是小case.我们还提供,如何将基站cell_id转换为GPS坐标? -------------------------------------- ...
- 三维地图前端arcgis_【ArcGIS JS API + eCharts系列】实现二、三维网络路径图的绘制...
概述 前面两篇文章通过扩展EchartsLayer.js这个图层类,实现了使用ArcGIS JS API和eCharts,在二维和三维场景下绘制迁徙图和散点图.这篇文章继续通过绘制网络路径图的例子,再 ...
最新文章
- Vivado使用误区与进阶——如何读懂用好 Timing Report
- 如何将struct System.Byte byte []转换为C#中的System.IO.Stream对象?
- Android 线性布局(LinearLayout)相关官方文档 - 布局參数部分
- Vue.JS项目同时使用Element-UI与vue-i18n时实现国际化的方案
- docker 查看日志_8个优秀Docker容器监控工具,收藏了
- 瑞友客户端无法建立跟远程计算机的连接,瑞友天翼终端错误信息的原因以及解决方法大全.doc...
- SQL 语句 - Select(2): 指定表中的字段
- 数学建模:lingo软件学习心得
- 我解决了net framework 4安装失败,提示找不到指定文件的问题
- 【机器人学】正运动学详解
- 远程访问服务器上的Jupyterlab
- Ajax的网络响应时间
- WiFi慢不一定是信号不好,这几招让你上网更顺畅
- 【路径规划】样条曲线
- PSP - TMScore(US-align)、RMSD、Sequence 源码
- getInputStream() has already been called for this request
- JAVA:最大的行和列
- Linux配置环境变量不起作用
- win10远程桌面多用户登录
- js计算多少天过生日
热门文章
- python的元组是否能重复_python – 在带有元组的列表列表中查找重复项
- MT6737/MT6737T/MT6737M处理器功能介绍,MT6737芯片资料下载
- pytorch中的神经网络模块基础类——torch.nn.Module
- IP-guard苹果加密软件苹果系统加密Mac文档加密软件
- Google谷歌中国总裁李开复将离职创业
- 永不服输的Java之路---重学Java (第二章)
- 位移到速度的变化 matlab,单摆运动过程的matlabsimulink建模与仿真.doc
- 7-176 数列求和
- 全国计算机等级考试监考培训,全国计算机等级考试 (NCRE) 监考培训
- 神经网络预测鸢尾花的种类