RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1606577
Accepted
PseudoNIMB
PseudoNIMB
Asked:2025-02-10 16:42:38 +0000 UTC2025-02-10 16:42:38 +0000 UTC 2025-02-10 16:42:38 +0000 UTC

java 中的 onActivityResult – 如何处理来自 Composable 的 BackHandler?

  • 772

简介:Java 中有一个复杂的项目,目前正在使用 Jetpack Compose(特别是 Composable 函数)在 Kotlin 中进行模块化重写。在不同活动之间传递额外参数的旧实现是典型的(通过意图):

主活动(java):

    button.setOnClickListener(v -> {
                startActivityForResult(new Intent(MainActivity.this, SecondActivity.class), 1234);
            });
    
    .....
    
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
        if (requestCode == 1234 && resultCode == RESULT_OK) {
                //TODO Здесь какие-то действия (например получение инта)
        }
    }

SecondActivity(java):

int intPosition = 7
    backButton.setOnClickListener(view -> {
       Intent intent = new Intent();
       intent.putExtra("result", intPosition);
       setResult(RESULT_OK, intent);
       finish();
    });

但是,过渡到 Composable 的新实现意味着使用 BackHandler 和 OnBackPressedDispatcher,下面是示例:

第二项活动(带有@Composable的kotlin):

class SecondActivity : ComponentActivity() {
        override fun onCreate(savedInstanceState: Bundle?) {
            super.onCreate(savedInstanceState)
            setContent {
                MaterialTheme {
                    PatternPager()
                }
            }
        }
    }
        
    @Composable
    fun PatternPager() {
    val onBackPressedDispatcher = LocalOnBackPressedDispatcherOwner.current?.onBackPressedDispatcher
    val onBackToActivity = {
        println("back pressed")
        scope.launch {
            awaitFrame()
            onBackPressedDispatcher?.onBackPressed()
        }
    }
        Box(...) {
            Row(...) {
                ...
                Button(
                    onClick = {
                        scope.launch {
                            //TODO Здесь логика перехода
                            onBackToActivity()
                        }
                    }
                }
            }

问题是,需要在 MainActivity.java 文件中做哪些更改,才能在类似于 onActivityResult 的 PatternPager() 函数中接受来自 @Composable 的更改,以及如何将来自 @Composable 的更改发送到 java。

转换已经实现,您只需要传递额外内容。这个任务并不容易,因为 MainActivity 需要以 java 格式保存。

我向那些遇到过项目从 Java 到 Kotlin 部分迁移的人寻求帮助和建议/假设。

java
  • 1 1 个回答
  • 19 Views

1 个回答

  • Voted
  1. Best Answer
    PseudoNIMB
    2025-02-12T16:04:13Z2025-02-12T16:04:13Z

    经过几天的时间,或多或少地研究了这些材料后,我做出了以下决定:

    在Java Screen中用更现代的ActivityResultLauncher替换@Deprecated startActivityForResult

    在kotlin屏幕内用@Composable中的活动替换失败的(或者也许我还没有学会)onBackPressedDispatcher

    下面分别是修改后的屏幕MainActivity.java和SecondActivity.Kt中的代码示例。

    主活动.java:

    button.setOnClickListener(v -> {
                    Intent intent = new Intent(this, SecondActivity.class)
                    activityResultLaunch(intent);
                });
        
        .....
        
        ActivityResultLauncher<Intent> activityResultLaunch = registerForActivityResult(
                new ActivityResultContracts.StartActivityForResult(),
                activityResult -> {
                    if (activityResult.getResultCode() == Activity.RESULT_OK) {
                        switch(activityResult.getData().getIntExtra("requestCode", 0)) {
                            case 1234:
                                //TODO Здесь какие-то действия (например получение инта)
                                break;
                            default:
                                //TODO Здесь ветка стандартных действий
                                break;
                        }
                    }
                }
        .....
    

    SecondActivity.Kt:

        class SecondActivity : ComponentActivity() {
                override fun onCreate(savedInstanceState: Bundle?) {
                    super.onCreate(savedInstanceState)
                    setContent {
                        MaterialTheme {
                            PatternPager()
                        }
                    }
                }
            }
                
            @Composable
            fun PatternPager() {
                val activity = (LocalLifecycleOwner.current as ComponentActivity)
                    Box(...) {
                        Row(...) {
                            ...
                            Button(
                                onClick = {
                                    scope.launch {
                                        //TODO Здесь логика перехода
                                        val intent = Intent()
                                        intent.putExtra("result", serializableModel)
                                        intent.putExtra("requestCode", 1234)
                                        activity.setResult(RESULT_OK, intent)
                                        activity.finish()
                                    }
                                }
                            }
                            Button(
                                onClick = {
                                    scope.launch {
                                        //TODO Здесь перехода без результата (отмена)
                                        activity.setResult(RESULT_CANCELED)
                                        activity.finish()
                                    }
                                }
                            }
                        }
    

    问题解决了。

    • 0

相关问题

  • wpcap 找不到指定的模块

  • 如何以编程方式从桌面应用程序打开 HTML 页面?

  • Android Studio 中的 R.java 文件在哪里?

  • HashMap 初始化

  • 如何使用 lambda 表达式通过增加与原点的距离来对点进行排序?

  • 最大化窗口时如何调整元素大小?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5