前言
android 6.0加入了运行时权限功能后,目前通用的解决方案大体可分为2种:
- 在需要使用权限的地方即时申请,用户允许后继续访问,用户拒绝的话,就是PM关心的事情了
- 在app启动时,一次性申请app所需要的所有权限,用户允许后照常使用,用户拒绝的话,那么又成了PM该关心的事情了
而今天这篇文章提供的解决方案,就是上述的方案二(支F宝的解决方案)
一 效果图
二 使用方法
- 在你root的gradle中添加引用
allprojects {
repositories {
...
maven { url "https://jitpack.io" }
}
}
然后在module的gradle中添加引用
dependencies {
compile 'com.github.kaxi4it:QuickPermissions:1.0'
}
- 在程序的首页或者你认为合适的地方,参考如下代码自行添加
public class MainActivity extends AppCompatActivity {
/**
* TODO 配置所需的全部权限
* 9个危险权限组分类,如有申请,则保留,如无申请,则整行注释
* 权限组是指当组内权限被允许后,那么同组的权限则都允许使用
* 以下是6.0下九组危险权限分类,请根据自己app的实际情况调整
* 假设同时需要READ_EXTERNAL_STORAGE和WRITE_EXTERNAL_STORAGE权限时,可只申请一个,另一个也会默认通过
*/ private String[] permissions = new String[]{
Manifest.permission.READ_CALENDAR,//WRITE_CALENDAR
Manifest.permission.CAMERA,
Manifest.permission.READ_CONTACTS,//WRITE_CONTACTS,GET_ACCOUNTS
Manifest.permission.ACCESS_FINE_LOCATION,//ACCESS_COARSE_LOCATION
Manifest.permission.RECORD_AUDIO,
Manifest.permission.READ_PHONE_STATE,//CALL_PHONE,READ_CALL_LOG,WRITE_CALL_LOG,ADD_VOICEMAIL,USE_SIP,PROCESS_OUTGOING_CALLS
Manifest.permission.BODY_SENSORS,
Manifest.permission.SEND_SMS,//RECEIVE_SMS,READ_SMS,RECEIVE_WAP_PUSH,RECEIVE_MMS
Manifest.permission.READ_EXTERNAL_STORAGE,//WRITE_EXTERNAL_STORAGE
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
new CheckPermissionsForAPI23(this, permissions);
}
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M)
checkPermissionsResult(requestCode, resultCode);
}
/**
* 处理用户拒绝权限后的操作
*/
private void checkPermissionsResult(int requestCode, int resultCode) {
//sdk23+用 如果用户拒绝赋予你所需要的权限 则直接退出app,if内方法可自行斟酌
if (requestCode == PermissionsActivity.REQUEST_CODE && resultCode == PermissionsActivity.PERMISSIONS_DENIED) {
finish();
}
}
}
其中,permissions数组里,每一行代表一个权限组,当你同时需要READ_EXTERNAL_STORAGE和WRITE_EXTERNAL_STORAGE权限时,可只申请一个,另一个也会默认通过,所以可以只申请一个,但是也不要随意申请你app中不需要的权限,否则你的app会一直要求用户给予权限,从而导致app无法使用
checkPermissionsResult
方法中,可自行处理如何应对用户拒绝权限后的逻辑,demo中是直接关闭app,真实案例上,其实我也是这样的,_
CheckPermissionsForAPI23
方法会在需要申请权限时,创建一个空的activity进行权限申请处理的操作,具体代码可以在github上详细查看,此处不赘述。
三 最终章
按照如上方式正确操作后,就可以做出仿支F宝的权限申请流程了
项目完整代码在 https://github.com/kaxi4it/QuickPermissions 中可查看