
- 最近更新时间
- 2020年03月05日
- 覆盖范围
- 全球209个国家和地区
- 运营公司
- 北京百度网讯科技有限公司
- 品牌愿景
- 科技让出行更简单
- 类 型
- 服务性软件
- 软件类型
- 出行类应用软件
- 推出时间
- 2005年
- 中文名
- 百度地图 [1]
- 外文名
- Baidu Maps
- 软件大小
- 94.8M
- 运营平台
- Web,PC,Android,iOS
- 最新版本
- 10.23.0.965
- 特色功能
- 智能语音,AR步导,智能驾车导航
-
Python实现百度地图、高德地图地理编码及高德地图经纬度坐标转百度地图经纬度坐标
2020-04-27 15:02:19pyecharts的基础还是echart,echart是百度地图开源的一个数据可视化 JS 库,从我个人使用的情况来看,目前pyecharts(博主pyecharts版本是0.5.11)有这两个问题: 地图精度不够。目前pyecharts...引言
近期博主在做地理数据可视化方面的研究,pyecharts提供了较好的工具,里面提供了很多图形,尤其是Map和Geo这两种图,一种是地图,一种是地理信息图。pyecharts的基础还是echart,echart是百度地图开源的一个数据可视化 JS 库,从我个人使用的情况来看,目前pyecharts(博主pyecharts版本是0.5.11)有这两个问题:
- 地图精度不够。目前pyecharts提供的地图层级有世界地图、各个国家的地图、中国各省地图、中国各地市图、区县图,到区县后,就不再细分,如果我想看某条道路的具体信息,就难以实现。
- 经纬度定位“不准确”。这不属于pyecharts是问题,应该属于百度地图在地理编码上的特点,当然,并不是说百度地图地理编码不准确,而是博主的目前在做的项目,地理位置都比较奇特,不管是BaiduMap还是AMap(高德地图)都很难定位到特别准确。由于pyecharts的底层地图是百度地图,所以看起来是pyecharts定位“不准确”。
要解决第一个问题,就是说想要更高层级的地图,这个就需要换可视化包了,也就是说,将pyecharts改成具有其他更高层级地图的可视化包。博主使用的是folium,这个包也很强大,pyecharts的强大之处在与echart的可视化功能,folium则体现在地图及地图的扩展应用上。folium目前支持OpenStreetMap、AMap等几种地图,但不支持百度地图。一度吐血,为啥我用的这两个包底层地图就不能通用下。但其实也好,为了用好这两个包,博主对百度、高德这两大地图大佬的开发文档进行了研究,现在将二者地理编码的方式记录下来。
开发环境:- Python3.7;
- pyecharts0.5.11;
- pycharm
百度地图地理编码
开发文档看这里,使用前需要去申请AK,同时最好申请开发者认证,能提升访问限制。开发文档其实写的很详细,无非是爬虫get和json解析那一套,我直接上代码。
import json import pandas as pd import numpy as np from urllib.request import urlopen, quote import requests def Scene2CoordinateBaiduMap(filename): data = pd.read_csv(filename) result = [] i = 1 j = 1 for k in data['地点']: address = quote(k) # 1 url = 'http://api.map.baidu.com/geocoder/v2/?address=' + address + '&output=json&ak=yourAK' # 2 req = urlopen(url) res = req.read().decode() temp = json.loads(res) try: # 3 result.append(temp['result']['location']) print('catch %d \n' % i) i = i + 1 except: result.append({'lat': 'null', 'lng': 'null'}) print('fail %d \n' % j) j = j + 1 print('成功定位%d个,成功率%.2f%%' % (i - 1, (i - 1) * 100 / (i + j - 2))) df = pd.DataFrame(result) df.to_csv('经纬度原始数据-百度地图.csv', index=False) if __name__ == '__main__': main()
先看导入的包,访问百度地图API返回的都是json格式的数据,要对数据进行解析,自然少不了json包,pandas和numpy常规包,基本上很难不用到,后面两个是网页数据获取的包。高德地图地理编码也是这几个包,后面不再重复写。
几点说明:
#1quote函数是为了得到GBK的url编码,国内的网站编码都是GBK编码的;
#2要把url里面的AK改成你自己申请的AK,而不是yourAK这个字符串;
#3为啥要用try来处理,因为不是所有的地理编码都能成功,如果不用try处理,容易报错,程序会中断。
这个函数写的很详细了,你提供一个CSV文件,其中一列命名为‘地点’,就能将你的所有填写的地点都能转换成经纬度,当然,也有不成功的,总体成功率在95%左右。总体来说,定位效果还是可以的,但是如果地点数据很多填写的不规范,地理编码虽然解析出经纬度,但很多都是有问题的,比如解析出来的点不在正确的地点,如下图。
这些点本来应该都出现在无锡市地图上,但还有不少点在无锡市外,也就是说,解析的不正确。问题出在哪里?博主又回过头去看文档,文档里说,请求的参数除了address外,还有city,也就是城市,这个参数不是必须要写的,如果是写了这个,会不会就正确了呢?于是,我找了一个落在无锡地图之外的点,将请求网址写成这样:http://api.map.baidu.com/geocoding/v3/?address=南湖大道双庆桥公交站前&city=无锡市&output=json&ak=您的ak&callback=showLocation
返回的数据如下:
showLocation&&showLocation({"status":0,"result":{"location":{"lng":120.31700801956372,"lat":31.532789952709309},"precise":0,"confidence":50,"comprehension":24,"level":"桥"}})
根据经纬度去百度地图拾取坐标系统中看看,巧了,点还对了。。。
博主懵逼了,上午的时候,明明是不对的,所以才想到要写一篇博客来解决这个问题,回过头来一想,因为我上午写的请求网址是这样的:http://api.map.baidu.com/geocoding/v3/?address=南湖大道双庆桥公交站前&city='无锡市'&output=json&ak=您的ak&callback=showLocation
无锡市我打了引号,其实是没必要打引号的。。。
所以,实际上,在请求网址里面加上城市名,就能保证经纬度转换的时候,所有点都落在你想要的城市里面。。。
持续吐血,这篇博客还要写吗,我上午已经按照我的解决思路,高德地图地理编码→高德地图转百度地图→pyecharts地点上图,这个套路,解析了3000+的地点。
都写了3000多字了,还是继续写完吧。。。高德地图地理编码
开发文档看这里
,技术细节与百度地图基本一致,请求格式上我换了一种写法,让读者可以更灵活的使用爬虫的技巧。
上代码def Scene2CoordinateAMap(filename): data = pd.read_csv(filename) sgdd = data['事故地点'].tolist() geo = [] key = 'yourKEY' base = 'https://restapi.amap.com/v3/geocode/geo' j = 1 k = 1 for i in range(len(sgdd)): parameters = {'address': sgdd[i], 'key': key, 'city':'无锡'} response = requests.get(base, parameters) answer = response.json() try: pos = answer['geocodes'][0]['location'] pos = pos.split(',') pos[0], pos[1] = pos[1], pos[0] geo.append(pos) print('catch %d \n'%j) j = j + 1 except: geo.append([ 'null','null']) print('fail %d \n'%k) k = k + 1 points = pd.DataFrame(geo) points.to_csv('经纬度填充-高德地图.csv', index=False, columns = ['lng', 'lat']) print('成功定位%d个,成功率%.2f%%' % (j - 1, (j - 1) * 100 / (j + k - 2)))
为啥我会写成‘无锡’,能理解了吧,我高德就是这么写的。。。
可以看出来,和百度地图请求方式有一点不同,我用的是requests.get去请求的,其实网上更多的推荐是用这种方式去请求,而不是用urlopen,不过我个人习惯用urlopen,两者都行吧。高德地图经纬度转百度地图经纬度
其实已经没啥必要写了,因为二者都差不多。
文档看这里,上代码def AMap2BaiduMap(filename): data = pd.read_csv(filename) base = 'http://api.map.baidu.com/geoconv/v1/?coords=' tail = '&from=3&to=5&ak=yourAK' transpos = [] j = 1 k = 1 for i in range(len(data)): url = base + str(data.iloc[i]['lng_Amap']) + ',' + str(data.iloc[i]['lat_Amap']) + tail req = urlopen(url) res = req.read().decode() temp = json.loads(res) try: pos = list(temp['result'][0].values()) # 字典转列表 transpos.append(pos) print('catch %d \n'%j) j = j + 1 except: transpos.append(['null','null']) print('fail %d \n'%k) k = k + 1 tran = pd.DataFrame(transpos) tran.to_csv('高德转百度.csv', index=False, columns = ['lng', 'lat']) print('成功转换%d个,成功率%.2f%%' % (j - 1, (j - 1) * 100 / (j + k - 2)))
注意下,链接里有这么句代码
from=3&to=5
官方文档解释如下:
源坐标类型:
1:GPS设备获取的角度坐标,WGS84坐标;
2:GPS获取的米制坐标、sogou地图所用坐标;
3:google地图、soso地图、aliyun地图、mapabc地图和amap地图所用坐标,国测局(GCJ02)坐标;
4:3中列表地图坐标对应的米制坐标;
5:百度地图采用的经纬度坐标;
6:百度地图采用的米制坐标;
7:mapbar地图坐标;
8:51地图坐标
目标坐标类型:
5:bd09ll(百度经纬度坐标);
6:bd09mc(百度米制经纬度坐标)我是高德经纬度转百度经纬度,自然是from=3to=5。
看看转换经纬度后的pyecharts-Geo图吧
全都在无锡市内了,大功告成,虽然没啥用了(╥╯^╰╥)完
-
百度地图接口爬取城市数据district_id
2020-12-16 16:48:07通过百度地图接口爬取百度地图城市数据,并存到mysql数据库里面: #!/usr/bin/python # coding=utf-8 import sys,time reload(sys) sys.setdefaultencoding("utf-8") import requests, traceback import json ...有问题可以联系本人QQ:1016401546,备注来意,否则不加
附件为通过百度地图接口爬取百度地图城市数据,并存到mysql数据库里面,信息表和脚本下载:
链接:https://pan.baidu.com/s/1w--dvalstFILrENbK4TasA
提取码:y71b
复制这段内容后打开百度网盘手机App,操作更方便哦--来自百度网盘超级会员V1的分享部分数据展示:
接口返回数据类型:
-
修复百度地图乱码
2019-04-17 09:58:46定位标注图标消失是因为原来的icon图片没有了,将 new BMap.Icon("http://app.baidu.com/map/images/us_mk_icon.png" /*修改为*/ ...中文乱码是因为生成的网页代码中,charset设置成gbk了,将 ......定位标注图标消失是因为原来的icon图片没有了,将
new BMap.Icon("http://app.baidu.com/map/images/us_mk_icon.png"
/*修改为*/new BMap.Icon("http://map.baidu.com/image/us_mk_icon.png"
中文乱码是因为生成的网页代码中,charset设置成gbk了,将
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
/*修改为*/<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
-
vue使用百度地图----在线地图
2020-10-09 11:31:23Part1 在线地图 1、安装组件 npm install vue-baidu-map --save ... ak: '**********************' //此处为百度地图秘钥 }); 百度AK秘钥申请地址 3、HTML部分 <div id="baidu_map"> <baidu-ma1、安装组件
npm install vue-baidu-map --save
2、在main.js中引入组件
import BaiduMap from 'vue-baidu-map Vue.use(BaiduMap, { ak: '**********************' //此处为百度地图秘钥 });
3、HTML部分
<div id="baidu-map"> <baidu-map class="bm-view" :center="map.center" :zoom="map.zoom" @ready="ready" :map-click="false" @load="loadMap" @zoomend="syncCenterAndZoom"> <!--缩放--> <bm-navigation anchor="BMAP_ANCHOR_TOP_RIGHT"></bm-navigation> <!--定位--> <bm-geolocation anchor="BMAP_ANCHOR_BOTTOM_RIGHT" :showAddressBar="true" :autoLocation="true"></bm-geolocation> <!--点--> <bm-marker v-for="(item,index) in map.markList" :key="index" :position="item.position" animation="BMAP_ANIMATION_DROP" @click="markClick(index)" :dragging="true" :icon="item.icon" @dragend="markChange"> </bm-marker> <!--提示信息--> <bm-info-window :width="350" :height="220" :show="windowData.isShow" :position="windowData.position" :title="windowData.title" @open="infoWindowOpen" @close="infoWindowClose"> <div @click="windowClick(windowData)"> <el-row :gutter="23"> <el-col :span="10" style="text-align: center; margin-top: 30px"> <el-image :src="windowData.picUrl" style="width: 120px; height: 120px;" > </el-image> </el-col> <el-col :span="13" style="text-align:left; margin-top: 10px;"> <div :class="alarmClassName(windowData.powerSwitch)"> 总闸:<span :class="spanClass(windowData.powerSwitch)">{{windowData.powerSwitch}}</span> </div> <div :class="alarmClassName(windowData.power)"> 市电:<span :class="spanClass(windowData.power)">{{windowData.power}}</span> </div> <div :class="alarmClassName(windowData.net)"> 主网络:<span :class="spanClass(windowData.net)">{{windowData.net}}</span> </div> <div :class="alarmClassName(windowData.deviceState)"> 设备状态:<span :class="spanClass(windowData.deviceState)">{{windowData.deviceState}}</span> </div> </el-col> </el-row> </div> </bm-info-window> </baidu-map> </div>
4、JS数据及方法
<script> const level_99_url = ''; const defaupicUrl = ''; export default { data(){ return{ map: { isShow: false, center: { lng: 116.2917, lat: 39.8427 }, zoom: 10, markList: [{ index:1, position: { lng: 116.2917, lat: 39.8427 }, faultLevel: 99, id: 1, name: '点位1', icon: { url: level_99_url, size: { width: 25, height: 25 } }, ip: '', picUrl: defaupicUrl, powerSwitch: '', power: '', net: '', deviceState: '', }], clickMarkIndex: '', }, windowData: { isShow: false, title: '', id: '', position: {}, powerSwitch: '', //总闸 power: '', //市电 net: '', //主网络 deviceState: '', //设备状态 picUrl: '', faultLevel:'', } } }, methods:{ //地图滚动 syncCenterAndZoom(e) { this.map.zoom = e.target.getZoom(); }, //初始化地图 ready({BMap, map}) { console.log(BMap, map); // 鼠标缩放 map.enableScrollWheelZoom(true); // 点击事件获取经纬度 map.addEventListener('click', function (e) { console.log(e.point.lng, e.point.lat) }); // 自定义样式 map.setMapStyle({ styleJson: [ { "featureType": "road", "elementType": "all", "stylers": { "lightness": 20 } }, { "featureType": "highway", "elementType": "geometry", "stylers": { "color": "#f49935" } }, { "featureType": "railway", "elementType": "all", "stylers": { "visibility": "off" } }, { "featureType": "local", "elementType": "labels", "stylers": { "visibility": "off" } }, { "featureType": "water", "elementType": "all", "stylers": { "color": "#d1e5ff" } }, { "featureType": "poi", "elementType": "labels", "stylers": { "visibility": "off" } } ] }); }, //标记点击事件 markClick(index) { this.map.clickMarkIndex = index; this.infoWindowOpen(); }, //信息窗体打开 infoWindowOpen() { this.windowData.isShow = true; var index = this.map.clickMarkIndex; this.windowData.id = this.map.markList[index].id; this.windowData.title = this.map.markList[index].name; this.windowData.position = this.map.markList[index].position; this.windowData.picUrl = this.map.markList[index].picUrl; this.windowData.faultLevel = this.map.markList[index].faultLevel; this.$nextTick(()=>{ if (this.windowData.faultLevel === 1) { //document.documentElement.style.setProperty('--box_background', 'rgba(8, 120, 18, 0.6)'); document.getElementsByClassName('BMap_pop')[0].childNodes[8].style.backgroundColor = 'transparent'; document.getElementsByClassName('BMap_pop')[0].childNodes[8].style.backgroundColor = 'rgba(253, 4, 95, 0.6)' } else if (this.windowData.faultLevel === 2) { //document.documentElement.style.setProperty('--box_background', 'rgba(255, 156, 1, 0.6)'); document.getElementsByClassName('BMap_pop')[0].childNodes[8].style.backgroundColor = 'transparent'; document.getElementsByClassName('BMap_pop')[0].childNodes[8].style.backgroundColor = 'rgba(255, 156, 1, 0.6)' } else if (this.windowData.faultLevel === 3) { //document.documentElement.style.setProperty('--box_background', 'rgba(226, 223, 30, 0.6)'); document.getElementsByClassName('BMap_pop')[0].childNodes[8].style.backgroundColor = 'transparent'; document.getElementsByClassName('BMap_pop')[0].childNodes[8].style.backgroundColor = 'rgba(226, 223, 30, 0.6)' } else if (this.windowData.faultLevel === 4) { //document.documentElement.style.setProperty('--box_background', 'rgba(8, 120, 18, 0.6)'); document.getElementsByClassName('BMap_pop')[0].childNodes[8].style.backgroundColor = 'transparent'; document.getElementsByClassName('BMap_pop')[0].childNodes[8].style.backgroundColor = 'rgba(0, 234, 220, 0.6)' } else{ //document.documentElement.style.setProperty('--box_background', 'rgba(8, 120, 18, 0.6)'); document.getElementsByClassName('BMap_pop')[0].childNodes[8].style.backgroundColor = 'transparent'; document.getElementsByClassName('BMap_pop')[0].childNodes[8].style.backgroundColor = 'rgba(8, 120, 18, 0.6)' } }) }, //信息窗体关闭 infoWindowClose() { this.windowData.isShow = false; this.windowData.faultLevel = '' }, //信息窗体点击事件 windowClick(id) { console.log(id) }, //信息窗体打开 bfClassName(faultLevel) { if (faultLevel === 1) { return 'bg_level_1' } else if (faultLevel === 2) { return 'bg_level_2' } else if (faultLevel === 3) { return 'bg_level_3' } else if (faultLevel === 4) { return 'bg_level_4' } else{ return 'bg_level_99' } }, //设置报警图标样式 alarmClassName(data) { if (data === '正常' || data === '-/-' || data[0] === '0') { return 'alarm_normal'; } else { return 'alarm_abnormal'; } }, //设置状态信息颜色 spanClass(data) { if (data === '正常' || data[0] === '0') { return 'span_normal'; } else if (data === '-/-') { return 'span_no_device'; } else { return 'span_abnormal'; } }, //标记点移动事件 markChange(params){ this.map.center.lat = params.point.lat; this.map.center.lng = params.point.lng; }, getMarkList(){ }, //加载数据(如果数据是异步加载) loadMap(){ this.getMarkList(); }, }, mounted() { } } </script>
**注:**上述代码,用到了this.$nextTick,这是在vue中如果要对dom进行操作,在此方法中可以保证dom节点已加载完成,vue中是以数据驱动的形式来渲染dom的,也就是说数据修改后,dom不会马上改变,它会排队等待修改。
5、CSS样式部分
<style > #baidu-map{ height: 100vh; } .bm-view { width: 100%; height: 100%; } /* 去除百度地图版权那行字 和 百度logo */ .bm-view .BMap_cpyCtrl { display: none !important; } .bm-view .anchorBL { display: none !important; } /*左上角*/ .BMap_pop div:nth-child(1) div { background-color: transparent !important; border-left: 0px !important; border-top: 0px !important; } /*右上角*/ .BMap_pop div:nth-child(3) div { display:none; } /*左下角*/ .BMap_pop div:nth-child(5) { display:none; } /*右下角*/ .BMap_pop div:nth-child(7) { display:none; } /*箭头部分*/ .BMap_pop div:nth-child(8) { display:none; } /*主体内容部分*/ .BMap_pop div:nth-child(9) { left: 0px !important; top: 0px !important ; font-size: 15px; color: #fff; line-height: 39px; width: 100% !important; height: 110% !important; background-color: var(--box_background); } /*顶中间*/ .BMap_pop .BMap_top{ display:none; } /*底中间*/ .BMap_pop .BMap_bottom{ display:none; } .BMap_pop .BMap_center { position: initial !important; border-left: 0px solid #ababab !important; border-right: 0px solid #ababab !important; background-color: transparent !important; } .BMap_bubble_title { color: #FFF; font-weight: bold; text-align: center; line-height: 35px; font-size: 18px; margin: 7px; } .alarm_normal{ color: #fff; line-height: 39px; font-size: 14px; } .alarm_normal:before{ content: ""; float: left; width: 20px; height: 20px; margin-right: 13px; margin-top: 8px; background-position: center center; background-image: url("../../../static/img/ElectronicMap/map.jk.one.png"); } .alarm_abnormal{ color: #fff; line-height: 39px; font-size: 14px; } .alarm_abnormal:before{ content: ""; float: left; width: 20px; height: 20px; margin-right: 13px; margin-top: 9px; background-position: center center; background-image: url("../../../static/img/ElectronicMap/map.jk.three.png"); } .span_normal{ color: #6ef22d; } .span_abnormal{ color: #fd0433; } .span_no_device{ color: rgb(74, 74, 74); font-weight: bolder; } .bg_level_1{ background: rgba(253, 4, 95, 0.7) } .bg_level_2{ background: rgba(255, 156, 1, 0.7) } .bg_level_3{ background: rgba(226, 223, 30, 0.7) } .bg_level_4{ background: rgba(0, 234, 220, 0.7) } .bg_level_99{ background: rgba(8, 120, 18, 0.7) } </style>
6、效果图
-
百度地图坐标系统解析
2019-06-22 14:55:52在地球上我们通过经纬度来描述某个位置,而经过投影之后的地图也有自己的坐标系统,本篇文章就来详细介绍在百度地图API中涉及的各种坐标体系。 在百度地图API中,你需要了解如下坐标系: 经纬度:通过经度... -
百度地图BaiduMap_AndroidSDK_v6.4.0中的路线规划功能为啥不可用???
2020-07-30 23:21:52百度地图BaiduMap_AndroidSDK_v6.4.0中的路线规划功能为啥不可用??? 百度地图例子BaiduMap_AndroidSDK_v6.4.0_Sample 中的路线规划都不可用?????[face]monkey:35.gif[/face] [img=... -
百度地图 创建应用
2019-09-25 23:55:281、你要使用百度地图的服务,就先要去百度地图开放平台创建一个应用,从而获取到一个大多数的Api服务都要用到的Key。连接地址:百度地图开放平台。 2、点击控制台。 3、点击创建应用 4、随便输一个应用名称,... -
常用的几种在线地图(天地图、百度地图、高德地图)坐标系之间的转换算法
2019-01-14 16:39:371、首先弄明白几种在线地图的坐标系; (1)天地图:CGCS2000,2000国家大地坐标系;我们其实很多时候直接用WGS84的坐标来代替CGCS2000坐标。因为CGCS2000的定义与WGS84实质一样。采用的参考椭球非常接近。扁率差异... -
百度地图自定义覆盖物工具栏,修改标识图标
2020-04-09 13:36:17drawingManager工具栏 drawingModes设置工具栏模式 直接上效果代码 <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html;...meta name="viewport" co... -
百度地图升级4:给点添加弹框
2020-05-25 17:29:10// 设置弹框的格式 var opts = { boxStyle: { width: "280px", height: "120px", }, enableAutoPan: true, }; //根据判断设置图标--排口 .. -
使用Python调用百度地图的API在地图上添加标记
2020-12-14 15:54:26地图的底图不支持百度地图,博主想用这个包的话,就不得不将数据点转到高德坐标系下,然后进行下一步工作,然而高德莫名其妙的封了我的账号,说我违规调取数据,简直莫须有; 间歇性的出现一些未知的问题,比如添加... -
百度地图POI数据获取
2019-01-17 00:57:06本文主要介绍百度地图POI数据获取:从百度地图得到POI数据,以json格式保存; POI数据获取的原理部分还可以参照零基础掌握百度地图兴趣点获取POI爬虫(python语言爬取)(基础篇)。 POI数据获取 百度地图POI数据... -
通过百度地图API获取用户所在地理位置信息
2020-10-18 21:42:38使用以下源码前,请先去百度地图开发平台申请密匙,前去申请:立即申请 2、源代码 此次定位代码是通过H5的方式实现的 <html> <head> <meta http-equiv="Content-Type" content="text/html; ... -
百度地图,地图轨迹
2020-06-06 21:20:20百度地图,记录行动轨迹: 效果图: 上代码: <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <meta name="viewport... -
使用百度地图绘制热力图
2018-01-30 10:01:51首先需要到百度地图开放平台注册开发者信息,并且获得AK应用访问标识码 因为要做本地调用,所以Referer白名单里面只写一个*就全允许了,拿到AK码之后写个HTML调用演示代码如下 这里是自己的... -
Python调用百度地图api获取起点终点路线规划距离和预估时长
2018-08-15 21:42:33现有起点和终点坐标值(经纬度lng、lat),目的是通过百度地图开发者平台的路线规划功能获取起点终点路线规划距离和预估时长,百度地图开发者平台路线规划使用说明网址为:... 工具:Python3 实现过程并不难,但是爬取... -
百度地图api 密钥获取
2019-03-14 17:05:291、进入百度地图api首页 http://lbsyun.baidu.com/ (首先要有个百度账号并登陆) 拉到页面最下方会看到申请密钥,点击 2、点击申请密钥后跳转到这个填写个人信息页面 3、填写完后 提交,等待邮件确认(别着急,我... -
Flutter百度地图
2020-07-29 23:26:11Flutter百度地图-重构项目 一、实现效果如下图 qq交流群:群号:730772561 1、地图中任意踩点进行杆塔和设备的新建,对与点和线进行关联 2、对于点和线进行各种操作。 3、自定义区域下载离线地图。 4…热烈线 5…... -
项目中加入百度地图(调用百度地图的接口)
2020-05-28 14:41:00这里用html调用百度地图做样例 先总结一下步骤, 首先需要注册账号,绑定之类的,然后申请一个AK密匙 然后在百度地图的De...
-
linux系统中的日志管理
-
Spring Boot API 的 Controller 如何获得发送的 JSON 数据
-
利用脚本,实现腾讯云DNSPod进行DDNS动态域名解析ipv6地址
-
基于CAN总线的数据可靠性传输
-
UE4游戏逆向与安全+FPS游戏逆向与安全
-
PHP框架最新性能压力测试比较
-
东南大学网络安全学院-软件学院夏令营
-
万象2004 非常好用
-
基于多传感器的三维目标位姿测量方法
-
一种具有在线自检功能的开出回路设计
-
原子光刻中原子通量的优化研究
-
PHP支付宝微信支付配置教程
-
易语言开发通达信DLL公式接口
-
Database Management Systems(数据库系统原理总结)- 第二章
-
Experimental methods for warm dense matter research
-
高精度位移测量系统的硬件在环仿真
-
数据类型转换、运算符、方法入门
-
【数据分析-随到随学】Spark理论及实战
-
软件测试基础
-
基于离散自适应滑模控制的DC-DC变换器的设计与仿真