微信小程序 接高德地图API

前置工作
  1. 注册登录及入口
    登录 高德地图官网 - 开发支持 - 微信小程序SDK

  2. 控制台 - 应用管理 - 我的应用 - 创建应用 - 应用下添加新的KEY以及信息


    添加key
  3. 小程序开发者后台 - 开发管理 - 服务器域名 - 添加高德地图域名白名单 https://restapi.amap.com

  4. 下载高德地图SDK文件 - 引入amap-wx.js文件到需要添加地图的js内

  5. 获取用户坐标权限
    在app.json中,添加获取目标位置的权限:

"permission": {
    "scope.userLocation": {
      "desc": "你的位置信息将用于小程序位置接口的效果展示"
    }
}
正式接入

在小程序目标页面 - 引入amap-wx.js文件后 - 通过上面的key来实例化地图

var amapFile = require('../../resources/js/amap-wx.js');
var myAmapFun = new amapFile.AMapWX({ key: 上面应用下的key });

基本结构

<map 
              id="map" 
              class="mapEle"
              longitude="{{longitude}}" 
              latitude="{{latitude}}" 
              scale="16" 
              show-location="true" 
              markers="{{markers}}" 
              polyline="{{polyline}}"
              bindmarkertap="makertapFn"
              show-scale="true"
></map>

通过myAmapFun可以实现的基本功能:

  1. 获取用户所在地区的基本信息
 getRegeoFn(){
    var that = this;
    myAmapFun.getRegeo({
      success: function(data){
        if(data[0]){
          var _yourCity = data[0].regeocodeData.addressComponent.province;
          that.setData({
            yourCity: _yourCity
          });
        }
      },
      fail(err){
        console.log(err)
      }
    })
 }
  1. 获取目标经纬度位置的周边关键词(美食、酒店、景区等)信息
 myAmapFun.getPoiAround({
      iconPathSelected: '../../resources/images/marker_checked.png',
      iconPath: '../../resources/images/marker.png',
      querykeywords: '美食',
      location:  '纬度,经度 ',
      success(data){
        var markersData = data.markers;

        that.setData({
          markers: markersData,
          markPointIndex: 0,
          latitude: markersData[0].latitude,
          longitude: markersData[0].longitude
        });
      },
      fail(info) {
        wx.showModal({ title: info.errMsg })
      }
 });
  1. 针对上述map组件事件bindmarkertap, 周边来做mark点击切换
    其实就是获取周边目标数组的一个filter操作,筛选条件就是目标点 id
makertapFn(ev){
    var that = this;
    var _markerId = ev.detail.markerId;
    var markersData = that.data.markers;
    var resEle = null;
    var _index = 0;
    //1. 获取markerId点的索引
    markersData.forEach((item,index)=>{
      if(item.id == _markerId){
        resEle = item;
        _index = index;
      }
    });
    //切换MARK
    setTimeout(()=>{
        that.changeMarkerColor(markersData, 0);
    },300)
  }

//筛选mark点状态切换
changeMarkerColor(data, i){
    var that = this;
    var markers = [];
    for (var j = 0; j < data.length; j++) {
      if (j == i) {
        data[j].iconPath = "../../resources/images/marker_checked.png";
      } else {
        data[j].iconPath = "../../resources/images/marker.png";
      }
      markers.push(data[j]);
    }
    that.setData({
      markers: markers
    });
}
  1. 通过 myAmapFun.getDrivingRoute 绘制路线与计算路程
    需要对线路进行处理,显示行驶的路线说明文字
//绘制驾车路线
drawDrivingPolylineFn(){
    var that = this;
    var markersData = that.data.markers;
    var _userLocal = that.data.userLocal;
    var _markPointIndex = that.data.markPointIndex;

    myAmapFun.getDrivingRoute({
      origin: `${_userLocal.longitude},${_userLocal.latitude}`,
      destination: `${markersData[_markPointIndex].longitude},${markersData[_markPointIndex].latitude}`,
      success: function(data){
        var points = [];
        if(data.paths && data.paths[0] && data.paths[0].steps){
          var steps = data.paths[0].steps;
          for(var i = 0; i < steps.length; i++){
            var poLen = steps[i].polyline.split(';');
            for(var j = 0;j < poLen.length; j++){
              points.push({
                longitude: parseFloat(poLen[j].split(',')[0]),
                latitude: parseFloat(poLen[j].split(',')[1])
              })
            } 
          }
        }
        that.setData({
          drivingSteps: steps,
          polyline: [{
            points: points,
            color: "#0091ff",
            width: 4
          }]
        });
        if(data.paths[0] && data.paths[0].distance){
          that.setData({
            distance: data.paths[0].distance
          });
        }
      },
      fail(err){
        console.log(err);
      }
    })
}
  1. 绘制公交线路,如果跨域城市则需要 获知两个城市的名称
//绘制公交路线 -- 跨城(city,cityd必填)
drawBusPolylineFn(){
  var that = this;
  var markersData = that.data.markers;
  var _userLocal = that.data.userLocal;
  var _markPointIndex = that.data.markPointIndex;
  var _yourCity = '北京市';
  var _targetCity = '江苏';
  
  myAmapFun.getTransitRoute({
    origin: `${_userLocal.longitude},${_userLocal.latitude}`,
    destination: `${markersData[_markPointIndex].longitude},${markersData[_markPointIndex].latitude}`,
    strategy: 0,
    city:_yourCity,
    cityd: _targetCity,
    success: function(data){
      var points = [];
      if(data && data.transits){
        var transits = data.transits;
        for(var i = 0; i < transits.length; i++){
          var segments = transits[i].segments;
          transits[i].transport = [];
          for(var j = 0; j < segments.length; j++){
            if(segments[j].bus && segments[j].bus.buslines && segments[j].bus.buslines[0] && segments[j].bus.buslines[0].name){
              var name = segments[j].bus.buslines[0].name
              if(j!==0){
                name = '--' + name;
              }
              transits[i].transport.push(name);
            }
          }
        }
      }
      that.setData({
        transits: transits
      });
      //处理距离与路线
      if(transits.length>0){
        var _distance = transits[0].distance;
        var _segments = transits[0].segments;
        for(var i=0; i<_segments.length; i++){
          if(_segments[i].bus.buslines[0] && _segments[i].bus.buslines[0].polyline){
            var poLen = _segments[i].bus.buslines[0].polyline.split(';');
            for(var j =0; j<poLen.length; j++){
              points.push({
                longitude: parseFloat(poLen[j].split(',')[0]),
                latitude: parseFloat(poLen[j].split(',')[1])
              })
            } 
          }
        }
        
        that.setData({
          distance: _distance,
          polyline: [{
            points: points,
            color: "#0091ff",
            width: 4
          }]
        });
      }
    },
    fail(err){
      console.log(err);
    }
  })
}
  1. 获取某地天气
    需要创建一个WEB类型的key
    城市编码表 下载地址

实时天气 参数说明

例子:

吴江区
adcode  citycode  
320509  0512

请求方式 --- GET

https://restapi.amap.com/v3/weather/weatherInfo?key=申请的web类型KEY&city=320509&extensions=base
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,002评论 6 509
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,777评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,341评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,085评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,110评论 6 395
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,868评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,528评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,422评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,938评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,067评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,199评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,877评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,540评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,079评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,192评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,514评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,190评论 2 357

推荐阅读更多精彩内容