117.Android 简单的拖拽列表+防止越界拖动(BaseRecyclerViewAdapterHelper)

news/2024/4/24 2:47:38/文章来源:https://blog.csdn.net/weixin_42061754/article/details/129159322

 

 

//1.第一步 导入依赖库和权限:

//依赖库:

//RecyclerView
implementation 'com.android.support:recyclerview-v7:28.0.0'//RecyclerAdapter
implementation 'com.github.CymChad:BaseRecyclerViewAdapterHelper:2.9.28'

//用到的权限:

<!--振动-->
<uses-permission android:name="android.permission.VIBRATE" />

 

 

 //2.第二步 新建ItemDraggableActivity页面:

//manifest注册:

<activityandroid:name=".phone.activity.ItemDraggableActivity"android:launchMode="singleTop"android:screenOrientation="portrait"android:windowSoftInputMode="stateHidden"tools:ignore="LockedOrientationActivity" />

//activity代码:

/*** @author CJF*/
public class ItemDraggableActivity extends AppCompatActivity implements BaseQuickAdapter.OnItemChildClickListener, View.OnClickListener {private final GridLayoutManager manager = new GridLayoutManager(this, 3);private final ItemDraggableAdapter adapter = new ItemDraggableAdapter(R.layout.item_draggable_item, new ArrayList<>());/*** 震动时长(毫秒)*/private final int milliseconds = 50;private Vibrator vibrator;private RecyclerView mTreeListRecy;private TextView mEdit;@Overrideprotected void onCreate(@Nullable Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_tree_list);//点击音效vibrator = (Vibrator) getSystemService(Context.VIBRATOR_SERVICE);mTreeListRecy = findViewById(R.id.mTreeListRecy);mEdit = findViewById(R.id.mEdit);mEdit.setOnClickListener(this);mTreeListRecy.setLayoutManager(manager);mTreeListRecy.setAdapter(adapter);DragAndSwipeCallback itemDragAndSwipeCallback = new DragAndSwipeCallback(adapter);ItemTouchHelper itemTouchHelper = new ItemTouchHelper(itemDragAndSwipeCallback);itemTouchHelper.attachToRecyclerView(mTreeListRecy);//可以不用设置,可以拖拽的方向,默认上下左右itemDragAndSwipeCallback.setDragMoveFlags(ItemTouchHelper.UP | ItemTouchHelper.DOWN | ItemTouchHelper.LEFT | ItemTouchHelper.RIGHT);//         开启拖拽 设置可拖拽item的根布局idadapter.enableDragItem(itemTouchHelper, R.id.mItemDraggableItemLin, true);adapter.setOnItemDragListener(onItemDragListener);// 开启滑动删除
//        adapter.enableSwipeItem();
//        adapter.setOnItemSwipeListener(onItemSwipeListener);adapter.setOnItemChildClickListener(this);List<ItemDraggableBean> list = new ArrayList<>();for (int i = 0; i < 10; i++) {ItemDraggableBean bean = new ItemDraggableBean();bean.setName("数据" + i);list.add(bean);}adapter.addData(list);}/*** 拖拽监听*/private OnItemDragListener onItemDragListener = new OnItemDragListener() {@Overridepublic void onItemDragStart(RecyclerView.ViewHolder viewHolder, int pos) {Log.e("TAG1231", "onItemDragStart" + "你在拖拽第" + (pos + 1) + "个位置的item哦!");//震动if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {vibrator.vibrate(VibrationEffect.createOneShot(milliseconds, VibrationEffect.DEFAULT_AMPLITUDE));} else {vibrator.vibrate(milliseconds);}//按住变大viewHolder.itemView.setScaleX(1.2f);viewHolder.itemView.setScaleY(1.2f);viewHolder.itemView.setAlpha(0.5f);//改变数据状态ItemDraggableBean draggableBean = adapter.getData().get(pos);if (!draggableBean.isShow()) {List<ItemDraggableBean> data = adapter.getData();for (ItemDraggableBean bean : data) {bean.setShow(true);}//循环遍历出所有的item布局 并显示图片//注意不可以直接使用 adapter.notifyDataSetChanged();数据刷新会导致直接调用onItemDragEnd()方法for (int i = 0; i < mTreeListRecy.getChildCount(); i++) {View childAt = mTreeListRecy.getChildAt(i);TextView textView = childAt.findViewById(R.id.mItemDraggableItemText);View view = childAt.findViewById(R.id.mItemDraggableItemImg);view.setVisibility(View.VISIBLE);Log.e("TAG1231", "textView:" + textView.getText().toString());}mEdit.setText("完成");}}@Overridepublic void onItemDragMoving(RecyclerView.ViewHolder source, int from, RecyclerView.ViewHolder target, int to) {Log.e("TAG1231", "onItemDragMoving");}@Overridepublic void onItemDragEnd(RecyclerView.ViewHolder viewHolder, int pos) {Log.e("TAG1231", "onItemDragEnd" + "拖拽到了第" + (pos + 1) + "个位置哦!");//变回原来大小viewHolder.itemView.setScaleX(1.0f);viewHolder.itemView.setScaleY(1.0f);viewHolder.itemView.setAlpha(1.0f);}};OnItemSwipeListener onItemSwipeListener = new OnItemSwipeListener() {@Overridepublic void onItemSwipeStart(RecyclerView.ViewHolder viewHolder, int pos) {ToastUtil.getInstance().showToast("继续向左滑动即可删除第" + (pos + 1) + "个位置的item");}@Overridepublic void clearView(RecyclerView.ViewHolder viewHolder, int pos) {}@Overridepublic void onItemSwiped(RecyclerView.ViewHolder viewHolder, int pos) {ToastUtil.getInstance().showToast("删除了第" + (pos + 1) + "个位置的item哦");}@Overridepublic void onItemSwipeMoving(Canvas canvas, RecyclerView.ViewHolder viewHolder, float dX, float dY, boolean isCurrentlyActive) {}};@Overridepublic void onItemChildClick(BaseQuickAdapter adapter, View view, int position) {adapter.remove(position);}@Overridepublic void onClick(View v) {switch (v.getId()) {case R.id.mEdit:boolean isEdit = "编辑".equals(mEdit.getText().toString());List<ItemDraggableBean> data = adapter.getData();for (ItemDraggableBean bean : data) {bean.setShow(isEdit);}adapter.notifyDataSetChanged();mEdit.setText(isEdit ? "完成" : "编辑");break;default:break;}}}

//3.第三步 新建DragAndSwipeCallback类继承ItemDragAndSwipeCallback,重写onChildDraw 防止越界拖动:

/*** @author CJF* 重写onChildDraw 防止越界拖动*/
public class DragAndSwipeCallback extends ItemDragAndSwipeCallback {public DragAndSwipeCallback(BaseItemDraggableAdapter adapter) {super(adapter);}/*** 重写onChildDraw 防止越界拖动** @param c* @param recyclerView* @param viewHolder* @param dX* @param dY* @param actionState* @param isCurrentlyActive*/@Overridepublic void onChildDraw(@NonNull Canvas c, @NonNull RecyclerView recyclerView, @NonNull RecyclerView.ViewHolder viewHolder, float dX, float dY, int actionState, boolean isCurrentlyActive) {float topY = viewHolder.itemView.getTop() + dY;float bottomY = topY + viewHolder.itemView.getHeight();float leftX = viewHolder.itemView.getLeft() + dX;float rightX = leftX + viewHolder.itemView.getWidth();if (topY < 0) {dY = 0;} else if (bottomY > recyclerView.getHeight()) {dY = recyclerView.getHeight() - viewHolder.itemView.getHeight() - viewHolder.itemView.getTop();}if (leftX < 0) {dX = 0;} else if (rightX > recyclerView.getWidth()) {dX = recyclerView.getWidth() - viewHolder.itemView.getWidth() - viewHolder.itemView.getLeft();}super.onChildDraw(c, recyclerView, viewHolder, dX, dY, actionState, isCurrentlyActive);}}

//4.第四步 新建ItemDraggableAdapter适配器类:

/*** @author CJF*/
public class ItemDraggableAdapter extends BaseItemDraggableAdapter<ItemDraggableBean, BaseViewHolder> {public ItemDraggableAdapter(List<ItemDraggableBean> data) {super(data);}public ItemDraggableAdapter(int layoutResId, List<ItemDraggableBean> data) {super(layoutResId, data);}@Overrideprotected void convert(BaseViewHolder helper, ItemDraggableBean item) {helper.setText(R.id.mItemDraggableItemText, item.getName());helper.setGone(R.id.mItemDraggableItemImg, item.isShow());helper.addOnClickListener(R.id.mItemDraggableItemImg);}}

//5.第五步 新建ItemDraggableBean类:

/*** @author CJF*/
public class ItemDraggableBean {private String name;private boolean isShow = false;public ItemDraggableBean() {}public ItemDraggableBean(String name, boolean isShow) {this.name = name;this.isShow = isShow;}public String getName() {return name;}public void setName(String name) {this.name = name;}public boolean isShow() {return isShow;}public void setShow(boolean show) {isShow = show;}}

//6.第六步 各个xml布局文件以及svg图片文件:

//activity_tree_list:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"xmlns:app="http://schemas.android.com/apk/res-auto"android:background="@color/color_white"android:orientation="vertical"><TextViewandroid:id="@+id/mEdit"android:background="@drawable/selector_common_item"android:textColor="@color/colorAccent"android:textStyle="bold"android:textSize="18sp"android:gravity="center"android:text="编辑"android:layout_width="match_parent"android:layout_height="wrap_content"/><android.support.v7.widget.RecyclerViewandroid:id="@+id/mTreeListRecy"android:layout_width="match_parent"android:layout_height="match_parent" /></LinearLayout>

//item_draggable_item:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="wrap_content"android:background="@drawable/bg_search"android:layout_margin="@dimen/dp_5"android:id="@+id/mItemDraggableItemLin"android:orientation="horizontal"><TextViewandroid:id="@+id/mItemDraggableItemText"android:layout_width="0dp"android:layout_height="wrap_content"android:layout_weight="1"android:gravity="left|center_vertical"android:minHeight="@dimen/dp_50"android:padding="@dimen/dp_10"android:text="text"android:textColor="@color/black"android:textSize="@dimen/sp_15" /><ImageViewandroid:scaleType="center"android:id="@+id/mItemDraggableItemImg"android:src="@drawable/crm_close"android:layout_width="@dimen/dp_50"android:layout_height="match_parent"/></LinearLayout>

//svg图片文件  crm_close:

<vector xmlns:android="http://schemas.android.com/apk/res/android"android:width="24dp"android:height="24dp"android:viewportWidth="24.0"android:viewportHeight="24.0"><pathandroid:fillColor="#FF000000"android:pathData="M19,6.41L17.59,5 12,10.59 6.41,5 5,6.41 10.59,12 5,17.59 6.41,19 12,13.41 17.59,19 19,17.59 13.41,12z"/>
</vector>

//------------------------------------------------------END---------------------------------------------------------------

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_72429.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何使用DevEco Studio创建Native C++应用

简介本篇主要介绍如何使用DevEco Studio for OpenAtom OpenHarmony &#xff08;以下简称“OpenHarmony”&#xff09;创建一个Native C应用。应用采用“Native C”模板&#xff0c;实现了通过Node-API调用C标准库的功能。本示例通过调用C标准库接口来演示调用过程&#xff0c;…

MES助力灯具照明行业从制造到”智造”

现如今&#xff0c;LED照明行业产品更新换代太快&#xff0c;一个产品一两年不更新一下外观、材料&#xff0c;就会被对手超越。这直接导致LED产品标准化程度不够高&#xff0c;LED下游制造类厂家智能化生产程度普遍偏低。 加之大多属于劳动密集型产业&#xff0c;传统的依靠买…

less、sass、webpack(前端工程化)

目录 一、Less 1.配置less环境 1.先要安装node&#xff1a;在cmd中&#xff1a;node -v检查是否安装node 2.安装less :cnpm install -g less 3.检查less是否安装成功&#xff1a;lessc -v 4.安装成功后&#xff0c;在工作区创建xx.less文件 5.在控制台编译less,命令&…

Ubuntu16.04使用apache创建个人用户主页并添加口令认证

文章目录一.安装apache二、apache文件和目录简述2.1 网站数据目录2.2 Apache配置文件三、创建个人用户主页3.1 开启个人用户主页功能3.2 建立目录和首页面3.3 开启模块3.4 测试四、添加口令认证4.1 生成密码数据库4.2 修改配置文件一.安装apache 创建虚拟机&#xff0c;保持默…

Python socket之TCP通信、下载文件

TCP简介TCP介绍TCP协议&#xff0c;传输控制协议&#xff08;英语&#xff1a;Transmission Control Protocol&#xff0c;缩写为 TCP&#xff09;是一种面向连接的、可靠的、基于字节流的传输层通信协议&#xff0c;由IETF的RFC 793定义。TCP通信需要经过创建连接、数据传送、…

深入浅出深度学习Pytroch

本文将以通俗易懂的方式&#xff0c;深入浅出地为您揭开深度学习模型构建与训练的面纱&#xff1a; 深度学习数据data模型model损失函数loss优化optimizer可视化visualizer深度学习 数据data 模型model 损失函数loss 优化optimizer 可视化visualizer深度学习数据data模型m…

如何写新闻稿?写好新闻稿的技巧与步骤

新闻稿是传递新闻事件和信息的重要手段&#xff0c;是传媒工作中不可或缺的一部分。写好一篇新闻稿可以让受众了解更多信息&#xff0c;进一步提高他们的关注度。以下是一些写好新闻稿的技巧和步骤&#xff0c;帮助你有效地传达新闻。1、确定新闻的核心信息在开始写新闻稿之前&…

短链或H5唤醒(跳转)APP应用

唤醒APP(两种方法) 一.短链唤醒(跳转)app ⭐ 短链跳转到APP&#xff0c;当如果用户手机不存在APP(某个应用)将会进入到官网页面。 app links实现 在android studio菜单栏Tools->App Links Ass点击,效果图如下 2.配置如下 点击ok,生成如下效果图 3.完成第二步后,会自动…

FreeRTOS入门(01):基础说明与使用演示

文章目录目的基础说明系统移植基础使用演示数据类型和命名风格总结碎碎念目的 FreeRTOS是一个现在非常流行的实时操作系统&#xff08;Real Time Operating System&#xff09;。本文将介绍FreeRTOS入门使用相关内容&#xff0c;这篇是第一篇&#xff0c;主要介绍基础背景方面…

【论文阅读】Anti-Adversarially Manipulated Attributions for WSSS

一篇CVPR2021上的论文&#xff0c;用于弱监督分割及半监督分割 论文标题&#xff1a; Anti-Adversarially Manipulated Attributions for Weakly and Semi-Supervised Semantic Segmentation&#xff08;AdvCAM&#xff09; 作者信息&#xff1a; 代码地址&#xff1a; htt…

2023年华为HCIE-Dacom认证题库(H12-891)

1、如图所示是某位网络工程师在排查OSPF故障时的输出信息。据此判断&#xff0c;以下哪种原因可能导致邻接关系无法正常建立。 Hello报文发送时间不一致认证密码不一致接口的IP地址掩码不一致区域类型不一致 正确答案&#xff1a;C 2、如图所示&#xff0c;路由器的所有接口开启…

ATTCK实战系列——红队实战(二)

网络配置 网卡&#xff1a; WEB&#xff1a; PC&#xff1a; DC&#xff1a; IPWEB10.10.10.80&#xff08;内&#xff09;/192.168.111.80&#xff08;外&#xff09;PC10.10.10.201&#xff08;内&#xff09;/192.168.111.201&#xff08;外&#xff09;DC10.10.10.10物理机…

C++线程/阻塞/同步异步----2

本章节内容为记录改写RTK代码时&#xff0c;学习的知识 同步和异步区别 1.定义不同&#xff1a;同步需要将通信双方的时钟统一到一个频率上&#xff0c;异步通信发送的字符间隔时间可以是任意的; 2.准确性不同&#xff1a;同步通信需要比较高精度的精确度&#xff0c;异步则不…

5.12 BGP选路原则综合实验

配置BGP的选路原则 1. 实验目的 熟悉BGP的选路的应用场景掌握BGP的选路的配置方法2. 实验拓扑 实验拓扑如图5-11所示: 图5-11:配置BGP的选路原则 3. 实验步骤 (1)配置IP地址 R1的配置

你知道 GO 中的 协程可以无止境的开吗?

GO语言天生高并发的语言&#xff0c;那么是不是使用 go 开辟协程越多越好的&#xff0c;那么在 go 里面&#xff0c;协程是不是可以开无限多个呢&#xff1f; 那么我们就一起来看看尝试写写 demo 吧 尝试开辟尽可能多的 协程 写一个 demo &#xff0c;循环开 1 << 31 …

Mac 安装 homebrew

文章目录1. 简介2. 安装2.1 官方安装2.2 安装 ARM 版 Homebrew2.3 安装 X86 版 Homebrew2.4 多版本共存3. 设置镜像3.1 初次安装brew后配置中科大 zsh3.2 换源配置中科大 zsh3.3 换源清华大学 zsh4. 问题1. 简介 omebrew是一款包管理工具&#xff0c;目前支持macOS和linux系统…

「TCG 规范解读」第10章 TPM工作组 保护你的数字环境

可信计算组织&#xff08;Ttrusted Computing Group,TCG&#xff09;是一个非盈利的工业标准组织&#xff0c;它的宗旨是加强在相异计算机平台上的计算环境的安全性。TCG于2003年春成立&#xff0c;并采纳了由可信计算平台联盟&#xff08;the Trusted Computing Platform Alli…

【春秋云境】CVE-2022-28512

靶标介绍&#xff1a; ​ Fantastic Blog (CMS)是一个绝对出色的博客/文章网络内容管理系统。它使您可以轻松地管理您的网站或博客&#xff0c;它为您提供了广泛的功能来定制您的博客以满足您的需求。它具有强大的功能&#xff0c;您无需接触任何代码即可启动并运行您的博客。…

IDEA工具系列之连接Linux

我们在开发的时候&#xff0c;用IDEA开发程序&#xff0c;用XSHELL来管理服务器&#xff0c;这两个工具切换比较麻烦。有没有用IDEA来连接Linux。当然有&#xff0c;下面有实践步骤&#xff1a; 首先&#xff1a;连接Linux 打开IDEA->Tools->Start SSH Session 其中1&…

REDIS09_LBS出现背景、GEO算法介绍、算法步骤、剖析、邻近网格位置推算

文章目录①. LBS出现的背景②. 重新认识经纬度③. 感性认识GeoHash④. Geohash算法介绍⑤. Geohash算法步骤⑥. 更深入剖析GeoHash⑦. 邻近网格位置推算①. LBS出现的背景 ①. 移动互联网时代LBS应用越来越多,所在位置附近三公里的药店、交友软件中附近的小姐姐、外卖软件中附近…