リストのページングを実装するために使用できるライブラリはありますか?
私が10行のスペースを持っていて、ユーザーがページごとに前後にスクロールするかどうかを選択できると仮定します(したがって、±10項目)。これは、たとえば-1, 0, +1
によって制御される場合があります。
これは、表示するアイテムが十分にない場合に前後にスクロールしないクラスを構築し、ユーザーが現在どのページにあるかを自己保存するために、おそらく多くの作業です。
それで何かありますか?
私は以前にこれを解決しました。ジェネリックコレクションをページのリスト(リストでもある)に分割する静的なgetPagesメソッドを作成しました。以下のコードを提供しました。
public static <T> List<List<T>> getPages(Collection<T> c, Integer pageSize) {
if (c == null)
return Collections.emptyList();
List<T> list = new ArrayList<T>(c);
if (pageSize == null || pageSize <= 0 || pageSize > list.size())
pageSize = list.size();
int numPages = (int) Math.ceil((double)list.size() / (double)pageSize);
List<List<T>> pages = new ArrayList<List<T>>(numPages);
for (int pageNum = 0; pageNum < numPages;)
pages.add(list.subList(pageNum * pageSize, Math.min(++pageNum * pageSize, list.size())));
return pages;
}
新しいリストをまったく作成したくない場合は、マイナーな最適化。
/**
* returns a view (not a new list) of the sourceList for the
* range based on page and pageSize
* @param sourceList
* @param page, page number should start from 1
* @param pageSize
* @return
*/
public static <T> List<T> getPage(List<T> sourceList, int page, int pageSize) {
if(pageSize <= 0 || page <= 0) {
throw new IllegalArgumentException("invalid page size: " + pageSize);
}
int fromIndex = (page - 1) * pageSize;
if(sourceList == null || sourceList.size() < fromIndex){
return Collections.emptyList();
}
// toIndex exclusive
return sourceList.subList(fromIndex, Math.min(fromIndex + pageSize, sourceList.size()));
}