/DevRing

安卓基础开发库,包含各常用模块,让开发简单点。

Primary LanguageJava

DevRing

label1 label2 label3 label4

介绍

DevRing是一个提供了常用模块的安卓基础开发库
主要包括 网络请求图片加载数据库事件总线缓存权限管理工具类 模块。

其中,网络请求使用Retrofit+RxJava实现,图片加载使用Glide实现(可替换),数据库使用GreenDao实现(可替换),事件总线使用EventBus实现(可替换),权限管理使用RxPermission实现。

Demo采用MVP+Dagger2进行开发,对以上提及的框架不熟悉的建议先行了解,底部也有相关的博客链接

使用

1.添加依赖

在项目module下的gradle中添加以下依赖:

compile 'com.ljy.ring:devring:1.0.9'

2.初始化、配置、构建

在Application的onCreate中进行初始化、配置、构建。
务必按顺序执行这三步。

//1.初始化
DevRing.init(this);


//2.根据你的需求进行相关模块的全局配置

//配置网络请求模块,如BaseUrl,连接超时时长,Log,全局Header,缓存,失败重试等
DevRing.configureHttp().setXXX()...

//配置图片加载模块,如替换实现框架,加载中图片,加载失败图片,开启过渡效果,缓存等
DevRing.configureImage().setXXX()...

//配置事件总线模块,如替换实现框架,EventBus的index加速
DevRing.configureBus().setXXX()...

//配置数据库模块、替换实现框架
DevRing.configureDB(dbManager);  

//配置缓存模块,如磁盘缓存的地址、大小等
DevRing.configureCache().setXXX()...

//配置其他模块,如是否显示RingLog,是否启用崩溃日志等
DevRing.configureOther().setXXX()...


//3.构建
DevRing.create();

3.开始调用

通过DevRing.xxxManager()得到相关模块的管理者,然后进行具体操作。

//网络请求模块:
//普通请求、上传请求、下载请求、监听上传下载进度、生命周期控制等。
DevRing.httpManager().xxx();

//图片加载模块:
//各类型图片的加载,可设置加载要求(圆形、圆角、模糊、灰白),下载图片,获取Bitmap等
DevRing.imageManager().xxx();

//事件总线模块:
//订阅、解除订阅,发送普通事件,发送粘性事件
DevRing.busManager().xxx();

//数据库模块:
//对key值对应的数据表进行增删改查等
DevRing.tableManager(key).xxx();

//缓存模块:
//提供内存缓存,磁盘缓存,SharedPreference缓存
DevRing.cacheManager().xxxCache().xxx();

//其他模块:权限管理、Activity管理
DevRing.permissionManager().xxx();
DevRing.activityListManager().xxx();

...

4.LifeCycleCallback

提供了ActivityLifeCallback 和 FragmentLifeCallback,以实现基类的功能。
只需Activity实现IBaseActivity接口即可完成相关的基类操作。
只需Fragment实现IBaseFragment接口即可完成相关的基类操作。
具体请查看关于基类的那些事以及项目代码

5.工具类

提供了部分常用的工具类:
ColorBar(设置导航栏/状态栏颜色),FileUtil(文件操作工具类),RingLog(可定位的Log打印),RingToast(吐司工具类),ImageUitl(图片工具类),NetworkUtil(网络状态工具类)等。

6.注意事项

  1. 配置参数为File时,请自行确保对传入的File具有可读写权限。  
  2. 部分框架需忽略混淆,具体的混淆配置请参考Demo中app下的proguard-rules.pro文件。
  3. DevRing库中AndroidManifest已添加了网络权限,所以主项目不必重复添加。
  4. DevRing库中已添加了Glide,EventBus,GreenDao,Dagger2,Retrofit2,RxJava2,RxAndroid2,RxLifeCycle2,RxPermission2的依赖,所以主项目不必重复添加。
  5. 可以通过exclude移除DevRing库中相关框架的依赖以减小包体积。 例如:
api ('com.ljy.ring:devring:x.x.x'){
   //如果不需使用图片加载模块或者该模块不使用Glide实现,那么可以加上这句移除Devring库中对Glide的依赖以减小包体积
   exclude module: 'glide'
   //如果不需使用事件总线模块或者该模块不使用EventBus实现,那么可以加上这句移除Devring库中对EventBus的依赖以减小包体积
   exclude module: 'eventbus'
   //如果不需使用数据库模块或者该模块不使用GreenDao实现,那么可以加上这句移除Devring库中对GreenDao的依赖以减小包体积
   exclude module: 'greendao'
}

Demo

内容

  1. 使用MVP+Dagger2进行开发。
  2. 演示了DevRing各模块的使用,如网络请求(电影列表,上传/下载例子),图片加载(电影图片),事件总线(更新收藏数量),数据库(电影收藏),权限管理(拍照/相册图片)等。
  3. 演示了如何使用Fresco替换图片加载模块中默认的Glide。
  4. 演示了如何使用RxBus替换事件总线模块中默认的EventBus。
  5. 演示了如何使用原生数据库替换数据库模块中默认的GreenDao。  
  6. 演示了如何使用LifeCycleCallback来实现Activity/Fragment基类的功能。
    ....

运行图

screen1   screen2

screen3   screen4



一键生成MVP、Dagger2代码

可快速生成MVP相关代码,如Model、Activity/Fragment、Presenter、IModel、IView.
可快速生成Dagger2相关代码,如Component、Module.
修改自JessYan的模板,根据DevRing Demo的代码结构以及个人需求进行了调整。

步骤1

拷贝devRingTemplate文件夹到

  • Windows: AS安装目录/plugins/android/lib/templates/activities
  • Mac: /Applications/Android Studio.app/Contents/plugins/android/lib/templates/activities 然后重启Android Studio

步骤2

在项目的根包名(如com.dev.base)下右键--->New --->Activity --->DevRing快速生成模板。

步骤3

在Page Name中输入功能模块名,然后根据需要勾选你要生成的部分,点击Finish一键生成。



版本信息

  • v1.0.8/1.0.9 (2018/5/20)

    • ActivityStackManager改为ActivityListManager
    • 修复CacheManager中SpCache的小问题
    • 优化http访问异常的处理
  • v1.0.7 (2018/5/15)

    • 优化部分工具类
    • 加入安卓7.0 File适配
    • 调整http访问异常处理
  • v1.0.6 (2018/4/20)

    • 调整对glide,eventbus,greendao的依赖方式(从compileOnly调整为api)

更多版本信息点这里查看


相关博客

相关框架的用法介绍,如果觉得对你有帮助,欢迎关注点赞~  

DevRing使用说明
系列开篇
Retrofit+RxJava
Fresco
Glide
EventBus
ButterKnife
GreenDAO
MVP
Dagger2
关于基类的那些事
常用的一些工具类


最后,感谢本项目中所涉及的开源代码的作者们。
有什么问题或建议,可以提issue或者简书告知。
如果觉得对你有帮助,不妨点个★star支持鼓励我~