Android开发经验谈禅与计算机程序设计艺术Android收藏集

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

2020-06-07  本文已影响0人  陈言强

EasyAndroid 是一个android完整的安装开发框架,已经应用于几个生产项目。

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之后就可以基于框架快速开发。

暂时先提交完整的框架代码,后续要完善本框架的用法。

看过前面几篇文章的同学一定会觉得奇怪,怎么页面只有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
上一篇 下一篇

猜你喜欢

热点阅读