[译]AndroidX中Activity Result APIs

2020-03-25  本文已影响0人  挚爱蔚然

原文 A first look at AndroidX Activity Result APIs

前言

几周前,我发表了一篇关于 AndroidX如何改变我们处理Activity和Fragment的方式 的文章,现在就来看看 AndroidX 中新引入的 Activity Result API,该 API 增加来处理 Activity 结果请求的功能,类似于我们用 SaveStateRegistry 或用 OnBackPressedDispatcher。
    Android Result APIs 从 AndroidX Activity 1.2.0-alpha02 和 Fragment 1.3.0-alpha02 开始引入的。你可以使用-ktx 扩展库来使用 Kotlin 开发更简洁的代码。

自定义 Contract 数据

如果我们想要和其他的Activity交互,并且通过获取到返回的数据,通过到做法是用startActivityForResult 调用其他到Activity并且重写onActivityResult获取到返回到数据,在onActivityResult 方法需要判断返回到数据类型,因为如果你调用多个Activity返回到数据都是在这个方法中,你必须保证你启用的是正确的 Activity 并且在结束的是获取输出结果。这就是抽象类ActivityResultContract<I, O>包含两个抽象方法的原因

public abstract class ActivityResultContract<I, O> {

    /** Create an intent that can be used for {@link Activity#startActivityForResult} */
    public abstract @NonNull Intent createIntent(@SuppressLint("UnknownNullness") I input);

    /** Convert result obtained from {@link Activity#onActivityResult} to O */
    public abstract @SuppressLint("UnknownNullness") O parseResult(
            int resultCode,
            @Nullable Intent intent);
}

继承ActivityResultContract类重写两个方法,定义个int类型的输入参数,一个String类型的返回数据

public class MyContract extends ActivityResultContract<Integer,String> {
    private String ACTION = "com.myapp.action.MY_ACTION";//指定Action
    private String INPUT_INT = "input_int";//
    private String OUTPUT_STRING = "output_string";
    private Context context;
    
    @NonNull
    @Override
    public Intent createIntent(Integer input) {
        //创建一个Intent 可以给startActivityForResult使用
        return new Intent(ACTION).putExtra(INPUT_INT,input);
    }

    @Override
    public String parseResult(int resultCode, @Nullable Intent intent) {
        //将从onActivityResult方法中获取的返回结果进行判断和转换成指定的对象类型
        String data = null;
        if (resultCode == Activity.RESULT_OK) {
            data=intent.getStringExtra(OUTPUT_STRING);
        }
        return data;
    }
}

库中预编译好的Contract类型

使用方法

在你的Activity中使用prepareCall 方法将你自定的ActivityResultContract类的对象传入,并传入一个ActivityResultCallback对象,用于处理获取到的已经转换成特定数据类型的结果

  prepareCall(new MyContract(), new ActivityResultCallback<String>() {
            @Override
            public void onActivityResult(String result) {
            //处理获取到的已经转换成特定数据类型的结果
            }
        });

测试

prepareCall方法可以选择采用的实例ActivityResultRegistry。在测试中,您可以提供伪造的注册表实现,例如,分派模拟结果。官方文档中提供了一些示例。

摘要

Activity Result APIs现在可在Alpha AndroidX alpha版本中使用,因此在达到稳定状态之前可能会引入许多更改。但是,很高兴知道正在准备对以前的API进行如此重大的改进,并将在未来几个月内投入生产!

上一篇 下一篇

猜你喜欢

热点阅读