Как добавить в макет динамически с несколькими 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, вместо того, чтобы пытаться построить их все по отдельности.