ToolBar是android5.0推出的控件,用来替代原有的ActionBar,实现自定义title的功能。
在使用它之前,(低版本要导入V7包)我们要在AndroidMainSelf文件里面将theme改成下面这样,不然的话会报错哦~:
<resources> <!-- Base application theme. --> <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar"> <!-- Customize your theme here. --> <item name="windowActionBar">false</item> <item name="windowNoTitle">true</item> <item name="colorPrimary">@color/colorPrimary</item> <item name="colorPrimaryDark">@color/colorPrimaryDark</item> <item name="colorAccent">@color/colorAccent</item> </style> </resources>没错,这里我们设置没有actionBar和没有title;
然后再我们的MainActivity里面必须继承AppCompatActivity,不然的话会提示你:
Caused by: java.lang.IllegalStateException: You need to use a Theme.AppCompat theme (or descendant) with this activity.
好了,现在就在我上一篇文章(抽屉布局)中的布局文件里面直接加上代码ToolBar:
<?xml version="1.0" encoding="utf-8"?> <android.support.v4.widget.DrawerLayout android:id="@+id/drawerlayout_main" xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" xmlns:app="http://schemas.android.com/apk/res-auto" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity" > <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <android.support.v7.widget.Toolbar android:layout_width="match_parent" android:layout_height="?attr/actionBarSize" android:background="?attr/colorPrimary"> <TextView android:layout_width="wrap_content" android:layout_height="30dp" android:text="点我一下试试" /> </android.support.v7.widget.Toolbar> <TextView android:id="@+id/home_textview_main" android:layout_width="match_parent" android:layout_height="match_parent" android:text="11111111111111111" /> </LinearLayout> <LinearLayout android:layout_width="200dp" android:layout_height="match_parent" android:layout_gravity="start" android:orientation="vertical" android:background="#ffff"> <TextView android:id="@+id/item_textview_main_1" android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1" android:text="11111" /> <TextView android:id="@+id/item_textview_main_2" android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1" android:text="22222" /> </LinearLayout> </android.support.v4.widget.DrawerLayout>
在ToolBar里面我们加了一个textview,现在运行一下,看看效果如下:
然后就可以在代码中设置一些列属性啦!这里要注意一下这个和我之前文章中抽屉布局锁展开的时候的样子不一样哦
这里展开的时候直接将title也覆盖掉了,所以我们可以用DrawerLayout和ToolBar的结合来实现这个功能。
现在来看看如何在toolbar上面点击textview打开Drawerlayout:
package com.example.administrator.drawerlayouttest; import android.support.annotation.NonNull; import android.support.v4.widget.DrawerLayout; import android.support.v7.app.ActionBarDrawerToggle; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.Gravity; import android.view.View; import android.widget.TextView; import android.widget.Toolbar; public class MainActivity extends AppCompatActivity implements View.OnClickListener { private TextView item1, item2, home; private DrawerLayout drawerLayout; private TextView toolbar; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); toolbar = findViewById(R.id.toolbar_main); drawerLayout = findViewById(R.id.drawerlayout_main); item1 = findViewById(R.id.item_textview_main_1); item2 = findViewById(R.id.item_textview_main_2); home = findViewById(R.id.home_textview_main); item1.setOnClickListener(this); item2.setOnClickListener(this); toolbar.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { drawerLayout.openDrawer(Gravity.LEFT); } }); } @Override public void onClick(View v) { switch (v.getId()) { case R.id.item_textview_main_1: home.setText(item1.getText().toString()); drawerLayout.closeDrawers(); break; case R.id.item_textview_main_2: home.setText(item2.getText().toString()); drawerLayout.closeDrawers(); break; } } }在上一篇文章的代码中添加了一个点击事件(因为想着方便就没有在onclick方法里面写,大家不要在意细节),然后调用openDrawer()方法,这里有一个问题就是,使用openDrawer方法,你必须将其中的值设置为和你在布局文件中设置的方向一致,不然程序会崩掉,这里就填入Gravity.LEFT,功能完成。