需要自定义ListView。这里就交FloatDelListView吧。

复写onTouchEvent方法。如下:

@Override
public boolean onTouchEvent(MotionEvent ev) {
switch (ev.getAction()) {
case MotionEvent.ACTION_DOWN:
          // 获取按下的条目视图(child view)
int childCount = getChildCount();
int[] listViewCoords = new int[2];
getLocationOnScreen(listViewCoords);
int x = (int) ev.getRawX() - listViewCoords[0];
int y = (int) ev.getRawY() - listViewCoords[1];
for (int i = 0; i < childCount; i++) {
downChild = getChildAt(i); //
Rect rect = new Rect();
assert downChild != null;
downChild.getHitRect(rect); int childPosition = getPositionForView(downChild); if (rect.contains(x, y)) {
downX = ev.getRawX();
int downPosition = childPosition; velocityTracker = VelocityTracker.obtain();
assert velocityTracker != null;
velocityTracker.addMovement(ev);
break;
}
}
isSwipe = false;
break;
case MotionEvent.ACTION_MOVE:
velocityTracker.addMovement(ev);
          // 计算水平和垂直方向移动速度
velocityTracker.computeCurrentVelocity(1000);
float velocityX = Math.abs(velocityTracker.getXVelocity());
float velocityY = Math.abs(velocityTracker.getYVelocity());

          // 水平移动距离
float deltaX = ev.getRawX() - downX;
float deltaMode = Math.abs(deltaX);
if (deltaX > 150) {// right swipe(右滑)
isSwipeToLeft = false;
} else if (deltaX < -150) {// left swipe(左滑)
isSwipeToLeft = true;
}
          // 如果水平滑动距离大于零,并且水平滑动速率比垂直大,说明是水平滑动
if (deltaMode > 0 && velocityY < velocityX) {
            // 这里的FloatDelButtonLayout是自定义的LinearLayout。
((FloatDelButtonLayout) downChild).showDelButton(ev, isSwipeToLeft);
isSwipe = true;
}
break;
case MotionEvent.ACTION_CANCEL:
case MotionEvent.ACTION_UP:
downChild.setSelected(false);
if (isSwipe) {
isSwipe = false;
return true;
}
break;
}
return super.onTouchEvent(ev);
}

FloatDelButtonLayou.java :

public class FloatDelButtonLayout extends LinearLayout {

   // 提供删除按钮的接口
private OnDelListener delListener;

   // 当前视图在列表中的索引,在delListener中使用
private int index;

   // 右滑 还是 左滑?
    private boolean isSwipeToLeft;
public void setOnDelListener(OnDelListener listener, int i) {
delListener = listener;
index = i;
} public FloatDelButtonLayout(Context context) {
super(context, null);
} public FloatDelButtonLayout(Context context, AttributeSet attrs) {
super(context, attrs, 0);
} public FloatDelButtonLayout(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
}

   // 用来显示或者隐藏删除按钮。
public void showDelButton(MotionEvent ev, boolean isSwipeToLeft) {
this.isSwipeToLeft = isSwipeToLeft;
onTouchEvent(ev);
} private OnClickListener clickDel = new OnClickListener() {
@Override
public void onClick(View v) {
delListener.onDel(index);
}
};

   /**
    * 这里的event是我们显示的从FloatDelListView的onTouchEvent里面传进来的,
*/
@Override
public boolean onTouchEvent(MotionEvent event) {
switch (MotionEventCompat.getActionMasked(event)) {
case MotionEvent.ACTION_MOVE:
          // 获取删除按钮对象,视图layout中必须要有id为del_button的Button标签
Button view = (Button) findViewById(R.id.del_button);
view.setText(R.string.del);
          // 设置Button的MarginLayoutParams,当然可以做成各种动作,比如渐隐之类的显示出来。
MarginLayoutParams layoutParams = (MarginLayoutParams) view.getLayoutParams();
assert layoutParams != null;
if (isSwipeToLeft) {
view.setVisibility(View.VISIBLE);
view.setOnClickListener(clickDel);
layoutParams.leftMargin = -200;
} else {
view.setVisibility(View.GONE);
layoutParams.leftMargin = 0;
}
view.setLayoutParams(layoutParams);
invalidate();
break;
}
return super.onTouchEvent(event);
} public interface OnDelListener {
void onDel(int i);
}
}

完成!希望对你有帮助!

Android ListView实现仿iPhone实现左滑删除按钮的更多相关文章

  1. Android滑动列表(拖拽,左滑删除,右滑完成)功能实现(1)

    场景: 近期做的TODO APP需要在主页添加一个功能,就是可以左滑删除,右滑完成.看了一下当前其他人做的例如仿探探式的效果,核心功能基本一样,但是和我预想的还是有少量区别,于是干脆自己重头学一遍如何 ...

  2. 仿QQ列表左滑删除

    一直想写个仿QQ通讯列表左滑删除的效果,今天终于忙里偷闲,简单一个. 大概思路是这样的: 通过 ontouchstartontouchmoveontouchend 结合css3的平移. 不多说,直接上 ...

  3. Android滑动列表(拖拽,左滑删除,右滑完成)功能实现(2)

    ItemTouchHelper类 之前我们实现了滑动列表的一些基本功能,为了实现更多的效果,我们来仔细看一下ItemTouchHelper中的类: ItemTouchHelper.SimpleCall ...

  4. Android开发学习之路-PopupWindow和仿QQ左滑删除

    这周作业,要做一个类似QQ的左滑删除效果的ListView,因为不想给每个item都放一个按钮,所以决定用PopupWindow,这里记录一下 先放一下效果图: 先说明一下这里面的问题: ①没有做到像 ...

  5. [转]ANDROID仿IOS微信滑动删除_SWIPELISTVIEW左滑删除例子

    转载:http://dwtedx.sinaapp.com/itshare_290.html 本例子实现了滑动删除ListView的Itemdemo的效果.大家都知道.这种创意是来源于IOS的.左滑删除 ...

  6. Android ListView左滑删除、左滑自定义功能

    最近项目需要ListView左滑删除功能,搜集了很多资料发现了一个某一前辈写的库能很简单的实现这个功能,而且有源码,直接拿来使用了. 库名字叫做SwipeMenuListView,下面给大家演示一下使 ...

  7. 类似QQ消息左滑删除的Demo

    最近在网上学到一篇类似QQ消息左滑删除的demo,完善了下代码,感觉还不错,特此分享一波: CustomSwipeListView.java 是个继承自ListView的类,里面调用了自定义View ...

  8. 模仿QQ左滑删除

    需求: 1.左滑删除 2.向左滑动距离超过一半的时候让它自动滑开,向右滑动超过一半的时候自动隐藏 3.一次只允许滑开一个item 还有,根本不需要自定义view来实现,谨防入坑 布局: <?xm ...

  9. 微信小程序实现左滑删除源码

    左滑删除效果在app的交互方式中十分流行,比如全民应用微信 微信左滑删除 再比如曾引起很大反响的效率app Clear Clear左滑删除 从技术上来说,实现这个效果并不困难,响应一下滑动操作,移动一 ...

随机推荐

  1. php获取html checkbox的值。

    一个小错误,搞了好久: <label><input class="short" type="checkbox" id="is_onl ...

  2. 关于v$sql_bind_capture 的问题

    ---先清空shared_pool SQL> alter system flush shared_pool; System altered. SQL> col value_STRING f ...

  3. VM Depot 登陆中国!

     发布于 2014-03-24 作者 陈 忠岳 今天我很高兴地向大家宣布,来自微软开放技术(上海)有限公司的首个产品 VM Depot 正式在中国发布!VM Depot是为Windows Azur ...

  4. Unity3D常见技术点(持续更新)

    一:获取对象, 添加对象等 1:使用prefab生成对象 GameObject ballObj = GameObject.Instantiate(Resources.Load(, Quaternion ...

  5. GridControl 列中显示图片 z

    如何在 DevExpress.XtraGrid.GridControl 显示图片列. 方法很多,我把它们逐一写在附言中,方便大家分情况合理使用. 附言1  附言2  附言3  第 1 条附言  ·  ...

  6. 16位cpu下主引导扇区及用户程序的编写

    一些约定 主引导扇区代码(0面0道1扇区)加载至0x07c00处 用户程序头部代码需包含以下信息:程序总长度.程序入口.重定位表等信息 用户程序 当虚拟机启动时,在屏幕上显示以下两句话: This i ...

  7. java NIO 资料总结

    1.http://developer.51cto.com/art/201204/328340.htm 2.http://ifeve.com/file-channel/并发编程网系列 3 http:// ...

  8. HTML5与CSS3权威指南.pdf3

    表单验证 <input name="text" type="text" required pattern="^\w.*$"> r ...

  9. (DT系列二)device tree的书写规范

    devicetree的书写规范 下面从节点,属性,reg,ranges,中断控制器等几个方面叙述devicetree的书写规范. 1,dts的基本元素:节点 .dts(或者其include的.dtsi ...

  10. EJB (not bound)

    问题: 在代码实在找不到错误的情况下,仍然报:XXXX not bound 问题产生过程: 通过下图方式创建的项目:EJBTest2_1 勾选下面两项,即可生成:EJBTest2_1EJB 和 EJB ...