Android实现侧滑菜单DrawerLayout

Kate ·
更新时间:2024-09-20
· 682 次阅读

本文实例为大家分享了Android实现侧滑菜单的具体代码,供大家参考,具体内容如下

点击左侧滑动

效果如下

代码实现过程:

1.导入框架build.gradle中

//materialDesign implementation 'com.google.android.material:material:1.0.0'

2.xml文件

主要的界面放在DrawerLayout 中,需要强调的是侧滑菜单也就是下图显示的TextView一定要设置layout_gravity属性,我是从左侧滑动的,所以设置为start

<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" android:fitsSystemWindows="true" tools:context=".MainActivity"> <androidx.constraintlayout.widget.ConstraintLayout 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" app:layout_constraintTop_toTopOf="parent" app:popupTheme="@style/ThemeOverlay.AppCompat.Light" /> </androidx.constraintlayout.widget.ConstraintLayout> <TextView android:layout_width="match_parent" android:layout_height="match_parent" android:layout_gravity="start" android:background="#FFFFFF" android:fitsSystemWindows="true" android:text="i am a textView" /> </androidx.drawerlayout.widget.DrawerLayout>

3.MainActivity

绑定xml文件中的toobar

protected void setupToobar() { toolbar = findViewById(R.id.toolbar); setSupportActionBar(toolbar); if (null != getSupportActionBar()) { getSupportActionBar().setDisplayHomeAsUpEnabled(true); } }

MainActivity 中将点击之后触发侧边滑动的图片ic_menu动态放到toolbr中

@Override protected void setupViews() { setupToobar(); drawerLayout = findViewById(R.id.drawer); if (null != getSupportActionBar()) { getSupportActionBar().setHomeAsUpIndicator(R.drawable.ic_menu); } }

android.R.id.home 触发左侧滑动

@Override public boolean onOptionsItemSelected(MenuItem item) { switch (item.getItemId()) { case android.R.id.home: drawerLayout.openDrawer(GravityCompat.START); break; case R.id.item_search: Toast.makeText(MainActivity.this, "搜索", Toast.LENGTH_SHORT).show(); } return true; }

到这就结束了。

4.后话

可以在主内容区里面再放一个布局,里面放各个fragment,就可以实现每个页面都有侧滑菜单的效果。
侧滑菜单里面的布局可以新建一个xml文件,然后include,可以看起来舒服点吧。
其他的效果后面慢慢来吧。
github下载地址

您可能感兴趣的文章:Android侧滑菜单之DrawerLayout用法详解Android自定义实现侧滑菜单效果Android实现QQ侧滑菜单效果Android侧滑菜单控件DrawerLayout使用详解android侧滑菜单控件DrawerLayout使用方法详解Android使用DrawerLayout实现双向侧滑菜单Android中DrawerLayout实现侧滑菜单效果Android Drawerlayout实现侧滑菜单效果android实现左右侧滑菜单效果Android使用DrawerLayout实现侧滑菜单效果



drawerlayout Android

需要 登录 后方可回复, 如果你还没有账号请 注册新账号