EasyAndroid 是一个android完整的安装开发框架,已经应用于几个生产项目。
EasyAndroid 不是脱离其你原来熟悉的开发框架而另起一套,它只是将原来的流程极大地简化,所以他完全兼容其他开发框架。同时也会兼容Google后续的升级。需要的同学可以放心使用。
github地址:https://github.com/chen397254698/EasyAndroid
EasyAndroid
一个完整基于kotlin的安卓开发框架,采用了mvvm设计模式。涵盖了:
1、基于retrofit2封装的通过kotlin协程实现的网络框架
2、基于阿里开源arouter修改的api-router实现项目模块化
3、基于glide的图片加载缓存框架
4、基于room实现的往来数据缓存加载
5、基于step实现的数据异步提交
6、基于PreferenceHolder实现的本地数据快速存储
7、基于mlist实现的简单复杂列表的快速开发扩展等等。。
本框架几乎涵盖了开发所需的所有模块组件。简单fork之后就可以基于框架快速开发。
后续要完善本框架的用法。
感谢ARouter https://github.com/alibaba/ARouter
看过前面几篇文章的同学一定会觉得奇怪,怎么页面只有fragment,activity跑哪里去了???
activity在使用的时候步骤繁琐,而且都是机械的复制,还需要到AndroidManifest.xml注册,忘记注册还会奔溃。Google已经发布了Navigation,一个activity承载所有的fragment,后期迁移也将会更加简单。
使用也非常简单,也平时创建fragment完全相同,只需要在fragment上加个@Launch注解。
然后就可以通过startPage启动页面。fragment保持原有的特性,可以任意插拔。
//定义页面
@Launch
class SimpleToolbarFragment: GroupSSListFragment() {
}
//启动
startPage(SimpleToolbarFragment::class)
至于activity的启动模式,再也不需要跑到AndroidManifest.xml设置,@Launch提供了配置项
@Launch(launchType = LaunchType.FULLSCREEN, swipeType = SwipeType.DISABLE)
//页面启动模式
public enum LaunchType {
//标准启动模式。默认
STANDARD,
//页面有输入框,等同于adjustResize|stateHidden
INPUT,
//singleTop模式
SINGLE_TOP,
//全屏模式
FULLSCREEN,
//模态,从底部弹出
COVER
}
fragment默认支持侧滑返回,当然也能在@Launch中禁用,或者定义侧滑方向
public enum SwipeType {
DISABLE,
FROM_LEFT,
FROM_RIGHT,
FROM_TOP,
FROM_BOTTOM
}
一个注解就搞定一个页面,为了灵活启动在startPage中还能覆盖@Launch的配置
fragment页面查找是基于阿里开源的Arouter实现的,所以支持跨模块启动。所以跨模块启动页面也同样简单。
//任意模块下定义页面
@Launch(path = "/app/SimpleFirstFragment")
class SimpleFirstFragment : BaseSimpleFragment() {
}
//任意模块下启动
startPage(route= "/app/SimpleFirstFragment")
在gradle.properties的配置中切换模块的运行模式,每个模块都可以作为独立的运行,或者作为主应用的一个模块。
#demo 是否作为单独应用运行
Module1IsModule=true
#Module1IsModule = false