一行代码搞定Android权限申请
前言
想到权限处理,安卓中提供权限请求方式就令人头疼。虽然头疼,我们还是来回顾一下默认的权限请求方式:
1.首先判断版本才能发起权限申请
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M){
//request..
}
2.其次发起之前还要做权限校验,是否已经获得该请求
if (PackageManager.PERMISSION_GRANTED == res){
//deal with the situation granted...
}else{
///request...
}
3.然后发起权限请求,并处理回调
requestPermissions(..)
...
override fun onRequestPermissionsResult(requestCode: Int, permissions: Array<out String>, grantResults: IntArray) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults)
if (requestCode == yourRequestCode){
if (grantResults[0]== PackageManager.PERMISSION_GRANTED){
//deal with the situation granted...
}else{
//deal with the situation refused...
}
}
}
简而言之一句话,复杂且繁琐。
emm.jpg现在不一样了,时代变了。我们只需要一行代码就可以实现上面的全部操作。
ohhh.gif我们先来预览一下
request(Manifest.permission.WRITE_EXTERNAL_STORAGE,requestCode){res ->
if (res) toast("WRITE_EXTERNAL_STORAGE granted...")
else toast("WRITE_EXTERNAL_STORAGE denied...")
}
是不是很简单。那么我们进入正文吧。
gkd.png
一、使用
1.添加依赖
implementation 'top.iwill.futuretools:simplepermission:1.0.1'
2.代码中使用
a.单个权限请求
request(Manifest.permission.WRITE_EXTERNAL_STORAGE,requestCode){res ->
if (res) toast("WRITE_EXTERNAL_STORAGE granted...")
else toast("WRITE_EXTERNAL_STORAGE denied...")
}
b.多个权限请求
回调定义
interface IPermissionCallback {
/**
* 多个请求成功部分的回调(没有则不会调用)
* @param grantedPermissions 请求成功的列表
*/
fun onGranted(grantedPermissions: ArrayList<out String>)
/**
* 多个请求失败部分的回调(没有则不会调用)
* @param deniedPermissions 请求成功的列表
*/
fun onDenied(deniedPermissions: ArrayList<out String>)
}
使用
request(arrayOf(Manifest.permission.WRITE_EXTERNAL_STORAGE,Manifest.permission.ACCESS_COARSE_LOCATION),requestCode){
onGranted {grantedList->
//do with grantedList...
}
onDenied {deniedList->
//do with deniedList...
}
}
en3.gif嗯?看到这里好像有哪里不对。看起来是挺简洁的,但是为什么没有Java版本啊,你把你的老大哥Java放到哪里了啊,真是一代新人换旧人啊,嗯?!啊?
gdldkf.jpg大哥息怒,给大哥递杯咖啡消消气。
有Java版本的,有的,有的。您请看:
Java使用
单个请求
PermissionUtilKt.request(activity
,Manifest.permission.ACCESS_COARSE_LOCATION,requestCode, listener);
多个请求
PermissionUtilKt.request(activity
,new String[]{Manifest.permission.ACCESS_COARSE_LOCATION},requestCode,listener);
dgdg.jpg大哥可还满意?
嗯,孺子可教。
二、原理分享
1.请求实现原理
通过对当前activity添加一个不可见的fragment,然后使用fragment进行请求的发起和回调。
内部发起权限请求调用
fragment.requestPermissions(permissions, requestCode)
内部权限请求fragment回调
class PermissionFragment : Fragment() {
companion object {
const val TAG = "top.iwill.simplepermission.PermissionFragment"
}
...
override fun onRequestPermissionsResult(requestCode: Int,
permissions: Array<out String>, grantResults: IntArray) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults)
...
}
}
2.DSL配置
通过添加DSL配置让回调更加简洁,DSL相关
class PermissionBuilder {
internal var onGranted: ((grantedPermissions: ArrayList<out String>) -> Unit)? = null
internal var onDenied: ((deniedPermissions: ArrayList<out String>) -> Unit)? = null
fun onGranted(function: ((grantedPermissions: ArrayList<out String>) -> Unit)?) {
this.onGranted = function
}
fun onDenied(function: ((deniedPermissions: ArrayList<out String>) -> Unit)?) {
this.onDenied = function
}
}
拓展函数
fun AppCompatActivity.request(permissions: Array<out String>, requestCode: Int, listener: PermissionBuilder.() -> Unit)
使用则十分简便
MainActivity.kt
request(arrayOf(Manifest.permission.WRITE_EXTERNAL_STORAGE),1){
onGranted {grantedList->
//do with grantedList...
}
onDenied {deniedList->
//do with deniedList...
}
}
三、后话
文中有不好的地方也请指导一二,在下一定悉心听取。
嘿嘿。
网友评论