<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta charset="UTF-8">
<title>百度地图API显示多个标注点带提示的代码</title>
<!--css-->
<style type="text/css">
body { margin: 0; font-family: "Helvetica,Arial,FreeSans"; color: #000000; font-size: 12px; }
.demo_main { padding: 20px; padding-top: 10px; }
.demo_title { padding: 10px; margin-bottom: 10px; background-color: #D3D8E0; border: solid 1px gray; }
.demo_content { padding: 10px; margin-bottom: 10px; border: solid 1px gray; }
fieldset { border: 1px solid gray; }
</style>
<!--javascript-->
<script src="http://www.w3school.com.cn/jquery/jquery.js" type="text/javascript"></script>
</head>
<body>
<div class="demo_main">
<fieldset class="demo_title">
百度地图API显示多个标注点带提示的代码
</fieldset>
<fieldset class="demo_content">
<div style="min-height: 800px; width: 100%;" id="map">
</div>
<script type="text/javascript">
let markerArr = [
{ title: "名称:合生汇苹果店", point: "116.485929,39.899881", address: "北京市朝阳区西大望路21号朝阳合生汇B2层-44a苹果专卖店"},
{ title: "名称:顺义华联店", point: "116.658409,40.133998", address: "北京市顺义区新顺南大街8号,华联顺义金街L1-55 "},
{ title: "名称:通州万达苹果", point: "116.647144,39.911961", address: "北京市通州区万达商场一层苹果专卖店"},
{ title: "名称:常营天街苹果店", point: "116.60353,39.930817", address: "北京市朝阳区长楹天街购物中心西区一层36号苹果店" },
{ title: "名称:望京凯德购物中心", point: "116.475079,39.998811", address: "北京市朝阳区长楹天街购物中心西区一层36号苹果店" },
{ title: "名称:石景山万达店", point: "116.231898,39.912079", address: "北京市朝阳区广顺北大街33号院215号楼01层(01)101内01-42号" },
{ title: "名称:五道口购物中心", point: "116.202423,39.59872", address: "北京市海淀区成府路28五道口购物中心一层101室20号DREAM ROOM苹果专卖" },
{ title: "名称:房山龙湖店", point: "116.147136,39.751717", address: "北京市房山区良乡拱辰北大街龙湖天街1L-02" },
{ title: "名称:五棵松华熙苹果", point: "116.283811,39.916725", address: "北京市海淀区复兴路69号16幢-1层-101" },
{ title: "名称:天通苑龙德广场苹果", point: "116.421907,40.066272", address: "北京市昌平区东小口镇立汤路186号院1号楼1层F1021、F1022" },
{ title: "名称:大兴大族广场", point: "116.520416,39.797548", address: "北京市大兴区北京经济技术开发区荣华南路2号院8号楼1层F1-13苹果" },
{ title: "名称:大兴龙湖店", point: "116.691295,39.878966", address: "北京市大兴区永兴路7号院1号楼龙湖大兴天街F1-58A" },
{ title: "名称:房山万科店", point: "116.216476,39.759352", address: "北京市房山区广阳新路9号院万科半岛广场购物中心1F-1082" },
{ title: "名称:房山熙悦天街", point: "116.191693,39.740022", address: "北京市房山区长于大街28号院3号楼A馆-1F-12苹果" },
{ title: "名称:旧宫万科苹果", point: "116.466038,39.811653", address: "北京市大兴区旧宫镇住总万科广场一层L1008" },
{ title: "名称:长安龙湖店", point: "116.129241,39.911662", address: "北京市门头沟区新城东街 17号院2号楼龙湖长安天街一层" },
{ title: "名称:丽泽龙湖天街", point: "116.341045,39.872105", address: "北京市丰台区丽泽路16号院1号楼1至5层105内2层03号" }
];
let map; //Map实例
function map_init() {
map = new BMap.Map("map");
//第1步:设置地图中心点,广州市
let point = new BMap.Point(116.303963, 39.915119);
//第2步:初始化地图,设置中心点坐标和地图级别。
map.centerAndZoom(point, 10);
//第3步:启用滚轮放大缩小
map.enableScrollWheelZoom(true);
//第4步:向地图中添加缩放控件
let ctrlNav = new window.BMap.NavigationControl({
anchor: BMAP_ANCHOR_TOP_LEFT,
type: BMAP_NAVIGATION_CONTROL_LARGE
});
map.addControl(ctrlNav);
//第5步:向地图中添加缩略图控件
let ctrlOve = new window.BMap.OverviewMapControl({
anchor: BMAP_ANCHOR_BOTTOM_RIGHT,
isOpen: 1
});
map.addControl(ctrlOve);
//第6步:向地图中添加比例尺控件
let ctrlSca = new window.BMap.ScaleControl({
anchor: BMAP_ANCHOR_BOTTOM_LEFT
});
map.addControl(ctrlSca);
let point_new = new Array(); //存放标注点经纬信息的数组
let marker = new Array(); //存放标注点对象的数组
//第7步:绘制点
for (let i = 0; i<markerArr.length; i++) {
let p0 = markerArr[i].point.split(",")[0];
let p1 = markerArr[i].point.split(",")[1];
point_new[i] = new window.BMap.Point(p0,p1);
marker[i]=new BMap.Marker(point_new[i]);
map.addOverlay(marker[i]);
addInfoWindow(marker[i], markerArr[i], i)
/* let maker = addMarker(new window.BMap.Point(p0, p1), i);
addInfoWindow(maker, markerArr[i], i);*/
}
}
// 添加标注
function addMarker(point, index) {
let myIcon = new BMap.Icon("http://api.map.baidu.com/img/markers.png",
new BMap.Size(23, 25), {
offset: new BMap.Size(10, 25),
imageOffset: new BMap.Size(0, 0 - index * 25)
});
let marker = new BMap.Marker(point, { icon: myIcon });
map.addOverlay(marker);
return marker;
}
// 添加信息窗口
function addInfoWindow(marker, poi) {
//pop弹窗标题
let title = '<div style="font-weight:bold;color:#CE5521;font-size:14px">' + poi.title + '</div>';
//pop弹窗信息
let html = [];
html.push('<table cellspacing="0" style="table-layout:fixed;width:100%;font:12px arial,simsun,sans-serif"><tbody>');
html.push('<tr>');
html.push('<td style="vertical-align:top;line-height:16px;width:38px;white-space:nowrap;word-break:keep-all">地址:</td>');
html.push('<td style="vertical-align:top;line-height:16px">' + poi.address + ' </td>');
html.push('</tr>');
html.push('</tbody></table>');
let infoWindow = new BMap.InfoWindow(html.join(""), { title: title, width: 200 });
let openInfoWinFun = function () {
marker.openInfoWindow(infoWindow);
};
marker.addEventListener("click", openInfoWinFun);
return openInfoWinFun;
}
//异步调用百度js
function map_load() {
let load = document.createElement("script");
load.src = "http://api.map.baidu.com/api?v=1.4&callback=map_init";
document.body.appendChild(load);
}
window.onload = map_load;
</script>
</fieldset>
</div>
</body>
</html>绿框注释 红框新增的
demo链接:
http://blog.csdn.net/a497785609/article/details/24009031
https://www.cnblogs.com/milkytea/p/6723481.html 你看这个博客就知道了
demo效果:
