html 多点直线,百度地图多点+画连接线+数字标注

(按钮)

(附近11)

var map; //Map实例

//后台传过来

var currentLat = 116.345555;

var currentLon = 40.018661;

var my ={ title: "我的位置"};

var markerArr = [

{ title: "1", point: "116.364531,40.057003"},

{ title: "2",point: "116.340934,40.013401"},

{ title: "3", point: "116.342213,40.041267"},

{ title: "4", point: "116.342223,40.042267"},

{ title: "5", point: "116.342233,40.043267"},

{ title: "6", point: "116.352243,40.044267"},

{ title: "7", point: "116.342253,40.045267"},

{ title: "8", point: "116.342263,40.046267"},

{ title: "9", point: "116.342273,40.047267"},

{ title: "10", point: "116.342283,40.087267"},

{ title: "11", point: "116.342293,40.097267"},

{ title: "12", point: "116.442203,40.007267"}

];

function map_init() {

map = new BMap.Map("map");

//第1步:设置地图中心点,当前城市

var point = new BMap.Point(currentLat,currentLon);

//第2步:初始化地图,设置中心点坐标和地图级别。

map.centerAndZoom(point, 14);

//第3步:启用滚轮放大缩小

map.enableScrollWheelZoom(true);

//第4步:向地图中添加缩放控件

var ctrlNav = new window.BMap.NavigationControl({

anchor: BMAP_ANCHOR_TOP_LEFT,

type: BMAP_NAVIGATION_CONTROL_LARGE

});

map.addControl(ctrlNav);

//第5步:向地图中添加缩略图控件

var ctrlOve = new window.BMap.OverviewMapControl({

anchor: BMAP_ANCHOR_BOTTOM_RIGHT,

isOpen: 1

});

map.addControl(ctrlOve);

//第6步:向地图中添加比例尺控件

var ctrlSca = new window.BMap.ScaleControl({

anchor: BMAP_ANCHOR_BOTTOM_LEFT

});

map.addControl(ctrlSca);

//第7步:绘制点

for (var i = 0; i < markerArr.length; i++) {

var p0 = markerArr[i].point.split(",")[0];

var p1 = markerArr[i].point.split(",")[1];

var maker = addMarker(new window.BMap.Point(p0, p1), i);

addInfoWindow(maker, markerArr[i]);

}

//绘制点

var points = new Array();

for (var i = 0; i < markerArr.length; i++) {

var p0 = markerArr[i].point.split(",")[0];

var p1 = markerArr[i].point.split(",")[1];

var thePoint1 = new BMap.Point(p0, p1);

points.push(thePoint1);

}

drawPolyline(map, points);

// 添加信息窗口

function addInfoWindow(marker, poi) {

// marker.setAnimation(BMAP_ANIMATION_BOUNCE); //跳动的动画

var label = new window.BMap.Label(poi.title, { offset: new window.BMap.Size(2, 1) });

marker.setLabel(label);

var clo="";

if("我的位置"==poi.title){

clo="#FF5782";

}else{

clo="#E6FED";

}

label.setStyle({

color: "#fff",

fontSize: "16px",

backgroundColor: "0.05",

border: "0",

fontWeight: "bold"

});

//maps.addOverlay(lab1);

var info = new window.BMap.InfoWindow("

" +poi.title+ "

"); // 创建信息窗口对象

marker.addEventListener("mouseover", openInfoWinFun);

var openInfoWinFun = function () {

this.openInfoWindow(info);

};

}

}

// 添加标注

function addMarker(point, index) {

index=11;

var 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)

});

var marker = new BMap.Marker(point, { icon: myIcon });

map.addOverlay(marker);

return marker;

}

//异步调用百度js

function map_load() {

var load = document.createElement("script");

load.src = "http://api.map.baidu.com/api?v=1.4&callback=map_init";

document.body.appendChild(load);

}

/**

* 画线

* @param bMap

* @param points

*/

function drawPolyline(bMap, points) {

if (points==null || points.length<=1) {

return;

}

bMap.addOverlay(new BMap.Polyline(points, {

strokeColor : "blue",

strokeWeight : 3,

strokeOpacity : 0.6

})); // 画线

}

window.onload = map_load;

原文:http://www.cnblogs.com/lvlina/p/6100828.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Vue2中实现高德地图的多点标注,你可以按照以下步骤进行操作: 1. 在Vue组件中引入高德地图的API,可以通过在`<head>`标签中添加`<script>`标签来引入高德地图的JavaScript API。 2. 在Vue组件中创建一个地图实例,可以使用`new AMap.Map`来实例化一个地图对象,并将其绑定到一个指定的DOM元素上。你可以使用以下代码创建地图实例: ```javascript map = new AMap.Map("container", { viewMode: "2D", zoom: 10, center: [83.28636635754393, 45.44533368853938], mapStyle: 'amap://styles/normal' }); ``` 这里的`"container"`是一个DOM元素的ID,表示地图将被渲染到该DOM元素中。 3. 在Vue组件中添加多个标记点,你可以使用`new AMap.Marker`来创建一个标记点对象,并将其添加到地图上。你需要为每个标记点指定一个位置(经纬度)和一个标记的图标。以下是一个添加标记点的示例代码: ```javascript marker1 = new AMap.Marker({ icon: "//a.amap.com/jsapi_demos/static/demo-center/icons/poi-marker-default.png", position: [116.406315, 39.908775], offset: new AMap.Pixel(-13, -30) }); marker2 = new AMap.Marker({ icon: "//a.amap.com/jsapi_demos/static/demo-center/icons/poi-marker-default.png", position: [经度, 纬度], offset: new AMap.Pixel(-13, -30) }); // 依次添加标记点到地图上 marker1.setMap(map); marker2.setMap(map); ``` 这里的`icon`表示标记点的图标,`position`表示标记点的位置(经纬度),`offset`表示标记点图标相对于位置的偏移量。 4. 最后,在Vue组件中显示地图和标记点。你可以在模板中添加一个包含地图的DOM元素,并将其样式设置为适当的大小。例如: ```html <template> <div id="map-container"></div> </template> <style> #map-container { width: 100%; height: 400px; } </style> ``` 这里的`map-container`是地图容器的ID,通过设置其宽度和高度来控制地图的大小。 通过按照以上步骤操作,你就可以在Vue2中实现高德地图的多点标注了。记得先引入高德地图的API,然后创建地图实例,并添加标记点到地图上。最后,在模板中显示地图容器即可。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [vue3实现高德地图多点标注(so easy)](https://blog.csdn.net/dyk11111/article/details/131002815)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值