这次的高级界面组件学习我要讲的是对话框。在平时的APP使用中,我们经常会在点击某个按钮的时候,可能会弹出一个长方形或类似长方形的框框,提示我们进行选择,并且会伴随着两个按钮——“确定”和“取消”,这就是我们最常见的对话框了。

用的最多的对话框应该就是AlertDialog了,但是我们往往会希望自定义对话框的布局,所以今天我介绍一下AlertDialog和它的多种展示模式,此外就是说一下自己是怎么自定义Alertdialog的。

一、AlertDialog之显示提示消息的对话框

1.首先是新建一个工程,在activity_main.xml定义四个点击按钮,并且在MainActivity中为这四个按钮设置监听,其中findViewById和onClickListener()的相关代码省略。

<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@color/color_home_bottom_weitao">

    <Button
        android:id="@+id/btn_alert_dialog_1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:padding="5dp"
        android:layout_centerInParent="true"
        android:text="@string/alert_dialog_simple"
        android:textColor="@color/white" />

    <Button
        android:id="@+id/btn_alert_dialog_2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/btn_alert_dialog_1"
        android:padding="5dp"
        android:layout_centerInParent="true"
        android:text="@string/alert_dialog_list"
        android:textColor="@color/white" />

    <Button
        android:id="@+id/btn_alert_dialog_3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/btn_alert_dialog_2"
        android:padding="5dp"
        android:layout_centerInParent="true"
        android:text="@string/alert_dialog_radio"
        android:textColor="@color/white" />


    <Button
        android:id="@+id/btn_alert_dialog_4"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/btn_alert_dialog_3"
        android:padding="5dp"
        android:layout_centerInParent="true"
        android:text="@string/alert_dialog_checkbox"
        android:textColor="@color/white" />

</RelativeLayout>




2. 把四个按钮实例化并且设置了监听之后,在onClick()方法中为四个按钮的点击事件调用相对应的方法:

(1)首先是简单提示对话框具体代码和实现,这里我们设置两个Button——“确定”和“取消”,也就是setPositiveButton和setNegativeButton,如果只是需要一个Button的话那就直接设置一个Button即可。具体的实现代码如下(simple()方法是点击简单对话框的相应按钮调用的方法):

private void simple(View source) {
    AlertDialog.Builder builder = new AlertDialog.Builder(getActivity())
            // 设置对话框的标题
            .setTitle("Do you like Android?")
                    // 设置对话框的标题左侧的icon
            .setIcon(R.drawable.home_icon)
                    // 设置对话框的提示内容
            .setMessage("If you like ,please select true \nelse cancel");
    // 添加确定按钮
    setPositiveButton(builder);
    // 添加取消按钮
    setNegativeButton(builder).create().show();

}




(2)同理写出简单列表对话框弹出的代码,其实和简单对话框没有太大的区别,只是定义了一个String类型的数组用来填充列表项,然后把setMessage()方法换成setItems()方法,具体方法的代码如下:




private String[] items = new String[]{"Android","JAVA","C++"};




private void simpleList(View source) {
    AlertDialog.Builder builder = new AlertDialog.Builder(getActivity())
            // 设置对话框的标题
            .setTitle("What is your favorite?")
            // 设置对话框的标题左侧的icon
            .setIcon(R.drawable.home_icon)
            // 设置对话框的提示内容
            .setItems(items, new DialogInterface.OnClickListener() {
                @Override
                public void onClick(DialogInterface dialog, int which) {
                    Toast.makeText(getActivity(), "You choosed" + items[which], Toast.LENGTH_SHORT).show();
                }
            });
    // 添加确定按钮
    setPositiveButton(builder);
    // 添加取消按钮
    setNegativeButton(builder).create().show();
}


(3)同理写出单选列表项对话框和多选列表项对话框,前者将简单对话框的setMessage()变成setSingleChoiceItem(),后者则是变成setMultiChoiceItems(),主要代码如下:




// 设置对话框默认被选中的行,这里是“1”,对应第二行
.setSingleChoiceItems(items, 1, new DialogInterface.OnClickListener() {

    @Override
    public void onClick(DialogInterface dialog, int which) {
        tvShow.setText("You choosed " + items[which]);
    }
});




// 设置对话框列表项是否被选中
.setMultiChoiceItems(items, new boolean[]{false, true, false}, null);

android ConstraintLayout 控件与另一个控件垂直居中_sed

                               

android ConstraintLayout 控件与另一个控件垂直居中_移动开发_02

上面算是对AlertDialog的一些简单实现,往往我们会想做更加高逼格的对话框。在AlertDialog中有一个setView方法,我们可以直接通过下列代码实现我们想要的对话框的显示:

private void customList(View source) {
    LinearLayout prompt = (LinearLayout) getActivity().getLayoutInflater()
    .inflate(R.layout.prompt_layout, null);
    AlertDialog.Builder builder = new AlertDialog.Builder(getActivity())
            // 设置对话框的标题
            .setTitle("The AlertDialog By Myself")
                    // 设置对话框的标题左侧的icon
            .setIcon(R.drawable.home_icon)
                    // 设置对话框列表项是否被选中
            .setView(prompt);
    // 添加确定按钮
    setPositiveButton(builder);
    // 添加取消按钮
    setNegativeButton(builder).create().show();
}


如上图所示,红色框框内的部分就是对应的prompt_layout,有兴趣额的小伙伴可以自己尝试各种风格的对话框,这里也就不多说了,以上就是我对于AlertDialog的一些学习和了解,有不对的地方欢迎指正。