После прокрутки Recycler перемещается в первое положение - PullRequest
1 голос
/ 09 июня 2019

Я сталкиваюсь с трудностями при работе с использованием 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();
        }
    });
}
...