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 android:background="@color/global_background_status_bar"           android:fitssystemwindows="true"

android:id="@+id/base_parent_view"

android:layout_height="match_parent"

android:layout_width="match_parent" a

ndroid:orientation="vertical" xmlns:android="https://schemas.android.com/apk/res/android">

 

<include layout="@layout/subview_toolbar/">

</include></linearlayout>

在基类中添加如上代码,基本可以用最小的改动达到使用Toolbar的目的。但是,这样也存在一个问题,就是会使我们的每个Activity的布局层次多了一层。