Material Desgin - Toolbar 和 滑动菜单的简单使用
Toolbar
新建项目会默认显示ActionBar,ActionBar根据项目指定的主题来显示,android:theam指定主题,在res/values/theams.xml中定义主题,因为用toolbar代替ActionBar,所以将parent主题设置为不带ActionBar的主题,如下:
<style name="Theme.MaterialTest" parent="Theme.MaterialComponents.Light.NoActionBar">
修改activity_main.xml,添加如下内容:
<androidx.appcompat.widget.Toolbar
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:id="@+id/toolbar"
android:background="?attr/colorPrimary"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"/>
在MainActivity中onCreate方法中添加如下内容,使toolbar现实出来
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
修改AndroidManifest.xml中的android:label属性,修改标题栏的文字。创建menu/toolbar.xml,给标题栏添加上action按钮,用到的属性有:
- android:id , 指定按钮id
- android:icon , 指定按钮图标
- android:title , 指定按钮文字
- app:showAsAction , 指定按钮显示位置,有三个可选项:always,ifRoom,never
具体代码应用如下:
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<item
android:id="@+id/backup"
android:icon="@drawable/ic_backup"
android:title="Backup"
app:showAsAction="always"/><!-- always:总是显示在页面上 -->
<item
android:id="@+id/delete"
android:icon="@drawable/ic_delete"
android:title="Delete"
app:showAsAction="ifRoom"/><!--ifRoom:如果有位置才显示,不然就出现在右边的三个点中-->
<item
android:id="@+id/settings"
android:icon="@drawable/ic_settings"
android:title="Settings"
app:showAsAction="never"/><!-- never:不显示在界面上,只让出现在右边的三个点中 -->
</menu>
p.s.使用xmlns:app是为了兼容以前的老系统
修改MainActivity中的代码,给toolbar.xml中的按钮设置点击事件。在OnCreateOptionsMenu方法中加载toolbar.xml文件,在onOptionsItemSelected方法中处理各个按钮的点击事件,具体实现如下:
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.toolbar,menu);
return true;
}
@Override
public boolean onOptionsItemSelected(@NonNull MenuItem item) {
switch (item.getItemId()){
case R.id.backup:
Toast.makeText(this, "clicked Backup", Toast.LENGTH_SHORT).show();
break;
case R.id.delete:
Toast.makeText(this, "clicked Delete", Toast.LENGTH_SHORT).show();
break;
case R.id.settings:
Toast.makeText(this, "clicked Settings", Toast.LENGTH_SHORT).show();
break;
default:
}
return true;
}
这就是Toolbar的简单使用。
滑动菜单
定义:
滑动菜单就是将一些菜单选项隐藏起来,而不是放置在主屏幕上,通过滑动的方式将菜单显示出来。
使用DrawerLayout实现滑动菜单
最外层使用DrawerLayout控件,从androix库引入,实现滑动菜单功能。FrameLayout控件中的内容为主屏幕中显示的内容,NavigationView为滑动菜单中显示的内容,layout_gravity属性必须指定,有三个可选项:
- left:表示滑动菜单在左边
- right:表示滑动菜单在右边
- start表示根据系统语言判断
<?xml version="1.0" encoding="utf-8"?>
<androidx.drawerlayout.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/drawer_layout"
tools:context=".MainActivity">
<!-- 主屏幕中的显示内容 -->
<FrameLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<androidx.appcompat.widget.Toolbar
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:id="@+id/toolbar"
android:background="?attr/colorPrimary"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"/>
</FrameLayout>
<!-- 滑动菜单中显示的内容,layout_gravity属性必须指定 -->
<com.google.android.material.navigation.NavigationView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="start"
android:id="@+id/nav_view"
app:menu="@menu/nav_menu"
app:headerLayout="@layout/nav_header"/>
</androidx.drawerlayout.widget.DrawerLayout>
使用NavigationView在滑动菜单页面定制布局
先在app/build.gradle中添加如下依赖:
implementation 'com.google.android.material:material:1.0.0'//用来提供NavigationView控件
implementation 'de.hdodenhof:circleimageview:3.1.0'//开源库,用来实现图片圆形化的功能
在menu下新建nav_menu来显示NavigationView的具体菜单项
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<group android:checkableBehavior="single"><!-- 指定所有菜单只能单选 -->
<item
android:id="@+id/nav_call"
android:icon="@drawable/nav_call"
android:title="Call"/>
<item
android:id="@+id/nav_friends"
android:icon="@drawable/nav_friends"
android:title="Friends"/>
<item
android:id="@+id/nav_location"
android:icon="@drawable/nav_friends"
android:title="Location"/>
<item
android:id="@+id/nav_mail"
android:icon="@drawable/nav_mail"
android:title="Mail"/>
<item
android:id="@+id/nav_task"
android:icon="@drawable/nav_task"
android:title="Tasks"/>
</group>
</menu>
在layout下新建nav_header.xml显示头部布局
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="180dp"
android:padding="10dp"
android:background="?attr/colorPrimary">
<!-- 将图片圆形化的控件,用法和ImageView一样 -->
<de.hdodenhof.circleimageview.CircleImageView
android:layout_width="70dp"
android:layout_height="70dp"
android:src="@drawable/nav_icon"
android:layout_centerInParent="true"
android:id="@+id/icon_image"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/username"
android:layout_alignParentBottom="true"
android:text="zhangxi0722@163.com"
android:textSize="14sp"
android:textColor="#FFF"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/mail"
android:layout_alignParentBottom="true"
android:layout_above="@+id/username"
android:text="zhangxi"
android:textSize="14sp"
android:textColor="#FFF"/>
</RelativeLayout>
在activity_main.xml引入设置好的nav_menu.xml和nav_header.xml,滑动页面设置完毕
在MainActivity onCreate方法中加入如下代码
mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
ActionBar actionBar = getSupportActionBar();//获得ActionBar实例
if(actionBar != null){
actionBar.setDisplayHomeAsUpEnabled(true);//先让导航按钮HomeAsUp显示出来
actionBar.setHomeAsUpIndicator(R.drawable.ic_menu);//再设置导航按钮图片ic_menu
}
NavigationView navigationView = (NavigationView) findViewById(R.id.nav_view);
navigationView.setCheckedItem(R.id.nav_call);//设置默认选中菜单
navigationView.setNavigationItemSelectedListener(new NavigationView.OnNavigationItemSelectedListener() {
@Override
public boolean onNavigationItemSelected( MenuItem item) {//设置选中事件监听
mDrawerLayout.closeDrawers();
return true;
}
});
在onOptionsItemSelected方法中添加如下代码
case android.R.id.home:
mDrawerLayout.openDrawer(GravityCompat.START);
break;
//HomeAsUp按钮默认是一个箭头返回上一层,默认id为home,通过调用openDrawer将滑动菜单显示出来
这就是滑动菜单的简单应用