• 【Android


      NavigationView是Android 5.0新特性——Material Design中的一个布局控件,可以结合DrawerLayout使用,让侧滑菜单变得更加美观(可以添加头部布局)。

      NavigationView需要嵌套在DrawerLayout内部,其相对于单独使用DrawerLayout的优点在于可以额外添加一个HeaderView头部布局。另外,NavigationView中的其他选项都是用menu的形式来编写的,menu中的分支也可以在NavigationView中形成分栏效果。

      和其他MD控件一样,使用NavigationView需要在gradle文件中注册依赖:

    compile 'com.android.support:design:24.1.1'

    1、NavigationView的属性:

                app:headerLayout:NavigationView的头部布局,其中可以存放ImageView、TextView等控件
                app:menu:NavigationView中的Item项,存在menu中

    2、布局示例:

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:id="@+id/activity_main"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="#FFFFFFFF"
        android:orientation="vertical">
    
        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="@color/colorPrimary"
            android:minHeight="?attr/actionBarSize" />
    
        <android.support.v4.widget.DrawerLayout
            android:id="@+id/drawer"
            android:layout_width="match_parent"
            android:layout_height="match_parent">
    
            <!-- 主界面布局 -->
            <FrameLayout
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:background="#DDDDDD" />
    
            <android.support.design.widget.NavigationView
                android:id="@+id/navigationview"
                android:layout_width="256.0dip"
                android:layout_height="match_parent"
                android:layout_gravity="left"
                android:background="@color/colorPrimary"
                android:fitsSystemWindows="true"
                app:headerLayout="@layout/sideworks_navhead"
                app:menu="@menu/navigate" />
    
        </android.support.v4.widget.DrawerLayout>
    </LinearLayout>

      menu文件中的代码如下:

    <menu xmlns:android="http://schemas.android.com/apk/res/android">
        <group>
            <item
                android:id="@+id/one_one"
                android:icon="@mipmap/ic_launcher"
                android:title="Group one Item one" />
            <item
                android:id="@+id/one_two"
                android:icon="@mipmap/ic_launcher"
                android:title="Group one Item two" />
            <item
                android:id="@+id/one_three"
                android:icon="@mipmap/ic_launcher"
                android:title="Group one Item three" />
        </group>
        <item android:title="Group Two">
            <menu>
                <item
                    android:id="@+id/two_one"
                    android:icon="@mipmap/ic_launcher"
                    android:title="Group one Item one" />
                <item
                    android:id="@+id/two_two"
                    android:icon="@mipmap/ic_launcher"
                    android:title="Group one Item two" />
            </menu>
        </item>
    </menu>

      头部布局中的代码如下:

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="#00000000"
        android:gravity="center_horizontal"
        android:orientation="vertical">
    
        <ImageView
            android:id="@+id/header_image"
            android:layout_width="150.0dip"
            android:layout_height="150.0dip"
            android:layout_marginTop="20.0dip"
            android:contentDescription="@string/app_name"
            android:src="@mipmap/ic_launcher" />
    
        <TextView
            android:id="@+id/header_title"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginBottom="20.0dip"
            android:layout_marginTop="10.0dip"
            android:text="Navigation View"
            android:textColor="#FFFFFFFF"
            android:textSize="18.0sp"
            android:textStyle="bold" />
    
    </LinearLayout>

    3、弹出抽屉:

      在JAVA代码中通过点击Toolbar中的ActionBarDrawerToggle来弹出抽屉。代码如下:

            // 绑定Toolbar到Activity中
            setSupportActionBar(toolbar);
            // 在Toolbar上设置一个按钮,点击这个按钮可以拉出抽屉
            ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(MainActivity.this, drawer, toolbar, R.string.drawer_open, R.string.drawer_close);
            toggle.syncState();
            drawer.addDrawerListener(toggle);

      最终的演示效果如下图:

      以上就是对NavigationView的简单用法的介绍,下面贴出码云上的源码,供大家参考。

    DEMO地址

  • 相关阅读:
    Sysbench对Mysql进行基准测试
    yum安装软件时报错libmysqlclient.so.18()(64bit)
    redis启动报错Could not connect to Redis at 127.0.0.1:6379: 由于目标计算机积极拒绝,无法连接。
    cmd 中连接mysql时报'mysql'不是内部或外部命令,也不是可运行的程序或批处理文件
    Mysql远程连接权限
    Git基础教程
    电脑adb命令给智能电视安装APK
    python基础之类
    python基础之函数
    前端之CSS第二部分属性相关
  • 原文地址:https://www.cnblogs.com/itgungnir/p/6210790.html
Copyright © 2020-2023  润新知