Android 6.0+动态权限申请(优雅封装,直接使用)

本文介绍了Android 6.0+引入的动态权限机制,详细阐述了为什么需要动态权限设置以及如何进行设置。通过鸿神大牛的MPermissions库,展示了在Activity和Fragment中优雅地申请和处理权限的方法。文章还提醒开发者在升级targetSdkVersion到23及以上时,应用可能仍能自动获取危险权限。同时提供了项目引入和混淆配置的指导。
摘要由CSDN通过智能技术生成

Android 6.0+需要申请的权限

Android 6.0 之前我们申请权限直接在配置文件中配置一下即可,但是6.0之后,谷歌官方将权限分为普通权限和危险权限。对于危险权限来说,我们就需要进行动态设置了。本文主要讲解为什么要进行Android 6.0 动态权限的设置、动态权限的使用、以及一个页面中需要同时申请多个危险权限的情况。非常感谢鸿神大牛(MPermissions)的对动态权限使用的封装,最后我们来看下如何在项目中引用鸿神封装好的包。

因为对于危险权限我们需要动态设置,不然应用会崩溃的,首先我们要清楚哪些是危险权限?看下面这张图

值得一说的是:同一组的权限不用重复授权,也就是说,同一组的权限只要有一个授权了,那么同一组的其它权限也都就授权了。

当你的应用中用到上面这些权限时,你就需要动态设置了。首先,你需要像以前一样把用到的权限依旧在配置文件中配置一下,然后,在你需要该权限的地方开撸代码进行动态设置了。下面以打电话为例来加以说明

首先,我们需要保证我们得有一台6.0的手机,targetSdkVersion的版本在23或者以上。其中需要注意一点,当我们的应用是升上来的时候,也就是说之前是23以下,现在我们让targetSdkVersion等于23或者以上时,即使不去动态设置这些危险权限,应用依旧不会崩溃掉,对于这种情况,谷歌会默认将所用到的这些危险权限自动授权。也就是说已经授权了,应用肯定不会崩溃啊。

引入

project's build.gradle

buildscript {
    dependencies {
        classpath 'com.neenbedankt.gradle.plugins:android-apt:1.4'
    }
}

module's buid.gradle

apply plugin: 'com.neenbedankt.android-apt'

dependencies {
    apt 'com.zhy:mpermission-compiler:1.0.0'
    compile 'com.zhy:mpermission-api:1.0.0'
}
*需要在AndroidManifest的application中添加
tools:replace="android:label"
*记得也要在ma
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值