Android - Расширяемый ListView - используя ViewHolder для оптимизации
У меня есть ListView, где каждая строка представляет собой изображение + текст. Я реализовал этот список как отдельный список, используя ViewHolder для оптимизации прокрутки. Сейчас я пытаюсь использовать тот же визуальный эффект, но на этот раз как часть Expandable ListView. Я сделал это, и хотя визуально это выглядит одинаково, естественно, прокрутка липкая ... Итак, вопрос в следующем:
Как я могу использовать технику ViewHolder в Expandable ListView?
Я предполагаю, что что-то должно быть сделано в методе getChildView (), но я не достаточно опытен с этой техникой, чтобы выяснить детали самостоятельно. Вот Адаптер и дочерний макет. Любая помощь будет оценена !!
public class MyExpandableListAdapter2 extends BaseExpandableListAdapter {
private final SparseArray<Group> groups;
public LayoutInflater inflater;
public Activity activity;
public MyExpandableListAdapter2(Activity act, SparseArray<Group> groups) {
activity = act;
this.groups = groups;
inflater = act.getLayoutInflater();
}
@Override
public Object getChild(int groupPosition, int childPosition) {
return groups.get(groupPosition).children.get(childPosition);
}
@Override
public long getChildId(int groupPosition, int childPosition) {
return 0;
}
@Override
public View getChildView(int groupPosition, final int childPosition,
boolean isLastChild, View convertView, ViewGroup parent) {
final String children = (String) getChild(groupPosition, childPosition);
convertView = inflater.inflate(R.layout.listrow_details2, null);
text = (TextView) convertView.findViewById(R.id.expandable_list_child_view2);
// Complicated code where I create a bitmap programmatically and set
// it as drawable on the TextView along with the appropriate text.
return convertView;
}
@Override
public int getChildrenCount(int groupPosition) {
return groups.get(groupPosition).children.size();
}
@Override
public Object getGroup(int groupPosition) {
return groups.get(groupPosition);
}
@Override
public int getGroupCount() {
return groups.size();
}
@Override
public void onGroupCollapsed(int groupPosition) {
super.onGroupCollapsed(groupPosition);
}
@Override
public void onGroupExpanded(int groupPosition) {
super.onGroupExpanded(groupPosition);
}
@Override
public long getGroupId(int groupPosition) {
return 0;
}
@Override
public View getGroupView(int groupPosition, boolean isExpanded,
View convertView, ViewGroup parent) {
if (convertView == null) {
convertView = inflater.inflate(R.layout.listrow_group2, null);
}
Group group = (Group) getGroup(groupPosition);
((TextView) convertView).setText(group.string);
((TextView) convertView).setCompoundDrawablesWithIntrinsicBounds(R.drawable.ic_launcher, 0, 0, 0);
//((TextView) convertView).setChecked(isExpanded);
return convertView;
}
@Override
public boolean hasStableIds() {
return false;
}
@Override
public boolean isChildSelectable(int groupPosition, int childPosition) {
return true;
}
}
дочерний макет: listrow_details2.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:paddingLeft="40dp" >
<TextView
android:id="@+id/expandable_list_child_view2"
android:clickable="true"
android:background="@layout/transparent_text_selector"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:drawablePadding="5dp"
android:gravity="top|left"
android:text="@string/hello_world"
android:textSize="14sp" >
</TextView>
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="#d3d3d3" />
</LinearLayout>