Android ListView 可拖拽Item 1 - 创建浮动Item

本文介绍了如何在Android中实现ListView的拖拽功能,特别是创建浮动视图的效果。通过自定义ListView,利用手势识别实现拖动,并隐藏原Item绘制浮动视图。目前仅实现了简单的拖动效果,后续会完善如Item左右移动等功能。源码可供下载。
摘要由CSDN通过智能技术生成


当前是ListView 可拖拽Item第一步,显示浮动视图。看看下面的图片演示浮动视图,但是也可以看到浮动视图之外的Item不会自动移动,并且浮动视图还可以左右移动等问题存在,所以这是第一部分,也是这个效果的起步。


一、有图有真相



二、分析

    

    1. 效果布局,因为是控制ListView子视图Item,而要控制的Item的父类ListView并没有提供可直接控制Item的方法和其他方式,所以这里选择自定义ListView来进行扩展。

    2.  首先是浮动视图的实现,当前是使用在ListView中隐藏选中的Item,并绘制出选中Item视图。具体实现分析请参考《Android 浮动视图效果 第三种实现方式》

         这种浮动视图的实现我也是第一次见,之前都没想象过还能这样实现浮动视图,把视图转换为图片,然后把图片绘制出来实现浮动效果。

    3.  ListView 可拖拽Item中会使用很多手势,这些手势可以通过自己监听判断来得到,但是也可以使用系统提供的手势辅助类实现。具体实现可以参考

          《Android 手势识别,使用SimpleOnGestureListener,OnGestureListener,OnDoubleTapListener》


三、伪代码

1. 首先自定义ListView\

public class DragSortListView extends ListView {

	public DragSortListView(Context context) {
		super(context);
		initCustomListView();
	}

	public DragSortListView(Context context, AttributeSet attrs) {
		super(context, attrs);
		initCustomListView();
	}

	public DragSortListView(Context context, AttributeSet attrs, int defStyle) {
		super(context, attrs, defStyle);
		initCustomListView();
	}
	
	private void initCustomListView() {
		// setOnTouchListener 与 当前视图onTouchEvent回到不冲突
		// 前者是在dispatchTouchEvent中调用,后者是在其后执行
		DragSortController controller = new DragSortController(this);
		setOnTouchListener(controller);
	}
}


2.   自定义ListView构造参数中添加了Touch Event 事件监听,用于把手势相关的代码摘出来,不用都放到自定义ListView代码也更清晰,下面再来看看自定义手势类中都做了些什么? 先来看看自定义手势:

public class DragSortController extends SimpleOnGestureListener implements
		OnTouchListener {

	private GestureDetect
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值