• 自定义列表对话框


    main.xml文件

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:gravity="center_horizontal"
        android:orientation="vertical" >
    
        <EditText
            android:id="@+id/show"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:editable="false"
            android:textSize="11pt" />
    
        <Button
            android:id="@+id/bn"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="请选择您最擅长的种族" />
    
    </LinearLayout>


    row.xml文件

    <?xml version="1.0" encoding="UTF-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:orientation="horizontal" >
    
        <!-- 定义一个ImageView,用于作为列表项的一部分。 -->
    
        <ImageView
            android:id="@+id/header"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:paddingLeft="10dp" />
        <!-- 定义一个TextView,用于作为列表项的一部分。 -->
    
        <TextView
            android:id="@+id/name"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:gravity="center_vertical"
            android:paddingLeft="10dp"
            android:textColor="#ff000066"
            android:textSize="16dp" />
    
    </LinearLayout>

    java文件

    public class CustomListDialog extends Activity {
        final int LIST_DIALOG = 0x113;
        // 定义3个列表项的名称
        private String[] names = new String[] { "神族", "虫族", "人族" };
        // 定义3个列表项对应的图标
        private int[] imageIds = new int[] { R.drawable.p, R.drawable.z,
                R.drawable.t };
    
        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.main);
            Button bn = (Button) findViewById(R.id.bn);
            // 为按钮绑定事件监听器
            bn.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View source) {
                    // 显示对话框
                    showDialog(LIST_DIALOG);
                }
            });
        }
    
        // 重写onCreateDialog方法创建对话框
        @Override
        public Dialog onCreateDialog(int id, Bundle state) {
            // 判断需要生成哪种类型的对话框
            switch (id) {
            case LIST_DIALOG: 
                Builder b = new AlertDialog.Builder(this);
                // 设置对话框的图标
                b.setIcon(R.drawable.tools);
                // 设置对话框的标题
                b.setTitle("单选列表对话框");
                // 创建一个List对象,List对象的元素是Map
                List<Map<String, Object>> listItems = new ArrayList<Map<String, Object>>();
                for (int i = 0; i < names.length; i++) {
                    Map<String, Object> listItem = new HashMap<String, Object>();
                    listItem.put("header", imageIds[i]);
                    listItem.put("personName", names[i]);
                    listItems.add(listItem);
                }
                // 创建一个SimpleAdapter
                SimpleAdapter simpleAdapter = new SimpleAdapter(this, listItems,
                        R.layout.row, new String[] { "personName", "header" },
                        new int[] { R.id.name, R.id.header });
    
                // 为对话框设置多个列表
                b.setAdapter(simpleAdapter
                // 为列表项的单击事件设置监听器
                        , new DialogInterface.OnClickListener() {
                            @Override
                            public void onClick(DialogInterface dialog, int which) {
                                TextView show = (TextView) findViewById(R.id.show);
                                // which代表哪个列表项被单击了
                                show.setText("您最擅长的种族为:" + names[which]);
    
                            }
                        });
                // 创建对话框
                return b.create();
            }
            return null;
        }
    }

    效果图

  • 相关阅读:
    PHP单引号和双引号的区别
    thinkphp实现导航高亮的简单方法
    js选中当前菜单后高亮显示的导航条
    Dubbo新版管控台
    把本人基于Dubbo的毕业设计分享粗来~
    Windows 查看端口占用情况
    GitLab 环境搭建【CentOS7】
    【非专业前端】vue+element+webpack
    【非专业前端】使用vue2.5.17+element2.4.5
    ElasticSearch6.3.2------入门
  • 原文地址:https://www.cnblogs.com/android-zcq/p/3280984.html
Copyright © 2020-2023  润新知