Я сталкиваюсь с трудностями при работе с использованием recyclerview и Gridview.Проблема заключается в том, что при успешной загрузке моего приложения на следующей странице (следующие данные) представление повторной обработки всегда возвращается наверх.
Я хочу, чтобы представление повторной проверки начиналось с последнего индекса.
Пример: загрузка первой страницы10 пунктов, после успешного заимствования на следующей странице представление перерабатывающего устройства начинает прокручиваться с пункта 8.
Чтобы решить эту проблему, я попробовал все решение в StackOverflow, но ничего не получилось.
recyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() {
@Override
public void onScrollStateChanged(@NonNull RecyclerView recyclerView, int newState) {
super.onScrollStateChanged(recyclerView, newState);
if (newState == AbsListView.OnScrollListener.SCROLL_STATE_TOUCH_SCROLL) {
isScrolling = true;
}
}
@Override
public void onScrolled(@NonNull RecyclerView recyclerView, int dx, int dy) {
super.onScrolled(recyclerView, dx, dy);
currentItems = manager.getChildCount();
totalItems = manager.getItemCount();
scrolloutItems = manager.findFirstVisibleItemPosition();
if (isScrolling && (currentItems + scrolloutItems == totalItems)) {
isScrolling = false;
getdata(pagetoken);
//getdata(pagetoken);
Toast.makeText(MainActivity.this, "Scrolling", Toast.LENGTH_SHORT).show();
}
}
});
}
public void getdata() {
progress.setVisibility(View.VISIBLE);
ApiClient.getApis().getblogdata(Constants.key).enqueue(new Callback<MyModel>() {
@Override
public void onResponse(Call<MyModel> call, Response<MyModel> response) {
if (response.isSuccessful()) {
assert response.body() != null;
arraylist.addAll(response.body().items);
}
if (arraylist != null) {
adapter = new Data_Adapter(MainActivity.this, arraylist);
recyclerView.setAdapter(adapter);
}
pagetoken = response.body().nextPageToken;
swiprefresh.setRefreshing(false);
progress.setVisibility(View.GONE);
}
@Override
public void onFailure(Call<MyModel> call, Throwable t) {
Toast.makeText(MainActivity.this, "\t \t Connection Error : \n Please Check Your Internet Connection", Toast.LENGTH_SHORT).show();
}
});
}
public void getdata(String pageToken) {
ApiClient.getApis().getblogdata(Constants.key, pageToken).enqueue(new Callback<MyModel>() {
@Override
public void onResponse(Call<MyModel> call, Response<MyModel> response) {
if (response.isSuccessful()) {
assert response.body() != null;
arraylist.addAll(response.body().items);
}
if (arraylist != null) {
adapter = new Data_Adapter(MainActivity.this, arraylist);
recyclerView.setAdapter(adapter);
}
if (response.body().nextPageToken != null) {
pagetoken = response.body().nextPageToken;
}
Log.d("retro", "" + arraylist.size());
swiprefresh.setRefreshing(false);
}
@Override
public void onFailure(Call<MyModel> call, Throwable t) {
Toast.makeText(MainActivity.this, "Connection Error : \n Please Check Your Internet Connection", Toast.LENGTH_SHORT).show();
}
});
}