源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

自定义ListView实现拖拽ListItem项交换位置(附源码)

  • 时间:2021-02-06 02:40 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:自定义ListView实现拖拽ListItem项交换位置(附源码)
[b]写在前面的话[/b] 在[url=http://www.1sucai.cn/article/38094.htm]上一篇[/url]实现了通过布局泵拿到不同布局为listitem布局,然后实现联系人的ListView,这一章要做的是拖拽ListView的Item项,本章原理是在上一篇博客基础之上的,上一篇博客:[url=http://www.1sucai.cn/article/38094.htm]自定义Adapter并通过布局泵LayoutInflater抓取layout模板编辑每一个item[/url] 实现效果图 [img]http://files.jb51.net/file_images/article/201306/201306071709052.gif?20135717927[/img]   [b]说明[/b] 首先我们看到的上面这张图就是实现的效果图了。拖动之后数据项完成交换位置。 [b]功能剖析[/b] 我们看到做的这个效果是一个拖拽ListView的Item项位置的功能,在布局方面还是用基于布局泵LayoutInflater来从不同的Layout模板拿到不同的布局然后将view返回。关于布局这一点的知识在上一篇有详细说明,文章开头已经说明,OK,下面我们来剖析一下这个拖动效果的实现吧,下面的文章将会以方法执行的顺序来给出各个方法的代码。然后依次剖析每个方法的作用。 [b]方法执行顺序[/b] [DragView] -> [初始化ListViewContext,和触发move事件的最小距离变量] [onInterceptTouchEvent] -> [初始化拖动的变量] [startDrag] -> [准备拖动的影像、window等变量] [stopDrag] -> [判断重置拖动的影像] [startDrag] -> [准备拖动的影像、window等变量] [onTouchEvent] -> [判断点击事件、根据动作做不同操作,或重新绘制Move影响,或者Stop停止拖动。交换数据,也就是下面的这两个方法] [onDrag] -> [实现滚动的动作] [onDrop] -> [实现数据item位置切换] 注意 上面的方法执行顺序只是大概逻辑,这其中还有判断和方法中调用其他方法,所以方法的调用是多次的,大家凑合看一下方法的大体功能吧,需要注意的是我们重写的onTouchEvent是要一直不断的监听我们的按键的,如果为Move的话也就是会一直不断的去调用onDrag方法去实现滚动的动作,在此我做了测试,给大家看一下打印的日志如下: [img]http://files.jb51.net/file_images/article/201306/201306071709453.gif?20135717108[/img]   我们看到move日志被执行了多次。说明我们在拖动的时候一直在执行这个方法。下面我会给大家自定义ListView的代码,代码中注释量很大,可读性很高,推荐大家参考上面我给出的方法运行顺序去理解,最后我将给出运行源码。
[url=http://xiazai.jb51.net/201306/yuanma/DragListView_jb51.net.rar]源码下载[/url]
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部