关于小程序获取用户当前位置的方法探究

why 46 2024-07-02

小程序如何获取用户当前位置

有三种方式可以获取用户当前位置:

1、wx.getLocation(多与wx.openLocation一起用)

获取当前的精度、纬度、速度。不需要授权。当type设置为gcj02 返回可用于wx.openLocation的坐标

2、wx.chooseLocation

需要授权,打开地图选择位置

第一次调用方法时先出现

image.png

允许权限之后之后再出现

image.png

如果第一次就不允许,则一直调用wx.chooseLocation的fail方法

3、wx.openLocation

需要授权,使用微信内置地图查看位置。多半用于查看起点到终点的路线怎么走

image.png

 授权方法有三种:

1、wx.getSetting

获取用户的当前设置,返回值中只会出现小程序已经向用户请求过的权限,类似下面的样子

526660c3a5f34984c36249ea9286230.png

2、wx.openSetting

调起权限设置选择界面,设置界面只会出现小程序已经向用户请求过的权限,类似下面的样子

image.png

3、wx.authorize

提前向用户发起授权请求。调用后会立刻弹窗询问用户是否同意授权小程序使用某项功能或获取用户的某些数据,但不会实际调用对应接口。如果用户之前已经同意授权,则不会出现弹窗,直接返回成功。,类似下面的样子

image.png

这就是wx.authorize出现的内容

问题来了:假如我第一次使用wx.chooseLocation()获取权限被拒绝,然后使用wx.getSetting()来重新获取权限该怎么做呢?

思路:wx.chooseLocation()有fail方法,如果第一次拒绝之后,以后调用选择地图都是触发的这个,那么我可以在fail方法里面,使用wx.getSetting(),这样就每次都能判断是否已经给与了权限了。

第一步:由于有可能会多次使用定位的方法,所以我把定位的方法写到App.js中,方便调用

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

App({

    //获取用户地理位置权限

    getPermission:function(obj){

      wx.chooseLocation({

        success: function (res) {   

            obj.setData({

                addr: res.address      //调用成功直接设置地址

            })               

        },

        fail:function(){

            wx.getSetting({

                success: function (res) {

                    var statu = res.authSetting;

                    if (!statu['scope.userLocation']) {

                        wx.showModal({

                            title: '是否授权当前位置',

                            content: '需要获取您的地理位置,请确认授权,否则地图功能将无法使用',

                            success: function (tip) {

                                if (tip.confirm) {

                                    wx.openSetting({

                                        success: function (data) {

                                            if (data.authSetting["scope.userLocation"] === true) {

                                                wx.showToast({

                                                    title: '授权成功',

                                                    icon: 'success',

                                                    duration: 1000

                                                })

                                                //授权成功之后,再调用chooseLocation选择地方

                                                wx.chooseLocation({

                                                    success: function(res) {

                                                        obj.setData({

                                                            addr: res.address

                                                        })

                                                    },

                                                })

                                            } else {

                                                wx.showToast({

                                                    title: '授权失败',

                                                    icon: 'success',

                                                    duration: 1000

                                                })

                                            }

                                        }

                                    })

                                }

                            }

                        })

                    }

                },

                fail: function (res) {

                    wx.showToast({

                        title: '调用授权窗口失败',

                        icon: 'success',

                        duration: 1000

                    })

                }

            })

        }

    })       

   },})

第二步:在需要获取地址的页面中:

1

2

3

4

5

6

7

8

9

10

var app = getApp();

Page({

   data:{

        addr:'请选择位置'        

    },

    //选择获取地理位置

    getAddress:function(){

          var that=this;

      app.getPermission(that);    //传入that值可以在app.js页面直接设置内容        },

})

最终效果图:

image.png

最终在手机上获取到的位置偏差不太大。

更新     wx.openSetting   的注意事项。

2.3.0 版本开始,用户发生点击行为后,才可以跳转打开设置页,管理授权信息

即2.3.0版本之后,我通过上面的wx.showModal的回调函数来调用wx.openSetting 会发生下面的错误:

image.png

openSetting:fail can only be invoked by user TAP gesture.

但是我测试 2.2.4 开始 到2.3.1 都会出现上面这种错误。

2.3.2及以上又不会出现这种问题。。。。。。。。

而且当我测试2.0.8 到  2.2.3  会出现下面的错误。。。。。。

 image.png

其它的就没有这问题了。搞不懂。。。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:借助小程序 API 接口动态获取元素宽高的方法解析
下一篇:实现小程序多图上传功能的有效途径探究
相关文章

 发表评论

暂时没有评论,来抢沙发吧~