为每一个导航抽屉片段更换工具栏

5
我遇到了新的Material Design支持库中所谓的Collapsing Toolbar, 我正在考虑将这种新设计应用于我的一些片段。
所以我也碰巧找到了这个第三方库Material View Pager,它与Collapsing Toolbar非常相似,除了它具有内置的View Pager。我非常想将其集成到我的应用程序中,因为其功能完全适合某个片段。而且由于它类似于Collapsing Toolbar,它提供了自己的Toolbar,需要通过setSupportActionBar()进行设置。
接下来,从我的代码中可以看到,我有一个负责在我的五个片段(COR、课程表、评估、INC监视器和清除)之间导航的Navigation Drawer

现在,我希望将这个“Collapsing Toolbar”应用于我的两个片段(COR和Clearance),并将这个“Material View Pager”应用于一个片段(Evaluation)。问题是,我已经为所有的片段设置了一个标准的工具栏(Toolbar)。

toolbar.xml

<android.support.v7.widget.Toolbar
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
    app:theme="@style/ActionBarPopupThemeOverlay"
    app:menu="@menu/menu_toolbar"
    android:id="@+id/toolbar"
    android:background="@color/primary_dark"
    android:layout_height="wrap_content"
    android:layout_width="match_parent"
    android:minHeight="?attr/actionBarSize"
    android:elevation= "4dp" />

MainActivity.java

public void setupToolbar() {
    toolbar = (Toolbar) findViewById(R.id.toolbar);
    if (toolbar != null) {
        setSupportActionBar(toolbar);
    }
}

public void setupNavigationDrawer() {
    drawer_layout = (DrawerLayout) findViewById(R.id.drawer_layout);
    navigation_view = (NavigationView) findViewById(R.id.navigation_view);

    navigation_view.setNavigationItemSelectedListener(new NavigationView.OnNavigationItemSelectedListener() {

        @Override
        public boolean onNavigationItemSelected(MenuItem menuItem) {
            fragment_manager = getSupportFragmentManager();
            fragment_transaction = fragment_manager.beginTransaction();
            fragment_transaction.setCustomAnimations(R.anim.fade_in, R.anim.fade_out);

            menuItem.setChecked(true);

            switch (menuItem.getItemId()) {
                case R.id.cor:   //Collapsing Toolbar here
                    fragment_transaction.replace(R.id.content, cor_fragment);
                    break;
                case R.id.sched: //Normal Toolbar here
                    fragment_transaction.replace(R.id.content, sched_fragment);
                    break;
                case R.id.eval:  //Material View Pager Toolbar here
                    fragment_transaction.replace(R.id.content, eval_fragment);
                    break;
                case R.id.inc:   //Normal Toolbar here
                    fragment_transaction.replace(R.id.content, inc_fragment);
                    break;
                case R.id.clear: //Collapsing Toolbar here
                    fragment_transaction.replace(R.id.content, clear_fragment);
                    break;
            }

            mHandler = new Handler();
            mHandler.removeCallbacksAndMessages(null);
            int delay = 400;
            mHandler.postDelayed(new Runnable() {
                @Override
                public void run() {
                    fragment_transaction.addToBackStack(null);
                    fragment_transaction.commit();
                }
            }, delay);

            drawer_layout.closeDrawers();

            return true;
        }
    });

    drawer_toggle = new ActionBarDrawerToggle(this, drawer_layout, toolbar, R.string.open_drawer, R.string.close_drawer) {
        @Override
        public void onDrawerOpened(View drawerView) {
            super.onDrawerOpened(drawerView);
        }
        @Override
        public void onDrawerClosed(View drawerView) {
            super.onDrawerClosed(drawerView);
        }
    };
    drawer_layout.setDrawerListener(drawer_toggle);
    drawer_toggle.syncState();

    drawer_layout.openDrawer(GravityCompat.START);
}

正如您从上面的评论中所看到的,对于每个正在加载的片段,我想要加载不同的工具栏。但是在我编写的代码中,我只能 setSupportActionBar() 一个 Toolbar。我尝试将 setSupportActionBar(toolbar_of_choice) 放置在我的 switch 语句的每个 case 中,但这会导致应用程序崩溃。
那么,在我的 Navigation Drawer 中为每个片段设置不同的工具栏是否有任何解决方法?

你曾经解决过这个问题吗?因为我也遇到了类似的情况。 - FlashAsh80
1个回答

0
@Override
public boolean onNavigationItemSelected(MenuItem menuItem) {
    fragment_manager = getSupportFragmentManager();
    fragment_transaction = fragment_manager.beginTransaction();
    fragment_transaction.setCustomAnimations(R.anim.fade_in, R.anim.fade_out);

    menuItem.setChecked(true);

    switch (menuItem.getItemId()) {
        case R.id.cor:   //Collapsing Toolbar here
            fragment_transaction.replace(R.id.content, cor_fragment);
            Toolbar toolbar =(Toolbar)findViewById(R.id.toolbar);
            toolbar.setVisibility(View.GONE);
            // use can replace original toolbar with collapsing//
            break;
        case R.id.sched: //Normal Toolbar here
            fragment_transaction.replace(R.id.content, sched_fragment);
Toolbar toolbar =(Toolbar)findViewById(R.id.toolbarmain);
        toolbar.setVisibility(View.VISIBLE);
            break;
        case R.id.eval:  //Material View Pager Toolbar here
            fragment_transaction.replace(R.id.content, eval_fragment);
            break;
        case R.id.inc:   //Normal Toolbar here
            fragment_transaction.replace(R.id.content, inc_fragment);
Toolbar toolbar =(Toolbar)findViewById(R.id.toolbarmain);
        toolbar.setVisibility(View.VISIBLE);
            break;
        case R.id.clear: //Collapsing Toolbar here
            fragment_transaction.replace(R.id.content, clear_fragment);
            break;
    }

使用上述代码,您可以轻松地利用折叠布局。

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