ToolBar的初步使用

2017-07-27  本文已影响0人  zhong_bao

android.support.v7.widget.Toolbar的针对于Activity的用法

1、配置
ToolBar要求我们的Activity主题必须是NoActionBar,所以在我们的appTheme设置为

 <!-- BaseTheme -->
    <style name="BaseTheme" parent="Theme.AppCompat.Light.NoActionBar">
        <!-- Customize your theme here. -->
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
    </style>

其次是我们的布局toolbar.xml,按照我们的布局特性可以自行定制和添加监听

<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:id="@+id/toolBar"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:fitsSystemWindows="true"
    android:minHeight="?attr/actionBarSize"
    android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
    android:background="@color/colorPrimary"
   >

    <RelativeLayout
        android:orientation="horizontal"
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

        <TextView
            android:id="@+id/tv_title"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:gravity="center"
            android:singleLine="true"
            android:text="title"
            android:textColor="@android:color/white"
            android:textSize="20sp"
            android:layout_marginRight="15dp"
            />

        <TextView
            android:id="@+id/tv_title_more"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentRight="true"
            android:layout_marginRight="10dp"
            android:text="title right"
            android:textColor="@android:color/white"
            android:textSize="20sp"
            android:visibility="gone"
             />
    </RelativeLayout>
</android.support.v7.widget.Toolbar>

最后是我们的BaseActivity的配置如下:

  @BindView(R.id.toolBar)
    Toolbar mToolbar;
    @BindView(R.id.tv_title)
    TextView mTitleTv;
    @BindView(R.id.tv_title_more)
    TextView mTitleRightTv;

    public FragmentManager mFm;


/***************** Toobar ******************/
    public void initTitle(String title){
        setSupportActionBar(mToolbar);
        mToolbar.setNavigationIcon(android.support.v7.appcompat.R.drawable.abc_ic_ab_back_material);
        mToolbar.setNavigationOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                popBack();
            }
        });
        mTitleTv.setVisibility(View.VISIBLE);
        mTitleTv.setText(title);
        getSupportActionBar().setDisplayShowTitleEnabled(false);
    }

    public void setTitleRight(String title,View.OnClickListener listener){

        mTitleRightTv.setVisibility(View.VISIBLE);
        mTitleRightTv.setText(title);
        mTitleRightTv.setOnClickListener(listener);
    }

    public void popBack() {
        mFm =  getSupportFragmentManager();
        if (mFm.getBackStackEntryCount() > 0)
            mFm.popBackStack();
        else
            finish();
    }
    /***************** Toobar ******************/

2、使用
每一个Activity中我们必须在其布局xx.xml文件添加一个

 <include
        android:id="@+id/toolBar"
        layout="@layout/toolbar"/>

最后调用方法 initTitle("痛痛痛!!!");

3 、效果图

toobar.png
上一篇下一篇

猜你喜欢

热点阅读