viewHolder.getAdapterPosition () в адаптере возвращает -1 позицию, и это вызвало IndexOutOfBoundException - PullRequest
0 голосов
/ 27 декабря 2018

Я пытаюсь применить лучшие методы для обработки onclick в адаптере, но у меня проблема IndexOutOfBoundException, когда getAdapterPostition внутри onCreateViewHolder, что не так с моим кодом?

Я уже пытаюсь проверитьно пока не решить.

public class VideoAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder> {

private DataFrontVideo datas;
private Context context;

public VideoAdapter(DataFrontVideo datas, Context context) {
    this.datas = datas;
    this.context = context;
}

@NonNull
@Override
public RecyclerView.ViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int i) {
    View view = LayoutInflater.from(viewGroup.getContext()).inflate(R.layout.item_video,null);
    final ViewHolder viewHolder = new ViewHolder(view);
    view.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            DataVideo video = datas.getContent().get(viewHolder.getAdapterPosition()); // ERROR HERE
            Intent intent = new Intent(context,DetailActivity.class);
            intent.putExtra("datas",video);
            context.startActivity(intent);
        }
    });
    return new ViewHolder(view);
}

@Override
public void onBindViewHolder(@NonNull RecyclerView.ViewHolder viewHolder, int position) {
    DataVideo dataVideo = datas.getContent().get(position);
    ViewHolder vh = (ViewHolder)viewHolder;
    vh.tvTitle.setText(dataVideo.getJudul());
    vh.tvArtis.setText(dataVideo.getAlias());
    vh.tvPrice.setText((dataVideo.getPrice().equals("0")?"Gratis":dataVideo.getPrice()));
    Glide.with(vh.img.getContext()).load(dataVideo.getThumb_pic()).into(vh.img);
}

@Override
public int getItemCount() {
    return (datas == null)? 0 : datas.getContent().size();
}

public class ViewHolder extends RecyclerView.ViewHolder{
    private ImageView img;
    private TextView tvTitle,tvArtis,tvPrice;

    public ViewHolder(@NonNull View itemView) {
        super(itemView);
        img = itemView.findViewById(R.id.imgVideo);
        tvArtis = itemView.findViewById(R.id.tvartis);
        tvTitle = itemView.findViewById(R.id.tvTitle);
        tvPrice = itemView.findViewById(R.id.tvPrice);
    }

}

}

не должно возвращаться -1

Ответы [ 3 ]

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

Переместите свой клик в onBindViewHolder. Здесь он будет работать для клика по заголовку, если вы хотите, чтобы все клики сделали макет для виджета завершенным и внедрили прослушиватель кликов

 @Override
public void onBindViewHolder(@NonNull RecyclerView.ViewHolder viewHolder, int position) {
DataVideo dataVideo = datas.getContent().get(position);
ViewHolder vh = (ViewHolder)viewHolder;
vh.tvTitle.setText(dataVideo.getJudul());
vh.tvArtis.setText(dataVideo.getAlias());
vh.tvPrice.setText((dataVideo.getPrice().equals("0")?"Gratis":dataVideo.getPrice()));
Glide.with(vh.img.getContext()).load(dataVideo.getThumb_pic()).into(vh.img);
 vh.tvTitle.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View view) {

        Intent intent = new Intent(context,DetailActivity.class);
        intent.putExtra("datas",dataVideo );
        context.startActivity(intent);
    }
});
}
0 голосов
/ 27 декабря 2018

Внутри ViewHolder вам нужно применить setOnClickListener и получить позицию предмета при нажатии, используя getAdapterPosition(), как показано ниже

    public class ViewHolder extends RecyclerView.ViewHolder{
        private ImageView img;
        private TextView tvTitle,tvArtis,tvPrice;

        public ViewHolder(@NonNull View itemView) {
            super(itemView);
            img = itemView.findViewById(R.id.imgVideo);
            tvArtis = itemView.findViewById(R.id.tvartis);
            tvTitle = itemView.findViewById(R.id.tvTitle);
            tvPrice = itemView.findViewById(R.id.tvPrice);
            YOUR_VIEW.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    Toast.makeText(mContext,"Position==>> "+getAdapterPosition(),Toast.LENGTH_LONG).show();

                    DataVideo video = datas.getContent().get(viewHolder.getAdapterPosition()); // ERROR HERE
                    Intent intent = new Intent(context,DetailActivity.class);
                    intent.putExtra("datas",video);
                    context.startActivity(intent);

                }
            });
    }
}
0 голосов
/ 27 декабря 2018

На самом деле проблема только в том, что вы регистрируете прослушиватель кликов в своем onCreateViewHolder, что неправильно, вам нужно зарегистрироваться на прослушивателе кликов в вашем onBindViewHolder, как показано ниже

@Override
public void onBindViewHolder(@NonNull RecyclerView.ViewHolder viewHolder, int position) {
    DataVideo dataVideo = datas.getContent().get(position);
    ViewHolder vh = (ViewHolder)viewHolder;
    vh.tvTitle.setText(dataVideo.getJudul());
    vh.tvArtis.setText(dataVideo.getAlias());
    vh.tvPrice.setText((dataVideo.getPrice().equals("0")?"Gratis":dataVideo.getPrice()));
    Glide.with(vh.img.getContext()).load(dataVideo.getThumb_pic()).into(vh.img);
vh.parentView.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {

            Intent intent = new Intent(context,DetailActivity.class);
            intent.putExtra("datas",dataVideo);
            context.startActivity(intent);
        }
    });
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...