Библиотека подкачки возвращает изначально пустой список - PullRequest
0 голосов
/ 05 декабря 2018

Я использую библиотеку подкачки для разбиения на страницы списка элементов, которые я получаю с моего сервера.Первоначально, когда мой фрагмент загружен, он возвращает пустой список.Но после изменения фрагментов и возврата к этому фрагменту я вижу загруженный список.После отладки я увидел, что данные на самом деле выбираются, но мой фрагмент был передан пустой список.

ItemDataSource:

@Override
public void loadInitial(@NonNull LoadInitialParams<Integer> params, @NonNull LoadInitialCallback<Integer, Item> callback) {
    apiService.getItems(OFFSET)
    .enqueue(new Callback<ItemWrapper>() {
        @Override
        public void onResponse(@NonNull Call<ItemWrapper> call,@NonNull Response<ItemWrapper> response) {
            callback.onResult(response.body().getItems(), null, OFFSET + 25);
        }

        @Override
        public void onFailure(@NonNull Call<ItemWrapper> call,@NonNull Throwable t) {
            t.printStackTrace();
        }
    });
}

@Override
public void loadBefore(@NonNull LoadParams<Integer> params, @NonNull LoadCallback<Integer, Item> callback) {

}

@Override
public void loadAfter(@NonNull LoadParams<Integer> params, @NonNull LoadCallback<Integer, Item> callback) {
    apiService.getItems(params.key)
            .enqueue(new Callback<ItemWrapper>() {
                @Override
                public void onResponse(@NonNull Call<ItemWrapper> call,@NonNull Response<ItemWrapper> response) {
                    Integer key = response.body().getItems().isEmpty() ? null : params.key + 25;
                    callback.onResult(response.body().getItems(), key);
                }

                @Override
                public void onFailure(@NonNull Call<ItemWrapper> call,@NonNull Throwable t) {
                    t.printStackTrace();
                }
            });
}

ItemDataSourceFactory:

@Override
public DataSource create() {
    ItemDataSource itemDataSource = new ItemDataSource();
    itemLiveDataSource.postValue(itemDataSource);
    return itemDataSource;
}

public MutableLiveData<ItemDataSource> getItemLiveDataSource() {
    return itemLiveDataSource;
}

ItemViewModel:

private LiveData<ItemDataSource> liveDataSource;
private LiveData<PagedList<Item>> itemPagedList;

private ItemViewModel(Application application) {
    ItemDataSourceFactory factory = new ItemDataSourceFactory();
    liveDataSource = factory.getItemLiveDataSource();

    PagedList.Config config = (new PagedList.Config.Builder())
                .setEnablePlaceholders(false)
                .setPageSize(ItemDataSource.LIMIT).build();

    itemPagedList = (new LivePagedListBuilder(factory, config)).build();
}

public LiveData<PagedList<Item>> getItems() {
    return itemPagedList;
}

Фрагмент:

ItemViewModel itemViewModel = ViewModelProviders.of(this).get(ItemViewModel.class);
itemViewModel.getItems.observe(this, items -> {
    adapter.submitList(items);
})

Ответы [ 3 ]

0 голосов
/ 14 декабря 2018

Не уверен на 100%, но я думаю, это потому, что вы выполняете асинхронный запрос.попробуйте изменить его, чтобы он работал синхронно для loadInitial(), например, request.execute()

0 голосов
/ 20 июня 2019

Ясин Айди прав.loadinitial() вызывает немедленно в том же потоке, где создается PagedList.Поскольку ваш API асинхронный, метод запускается пустым в первый раз

0 голосов
/ 13 декабря 2018

Однажды у меня тоже была эта проблема, и я до сих пор не могу понять, почему она не работает для некоторых фрагментов.Решение, которое я нашел, хотя это скорее быстрое схематичное исправление, заключается в двойной загрузке фрагмента.

...