欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

百度地图JS API GPS坐标转换成百度地图坐标(修改版)

程序员文章站 2022-06-10 10:50:35
...

在上一篇博客中做的GPS坐标转换成百度地图坐标的功能中,在实际工作中发现了一个问题,就是画出来的行车轨迹会有很多的漂移和往复,经过分析,是由于BMap.Convertor.translate()方法调用的时候,是通过异步的方法调用的,所以导致转换后的数据随机排列,并且还会出现掉数据点的情况,现在来修改一下。

出现数据随机排列的原因是我在取出数据来转换的时候是用for循环来的,如何想解决这个问题,循环结构肯定是不能用的,用就一定会出现上述的问题,只能通过全局变量来实现。

定义两个全局变量:

//______________________________这是地图中其他的变量

var Models = "${PathHistory}";// 获取后台行车轨迹的数据

var CoordinatesArr=Models.split("/");// 分割数据
var map = new BMap.Map("container");   // 创建地图实例  116.399, 39.910	
	
var pArr=[];// 装转换过后的数组
var centerPoint=null;// 地图中心坐标
var markerhead=null;// 全局的标注
	
//______________________________这是地图中其他的变量

var al=CoordinatesArr.length - 1;// 数据的长度
var now=0;// 计数变量

在函数中取出数据转换:

// 转换数据函数
function makeLine() {
    var Coordinates = CoordinatesArr[now].split(",");

    BMap.Convertor.translate(new BMap.Point(Coordinates[0],Coordinates[1]),0,translateCallback);
    now++;
}

转换之后调用回调函数:

//坐标转换完之后的回调函数
function translateCallback(point){
    pArr.push(point);
    setTimeout("makepoly()", 250);// 调用画轨迹的函数
}

然后再调用画行车轨迹的函数:

        // 在地图上画行车轨迹的函数
	function makepoly() {

		// 删除之前添加的标注
		map.removeOverlay(markerhead);
		
		centerPoint = new BMap.Point(pArr[now-1].lng, pArr[now-1].lat);  // 创建点坐标
		
		map.centerAndZoom(centerPoint, 18);// 初始化地图,设置中心点坐标和地图级别
		map.addControl(new BMap.MapTypeControl()); 
		map.enableScrollWheelZoom();

		var polyline = new BMap.Polyline(pArr, {strokeColor:"red", strokeWeight:3, strokeOpacity:0.5}); //颜色、宽度为3
		map.addOverlay(polyline); // 将路线添加到地图上
	
		//添加标注    画意摄影主义
		markerhead = new BMap.Marker(centerPoint);        // 在起点创建标注  
		map.addOverlay(markerhead);                     // 将标注添加到地图中 
		
		// 判断计数变量是否比数据长度小,是就继续转换
		if(now<al){
			makeLine();
		}
	}

这其中非常重要的就是后面的判断:

// 判断计数变量是否比数据长度小,是就继续转换
if(now<al){
    makeLine();
}

如果还没有转换完成就继续转换,这样形成一个循环,才能把数据全部转换完整。


下面贴出完整的页面:

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<%@ taglib prefix="s" uri="/struts-tags" %>

<!DOCTYPE>
<html xmlns="http://www.w3.org/1999/xhtml">
  <head>

  <meta content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, user-scalable=0;" name="viewport" />
  <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> 

  <s:iterator id="map" value="PathHistoryCoordinates" var="map" status="index"></s:iterator>

<title>行车轨迹</title>
<style type="text/css">
#container{height:100%; width:100%;}
</style>

<script type="text/javascript" src="http://api.map.baidu.com/api?v=1.5&ak=F23c57cf276323e3f60ab6bb90af4767"></script>
<script type="text/javascript" src="http://developer.baidu.com/map/jsdemo/demo/convertor.js"></script>

</head>

<body style='padding:0;margin:0;'>
 <!-- 地图图层 -->
 <div id="container"></div>

<script type="text/javascript">

	var Models = "${PathHistory}";// 获取后台行车轨迹的数据

	var CoordinatesArr=Models.split("/");// 分割数据
	var map = new BMap.Map("container");   // 创建地图实例  116.399, 39.910	
	
	var pArr=[];// 装转换过后的数组
	var centerPoint=null;// 地图中心坐标
	var markerhead=null;// 全局的标注
	
	var al=CoordinatesArr.length - 1;// 数据的长度
	var now=0;// 计数变量


	var pointhead = CoordinatesArr[0].split(",");
	// 判断!如果云端没有数据,则提示用户,并将坐标定位到北京
	if(pointhead[0] && pointhead[1]){
		makeLine();
	}else{
		var centerPoint = new BMap.Point(108.27589,22.810024);  // 创建点坐标  南宁108.27589,22.810024
		//alert("云端没有数据!");
		if(Models=="设备没有绑定车辆!"){
			alert("设备没有绑定车辆!");
		}else{
			alert("云端没有数据!");
		}
	}

	// 转换数据函数
	function makeLine() {
		var Coordinates = CoordinatesArr[now].split(",");
		//p.push(new BMap.Point(Coordinates[0],Coordinates[1]));

		BMap.Convertor.translate(new BMap.Point(Coordinates[0],Coordinates[1]),0,translateCallback);
		
		now++;
	}
	
	//坐标转换完之后的回调函数
	function translateCallback(point){
	   //alert(point.lng + "," + point.lat);
		pArr.push(point);

		setTimeout("makepoly()", 250);// 调用画轨迹的函数
	}
	
	// 在地图上画行车轨迹的函数
	function makepoly() {

		// 删除之前添加的标注
		map.removeOverlay(markerhead);
		
		centerPoint = new BMap.Point(pArr[now-1].lng, pArr[now-1].lat);  // 创建点坐标
		
		map.centerAndZoom(centerPoint, 18);// 初始化地图,设置中心点坐标和地图级别
		map.addControl(new BMap.MapTypeControl()); 
		map.enableScrollWheelZoom();

		var polyline = new BMap.Polyline(pArr, {strokeColor:"red", strokeWeight:3, strokeOpacity:0.5}); //颜色、宽度为3
		map.addOverlay(polyline); // 将路线添加到地图上
	
		//添加标注    画意摄影主义
		markerhead = new BMap.Marker(centerPoint);        // 在起点创建标注  
		map.addOverlay(markerhead);                     // 将标注添加到地图中 
		
		// 判断计数变量是否比数据长度小,是就继续转换
		if(now<al){
			makeLine();
		}
	}


</script> 

<div id="testdiv"> </div>

</body>  
</html>




转载于:https://my.oschina.net/hehongbo/blog/478496