Как заполнить представление списка, используя массив в пользовательском адаптере, используя класс модели? - PullRequest
0 голосов
/ 01 октября 2019

Я пытался адаптировать этот учебник кода: https://www.journaldev.com/10416/android-listview-with-custom-adapter-example-tutorial

для моего представления списка, учебник использует пользовательский адаптер и модальный класс. В уроке они используют строки для заполнения строк, мне нужно заполнить строку с помощью массива строк, этот массив строк содержит строку файлов внутри определенной папки. Уже пытаются преобразовать все строки в массив строк, но я получаю эту ошибку:

64: ошибка: не найден подходящий метод для setText (String [])

    viewHolder.txtTitle.setText(dataModel.getFicheros());
                       ^
method TextView.setText(CharSequence) is not applicable
  (argument mismatch; String[] cannot be converted to CharSequence)
method TextView.setText(int) is not applicable
  (argument mismatch; String[] cannot be converted to int)    

CustomAdapter.java: 65: ошибка: не найден подходящий метод для setText (String [])

    viewHolder.txtFecha.setText(dataModel.getFecha());
                       ^
method TextView.setText(CharSequence) is not applicable
  (argument mismatch; String[] cannot be converted to CharSequence)
method TextView.setText(int) is not applicable
  (argument mismatch; String[] cannot be converted to int)

Как я могу заполнить их, используя массив?

Код:

Mainactivy.java

 final File carpeta = new 

     String[] fecha = new String[] { "a", "b", "c" , "b", "c", "b", "c", "b", "c", "b", "c", "b", "c", "b", "c","b", "c" , "b", "c", "b", "c", "b", "c", "b", "c", "b", "c", "b", "c","b", "c" , "b", "c", "b", "c", "b", "c", "b", "c", "b", "c", "b", "c"};

Файл ("/ storage / emulated / 0 / Android / data / cc.openframeworks.androidMultiOFActivitiesExample / files / xml");Список список = новый ArrayList ();

    ficheros = list.toArray(new String[list.size()]);
    listarFicherosPorCarpeta(carpeta);
    listView=(ListView)findViewById(R.id.listview);

    dataModels= new ArrayList<>();

    dataModels.add(new DataModel(ficheros,fecha));
    dataModels.add(new DataModel(ficheros,fecha));
    adapter= new CustomAdapter(dataModels,getApplicationContext());

    listView.setAdapter(adapter);

public void listarFicherosPorCarpeta(final File carpeta) {

    for (final File ficheroEntrada: carpeta.listFiles()) {

        if (ficheroEntrada.isDirectory()) {
            listarFicherosPorCarpeta(ficheroEntrada);
        } else {
            System.out.println(ficheroEntrada.getName());
            list.add(ficheroEntrada.getName());
        }
    }
//          listAdapter.notifyDataSetChanged();
    }

CustomAdapter.java

public class CustomAdapter extends ArrayAdapter<DataModel> {

    private ArrayList<DataModel> dataSet;
    Context mContext;

    // View lookup cache
    private static class ViewHolder {
        TextView txtTitle;
        TextView txtFecha;
    }

    public CustomAdapter(ArrayList<DataModel> data, Context context) {
        super(context, R.layout.rowlayout, data);
        this.dataSet = data;
        this.mContext=context;

    }


    private int lastPosition = -1;

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        // Get the data item for this position
        DataModel dataModel = getItem(position);
        // Check if an existing view is being reused, otherwise inflate the view
        ViewHolder viewHolder; // view lookup cache stored in tag

        final View result;

        if (convertView == null) {

            viewHolder = new ViewHolder();
            LayoutInflater inflater = LayoutInflater.from(getContext());
            convertView = inflater.inflate(R.layout.rowlayout, parent, false);
            viewHolder.txtTitle = (TextView) convertView.findViewById(R.id.listtext);
            viewHolder.txtFecha = (TextView) convertView.findViewById(R.id.fechatxt);

            result=convertView;

            convertView.setTag(viewHolder);
        } else {
            viewHolder = (ViewHolder) convertView.getTag();
            result=convertView;
        }

        Animation animation = AnimationUtils.loadAnimation(mContext, (position > lastPosition) ? R.anim.up_from_bottom : R.anim.down_from_top);
        result.startAnimation(animation);
        lastPosition = position;



        viewHolder.txtTitle.setText(dataModel.getFicheros());
        viewHolder.txtFecha.setText(dataMlodel.getFecha());

        // Return the completed view to render on screen
        return convertView;
    }
}

Datamodel.java

package cc.openframeworks.androidMultiOFActivitiesExample;

public class DataModel {

    String[] ficheros;
    String[] fecha;

    public DataModel(String[] ficheros, String[] fecha) {
        this.ficheros = ficheros;
        this.fecha = fecha;


    }

    public String[] getFicheros() {
        return ficheros;
    }

    public String[] getFecha() {
        return fecha;
    }

}

1 Ответ

0 голосов
/ 01 октября 2019

Строки

viewHolder.txtTitle.setText(dataModel.getFicheros());
viewHolder.txtFecha.setText(dataMlodel.getFecha()); // typo error, it's dataModel.getFecha()

присутствуют в ваших CustomAdapter вызовах getFicheros() и getFecha() из вашего DataModel класса.

Теперь проблема в том, что getFicheros() возвращает String[], к сожалению, ни один метод Android TextView setText() не предназначен для работы с String[] в качестве параметра (естьво всех 5 перегруженных версиях метода setText()).

Следовательно, вы получаете 64: error: no suitable method found for setText(String[]).

Та же проблема существует с вашим getFecha() методом.

...