热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

Android中RecyclerView实现Item添加和删除的代码示例

本文介绍了Android中RecyclerView实现Item添加和删除的代码示例,分享给大家,具体如下: 先上效果图: Rec

本文介绍了Android中RecyclerView实现Item添加和删除的代码示例,分享给大家,具体如下:

先上效果图:


RecyclerView简介:

RecyclerView用以下两种方式简化了数据的展示和处理:

1. 使用LayoutManager来确定每一个item的排列方式。

2. 为增加和删除项目提供默认的动画效果,也可以自定义。

RecyclerView项目结构如下:

Adapter:使用RecyclerView之前,你需要一个继承自RecyclerView.Adapter的适配器,作用是将数据与每一个条目的界面进行绑定。

LayoutManager:用来确定每一个item如何进行排列摆放,何时展示和隐藏。

RecyclerView-Item添加:

在适配器中加入如下代码:

  // 添加数据
  public void addData(int position) {
//   在list中添加数据,并通知条目加入一条
    list.add(position, "我是商品" + position);
    //添加动画
    notifyItemInserted(position);
  }

调用时:

 adapter.addData(list.size());

RecyclerView-Item删除:

在适配器中加入如下代码:

  // 删除数据
  public void removeData(int position) {
    list.remove(position);
    //删除动画
    notifyItemRemoved(position);
    notifyDataSetChanged();
  }

调用时:

//Item里的删除
   removeData(position);
//外面的控件的删除
adapter. removeData(position);

需要注意的是我再删除动画的下面加了notifyDataSetChanged();代码,因为我们在删除条目时不一定是按照顺序删除的,也许是错位删除,这样会因为position的原因造成角标越界异常,所以需要整体刷新一下。

整体代码:

**1.MainActivity **

package com.android.qzs.qzsrecycleview;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.DefaultItemAnimator;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.view.View;
import android.widget.ImageView;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
  private RecyclerView mRecyclerView;
  private ImageView iv_add;
  private RecycleAdapter adapter;
  private List list = new ArrayList();
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    initView();
    initRecycle();
    iv_add.setOnClickListener(new View.OnClickListener() {
      @Override
      public void onClick(View v) {
        //       添加自带默认动画
          adapter.addData(list.size());
    }
    });
  }
  private void initRecycle() {
    // 纵向滑动
    LinearLayoutManager linearLayoutManager = new LinearLayoutManager(this);
    mRecyclerView.setLayoutManager(linearLayoutManager);
//   获取数据,向适配器传数据,绑定适配器
    list = initData();
    adapter = new RecycleAdapter(MainActivity.this, list);
    mRecyclerView.setAdapter(adapter);
//   添加动画
    mRecyclerView.setItemAnimator(new DefaultItemAnimator());
  }
  private void initView() {
    iv_add = (ImageView) findViewById(R.id.iv_add);
    mRecyclerView = (RecyclerView) findViewById(R.id.recyclerview);
  }
  
  protected ArrayList initData() {
    ArrayList mDatas = new ArrayList();
    for (int i = 0; i <1; i++) {
      mDatas.add("我是商品" + i);
    }
    return mDatas;
  }
}

2.RecycleAdapter

package com.android.qzs.qzsrecycleview;
import android.content.Context;
import android.support.design.widget.Snackbar;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
import java.util.ArrayList;
import java.util.List;
/**
 * Created by qzs on 2017/9/04.
 */
class RecycleAdapter extends RecyclerView.Adapter {
  private Context context;
  private List list;
  public RecycleAdapter(Context context, List list) {
    this.cOntext= context;
    this.list = list;
  }
  @Override
  public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
    MyViewHolder holder = new MyViewHolder(LayoutInflater.from(
        context).inflate(R.layout.item_home, parent,
        false));
    return holder;
  }
  @Override
  public void onBindViewHolder(MyViewHolder holder, final int position) {
    holder.tv.setText(list.get(position));
    holder.tv_delete.setOnClickListener(new View.OnClickListener() {
      @Override
      public void onClick(View v) {
        if (list.size() == 1) {
          Snackbar.make(v, "此条目不能删除", Snackbar.LENGTH_SHORT).show();
        } else {
          //        删除自带默认动画
          removeData(position);
        }
      }
    });
  }
  @Override
  public int getItemCount() {
    return list.size();
  }
  // 添加数据
  public void addData(int position) {
//   在list中添加数据,并通知条目加入一条
    list.add(position, "我是商品" + position);
    //添加动画
    notifyItemInserted(position);
  }
  // 删除数据
  public void removeData(int position) {
    list.remove(position);
    //删除动画
    notifyItemRemoved(position);
    notifyDataSetChanged();
  }
  /**
   * ViewHolder的类,用于缓存控件
   */
  class MyViewHolder extends RecyclerView.ViewHolder {
    TextView tv, tv_delete;
    //因为删除有可能会删除中间条目,然后会造成角标越界,所以必须整体刷新一下!
    public MyViewHolder(View view) {
      super(view);
      tv = (TextView) view.findViewById(R.id.id_num);
      tv_delete = (TextView) view.findViewById(R.id.tv_delete);
    }
  }
}

源码下载地址

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • 本文将详细介绍多个流行的 Android 视频处理开源框架,包括 ijkplayer、FFmpeg、Vitamio、ExoPlayer 等。每个框架都有其独特的优势和应用场景,帮助开发者更高效地进行视频处理和播放。 ... [详细]
  • 本文详细探讨了Android Activity中View的绘制流程和动画机制,包括Activity的生命周期、View的测量、布局和绘制过程以及动画对View的影响。通过实验验证,澄清了一些常见的误解,并提供了代码示例和执行结果。 ... [详细]
  • vivo Y5s配备了联发科Helio P65八核处理器,这款处理器采用12纳米工艺制造,具备两颗高性能Cortex-A75核心和六颗高效能Cortex-A55核心。此外,它还集成了先进的图像处理单元和语音唤醒功能,为用户提供卓越的性能体验。 ... [详细]
  • 目录一、salt-job管理#job存放数据目录#缓存时间设置#Others二、returns模块配置job数据入库#配置returns返回值信息#mysql安全设置#创建模块相关 ... [详细]
  • Appium + Java 自动化测试中处理页面空白区域点击问题
    在进行移动应用自动化测试时,有时会遇到某些页面没有返回按钮,只能通过点击空白区域返回的情况。本文将探讨如何在Appium + Java环境中有效解决此类问题,并提供详细的解决方案。 ... [详细]
  • 本文深入探讨了Memcached的内存管理机制,特别是其采用的Slab Allocator技术。该技术通过预分配不同大小的内存块来有效解决内存碎片问题,并确保高效的数据存储与检索。文中详细描述了Slab Allocator的工作原理、内存分配流程以及相关的优化策略。 ... [详细]
  • Java项目分层架构设计与实践
    本文探讨了Java项目中应用分层的最佳实践,不仅介绍了常见的三层架构(Controller、Service、DAO),还深入分析了各层的职责划分及优化建议。通过合理的分层设计,可以提高代码的可维护性、扩展性和团队协作效率。 ... [详细]
  • 深入解析Java虚拟机(JVM)架构与原理
    本文旨在为读者提供对Java虚拟机(JVM)的全面理解,涵盖其主要组成部分、工作原理及其在不同平台上的实现。通过详细探讨JVM的结构和内部机制,帮助开发者更好地掌握Java编程的核心技术。 ... [详细]
  • PostgreSQL 最新动态 —— 2022年4月6日
    了解 PostgreSQL 社区的最新进展和技术分享 ... [详细]
  • 微信小程序:授权登录与手机号绑定
    本文详细介绍了微信小程序中用户授权登录及绑定手机号的流程,结合官方指引和实际开发经验,提供了一套完整的实现方案,帮助开发者更好地理解和应用。 ... [详细]
  • ElasticSearch 集群监控与优化
    本文详细介绍了如何有效地监控 ElasticSearch 集群,涵盖了关键性能指标、集群健康状况、统计信息以及内存和垃圾回收的监控方法。 ... [详细]
  • 本文详细介绍了 Python 中的条件语句和循环结构。主要内容包括:1. 分支语句(if...elif...else);2. 循环语句(for, while 及嵌套循环);3. 控制循环的语句(break, continue, else)。通过具体示例,帮助读者更好地理解和应用这些语句。 ... [详细]
  • 并发编程 12—— 任务取消与关闭 之 shutdownNow 的局限性
    Java并发编程实践目录并发编程01——ThreadLocal并发编程02——ConcurrentHashMap并发编程03——阻塞队列和生产者-消费者模式并发编程04——闭锁Co ... [详细]
  • 优化Flask应用的并发处理:解决Mysql连接过多问题
    本文探讨了在Flask应用中通过优化后端架构来应对高并发请求,特别是针对Mysql 'too many connections' 错误的解决方案。我们将介绍如何利用Redis缓存、Gunicorn多进程和Celery异步任务队列来提升系统的性能和稳定性。 ... [详细]
  • 访问一个网页的全过程
    准备:DHCPUDPIP和以太网启动主机,用一根以太网电缆连接到学校的以太网交换机,交换机又与学校的路由器相连.学校的这台路由器与一个ISP链接,此ISP(Intern ... [详细]
author-avatar
拍友2602932873
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有