滑动菜单栏

效果如下:

新建menu布局,表示菜单栏的选项

XML 复制代码
 <menu xmlns:android="http://schemas.android.com/apk/res/android"> 
    <group android:checkableBehavior="single"> 
        <item 
            android:id="@+id/navCall" 
            android:icon="@drawable/nav_call" 
            android:title="Call" /> 
        <item 
            android:id="@+id/navFriends" 
            android:icon="@drawable/nav_friends" 
            android:title="Friends" /> 
        <item 
            android:id="@+id/navLocation" 
            android:icon="@drawable/nav_location" 
            android:title="Location" /> 
        <item 
            android:id="@+id/navMail" 
            android:icon="@drawable/nav_mail" 
            android:title="Mail" /> 
        <item 
            android:id="@+id/navTask" 
            android:icon="@drawable/nav_task" 
            android:title="Tasks" /> 
    </group

group表示item的选项属于group组内,并且设置了group里面的选项为单选

菜单栏由两部分组成,头部和菜单。上面已经实现了菜单。现在要实现头部:

XML 复制代码
 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="match_parent" 
    android:layout_height="180dp" 
    android:padding="10dp" 
    android:background="@color/colorPrimary"> 
 
    <de.hdodenhof.circleimageview.CircleImageView 
        android:id="@+id/iconImage" 
        android:layout_width="70dp" 
        android:layout_height="70dp" 
        android:src="@drawable/nav_icon" 
        android:layout_centerInParent="true" /> 
 
    <TextView 
        android:id="@+id/mailText" 
        android:layout_width="wrap_content" 
        android:layout_height="wrap_content" 
        android:layout_alignParentBottom="true" 
        android:text="tonygreendev@gmail.com" 
        android:textColor="#FFF" 
        android:textSize="14sp" /> 
 
    <TextView 
        android:id="@+id/userText" 
        android:layout_width="wrap_content" 
        android:layout_height="wrap_content" 
        android:layout_above="@id/mailText" 
        android:text="Tony Green" 
        android:textColor="#FFF" 
        android:textSize="14sp" /> 
 
</RelativeLayout> 

activity_main.xml:

XML 复制代码
<androidx.drawerlayout.widget.DrawerLayout 
    xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    android:id="@+id/drawerLayout" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent"> 
 
    <FrameLayout 
        android:layout_width="match_parent" 
        android:layout_height="match_parent"> 
        <androidx.appcompat.widget.Toolbar 
            android:id="@+id/toolbar" 
            android:layout_width="match_parent" 
            android:layout_height="?attr/actionBarSize" 
            android:background="@color/colorPrimary" 
            android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar" 
            app:popupTheme="@style/ThemeOverlay.AppCompat.Light" /> 
    </FrameLayout> 
    <com.google.android.material.navigation.NavigationView 
        android:id="@+id/navView" 
        android:layout_width="match_parent" 
        android:layout_height="match_parent" 
        android:layout_gravity="start" 
        app:menu="@menu/nav_menu" 
        app:headerLayout="@layout/nav_header"/> 
</androidx.drawerlayout.widget.DrawerLayout> 

drawerlayout是菜单栏的主体,一般配合NavigationView使用,实现好看的UI界面。drawerlayout的第一个布局是主界面的布局。第二个是打开菜单栏后的菜单栏的布局。此处直接由NavigationView替换即可。

相关推荐
2501_9400940232 分钟前
mig烧录卡资源 Mig-Switch游戏合集 烧录卡 1.75T
android·游戏·安卓·switch
渡我白衣42 分钟前
深入理解 OverlayFS:用分层的方式重新组织 Linux 文件系统
android·java·linux·运维·服务器·开发语言·人工智能
2501_915106321 小时前
iOS性能调优的系统化实践,从架构分层到多工具协同的全流程优化指南(开发者深度版)
android·ios·小程序·架构·uni-app·iphone·webview
stevenzqzq2 小时前
android recyclerview缓存_缓存问题解决办法
android·java·缓存
下位子2 小时前
『OpenGL学习滤镜相机』- Day10: 相机预览与 OpenGL 结合
android·opengl
那就逆流而上吧2 小时前
Android AIDL 的详细讲解和实践指南
android
TDengine (老段)4 小时前
TDengine 字符串函数 POSITION 用户手册
android·java·大数据·数据库·物联网·时序数据库·tdengine
2501_937154935 小时前
神马影视 8.8 源码 2025 版,HDR + 杜比音效 + 零卡顿
android·源码·源代码管理·机顶盒
asjhan5 小时前
Android framework强制修改系统属性
android
雨白13 小时前
Jetpack Compose Navigation 2.x 详解
android·android jetpack