微信小程序~获取位置信息
微信小程序提供的getlocation来获取用户的定位,能够得到用户的经纬度信息
(注:getloaction需要用户授权scope.userLocation)结合map组件能够得到用户的详细定位
<map id="map" longitude="{{longitude}}" latitude="{{latitude}}" scale="" show-location style="width: 100%; height: 400rpx;"></map>
onReady:function(){
wx.getLocation({
type: 'wgs84',//默认wgs84是全球定位系统获取的坐标,gcj02是国家测绘局给出的坐标
success: (res) => {
console.log('经度' + res.longitude + ',纬度' + res.latitude);
this.setData({
latitude: res.latitude,
longitude: res.longitude
})
}
})
}

| 参数名 | 参数类型 | 描述 |
|---|---|---|
| longitude | Number | 中心经度 |
| latitude | Number | 中心纬度 |
| scale | Number | 缩放级别,取值范围 5-18(默认16 number) |
| markers | Array | 标记点 |
| polyline | Array | 路线 |
| circle | Array | 圆 |
| controls | Array | 控件 |
| include-points | Array | 缩放视野以及所有给定的坐标点 |
| circle | Boolean | 圆 |
| show-location | EventHandle | 显示带有方向的当前定位点 |
| bindmarkertap | EventHandle | 点击标记点时触发 |
| bindcontroltap | EventHandle | 点击控件时触发 |
| bindregionchange | EventHandle | 视野发生变化时触发 |
| bindtap | EventHandle | 点击地图时触发 |
除了显示基本地图,还可以在地图上添加markers–标注,polyline–折线,circles–圆形,controls–控件。
markers
data: {
markers: [{
iconPath: "../../img/marker_red.png",
id: ,
latitude: 40.002607,
longitude: 116.487847,
callout:{
content:'气泡名称',
color: '#FF0000',
fontSize: ,
borderRadius: ,
display: 'ALWAYS',
},
width: ,
height:
}],
... //省略代码
}
| 参数名 | 参数类型 | 必传 | 描述 |
|---|---|---|---|
| id | Number | N | 标记点id(marker事件回调会返回此id) |
| longitude | Number | Y | 中心经度(浮点数,范围:-180~180) |
| latitude | Number | Y | 中心纬度(浮点数,范围:-90~90) |
| title | String | N | 标注点名 |
| iconPath | String | Y | 显示的图标(项目目录下的图片路径,支持相对路径写法,以‘/’开头,则表示相对小程序的根目录,也支持临时路径) |
| rotate | Number | N | 旋转角度(顺时针旋转的角度,范围:0~360,默认0) |
| alpha | Number | N | 标注的透明度(默认1,无透明) |
| width | Number | N | 标注图标宽度(默认图标实际宽度) |
| height | Number | N | 标注图标高度(默认图标实际高度) |
| callout | Object | N | 自定义标注点上方的气泡窗口 ({content,color,fontSize,borderRadius,bgColor,padding,boxShadow,display}) |
| label | Object | N | 为标记点旁边增加标签({color,font Size,content,x,y},可识别换行符,x,y原点是marker对应的经纬度) |
polyline
指定一系列坐标点,从数组第一项连线至最后一项
| 参数名 | 参数类型 | 必传 | 描述 |
|---|---|---|---|
| points | Array | Y | 经纬度数组([{latitude:0,longitude:0}]) |
| color | String | N | 线的颜色(8位16进制表示,后两位表示alpha值,如:#000000AA) |
| width | Number | N | 线的宽度 |
| dotted'Line | Boolean | N | 是否是虚线(默认false) |
// .wxml
<map id="myMap" style='width:100%;height:50%' longitude="{{longitude}}" latitude="{{latitude}}" polyline='{{polyline}}'/>
// .js
Page({
data: {
polyline:[{
points:[{
latitude:'40.006822',
longitude:'116.481451'
}, {
longitude: '116.487847',
latitude: '40.002607'
}, {
longitude: '116.496507',
latitude: '40.006103'
}, {
latitude:'40.002607',
longitude: '116.587847',
}],
width:,
color:'#000000AA',
dottedLine:false
}]
}
})
circles
在地图上显示圆
| 参数名 | 参数类型 | 必传 | 描述 |
|---|---|---|---|
| longitude | Number | Y | 中心经度(浮点数,范围:-180~180) |
| latitude | Number | Y | 中心纬度(浮点数,范围:-90~90) |
| color | String | N | 描边颜色(8位16进制表示,后两位表示alpha值,如:#000000AA) |
| fill'Color | String | N | 填充颜色(8位16进制表示,后两位表示alpha值,如:#000000AA) |
| strokeWidth | Number | N | 描边宽度 |
| radius | Number | Y | 半径 |
// .wxml
<map id="myMap" style='width:100%;height:50%' longitude="{{longitude}}" latitude="{{latitude}}" circles='{{circles}}'/>
// .js
Page({
data: {
circles:[{
latitude:40.002607,
longitude: 116.587847,
color: '#ee7788aa',
radius: ,
fillColor:'#7cb5ec88',
strokeWidth:
}]
}
})
controls
在地图上显示控件,控件不随地图移动
| 参数名 | 参数类型 | 必传 | 描述 |
|---|---|---|---|
| id | Number | N | 控件id(在控件点击事件回调返回此id) |
| position | Object | Y | 控件在地图的位置(控件相对地图位置) |
| icon'Path | String | Y | 显示的图标(项目路径下的路径,支持相对路径写法,以‘/’开头表示相对小程序的根目录) |
| clickable | Boolean | N | 是否可点击(默认不可点击) |
position
| 参数名 | 参数类型 | 必传 | 描述 |
|---|---|---|---|
| left | Number | N | 距离地图左边界的距离(默认为0) |
| top | Number | N | 距离地图上边界的距离(默认为0) |
| width | Number | N | 控件宽度(默认图片宽度) |
| height | Number | N | 控件高度(默认图片高度) |
// .wxml
<map id="myMap" style='width:100%;height:400px' longitude="{{longitude}}" latitude="{{latitude}}" controls='{{controls}}' bindcontroltap='controltap'/>
// .js
Page({
data: {
controls: [{
id: ,
iconPath: '../../img/marker_yellow.png',
position: {
left: ,
top: ,
width: ,
height:
},
clickable: true
}]
}
}),
controltap: function (e) {
console.log(e.controlId); # 控件id
}
#可以通过在map上添加一个按钮,来实现诸如:定位、状态返回等操作。
#(直接通过布局文件在map上添加view是显示不出来的)
绑定事件
| 参数名 | 参数类型 | 描述 |
|---|---|---|
| bindmarkertap | EventHandel | 点击标记点时触发 |
| bindcontroltap | EventHandel | 点击控件时触发 |
| bindregionchange | EventHandel | 视野发生变化时触发 |
| bindtap | EventHandel | 点击地图时触发 |
BUG
关于经纬度,官方文档上都写的是Number类型。但是通过IDE调试的时候,写成字符串也是可以的。但是在IOS真机上运行时,markers却显示不出来,也不报错。
后来自己对照属性的类型,发现后台传来的经纬度是字符串类型的。而字符串类型的经纬度在IOS真机上经测试就是显示不出来。
所以将字符串转成Number类型即可。
附原始手册地址:http://blog.csdn.net/crazy1235/article/details/55004841
.
微信小程序~获取位置信息的更多相关文章
- (八)微信小程序---获取定位信息chooseLocation
微信小程序---获取定位信息 chooseLocation wxml <view bindtap="getlocalPath">{{localPath}}</v ...
- 图解微信小程序---获取电影信息
图解微信小程序---获取电影信息 代码笔记 第一步:编写js文件,调用api获取相对应电影详情信息(注意带入的参数是id不在是榜单的type,电影api的movie后面又斜杠,别忘了,对应的绑定数据的 ...
- 微信小程序 获取用户信息并保存登录状态
微信小程序 获取用户信息并保存登录状态:http://www.360doc.com/content/18/0124/11/9200790_724662071.shtml
- Laravel wxxcx 微信小程序获取用户信息
wxxcx 是Laravel5微信小程序登录获取用户信息扩展 部署 12345678 # 安装$ composer require iwanli/wxxcx# 注册服务# 在 /config/app. ...
- 微信小程序获取用户信息,解密encryptedData 包括敏感数据在内的完整用户信息的加密数据
package com.iups.wx.wxservice; import java.io.UnsupportedEncodingException; import java.security.Alg ...
- 微信小程序 获取用户信息 encryptData解密 C#版本
最近学习小程序开发,需要对encryptData解密,获取用户信息,官方源码没有C#版本,网上的资料比较杂,有的使用还有问题,下面贴一下自己亲试可以使用的一个源码 1.code 换取 session_ ...
- [小程序]微信小程序获取位置展示地图并标注信息
1.map组件的高度如果想要铺满屏幕,要是使用height:100vh样式2.获取位置要在app.json中标明权限3.先使用wx.getLocation获取自己的位置,然后再回调中使用setData ...
- 微信小程序获取用户信息
App({ appData: { userInfo:{ user_portraitUrl: "", user_nick: "", user_gender: 0, ...
- 微信小程序获取用户信息“授权失败”场景的处理
很多的时候我们在处理小程序功能的时候需要用户获取用户信息,但是呢为了信息安全,用户不授权导致授权失败场景:但是小程序第二次不在启动授权信息弹层,为了用户体验,可以用以下方式处理: function i ...
随机推荐
- Node.js 多线程完全指南
[原文] 很多人都想知道单线程的 Node.js 怎么能与多线程后端竞争.考虑到其所谓的单线程特性,许多大公司选择 Node 作为其后端似乎违反直觉.要想知道原因,必须理解其单线程的真正含义. Jav ...
- 禅道的使用—bug管理工具
简介 禅道项目管理软件集产品管理.项目管理.质量管理.文档管理.组织管理和事务管理于一体,是一款功能完备的项目管理软件,完美地覆盖了项目管理的核心流程. 1.禅道使用的基本流程 禅道管理软件中,核心的 ...
- consul集群搭建以及ACL配置
由于时间匆忙,要是有什么地方没有写对的,请大佬指正,谢谢.文章有点水,大佬勿喷这篇博客不回去深度的讲解consul中的一些知识,主要分享的我在使用的时候的一些操作和遇见的问题以及解决办法.当然有些东西 ...
- k8s-RC副本机制
一.libeness probe的三种检测机制 HTTP GET:对容器的IP(指定的端口和路径)执行HTTP GET请求,收到响应并返回状态码不代表错误(2xx/3xx),成功 TCP socket ...
- Django ORM 数据库设置和读写分离
一 Django的数据库配置 (一)修改settings.py文件关于数据库的配置: Django默认使用sqlite: DATABASES = { 'default': { 'ENGINE': 'd ...
- win运行canal
1.mysql开启log_bin 用命令查看是否开启 SHOW VARIABLES LIKE 'log_bin'; OFF为未开启,ON为开启 Win环境的话找到my.ini,Linux环境的话找到m ...
- Zookeeper架构及FastLeaderElection机制
原文链接:http://www.jasongj.com/zookeeper/fastleaderelection/ Zookeeper是什么 Zookeeper是一个分布式协调服务,可用于服务发现,分 ...
- 13 IO流(十)——BufferedReader/BufferedWriter 装饰流
Buffered字符包装流 与Buffered字节装饰流一样,只不过是对字符流进行包装. 需要注意的地方 Buffered字符流在Reader与Writer上有两个新的方法:String readLi ...
- 中国大学MOOC-翁恺-C语言程序设计习题集(二)
04-0. 求符合给定条件的整数集(15)给定不超过6的正整数A,考虑从A开始的连续4个数字.请输出所有由它们组成的无重复数字的3位数. 输入格式: 输入在一行中给出A. 输出格式: 输出满足条件的的 ...
- quartz2.3.0(十五)执行、暂停、继续执行、清除,花式操作数据库中持久化的job任务
#################################################################################################### ...