Android RecyclerViewSwipeDismiss:水平、垂直方向的拖曳删除item
Android RecyclerViewSwipeDismiss:水平、垂直方向的拖曳删除item
RecyclerViewSwipeDismiss是一种支持RecyclerView的水平、垂直方向拖曳删除RecyclerView里面条目item的第三方开源项目,RecyclerViewSwipeDismiss在gitbub上的项目主页是:https://github.com/CodeFalling/RecyclerViewSwipeDismiss
我在以前写过类似的项目内容,最典型的就是腾讯QQ的消息列表,见附录文章1所简介,QQ的消息列表中某一个条目左滑以后会滑出一系列选项,比如删除、置顶等。同样,也有像附录文章2那样左滑右滑可以删除ListView内容的开源项目。
这篇文章要介绍的RecyclerViewSwipeDismiss,除了支持RecyclerView这个最新的“ListView”外,RecyclerViewSwipeDismiss还支持垂直方向的上滑/下滑,以及水平方向的左滑/右滑删除,这和附录文章1,2的开源项目相比较有其应用场景特色,假设有一个水平方向的RecyclerView,那么我可以设置成垂直方向的滑动删除;假设是一个垂直方向的RecyclerView,那么我可以设置成水平方向的左滑/右滑删除。
写一个简单的例子,测试的MainActivity.java:
package zhangphil.demo; import android.app.Activity;
import android.os.Bundle;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
import android.widget.Toast; import java.util.LinkedList;
import java.util.List; import io.github.codefalling.recyclerviewswipedismiss.SwipeDismissRecyclerViewTouchListener; public class MainActivity extends Activity { @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); final RecyclerView mRecyclerView = (RecyclerView) findViewById(R.id.recyclerView); LinearLayoutManager horizontalLayoutManager = new LinearLayoutManager(this);
horizontalLayoutManager.setOrientation(LinearLayoutManager.HORIZONTAL);
mRecyclerView.setLayoutManager(horizontalLayoutManager); List<String> data = new LinkedList<String>();
for (int i = 0; i < 100; i++)
data.add("数据:" + i); final MyAdapter adapter = new MyAdapter(data);
mRecyclerView.setAdapter(adapter); SwipeDismissRecyclerViewTouchListener listener = new SwipeDismissRecyclerViewTouchListener.Builder(
mRecyclerView,
new SwipeDismissRecyclerViewTouchListener.DismissCallbacks() {
@Override
public boolean canDismiss(int position) {
return true;
} @Override
public void onDismiss(View view) {
int id = mRecyclerView.getChildPosition(view);
adapter.data.remove(id);
adapter.notifyDataSetChanged();
Toast.makeText(getApplication(), String.format("删除 %d", id), Toast.LENGTH_SHORT).show();
}
})
.setIsVertical(true) /**true为垂直方向拖曳删除,如果是false,那么是水平方向的拖曳删除*/
.create(); mRecyclerView.setOnTouchListener(listener);
} public class MyAdapter extends RecyclerView.Adapter<MyViewHolder> { public List<String> data; public MyAdapter(List<String> data) {
super();
this.data = data;
} @Override
public MyViewHolder onCreateViewHolder(ViewGroup viewGroup, int i) {
View view = View.inflate(viewGroup.getContext(), android.R.layout.simple_list_item_1, null);
MyViewHolder holder = new MyViewHolder(view);
return holder;
} @Override
public void onBindViewHolder(MyViewHolder viewHolder, int i) {
viewHolder.mTextView.setText(data.get(i));
} @Override
public int getItemCount() {
return data.size();
}
} private class MyViewHolder extends RecyclerView.ViewHolder {
public TextView mTextView; public MyViewHolder(View itemView) {
super(itemView);
mTextView = (TextView) itemView;
}
}
}
布局文件:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"> <android.support.v7.widget.RecyclerView
android:id="@+id/recyclerView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scrollbars="vertical" /> </RelativeLayout>
运行结果:
在设计时候要注意一些常识,比如,如果设计的是一个水平的RecyclerView,那么比较自然的滑动删除方向是垂直的上滑/下滑;而如果是一个垂直方向的RecyclerView,那么比较自然的滑动删除方向是水平的左滑/右滑。RecyclerViewSwipeDismiss通过setIsVertical(boolean b)布尔值控制,true为垂直方向的上下滑动删除,false则是水平方向的左右滑动删除,开发者应该设计相配套的RecyclerView方向。
附录文章:
1,《Android SwipeMenuListView》链接地址:http://blog.csdn.net/zhangphil/article/details/46999127
2,《Android SwipeToDismiss:左滑/右滑删除ListView条目Item》链接地址:http://blog.csdn.net/zhangphil/article/details/47081863
Android RecyclerViewSwipeDismiss:水平、垂直方向的拖曳删除item的更多相关文章
- Android RecyclerView(瀑布流)水平/垂直方向分割线
Android RecyclerView(瀑布流)水平/垂直方向分割线 Android RecyclerView不像过去的ListView那样随意的设置水平方向的分割线,如果要实现Recycle ...
- css 元素水平垂直方向居中
html部分 <div class="parent"> <div class="child"> - -居中- - </div> ...
- 小div在大div里面水平垂直都居中的实现方法
关于如何设置小盒子在大盒子里面水平垂直方向同时居中的实现方法有很多种,下面仅列举了常用的几种. 首先看一下要实现的效果图及对应的html代码: <div class="parent&q ...
- HTML-移动端如何使用css让百分比布局的弹窗水平和垂直方向上居中
pc端让一个弹窗水平和垂直方向居中,在知道弹窗宽高的情况下很好计算,只需要用如下css即可: #date{ width: 300px; height: 300px; position: absolut ...
- CSS居中问题:块级元素和行级元素在水平方向以及垂直方向的居中问题
元素的居中问题是每个初学者碰到的第一个大问题,在此我总结了下各种块级 行级 水平 垂直 的居中方法,并尽量给出代码实例. 首先请先明白块级元素和行级元素的区别 块级元素 块级元素水平居中 1:marg ...
- div里面的元素在【垂直 方向】上水平分布 使用calc()函数动态计算
1==>如何让div里面的元素在[垂直 方向]上水平分布.important-dec{ height: 121px; //必须固定高度 flex-direction: column; //垂直排 ...
- Android 使用NineOldAndroids实现绚丽的ListView左右滑动删除Item效果
本文出自xiaanming的博客(http://blog.csdn.net/xiaanming/article/details/18311877) 今天还是给大家带来自定义控件的编写,自定义一个Lis ...
- 《在纹线方向上进行平滑滤波,在纹线的垂直方向上进行锐化滤波》 --Gabor增强的具体实践
<在纹线方向上进行平滑滤波,在纹线的垂直方向上进行锐化滤波> --Gabor增强的具体实践 一.问 ...
- 禁止uiscrollview垂直方向滚动,只允许水平方向滚动;或只允许垂直方向滚动
禁止UIScrollView垂直方向滚动,只允许水平方向滚动 scrollview.contentSize = CGSizeMake(你要的长度, 0); 禁止UIScrollView水平方向滚动, ...
随机推荐
- uoj#34
模板 #include<bits/stdc++.h> #define pi acos(-1) using namespace std; ; int n, m, L, x; int r[N] ...
- AD10 库下载地址
http://wiki.altium.com/display/ADOH/Download+Libraries 最新更新库地址: http://designcontent.live.altium.com ...
- CSS小代码汇总整理
/**实现斑马线的表格*/table.flexme tbody tr:nth-child(2n){background-color:#D6E7FC;} /*返回偶数序的子元素*/table.flexm ...
- 7.2 高速缓冲存储器-Cache
高速缓冲存储器:Cache.Cache的功能是提高CPU数据的输入和输出的速率.CPU的速度与主存的速度之间有巨大的差异.主存的存取时间.存取速度要比CPU的速度要慢了很多倍.为了调和它们之间的巨大速 ...
- html5打开摄像头并用canvas模拟拍照
网上很多关于用HTML5打开本地摄像头的文章,但各有瑕疵.根据我自己的亲身体验,我分享一下我用HTML5打开摄像头的经验. 废话不多说,直接看代码. HTML代码: <video id=&quo ...
- HttpPostedFileBase 基类
public void uploadDocMentSave(string Type) { if (Request.Files.Count > 0) { Htt ...
- DML和DQL语句
DML操作: a.插入单行数据: INSERT INTO 表名(列名,列名,...) VALUE(列值,列值,...); 表的字段名是可选的,如果省略,则一次插入所有字段 多个列表和多个值之 ...
- Struts之 拦截器配置 ( Interceptor )
struts2体系结构的核心就是拦截器. 以链式执行,对真正要执行的方法(execute())进行拦截.首先执行Action配置的拦截器,在Action和Result执行之后,拦截器再一次执行(与先前 ...
- CSS——层级
层级问题:选中的盒子显示的效果并不完整,右边的边框并没有显示红色,原因是其右边的盒子压了它的边框. <!DOCTYPE html> <html lang="en" ...
- CSS——伪类
在a标签中运用最多: 1.a:link {color: #FF0000} /* 未访问的链接 */ 2.a:visited {color: #00FF00} /* 已访问的链接 */ 3.a:hove ...