百度地图 订阅
百度地图(Baidu Map)是为用户提供包括智能路线规划、智能精准导航(驾车、步行、骑行)、实时路况、实时公交等出行相关服务的平台。百度地图作为新一代人工智能地图,秉持”科技让出行更简单“的品牌使命,以"科技"为手段不断探索创新。伴随AI时代的到来,百度地图不仅实现了语音交互覆盖用户产品使用全流程,还上线了AR步导、AR导游等实用功能,且地点信息丰富,更加方便用户的出行。2019年9月,百度地图全新发布“百雀灵计划”,上线全球首个地图语音定制功能,让用户出行更具个性化。 展开全文
百度地图(Baidu Map)是为用户提供包括智能路线规划、智能精准导航(驾车、步行、骑行)、实时路况、实时公交等出行相关服务的平台。百度地图作为新一代人工智能地图,秉持”科技让出行更简单“的品牌使命,以"科技"为手段不断探索创新。伴随AI时代的到来,百度地图不仅实现了语音交互覆盖用户产品使用全流程,还上线了AR步导、AR导游等实用功能,且地点信息丰富,更加方便用户的出行。2019年9月,百度地图全新发布“百雀灵计划”,上线全球首个地图语音定制功能,让用户出行更具个性化。
信息
最近更新时间
2020年03月05日
覆盖范围
全球209个国家和地区
运营公司
北京百度网讯科技有限公司
品牌愿景
科技让出行更简单
类    型
服务性软件
软件类型
出行类应用软件
推出时间
2005年
中文名
百度地图 [1]
外文名
Baidu Maps
软件大小
94.8M
运营平台
Web,PC,Android,iOS
最新版本
10.23.0.965
特色功能
智能语音,AR步导,智能驾车导航
百度地图AI化数据生产 加速产业升级
百度地图80%数据采集环节已实现AI化 [2]  ,拥有国内规模最大的采集团队和最领先的采集设备,是业内AI化水平最高、搭载AI技术最强最丰富,唯一拥有全景数据的地图服务商,道路里程覆盖已达1000万公里 [3]  。
收起全文
精华内容
下载资源
问答
  • pyecharts的基础还是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图吧
    在这里插入图片描述
    全都在无锡市内了,大功告成,虽然没啥用了(╥╯^╰╥)

    展开全文
  • vue使用百度地图----在线地图

    万次阅读 2020-10-09 11:31:23
    Part1 在线地图 1、安装组件 npm install vue-baidu-map --save ... ak: '**********************' //此处为百度地图秘钥 }); 百度AK秘钥申请地址 3、HTML部分 <div id="baidu_map"> <baidu-ma

    1、安装组件

    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-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">


     

    展开全文
  • 百度地图坐标系统解析

    万次阅读 2019-06-22 14:55:52
    在地球上我们通过经纬度来描述某个位置,而经过投影之后的地图也有自己的坐标系统,本篇文章就来详细介绍在百度地图API中涉及的各种坐标体系。 在百度地图API中,你需要了解如下坐标系: 经纬度:通过经度...

    微信搜索:“二十同学” 公众号,欢迎关注一条不一样的成长之路       

    我们都知道地球是圆的,电脑显示器是平的,要想让位于球面的形状显示在平面的显示器上就必然需要一个转换过程,这个过程就叫做投影(Projection)。在地球上我们通过经纬度来描述某个位置,而经过投影之后的地图也有自己的坐标系统,本篇文章就来详细介绍在百度地图API中涉及的各种坐标体系。

    在百度地图API中,你需要了解如下坐标系:

    • 经纬度:通过经度(longitude)和纬度(latitude)描述的地球上的某个位置。
    • 平面坐标:投影之后的坐标(用x和y描述),用于在平面上标识某个位置。
    • 像素坐标:描述不同级别下地图上某点的位置。
    • 图块坐标:地图图块编号(用x和y描述)。
    • 可视区域坐标:地图可视区域的坐标系(用x和y描述)。
    • 覆盖物坐标:覆盖物相对于容器的坐标(用x和y描述)。

    别被这么多的坐标系吓着,看完了后面的讲解相信你会逐渐理解它们。

    经纬度

          这个就不多说了,不熟悉的可以翻翻地理书。但需要注意的是即便同是经纬度坐标也可能属于不同的坐标体系。一般GPS设备获取的经纬度属于WGS84坐标系,这是一个比较通用的坐标体系。由于某些原因国内不能直接使用WGS84坐标,因此百度地图API的经纬度是经过加密偏移的。

    平面坐标

          前面说过,球面上的形状需要经过投影才能变换为平面上的形状,变换后就需要有一个平面坐标系统来描述地图上某个位置。百度地图API默认使用墨卡托投影(Mercator Projection),同样需要注意的是由于投影参数不同,同样是墨卡托投影也会有所差别。

          平面坐标系的原点与经纬度的原点一致,即赤道与0度经线相交的位置:

    0f9f47ec256410b02e2e2112

           在百度地图API中,平面坐标是以最大级别18级为基准的。就是说在18级下,平面坐标的一个单位就代表了屏幕上的1个像素。平面坐标与地图所展示的级别没有关系,也就是说在1级和18级下,天安门位置的平面坐标都是一致的。那么如何知道某个位置的平面坐标呢?可通过BMap.MercatorProjection类来完成,该类提供经纬度与平面坐标互相转换的方法。例如天安门的经纬度大约为116.404, 39.915,经过转换即可得到平面坐标:

    var projection =new BMap.MercatorProjection();
    var point = projection.lngLatToPoint(new BMap.Point(116.404, 39.915));
    alert(point.x +", "+ point.y);

    结果如下:

    07c0c4197b9d101bdbb4bd1d

    这个就是平面坐标。你可以这样理解它的含义:第18级下,天安门距离坐标原点的位置差为:12958175, 4825923.77,单位为像素。

    像素坐标

    在第18级下,我们直接将平面坐标向下取整就得到了像素坐标,而在其他级别下可以通过如下公式进行换算(这里取整为向下取整):

    像素坐标 = |平面坐标 × 2 zoom -18|

    比如经过计算,在第4级天安门位置的像素坐标是:790, 294

    25c9ed092446bae3d0581bef

    不同级别下,同一个地理位置的像素坐标是不一样的,它与当前地图的级别相关。

    图块坐标

           百度地图API在展示地图时是将整个地图图片切割成若干图块来显示的,当地图初始化或是地图级别、中心点位置发生变化时,地图API会根据当前像素坐标计算出视野内需要的图块坐标(也叫图块编号),从而加载对应的图块用以显示地图。

    百度地图的图块坐标原点与平面坐标一致,从原点向右上方开始编号为0, 0:

    833962df022ded72485403eb

    如何知道某个位置的图块坐标呢?通过如下公式计算即可(这里为向下取整):

    图块坐标 =|像素坐标 ÷ 256|

          256实际上是每个图块的宽度和高度,我们用像素坐标除以这个数就知道图块坐标了。还以天安门为例,在第4级下天安门所在的图块编号为:3, 1,而在第18级下,图块编号为:50617, 18851

    可视区域坐标

          地图都是显示在确定大小的矩形框中的,这个矩形框通常是开发者在初始化地图传入的某个容器元素。这个矩形框也有自己的坐标系,在百度地图API中称之为可视区域坐标系,它的原点位于矩形的左上角。

    7eac4ccf8a67b95cf9dc61f7

    通过Map类的pointToPixel和pixelToPoint方法可以相互转换经纬度坐标与可视区域坐标。

    覆盖物坐标

           覆盖物在实现上就是若干DOM元素,这些元素会被放在若干覆盖物容器内(具体请参考地图API开发指南),那么覆盖物的坐标实际上就是相对于这些覆盖物容器的坐标。在地图初始化完成后,覆盖物容器的左上角与地图可视区域左上角位置相同,一旦地图被移动、缩放,覆盖物容器位置就会发生变化。在自定义覆盖物的时候API提供经纬度信息,而开发者需要自行将经纬度转换为覆盖物的像素坐标,从而覆盖物才能显示在正确的位置上。这个转换过程可以通过Map的pointToOverlayPixel和overlayPixelToPoint两个方法来实现。 

    展开全文
  • 百度地图BaiduMap_AndroidSDK_v6.4.0中的路线规划功能为啥不可用??? 百度地图例子BaiduMap_AndroidSDK_v6.4.0_Sample 中的路线规划都不可用?????[face]monkey:35.gif[/face] [img=...
  • 1、首先弄明白几种在线地图的坐标系; (1)天地图:CGCS2000,2000国家大地坐标系;我们其实很多时候直接用WGS84的坐标来代替CGCS2000坐标。因为CGCS2000的定义与WGS84实质一样。采用的参考椭球非常接近。扁率差异...
  • 百度地图 创建应用

    万次阅读 2019-09-25 23:55:28
    1、你要使用百度地图的服务,就先要去百度地图开放平台创建一个应用,从而获取到一个大多数的Api服务都要用到的Key。连接地址:百度地图开放平台。 2、点击控制台。 3、点击创建应用 4、随便输一个应用名称,...
  • 百度地图升级4:给点添加弹框

    万次阅读 2020-05-25 17:29:10
    // 设置弹框的格式 var opts = { boxStyle: { width: "280px", height: "120px", }, enableAutoPan: true, }; //根据判断设置图标--排口 var marker = ... // 将标注添加到地图中 addClickHandler(content, marker);
  • 地图的底图不支持百度地图,博主想用这个包的话,就不得不将数据点转到高德坐标系下,然后进行下一步工作,然而高德莫名其妙的封了我的账号,说我违规调取数据,简直莫须有; 间歇性的出现一些未知的问题,比如添加...
  • 百度地图POI数据获取

    万次阅读 2019-01-17 00:57:06
    本文主要介绍百度地图POI数据获取:从百度地图得到POI数据,以json格式保存; POI数据获取的原理部分还可以参照零基础掌握百度地图兴趣点获取POI爬虫(python语言爬取)(基础篇)。 POI数据获取 百度地图POI数据...
  • 百度地图,地图轨迹

    千次阅读 2020-06-06 21:20:20
    百度地图,记录行动轨迹: 效果图: 上代码: <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <meta name="viewport...
  • 使用以下源码前,请先去百度地图开发平台申请密匙,前去申请:立即申请 2、源代码 此次定位代码是通过H5的方式实现的 <html> <head> <meta http-equiv="Content-Type" content="text/html; ...
  • 使用百度地图绘制热力图

    万次阅读 热门讨论 2018-01-30 10:01:51
    首先需要到百度地图开放平台注册开发者信息,并且获得AK应用访问标识码 因为要做本地调用,所以Referer白名单里面只写一个*就全允许了,拿到AK码之后写个HTML调用演示代码如下 这里是自己的...
  • 现有起点和终点坐标值(经纬度lng、lat),目的是通过百度地图开发者平台的路线规划功能获取起点终点路线规划距离和预估时长,百度地图开发者平台路线规划使用说明网址为:... 工具:Python3 实现过程并不难,但是爬取...
  • Flutter百度地图

    千次阅读 2020-07-29 23:26:11
    Flutter百度地图-重构项目 一、实现效果如下图 qq交流群:群号:730772561 1、地图中任意踩点进行杆塔和设备的新建,对与点和线进行关联 2、对于点和线进行各种操作。 3、自定义区域下载离线地图。 4…热烈线 5…...
  • 百度地图api 密钥获取

    万次阅读 2019-03-14 17:05:29
    1、进入百度地图api首页 http://lbsyun.baidu.com/ (首先要有个百度账号并登陆) 拉到页面最下方会看到申请密钥,点击 2、点击申请密钥后跳转到这个填写个人信息页面 3、填写完后 提交,等待邮件确认(别着急,我...
  • 这里用html调用百度地图做样例 先总结一下步骤, 首先需要注册账号,绑定之类的,然后申请一个AK密匙 然后在百度地图的De...
  • 基于百度地图实现Android定位功能实现(详解+教程)初始化(一)获取到SHA1Android studio 配置定位功能实现 初始化 (一)获取到SHA1 首先你得注册和获取密钥,这里就直接参考百度地图的教程即可 链接: 注册. 这里...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 39,952
精华内容 15,980
关键字:

百度地图