ListView滑动删除 ,仿腾讯QQ(1),vivoandroid面试

  • 用户滑动的最小距离

*/

private int touchSlop;

/**

  • 是否响应滑动

*/

private boolean isSliding;

/**

  • 手指按下时的x坐标

*/

private int xDown;

/**

  • 手指按下时的y坐标

*/

private int yDown;

/**

  • 手指移动时的x坐标

*/

private int xMove;

/**

  • 手指移动时的y坐标

*/

private int yMove;

private LayoutInflater mInflater;

private PopupWindow mPopupWindow;

private int mPopupWindowHeight;

private int mPopupWindowWidth;

private Button mDelBtn;

/**

  • 为删除按钮提供一个回调接口

*/

private DelButtonClickListener mListener;

/**

  • 当前手指触摸的View

*/

private View mCurrentView;

/**

  • 当前手指触摸的位置

*/

private int mCurrentViewPos;

/**

  • 必要的一些初始化

  • @param context

  • @param attrs

*/

public QQListView(Context context, AttributeSet attrs)

{

super(context, attrs);

mInflater = LayoutInflater.from(context);

touchSlop = ViewConfiguration.get(context).getScaledTouchSlop();

View view = mInflater.inflate(R.layout.delete_btn, null);

mDelBtn = (Button) view.findViewById(R.id.id_item_btn);

mPopupWindow = new PopupWindow(view, LinearLayout.LayoutParams.WRAP_CONTENT,

LinearLayout.LayoutParams.WRAP_CONTENT);

/**

  • 先调用下measure,否则拿不到宽和高

*/

mPopupWindow.getContentView().measure(0, 0);

mPopupWindowHeight = mPopupWindow.getContentView().getMeasuredHeight();

mPopupWindowWidth = mPopupWindow.getContentView().getMeasuredWidth();

}

@Override

public boolean dispatchTouchEvent(MotionEvent ev)

{

int action = ev.getAction();

int x = (int) ev.getX();

int y = (int) ev.getY();

switch (action)

{

case MotionEvent.ACTION_DOWN:

xDown = x;

yDown = y;

/**

  • 如果当前popupWindow显示,则直接隐藏,然后屏蔽ListView的touch事件的下传

*/

if (mPopupWindow.isShowing())

{

dismissPopWindow();

return false;

}

// 获得当前手指按下时的item的位置

mCurrentViewPos = pointToPosition(xDown, yDown);

// 获得当前手指按下时的item

View view = getChildAt(mCurrentViewPos - getFirstVisiblePosition());

mCurrentView = view;

break;

case MotionEvent.ACTION_MOVE:

xMove = x;

yMove = y;

int dx = xMove - xDown;

int dy = yMove - yDown;

/**

  • 判断是否是从右到左的滑动

*/

if (xMove < xDown && Math.abs(dx) > touchSlop && Math.abs(dy) < touchSlop)

{

// Log.e(TAG, "touchslop = " + touchSlop + " , dx = " + dx +

// " , dy = " + dy);

isSliding = true;

}

break;

}

return super.dispatchTouchEvent(ev);

}

@Override

public boolean onTouchEvent(MotionEvent ev)

{

int action = ev.getAction();

/**

  • 如果是从右到左的滑动才相应

*/

if (isSliding)

{

switch (action)

{

case MotionEvent.ACTION_MOVE:

int[] location = new int[2];

// 获得当前item的位置x与y

mCurrentView.getLocationOnScreen(location);

// 设置popupWindow的动画

mPopupWindow.setAnimationStyle(R.style.popwindow_delete_btn_anim_style);

mPopupWindow.update();

mPopupWindow.showAtLocation(mCurrentView, Gravity.LEFT | Gravity.TOP,

location[0] + mCurrentView.getWidth(), location[1] + mCurrentView.getHeight() / 2

  • mPopupWindowHeight / 2);

// 设置删除按钮的回调

mDelBtn.setOnClickListener(new OnClickListener()

{

@Override

public void onClick(View v)

{

if (mListener != null)

{

mListener.clickHappend(mCurrentViewPos);

mPopupWindow.dismiss();

}

}

});

// Log.e(TAG, “mPopupWindow.getHeight()=” + mPopupWindowHeight);

break;

case MotionEvent.ACTION_UP:

isSliding = false;

}

// 相应滑动期间屏幕itemClick事件,避免发生冲突

return true;

}

return super.onTouchEvent(ev);

}

/**

  • 隐藏popupWindow

*/

private void dismissPopWindow()

{

if (mPopupWindow != null && mPopupWindow.isShowing())

{

mPopupWindow.dismiss();

}

}

public void setDelButtonClickListener(DelButtonClickListener listener)

{

mListener = listener;

}

interface DelButtonClickListener

{

public void clickHappend(int position);

}

}

代码注释写得很详细,简单说一下,在dispatchTouchEvent中设置当前是否响应用户滑动,然后在onTouchEvent中判断是否响应,如果响应则popupWindow以动画的形式展示出来。当然屏幕上如果存在PopupWindow则屏幕ListView的滚动与Item的点击,以及从右到左滑动时屏幕Item的click事件。

接下来是MainActivity.java,这里代码很简单不做介绍了。

package com.example.listviewitemslidedeletebtnshow;

import java.util.ArrayList;

import java.util.Arrays;

import java.util.List;

import android.app.Activity;

import android.os.Bundle;

import android.view.View;

import android.widget.AdapterView;

import android.widget.AdapterView.OnItemClickListener;

import android.widget.ArrayAdapter;

import android.widget.Toast;

import com.example.listviewitemslidedeletebtnshow.QQListView.DelButtonClickListener;

public class MainActivity extends Activity

{

private QQListView mListView;

private ArrayAdapter mAdapter;

private List mDatas;

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

【延伸Android必备知识点】

【Android部分高级架构视频学习资源】

**Android精讲视频学习后更加是如虎添翼!**进军BATJ大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务Curd而已!现如今市场上初级程序员泛滥,这套教程针对Android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶Android中高级、架构师对你更是如鱼得水!

**任何市场都是优胜略汰适者生存,只要你技术过硬,到哪里都不存在饱和不饱和的问题,所以重要的还是提升自己。懂得多是自己的加分项 而不是必须项。门槛高了只能证明这个市场在不断成熟化!**另外一千个读者就有一千个哈姆雷特,所以以上只是自己的关键,不喜勿喷!

如果你是卡在缺少学习资源的瓶颈上,那么刚刚好我能帮到你。欢迎关注会持续更新和分享的。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

ATJ大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务Curd而已!现如今市场上初级程序员泛滥,这套教程针对Android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶Android中高级、架构师对你更是如鱼得水!

**任何市场都是优胜略汰适者生存,只要你技术过硬,到哪里都不存在饱和不饱和的问题,所以重要的还是提升自己。懂得多是自己的加分项 而不是必须项。门槛高了只能证明这个市场在不断成熟化!**另外一千个读者就有一千个哈姆雷特,所以以上只是自己的关键,不喜勿喷!

如果你是卡在缺少学习资源的瓶颈上,那么刚刚好我能帮到你。欢迎关注会持续更新和分享的。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 23
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值