无需轻弹即可管理片段后栈流
Manage Fragment Backstack Flow without flicks
- 我创建了 AppCompatActivity Opened 片段 A->B->C->D->E->F
用替换()
- 当我按下
按钮我想清除到 C 的片段并想在 C 之上打开 G 所以新序列将是 A->B->C->G.I 可以用
popBackStackImmediate() 并使用替换功能在 C 之上添加 G。
问题:当我按下按钮时,我看到 C 几分之一秒,然后 G 显示在 it.To 防止这种情况我试图在帮助下停止动画answer 但 C 仍然可见几分之一秒,即使动画因片段而停止。
我们有没有更好的方法来设计片段流或解决在 C 之上替换片段时的这种轻弹?
更多通用解决方案 用于此类导航流程,像这样替换片段
getSupportFragmentManager().beginTransaction().
replace(R.id.f_container,new FragmentA())
.addToBackStack("A")
.commit();
getSupportFragmentManager().beginTransaction().
replace(R.id.f_container,new FragmentB())
.addToBackStack("B")
.commit();
以同样的方式做到片段 F 并假设您在 F 上有提交按钮
现在在提交按钮的 onClick 中
使用如下所示的 POP_BACK_STACK_INCLUSIVE 标志弹出堆栈直到 D 并添加带有片段 G 的替换容器
getActivity().getSupportFragmentManager().popBackStack("D",
FragmentManager.POP_BACK_STACK_INCLUSIVE);
getSupportFragmentManager().beginTransaction().
replace(R.id.f_container,new FragmentG())
.addToBackStack("G")
.commit();
现在,当您按下后退按钮时,您将看到片段 C
我希望这对你有帮助,它对我有用
我对这个问题很好奇,所以我创建了一个示例项目并实现了您在问题中提到的相同 use-case。这是我处理这个的方法。
使用此方法从后台删除 F、E、D 片段
private void removeFragments() {
getSupportFragmentManager().popBackStack("F", FragmentManager.POP_BACK_STACK_INCLUSIVE);
getSupportFragmentManager().popBackStack("E", FragmentManager.POP_BACK_STACK_INCLUSIVE);
getSupportFragmentManager().popBackStack("D", FragmentManager.POP_BACK_STACK_INCLUSIVE);
}
使用此方法替换片段
private void replaceNewFragment(String key) {
getSupportFragmentManager().beginTransaction().addToBackStack(key)
.replace(android.R.id.content, AFragment.newInstance(key)).commit();
}
这是一个视频演示视频。
此项目于 github
完成
- 我创建了 AppCompatActivity Opened 片段 A->B->C->D->E->F 用替换()
- 当我按下 按钮我想清除到 C 的片段并想在 C 之上打开 G 所以新序列将是 A->B->C->G.I 可以用 popBackStackImmediate() 并使用替换功能在 C 之上添加 G。
问题:当我按下按钮时,我看到 C 几分之一秒,然后 G 显示在 it.To 防止这种情况我试图在帮助下停止动画answer 但 C 仍然可见几分之一秒,即使动画因片段而停止。
我们有没有更好的方法来设计片段流或解决在 C 之上替换片段时的这种轻弹?
更多通用解决方案 用于此类导航流程,像这样替换片段
getSupportFragmentManager().beginTransaction().
replace(R.id.f_container,new FragmentA())
.addToBackStack("A")
.commit();
getSupportFragmentManager().beginTransaction().
replace(R.id.f_container,new FragmentB())
.addToBackStack("B")
.commit();
以同样的方式做到片段 F 并假设您在 F 上有提交按钮 现在在提交按钮的 onClick 中
使用如下所示的 POP_BACK_STACK_INCLUSIVE 标志弹出堆栈直到 D 并添加带有片段 G 的替换容器
getActivity().getSupportFragmentManager().popBackStack("D",
FragmentManager.POP_BACK_STACK_INCLUSIVE);
getSupportFragmentManager().beginTransaction().
replace(R.id.f_container,new FragmentG())
.addToBackStack("G")
.commit();
现在,当您按下后退按钮时,您将看到片段 C
我希望这对你有帮助,它对我有用
我对这个问题很好奇,所以我创建了一个示例项目并实现了您在问题中提到的相同 use-case。这是我处理这个的方法。
使用此方法从后台删除 F、E、D 片段
private void removeFragments() {
getSupportFragmentManager().popBackStack("F", FragmentManager.POP_BACK_STACK_INCLUSIVE);
getSupportFragmentManager().popBackStack("E", FragmentManager.POP_BACK_STACK_INCLUSIVE);
getSupportFragmentManager().popBackStack("D", FragmentManager.POP_BACK_STACK_INCLUSIVE);
}
使用此方法替换片段
private void replaceNewFragment(String key) {
getSupportFragmentManager().beginTransaction().addToBackStack(key)
.replace(android.R.id.content, AFragment.newInstance(key)).commit();
}
这是一个视频演示视频。
此项目于 github
完成