热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

如何使用列表适配器在回收器视图中修改列表?

因此,当我从互联网上获取数据时(例如,当我们不断滚动并进行分页时,就像Youtu

因此,当我从互联网上获取数据时(例如,当我们不断滚动并进行分页时,就像Youtube),我试图在回收器视图的最后一个索引中添加加载项。像这样

如何使用列表适配器在回收器视图中修改列表?

现在我的回收站视图扩展了ListAdapter,不再使用RecyclerView.Adapter

如果使用RecyclerView.Adapter(旧方式),我将为适配器编写如下代码:

public class PaginationAdapter extends RecyclerView.Adapter {
private static final int ITEM = 0;
private static final int LOADING = 1;
private static final String BASE_URL_IMG = "https://image.tmdb.org/t/p/w150";
private List movieResults;
private Context context;
private boolean isLoadingAdded = false;
public PaginationAdapter(Context context) {
this.cOntext= context;
movieResults = new ArrayList<>();
}
public List getMovies() {
return movieResults;
}
public void setMovies(List movieResults) {
this.movieResults = movieResults;
}
@Override
public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent,int viewType) {
RecyclerView.ViewHolder viewHolder = null;
LayoutInflater inflater = LayoutInflater.from(parent.getcontext());
switch (viewType) {
case ITEM:
viewHolder = getViewHolder(parent,inflater);
break;
case LOADING:
View v2 = inflater.inflate(R.layout.item_progress,parent,false);
viewHolder = new LoadingVH(v2);
break;
}
return viewHolder;
}
@NonNull
private RecyclerView.ViewHolder getViewHolder(ViewGroup parent,LayoutInflater inflater) {
RecyclerView.ViewHolder viewHolder;
View v1 = inflater.inflate(R.layout.item_list,false);
viewHolder = new MovieVH(v1);
return viewHolder;
}
@Override
public void onBindViewHolder(RecyclerView.ViewHolder holder,int position) {
Movie result = movieResults.get(position); // Movie
switch (getItemViewType(position)) {
case ITEM:
// some code here
break;
case LOADING:
// Do nothing
break;
}
}
@Override
public int getItemCount() {
return movieResults == null ? 0 : movieResults.size();
}
@Override
public int getItemViewType(int position) {
return (position == movieResults.size() - 1 && isLoadingAdded) ? LOADING : ITEM;
}
public void addLoadingFooter() {
isLoadingAdded = true;
movieResults.add(new Moview());
notifyItemInserted(movieResults.size() - 1);
}
public void removeLoadingFooter() {
isLoadingAdded = false;
int position = movieResults.size() - 1;
Movie result = getItem(position);
if (result != null) {
movieResults.remove(position);
notifyItemRemoved(position);
}
}
}

但是现在我正在尝试将ListAdapter用于我的Recycler View。这是我的代码,如果我的回收站视图使用ListAdapter

class GeneralEventRecyclerViewAdapter(val mContext: Context): ListAdapter(DIFF_CALLBACK) {
lateinit var mOnEventKMListener : OnEventKMListener
private val ITEM = 0
private val LOADING = 1
private var isLoadingAdded = false
fun setOnItemClicklistener(listener: OnEventKMListener) {
mOnEventKMListener= listener
}
override fun onCreateViewHolder(parent: ViewGroup,viewType: Int): RecyclerView.ViewHolder {
if (viewType == ITEM) {
val itemView = LayoutInflater.from(parent.context).inflate(R.layout.item_general_event,false)
return GeneralEventViewHolder(itemView,mOnEventKMListener)
} else {
val loadingView = LayoutInflater.from(parent.context).inflate(R.layout.item_progress,false)
return LoadingViewHolder(loadingView)
}
}
override fun onBindViewHolder(holder: RecyclerView.ViewHolder,position: Int) {
if (getItemViewType(position) == ITEM) {
// some code here
}
}
override fun getItemViewType(position: Int): Int {
if (position == currentList.size - 1 && isLoadingAdded) {
return LOADING
} else {
return ITEM
}
}
fun addLoadingFooter() {
isLoadingAdded = true
currentList.add(Event())
notifyItemInserted(currentList.size - 1)
}
fun removeLoadingFooter() {
isLoadingAdded = false
val position: Int = currentList.size - 1
val result: Event? = getItem(position)
if (result != null) {
currentList.removeAt(position)
notifyItemRemoved(position)
}
}
companion object {
private val DIFF_CALLBACK = object : DiffUtil.ItemCallback() {
override fun areItemsTheSame(oldItem: Event,newItem: Event): Boolean {
return oldItem.eventID == newItem.eventID
}
override fun areContentsTheSame(oldItem: Event,newItem: Event): Boolean {
return oldItem == newItem
}
}
}
}

这是我的问题.....

在添加和删除回收站中的加载项时,我试图模仿这两种方法(使用RecyclerView.Adapter):

public void addLoadingFooter() {
isLoadingAdded = true;
movieResults.add(new Moview());
notifyItemInserted(movieResults.size() - 1);
}
public void removeLoadingFooter() {
isLoadingAdded = false;
int position = movieResults.size() - 1;
Movie result = getItem(position);
if (result != null) {
movieResults.remove(position);
notifyItemRemoved(position);
}
}

我假设如果使用ListAdapter

,则上述两种方法与下面的两种方法相同。

fun addLoadingFooter() {
isLoadingAdded = true
currentList.add(Event())
notifyItemInserted(currentList.size - 1)
}
fun removeLoadingFooter() {
isLoadingAdded = false
val position: Int = currentList.size - 1
val result: Event? = getItem(position)
if (result != null) {
currentList.removeAt(position)
notifyItemRemoved(position)
}
}

但是当我运行该应用程序时,我会崩溃

java.lang.UnsupportedOperationException
at java.util.AbstractList.add(AbstractList.java:148)
at java.util.AbstractList.add(AbstractList.java:108)

currentList.add(Event())

如果使用ListAdapter,似乎无法在列表中添加新项目。那么如何使用列表适配器在回收站视图中修改列表?

如果使用ListAdapter,我不知道如何访问现有列表,看来currentList不能被修改

java或kotlin没问题



最终使用

找到解决方案

override fun getItemViewType(position: Int): Int {
if ( position == currentList.lastIndex && isLoadingAdded) {
return LOADING
} else {
return ITEM
}
}
fun addLoadingFooter(currentList: ArrayList) {
isLoadingAdded = true
currentList.add(Event())
submitList(currentList)
notifyItemInserted(currentList.lastIndex)
}
fun removeLoadingFooter(currentList: ArrayList) {
isLoadingAdded = false
val result = currentList[currentList.lastIndex]
currentList.remove(result)
submitList(currentList)
notifyItemRemoved(currentList.size)
}

,

聚会迟到,但您当前的回答并未充分利用ListAdapter。您应该改用 ListAdapter.submitList,它可以完成大部分 notifyItemXXXXXX 工作。

val newList = ArrayList(listAdapter.currentList)
newList.add(Event()) // or to remove / update / ... etc.
listAdapter.submitList(newList)

还有一件重要的事情要知道:submitList 必须使用来自原始对象的新对象(列表)

val objList = mutableListOf(myObjects)
listAdapter.submitList(objList)
objList.add(newObject)
listAdapter.submitList(objList) // will NOT do updates.
listAdapter.submitList(ArrayList(objList)) // will do updates.

它在另一个 Stack Overflow question 中被提及。


推荐阅读
  • 在Android中实现黑客帝国风格的数字雨效果
    本文将详细介绍如何在Android平台上利用自定义View实现类似《黑客帝国》中的数字雨效果。通过实例代码,我们将探讨如何设置文字颜色、大小,以及如何控制数字下落的速度和间隔。 ... [详细]
  • 本文探讨了如何使用Scrapy框架构建高效的数据采集系统,以及如何通过异步处理技术提升数据存储的效率。同时,文章还介绍了针对不同网站采用的不同采集策略。 ... [详细]
  • Android 开发技巧:使用 AsyncTask 实现后台任务与 UI 交互
    本文详细介绍了如何在 Android 应用中利用 AsyncTask 来执行后台任务,并及时将任务进展反馈给用户界面,提高用户体验。 ... [详细]
  • 本文详细探讨了 Android Service 组件中 onStartCommand 方法的四种不同返回值及其应用场景。Service 可以在后台执行长时间的操作,无需提供用户界面,支持通过启动和绑定两种方式创建。 ... [详细]
  • iOS如何实现手势
    这篇文章主要为大家展示了“iOS如何实现手势”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“iOS ... [详细]
  • Hadoop MapReduce 实战案例:手机流量使用统计分析
    本文通过一个具体的Hadoop MapReduce案例,详细介绍了如何利用MapReduce框架来统计和分析手机用户的流量使用情况,包括上行和下行流量的计算以及总流量的汇总。 ... [详细]
  • 本文旨在探讨Swift中的Closure与Objective-C中的Block之间的区别与联系,通过定义、使用方式以及外部变量捕获等方面的比较,帮助开发者更好地理解这两种机制的特点及应用场景。 ... [详细]
  • 本文探讨了如何利用 Android 的 Movie 类来展示 GIF 动画,并详细介绍了调整 GIF 尺寸以适应不同布局的方法。同时,提供了相关的代码示例和注意事项。 ... [详细]
  • 一、使用Microsoft.Office.Interop.Excel.DLL需要安装Office代码如下:2publicstaticboolExportExcel(S ... [详细]
  • 深入理解iOS中的链式编程:以Masonry为例
    本文通过介绍Masonry这一轻量级布局框架,探讨链式编程在iOS开发中的应用。Masonry不仅简化了Auto Layout的使用,还提高了代码的可读性和维护性。 ... [详细]
  • 本文详细介绍如何在SSM(Spring + Spring MVC + MyBatis)框架中实现分页功能。包括分页的基本概念、数据准备、前端分页栏的设计与实现、后端分页逻辑的编写以及最终的测试步骤。 ... [详细]
  • 【MySQL】frm文件解析
    官网说明:http:dev.mysql.comdocinternalsenfrm-file-format.htmlfrm是MySQL表结构定义文件,通常frm文件是不会损坏的,但是如果 ... [详细]
  • 数据输入验证与控件绑定方法
    本文提供了多种数据输入验证函数及控件绑定方法的实现代码,包括电话号码、数字、传真、邮政编码、电子邮件和网址的验证,以及报表绑定和自动编号等功能。 ... [详细]
  • 尽管在WPF中工作了一段时间,但在菜单控件的样式设置上遇到了一些基础问题,特别是关于如何正确配置前景色和背景色。 ... [详细]
  • C/C++ 应用程序的安装与卸载解决方案
    本文介绍了如何使用Inno Setup来创建C/C++应用程序的安装程序,包括自动检测并安装所需的运行库,确保应用能够顺利安装和卸载。 ... [详细]
author-avatar
Durston
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有