当前是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