1.wxml

<view class="container"><view class='newHouseTitle'>当前位置</view><view class="map_wrap"><map id="map" longitude="{{t_lng}}" latitude="{{t_lat}}" scale="15" markers="{{markers}}" class="map_map" bindtap="show_big_map"></map><view class="xmwzB flex tfAlignC flexSb"><view class="xmwzBLi {{index==xmwzB_index?'on':''}}" data-index='{{index}}' catchtap="xmwzB_click" wx:for='{{tabs}}' wx:key='index'><image class="img" src="{{index!=xmwzB_index?item.ico:item.ico_active}}"></image>{{item.name}}</view></view><view class="xmwzUl" wx:if='{{arrlist_cur&&arrlist_cur.length}}'><view class="xmwzUl-li flex flexSb tfAlignC" wx:for='{{arrlist_cur}}' wx:key='index'><view class="xmwzUl-li-name tfLine1" style="max-width:500rpx;">{{item.title}}</view><view class="xmwzUl-li-add">{{item.distance}}m</view></view></view></view></view>

2.css

/*弹性布局*/
.flex {display: -webkit-box;display: -moz-box;display: -ms-flexbox;display: -webkit-flex;display: flex;display: box;flex-wrap:wrap;
}
.noWarp{flex-wrap:nowrap;
}
/*元素居中*/
.alignC{align-items: center;-webkit-box-align: center;-webkit-align-items: center;-moz-align-items: center;-ms-align-items: center;-o-align-items: center;
}
/*水平排列*/
.flexH{-webkit-box-orient: horizontal;-webkit-flex-direction: row;-moz-flex-direction: row;-ms-flex-direction: row;-o-flex-direction: row;flex-direction: row;
}
/*垂直排列*/
.flexV {-webkit-box-orient: vertical;-webkit-flex-direction: column;-moz-flex-direction: column;-ms-flex-direction: column;-o-flex-direction: column;flex-direction: column;
}
/*两端对齐*/
.flexSa {-webkit-box-pack: justify;justify-content: space-around;-webkit-justify-content: space-around;-moz-justify-content: space-around;-ms-justify-content: space-around;-o-justify-content: space-around;
}
/*居中对齐*/
.flexC {-webkit-box-pack: center;justify-content: center;-webkit-justify-content: center;-moz-justify-content: center;-ms-justify-content: center;-o-justify-content: center;
}
.flexSb {justify-content: space-between;-webkit-justify-content: space-between;-moz-justify-content: space-between;-ms-justify-content: space-between;-o-justify-content: space-between;
}
.flexS {-webkit-box-pack: start;justify-content: flex-start;-webkit-justify-content: flex-start;-moz-justify-content: flex-start;-ms-justify-content: flex-start;-o-justify-content: flex-start;
}
.flexE {-webkit-box-pack: end;justify-content: flex-end;-webkit-justify-content: flex-end;-moz-justify-content: flex-end;-ms-justify-content: flex-end;-o-justify-content: flex-end;
}.tfLine1 {white-space: nowrap;overflow: hidden;text-overflow: ellipsis;
}/* 页面内容 */
.container{padding: 0 25rpx;
}.newHouseTitle {height: 100rpx;line-height: 100rpx;font-size: 35rpx;font-weight: bold;
}.map_map{width: 100%;height:300rpx;
}.xmwz{padding: 0 35rpx;
}.xmwzT{width: 100%;height: 300rpx;
}.xmwzB{margin-top: 25rpx;
}.xmwzBLi{background-size:48rpx 48rpx;background-repeat: no-repeat;background-position:top center;padding-top: 72rpx;text-align: center;font-size: 30rpx;color: #333333;padding-bottom: 30rpx;position: relative;
}.xmwzBLi:before{position: absolute;width: 100%;height: 10rpx;background-color: transparent;left: 0;bottom: 0;display: block;content:'';
}.xmwzBLi.on::before{background-color: #3072f6;
}.xmwzBLi .img{position: absolute;left: 50%;top: 5rpx;margin-left: -24rpx;width: 48rpx;height: 48rpx;}.xmwzUl{padding: 15rpx 0 50rpx;
}.xmwzUl-li{height: 60rpx;line-height: 60rpx;
}.xmwzUl-li-name{font-size: 30rpx;color: #666666;
}.xmwzUl-li-add{background-image: url();background-size:24rpx 30rpx;background-repeat: no-repeat;background-position: left center;padding-left:36rpx;font-size: 30rpx;color: #aaaaaa;
}

3.js

var QQMapWX = require('../../lib/qqmap-wx-jssdk.min.js');
var qqmapsdk;
qqmapsdk = new QQMapWX({key: 'RAMBZ-UKXW6-FZOSO-M6ENO-RCTTE-THFBQ'
});
Page({/*** 页面的初始数据*/data: {// 获取的经纬度t_lat: '32.00335',t_lng: '118.73145',// 地图的markersmarkers: [],// 当前选中第几个xmwzB_index: 0,// tab列表tabs: [{ico: '../../images/around/icon1.png',ico_active: '../../images/around/icon1_1.png',name: '交通'},{ico: '../../images/around/icon2.png',ico_active: '../../images/around/icon2_1.png',name: '学校'},{ico: '../../images/around/icon3.png',ico_active: '../../images/around/icon3_1.png',name: '医疗'},{ico: '../../images/around/icon4.png',ico_active: '../../images/around/icon4_1.png',name: '购物'},{ico: '../../images/around/icon5.png',ico_active: '../../images/around/icon5_1.png',name: '餐饮'},],// 把从腾讯地图SDK获取的位置存起来,以后每次点击就不用请求了。arrlist:[[],[],[],[],[]],arrlist_cur:'',},/*** 生命周期函数--监听页面加载*/onLoad: function (options) {var that = this;var marks = [];// 地图上的icon图标marks.push({ // 获取返回结果,放到mks数组中latitude: that.data.t_lat,longitude: that.data.t_lng,iconPath: '../../images/around/address.png', //图标路径width: 20,height: 20,});// 改写气泡marks.push({ // 获取返回结果,放到mks数组中title: '想要展示的名字',latitude: that.data.t_lat,longitude: that.data.t_lng,iconPath: '../../images/around/cover_1.png', //图标路径width: 20,height: 20,address: '详细地址',callout: {content: '想要展示的名字',color: '#fff',bgColor: '#3072f6',fontSize: 14,padding: 10,borderRadius: 10,display: 'ALWAYS'}});that.setData({markers: marks});// 进页面先请求一波(第一个tab下对应的列表内容)that.nearby_search(that.data.tabs[0].name);},// 点击tab切换xmwzB_click(e) {var that = this;var index = e.currentTarget.dataset.index;that.setData({xmwzB_index: index}, () => {var name = that.data.tabs[index].name;that.nearby_search(name);});},// 通过关键字调用地图SDK,搜索获取结果列表nearby_search(key) {var that = this;var xmwzB_index = that.data.xmwzB_index;var list_c = that.data.arrlist[xmwzB_index];// 判断是否请求过了,如果没请求过则请求;请求过了就直接赋值if(list_c.length){that.setData({arrlist_cur:list_c});}else{wx.showToast({title: '请稍后',icon: 'loading',duration: 2000})qqmapsdk.search({keyword: key, // 搜索关键词page_size: 5, // 一页展示几个location: that.data.t_lat + ',' + that.data.t_lng, //设置周边搜索中心点success: function (res) { //搜索成功后的回调wx.hideToast({});var arrlist = [];// 对获取的信息进行处理,整理出需要的字段// 有些可能会涉及位置跳转(需要经纬度);展示位置名(详细参数设置参考官网说明)for (var i = 0; i < res.data.length; i++) {arrlist.push({ // 获取返回结果,放到mks数组中title: res.data[i].title,latitude: res.data[i].location.lat,longitude: res.data[i].location.lng,distance: res.data[i]._distance,})}// 每次不用重新赋值,通过下标给需要的赋值var arrlist_key = 'arrlist['+xmwzB_index+']';that.setData({[arrlist_key]: arrlist,arrlist_cur:arrlist});},fail: function (res) {console.log(res);},complete: function (res) {//console.log(res.data);}});}},// 小程序地图api,跳转大地图show_big_map: function () {var that = this;wx.openLocation({latitude: parseFloat(that.data.t_lat), // 纬度,浮点数,范围为90 ~ -90longitude: parseFloat(that.data.t_lng), // 经度,浮点数,范围为180 ~ -180。name: '想要展示的名字', // 位置名address: '详细地址', // 地址详情说明scale: 16, // 地图缩放级别,整形值,范围从1~28。默认为最大});}
})

4.效果

5.说明:

5.1 qqmap-wx-jssdk 地址:https://lbs.qq.com/qqmap_wx_jssdk/index.html (文档不长,写的比较详细,参数和使用方法,可以大概看一下);

5.2 demo包也可去百度云盘下载:

链接:https://pan.baidu.com/s/11QSw2szxNCJFkAiI0uwsYA 
        提取码:dk09

5.3 可以将写的代码优化一下,每次进来只请求一次,用一个数组存储一下数据,如果数组中有则不请求接口直接使用,如果数组中没有则请求接口获取,官方也做了说明,点击传送门去官方。

5.4 在地图表面气泡展示,点击气泡改变气泡状态,点击进入传送门。

小程序结合腾讯地图(QQMapWX)SDK做位置周边搜索展示相关推荐

  1. 小程序结合腾讯地图(QQMapWX)SDK做位置周边搜索在地图上展示气泡点,点击气泡展示不同状态

    1.背景: 在微信小程序中,地图上展示一个坐标点周边的医院学校等周边设施,通过地图上气泡的方式.点击气泡展示不同的气泡状态,点击导航跳转到对应气泡点所在的坐标位置. 2.实现思路: 2.1布局: 地图 ...

  2. (uni-app)微信小程序之腾讯地图(定位当前位置,地图标点及导航)

    话不多说,直接代码!!! 一.dom <template><view><map id="tencentMap" :style="[...ma ...

  3. 微信小程序调用腾讯地图,获取当前位置得到数据有偏差以及不同软件,不同坐标之间的转换Gcoord

    前言: 在微信小程序中调用腾讯本家地图后,发现有偏差,而且距离还不小,在找了很多资料后,发现网上的资料很多都是挂羊头卖狗肉,都是坐标轴之间的互转,比如腾讯的坐标和百度坐标之间的转换,还起的名字是解决小 ...

  4. 腾讯小程序 java编写_微信小程序 使用腾讯地图SDK详解及实现步骤

    微信小程序 使用腾讯地图SDK详解及实现步骤 近期在做一款彩票服务类项目中用到了腾讯地图提供的小程序解决方案,拿来给大家分享一下! 使用起来非常简单,就是一些功能还有待完善. 官方文档:http:// ...

  5. 微信小程序 使用腾讯地图SDK详解及实现步骤

    信小程序 使用腾讯地图SDK详解及实现步骤 微信小程序JavaScript SDK: 官方文档:http://lbs.qq.com/qqmap_wx_jssdk/index.html 步骤: 1.申请 ...

  6. 微信小程序接入腾讯地图sdk地图 用户自选位置。踩坑+代码实现

    采坑记录: 1.微信小程序对腾讯地图的支持好.拓展强,不建议使用其他地图 2.坐标问题** 高德地图与腾讯地图使用的是 GCJ02坐标系 3.使用微信小程序的内置方法的经纬度存在偏差.解决方案看下文 ...

  7. 微信小程序使用腾讯地图进行路线规划,坐标转地址,逆地理编码,计算目的地跟自身定位的距离

    微信小程序使用腾讯地图 1.介绍腾讯地图 官方文档: https://lbs.qq.com/ 这里,我主要运用的是这几个api ,我在运用的过程中主要实现的功能有:地图路线规划.地址转坐标+计算距离. ...

  8. 微信小程序调用腾讯地图API进行驾车路线规划

    微信小程序调用腾讯地图API进行驾车路线规划 申请key 下载sdk 实现代码 遇到的问题 申请key 微信小程序的地图api是非常有限的,所以部分功能实现需要调用地图api.使用腾讯地图api过程如 ...

  9. uni-app 小程序使用腾讯地图完成搜索功能

    前言 使用uni-app开发小程序时候使用腾讯地图原生SDK是,要把原生写法转成vue写法在这记录一下. 我们需要注意的是使用高德地图时我们不仅要引入SDK,还要再uni-app中配置允许使用. 由于 ...

  10. uni-app 写H5 小程序 使用腾讯地图获取地理位置

    uni-app 写公众号 小程序 使用腾讯地图获取地理位置 1.首先需要在腾讯地图里面申请key 2.下载微信小程序JavaScriptSDK,微信小程序 JavaScriptSDK v1.1   J ...

最新文章

  1. 为什么不使用多机训练神经网络
  2. 背水一战 Windows 10 (10) - 资源: StaticResource, ThemeResource
  3. contrastive loss function (papers)
  4. java动态执行逻辑_动态执行代码逻辑
  5. [转].NET 数字格式化:忽略末尾零
  6. 对Xcode菜单选项的详细探索
  7. 过于离谱,我实现憋不住了!
  8. java.sql 拒绝连接_hive jdbc 拒绝连接问题
  9. RSA加密算法简单分析
  10. Java Set基础知识
  11. 使用WindowsXP中的网桥功能
  12. 如何:删除Word 2010中的“向下箭头”
  13. 我们该用什么分布式数据库?
  14. 操作系统:哲学家就餐问题
  15. GO语言实现区块链Part6 Transactions 2
  16. DataGrip 安装教程 详细版
  17. 【SonarQube】安装、配置与使用 01
  18. Stacked Hourglass Networks
  19. PDF如何解密?这些方法你知道吗?
  20. PS抠图之单色背景图片

热门文章

  1. 143578-65-8,CYCLO(-D-PHE-HIS-TRP-ALA-VAL-GLY-HIS-LEU-LEU)
  2. iOS开发面试只需知道这些,技术基本通关!(网络篇)
  3. Linux #! /bin/sh的意思
  4. 2022腾讯QQ春节红包活动 虎跃星辰玩法总攻略
  5. 立创eda学习笔记二十九:原理图转PCB
  6. C++ primer (5th) 随想与学习笔记 6 优先级晦涩难通 新标准更清晰
  7. easyui php分页,jQuery EasyUI 教程-Pagination(分页)
  8. 辛苦开发的 App 被山寨?mPaaS 帮你为 APK 上把加固锁
  9. Head First设计模式-适配器模式
  10. 纯0基础Java自学