向上导航(操作栏的返回箭头)对于片段无效。

8
我使用抽屉布局作为我的活动基础布局,并在这个抽屉布局内的帧上替换了两个片段。第一个片段没有添加到片段的后退栈中。我在我的活动中显示汉堡图标(我还想在我的第一个片段中显示抽屉菜单)。在第二个片段中,我通过mActionBarDrawerToggle.setDrawerIndicatorEnabled(false)禁用了汉堡图标,并使用actionBar.setDisplayHomeAsUpEnabled(true)启用了返回按钮。

在第一个片段的onResume中,我通过mActionBarDrawerToggle.setDrawerIndicatorEnabled(true)启用了汉堡图标,以便当用户从第二个片段按下返回按钮(硬件和操作栏的向上按钮)回到第一个片段时,汉堡图标将被启用。一切都很好,只是我无法从第二个片段的操作栏返回按钮返回。我无法点击它。 以下是我的代码:

活动代码

if (Utility.isLargeScreen(this))
        setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
    else
        setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);

    mHiddenGemsApplication = (HiddenGemsApplication) getApplication();

    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_home);
    initViews();

    setSupportActionBar(mToolbar);
    ActionBar actionBar = getSupportActionBar();
    if (actionBar != null) {
        actionBar.setDisplayShowTitleEnabled(false);
        actionBar.setDisplayHomeAsUpEnabled(true);
    }
    mTextViewActionBarTitle.setText(getString(R.string.app_name));

    mActionBarDrawerToggle = new ActionBarDrawerToggle(HomeActivity.this, mDrawerLayout, mToolbar, R.string.open_drawer, R.string.close_drawer) {

        @Override
        public void onDrawerClosed(View drawerView) {
            super.onDrawerClosed(drawerView);
        }

        @Override
        public void onDrawerOpened(View drawerView) {
            super.onDrawerOpened(drawerView);
        }
    };

    mDrawerLayout.setDrawerListener(mActionBarDrawerToggle);

    mActionBarDrawerToggle.syncState();

    mFragmentManager = getSupportFragmentManager();

    replaceFragment(new CategoryFragment(), getString(R.string.app_name), CategoryFragment.TAG);

 @Override
public void onBackPressed() {

    if (mDrawerLayout.isDrawerOpen(GravityCompat.START)) {
        mDrawerLayout.closeDrawers();
        return;
    }
    super.onBackPressed();
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {

    switch (item.getItemId()) {
        case android.R.id.home:
            if (mFragmentManager.getBackStackEntryCount() > 0) {
                mFragmentManager.popBackStack();
            }
            return true;
        default:
            return super.onOptionsItemSelected(item);
    }
}

 public void replaceFragment(Fragment fragment, String actionBarTitle, String tag) {

    if (mFragmentManager == null)
        return;

    FragmentTransaction fragmentTransaction = mFragmentManager.beginTransaction();
    fragmentTransaction.replace(R.id.content_frame, fragment, tag);
    if (!tag.equals(CategoryFragment.TAG))
        fragmentTransaction.addToBackStack(tag);
    fragmentTransaction.commit();

    setActionBarTitle(actionBarTitle);
}

public void setActionBarTitle(String actionBarTitle) {
    if (!TextUtils.isEmpty(actionBarTitle))
        mTextViewActionBarTitle.setText(actionBarTitle);
}

public void setDrawerIndicatorEnabled(boolean value) {
    if (mActionBarDrawerToggle != null) {
        mActionBarDrawerToggle.setDrawerIndicatorEnabled(value);
    }
}

活动XML

<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/drawer_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
tools:context="nirvaniclabs.com.hiddengems.activities.HomeActivity">

<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <include
        android:id="@+id/toolbarlayout"
        layout="@layout/toolbar_layout" />

    <FrameLayout
        android:id="@+id/content_frame"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_below="@id/toolbarlayout" />
</RelativeLayout>

<android.support.design.widget.NavigationView
    android:id="@+id/navigation"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:layout_gravity="start"
    app:menu="@menu/navigation_items" />

</android.support.v4.widget.DrawerLayout>

第一部分:

 private Button mButtonTemp;
private AppCompatActivity mActivity;
public static String TAG = "CategoryFragment";

public CategoryFragment() {
    // Required empty public constructor
}

@Override
public void onAttach(Context context) {
    super.onAttach(context);

    if (context instanceof Activity)
        mActivity = (AppCompatActivity) context;
}

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
                         Bundle savedInstanceState) {
    // Inflate the layout for this fragment
    View viewGroup = inflater.inflate(R.layout.fragment_category, container, false);
    initViews(viewGroup);

    mButtonTemp.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {

            ((HomeActivity) mActivity).replaceFragment(new TripListFragment(), "Trip Fragment", TripListFragment.TAG);
        }
    });

    return viewGroup;
}

private void initViews(View viewGroup) {
    mButtonTemp = (Button) viewGroup.findViewById(R.id.btn_temp);
}

@Override
public void onResume() {
    super.onResume();
    ((HomeActivity) mActivity).setDrawerIndicatorEnabled(true);
    ((HomeActivity) mActivity).setActionBarTitle(getString(R.string.app_name));
}

第二个片段
  private AppCompatActivity mActivity;
public static String TAG = "TripListFragment";

public TripListFragment() {
    // Required empty public constructor
}

@Override
public void onAttach(Context context) {
    super.onAttach(context);
    if (context instanceof Activity)
        mActivity = (AppCompatActivity) context;
}

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    setHasOptionsMenu(true);
    ActionBar actionBar = mActivity.getSupportActionBar();
    if (actionBar != null) {
        actionBar.setDisplayShowTitleEnabled(false);
        actionBar.setDisplayHomeAsUpEnabled(true);
    }
}


@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
                         Bundle savedInstanceState) {
    // Inflate the layout for this fragment
    return inflater.inflate(R.layout.fragment_trip_list, container, false);
}


@Override
public void onResume() {
    super.onResume();
    ((HomeActivity) mActivity).setDrawerIndicatorEnabled(false);
}

另外,在第二个片段中,我能够滑动并查看抽屉菜单。我不想有这种行为,抽屉菜单应该只在第一个片段中打开。

如果我的代码有任何问题,请告诉我。


2
你能画一个关于你的工作流程的小图吗? - Hugo Gresse
想问一下你能否帮我一点忙。当切换片段时,我无法让返回按钮显示出来。你能提供你的“toolbar_layout”和“navigation_items”布局,这样我就可以看到如何使支持在切换片段时显示返回按钮的布局正常工作。谢谢。 - Neglected Sanity
2个回答

13

终于得到了答案。在我的场景中,我通过 mActionBarDrawerToggle.setDrawerIndicatorEnabled(false); 禁用了抽屉指示器,因此导航图标的点击也被禁用了。为了启用它,我需要将 ToolbarNavigationClickListener 添加到 ActionBarDrawerToggle 中,以便能够启用导航图标的点击。

以下是我的工作代码:

mActionBarDrawerToggle.setToolbarNavigationClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                onBackPressed();
            }
        });

请参考此链接以获取更多的解释。


3

在经过很长时间的挣扎后,我终于用以下代码解决了片段中“上一页”按钮无法正常工作的问题。 在onCreate()或onCreateView()中必须设置setHasOptionsMenu。

setHasOptionsMenu(true);

然后,在onOptionsItemSelected()中,将以下代码添加到switch语句[或if语句]中,以检查是否按下了向上/主页按钮:

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    x.L();

    switch (item.getItemId()) {
        case android.R.id.home :
            getActivity().onBackPressed();

            break;

        case R.id.mn_exit :
            exitFragment();

            break;

        default :
            break;
    }

    return super.onOptionsItemSelected(item);
}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接