Как добавить в макет динамически с несколькими RelativeLayout.LayoutParams

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

название

SetsXReps

[][][][][] ---> массив текстовых просмотров

[][][][][] ---> массив флажков

Количество текстовых представлений и флажков зависит от элемента в адаптере, поэтому мне нужно создать эту часть динамически. У меня возникают проблемы с динамическим добавлением этих элементов в мою относительную схему, которую я частично определяю в своем XML. Вот мой класс фрагмента, за которым следует мой xml для пользовательского элемента списка. Идентификатор для макета - list_item_exercise_in_workout. У меня есть код для добавления строки textviews, но я сталкиваюсь с проблемами при добавлении флажков. Ниже я прокомментировал код, который я пытался добавить, но он не работает. Проблема исходит от второго RelativeLayout.LayoutParams и от того, как я пытаюсь добавить в строку вторую строку. Заранее спасибо, я очень ценю любую помощь, которая мне оказывается.

 public class WorkoutFragment extends Fragment
{
    public static final String EXTRA_ALREADYCREATED_ID = "alreadyCreated";

    private ExAdapter adapter;
    private ListView listView;
    private ArrayList<Set> sets;
    private Workout w;

    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        UUID workoutId = (UUID) getArguments().getSerializable(EXTRA_ALREADYCREATED_ID);
        w = WorkoutMASTER.get(getActivity()).getWorkout(workoutId);
        sets = w.getSets();
    }

    public View onCreateView(LayoutInflater inflater, ViewGroup parent,Bundle savedInstanceState)
    {
        View v = inflater.inflate(R.layout.fragment_workout, parent, false);
        listView = (ListView) v.findViewById(R.id.listWorkout);

        adapter = new ExAdapter(getActivity(), R.layout.fragment_workout, R.id.listWorkout, sets);
        listView.setAdapter(adapter);

        return v;
    }
    public static WorkoutFragment newInstance(UUID workoutId)
    {
        Bundle args = new Bundle();
        args.putSerializable(EXTRA_ALREADYCREATED_ID, workoutId);
        WorkoutFragment fragment = new WorkoutFragment();
        fragment.setArguments(args);

        return fragment;
    }
    private class ExAdapter extends ArrayAdapter<Set>
    {
        public ExAdapter(Context c, int resource, int textViewResourceId, ArrayList<Set> sets ) {
            super(c, 0, sets);
        }
        public View getView(final int position, View convertView, ViewGroup parent)
        {
            //if we werent given a view, inflate one
            if(convertView == null)
            {
                convertView = getActivity().getLayoutInflater().inflate(R.layout.list_item_exercise_in_workout, null);
            }
            Set s = getItem(position);

            RelativeLayout container = (RelativeLayout) convertView.findViewById(R.id.relativeLayoutEx);

           TextView name = (TextView) convertView.findViewById(R.id.exName);
            name.setText(s.getName());
            TextView setsReps = (TextView) convertView.findViewById(R.id.setsXreps);
            setsReps.setText(s.getSets() + "X" + s.getReps());

            CheckBox[] checkBoxes = new CheckBox[s.getSetsInt()];
            EditText[] weightBoxes = new EditText[s.getSetsInt()];
            //initialize weightBoxes's text to the inputted weight
            for(int i = 0; i < weightBoxes.length+1; i++)
            {
                weightBoxes[i] = new EditText(getActivity());
                weightBoxes[i].setText(s.getWeight());
                weightBoxes[i].setId(i);

                checkBoxes[i] = new CheckBox(getActivity());

                RelativeLayout.LayoutParams params = new RelativeLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT,
                        ViewGroup.LayoutParams.WRAP_CONTENT);
                RelativeLayout.LayoutParams params2 = new RelativeLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT,
                        ViewGroup.LayoutParams.WRAP_CONTENT);

                //statement here to add the edit text's horizontally
                if(i==0)
                params.addRule(RelativeLayout.ALIGN_PARENT_LEFT, RelativeLayout.TRUE);
                else
                 params.addRule(RelativeLayout.RIGHT_OF, i-1);

                params.leftMargin = 107;

                //params2.addRule(RelativeLayout.BELOW, i);
                //params2.leftMargin = 107;

                container.addView(weightBoxes[i], params);
                //container.addView(checkBoxes[i], params2);
            }
            return convertView;
        }
    }
}

XML:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/relativeLayoutEx"
   >
    <TextView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:textAppearance="?android:attr/textAppearanceMedium"
    android:text="Name"
    android:id="@+id/exName"
    android:layout_alignParentTop="true"
    android:layout_alignParentLeft="true"
    android:layout_alignParentStart="true" />

<TextView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:textAppearance="?android:attr/textAppearanceMedium"
    android:text="SetsXReps"
    android:id="@+id/setsXreps"
    android:layout_below="@id/exName"
    android:layout_alignParentLeft="true"
   />

<Button
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="New Button"
    android:id="@+id/button2"
    android:layout_below="@+id/setsXreps"
    android:layout_alignParentLeft="true"
    android:layout_alignParentStart="true"
    android:layout_marginTop="112dp" />

1 ответ

Решение

Вы действительно можете дать ListView несколько пользовательских макетов, так что вам не нужно добавлять их динамически.

Для этого вам нужно переопределить ваш адаптер getItemViewType а также getViewTypeCount метод.

getViewTypeCount просто нужно вернуть целое число == количество различных макетов, которые вы будете иметь.

getItemViewType занимает позицию, и вы можете оценить элемент в этой позиции и вернуть другой int в зависимости от типа объекта или параметров, которые вам нужно оценить.

Затем в getView, ты можешь позвонить getItemViewType для этой позиции создайте переключатель или блок if, чтобы загрузить соответствующий тип представления, а затем вуаля, у вас есть разные макеты XML, вместо того, чтобы пытаться построить их все по отдельности.

Другие вопросы по тегам