uniapp指南针compass在苹果ios手机h5网站web上不动,安卓上面没问题的解决方法和思路

原因及解决方案:

1.uni.startCompass(),一定要绑定在事件上。不能无事件调用,即用户没有操作的情况下调用。

2.授权窗口,在调用uni.startCompass的时候,会自动弹出,无需特殊申请。

3.安卓不受影响 ,可以在无事件的情况下使用。

原因:

ios手机h5需要有方向和动作权限,这个不需要单独申请

权限弹出窗需要触发的事件,比如点击等,不能直接用代码来实现,就比如我是在onLoad里面来startCompass的,这样就不行。

解决方案:

给页面整体增加一个点击事件,事件内容开始兼听

   et_startCompass: function () {
            var that = this;
            if (that.cmbox.status == 'start') {//即已经开始了
                return false;
            }
            uni.startCompass({
                success: function (res) {
                    that.cmbox.status = 'start';
                },
                complete: function (res) {
                    that.debox.errmsg = JSON.stringify(res);
                }
            });
            uni.onCompassChange(function (res) {
                that.debox.msg = JSON.stringify(res);
                that.debox.deg = new Number(res.direction).toFixed(1);
                that.et_formatDir();
            });
        },

当使用uni.startComplass()的时候,会自动弹出此授权窗口

效果如下图:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值