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. HtmlHelper的扩展分页方法

    一.新建一个空MVC项目,命名为MVCAppPager 二.新建一个文件夹PageHelper,在文件夹下新建接口IPageList以及实现类PageList IPageList接口: public ...

  2. mybatis:开发环境搭建--增删改查--多表联合查询(多对一)

    什么是mybatisMyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索.MyBatis使用简单的XML或 ...

  3. 124.C++输出小结

    #include <iostream> #include <iomanip> using namespace std; void main() { ////调用cout的成员函 ...

  4. codeforces 589A Email Aliases(map)

    Description Polycarp has quite recently learned about email aliases. Of course, he used to suspect t ...

  5. 轻量级记事本工具:CintaNotes

    本片文章介绍CintaNotes小工具 功能介绍: 方便.快捷的记录笔记: 快捷地从任何地方等截取内容生成笔记: 高效的记事本内容查询: 轻松的标签管理 支持移动设备和电脑同步(估计要收费) 官网下载 ...

  6. 二分法查找 js 算法

    二分法查找算法:采用二分法查找时,数据需是排好序的.主要思想是:(设查找的数组区间为array[s, e])(1)确定该区间的中间位置m(2)将查找的值T与array[m]比较,若相等,查找成功返回此 ...

  7. 大吉大利,晚饭吃鸡!——accept关闭问题

    假期收尾了,学芽子们都军训了.一群张一山和周冬雨在校内晃晃悠悠,说起来春风十里也就军训比较有意思.对于我这种一年追一部剧的人,显然是有点对不住.在我假期任务即将圆满之际,我开始放慢脚步寻找生活的美妙时 ...

  8. ES6学习笔记(九)Set和Map数据结构

    1.set 基本等于Java的Set集合类型,无序不可重复集,常被用来去重. 基本用法 const s = new Set();//通过Set()构造函数创建 [2, 3, 5, 4, 5, 2, 2 ...

  9. sed的一些tricks

    1.sed -f xx.sed input_file 可以将一系列操作放在一个xx.sed脚本里执行 ``` #!/bin/sed -f ``` 2.在匹配字符串后面或行尾添加内容 在text后面添加 ...

  10. Image与byte[]数组的相互转换

         近期项目有个需求是关于图片操作的,须要将图片保存到数据库中.经过尝试才知道Image类型文件是不能直接存储到数据库中的.保存之前须要我们做一步转换:将Image转换成字节数组类型Byte ...