DrawerLayout-侧滑菜单
版本:2018/5/12-1(11:00)
1、DrawerLayout是什么?
侧滑菜单。
2.
2、DrawerLayout的使用
侧滑菜单的布局需要用layout_gravity属性指定。主体View的布局中宽高需要为match_parent且不能有layout_gravity属性
//布局文件
<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.DrawerLayout
android:id="@+id/md_drawerlayout"
xxx>
<Button
android:id="@+id/md_slidemenu_text"
android:layout_width="match_parent"
android:layout_height="match_parent"
xxx
android:layout_gravity="start"/>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
xxx主体xxx
</LinearLayout>
</android.support.v4.widget.DrawerLayout>
DrawerLayout drawerLayout = findViewById(R.id.md_drawerlayout);
Button button = findViewById(R.id.md_slidemenu_text);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
drawerLayout.closeDrawer(button); //关闭侧滑菜单
}
});
3、DrawerLayout中android:layout_gravity属性
left/start:菜单位于左侧top/bottom:菜单位于右侧
4、DrawerLayout的方法
1-打开
drawerLayout.openDrawer(button);
2-关闭
drawerLayout.closeDrawer(button);
3-设置监听器(DrawerListener)
drawerLayout.setDrawerListener(new DrawerLayout.DrawerListener() {
//滑动时
@Override
public void onDrawerSlide(View drawerView, float slideOffset) {
}
//打开时
@Override
public void onDrawerOpened(View drawerView) {
}
//关闭时
@Override
public void onDrawerClosed(View drawerView) {
}
//状态改变时:{@link #STATE_IDLE}, {@link #STATE_DRAGGING} or {@link #STATE_SETTLING}.
@Override
public void onDrawerStateChanged(int newState) {
}
});
4-设置监听器(SimpleDrawerListener)
//可以选择性实现其中的部分回调接口
drawerLayout.setDrawerListener(new DrawerLayout.SimpleDrawerListener() {
@Override
public void onDrawerSlide(View drawerView, float slideOffset) {
super.onDrawerSlide(drawerView, slideOffset);
}
});
本文详细介绍了Google推出的侧滑菜单DrawerLayout的使用方法及属性设置。包括如何在布局文件中配置侧滑菜单的位置和触发方式,以及如何通过代码控制菜单的打开与关闭,并提供了DrawerLayout常用方法和监听器的实现示例。
1637

被折叠的 条评论
为什么被折叠?



