Android

Android MVVM使用文档

2021-06-16  本文已影响0人  黄宏发

项目依赖关系

7JY62U9%8${5$%57Y_H$WAN.png

关联关系

1、应用层APP也就是项目当中的宿主
2、组件层则是项目当中的业务组件
3、基础层是一些公共的lib包

宿主依赖业务组件

dependencies {
   //宿主项目中判断组件是否需要独立运行
    if (isBuildModule.toBoolean()) {
        //组件独立运行时,宿主项目直接依赖基础库,避免编译错误
        implementation project(':library-base')
    } else {
        //主业务模块
        implementation project(':module-main')
        //登录模块
        implementation project(':module-sign')
        //首页模块
        implementation project(':module-home')
        //用户模块
        implementation project(':module-user')
        //我的模块
        implementation project(':module-mine')
    }
}

业务组件依赖library-base

dependencies {
   //组件依赖基础库
    api project(':library-base')
    //组件中依赖阿里路由编译框架
    annotationProcessor rootProject.ext.dependencies["arouter_compiler"]
    //按需依赖第三方组件
}

library-base依赖公共库

dependencies {
    //公用的support相关库在base中依赖
    api rootProject.ext.support["design"]
    api rootProject.ext.support["appcompat-v7"]
    api rootProject.ext.support["constraint-layout"]
    api rootProject.ext.support["recyclerview-v7"]
    //公用资源在base中依赖
    api project(':library-soure')
    api project(':network_processor')
    api project(':library-dialog')
    api project(':third-party-pay-login-share')
    //核心基础库(由于这是例子, 所以这里采用远程依赖的方式, 可根据实际情况自行换成源码依赖,源码地址:https://github.com/goldze/MVVMHabit)
    api rootProject.ext.dependencies["MVVMHabit"]
    //阿里路由框架
    api rootProject.ext.dependencies["arouter_api"]
    api rootProject.ext.dependencies["lifecycle-extensions"]
    api rootProject.ext.dependencies["lifecycle-compiler"]
    api rootProject.ext.dependencies["immersionbar"]
    api rootProject.ext.dependencies["alibabajson"]
    api rootProject.ext.dependencies["xxpermissions"]
    api rootProject.ext.dependencies["wechat"]
    //其他公共库,例如图片选择、分享、推送等
}

开启dataBinding

Android MVVM模式离不开DataBinding,每个组件中都需要开启,包括宿主App

android {
    //开启DataBinding
    dataBinding {
        enabled true
    }
}

manifest配置

1、组件在自己的AndroidManifest.xml各自配置activity,application标签无需添加属性,也不需要指定activity的intent-filter。当合并打包时,gradle会将每个组件的AndroidManifest合并到宿主App中。
组件关联到宿主时AndroidManifest.xml示例:
当我们程序的程序需要跳转到组件module-main里面的MainActivity时,就在组件module-main的AndroidManifest.xml里面声明

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.szy.pinhole.main">

    <application>
        <!--在自己组件中注册Activity-->
        <activity
            android:name=".activity.MainActivity"
            android:configChanges="orientation|keyboardHidden|screenSize"
            android:exported="true"
            android:launchMode="singleTask"
            android:screenOrientation="portrait" />
        <service
            android:name=".service.ReportRecordDataService"
            android:enabled="true"
            android:exported="false" />
    </application>
</manifest>

2、组件独立运行时,就需要单独的一个AndroidManifest.xml作为调试用。可以在src/main文件夹下创建一个alone/AndroidManifest.xml。配置application标签属性,并指定启动的activity。这个跟宿主APP的AndroidManifest.xml配置结构是一样的

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.goldze.main">
    <application
        ...
        >
        <activity 
            ...
            >
            <intent-filter>
                ...
            </intent-filter>
        </activity>
    </application>
</manifest>

build.gradle中配置

android {
    sourceSets {
        main {
            ...
            if (isBuildModule.toBoolean()) {
                //独立运行
                manifest.srcFile 'src/main/alone/AndroidManifest.xml'
            } else {
                //合并到宿主
                manifest.srcFile 'src/main/AndroidManifest.xml'
                resources {
                    //正式版本时,排除alone文件夹下所有调试文件
                    exclude 'src/main/alone/*'
                }
            }
        }
    }
}

Activity之间跳转与传值

1、在activity里面添加注解@Route(path = RouterActivityPath.Scan.PAGER_SCAN_WIFI_RESULT)
2、通过阿里的ARouter调用执行RouterActivityPath.Scan.PAGER_SCAN_WIFI_RESULT
//示例代码:

ARouter.getInstance().build(RouterActivityPath.Scan.PAGER_SCAN_WIFI_RESULT)
                    .withParcelableArrayList("ipList", ipList).navigation();

Activity接收传值

1、需要再onCreate方法添加
 ARouter.getInstance().inject(this);
2、通过声明获取属性即可获取到值
@Autowired(name = "ipList")
ArrayList<ScanDeviceEntity> ipList;

ARouter传递一个int类型的id,String类型同理

ARouter.getInstance().build(RouterActivityPath.Strategy.PAGER_ARTICLE_ACTIVITY)
                                .withInt("id", videoEntity.getId()).navigation();

Activity接收一个int类型的id值,String类型同理

1、需要再接收值的Activity里面的onCreate方法添加
ARouter.getInstance().inject(this);

@Autowired()
int id;
上一篇下一篇

猜你喜欢

热点阅读