利用百度地图API实现gps坐标到百度坐标的批量坐标转换(如1000个点)

2024-05-12 17:38

本文主要是介绍利用百度地图API实现gps坐标到百度坐标的批量坐标转换(如1000个点),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.改写百度提供的批量转化js,实现一次请求100个坐标点

2.利用递归回调控制坐标转换的回传顺序,保证先请求的一组坐标(一组100个)先到达


首先我们来看一下百度地图api的demo里有两个坐标转换的例子:

        原始坐标转换成百度坐标:http://developer.baidu.com/map/jsdemo.htm#a5_2

        批量坐标转换:http://developer.baidu.com/map/jsdemo.htm#a5_3

        他们都使用了一个方法BMap.Convertor.translate(pointArr, 0, translateCallback);或者方法BMap.Convertor.transMore(pointsArray[posIndex], 0, callback);

        他们分别由百度提供的两个js实现:http://developer.baidu.com/map/jsdemo/demo/convertor.js(单个坐标转换接口)http://developer.baidu.com/map/jsdemo/demo/changeMore.js(这是批量转换接口),这里0表示转换前是GPS设备获取的角度坐标,方法里默认的type=4是转换后的百度地图采用的经纬度坐标,函数里mode=1表示是批量转换,但实际上从源码里获知,批量转换仍然受到一次只能请求20个坐标点的转换。

        所以我们改写百度提供的js文件,直接使用它的原生坐标转换api:http://developer.baidu.com/map/index.php?title=webapi/guide/changeposition 这里有关于这个api的参数的详尽解释,它一次请求的坐标数限制是100个。服务地址是:http://api.map.baidu.com/geoconv/v1/?例如,我们可以这样请求:

var positionUrl = "http://api.map.baidu.com/geoconv/v1/?coords=114.21892734521,29.575429778924;114.21892734521,29.575429778924&from=1&to=5&ak=您的密钥&callback="+callback;

下面我们实现自己的批量坐标转换(一次请求100个坐标点)

上面方法里引用的其它函数我们依然沿用百度提供的js的一些方法:

2.使用上面的坐标转换方法myTransMore

假设testJsonStr 可能是你要处理的一些位置信息,例如是这样的json对象数组:

var testJsonStr = [ //1000条数据

     {"deviceId":"0001", "name": "0001", "longitude":116.174008, "latitude":40.059728, "time":"2015-12-18 16:19:51"},

     {"deviceId":"0002", "name": "0002", "longitude":116.172708, "latitude":40.0603688, "time":"2015-12-18 15:44:36"},

     {"deviceId":"0003", "name": "0003", "longitude":116.174535, "latitude":40.059727, "time":"2015-12-18 09:31:19"},

        ......

     {"deviceId":"1000", "name": "1000", "longitude":116.37391967068, "latitude":39.981656, "time":"2015-12-18 16:59:34"} ]


利用递归回调控制坐标转换后回传的数据的顺序,使得先发出的坐标转换请求得到的数据先到达程序,如果不做控制,由于网络的原因,有可能后发的请求转换的数据却先到达了程序,这样你就不知道传回来的数据是谁的响应,即找不到纠偏后的坐标与纠偏前的坐标的对应关系了。








这篇关于利用百度地图API实现gps坐标到百度坐标的批量坐标转换(如1000个点)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/983292

相关文章

shell脚本批量导出redis key-value方式

《shell脚本批量导出rediskey-value方式》为避免keys全量扫描导致Redis卡顿,可先通过dump.rdb备份文件在本地恢复,再使用scan命令渐进导出key-value,通过CN... 目录1 背景2 详细步骤2.1 本地docker启动Redis2.2 shell批量导出脚本3 附录总

批量导入txt数据到的redis过程

《批量导入txt数据到的redis过程》用户通过将Redis命令逐行写入txt文件,利用管道模式运行客户端,成功执行批量删除以Product*匹配的Key操作,提高了数据清理效率... 目录批量导入txt数据到Redisjs把redis命令按一条 一行写到txt中管道命令运行redis客户端成功了批量删除k

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON:

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi