【Jetpack篇】Paging Item的新增与删除

2,516 阅读2分钟

一、整体思路:

创建新的数据源装载旧数据以及新增/删除数据。利用List集合进行增加和删除,通过loadInitial将最新的List数据返回给PagedList,最后调用submitList更新数据。

PageKeyedDataSource作为数据源为例,首先新建一个DataSource的类PageKeyedDataSourceExtension继承PageKeyedDataSource

在新的DataSource中创建一个List装载新的数据,也是后续用来增加和删除数据的集合。

 public List<ExBean> mDataList = new ArrayList<>();

在实现的loadInitial()方法中将最新的mDataList数据通过LoadInitialCallback返回给PagedListloadBeforeloadAfter只需要传入空的List即可。

 @Override
    public void loadInitial(@NonNull LoadInitialParams<Integer> params, @NonNull LoadInitialCallback<Integer, ExBean> callback) {
        callback.onResult(mDataList, null, null);
    }

    @Override
    public void loadBefore(@NonNull LoadParams<Integer> params, @NonNull LoadCallback<Integer, ExBean> callback) {
        callback.onResult(Collections.<ExBean>emptyList(), null);

    }

    @Override
    public void loadAfter(@NonNull LoadParams<Integer> params, @NonNull LoadCallback<Integer, ExBean> callback) {
        callback.onResult(Collections.<ExBean>emptyList(), null);
    }

PageKeyedDataSourceExtension中创建一个新的PagedList用来重新绑定Adapter,

    public PagedList<ExBean> createNewPagedList(PagedList.Config config) {
        @SuppressLint("RestrictedApi") PagedList<ExBean> pagedList
        = new PagedList.Builder<>(this, config)
                .setFetchExecutor(ArchTaskExecutor.getIOThreadExecutor())
                .setNotifyExecutor(ArchTaskExecutor.getMainThreadExecutor())
                .build();
        return pagedList;
    }

准备好新的数据源之后,可以开始进行增删的具体操作。

二、新增

//增加
public void add(ExBean exBean) {
        //获取当前PagedList
        PagedList<ExBean> curList = getCurrentList();
        PageKeyedDataSourceExtension source = new PageKeyedDataSourceExtension();
        //将当前数据以及所要增加的数据添加到新的数据集中
        source.mDataList.addAll(curList);
        source.mDataList.add(exBean);
        
        //创建新的数据PagedList
        PagedList<ExBean> pagedList = source.createNewPagedList(curList.getConfig());
        submitList(pagedList);
    }


获取当前的PagedList,并且将其添加到PageKeyedDataSourceExtension的List集合中,同时新增一条新的数据exBean,获取完新的数据后,通过createNewPagedList(即new PagedList.Builder<>)来触发loadInitial,返回新的PagedList,最后则利用submitList绑定新数据。

三、删除

删除与新增是一个道理,利用PagedListAdapter的getItem(int positon)获取到需要删除的数据,通过遍历剔除需要删除的数据,创建新的数据源后再次绑定到Adapter上。

//删除
public void delete(int position) {
        //获取当前PagedList
        PagedList<ExBean> curList = getCurrentList();
        PageKeyedDataSourceExtension source = new PageKeyedDataSourceExtension();
        ExBean b = getItem(position);
        //遍历当前PagedList,剔除需要删除的item
        for(ExBean bean : curList){
           if(bean != b){
               source.mDataList.add(bean);
             }
        }
        
        //创建新的数据PagedList
        PagedList<ExBean> pagedList = source.createNewPagedList(curList.getConfig());
        submitList(pagedList);
    }

看下效果:

四、其它问题

在新增和删除中,由于创建了新的数据源并且绑定到了Adapter上,Paging的滑动也就被新的数据源所接管。

从代码PageKeyedDataSourceExtension类的loadAfter中可以知道,传入了一个空的List集合,

    ...
  @Override
    public void loadAfter(@NonNull LoadParams<Integer> params, @NonNull LoadCallback<Integer, ExBean> callback) {
        callback.onResult(Collections.<ExBean>emptyList(), null);
    }
    ...

导致在新增或者删除之后,如果用户继续想要向下滑动请求数据,是没有数据返回的。

如果有需求说要在新增或者删除后继续滑动请求,这也就需要做特殊的处理。我们都了解loadAfter是用来返回下一页数据的,我们在loadAfter继续用新增/删除之前的DataSource去接管,如下:

 @Override
    public void loadAfter(@NonNull LoadParams<Integer> params, @NonNull LoadCallback<Integer, ExBean> callback) {
        //callback.onResult(Collections.<ExBean>emptyList(), null);
        mDataSource.loadAfter(params,callback)//mDataSource为旧的数据源
    }