ano*_*rse 5 android android-fragments android-toolbar android-collapsingtoolbarlayout
我遇到了Android的新材料设计支持库的这个所谓的折叠工具栏,我正在考虑将这个新设计应用到我的一些片段中.
所以我也碰巧到达了第三方库,Material View Pager,它与a非常相似Collapsing Toolbar,只不过它有一个内置的View Pager.我想将它集成到我的应用程序中,因为它的功能非常适合某个片段.并且因为它类似于a Collapsing Toolbar,所以它提供了自己Toolbar需要设置的东西setSupportActionBar().
继续,从下面的代码中,我有一个Navigation Drawer负责导航我的五个片段(COR,课程表,评估,INC监视器和清除)之间的导航.
现在,我希望Collapsing Toolbar将它应用于我的两个片段(COR和Clearance),并将其Material View Pager应用于一个片段(评估).问题是,我已经Toolbar为我的所有片段设置了一个标准:
<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" />
Run Code Online (Sandbox Code Playgroud)
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);
}
Run Code Online (Sandbox Code Playgroud)
从上面的注释中可以看出,对于要加载的每个片段,我想加载一个不同的工具栏.但在我写的代码中,我只能有setSupportActionBar()一个Toolbar.我试着加入我的setSupportActionBar(toolbar_of_choice)每一个声明,但它崩溃了应用程序.caseswitch
那么为我的每个片段设置不同的工具栏是否有任何变通方法Navigation Drawer?
小智 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;
}
Run Code Online (Sandbox Code Playgroud)
使用上面的代码,您可以轻松地利用折叠布局。
| 归档时间: |
|
| 查看次数: |
922 次 |
| 最近记录: |