刷新视图的动画由于Android中的setAdapter而卡住了。

问题描述 投票:0回答:1

我有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));
            }
        });
android android-layout android-recyclerview recycler-adapter swiperefreshlayout
1个回答
0
投票

我没有在视图绑定工作,但看到下面的行,罪魁祸首。

   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();

我建议,+下一步在创建适配器时,传递一个空列表。

  • 为什么你不在创建适配器的Host类中初始化DisplayImageOptions实例,然后将初始化的实例传递给适配器。
  • 这样一来,开销就在主机类上,而不是在适配器上。

  • 最后,当刷卡完成后,一个新的Lest就准备好了。

    mAdapter.setNewList(whatever list){this.yourList = newList;notifyDataSetChanged.}。

这应该可以完成工作

© www.soinside.com 2019 - 2024. All rights reserved.