, поэтому я пытаюсь добавить загрузочный элемент в последний индекс моего представления переработчика при получении данных из Интернета, например Youtube, когда мы продолжаем прокручивать и разбиваем на страницы. как-то так

теперь мое представление переработчика расширяется ListAdapter
и больше не используется RecyclerView.Adapter<RecyclerView.ViewHolder>
при использовании RecyclerView.Adapter<RecyclerView.ViewHolder>
(по-старому) Я напишу код для моего адаптера следующим образом:
public class PaginationAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder> {
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<Movie> movieResults;
private Context context;
private boolean isLoadingAdded = false;
public PaginationAdapter(Context context) {
this.context = context;
movieResults = new ArrayList<>();
}
public List<Movie> getMovies() {
return movieResults;
}
public void setMovies(List<Movie> 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, parent, 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<Event, RecyclerView.ViewHolder>(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, parent, false)
return GeneralEventViewHolder(itemView, mOnEventKMListener)
} else {
val loadingView = LayoutInflater.from(parent.context).inflate(R.layout.item_progress, parent, 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<Event>() {
override fun areItemsTheSame(oldItem: Event, newItem: Event): Boolean {
return oldItem.eventID == newItem.eventID
}
override fun areContentsTheSame(oldItem: Event, newItem: Event): Boolean {
return oldItem == newItem
}
}
}
}
вот моя проблема .....
Я пытаюсь имитировать эти 2 метода (используя 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);
}
}
Я предполагаю, что эти 2 метода выше будут такими же, как мои 2 метода ниже при использовании 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
. так как изменить список в представлении рециркулятора с помощью List Adapter?
Я не знаю, как получить доступ к существующему списку, если используется ListAdapter
, кажется, currentList
нельзя изменить
Ява или Котлин в порядке