热门标签 | 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 中被提及。


推荐阅读
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • JVM 学习总结(三)——对象存活判定算法的两种实现
    本文介绍了垃圾收集器在回收堆内存前确定对象存活的两种算法:引用计数算法和可达性分析算法。引用计数算法通过计数器判定对象是否存活,虽然简单高效,但无法解决循环引用的问题;可达性分析算法通过判断对象是否可达来确定存活对象,是主流的Java虚拟机内存管理算法。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
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社区 版权所有