Shun 发表于 2022-5-21 12:02:23

Material Desgin

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将滑动菜单显示出来这就是滑动菜单的简单应用


   
   
   
                        

https://www.cnblogs.com/zhangxixxzz/p/16294789.html
页: [1]
查看完整版本: Material Desgin