高德地图 JS API 学习摘要1

1、安装

准备-入门-教程-地图 JS API

2、使用

1、在页面添加 JS API 的入口脚本标签,并将其中「您申请的key值」替换为您刚刚申请的 key;

<script type="text/javascript" src="https://webapi.amap.com/maps?v=1.4.12&key=您申请的key值"></script> 

2、添加div标签作为地图容器,同时为该div指定id属性;

<div id="container"></div> 

3、为地图容器指定高度、宽度;

#container {width:300px; height: 180px; }  

4、进行移动端开发时,请在head内添加viewport设置,以达到最佳的绘制性能;

<meta name="viewport" content="initial-scale=1.0, user-scalable=no"> 

JSAPI 1.3 开始完全支持 HTTPS 协议,如需使用安全协议,替换 JS API 的入口脚本URL中的httphttps即可。随着 ChromeiOS 等相继限制非安全域的定位请求,我们建议您升级网站到HTTPS协议,并使用HTTPS协议加载 JS API

3、API

创建地图
<div id="container"></div>
<script src="https://webapi.amap.com/maps?v=1.4.12&key=您申请的key值"></script>
<script>
    var map = new AMap.Map('container', {
        resizeEnable: true, //是否监控地图容器尺寸变化
        zoom:11, //初始化地图层级
        center: [116.397428, 39.90923] //初始化地图中心点
    });
</script>
地图加载完成

地图加载完成事件 map.on("complete")

map.on("complete", function(){
    log.success("地图加载完成!");  
});
地图的销毁 map.destroy()
document.querySelector("#destroy-btn").onclick = destroyMap;
function destroyMap() {
    map && map.destroy();
    log.info("地图已销毁");
}
异步加载地图

JSAPI引用地址url加上callback参数,异步调用JSAPI接口

var url = 'https://webapi.amap.com/maps?v=1.4.12&key=您申请的key值&callback=onApiLoaded';
var jsapi = document.createElement('script');
jsapi.charset = 'utf-8';
jsapi.src = url;
document.head.appendChild(jsapi);

// callback = onApiLoaded
function onApiLoaded(){
    var map = new AMap.Map('container', {
        center: [117.000923, 36.675807],
        zoom: 6
    });
    map.plugin(["AMap.ToolBar"], function() {
        map.addControl(new AMap.ToolBar());
    });
}
插件的使用

JS API 提供了众多的插件功能,这些功能不会主动随着 JSAPI 主体资源下发,需要引入之后才能使用这些插件的功能。

  1. 异步加载插件

异步加载指的是在 JS API 加载完成之后,在需要使用到某个插件的时候,通过AMap.plugin方法按需引入插件,在plugin回调之后使用插件功能。

var map = new AMap.Map('container',{
    zoom:12,
    center:[116.39,39.9]
});
AMap.plugin('AMap.ToolBar',function(){//异步加载插件
    var toolbar = new AMap.ToolBar();
    map.addControl(toolbar);
});
  1. 异步加载多个插件

AMap.plugin的第一个参数使用数组即可同时加载引入多个插件。

AMap.plugin(['AMap.ToolBar','AMap.Driving'],function(){//异步同时加载多个插件
    var toolbar = new AMap.ToolBar();
    map.addControl(toolbar);
    var driving = new AMap.Driving();//驾车路线规划
    driving.search(/*参数*/)
});
  1. 同步加载插件

可以在 JS API入口地址中添加plugin参数,将需要使用的一个或者多个插件的名称作为参数即可&plugin=AMap.ToolBar。 需要加载多个插件时,plugin参数中的插件名称之间以逗号分割。&plugin=AMap.ToolBar,AMap.Driving"

<script type="text/javascript" src="https://webapi.amap.com/maps?v=1.4.7&key=您申请的key值&plugin=AMap.ToolBar,AMap.Driving"></script> 
<script type="text/javascript" >
    var map = new AMap.Map('mapContainer',{
        zoom:12,
        center:[116.39,39.9]
    });
    var toolbar = new AMap.ToolBar();
    map.plugin(toolbar);
    var driving = new AMap.Driving();
    driving.search(/*参数*/)
</script>

  1. 插件列表
类名 功能说明
AMap.ElasticMarker 灵活点标记,可以随着地图级别改变样式和大小的 Marker
AMap.ToolBar 工具条,控制地图的缩放、平移等
AMap.Scale 比例尺,显示当前地图中心的比例尺
AMap.OverView 鹰眼,显示缩略图
AMap.MapType 图层切换,用于几个常用图层切换显示
AMap.Geolocation 定位,提供了获取用户当前准确位置、所在城市的方法
AMap.AdvancedInfoWindow 高级信息窗体,整合了周边搜索、路线规划功能
AMap.Autocomplete 输入提示,提供了根据关键字提示信息的功能
AMap.PlaceSearch 地点搜索服务,提供了关键字搜索、周边搜索、范围内搜索等功能
AMap.PlaceSearchLayer 搜索结果图层类,将搜索结果作为图层展示
AMap.DistrictSearch 行政区查询服务,提供了根据名称关键字、citycode、adcode 来查询行政区信息的功能
AMap.LineSearch 公交路线服务,提供公交路线相关信息查询服务
AMap.StationSearch 公交站点查询服务,提供途经公交线路、站点位置等信息
AMap.Driving 驾车路线规划服务,提供按照起、终点进行驾车路线的功能
AMap.TruckDriving 货车路线规划
AMap.Transfer 公交路线规划服务,提供按照起、终点进行公交路线的功能
AMap.Walking 步行路线规划服务,提供按照起、终点进行步行路线的功能
AMap.Riding 骑行路线规划服务,提供按照起、终点进行骑行路线的功能
AMap.DragRoute 拖拽导航插件,可拖拽起终点、途经点重新进行路线规划
AMap.ArrivalRange 公交到达圈,根据起点坐标,时长计算公交出行是否可达及可达范围
AMap.Geocoder 地理编码与逆地理编码服务,提供地址与坐标间的相互转换
AMap.CitySearch 城市获取服务,获取用户所在城市信息或根据给定IP参数查询城市信息
AMap.IndoorMap 室内地图,用于在地图中显示室内地图
AMap.MouseTool 鼠标工具插件
AMap.CircleEditor 圆编辑插件
AMap.PolyEditor 折线、多边形编辑插件
AMap.MarkerClusterer 点聚合插件
AMap.RangingTool 测距插件,可以用距离或面积测量
AMap.CloudDataLayer 云图图层,用于展示云图信息
AMap.CloudDataSearch 云图搜索服务,根据关键字搜索云图点信息
AMap.Weather 天气预报插件,用于获取未来的天气信息
AMap.RoadInfoSearch 道路信息查询,已停止数据更新,反馈信息仅供参考
AMap.Hotspot 热点插件,地图热点已默认开启,不用手动添加,由Map的 isHotspot 属性替代
AMap.Heatmap 热力图插件
中英文地图切换
var map = new AMap.Map('container', {
    resizeEnable: true,
    center: [121.498586, 31.239637],
    lang: "en" //可选值:en,zh_en, zh_cn
});

map.setLang('zh_cn'); // 中文
map.setLang('zh_en'); // 中英文对照
获取地图中心点/级别
  • map.getCenter()获取地图中心点
  • map.getZoom()获取地图缩放级别
设置地图中心点/级别
  • setCenter():改变地图中心点
  • setZoom():改变地图级别
  • setZoomAndCenter() :同时设置地图层级与中心点
map.setZoom(zoom); //设置地图层级 zoom 整数
map.setCenter([lng, lat]); //设置地图中心点 [经度、纬度] 保持6位小数点 toFixed(6)
map.setZoomAndCenter(zoom, [lng, lat]); //同时设置地图层级与中心点
绑定地图移动与缩放事件
map.on('moveend', callback);
map.on('zoomend', callback);
获取地图当前行政区
<script type="text/javascript" src='https://a.amap.com/jsapi_demos/static/demo-center/js/prety-json.js'></script>
<p><span id="map-city"></span></p>
map.getCity( function(info){
    console.log(info)
    var node = new PrettyJSON.view.Node({
        el: document.querySelector("#map-city"),
        data: info
    });
});    

使用map.getCity()获取地图当前中心所在行政区。回调函数的参数info对象拥有四个属性,province省份、city城市、citycode城市编码、district区。

new PrettyJSON.view.Node()接受一个参数对象渲染视图,el指定渲染的元素,data指定渲染的数据

设置地图当前行政区

map.setCity(xx)可以通过中文城市名、adcodecitycode等设置地图的中心点。(只支持中国境内)

设置/获取地图显示范围

通过map.getBounds()map.setBounds()设置/获取地图显示范围

var bounds = map.getBounds();
document.querySelector("#ne").innerText = bounds.northeast.toString();
document.querySelector("#sw").innerText = bounds.southwest.toString();

var mybounds = new AMap.Bounds([116.319665, 39.855919], [116.468324,39.9756]);
map.setBounds(mybounds);
限制地图显示范围
var limitBounds = map.getLimitBounds();// 获取地图限制区域信息
limitBounds.northeast.toString();
limitBounds.southwest.toString();
var bounds = map.getBounds(); // 获取显示范围
map.setLimitBounds(bounds); // 限制地图显示范围
map.clearLimitBounds(); // 取消限制
// 取消之后map.getLimitBounds()将获取不到值
地图的平移

除了鼠标、触摸交互,通过map.panBy()map.panTo()也可以移动地图

 var map = new AMap.Map('container', {
    resizeEnable: true,
    zoom: 13,
    center: [116.397428, 39.90923]
});

// 使用AMap.event.addDomListener监听DOM事件
AMap.event.addDomListener(document.getElementById('piexBtn'), 'click', function() {
    map.panBy(50, 100);// 平移多少 两个都是正值就是往左上平移
});
AMap.event.addDomListener(document.getElementById('pantoBtn'), 'click', function() {
    map.panTo([116.405467, 39.907761]); // 平移到哪去
});
交互控制

通过map.setStatus()修改地图的可拖拽、可缩放等状态。

var mapOpts = {
    showIndoorMap: false, // 是否在有矢量底图的时候自动展示室内地图,PC默认true,移动端默认false
    resizeEnable: true, //是否监控地图容器尺寸变化,默认值为false
    dragEnable: false, // 地图是否可通过鼠标拖拽平移,默认为true
    keyboardEnable: false, //地图是否可通过键盘控制,默认为true
    doubleClickZoom: false, // 地图是否可通过双击鼠标放大地图,默认为true
    zoomEnable: false, //地图是否可缩放,默认值为true
    rotateEnable: false // 地图是否可旋转,3D视图默认为true,2D视图默认false
}

var map = new AMap.Map('container', mapOpts);

   //通过map.setStatus方法动态设置地图状态
map.setStatus({
    dragEnable: true,
    keyboardEnable: true,
    doubleClickZoom: true,
    zoomEnable: true,
    rotateEnable: true
});
获取鼠标点击经纬度

给地图绑定click事`件,获取鼠标位置的经纬度坐标。

  • e.lnglat.getLng():获取经度
  • e.lnglat.getLat():获取纬度
map.on('click', function(e) {
    document.getElementById("lnglat").value = e.lnglat.getLng() + ',' + e.lnglat.getLat()
});
注册事件

Map、覆盖物等常用类,我们推荐直接使用这些类的对象的onoff成员方法来实现事件的简单绑定和移除

  • map.on : 注册事件,给Map或者覆盖物对象注册事件
  • map.off :移除事件绑定

使用AMap.event命名空间

  • AMap.event.addDomListener :注册DOM对象事件
  • AMap.event.addListener: 注册对象事件
  • AMap.event.addListenerOnce: 注册对象事件 但事件只会被触发一次,之后将自动移除
  • AMap.event.removeListener: 删除监听事件
  • AMap.event.trigger: 触发非DOM事件

MapsEvent 对象规范

  • lnglat: 发生事件时光标所在处的经纬度坐标。
  • pixel: 发生事件时光标所在处的像素坐标。
  • type: 事件类型。
  • target: 发生事件的目标对象。
输入自动提示 选择自动定位
// 引入Autocomplete插件
<script src="https://webapi.amap.com/maps?v=1.4.12&key=您申请的key值&plugin=AMap.Autocomplete"></script>

<input type="text"  id="tipinput">
var auto = new AMap.Autocomplete({
    input: "tipinput"
});

AMap.event.addListener(auto, "select", select);//注册监听,当选中某条记录时会触发
function select(e) {
    if (e.poi && e.poi.location) {
        map.setZoom(15);
        map.setCenter(e.poi.location);
    }
}
// 事件对象e拥有poi和type两个属性
select事件的事件对象
地图的热点

通过isHotspot开启地图的热点功能,并以

var map = new AMap.Map('container', {
    resizeEnable: true,
    center: [116.397428, 39.90923],
    zoom: 13,
    isHotspot: true
});
var placeSearch = new AMap.PlaceSearch();  //构造地点查询类
var infoWindow=new AMap.AdvancedInfoWindow({}); //高级信息窗体,整合了周边搜索、路线规划功能
map.on('hotspotover', function(result) {
    placeSearch.getDetails(result.id, function(status, result) {
        if (status === 'complete' && result.info === 'OK') {
            placeSearch_CallBack(result);
        }
    });
});
//回调函数
function placeSearch_CallBack(data) { //infoWindow.open(map, result.lnglat);
    var poiArr = data.poiList.pois;
    var location = poiArr[0].location;
    infoWindow.setContent(createContent(poiArr[0]));
    infoWindow.open(map,location);
}
function createContent(poi) {  //信息窗体内容
    var s = [];
    s.push('<div class="info-title">'+poi.name+'</div><div class="info-content">'+"地址:" + poi.address);
    s.push("电话:" + poi.tel);
    s.push("类型:" + poi.type);
    s.push('<div>');
    return s.join("<br>"); // 返回一个html字符串
}
设置鼠标样式

使用Map.setDefaultCursor设置地图默认的鼠标样式,用于自定义地图等场景。

map.setDefaultCursor("pointer");

// "default"  默认箭头
// "pointer"  指针
// "move"  可移动表示
// "crosshair"  十字线
// ...
覆盖物的添加与移除
  • new AMap.Marker() :构造标记
  • new AMap.Circle(): 构造矢量圆形
  • map.add(mark / circle): 添加标记
  • map.remove(mark / circle): 移除标记(与上接受相同的参数才能移除)
  • map.setFitView():有时候地图上可视化元素较多,我们需要地图调整合适的缩放等级和中心点,以保证所有元素都显示其中时,我们可以调用setFitView()方法,以实现该效果。
var map = new AMap.Map('container', {
    resizeEnable: true,
    zoom:11,
    center: [116.397428, 39.90923]
});
    // 构造点标记
var marker = new AMap.Marker({
    icon: "https://webapi.amap.com/theme/v1.3/markers/n/mark_b.png", // 标记点图片
    position: [116.405467, 39.907761] // 标记点位置
});
// 构造矢量圆形
var circle = new AMap.Circle({
    center: new AMap.LngLat("116.403322", "39.920255"), // 圆心位置
    radius: 1000,  //半径
    strokeColor: "#F33",  //线颜色
    strokeOpacity: 1,  //线透明度
    strokeWeight: 3,  //线粗细度
    fillColor: "#ee2200",  //填充颜色
    fillOpacity: 0.35 //填充透明度
});
//事件绑定
document.querySelector("#add-marker").onclick = function() {
    map.add(marker);
    map.setFitView();
}
document.querySelector("#remove-marker").onclick = function() {
    map.remove(marker);
    map.setFitView();
}
document.querySelector("#add-circle").onclick = function() {
    map.add(circle);
    map.setFitView();
}
document.querySelector("#remove-circle").onclick = function() {
    map.remove(circle);
    map.setFitView();
}
图层的添加与移除
// 构造官方卫星、路网图层
var satelliteLayer = new AMap.TileLayer.Satellite();
var roadNetLayer =  new AMap.TileLayer.RoadNet();

//批量添加图层
map.add([satelliteLayer, roadNetLayer]);

//事件绑定
document.querySelector("#add-satellite-layer").onclick = function() {
    map.add(satelliteLayer);
}

document.querySelector("#remove-satellite-layer").onclick = function() {
    map.remove(satelliteLayer);
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352

推荐阅读更多精彩内容

  • 自定义地图 指定Map.mapStyle属性,实现自定义样式地图。 使用Map.setMapStyle()方法,加...
    Upcccz阅读 3,469评论 2 1
  • 高德地图使用的基础方法 第一步:申请高德地图key码 申请地址:http://lbs.amap.com/dev/k...
    喵星汪汪阅读 4,376评论 0 7
  • Introduction WARNING: This plugin is best used with RPG M...
    沧笙阅读 3,754评论 0 21
  • 受不了这种夜里孤寂的清冷 好像支撑自己的信念突然崩塌 好像近视的度数都一下子加深 世界变得模糊起来 世界的不真切让...
    源靖乡阅读 264评论 1 0
  • 之一端午抒怀 让艾香绕着艾香让粽馅咬着粽馅从去年的端阳到今年的端阳在外漂泊已有一年的时间 从遥远的湖南来到了若大的...
    闲不语阅读 126评论 0 1