高德地图实现多点标注marker和动态信息窗体[通俗易懂]

高德地图实现多点标注marker和动态信息窗体[通俗易懂]先说一下项目对地图的需求:在后台新增地图管理模块,要求,每一辆车都在地图上有标注,而且点击标注时要显示出车辆的相关信息,比如车牌和车辆的当前状态。下图就是实现的效果。当然从高德地图api也能查看到这一块,比如多点标注,简单信息窗体,这些都有api,可以先看官网的,然后,再看我这篇文章,怎么融合一起,记住数据全部来自后台数据库,这样才能保证一切数据都是动态的,可实时更新的。首

大家好,又见面了,我是你们的朋友全栈君。

先说一下项目对地图的需求:在后台新增地图管理模块,要求,每一辆车都在地图上有标注,而且点击标注时要显示出车辆的相关信息,比如车牌和车辆的当前状态。

下图就是实现的效果。

高德地图实现多点标注marker和动态信息窗体[通俗易懂]高德地图实现多点标注marker和动态信息窗体[通俗易懂]高德地图实现多点标注marker和动态信息窗体[通俗易懂]

当然从高德地图api也能查看到这一块,比如多点标注,简单信息窗体,这些都有api,可以先看官网的,然后,再看我这篇文章,怎么融合一起,记住数据全部来自后台数据库,这样才能保证一切数据都是动态的,可实时更新的。

首先,定义map,渲染出基础的地图。

var map = new AMap.Map('container', {
    resizeEnable: true,   
    zoom: 5
});  


center我就暂时没有定义会自动定位IP的地址获取中心点。接下里需要清除障碍物,全局几个变量,

map.clearMap();  
var markers = []; 
var infoWindow;


好的,接下里开始请求数据,数据主要包括坐标点和信息窗体要展示的参数,比如我的有车辆的运单号和车辆状态,车牌号等参数。

$.ajax({
	url : "eos_TranOrderFollowing/mapcartrans.do",
	type : "get",
	dataType : "json",

	success : function(e) {
		
		// var data=[{"fLong":'112.00003','fLati':'38.2345'},{"fLong":'115.00003','fLati':'38.2345'},{"fLong":'114.00003','fLati':'38.2345'},{"fLong":'116.00003','fLati':'38.2345'}];
		// e.data = data;
		var marker;		
		for(var i=0 ; i< e.data.length;i++){
			var jfong=[ e.data[i].fLong,e.data[i].fLati];	
				marker = new AMap.Marker({
			    position: jfong,
			    zIndex: 101,
			    map:map
				});	
				console.log(e.data[3]);	
			marker.setMap(map);	
			marker.orderON=e.data[i].orderON;
			marker.tranOFID=e.data[i].tranOFID;
			marker.fhadd=e.data[i].fhadd;
			marker.sAdd=e.data[i].sAdd;
			marker.status=e.data[i].status;			
			 marker.on('click', function(e){
				
				 infoWindow.setContent("<ul class='main'><li> 运单号: <span style='color:blue'>"+e.target.orderON+"</span></li>" 
				         + "<li>  派车单号: <span style='color:blue'>"+e.target.tranOFID+"  </span></li>" 
				         + "<li>  发货地址: <span style='color:blue'>"+e.target.fhadd+"  </span></li>"
				         + "<li>  收货地址: <span style='color:blue'>"+e.target.sAdd+"  </span></li>"
				         + "<li>  车辆状态 : <span style='color:blue'>"+e.target.status +"  </span></li></ul>");
				 infoWindow.open(map, e.lnglat);
			 });
			
			
		}	// for-end
		
		infoWindow = new AMap.InfoWindow({
			isCustom:	true,
			draggable: true,  //是否可拖动
	        offset: new AMap.Pixel(0, -31),
	        content:""
	    });
		
	}
		

}) //	Ajax结束



因为,我要展示的marker是很多的,后台返回的数据肯定不止1条,所以通过for循环,拿到所有的坐标,我定义的jfong变量,比如我的就有16个坐标点,然后定义marker,把position = jfong;这样就同样可以获得16个marker点了,然后添加标注图标icon,需要自定义图标的看下官网api很简单的。

marker.setMap(map);


这样多点的marker就实现了,接下来就是信息窗体了。因为我们需要在信息窗体展示的动态数据是在success:function(E)里面的,也就是在E里面。而点击图标时,执行的function(e),这个e是高德地图定义的,这里就需要把我们自己的参数赋值到这里面,也就是代码中的   marker.参数名称 = E.data[i].参数名称,通过这样的赋值后,捏可以打印一下(e)看下数据,然后通过e.Target.参数名称   就能够拿到了。信息窗体就不用多说了,把重点的参数赋值说明白就OK啦。我是自定义的信息窗体,通过setContent 动态设置了参数。


毕竟是自定义的信息窗体,所有肯定需要关闭按钮,样式自己随便写,只需要执行关闭自定义信息窗体事件即可

 function closeInfoWindow() {
        map.clearInfoWindow();
    }

好了,这样一个多点标注+动态信息窗体就轻松的实现了。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/143261.html原文链接:https://javaforall.net

(0)
上一篇 2022年5月11日 上午9:20
下一篇 2022年5月11日 上午9:40


相关推荐

  • idea断点调试总结

    idea断点调试总结一 设置条件断点也就是在调试时 想要在某个变量值为某一个特定值或符合其它条件时 能够将线程挂起 如图 如果 for 循环中定位问题 希望执行集合中的 id 为 369 的对象时能够将线程挂起 看看该对象为何执行报错 此时在如图所示弹框中设置表达式即可 注意使用 判断 就是要使条件表达式的结果为 boolean 类型 在弹出的对话框中有 Enabled 和 Suspend 选项 这 Enable 是断点是否启

    2026年3月26日
    4
  • AOP:使用命令模式实现AOP

    AOP:使用命令模式实现AOP

    2021年8月24日
    64
  • IDEA: 全局搜索 、全局查找

    IDEA: 全局搜索 、全局查找在使用Eclipse的时候用到了全局查找功能Ctrl+H,还是非常好用的, 在IDEA中同样有全局搜索功能,我用的是Eclipse版本的快捷键,是Ctrl+H。    特此查找记录,分享。…

    2022年6月28日
    43
  • AI经典案例_北京航空航天大学高小鹏

    AI经典案例_北京航空航天大学高小鹏来源:新智元本文约8000字,建议阅读10分钟本次报告评估了2016年至2021年间人工智能的发展,涵盖14大问题,探讨了人工智能发展的关键领域。时隔5年,由斯坦福大学教授李飞飞主导…

    2026年4月18日
    8
  • isnotempty和isnotnull_it is和it’s的区别是什么

    isnotempty和isnotnull_it is和it’s的区别是什么首先isNotEmpty和isNotBank都是判断字符是否为空,它是属于org.apache.commons.lang包下的(当然你可以可以采用其他包下的,或则自己造轮子)这里再说下俩者的区别,isNotEmpty是当字符对象null或则是&amp;quot;“时判定字符对象为空,isNotBlank也是当字符对象null或则是”“时判定字符对象为空,它还多一种情况判断,当字符对象为”&amp;quot;这种空白字符串(只有…

    2026年4月14日
    8
  • Python调用C语言实现数独计算逻辑提速100倍

    Python调用C语言实现数独计算逻辑提速100倍之前我们实现 python 自动玩数独游戏 详见 让程序自动玩数独游戏让你秒变骨灰级数独玩家 链接 https blog csdn net as article details 最终达到了这样的效果 中间我们将一个超难的数独算法耗时由 17 秒优化到 3 秒到 有读者提出能否计算数独的逻辑用 C 改写进一步提升性能 完全不会 C C 的我 在找到 c 语言大佬写的数独算法后 经过几十次尝试 顺利用 Python 调用了该算法 成功将程序优化到耗时 1 毫秒以内 下面看看操作流程

    2026年3月17日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号