关于安卓实现通用权限库的封装

简介: 关于安卓实现通用权限库的封装

!!!代码在文末!!!

内容如题,为什么要封装一个权限请求库,就是因为便于维护。
注意,本文不是开发一个权限请求库,是基于已有的三方权限请求库,进行二次封装,以便于
后续项目的维护!!!

发问

(一)权限二次封装,需要什么,怎样做到随意切换?

(二)除了封装已有的功能,还需要额外增加什么功能更便于日常需求开发?

带着这两个问题,进入下一步。

思路

博主采用的是构造者模式,抽象工厂模式进行封装,这样对于后续的维护更加方便。

对于库的入参,使用的是构造者模式,这样便于后续参数的维护。
核心代码如下:



    /**
     * builder 模式
     */

    //context
    public static PermissionUtils with(Activity activity) {
        return new PermissionUtils(activity);
    }

    public static PermissionUtils with(Fragment fragment) {
        return new PermissionUtils(fragment.requireContext());
    }

    public static PermissionUtils with(android.app.Fragment fragment) {
        return new PermissionUtils(fragment.getActivity());
    }

    //拦截器
    public PermissionUtils intercept(PermissionIntercept intercept) {
        this.mIntercept = intercept;
        return this;
    }

    //权限请求框架类型
    public PermissionUtils type(PermissionType type) {
        this.mPermissionType = type;
        return this;
    }

    //permission
    public PermissionUtils request(String[] permission) {
        this.mRequestGroup = permission;
        return this;
    }


    //key
    public PermissionUtils key(int key) {
        this.mReqKey = key;
        return this;
    }

    //listener
    public PermissionUtils setListener(PermissionCallback callback) {
        this.mCallback = callback;
        return this;
    }

    //拒绝后自动进入设置页面
    public PermissionUtils autoIntoSetting(boolean enter) {
        this.mAutoEnterSetting = enter;
        return this;
    }

    //build
    public PermissionUtils start() {
        build();
        return this;
    }

后续若有新参数传入,只需要直接加参数即可。

对于权限的实现,这里使用的是xxpermission库,主要定义了抽象接口进行实现:

    /**
     * 判断是否拥有权限
     */
    public boolean isGrant(Context context, String permission);

    public boolean isGrant(Context context, String[] permission);

    public boolean isGrant(Context context, List<String> permission);


    /**
     * 请求权限
     */
    public void requestPermission(Activity activity, String[] permission,
                                  int type, boolean enterSetting, PermissionCallback callback);

    public void requestPermission(Activity activity, List<String> permission,
                                  int type, boolean enterSetting, PermissionCallback callback);

    public void requestPermission(Fragment fragment, String[] permission,
                                  int type, boolean enterSetting, PermissionCallback callback);

    public void requestPermission(Fragment fragment, List<String> permission,
                                  int type, boolean enterSetting, PermissionCallback callback);

    public void requestPermission(android.app.Fragment fragment, String[] permission,
                                  int type, boolean enterSetting, PermissionCallback callback);

    public void requestPermission(android.app.Fragment fragment, List<String> permission,
                                  int type, boolean enterSetting, PermissionCallback callback);

后续若再有其他库,则实现类实现这些接口即可。

最后,核心的构造方法如下:

    public static PermissionImplApi create(PermissionType permissionType) {
        PermissionImplApi implApi;
        switch (permissionType) {
            case TYPE_PERMISSION_XX:
                implApi = new XXPermission();
                break;
            default:
                implApi = new XXPermission();
                break;
        }
        return implApi;
    }

至此,已经全部实现了普通请求权限功能。

但,很多应用请求权限时,都会有个应用内弹窗先让用户了解这些权限时用来干什么的,点击确认后,才会有后续的权限申请。这里特意封装了一个拦截器。开发者只需要实现拦截器类即可。实例代码如下:

public class PermissionIntercept1 implements PermissionIntercept {
    @Override
    public boolean ensureDialog(Context context, InterceptDialogCallback interceptDialog) throws Exception {
        PermissionDialog.Builder builder = new PermissionDialog.Builder(context);
        builder.setIcon(R.mipmap.ic_launcher)  //设置图标
                .setTitle("我是对话框")      //设置标题
                .setMessage("请求权限")     //设置消息
                .setPositiveButton("确定", new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        dialog.dismiss();
                        interceptDialog.confirm();
                    }
                })
                .setNegativeButton("取消", new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        dialog.dismiss();
                        interceptDialog.cancel();
                    }
                })
                .create()   //创建
                .show();    //显示
        return true;
    }
}

最后,只需调用一下以下方法,即可申请权限,注意,某些参数不一定要填写,请按需设置:

        PermissionUtils.with((Activity) getContext())
                .key(1111)
                .intercept(new PermissionIntercept1())
                .request(new String[]{Permission.READ_PHONE_STATE})
                .setListener(new PermissionCallback() {
                    @Override
                    public void result(int type, int status, boolean grantAll) {
                        LogUtil.d("result: type" + type + " status: " + status + " grantAll: " + grantAll);
                    }

                    @Override
                    public void result(int type, int status, List<String> permissions, boolean grantAll) {
                        LogUtil.d("result2: type" + type + " status: " + status + " permissions: " + GsonUtils.getJsonStr(permissions) + " grantAll: " + grantAll);
                    }

                    @Override
                    public void error(int code) {
                        LogUtil.d("result2: error" + code);
                    }
                }).start();

代码地址--库libpermission
that's all----------------------------------------------------

目录
相关文章
|
4月前
|
存储 缓存 Android开发
安卓Jetpack Compose+Kotlin, 使用ExoPlayer播放多个【远程url】音频,搭配Okhttp库进行下载和缓存,播放完随机播放下一首
这是一个Kotlin项目,使用Jetpack Compose和ExoPlayer框架开发Android应用,功能是播放远程URL音频列表。应用会检查本地缓存,如果文件存在且大小与远程文件一致则使用缓存,否则下载文件并播放。播放完成后或遇到异常,会随机播放下一首音频,并在播放前随机设置播放速度(0.9到1.2倍速)。代码包括ViewModel,负责音频管理和播放逻辑,以及UI层,包含播放和停止按钮。
|
2月前
|
存储 安全 Android开发
"解锁Android权限迷宫:一场惊心动魄的动态权限请求之旅,让你的应用从平凡跃升至用户心尖的宠儿!"
【8月更文挑战第13天】随着Android系统的更新,权限管理变得至关重要。尤其从Android 6.0起,引入了动态权限请求,增强了用户隐私保护并要求开发者实现更精细的权限控制。本文采用问答形式,深入探讨动态权限请求机制与最佳实践,并提供示例代码。首先解释了动态权限的概念及其重要性;接着详述实现步骤:定义、检查、请求权限及处理结果;最后总结了六大最佳实践,包括适时请求、解释原因、提供替代方案、妥善处理拒绝情况、适应权限变更及兼容旧版系统,帮助开发者打造安全易用的应用。
47 0
|
16天前
|
存储 API Android开发
"解锁Android权限迷宫:一场惊心动魄的动态权限请求之旅,让你的应用从平凡跃升至用户心尖的宠儿!"
随着Android系统的更新,权限管理成为应用开发的关键。尤其在Android 6.0(API 级别 23)后,动态权限请求机制的引入提升了用户隐私保护,要求开发者进行更精细的权限管理。
43 2
|
2月前
|
编解码 测试技术 Android开发
Android经典实战之用 CameraX 库实现高质量的照片和视频拍摄功能
本文详细介绍了如何利用CameraX库实现高质量的照片及视频拍摄功能,包括添加依赖、初始化、权限请求、配置预览与捕获等关键步骤。此外,还特别针对不同分辨率和帧率的视频拍摄提供了性能优化策略,确保应用既高效又稳定。
90 1
Android经典实战之用 CameraX 库实现高质量的照片和视频拍摄功能
|
2月前
|
监控 Java API
Android经典实战之OkDownload:一个经典强大的文件下载开源库,支持断点续传
本文介绍的 OkDownload 是一个专为 Android 设计的开源下载框架,支持多线程下载、断点续传和任务队列管理等功能,具备可靠性、灵活性和高性能特点。它提供了多种配置选项和监听器,便于开发者集成和扩展。尽管已多年未更新,但依然适用于大多数文件下载需求。
107 1
|
2月前
|
API Android开发
Android项目架构设计问题之选择和使用合适的UI库如何解决
Android项目架构设计问题之选择和使用合适的UI库如何解决
41 0
|
2月前
|
安全 Java 网络安全
Android远程连接和登录FTPS服务代码(commons.net库)
很多文章都介绍了FTPClient如何连接ftp服务器,但却很少有人说如何连接一台开了SSL认证的ftp服务器,现在代码来了。
75 2
|
2月前
|
测试技术 API Android开发
Android经典实战之简化 Android 相机开发:CameraX 库的全面解析
CameraX是Android Jetpack的一个组件,旨在简化相机应用开发,提供了易于使用的API并支持从Android 5.0(API级别21)起的设备。其主要特性包括广泛的设备兼容性、简洁的API、生命周期感知、简化实现及方便的集成与测试。通过简单的几个步骤即可实现如拍照、视频录制等功能。此外,还提供了最佳实践指导以确保应用的稳定性和性能。
37 0
|
3月前
|
存储 数据库 Android开发
🔥Android Jetpack全解析!拥抱Google官方库,让你的开发之旅更加顺畅无阻!🚀
【7月更文挑战第28天】在Android开发中追求高效稳定的路径?Android Jetpack作为Google官方库集合,是你的理想选择。它包含多个独立又协同工作的库,覆盖UI到安全性等多个领域,旨在减少样板代码,提高开发效率与应用质量。Jetpack核心组件如LiveData、ViewModel、Room等简化了数据绑定、状态保存及数据库操作。引入Jetpack只需在`build.gradle`中添加依赖。例如,使用Room进行数据库操作变得异常简单,从定义实体到实现CRUD操作,一切尽在掌握之中。拥抱Jetpack,提升开发效率,构建高质量应用!
53 4
|
3月前
|
Java API 开发工具
一个专为Android平台设计的高度可定制的日历库
Calendar库是Android开发的工具,支持RecyclerView和Compose,提供高度定制的日历组件。功能包括:单选/多选/范围日期选择、周/月模式、禁用特定日期、设置边界、自定义视图、每周起始日、滚动方式、热力图、标题和脚注、滑动导航及兼容低版本API。示例应用和源码可在GitHub找到,通过Gradle集成,有详细文档指导。
66 16
下一篇
无影云桌面