我想在活动的(Java)片段(Kotlin)之一中处理用户后按操作。
在活动的 onCreate 方法中我调用
OnBackPressedCallback onBackPressedCallback = new OnBackPressedCallback(true) {
(...) handling back press when there's other BackPressedDispatcherCallbacks registered (...)
}
getOnBackPressedDispatcher().addCallback(this, onBackPressedCallback);
然后在我想处理后按的片段的 onCreateView() 中,我调用
activity?.onBackPressedDispatcher?.addCallback(viewLifecycleOwner, object : OnBackPressedCallback(true) {
override fun handleOnBackPressed() {
(...) handling back press here, not in activity (...)
}})
一切都按预期工作,直到我将应用程序置于后台然后返回前台,导致 Activity 和 Fragment 的 OnStop -> OnStart 被调用。
在这种情况下,应用程序会忽略 Fragment 回调并且正在调用 Activity 的回调。
我发现的是
onBackPressedDispatcher 以与添加回调相反的顺序调用回调。仅当最近添加的回调未启用时,才会调用之前添加的回调(仅调用最后启用的回调)
向 Activity 和 Fragment 生命周期添加观察者并记录结果打印:
FRAG:ON_START 行动:ON_START 片段:ON_RESUME 行动:ON_RESUME
OnStart 和 OnResume 上的 Activity 在 Fragments 等效项之后被调用,这有效地使 Activity 的回调成为最后一个活动回调并接收返回事件而不是 Fragment。
我正在寻找解决方案。我真的很感激任何关于如何推动它前进的建议。
PS。调用最后一个片段方法(活动fragmentManager堆栈上的最后一个)的方法是行不通的,因为目前,对于应用程序来说,这些片段不添加到后台堆栈至关重要。
活动中即可使用
getOnBackPressedDispatcher().addCallback(onBackPressedCallback);
而不是
getOnBackPressedDispatcher().addCallback(this, onBackPressedCallback);
如果你没有在
addCallback
中传递lyfecycleOwner,回调会立即添加到责任链中,因此你不必等待活动状态为STARTED