Android开发框架(3)基于fragment的页面管理

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跑哪里去了???


1591500668(1).png

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

下一篇 页面间的参数传递

你可能感兴趣的:(Android开发框架(3)基于fragment的页面管理)