android Toobar的一个简单封装

现有的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,toolbar,design,material)