登录

去注册 忘记密码?

登录

注册

去登录

  • 扫码关注公众号
  • 发送“我爱安卓
  • 即可获取验证码

注册

解锁回答区域

  • 扫码关注公众号
  • 发送“我爱安卓

若你登陆,将永久解锁;
若未登录,仅本机解锁。

解锁回答区域

获取注册验证码

  • 扫码关注公众号
  • 发送“我爱安卓
  • 即可获取验证码

ActivityMessenger(startActivity存取参数辅助类)

wuyr   2019-10-21 23:25   收藏

ActivityMessenger,借助Kotlin特性,简化Activity之间传参和回调的逻辑代码。

博客详情: https://blog.csdn.net/u011387817/article/details/99844066

唠叨:

在日常开发中,每次使用startActivityForResult时,要做的事情都超级多:

  1. 定义一个RequestCode

  2. 重写onActivityResult并在这里判断RequestCodeResultCode

  3. 如果有携带参数,还要一个个通过putExtra方法putIntent里;

  4. 目标Activity处理完成后还要把数据一个个putIntent中,setResult然后finish

  5. 如果参数是可序列化的泛型类对象(如ArrayList<Model>),取出来的时候不但要显式强制转型,还要把 UNCHECKED_CAST 警告抑制;

在饱受这些繁琐折磨之后,便诞生出了ActivityMessenger

它有以下特点:

  1. startActivityForResult不用另外定义RequestCode

  2. 跟其他库一样,startActivityForResult不用重写onActivityResult方法,也不用判断RequestCodeResultCode

  3. startActivity如有携带参数不须一个个调用putExtra方法;

  4. Intent中取出数据时,无须调用对应类型的方法,如getStringExtra()getIntExtra()getSerializableExtra()等;

  5. 如果参数是可序列化的泛型类对象(如ArrayList<Model>),取出来的时候不用强制转型,也没有可怕的 UNCHECKED_CAST 警告了;

示例:

startActivity:

方式1(假设TestActivity是要启动的Activity):

    //不携带参数
    ActivityMessenger.startActivity<TestActivity>(this)
    
    //携带参数(可连续多个键值对)
    ActivityMessenger.startActivity<TestActivity>(this, "Key" to "Value")

方式2(假设TestActivity是要启动的Activity):

    //不携带参数
    ActivityMessenger.startActivity(this, TestActivity::class)
    
    //携带参数(可连续多个键值对)
    ActivityMessenger.startActivity(
        this, TestActivity::class,
        "Key1" to "Value",
        "Key2" to 123
    )


startActivityForResult:

方式1(假设TestActivity是要启动的Activity):

    //不携带参数
    ActivityMessenger.startActivityForResult<TestActivity>(this) {
        if (it == null) {
            //未成功处理,即(ResultCode != RESULT_OK)
        } else {
            //处理成功,这里可以操作返回的intent
        }
    }
    
    //携带参数同startActivity。

方式2(假设TestActivity是要启动的Activity):

    //不携带参数
    ActivityMessenger.startActivityForResult(this, TestActivity::class) {
        if (it == null) {
            //未成功处理,即(ResultCode != RESULT_OK)
        } else {
            //处理成功,这里可以操作返回的intent
        }
    }
    
    //携带参数同startActivity。    


finish:

    //退出并设置参数
    ActivityMessenger.finish(this, "Key1" to "Value1", "Key2" to 2)


getExtras(获取Intent参数):

方式1

    //预先声明好类型
    var mData: List<String>? = null
    mData = intent.get("Key1")

方式2

    //取出时再决定类型
    val result = intent.get<String>("Key2")

方式3

    // 使用委托
    val key3 by extraAct("key3", "test")
    var key4: String? by extraAct("key4")


使用方式:

添加依赖:

implementation 'com.wuyr:activitymessenger:1.0.3'

库源码地址: https://github.com/Ifxcyr/ActivityMessenger


感谢:

Jowan: https://www.jowanxu.top/

RxActivityResult: https://github.com/nekocode/RxActivityResult

项目地址:https://github.com/wuyr/ActivityMessenger