软件编程
位置:首页>> 软件编程>> Android编程>> Android利用RecyclerView实现全选、置顶和拖拽功能示例

Android利用RecyclerView实现全选、置顶和拖拽功能示例

作者:爱开发  发布时间:2023-06-05 18:21:22 

标签:recyclerview,全选,拖拽

前言

今天给大家分享是如何在RecyclerView实现全选,ItemTouchHelper实现侧滑删除,拖拽功能。比较基础。关于RecyclerView的强大,就不多说了。在Android L SDK发布的新API中最有意思的就是RecyclerView 和 CardView了, 按照官方的说法, RecyclerView 一个ListView 的一个更高级更灵活的一个版本, 可以自定义的东西太多了。

效果:

Android利用RecyclerView实现全选、置顶和拖拽功能示例
RecyclerView实现全选,ItemTouchHelper实现侧滑删除,拖拽功能

使用RecyclerView,首先我们需要依赖


compile 'com.android.support:recyclerview-v7:23.+'

项目结构:

Android利用RecyclerView实现全选、置顶和拖拽功能示例
项目结构

主要是把选择的存储在HashMap记录下来,通知用eventbus发送。下面我们一步一步来实现这种效果.

方法如下

1、我们新建一个MainActivity 布局


public class MainActivity extends Activity {
private RecyclerView recyclerView;
private CheckBox checkbox;
private TextView selected;
private ListAdapter adapter;
private EventBus event;
private boolean isChange = false;
private ArrayList<Book> list = new ArrayList<>();

@Override
protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 initView();
 initData();
}

private void initView() {
 event = EventBus.getDefault();
 event.register(this);
 recyclerView = (RecyclerView) findViewById(R.id.recyclerview);
 checkbox = (CheckBox) findViewById(R.id.checkbox);
 selected = (TextView) findViewById(R.id.selected);
}

private void initData() {
 for (int i = 0; i < 20; i++) {
  Book model = new Book();
  model.setId(i);
  model.setName("商品" + i);
  model.setDesc("描述" + i);
  list.add(model);
 }
 adapter = new ListAdapter(list, event);
 recyclerView.setHasFixedSize(true);
 recyclerView.setAdapter(adapter);
 recyclerView.setLayoutManager(new GridLayoutManager(this, 3));
 checkbox.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
  @Override
  public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
   try {
    HashMap<Integer, Boolean> map = new HashMap<Integer, Boolean>();
    int count = 0;
    if (isChecked) {
     isChange = false;
    }
    for (int i = 0, p = list.size(); i < p; i++) {
     if (isChecked) {
      map.put(i, true);
      count++;
     } else {
      if (!isChange) {
       map.put(i, false);
       count = 0;
      } else {
       map = adapter.getMap();
       count = map.size();
      }
     }
    }
    selected.setText("已选" + count + "项");
    adapter.setMap(map);
   } catch (Exception e) {
    e.printStackTrace();
   }
  }
 });

adapter.setOnItemClickListener(new ListAdapter.ItemClickListener() {
  @Override
  public void onItemClick(RecyclerView.ViewHolder holder, int positon) {
   Log.e("onItemClick", "" + positon);
  }

@Override
  public void onItemLongClick(final RecyclerView.ViewHolder holder, final int positon) {
   Log.e("onItemLongClick", "" + positon);
  }
 });
}

public void onEventMainThread(SelectEvent event) {
 int size = event.getSize();
 if (size < list.size()) {
  isChange = true;
  checkbox.setChecked(false);
 } else {
  checkbox.setChecked(true);
  isChange = false;
 }
 selected.setText("已选" + size + "项");
}
@Override
protected void onDestroy() {
 super.onDestroy();
 event.unregister(this);
}
}

2、我们建一个ListAdapter适配器


public class ListAdapter extends RecyclerView.Adapter<ListAdapter.ItemViewHolder> {

private List<Book> mItems;
private List<Book> selected;
public HashMap<Integer, Boolean> map;
private EventBus eventBus;

public ListAdapter(List<Book> mItems, EventBus eventBus) {
 this.mItems = mItems;
 this.eventBus = eventBus;
 map = new HashMap<>();
 selected = new ArrayList<>();
 init();
}

private void init() {
 if (null == mItems || mItems.size() <= 0) {
  return;
 }
 for (int i = 0, p = mItems.size(); i < p; i++) {
  map.put(i, false);
 }
}

@Override
public ItemViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
 View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.activity_main_item, parent, false);
 ItemViewHolder itemViewHolder = new ItemViewHolder(view);
 return itemViewHolder;
}

@Override
public void onBindViewHolder(final ItemViewHolder holder, final int position) {
 if (null == mItems || mItems.size() <= 0) {
  return;
 }
 holder.name.setText(mItems.get(position).getName());
 holder.desc.setText(mItems.get(position).getDesc());

holder.checkBox.setTag(new Integer(position));//防止划回来时选中消失

if (map != null) {
  ((ItemViewHolder) holder).checkBox.setChecked((map.get(position)));
 } else {
  ((ItemViewHolder) holder).checkBox.setChecked(false);
 }
 holder.checkBox.setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View view) {
   int mFlags = (Integer) view.getTag();
   if (map != null) {
    if (map.get(position)) {
     map.put(position, false);
     eventBus.post(new SelectEvent(selected(map)));
    } else {
     map.put(mFlags, Boolean.TRUE);
     eventBus.post(new SelectEvent(selected(map)));
    }
   }
  }
 });
 holder.itemView.setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View v) {
   mItemClickListener.onItemClick(holder,holder.getAdapterPosition());
  }
 });
 holder.itemView.setOnLongClickListener(new View.OnLongClickListener() {
  @Override
  public boolean onLongClick(View v) {
   mItemClickListener.onItemLongClick(holder,holder.getAdapterPosition());
   return true;
  }
 });
}

private int selected(HashMap<Integer, Boolean> map) {
 int size = 0;
 for (Integer key : map.keySet()) {
  if(map.get(key)){
   size++;
  }
 }
 return size;
}
@Override
public int getItemCount() {
 return mItems == null? 0 :mItems.size();
}
public static class ItemViewHolder extends RecyclerView.ViewHolder{

public final CheckBox checkBox;
 public final TextView name;
 public final TextView desc;

public ItemViewHolder(View itemView) {
  super(itemView);
  checkBox = (CheckBox) itemView.findViewById(R.id.checkbox);
  name = (TextView) itemView.findViewById(R.id.tv_name);
  desc = (TextView) itemView.findViewById(R.id.tv_desc);
 }
}

public HashMap<Integer, Boolean> getMap() {
 return map;
}

public void setMap(HashMap<Integer, Boolean> map) {
 this.map = map;
 notifyDataSetChanged();
}

/**
 * 点击事件和长按事件
 */
public interface ItemClickListener{
 void onItemClick(RecyclerView.ViewHolder holder , int position);
 void onItemLongClick(RecyclerView.ViewHolder holder , int position);
}

private ItemClickListener mItemClickListener;
public void setOnItemClickListener(ItemClickListener listener){
 this.mItemClickListener=listener;
}
}

3、我们新建实体Book和SelectEvent


package com.aikaifa.checkall.bean;

public class Book {

private int id;
private String name;
private String desc;

public String getDesc() {
 return desc;
}

public void setDesc(String desc) {
 this.desc = desc;
}

public String getName() {
 return name;
}

public void setName(String name) {
 this.name = name;
}

public int getId() {
 return id;
}

public void setId(int id) {
 this.id = id;
}

public Book() {
}
}

public class SelectEvent {
private int size;

public SelectEvent(int size) {
 this.size = size;
}

public int getSize() {
 return size;
}
}

4、建立checkbox_selector.xml选中样式


<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@mipmap/checkbox_pressed" android:state_checked="true"/>
<item android:drawable="@mipmap/checkbox_normal" android:state_checked="false"/>
<item android:drawable="@mipmap/checkbox_normal"/>
</selector>

5、建立一个activity_main.xml布局


<?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"
android:orientation="vertical">

<LinearLayout
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:orientation="horizontal">

<CheckBox
  android:id="@+id/checkbox"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:drawablePadding="10dp"
  android:text="全选"
  android:textColor="#969696"
  android:textSize="12sp" />

<TextView
  android:id="@+id/selected"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:layout_marginLeft="10dp"
  android:gravity="center_vertical"
  android:text="已选0项" />
</LinearLayout>

<android.support.v7.widget.RecyclerView
 android:id="@+id/recyclerview"
 android:layout_width="match_parent"
 android:layout_height="match_parent" />
</LinearLayout>

activity_main_item布局


<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/item"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="10dp"
android:clickable="true"
android:focusable="true">

<RelativeLayout
 android:id="@+id/rl_app"
 android:layout_width="50dp"
 android:layout_height="50dp"
 android:layout_centerHorizontal="true">

<ImageView
  android:id="@+id/iv"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:src="@mipmap/ic_launcher" />

<CheckBox
  android:id="@+id/checkbox"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:layout_alignParentRight="true"
  android:layout_gravity="center_vertical"
  android:button="@drawable/checkbox_selector" />

</RelativeLayout>

<TextView
 android:id="@+id/tv_name"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:layout_below="@+id/rl_app"
 android:gravity="center"
 android:text="name"
 android:textColor="#ffffff" />

<TextView
 android:id="@+id/tv_desc"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:layout_below="@+id/tv_name"
 android:gravity="center"
 android:textColor="#f5f5f5"
 android:textSize="9sp" />
</RelativeLayout>

这样关于RecyclerView实现全选,ItemTouchHelper实现侧滑删除,拖拽功能就完成了。

示例代码下载:

项目地址:https://github.com/88ios/RecyclerViewCheckAll

本地下载:点击这里

来源:http://www.jianshu.com/p/7082b7d10760

0
投稿

猜你喜欢

  • 问题遇到问题:在前后端分离跨域访问的项目中shiro进行权限拦截失效 (即使有正确权限的访问也会被拦截) 时造成302重定向错误等问题报错:
  • 本文实例为大家分享了Android利用Canvas类绘制图形的具体代码,供大家参考,具体内容如下首先介绍一下相关基础知识。1.画笔(pain
  • C#剪切板Clipboard类我们现在先来看一下官方文档的介绍位于:System.Windows.Forms 命名空间下Provides m
  • 前言《布谷鸟闯关-简单版》是一个基于java的布谷鸟闯关游戏,摁上键控制鸟的位置穿过管道间的缝隙,需要做碰撞检测,监听键盘事件,背景图片的切
  • 希尔排序,也称递减增量排序算法,是插入排序的一种更高效的改进版本。希尔排序是非稳定排序算法。希尔排序是基于插入排序的以下两点性质而提出改进方
  • 如何在Unity里修改FBX模型自带的动画我们在把模型做成预制体的时候会出现,模型当前看到的位置和动画播放的位置不一致,而且模型动画文件又是
  • 如何在listview中插入图片,相信大家很想知道,下面就为大家分享具体步骤:第一步:在窗体中拖入ListView控件和imageList控
  •  一、输入映射parameterType指定输入参数的Java类型,可以使用别名或者类的全限定名。它可以接收简单类型、POJO、H
  • Android中子线程和UI线程之间通信的详细解释 1.在多线程编程这块,我们经常要使用Handler,Thread和Runnable这三个
  • 这篇文章主要介绍了java private关键字用法实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的
  • 本文实例为大家分享了viewGroup实现点击动画效果展示的具体代码,供大家参考,具体内容如下public class MyCustomVi
  • 前言MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手
  • 程序在32位操作系统上运行正常,在64位操作系统上运行读卡功能提示”试图加载格式不正确“。-------------------------
  • 前面做了app微信支付的回调处理,现在需要做微信公众号的支付,花了一天多时间,终于折腾出来了!鉴于坑爹的微信官方没有提供Java版的demo
  • 有时候你希望在一个嵌套循环的外层循环中执行Continue操作。例如,假设你有一连串的标准,和一堆items。并且你希望找到一个符合每个标准
  • 现在,我们来讲一下怎么用Java来实现简单画板,要实现的功能有:选择图形(方形、圆形、多边形...)、可以选择颜色。首先,打开windows
  • 本文实例为大家分享了Android实现APP秒表功能的具体代码,供大家参考,具体内容如下这几天一直在看安卓,也正好赶上老师布置的作业,所以就
  • 一 概述CMDD:\Project\Computer-Science-And-Technology\writeExam\farben\src
  • 前言对于联表查询的四个注解 @OneToOne、@OneToMany、@ManyToOne 和 @ManyToMany,他们有几个用得比较多
  • 本文实例总结了Java JDBC连接数据库常见操作。分享给大家供大家参考,具体如下:db.properties配置文件(MySql数据库)#
手机版 软件编程 asp之家 www.aspxhome.com