ExpandableListView

如何在ExpandableListView中显示图片

小樊
83
2024-10-14 13:39:06
栏目: 编程语言

在ExpandableListView中显示图片需要以下几个步骤:

  1. 首先,确保你已经将所需的图片添加到项目的资源文件夹(res/drawable)中。

  2. 创建一个自定义的布局文件,例如list_item_image.xml,用于定义列表项的布局。在这个布局文件中,添加ImageView和其他需要的控件。例如:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="horizontal">

    <ImageView
        android:id="@+id/imageView"
        android:layout_width="48dp"
        android:layout_height="48dp"
        android:src="@drawable/your_image" />

    <TextView
        android:id="@+id/textView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="16dp"
        android:text="Your Text" />

</LinearLayout>

请确保将your_image替换为实际的图片资源名称。

  1. 创建一个自定义的适配器类,继承自BaseAdapter。在这个类中,重写getView()方法,用于设置列表项的布局和数据。例如:
public class ImageExpandableListAdapter extends BaseAdapter {

    private Context context;
    private List<String> groupHeaders;
    private List<List<String>> childItems;
    private int resource;

    public ImageExpandableListAdapter(Context context, List<String> groupHeaders, List<List<String>> childItems, int resource) {
        this.context = context;
        this.groupHeaders = groupHeaders;
        this.childItems = childItems;
        this.resource = resource;
    }

    @Override
    public int getGroupCount() {
        return groupHeaders.size();
    }

    @Override
    public int getChildrenCount(int groupPosition) {
        return childItems.get(groupPosition).size();
    }

    @Override
    public Object getGroup(int groupPosition) {
        return groupHeaders.get(groupPosition);
    }

    @Override
    public Object getChild(int groupPosition, int childPosition) {
        return childItems.get(groupPosition).get(childPosition);
    }

    @Override
    public long getGroupId(int groupPosition) {
        return groupPosition;
    }

    @Override
    public long getChildId(int groupPosition, int childPosition) {
        return childPosition;
    }

    @Override
    public boolean hasStableIds() {
        return false;
    }

    @Override
    public View getGroupView(int groupPosition, boolean isExpanded, View convertView, ViewGroup parent) {
        String headerTitle = (String) getGroup(groupPosition);
        if (convertView == null) {
            LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            convertView = inflater.inflate(resource, null);
        }

        TextView textView = (TextView) convertView.findViewById(R.id.textView);
        textView.setText(headerTitle);

        return convertView;
    }

    @Override
    public View getChildView(int groupPosition, int childPosition, boolean isLastChild, View convertView, ViewGroup parent) {
        final String childText = (String) getChild(groupPosition, childPosition);
        if (convertView == null) {
            LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            convertView = inflater.inflate(resource, null);
        }

        ImageView imageView = (ImageView) convertView.findViewById(R.id.imageView);
        imageView.setImageResource(R.drawable.your_image); // 设置图片资源

        return convertView;
    }

    @Override
    public boolean isChildSelectable(int groupPosition, int childPosition) {
        return true;
    }
}

请确保将your_image替换为实际的图片资源名称。

  1. 在你的Activity或Fragment中,设置ExpandableListView的适配器为自定义的适配器,并传入相应的参数。例如:
ExpandableListView expandableListView = findViewById(R.id.expandableListView);
List<String> groupHeaders = new ArrayList<>();
List<List<String>> childItems = new ArrayList<>();

// 添加分组数据和子项数据
// ...

ImageExpandableListAdapter adapter = new ImageExpandableListAdapter(this, groupHeaders, childItems, R.layout.list_item_image);
expandableListView.setAdapter(adapter);

现在,你应该可以在ExpandableListView中看到图片了。如果需要根据数据动态更改图片,可以在适配器类的getView()方法中设置ImageView的图片资源。

0
看了该问题的人还看了