我有Recycleview的拉动刷新功能,通过执行拉动刷新,我在Recycleview中洗牌记录。
现在我的问题是,一旦我将新的数组设置为Recycleview,使用pull刷新视图。这里刷新视图会卡住,事实上整个Recycleview会因为notifyDataSetChange()方法而卡住,这个问题只存在1或2秒。另外,我的数组记录数是200条,可能也是这个原因。
提示:我可以在这里为这个任务添加一个进度条,但我不想阻止用户交互,所以任何帮助,我可以设置适配器,没有任何滞后问题的UI?
适配器
public class BaseAdapter extends RecyclerView.Adapter<BaseAdapter.MyViewHolder> implements View.OnClickListener {
public Context context;
List<Model.Result> list;
Controller controller;
CommonFunctions cmf;
String user_id;
int layout;
ImageLoader imageLoader;
private DisplayImageOptions options;
public BaseAdapter(Context context, List<Model.Result> list, int layout, Controller controller) {
this.context = context;
this.list = list;
this.controller = controller;
this.layout = layout;
imageLoader = ImageLoader.getInstance(); // Get singleton instance
options = new DisplayImageOptions.Builder()
.showImageOnLoading(R.drawable.placeholder_ic)
.showImageOnFail(R.drawable.placeholder_ic)
.cacheInMemory(true)
.cacheOnDisk(true)
.build();
cmf = new CommonFunctions(context);
user_id = CommonFunctions.myPreference.getString(context, GlobalConstants.id);
}
@Override
public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = LayoutInflater.from(context).inflate(layout, parent, false);
MyViewHolder holder = new MyViewHolder(view);
return holder;
}
@Override
public void onBindViewHolder(MyViewHolder holder, int pos) {
// holder.name.setText(list.get(pos).getCatName());
if (holder.name != null)
holder.name.setText(list.get(pos).getAudioName());
if (holder.title != null)
holder.title.setText(list.get(pos).getArtistName());
if (holder.timeDuration != null)
holder.timeDuration.setText(list.get(pos).getAudiolength());
if(holder.txtTopicName!=null)
holder.txtTopicName.setText(list.get(pos).getCatName());
if (holder.image != null) {
imageLoader.displayImage(list.get(pos).getAudioImage(), holder.image,options);
}
}
@Override
public int getItemCount() {
return list.size();
}
@Override
public void onClick(View v) {
if (v.getId() == R.id.TV_title) {
}
}
public class MyViewHolder extends RecyclerView.ViewHolder {
LinearLayout ll_row;
ImageView iv_more, image;
TextView name, title, timeDuration,txtTopicName;
public MyViewHolder(View itemView) {
super(itemView);
ll_row = itemView.findViewById(R.id.ll_row);
iv_more = itemView.findViewById(R.id.iv_more);
image = itemView.findViewById(R.id.image);
name = itemView.findViewById(R.id.name);
title = itemView.findViewById(R.id.title);
timeDuration = itemView.findViewById(R.id.time_duration);
txtTopicName = itemView.findViewById(R.id.txtTopicName);
}
}
}
刷新视图
binding.swipeLayout.setOnRefreshListener(() -> {
binding.swipeLayout.setRefreshing(false);
if(array!=null&&array.size()>0){
Collections.shuffle(array, new Random());
binding.recyclerView.setAdapter(new BaseAdapter(getActivity(),array, layout,null));
}
});
我没有在视图绑定工作,但看到下面的行,罪魁祸首。
binding.recyclerView.setAdapter(new BaseAdapter(getActivity(),array, layout,null));
/那一个重操作的创建一个构造函数和顶部的,看看你的适配器类,如何重.你的Base适配器构造函数似乎很重。
imageLoader = ImageLoader.getInstance(); // Get singleton instance
options = new DisplayImageOptions.Builder() // heavy
.showImageOnLoading(R.drawable.placeholder_ic)
.showImageOnFail(R.drawable.placeholder_ic)
.cacheInMemory(true)
.cacheOnDisk(true)
.build();
我建议,+下一步在创建适配器时,传递一个空列表。
这样一来,开销就在主机类上,而不是在适配器上。
最后,当刷卡完成后,一个新的Lest就准备好了。
mAdapter.setNewList(whatever list){this.yourList = newList;notifyDataSetChanged.}。
这应该可以完成工作