android侧滑菜单控件DrawerLayout使用方法详解

作者:恋恋西风 时间:2023-02-02 23:58:43 

drawerLayout是Support Library包中实现了侧滑菜单效果的控件,可以说drawerLayout是因为第三方控件如MenuDrawer等的出现之后,google借鉴而出现的产物。drawerLayout分为侧边菜单和主内容区两部分,侧边菜单可以根据手势展开与隐藏(drawerLayout自身特性),主内容区的内容可以随着菜单的点击而变化(这需要使用者自己实现)。

使用步骤:

创建一个DrawerLayout

为了添加导航抽屉,你需要在你的布局界面中声明一个DrawerLayout对象作为布局的根节点。同时在DrawerLayout内部添加两个view:

  • 添加一个View,它包含应用的主内容(当抽屉隐藏时你的主要布局);

  • 添加另一个View它包含了导航抽屉;

如下面例子所示:该布局使用了DrawerLayout它包含了两个子节点:一个FrameLayout它包含了主要内容(在运行时将会被Fragment替换) 和 一个ListView作为导航抽屉,上面titlebar 上图标,负责打开、关闭抽屉;


<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"

xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
>
<LinearLayout
 android:orientation="horizontal"
 android:layout_width="match_parent"
 android:id="@+id/titleBar"
 android:gravity="center_vertical"
 android:background="@android:color/darker_gray"
 android:layout_height="40dp">

<ImageView
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:src="@drawable/ic_drawer"
  android:onClick="onClickDrawerOpened"
  android:clickable="true"
  android:id="@+id/imageView" />
</LinearLayout>
<android.support.v4.widget.DrawerLayout
 android:id="@+id/drawer_layout"
 android:layout_below="@id/titleBar"
 android:layout_width="match_parent"
 android:layout_height="match_parent">
 <!-- The main content view -->

<FrameLayout
  android:id="@+id/content_frame"

android:layout_width="match_parent"
  android:layout_height="match_parent"></FrameLayout>

<!-- The navigation drawer -->
 <ListView
  android:id="@+id/left_drawer"
  android:layout_width="240dp"
  android:layout_height="match_parent"
  android:layout_gravity="start"
  android:background="#111"
  android:choiceMode="singleChoice"
  android:divider="@android:color/transparent"
  android:dividerHeight="0dp" />
</android.support.v4.widget.DrawerLayout>
</RelativeLayout>

上面这个例子包含了一些重要的布局技巧:

  • 主内容View(FrameLayout在最上层)必须是Drawerlayout的第一个子节点因为XML在安排这些界面的时候是按照Z轴的顺序来安排的 同时 抽屉必须在主内容的顶部。

  • 主内容View被设置成匹配父View的宽和高,因为当导航抽屉隐藏的时候它要填充整个UI。

  • 导航View(ListView)必须被声明一个水平的gravity借助属性android:layout_gravity。为了满足从右到左的约定,声明它的值为”start” 代替 “left”(因此这个抽屉将会在右面呈现当布局是RTL时)

  • 在导航View声明时:宽度用dp为单位、高度匹配父View。为了保证用户无论怎样都能看到主内容的一部分,导航抽屉的宽度不能超过320dp

初始化Drawer List

在你的Activity中,要做的第一件事是初始化导航抽屉的列表项。具体该怎么做根据你APP的内容来定,但是导航抽屉通常包含一个Listview,所以还需要一个相匹配的Adapter(比如 ArrayAdapter 或者 SimpleCursorAdapter)
下面的例子,告诉你该如何借助一个string array 来初始化一个导航list


public class MainActivity extends Activity {
private DrawerLayout mDrawerLayout;
private ListView mDrawerList;

private String[] mPlanetTitles;

@Override
protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);

mPlanetTitles = getResources().getStringArray(R.array.planets_array);
 mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
 mDrawerList = (ListView) findViewById(R.id.left_drawer);

// set a custom shadow that overlays the main content when the drawer opens
 mDrawerLayout.setDrawerShadow(R.drawable.drawer_shadow, GravityCompat.START);
 // set up the drawer's list view with items and click listener
 mDrawerList.setAdapter(new ArrayAdapter<String>(this,
   R.layout.drawer_list_item, mPlanetTitles));
 mDrawerList.setOnItemClickListener(new DrawerItemClickListener());
}
//................................
}

处理导航点击事件

当用户选择了抽屉列表里面的一个Item时, 系统调用onItemClickListener上的onItemClick(), 给setOnItemClickListener().
你在onItemClick()方法里面做什么, 取决于你的app实现的结构. 在下面的例子中, 选择每一个Item都会在主要内容的布局中插入一个不同的Fragment.


private class DrawerItemClickListener implements ListView.OnItemClickListener {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
 selectItem(position);
}
}

private void selectItem(int position) {
// update the main content by replacing fragments
Fragment fragment = new PlanetFragment();
Bundle args = new Bundle();
args.putInt(PlanetFragment.ARG_PLANET_NUMBER, position);
fragment.setArguments(args);

FragmentManager fragmentManager = getFragmentManager();
fragmentManager.beginTransaction().replace(R.id.content_frame, fragment).commit();

// update selected item and title, then close the drawer
mDrawerList.setItemChecked(position, true);
mDrawerLayout.closeDrawer(mDrawerList);
}

 打开和关闭抽屉 

使用onDrawerOpened()和onDrawerClosed () 打开和关闭抽屉:


public void onClickDrawerOpened(View drawerView) {
if(!mDrawerLayout.isDrawerOpen(GravityCompat.START))//if not open ,open or close;
{
mDrawerLayout.openDrawer(mDrawerList);
}
else
{
mDrawerLayout.closeDrawer(mDrawerList);
}
}

效果图:

android侧滑菜单控件DrawerLayout使用方法详解

Demo 下载

来源:http://blog.csdn.net/q610098308/article/details/50234331

标签:android,DrawerLayout
0
投稿

猜你喜欢

  • 一篇文章带你搞定SpringBoot不重启项目实现修改静态资源

    2021-06-03 03:16:41
  • 浅谈resultMap的用法及关联结果集映射

    2022-12-25 17:42:21
  • C#获取鼠标在listview右键点击单元格的内容方法

    2023-10-26 12:40:47
  • Java Set集合及其子类HashSet与LinkedHashSet详解

    2023-11-26 11:39:35
  • Mybatis中一条SQL使用两个foreach的问题及解决

    2022-02-04 06:05:41
  • C#操作XML文件实例汇总

    2023-03-26 03:55:08
  • C# 中用 Sqlparameter 的两种用法

    2022-11-19 03:52:52
  • c#学习之30分钟学会XAML

    2022-02-08 03:09:52
  • commons fileupload实现文件上传的实例代码

    2021-08-22 16:53:00
  • 三种Android单击事件onclick的实现方法

    2022-05-21 16:54:03
  • Map集合之HashMap的使用及说明

    2022-07-23 15:56:56
  • 详解SpringMVC中的日期处理和文件上传操作

    2021-11-13 05:39:18
  • Android中ImageView实现选择本地图片并显示功能

    2023-07-02 23:47:09
  • Android开发之imageView图片按比例缩放的实现方法

    2023-01-09 21:52:51
  • Java线程间的通信方式详解

    2022-05-20 10:33:47
  • C#最简单的字符串加密解密方法

    2022-10-30 12:46:36
  • Java结构型设计模式之桥接模式详细讲解

    2023-08-26 16:25:56
  • 解析Android框架之OkHttp3源码

    2022-12-05 16:28:02
  • SpringBoot2.x过后static下的静态资源无法访问的问题

    2023-07-07 00:21:09
  • java中synchronized(同步代码块和同步方法)详解及区别

    2021-09-03 08:44:05
  • asp之家 软件编程 m.aspxhome.com