Android - ListView expansível - usando o ViewHolder para otimização
Eu tenho um ListView onde cada linha é uma imagem + texto. Eu implementei esta lista como uma lista separada usando um ViewHolder para otimizar a rolagem. Agora estou tentando usar o mesmo efeito visual, mas desta vez como parte de um ListView expansível. Eu fiz isso e, embora visualmente pareça o mesmo, naturalmente a rolagem é pegajosa ... Então a pergunta é:
Como posso usar a técnica ViewHolder em um ListView expansível?
Eu imagino que algo deve ser feito dentro do método getChildView (), mas não tenho experiência suficiente com essa técnica para descobrir os detalhes por mim mesmo. Aqui está o adaptador e o layout filho. Qualquer ajuda será muito apreciada !!
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;
}
}
layout filho: 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>