У меня есть recyclerview, который содержит cardview, внутри cardview у меня есть куча переключателей и 2 средства выбора времени и 2 textview. Мне нужно динамически добавлять новые карты в recyclerview при нажатии кнопки. Я реализовал адаптацию для этого, и при нажатии кнопки элемент добавляется в список.

Проблема в том, что когда я добавляю карту и меняю время или выбираю переключатель, затем снова нажимаю кнопку добавления, старая карта обновляется, и dta, который я ввел, исчез, как я могу его получить

И у меня есть скриншоты, как это работает

Пожалуйста, помогите мне это исправить, спасибо

Вот мой код:

код адаптера

@Override
    public LabourWorkAdapter.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
    View v = LayoutInflater.from(parent.getContext()).inflate(R.layout.labour_work_card, parent, false);
    return new LabourWorkAdapter.ViewHolder(v);
    }

    @Override
    public void onBindViewHolder(final LabourWorkAdapter.ViewHolder holder, final int position) {
    final LabourWorkList listItem = labourWork.get(position);

    holder.fromTime.setText(listItem.getFromDate());
    holder.toTime.setText(listItem.getToDate());

    //        holder.cDay.setText(listItem.getFullDay());
    holder.fromTimePicker.setOnClickListener(new View.OnClickListener() {
    int hour_x = 0;
    int minute_x = 0;

    @Override
    public void onClick(View view) {
    TimePickerDialog mTimePicker = new TimePickerDialog(context, new TimePickerDialog.OnTimeSetListener() {
    @Override
    public void onTimeSet(TimePicker timePicker, int selectedHour, int selectedMinute) {
    String hr, mn, timeMode = "AM";
    if (selectedHour > 12){
    selectedHour = selectedHour-12;
    timeMode = "PM";
    }
    if (selectedHour < 10){
    hr = "0"+selectedHour;
    }else{
    hr = ""+selectedHour;
    }
    if (selectedMinute < 10){
    mn = "0"+selectedMinute;
    }else{
    mn = ""+selectedMinute;
    }
    holder.fromTime.setText( hr + ":" + mn + timeMode);
    }
    }, hour_x, minute_x, false);
    mTimePicker.setTitle("Select Time");
    mTimePicker.show();
    }
    });

    holder.toTimePicker.setOnClickListener(new View.OnClickListener() {
    int hour_x = 0;
    int minute_x = 0;

    @Override
    public void onClick(View view) {
    TimePickerDialog mTimePicker = new TimePickerDialog(context, new TimePickerDialog.OnTimeSetListener() {
    @Override
    public void onTimeSet(TimePicker timePicker, int selectedHour, int selectedMinute) {
    String hr, mn, timeMode = "AM";
    if (selectedHour > 12){
    selectedHour = selectedHour-12;
    timeMode = "PM";
    }
    if (selectedHour < 10){
    hr = "0"+selectedHour;
    }else{
    hr = ""+selectedHour;
    }
    if (selectedMinute < 10){
    mn = "0"+selectedMinute;
    }else{
    mn = ""+selectedMinute;
    }
    holder.toTime.setText( hr + ":" + mn + timeMode);
    }
    }, hour_x, minute_x, false);
    mTimePicker.setTitle("Select Time");
    mTimePicker.show();
    }
    });

    holder.delete.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View view) {
    labourWork.remove(position);
    notifyItemRemoved(position);
    notifyDataSetChanged();
    notifyItemRangeChanged(position, labourWork.size());
    CharSequence text = "Position "+ position;
    int duration = Toast.LENGTH_SHORT;

    Toast toast = Toast.makeText(context, text, duration);
    toast.show();
    }
    });
    //        holder.labourWorkDay


    }



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


    public class ViewHolder extends RecyclerView.ViewHolder {
    TextView fromTime, toTime;
    Button fromTimePicker, toTimePicker;
    ImageView delete;

    public ViewHolder(View itemView) {
    super(itemView);

    fromTime = (TextView) itemView.findViewById(R.id.fromTime);
    toTime = (TextView) itemView.findViewById(R.id.toTime);
    fromTimePicker = (Button) itemView.findViewById(R.id.fromTimePicker);
    toTimePicker = (Button) itemView.findViewById(R.id.toTimePicker);
    delete = (ImageView) itemView.findViewById(R.id.deleteLabourCard);
    }
    }

прослушиватель нажатия кнопки

rId.setText(tempLabourId);

recyclerView = (RecyclerView) findViewById(R.id.workDetailsRecycler);
recyclerView.setHasFixedSize(true);
recyclerView.setLayoutManager(new LinearLayoutManager(this));

workList = new ArrayList<>();

addItem = (FloatingActionButton) findViewById(R.id.addLabor);

addItem.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
addToRecyclerView(sPosition);
sPosition++;
}
});


public void addToRecyclerView(int position){
LabourWorkList listItem = new LabourWorkList(position);
recyclerView.findViewHolderForAdapterPosition(position);
workList.add(listItem);

adapter = new LabourWorkAdapter(workList, LabourWork.this);
recyclerView.setAdapter(adapter);
adapter.notifyDataSetChanged();
}
1
rakcode 24 Июн 2017 в 17:45
1
Покажите минимальный воспроизводимый пример. В частности, в вашем коде есть ошибка компилятора, потому что нет классов. Также исправьте форматирование.
 – 
Code-Apprentice
24 Июн 2017 в 17:51
Вы также можете посмотреть на адаптеры различные методы, которые соответствуют вашим требованиям, вместо того, чтобы использовать только notifyDataSetChanged(). developer.android.com/reference/android/support/ v7 / widget /…
 – 
Raghunandan
24 Июн 2017 в 18:00

1 ответ

Лучший ответ

Recyclerview обновляется каждый раз, потому что вы настраиваете адаптер каждый раз, когда добавляете новый элемент и вызываете метод notifyDataSetChanged.

Чтобы решить эту проблему, установите адаптер только один раз, затем добавьте новый элемент в список и вызовите

adapter.notifyItemRangeInserted(lastListSize, newListSize);
1
Patrick R 1 Июл 2017 в 13:32