溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

小程序怎樣獲取用戶當前位置

發布時間:2021-01-29 10:58:59 來源:億速云 閱讀:322 作者:小新 欄目:移動開發

這篇文章給大家分享的是有關小程序怎樣獲取用戶當前位置的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

有三種方式可以獲取用戶當前位置:

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

獲取當前的精度、緯度、速度。不需要授權。當type設置為gcj02 返回可用于wx.openLocation的坐標

2、wx.chooseLocation

需要授權,打開地圖選擇位置

第一次調用方法時先出現

小程序怎樣獲取用戶當前位置

允許權限之后之后再出現

小程序怎樣獲取用戶當前位置

如果第一次就不允許,則一直調用wx.chooseLocation的fail方法

3、wx.openLocation

需要授權,使用微信內置地圖查看位置。多半用于查看起點到終點的路線怎么走

小程序怎樣獲取用戶當前位置

授權方法有三種:

1、wx.getSetting

獲取用戶的當前設置,返回值中只會出現小程序已經向用戶請求過的權限,類似下面的樣子

小程序怎樣獲取用戶當前位置

2、wx.openSetting

調起權限設置選擇界面,設置界面只會出現小程序已經向用戶請求過的權限,類似下面的樣子

小程序怎樣獲取用戶當前位置

3、wx.authorize

提前向用戶發起授權請求。調用后會立刻彈窗詢問用戶是否同意授權小程序使用某項功能或獲取用戶的某些數據,但不會實際調用對應接口。如果用戶之前已經同意授權,則不會出現彈窗,直接返回成功。,類似下面的樣子

小程序怎樣獲取用戶當前位置

這就是wx.authorize出現的內容

問題來了:假如我第一次使用wx.chooseLocation()獲取權限被拒絕,然后使用wx.getSetting()來重新獲取權限該怎么做呢?

思路:wx.chooseLocation()有fail方法,如果第一次拒絕之后,以后調用選擇地圖都是觸發的這個,那么我可以在fail方法里面,使用wx.getSetting(),這樣就每次都能判斷是否已經給與了權限了。

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

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
                    })
                }
            })
        }
    })        
   },})

第二步:在需要獲取地址的頁面中:

var app = getApp();
Page({
   data:{
        addr:'請選擇位置'         
    },
    //選擇獲取地理位置
    getAddress:function(){
          var that=this;
      app.getPermission(that);    //傳入that值可以在app.js頁面直接設置內容        }, 
})

最終效果圖:

小程序怎樣獲取用戶當前位置

最終在手機上獲取到的位置偏差不太大。

更新     wx.openSetting   的注意事項。

2.3.0 版本開始,用戶發生點擊行為后,才可以跳轉打開設置頁,管理授權信息

即2.3.0版本之后,我通過上面的wx.showModal的回調函數來調用wx.openSetting 會發生下面的錯誤:

小程序怎樣獲取用戶當前位置

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  會出現下面的錯誤。。。。。。

小程序怎樣獲取用戶當前位置

感謝各位的閱讀!關于“小程序怎樣獲取用戶當前位置”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女