Android 替换每个导航抽屉片段的工具栏
我遇到了这个所谓的Android新材料设计支持库,我正在考虑将这个新设计应用到我的一些片段中 因此,我也碰巧看到了这个第三方库,它非常类似于一个Android 替换每个导航抽屉片段的工具栏,android,android-fragments,android-toolbar,android-collapsingtoolbarlayout,Android,Android Fragments,Android Toolbar,Android Collapsingtoolbarlayout,我遇到了这个所谓的Android新材料设计支持库,我正在考虑将这个新设计应用到我的一些片段中 因此,我也碰巧看到了这个第三方库,它非常类似于一个折叠工具栏,只是它有一个内置的查看页面。我很想将它集成到我的应用程序中,因为它的功能非常适合某个片段。而且,由于它类似于折叠工具栏,因此它提供了自己的工具栏,需要通过setSupportActionBar()进行设置 接下来,从下面的代码开始,我有一个导航抽屉,负责在我的五个片段(COR、课程表、评估、INC监控和许可)之间导航 现在,我希望将此折叠工具
折叠工具栏
,只是它有一个内置的查看页面
。我很想将它集成到我的应用程序中,因为它的功能非常适合某个片段。而且,由于它类似于折叠工具栏,因此它提供了自己的工具栏,需要通过setSupportActionBar()
进行设置
接下来,从下面的代码开始,我有一个导航抽屉
,负责在我的五个片段(COR、课程表、评估、INC监控和许可)之间导航
现在,我希望将此折叠工具栏
应用于我的两个片段(COR&Clearance),并将此材质视图页面
应用于一个片段(评估)。问题是,我已经为我的所有片段设置了标准的工具栏
:
toolbar.xml
从上面的注释中可以看出,对于加载的每个片段,我想加载一个不同的工具栏。但是在我编写的代码中,我只能setSupportActionBar()
oneToolbar
。我尝试在我的开关语句的每个案例中放置setSupportActionBar(任选工具栏)
,但它使应用程序崩溃
那么,在我的导航抽屉
中为每个片段设置不同的工具栏时,有什么变通方法吗
@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;
}
使用上述代码,您可以轻松地使用折叠布局。您解决过这个问题吗?因为我正处于类似的情况。
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);
}
@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;
}