赞
踩
创建新的数据源装载旧数据以及新增/删除数据。利用List集合进行增加和删除,通过loadInitial将最新的List数据返回给PagedList,最后调用submitList更新数据。
以PageKeyedDataSource作为数据源为例,首先新建一个DataSource的类PageKeyedDataSourceExtension继承PageKeyedDataSource,
在新的DataSource中创建一个List装载新的数据,也是后续用来增加和删除数据的集合。
public List<ExBean> mDataList = new ArrayList<>();
在实现的loadInitial()方法中将最新的mDataList数据通过LoadInitialCallback返回给PagedList,loadBefore和loadAfter只需要传入空的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为旧的数据源
}
https://juejin.cn/post/6901296420410638343
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。