1.首先我们看一下它的监听事件的生命周期

代码如下

 mDrawerLayout.setDrawerListener(new DrawerListener() {
@Override
public void onDrawerStateChanged(int arg0) {
mHistoryHideButton.startAnimation(myAnimation);
android.util.Log.e("zhangshuli", "statechange");
} @Override
public void onDrawerSlide(View arg0, float arg1) {
mHistoryHideButton.startAnimation(myAnimationRecover);
android.util.Log.e("zhangshuli", "slide"); } @Override
public void onDrawerOpened(View arg0) {
myHistoryAnimationSetCount = 0;
myHistoryItemCount= mHistory.mEntries.size()-1;
if (mHistoryDisplayList.getCount() == 0) {
mHistoryClearButton.setEnabled(false);
} else {
mHistoryClearButton.setEnabled(true);
}
android.util.Log.e("zhangshuli", "open");
} @Override
public void onDrawerClosed(View arg0) {
history_clear_choose.setVisibility(View.GONE);
android.util.Log.e("zhangshuli", "colse");
}
});

当我们直接点开,也就是执行

if (!mDrawerLayout.isDrawerVisible(GravityCompat.END)) {
mDrawerLayout.openDrawer(GravityCompat.END);
}

的时候,打印结果如下

- ::57.163 E/zhangshuli(): statechange
- ::57.171 E/zhangshuli(): slide
- ::57.204 E/zhangshuli(): slide
- ::57.238 E/zhangshuli(): slide
- ::57.262 E/zhangshuli(): slide
- ::57.290 E/zhangshuli(): slide
- ::57.317 E/zhangshuli(): slide
- ::57.341 E/zhangshuli(): slide
- ::57.366 E/zhangshuli(): slide
- ::57.393 E/zhangshuli(): slide
- ::57.420 E/zhangshuli(): slide
- ::57.445 E/zhangshuli(): slide
- ::57.470 E/zhangshuli(): slide
- ::57.496 E/zhangshuli(): slide
- ::57.519 E/zhangshuli(): slide
- ::57.545 E/zhangshuli(): slide
- ::57.590 E/zhangshuli(): open
- ::57.591 E/zhangshuli(): statechange

我们可以看到

onDrawerStateChanged 在状态开始改变跟状态改变完成以后各执行一次
onDrawerOpened 最终打开以后执行
onDrawerSlide 一直在移动的过程中执行

关闭的时候,点击关闭

- ::27.180 E/zhangshuli(): statechange
- ::27.190 E/zhangshuli(): slide
- ::27.215 E/zhangshuli(): slide
- ::27.246 E/zhangshuli(): slide
- ::27.270 E/zhangshuli(): slide
- ::27.295 E/zhangshuli(): slide
- ::27.319 E/zhangshuli(): slide
- ::27.349 E/zhangshuli(): slide
- ::27.378 E/zhangshuli(): slide
- ::27.412 E/zhangshuli(): slide
- ::27.440 E/zhangshuli(): slide
- ::27.463 E/zhangshuli(): slide
- ::27.485 E/zhangshuli(): slide
- ::27.506 E/zhangshuli(): slide
- ::27.527 E/zhangshuli(): slide
- ::27.561 E/zhangshuli(): slide
- ::27.601 E/zhangshuli(): colse
- ::27.601 E/zhangshuli(): statechange

跟上面唯一的区别也就是

彻底关闭的时候,执行

onDrawerClosed

当我们是滑动打开的时候

- ::20.367 E/zhangshuli(): statechange
- ::20.375 E/zhangshuli(): slide
- ::20.395 E/zhangshuli(): statechange
- ::20.439 E/zhangshuli(): slide
- ::20.470 E/zhangshuli(): slide
- ::20.500 E/zhangshuli(): slide
- ::20.524 E/zhangshuli(): slide
- ::20.548 E/zhangshuli(): slide
- ::20.572 E/zhangshuli(): slide
- ::20.599 E/zhangshuli(): slide
- ::20.621 E/zhangshuli(): slide
- ::20.643 E/zhangshuli(): slide
- ::20.666 E/zhangshuli(): slide
- ::20.689 E/zhangshuli(): slide
- ::20.713 E/zhangshuli(): slide
- ::20.736 E/zhangshuli(): slide
- ::20.760 E/zhangshuli(): slide
- ::20.785 E/zhangshuli(): slide
- ::20.810 E/zhangshuli(): slide
- ::20.834 E/zhangshuli(): slide
- ::20.859 E/zhangshuli(): slide
- ::20.882 E/zhangshuli(): slide
- ::20.906 E/zhangshuli(): slide
- ::20.931 E/zhangshuli(): slide
- ::20.962 E/zhangshuli(): slide
- ::20.994 E/zhangshuli(): slide
- ::21.019 E/zhangshuli(): slide
- ::21.045 E/zhangshuli(): slide
- ::21.070 E/zhangshuli(): slide
- ::21.094 E/zhangshuli(): slide
- ::21.118 E/zhangshuli(): slide
- ::21.143 E/zhangshuli(): slide
- ::21.168 E/zhangshuli(): slide
- ::21.193 E/zhangshuli(): slide
- ::21.218 E/zhangshuli(): slide
- ::21.241 E/zhangshuli(): slide
- ::21.266 E/zhangshuli(): slide
- ::21.291 E/zhangshuli(): slide
- ::21.318 E/zhangshuli(): slide
- ::21.343 E/zhangshuli(): slide
- ::21.367 E/zhangshuli(): slide
- ::21.392 E/zhangshuli(): slide
- ::21.417 E/zhangshuli(): slide
- ::21.442 E/zhangshuli(): slide
- ::21.469 E/zhangshuli(): slide
- ::21.494 E/zhangshuli(): slide
- ::21.519 E/zhangshuli(): slide
- ::21.544 E/zhangshuli(): slide
- ::21.569 E/zhangshuli(): slide
- ::21.597 E/zhangshuli(): slide
- ::21.623 E/zhangshuli(): slide
- ::21.649 E/zhangshuli(): slide
- ::21.674 E/zhangshuli(): slide
- ::21.698 E/zhangshuli(): slide
- ::21.724 E/zhangshuli(): slide
- ::21.750 E/zhangshuli(): slide
- ::21.776 E/zhangshuli(): slide
- ::21.801 E/zhangshuli(): slide
- ::21.832 E/zhangshuli(): slide
- ::21.858 E/zhangshuli(): slide
- ::21.882 E/zhangshuli(): slide
- ::21.906 E/zhangshuli(): slide
- ::21.930 E/zhangshuli(): slide
- ::21.955 E/zhangshuli(): slide
- ::21.980 E/zhangshuli(): slide
- ::22.007 E/zhangshuli(): slide
- ::22.035 E/zhangshuli(): slide
- ::22.062 E/zhangshuli(): slide
- ::22.262 E/zhangshuli(): open
- ::22.262 E/zhangshuli(): statechange

其实跟我们直接点开没太大区别,就是

onDrawerSlide 一直在执行。所以,这个方法应该可以得到你的移动坐标

滑动关闭的时候

- ::38.056 E/zhangshuli(): statechange
- ::38.073 E/zhangshuli(): slide
- ::38.100 E/zhangshuli(): slide
- ::38.130 E/zhangshuli(): slide
- ::38.161 E/zhangshuli(): slide
- ::38.193 E/zhangshuli(): slide
- ::38.222 E/zhangshuli(): slide
- ::38.250 E/zhangshuli(): slide
- ::38.275 E/zhangshuli(): slide
- ::38.298 E/zhangshuli(): slide
- ::38.322 E/zhangshuli(): slide
- ::38.347 E/zhangshuli(): slide
- ::38.371 E/zhangshuli(): slide
- ::38.402 E/zhangshuli(): slide
- ::38.429 E/zhangshuli(): slide
- ::38.457 E/zhangshuli(): slide
- ::38.483 E/zhangshuli(): slide
- ::38.508 E/zhangshuli(): slide
- ::38.534 E/zhangshuli(): slide
- ::38.559 E/zhangshuli(): slide
- ::38.582 E/zhangshuli(): slide
- ::38.606 E/zhangshuli(): slide
- ::38.631 E/zhangshuli(): slide
- ::38.657 E/zhangshuli(): slide
- ::38.688 E/zhangshuli(): slide
- ::38.714 E/zhangshuli(): slide
- ::38.741 E/zhangshuli(): slide
- ::38.767 E/zhangshuli(): slide
- ::38.796 E/zhangshuli(): slide
- ::38.823 E/zhangshuli(): slide
- ::38.849 E/zhangshuli(): slide
- ::38.876 E/zhangshuli(): slide
- ::38.903 E/zhangshuli(): slide
- ::38.930 E/zhangshuli(): slide
- ::38.959 E/zhangshuli(): slide
- ::38.986 E/zhangshuli(): slide
- ::39.009 E/zhangshuli(): slide
- ::39.032 E/zhangshuli(): slide
- ::39.066 E/zhangshuli(): slide
- ::39.135 E/zhangshuli(): slide
- ::39.160 E/zhangshuli(): slide
- ::39.184 E/zhangshuli(): slide
- ::39.212 E/zhangshuli(): slide
- ::39.239 E/zhangshuli(): slide
- ::39.349 E/zhangshuli(): statechange
- ::39.360 E/zhangshuli(): slide
- ::39.383 E/zhangshuli(): slide
- ::39.404 E/zhangshuli(): slide
- ::39.425 E/zhangshuli(): slide
- ::39.446 E/zhangshuli(): slide
- ::39.467 E/zhangshuli(): slide
- ::39.488 E/zhangshuli(): slide
- ::39.508 E/zhangshuli(): slide
- ::39.529 E/zhangshuli(): slide
- ::39.549 E/zhangshuli(): slide
- ::39.585 E/zhangshuli(): slide
- ::39.619 E/zhangshuli(): colse
- ::39.619 E/zhangshuli(): statechange

也是一样的。所以,在它的方法中,我们可以做很多事情

我们可以得出结论
1.onDrawerStateChanged:总是在drawerlayout状态发生切换时候执行两次,一次是状态刚刚发生改变的时候,一次是状态改变彻底完成的时候,它总是在监听事件最开始跟末尾个执行一次
2.onDrawerSlide:它是在状态发生改变的过程中一直执行
3.onDrawerOpened(打开)、onDrawerClosed(关闭):他们是在状态改变完成以后执行,是发生在第二次onDrawerStateChanged前面

												

drawerLayout-监听事件四个方法介绍的更多相关文章

  1. java在线聊天项目0.3版本 制作客户端窗体,实现发送按钮和回车发送信息功能,使用ActionListener监听事件中actionPerformed方法(用内部类和匿名内部类两种方法)

    方法一,使用匿名内部类的监听方法,因方法一致代码稍冗余 package com.swift; import java.awt.BorderLayout; import java.awt.Color; ...

  2. android中实现监听的四种方法

    (1)自身类作为事件监听器 package cn.edu.gdmec.s07150745.work5; import android.support.v7.app.AppCompatActivity; ...

  3. UI设计篇·入门篇·简单动画的实现,透明动画/旋转动画/移动动画/缩放动画,混合动画效果的实现,为动画设置监听事件,自定义动画的方法

    基本的动画构成共有四种:透明动画/旋转动画/移动动画/缩放动画. 配置动画的方式有两种,一种是直接使用代码来配置动画效果,另一种是使用xml文档配置动画效果 相比而言,用xml文档写出来的动画效果,写 ...

  4. Second Day: 关于Button监听事件的三种方法(匿名类、外部类、继承接口)

    第一种:通过匿名类实现对Button事件的监听 首先在XML文件中拖入一个Button按钮,并设好ID,其次在主文件.java中进行控件初始化(Private声明),随后通过SetOnClickLis ...

  5. 关于实现自定义Dialog和实现Dialog里view的事件监听的两种方法

    一.自定义dialog. 二.实现dialog里view的事件监听 1.自定义dialog比较简单.在实例化new的时候,加入样式,布局就行了.或者重写dialog. 2.实现dialog里view的 ...

  6. miniui 给表格行添加监听事件的几种方法以及点击某列列名数据不能排序的问题

    最近在使用miniui框架做开发,在做表格行的点击监听事件中发现了几个属性,都可以起到监听效果但是执行的结果却大有不同.好了废话不多说,直接上代码. <div id="pageGrid ...

  7. 阅读layim代码小记,监听事件实现方法

    (function (win) { //注册事件 var chat = function () { $('#open').on('click', function () { sendMessage() ...

  8. 安卓开发学习日记 DAY5——监听事件onClick的实现方法

    今天主要学习了监听事件的是实现方法,就是说,做了某些动作后,怎么监听这个动作并作出相应反应. 方法主要有三种: 1.匿名内部类的方法 2.独立类的方法 3.类似实现接口的方法 以下分别分析: 1.匿名 ...

  9. Android成长日记-Android监听事件的方法

    1. Button鼠标点击的监听事件 --setOnClickListener 2. CheckBox, ToggleButton , RadioGroup的改变事件 --setOnCheckedCh ...

随机推荐

  1. 安装配置FreeBSD9全过程体验

    安装配置FreeBSD9全过程体验(时长11分钟) 总所周知,FreeBSD是一个高效.稳定的UNIX操作系统.在今年年初,FreeBSD 又发布了9.0版本,它将采用全新的文本安装器,升级ZFS文件 ...

  2. Vue总结(一)

    vue总结 构建用户界面的渐进式框架 渐进式:用到什么功能即可使用转么的框架子模块. 两个核心点 向应的数据绑定 当时图发生改变->自动跟新视图,利用Object.defindProperty中 ...

  3. Flex4之事件详解

    第一.Flex事件简介 事件贯穿于Flex应用开发的全过程.事件是ActionScript .0中最重要的部分之一,也是Flex应用程序开发的核心基础.本章将在DOM 3的基础上详细讲解ActionS ...

  4. 注解:@SuppressWarning()的用法

    @SuppressWarning() 作用:J2SE 提供的一个批注或者注解.该批注的作用是给编译器一条指令,忽略这些警告信息. 常用:unchecked,serial. 1.如果传入多种情况,这几种 ...

  5. PatentTips - System and method to deprivilege components of a virtual machine monitor

    BACKGROUND INFORMATION An embodiment of the present invention relates generally to virtualization pl ...

  6. IOCP模型总结(总结回想)

    IOCP旧代码重提.近期一直在玩其它方面的东东.时不时回想一下,收益多多. IOCP(I/O Completion Port,I/O完毕port)是性能最好的一种I/O模型.它是应用程序使用线程池处理 ...

  7. PopupWindow的一些属性

     void setOutsideTouchable(boolean touchable)            Controls whether the pop-up will be informed ...

  8. vmware虚拟机Windows 2003上网问题

    近期须要在Windows 2003 上面做点操作,于是安装虚拟机玩了一下,发现并不能上网,最后的解决的方法是: 卸载IE增强的安全配置 控制面板→加入或删除程序→加入/删除Windows组件" ...

  9. jquery11源码 animate() : 运动的方法

    { var fxNow, timerId, rfxtypes = /^(?:toggle|show|hide)$/, rfxnum = new RegExp( "^(?:([+-])=|)( ...

  10. 不仅仅是MVC

    MVC Smart MV Three tier 等等