0

我已经为此困扰了两天了:

1 个活动,3 个片段(A、B 和 C)。B 和 C 是选项卡。如果我用 B 替换片段 A 并将 A 添加到后堆栈,如下所示:

fragmentManager.beginTransaction()
               .addToBackStack("A_TO_B_TAG")
               .replace(R.id.fragmentContainer, fragment, "FragmentB")
               .setTransition(FragmentTransaction.TRANSIT_FRAGMENT_FADE)
               .commit();

当我从片段 C 中点击向上插入符号并执行以下操作时:

 @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        switch (item.getItemId()) {
            case android.R.id.home:
                //Pop the back stack and hide the Up caret
                FragmentManager fm = mHostingActivity.getSupportFragmentManager();
                if (fm.getBackStackEntryCount() > 0) {
                    fm.popBackStack();
                }
                mHostingActivity.getDrawerToggle().setDrawerIndicatorEnabled(true);

                //Kill any tabs
                mHostingActivity.getSupportActionBar().setNavigationMode(ActionBar.NAVIGATION_MODE_STANDARD);
                mHostingActivity.getSupportActionBar().removeAllTabs();


                return true;
        }
        return super.onOptionsItemSelected(item);
    }

然后使用第一个代码片段重新输入 B,不调用 A 的 onPause() / onStop() 并且两者都绘制在 one-another 的顶部。有谁知道这可能是什么原因?

我已经提交了一份错误报告,因为我真的不确定为什么会发生这种行为,它位于此处

4

1 回答 1

0

因此,据我所知,这是正在发生的事情,如果有人偶然发现这个问题,我希望我的回答很有用!

重新输入选项卡式片段,即:

添加 A -> 用选项卡 B 替换 A -> 用选项卡 C 替换 B -> 弹出选项卡 C -> 然后再次用选项卡 B 替换 A

在最后一次转换中用 B 替换 A 时没有分离,所以我把它放在Fragment A 的 onCreateView()

        final FragmentManager fm = mHostingActivity.getSupportFragmentManager();
        fm.addOnBackStackChangedListener(new FragmentManager.OnBackStackChangedListener() {
            @Override
            public void onBackStackChanged() {
                if (fm.getBackStackEntryCount() == 0) {
                    Fragment fragmentB = fm.findFragmentByTag("FragmentB");
                    Fragment fragmentC =  fm.findFragmentByTag("FragmentC");

                    if (fragmentB != null) {
                        //Hmm force detach here rather than when we pop via the up affordance
                        if (!fragmentB.isDetached())
                            fm.beginTransaction().detach(fragmentB).commit();
                    }
                    if (fragmentC != null) {
                        if (!fragmentC.isDetached())
                            fm.beginTransaction().detach(fragmentC).commit();
                    }

                    //Listened for any changes after re-entering the FragmentA so we can remove the listener
                    fm.removeOnBackStackChangedListener(this);
                }
            }
        });

这意味着每次创建片段 A 时,我们都会分离任何错误地可能尚未分离的选项卡式片段。

于 2014-06-13T11:28:03.297 回答