关于ACCESS_BACKGROUND_LOCATION权限申请,导致不弹权限对话框的问题记录

Android 6.0以后,对于需要动态申请的权限,一般步骤如下:

1.在Manifest中添加相应权限;
2.使用ActivityCompat或者ContextCompatcheckSelfPermission的方法,检查有没有权限;
3.如果没有权限,则使用ActivityCompatrequestPermissions方法申请相应权限。
4.重写onRequestPermissionsResult方法,监听权限授权结果

对于定位权限,一般需要申请ACCESS_COARSE_LOCATION权限或者ACCESS_FINE_LOCATION权限,当targetSdkVersion >= 29时,还需要申请ACCESS_BACKGROUND_LOCATION权限
例如:

private fun checkPermissions() {
        val mutableListOf = mutableListOf<String>()
        for (permission: String in permissions) {
            if (ActivityCompat.checkSelfPermission(
                    this,
                    permission
                ) != PackageManager.PERMISSION_GRANTED
            ) {
                mutableListOf.add(permission)
                Log.d("PermissionTag", "has no $permission permission")
            }
        }

        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {
            if (ACCESS_BACKGROUND_LOCATION.isNotEmpty() && ActivityCompat.checkSelfPermission(
                    this,
                    ACCESS_BACKGROUND_LOCATION
                ) != PackageManager.PERMISSION_GRANTED
            ) {
                mutableListOf.add(ACCESS_BACKGROUND_LOCATION)
                Log.d("PermissionTag", "has no background location permission")
            }
        }
        if (mutableListOf.isNotEmpty()) {
            val permissions = mutableListOf.toTypedArray()
            ActivityCompat.requestPermissions(this, permissions, 0x01)
        }
    }

其中,permissions和ACCESS_BACKGOUND_LOCATION为定义的权限常量

val permissions = arrayOf(
    Manifest.permission.ACCESS_FINE_LOCATION,
    Manifest.permission.CHANGE_WIFI_STATE,
    Manifest.permission.WRITE_EXTERNAL_STORAGE
)

val ACCESS_BACKGROUND_LOCATION =
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) Manifest.permission.ACCESS_BACKGROUND_LOCATION else ""

但是,当app的targetSdkVersion>=30,如果要申请ACCESS_BACKGOUND_LOCATION权限,则需要先申请ACCESS_COARSE_LOCATION权限或者ACCESS_FINE_LOCATION权限以后,才能申请ACCESS_BACKGROUND_LOCATION权限。如果ACCESS_BACKGROUND_LOCATION权限ACCESS_COARSE_LOCATION权限或者ACCESS_FINE_LOCATION权限一起申请,则不会弹出权限申请对话框,如果还有其他权限一起申请,则会导致所有权限申请都不会弹窗。

解决方法:
方法1.targetSdkVersion<=2;
方法2.先申请通过ACCESS_COARSE_LOCATION权限或者ACCESS_FINE_LOCATION权限,申请通过以后,再申请ACCESS_BACKGROUND_LOCATION权限

关于定位权限介绍,参考定位权限

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
如果您只申请了 `ACCESS_COARSE_LOCATION` 权限,那么可能无法通过 `getLastKnownLocation` 方法获取到位置信息,因为该方法只能获取到设备最后一次记录的位置,而不是实时位置。如果设备在获取位置之后经过了一段时间,那么这个位置可能已经过期了。 您可以尝试使用 `LocationListener` 接口来实时获取设备的位置信息。示例代码如下: ```java LocationManager locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE); if (ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) { // 没有权限,请求权限 ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.ACCESS_COARSE_LOCATION}, REQUEST_CODE); return; } // 设置位置提供器和最小更新时间和最小更新距离 locationManager.requestLocationUpdates(LocationManager.NETWORK_PROVIDER, 1000, 10, new LocationListener() { @Override public void onLocationChanged(Location location) { double latitude = location.getLatitude(); double longitude = location.getLongitude(); Log.d(TAG, "Latitude: " + latitude + ", Longitude: " + longitude); // 在这里进行位置信息的处理 } @Override public void onStatusChanged(String provider, int status, Bundle extras) { } @Override public void onProviderEnabled(String provider) { } @Override public void onProviderDisabled(String provider) { } }); ``` 在这个例子中,我们使用 `LocationManager.NETWORK_PROVIDER` 作为位置提供程序,设置了最小更新时间为1秒,最小更新距离为10米,表示当设备移动超过10米或者1秒钟时间过去之后,就会获取到最新的位置信息。 请注意,由于使用的是网络位置提供程序,因此获取到的位置信息可能会有一定的误差。如果您想要获得更精确的位置信息,需要申请 `ACCESS_FINE_LOCATION` 权限,并使用 `LocationManager.GPS_PROVIDER` 作为位置提供程序来获取位置信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值