百度地图-绘制工具以及覆盖物的简单使用

本文介绍了如何使用Flask框架配合百度地图API,实现实时显示高校位置并支持范围选择,包括经纬度查询、地图渲染及绘制工具应用。

这几天重拾了地图相关的功能,做一个小小的总结。

本文的示例的后端为flask框架,前端使用了bootstrap和jQuery以及百度地图API。


接下来是展示部分。

地图上的覆盖物表示高校所处的位置,当高校所代表的覆盖物过近时,会通过百度提供的API来合并这些点;

当使用绘制左上角的绘制工具,圈定范围后,会弹出右侧边栏,并显示圈定范围内的高校的名称(排名不分先后)。

示例代码在github,演示截图如下:

在本示例中,会涉及到以下内容:

  1. 使用百度API查询经纬度;
  2. 百度地图渲染;
  3. 百度地图-绘制工具和覆盖物。

1.项目结构

下图为本示例的项目结构示意图:

app.py是flask的入口文件,为了便于演示,本文使用如下代码启动flask服务器(官方建议使用flask run命令启动,不过如此启动貌似不好调试):

if __name__ == '__main__':
    app.run()

 config文件中存储了访问百度地图API的ak数据,本示例的config文件并没有上传到github上,有需要的可以去百度地图申请

register文件中的代码是要注册到app中的一些功能,比如flask的自定义命令、url_for在上下文的重写等;

utils文件中目前只存储了一个根据位置查询经纬度的函数get_position;

2.根据位置查询经纬度

此部分代码被封装在了utils.py文件夹中:

import hashlib
import requests
from urllib import parse

from config import BAIDU_AK


def get_position(address):
    """
    请求百度,获取地址所在的经纬度
    :param address: 地址,比如东南大学 或昆山开发区前进东路企业科技园科技广场1505室
    :return:{'status': 0, 'result':
        {'location':
            {'lng': float, 'lat': float}, 'precise': 0, 'confidence': 70, 'comprehension': 0, 'level': '教育'}}
    """
    # 以get请求为例http://api.map.baidu.com/geocoder/v2/?address=百度大厦&output=json&ak=你的ak
    queryStr = '/geocoder/v2/?address=%s&output=json&ak=kNPyYMh5Yx4huR43nIRCYiO2Ms4XCNTD' % address
    # 对queryStr进行转码,safe内的保留字符不转换
    encodedStr = parse.quote(queryStr, safe="/:=&?#+!$,;'@()*[]")
    # 在最后直接追加上yoursk
    rawStr = encodedStr + BAIDU_AK
    # 计算sn
    sn = (hashlib.md5(parse.quote_plus(rawStr).encode("utf8")).hexdigest())
    # 由于URL里面含有中文,所以需要用parse.quote进行处理,然后返回最终可调用的url
    url = parse.quote("http://api.map.baidu.com" + queryStr + "&sn=" + sn, safe="/:=&?#+!$,;'@()*[]")
    result = eval(requests.get(url).text)
    return result

该功能需要从百度地图申请一个ak,然后才能使用本功能。

为了方便使用,本示例把该函数封装成了一个命令,并保存到register.py文件中:

# register.py

import os
import pandas
from flask import current_app, url_for

from utils import get_position
from config import BAIDU_AK


def register_commands(app):
    @app.cli.command()
    def school_location():
        """get lng and lat of schools"""
        data = []
        # 目前定死,之后可从数据库读取等等
        schools = [
            {'name': '东南大学', 'city': '南京市'},
            {'name': '南京大学', 'city': '南京市'},
            {'name': '南京工程学院', 'city': '南京市'}
        ]
        for idx, school in enumerate(schools):
            geo_result = get_position('%s(%s)' % (school['name'], school['city']))
            datum = {'name': school['name']}
            datum.update(geo_result[
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值