添加并删除Marker

var data=new Array();
// 定位、显示内容
function setLocation(x,y,name,time,speed,direction,GPSstatus,carstatus,warning,wstatus){//参数:经纬度...
//创建自定义图标
var pt = new BMap.Point(x, y);

//map.setCenter(pt); //设置地图中心点。center除了可以为坐标点以外,还支持城市名
//map.setZoom(15); //将视图切换到指定的缩放等级,中心点坐标不变

//map.centerAndZoom(pt,15);

var myIcon = new BMap.Icon("Images/car.png", new BMap.Size(32,32));
marker2 = new BMap.Marker(pt,{icon:myIcon}); // 创建标注
marker2.setTitle(name);
map.addOverlay(marker2); // 将标注添加到地图中

data.push(marker2); //将marker2放进数组

//添加一个Label
myLable = new BMap.Label("---",
{offset:new BMap.Size(25,-25),position:pt});
myLable.setTitle("---");
map.addOverlay(myLable);


var content="";

var warn=warning==""?"无":warning;

var sb=new StringBuilder();
sb.append("<div style='border:1px; background-color:#666666; height:1px;'></div>");
sb.append("<table style='font-size:12px; margin-top:3px;' width='100%' border='0' cellpadding='0' cellspacing='0'>");
sb.append("<tr><td style='color:#77AABF;'>时间:</td><td>"+ time +"</td><td style='color:#77AABF;'>速度方向:</td><td>"+ speed+"km/h,"+direction +"</td></tr>");
sb.append("<tr><td style='color:#77AABF;'>定位状态:</td><td>"+ GPSstatus +"</td> <td style='color:#77AABF;'>车辆状态:</td><td>"+ carstatus +"</td></tr>");
sb.append("<tr><td style='color:#77AABF;'>经度:</td><td>"+ x +"</td><td style='color:#77AABF;'>纬度:</td><td>"+ y +"</td></tr>");
sb.append("<tr><td style='color:#77AABF;'>报警信息:</td><td>"+ warn +"</td> <td style='color:#77AABF;'>报警状态:</td><td>"+wstatus+"</td></tr>");
sb.append("</table>");
//创建信息窗口
var opts = {
width : 320, // 信息窗口宽度
height: 120, // 信息窗口高度
title : "<font style='font-weight:bold;'>["+ name +"]</font>", // 信息窗口标题
enableMessage:false
}

var infoWindow2 = new BMap.InfoWindow(sb.toString(),opts);
marker2.addEventListener("click", function(){this.openInfoWindow(infoWindow2);});
}


//移除单个标记 - 待完善
function removeMarker(name){
alert(name);
for(var i=0;i<data.length;i++)
{
if (data[i].getTitle()==name) {
map.removeOverlay(data[i]);
}
}
//map.removeOverlay(myLable);
}

转载于:https://www.cnblogs.com/winnxm/p/4537107.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
高德地图提供了多种方法来移除marker。其中一种方法是使用方法一,即清除地图上所有的marker。你可以使用AMap对象的clear()方法来实现这一功能。例如,你可以使用以下代码来清除地图上的所有marker: AMap aMap = mapView.getMap(); aMap.clear(); \[2\] 另一种方法是使用方法二,即添加删除指定的marker。你可以使用Marker对象的remove()方法来删除指定的marker。首先,你需要获取地图上所有的marker,然后遍历这个marker列表,判断每个marker的类型,如果符合条件,就调用remove()方法来删除marker。例如,你可以使用以下代码来删除指定类型的marker: List<Marker> mapScreenMarkers = aMap.getMapScreenMarkers(); for (int i = 0; i < mapScreenMarkers.size(); i++) { Marker marker = mapScreenMarkers.get(i); if (marker.getObject() instanceof xxx) { marker.remove(); } } aMap.invalidate(); \[1\] 还有一种方法是利用集合分类管理marker,并通过visible属性来设置marker的显示或隐藏。你可以创建一个ArrayList来存储所有的marker,并使用setVisiable()方法来设置marker的显示或隐藏。例如,你可以使用以下代码来管理marker的显示或隐藏: ArrayList<Marker> list = new ArrayList<>(); MarkerOptions options = new MarkerOptions(); options.title("xxx").position(xxx).icon(xxx); Marker marker = aMap.addMarker(options); marker.setObject(xxx); list.add(marker); for(int i=0;i<list.size();i++){ Marker marker = list.get(i); marker.setVisible(xxx); } \[3\] 总结起来,高德地图提供了多种方法来移除marker,包括清除地图上所有的marker删除指定的marker以及通过集合分类管理marker来设置显示或隐藏。你可以根据自己的需求选择合适的方法来移除marker。 #### 引用[.reference_title] - *1* *2* *3* [高德地图Marker的管理(添加,删除)](https://blog.csdn.net/u010378579/article/details/53096864)[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^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值