我有片段A,B,C,D,E,导航流程是A-> B-> C-> D-> E。所以你可以说A是导航开始的基础片段。
导航流程
Add fragment with Backstack Navigate to Fragment A
A E
-> B (Add B to backstack) -> D (Remove E from backstack)
B D
-> C (Add C to backstack) -> C (Remove D from backstack)
C C
-> D (Add D to backstack) -> B (Remove C from backstack)
D B
-> E (Add E to backstack) -> A (Remove B from backstack)
** Trying to back from A and message pops
(Press once again to exit!)
使用backstack添加片段
public void pushFragmentWithBackState(Fragment DestinationFragment) throws Exception {
try {
Fragment SourceFragment = this;
int viewResourceID = ((ViewGroup) SourceFragment.getView().getParent()).getId();
FragmentManager fragmentManager = getFragmentManager();
FragmentTransaction ft = fragmentManager.beginTransaction();
ft.setCustomAnimations(R.anim.enter, R.anim.exit, R.anim.pop_enter, R.anim.pop_exit);
ft.add(viewResourceID, DestinationFragment);
ft.hide(SourceFragment);
ft.addToBackStack(DestinationFragment.getClass().getName());
ft.commit();
} catch (Exception ex) {
throw ex;
}
}
返回片段A (选中导航到片段A)
在这段代码中,我正在检查如果片段管理器中没有后向堆栈条目,这意味着我们在片段A上,我显示消息再次按下退出或者只是从片段返回。
@Override
public void onBackPressed() {
// code here to show dialog
//super.onBackPressed(); // optional depending on your needs
if (getSupportFragmentManager().getBackStackEntryCount() >= 1) {
BaseFragment fragment = (BaseFragment) getSupportFragmentManager().getFragments().get(getSupportFragmentManager().getBackStackEntryCount() - 1);
if (fragment != null) {
if (!fragment.onFragmentBackPressed()) {
//super.onBackPressed();
if (back_pressed + 2000 > System.currentTimeMillis()) {
finish();
} else {
Toast.makeText(getBaseContext(), "Press once again to exit!", Toast.LENGTH_SHORT).show();
back_pressed = System.currentTimeMillis();
}
}
} else {
//super.onBackPressed();
if (back_pressed + 2000 > System.currentTimeMillis()) {
finish();
} else {
Toast.makeText(getBaseContext(), "Press once again to exit!", Toast.LENGTH_SHORT).show();
back_pressed = System.currentTimeMillis();
}
}
} else {
if (back_pressed + 2000 > System.currentTimeMillis()) {
finish();
} else {
Toast.makeText(getBaseContext(), "Press once again to exit!", Toast.LENGTH_SHORT).show();
back_pressed = System.currentTimeMillis();
}
}
}
问题
如果我尝试从E -> B
导航并删除所有堆栈
来自片段E
poptoBackStackFragment(B.class);
方法
public boolean poptoBackStackFragment(Class SourceFragmentClass) {
getFragmentManager().popBackStack(SourceFragmentClass.getName(),0);
return true;
}
当我尝试这样做时,它不会从getSupportFragmentManager().getFragments()
清除片段列表(fragment manager
)并且位置错误,并且再次向前推送流程。 B-> C-> D片段列表如下:
在回到片段A
中找到它 BaseFragment fragment = (BaseFragment) getSupportFragmentManager().getFragments().get(getSupportFragmentManager().getBackStackEntryCount() - 1);
示例:
因为我检查我是否在基础片段上的逻辑失败并且消息即将到来我甚至没有开始片段(再按一次退出)。
当我导航到B并删除所有片段到堆栈时,为什么片段列表不明确? 我错过了什么吗?请帮忙。
注意:我还使用FragmentManager.POP_BACK_STACK_INCLUSIVE从堆栈中清除它,但发生了同样的问题。
答案 0 :(得分:0)
在getFragments
上没有方法FragmentManager
,或者更确切地说是{,}},但它是隐藏的,不应该被使用。没有说明它应该如何表现在任何地方。我认为你应该使用getBackStackEntryAt
代替,它应该有明确的行为。