Django调用百度地图api在地图上批量增加标记点

在调用百度地图api进行web开发时遇到了一个需求,我们需要在网页中内嵌一个div 然后在div中调用百度地图的js显示我们所需要的地区。根据需求坐标在地图上添加若干个标记点,并批量的为各个标记点设置监听函数,使之显示我们所需要的信息

开始

创建工程

首先,创建一个测试用的工程来测试我们的需要,可以使用pycharm或者django自带的命令创建工程

django-admin startproject addressdemo

创建app

  • 创建工程之后,cd到工程目录,创建一个名为addresstest的应用
python manage.py startapp addresstest

创建一个名为templates文件,在其中创建一个address.html的测试用页面

  • 在address.html中我们需要先为地图创建一个容器 在这里我们使用一个确定好的div病设置id为allmap
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no"/>
    <style type="text/css">
        body, html {
            width: 100%;
            height: 100%;
            margin: 0;
            font-family: "微软雅黑";
        }

        #allmap {
            height: 700px;
            width: 100%;
        }

        #r-result {
            width: 100%;
            font-size: 14px;
        }
    </style>
    
    <title>经纬度定位</title>
</head>
<body>
<div id="allmap"></div>
<div id="r-result">

    <input type="button" />
</div>
</body>
</html>
  • 同时我们也设置了一个button为了更好的测试我们写的引用的函数

注册百度开发者账号获取秘钥

  • 访问<a href="http://lbsyun.baidu.com/index.php?title=jspopular">百度地图开放平台</a>注册账号并获取秘钥
    获得秘钥的页面应该如下:


    注册获取百度地图开发者账号

在address.html添加上引入百度api的js代码

<script type="text/javascript"
        src="http://api.map.baidu.com/api?v=2.0&ak=你的秘钥"></script>

连接mysql数据库

  • settings.py中修改数据库连接语句
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'addressdemo',
        'USER': 'root',
        'PASSWORD': '000000',
        'HOST': 'localhost',
        'PORT': '3306',
    }
}

设置模型类

  • 在创建的app下的models.py中添加如下语句
class address_info(models.Model):
    longitude = models.FloatField()
    latitude = models.FloatField()
    data = models.CharField(max_length=200)

注:

  • longitude为经度
  • latitude为维度
  • data为标记被点击所触发的显示的内容

执行同步数据库操作

python manage.py makemigrations
python manage.py migrate
  • django 1.7之后版本适用

查看数据库并在其中addresstest_address_info表中插入测试数据

  • 如图为我插入的几条测试数据


    数据库插入测试数据

在view和urls中配置视图函数和URL

修改views

  • 修改完成后的address/views.py
from django.shortcuts import render
import json
from addresstest.models import address_info


def test(request):
    address_point = address_info.objects.all()
    address_longitude = []
    address_latitude = []
    address_data = []
    for i in range(len(address_point)):
        address_longitude.append(address_point[i].longitude)
        address_latitude.append(address_point[i].latitude)
        address_data.append(address_point[i].data)

    return render(request, 'address.html',
                  {'address_longitude': json.dumps(address_longitude),
                   'address_latitude': json.dumps(address_latitude), 'address_data': json.dumps(address_data)})

  • 由于需要在前段页面中的js代码区域中使用,我们需要将列表json序列化然后通过页面渲染 或者 前段请求后端返回response携带接送数据
  • 起初本想直接将address_point这个数据集直接传到前段,在由前段使用模板,没有时间类型也不知道为什么会序列化出错,如果有知道的可以反馈给我

注:

  • address_longitude为若干个坐标的经度
  • address_latitude为若干个坐标的维度
  • address_data为标记上所需要显示的数据
修改urls
  • 由于只用来测试,所以我们只需要在工程名下的urls写设置一下即可
 from django.conf.urls import url
 from django.contrib import admin
 from addresstest import views
 
 urlpatterns = [
     url(r'^admin/', admin.site.urls),
     url(r'^address/',views.test),
 ]

在address.html添加设置地图的js

  • 因为js语句块放在页面哪里都可以被执行,所以大家可以按照自己的喜好放置,在这里我选择放在页面的最后
  <script type="text/javascript">
      var map = new BMap.Map("allmap");
      map.centerAndZoom(new BMap.Point(118.3088230000, 32.3002390000), 18);
      map.enableScrollWheelZoom(true);
      var navigationControl = new BMap.NavigationControl({
          // 靠左上角位置
          anchor: BMAP_ANCHOR_TOP_LEFT,
          // LARGE类型
          type: BMAP_NAVIGATION_CONTROL_LARGE,
          // 启用显示定位
          enableGeolocation: true
      });
      map.addControl(navigationControl);
  
      function get_location() {
  
          var address_latitude ={{ address_latitude |safe}};
          var address_longitude ={{ address_longitude|safe }};
          var address_data ={{ address_data |safe}};
  
  
          var point = []; //存放标注点经纬信息的数组
          var marker = []; //存放标注点对象的数组
          for (var i = 0; i < address_longitude.length; i++) {
              point[i] = new BMap.Point(address_longitude[i], address_latitude[i]); //循环生成新的地图点
              marker[i] = new BMap.Marker(point[i]); //按照地图点坐标生成标记
              map.addOverlay(marker[i]);
          }
  
          for (i = 0; i < marker.length; i++) {
              (function () {
                  var index = i;
                  marker[index].addEventListener('click', function () {
                      this.openInfoWindow(new BMap.InfoWindow(address_data[index]));
                  });
              })();
          }
  
      }
  </script>
  • 由于marker在添加监听事件时调用外部函数添加参数无效但是我们这里又需要传递从数据库读出来的需要显示的信息,所以我们这里使用了js的闭包的概念,还使用了匿名函数,直接写在监听事件函数内
  • 完整的address.html代码如下
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no"/>
    <style type="text/css">
        body, html {
            width: 100%;
            height: 100%;
            margin: 0;
            font-family: "微软雅黑";
        }

        #allmap {
            height: 700px;
            width: 100%;
        }

        #r-result {
            width: 100%;
            font-size: 14px;
        }
    </style>
    <script type="text/javascript"
            src="http://api.map.baidu.com/api?v=2.0&ak=你的秘钥"></script>
    <title>经纬度定位</title>
</head>
<body>
<div id="allmap"></div>
<div id="r-result">

    <input type="button" value="获取我的位置" onclick="get_location()"/>
</div>
</body>
</html>
<script type="text/javascript">
    // 百度地图API功能
  
    var map = new BMap.Map("allmap");
    map.centerAndZoom(new BMap.Point(118.3088230000, 32.3002390000), 18);
    map.enableScrollWheelZoom(true);
    var navigationControl = new BMap.NavigationControl({
        // 靠左上角位置
        anchor: BMAP_ANCHOR_TOP_LEFT,
        // LARGE类型
        type: BMAP_NAVIGATION_CONTROL_LARGE,
        // 启用显示定位
        enableGeolocation: true
    });
    map.addControl(navigationControl);

    function get_location() {

        var address_latitude ={{ address_latitude |safe}};
        var address_longitude ={{ address_longitude|safe }};
        var address_data ={{ address_data |safe}};


        var point = []; //存放标注点经纬信息的数组
        var marker = []; //存放标注点对象的数组
        for (var i = 0; i < address_longitude.length; i++) {
            point[i] = new BMap.Point(address_longitude[i], address_latitude[i]); //循环生成新的地图点
            marker[i] = new BMap.Marker(point[i]); //按照地图点坐标生成标记
            map.addOverlay(marker[i]);
        }

        for (i = 0; i < marker.length; i++) {
            (function () {
                var index = i;
                marker[index].addEventListener('click', function () {
                    this.openInfoWindow(new BMap.InfoWindow(address_data[index]));
                });
            })();
        }
    }

</script>

运行测试服务器查看效果

  python manage.py runserver
  • 在浏览器地址栏输入http://127.0.0.1:8000/address
  • 点击按钮获取我的位置


    批量地址标记显示结果

    如上图显示即为成功。

注:

  • 上述代码在django1.9Python2.7.12ubuntu16.04 lts中编译成功运行,其他环境请自行测试
  • 上述文字皆为个人看法,如有错误或建议请及时联系我
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,905评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,140评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,791评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,483评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,476评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,516评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,905评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,560评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,778评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,557评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,635评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,338评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,925评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,898评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,142评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,818评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,347评论 2 342

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,580评论 18 139
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,016评论 4 62
  • 青青河边草…………,这首歌是我童年时期记忆最深刻的一首,同学们会经常对着我唱这首歌,因为我的名字叫青青。 ...
    Ziyi325阅读 271评论 0 1
  • 共享单车是当下都市最流行的交通模式,来到南京,随处可见的单车让我的好奇心再度膨胀,拿起手机扫码注册,瞬间加入了共享...
    林九儿阅读 574评论 3 5
  • 一波一桥一倩影, 一风一浪一芦荡。 一眺一望一美景, 一草一木一心伤。
    风筝_5c59阅读 337评论 20 25