(Android) Загрузка данных в RecyclerView при прокрутке вниз экрана - PullRequest
0 голосов
/ 04 января 2019

Я хочу создать приложение с использованием Marvel API и Retrofit. Когда я получаю ответ, в качестве основного ограничения API отображаются только первые 10 или 20 результатов. Как я могу сделать так, чтобы он загружал больше данных при прокрутке вниз экрана?

MainActivity.java

public class MainActivity extends AppCompatActivity {

    private MyAdapter myAdapter;
    private RecyclerView myRecyclerView;

    private RequestManager glide;

    Date today = new Date();
    int ts = 1;

    private static final String API_KEY = "c05b97de2b2e597428a65451d0df12a7";
    private static final String HASH = "9e36e240cadffa03ecaa206887b23335";

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        this.glide = glide;

//Create a handler for the RetrofitInstance interface//

        GetData service = RetrofitClient.getRetrofitInstance().create(GetData.class);

        Call<MarvelResponse> call = service.getAllCharacters(Long.valueOf(ts), API_KEY, HASH);

        call.enqueue(new Callback<MarvelResponse>() {

            @Override

//Handle a successful response//

            public void onResponse(Call<MarvelResponse> call, Response<MarvelResponse> response) {
                loadDataList(response.body());
            }

            @Override

//Handle execution failures//

            public void onFailure(Call<MarvelResponse> call, Throwable throwable) {

//If the request fails, then display the following toast//

                Toast.makeText(MainActivity.this, "Unable to load users", Toast.LENGTH_SHORT).show();
            }
        });

    }

//Display the retrieved data as a list//

    private void loadDataList(MarvelResponse usersList) {

//Get a reference to the RecyclerView//

        myRecyclerView = findViewById(R.id.myRecyclerView);
        myAdapter = new MyAdapter(usersList.getData().getResults());

//Use a LinearLayoutManager with default vertical orientation//

        RecyclerView.LayoutManager layoutManager = new LinearLayoutManager(MainActivity.this);
        myRecyclerView.setLayoutManager(layoutManager);

//Set the Adapter to the RecyclerView//

        myRecyclerView.setAdapter(myAdapter);
    }

}

MyAdapter.java

public class MyAdapter extends RecyclerView.Adapter<MyAdapter.CustomViewHolder> {

    private static final String TAG = MyAdapter.class.getSimpleName();
    private List<MarvelResults> dataList;

    public MyAdapter(List<MarvelResults> dataList){
        this.dataList=dataList;
    }

    class CustomViewHolder extends RecyclerView.ViewHolder{
        //get a reference to the Views in our layout
        public final View myView;

        TextView textCharacter;
        TextView textDescription;
        ImageView imageView;
        LinearLayout linearLayout;

        CustomViewHolder(View itemView){
            super(itemView);
            myView = itemView;

            textCharacter = myView.findViewById(R.id.character);
            textDescription = myView.findViewById(R.id.description);
            imageView = myView.findViewById(R.id.imageView);

        }
    }

    //construct a RecyclerView.ViewHolder
    public CustomViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        LayoutInflater layoutInflater = LayoutInflater.from(parent.getContext());
        View view = layoutInflater.inflate(R.layout.row_layout, parent, false);
        return new CustomViewHolder(view);
    }

    @Override

    //set the data

    public void onBindViewHolder(CustomViewHolder holder, int position) {

        holder.textCharacter.setText(dataList.get(position).getName());
        holder.textDescription.setText(dataList.get(position).getDescription());

        Uri uri = Uri.parse(dataList.get(position).getThumbnail());
        Glide.with(holder.imageView.getContext()).load(uri).into(holder.imageView);
        Log.d(TAG, "onBindViewHolder() called with: holder = [" + uri + "], position = [" + position + "]");

    }

    //calculate the item count for the RecylerView//

    @Override
    public int getItemCount() {
        return dataList.size();
    }

}

Извините, я новичок.

Заранее спасибо!

Вот ссылка для документации Marvel Api.

1 Ответ

0 голосов
/ 04 января 2019

Я думаю, вам нужно поиграть с параметрами offset и limit в вашем запросе. Например, вы можете увеличивать offset на 20 в каждом запросе и устанавливать limit на 20, начиная с offset 0 и увеличивая его каждый раз, когда достигается дно. Таким образом, каждый запрос должен вернуть следующие 20 предметов. Взгляните сюда: https://developer.marvel.com/documentation/apiresults

Чтобы определить, когда достигнуто дно на RecyclerView, вы можете использовать addOnScrollListener что-то вроде этого:

private int firstVisibleItem, visibleItemCount, totalItemCount;
private boolean loading = true;
private int offset = 0;

recyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() {

        @Override
        public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
            super.onScrolled(recyclerView, dx, dy);

            visibleItemCount = recyclerView.getChildCount();
            totalItemCount = layoutManager.getItemCount();
            firstVisibleItem = layoutManager.findFirstVisibleItemPosition();

             if (loading) {
                if (totalItemCount > previousTotal) {
                    loading = false;
                    previousTotal = totalItemCount;
                }
            }
            if (!loading && (visibleItemCount + firstVisibleItem)
                    >= totalItemCount) {
                // End has been reached

                offset += 20;
                // send request to load more videos here

                loading = true;
            }
        }

    });
...