Я использую в своем списке функцию получения файла csv. Я уже связал это со своим Arrayadapter. У меня есть внутри моего xml для списка 3 текстовых представлений для csv и флажка. Для каждой строки из csv будет создан флажок. Я не буду сохранять состояния флажков, если щелкнуть, и перезвонить им после обновления, закрытия и т. д.
`Это мой единственный пункт в списке
<CheckBox
android:id = "@+id/cbSomeCheckbox"
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:layout_alignParentLeft = "true"
android:layout_marginBottom = "8dp"
android:layout_marginLeft = "8dp"
android:layout_marginStart = "8dp"
android:layout_marginTop = "8dp"
app:layout_constraintBottom_toBottomOf = "parent"
app:layout_constraintStart_toStartOf = "parent"
app:layout_constraintTop_toTopOf = "parent" />
//the 3 textviews are for my csv file
<TextView
android:id = "@+id/name"
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:layout_marginBottom = "8dp"
android:layout_marginEnd = "8dp"
android:layout_marginLeft = "8dp"
android:layout_marginRight = "8dp"
android:layout_marginStart = "8dp"
android:layout_marginTop = "8dp"
android:text = "LVL"
android:textSize = "18sp"
app:layout_constraintBottom_toBottomOf = "parent"
app:layout_constraintEnd_toStartOf = "@+id/score"
app:layout_constraintStart_toEndOf = "@+id/cbSomeCheckbox"
app:layout_constraintTop_toTopOf = "parent" />
<TextView
android:id = "@+id/score"
android:layout_width = "wrap_content"
android:layout_height = "16dp"
android:layout_marginBottom = "8dp"
android:layout_marginEnd = "8dp"
android:layout_marginRight = "8dp"
android:layout_marginTop = "8dp"
android:text = "TextView"
app:layout_constraintBottom_toBottomOf = "parent"
app:layout_constraintEnd_toStartOf = "@+id/tvSomeText"
app:layout_constraintTop_toTopOf = "parent"
app:layout_constraintVertical_bias = "0.499" />
<TextView
android:id = "@+id/tvSomeText"
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:layout_marginBottom = "8dp"
android:layout_marginEnd = "8dp"
android:layout_marginRight = "8dp"
android:layout_marginTop = "8dp"
android:text = "TextView"
app:layout_constraintBottom_toBottomOf = "parent"
app:layout_constraintEnd_toEndOf = "parent"
app:layout_constraintTop_toTopOf = "parent" />
Это мой ArrayAdapter
package com.example.customlist;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.CheckBox;
import android.widget.TextView;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
public class ItemArrayAdapter extends ArrayAdapter<String[]> {
private List<String[]> scoreList = new ArrayList<String[]>();
static class ItemViewHolder {
TextView name;
TextView score;
}
public ItemArrayAdapter(Context context, int resource) {
super(context, resource);
}
public void add(String[] object) {
scoreList.add(object);
super.add(object);
}
@Override
public int getCount() {
return this.scoreList.size();
}
@Override
public String[] getItem(int position) {
return this.scoreList.get(position);
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View row = convertView;
ItemViewHolder viewHolder;
if (row == null){
LayoutInflater inflater = (LayoutInflater) this.getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
row = inflater.inflate(R.layout.single_list_item, parent, false);
viewHolder = new ItemViewHolder();
viewHolder.name = (TextView) row.findViewById(R.id.name);
viewHolder.score = (TextView) row.findViewById(R.id.score);
row.setTag(viewHolder);
} else {
viewHolder = (ItemViewHolder) row.getTag();
}
String[] stat = getItem(position);
viewHolder.name.setText(stat[0]);
viewHolder.score.setText(stat[1]);
return row;
}
}
Извините, я добавил изображение и изменил свой вопрос.
Вы можете создать ArrayList для сохранения позиции или идентификатора csv (элемента списка), который проверяется пользователем. (Если у вас есть какие-либо проблемы, свяжитесь со мной: [email protected]) Например:
holder.cbDelete.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
if (null != mCallBack) {
if (isChecked){
mListIDChecked.add(id);
}else if (mListIDChecked.contains(id)){
mListIDChecked.remove(id);
}
}
}
});
if ( mListIDChecked.contains(id)){
holder.cbDelete.setChecked(true);
}else{
holder.cbDelete.setChecked(false);
}
не понял твой вопрос