比较两个ListView的父项和子项,并改变图片索引
创始人
2024-12-14 08:30:21
0

以下是一个示例代码,演示了如何比较两个ListView的父项和子项,并改变图片索引:

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import android.app.Activity;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseExpandableListAdapter;
import android.widget.ExpandableListView;
import android.widget.ImageView;
import android.widget.TextView;

public class MainActivity extends Activity {

    private ExpandableListView listView1, listView2;
    private List listDataHeader1, listDataHeader2;
    private Map> listDataChild1, listDataChild2;
    private MyExpandableListAdapter adapter1, adapter2;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        // 初始化数据
        initData();

        // 初始化ListView
        listView1 = (ExpandableListView) findViewById(R.id.listView1);
        listView2 = (ExpandableListView) findViewById(R.id.listView2);

        // 初始化适配器
        adapter1 = new MyExpandableListAdapter(listDataHeader1, listDataChild1);
        adapter2 = new MyExpandableListAdapter(listDataHeader2, listDataChild2);

        // 设置适配器
        listView1.setAdapter(adapter1);
        listView2.setAdapter(adapter2);

        // 处理父项点击事件
        listView1.setOnGroupClickListener(new ExpandableListView.OnGroupClickListener() {
            @Override
            public boolean onGroupClick(ExpandableListView parent, View v, int groupPosition, long id) {
                // 获取当前父项的图片
                ImageView imageView = (ImageView) v.findViewById(R.id.imageView);
                int imageIndex = (int) imageView.getTag();

                // 获取对应的子项列表
                List childList = listDataChild1.get(listDataHeader1.get(groupPosition));

                // 比较父项和子项的数量
                if (childList.size() > imageIndex) {
                    // 子项数量大于图片索引,修改图片索引
                    imageIndex++;
                } else {
                    // 子项数量小于等于图片索引,重置图片索引
                    imageIndex = 0;
                }

                // 更新图片索引
                imageView.setTag(imageIndex);
                imageView.setImageResource(getImageResource(imageIndex));

                return false;
            }
        });

        // 处理子项点击事件
        listView1.setOnChildClickListener(new ExpandableListView.OnChildClickListener() {
            @Override
            public boolean onChildClick(ExpandableListView parent, View v, int groupPosition, int childPosition, long id) {
                // 与处理父项点击事件类似,对应修改子项的图片索引
                List childList = listDataChild1.get(listDataHeader1.get(groupPosition));
                ImageView imageView = (ImageView) v.findViewById(R.id.imageView);
                int imageIndex = (int) imageView.getTag();

                if (childList.size() > imageIndex) {
                    imageIndex++;
                } else {
                    imageIndex = 0;
                }

                imageView.setTag(imageIndex);
                imageView.setImageResource(getImageResource(imageIndex));

                return false;
            }
        });
    }

    // 初始化数据
    private void initData() {
        listDataHeader1 = new ArrayList();
        listDataHeader2 = new ArrayList();
        listDataChild1 = new HashMap>();
        listDataChild2 = new HashMap>();

        // 添加父项1
        listDataHeader1.add("Parent 1");
        // 添加父项1的子项列表
        List childList1 = new ArrayList();
        childList1.add("Child 1");
        childList1.add("Child 2");
        childList1.add("Child 3");
        listDataChild1.put(listDataHeader1.get(0), childList1);

        // 添加父项2
        listDataHeader1.add("Parent 2");
        // 添加父项2的子项列表
        List childList2 = new ArrayList();
        childList2.add("Child 1");
        childList2.add("Child 2");
        childList2.add("Child 3");
        listDataChild1.put(listDataHeader1.get(1), childList2);

        // 添加父项3
        listDataHeader2.add("Parent 1");
        // 添加父项3的子项列表
        List childList3 = new ArrayList();
        childList3.add("Child

相关内容

热门资讯

透视辅助!aapoker有什么... 透视辅助!aapoker有什么规律吗,aapoker能玩原来是有挂(详细有猫腻教程)辅助器中分为三种...
透视辅助!红龙扑克竟然是真的有... 透视辅助!红龙扑克竟然是真的有挂,红龙扑克果然是真的有挂(详细辅助工具教程);无聊就玩这款真的有辅助...
透视辅助!微扑克网页版辅助,(... 透视辅助!微扑克网页版辅助,(微扑克总结)其实有挂(详细wpk透视辅助教程)1)wpk透视辅助辅助挂...
一分钟了解!!红龙poker正... 一分钟了解!!红龙poker正规吗,红龙扑克真是存在有挂(详细辅助器教程);小薇(透视辅助)致您一封...
5分钟了解!微扑克透视辅助脚本... 5分钟了解!微扑克透视辅助脚本,微扑克规律一直真的是有挂(详细wpk透视辅助教程)所有人都在同一条线...
透视辅助!aaPOKER原来是... 透视辅助!aaPOKER原来是真的有挂,aapoker辅助确实存在有挂(详细外卦挂教程);1、实时a...
透视辅助!微扑克ai辅助器苹果... 透视辅助!微扑克ai辅助器苹果版,(微扑克代码)本来是真的有挂(详细ai辅助器苹果版教程)是一款可以...
盘点一款!!德扑计算胜率软件,... 盘点一款!!德扑计算胜率软件,德扑之星模拟器竟然是真的有挂(详细线上房间教程);一、AI软件牌型概率...
透视辅助!wPK透视辅助软件,... 透视辅助!wPK透视辅助软件,WPK线上其实真的是有挂(详细透明挂教程)1、打开软件启动之后找到中间...
透视辅助!wPk果然有挂,wp... 透视辅助!wPk果然有挂,wpk机制好像存在有挂(详细透明挂教程)1、进入游戏-大厅左侧-新手福利-...