标签:android material design toolbar
现有的APP尝试向Material Design靠齐,开始使用Toolbar代替之前的ActionBar。
Toolbar和ActionBar的直观区别就是需要我们自己将ToolBar加到自己的布局文件中。目前的情况是:在我们的现有项目上改动,多数的Activity都是继承一个BaseActivity。为了用最小的代价达到目的,简单的思考之后,做了如下的改动:
/** * 带ToolBar的基类 */ public class BaseActivity extends ActionBarActivity { private static final int BASE_VIEW_ID = R.layout.activity_base; private static final LayoutParams LAYOUT_PARAMS = new LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT); private LinearLayout mParentView; private Toolbar mToolBar; @Override protected void onCreate(Bundle savedInstanceState) { ViewUtils.startTranslucent(this); super.onCreate(savedInstanceState); setContentView(BASE_VIEW_ID); } @Override public void setContentView(int layoutResID) { if (BASE_VIEW_ID == layoutResID) { super.setContentView(layoutResID); mParentView = (LinearLayout) findViewById(R.id.base_parent_view); mToolBar = (Toolbar) findViewById(R.id.toolbar); initToolbar(mToolBar); return; } mParentView.addView(getLayoutInflater().inflate(layoutResID, null), LAYOUT_PARAMS); } @Override public void setContentView(View view) { mParentView.addView(view, LAYOUT_PARAMS); } private void initToolbar(Toolbar toolbar) { setSupportActionBar(toolbar); getSupportActionBar().setDisplayHomeAsUpEnabled(true); toolbar.setNavigationOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { finish(); } }); } public Toolbar getToolBar() { return mToolBar; } public void setBackground(int colorId) { if (null != mParentView) { mParentView.setBackgroundColor(getResources().getColor(colorId)); } } }
布局文件activity_base.xml:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/base_parent_view" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@color/global_background_status_bar" android:fitsSystemWindows="true" android:orientation="vertical"> <include layout="@layout/subview_toolbar"/> </LinearLayout>在基类中添加如上代码,基本可以用最小的改动达到使用Toolbar的目的。但是,这样也存在一个问题,就是会使我们的每个Activity的布局层次多了一层。
如果有更好的思路,欢迎分享~~
标签:android material design toolbar
原文地址:http://blog.csdn.net/ttdevs/article/details/44906971