Android AlertDialog对话框详解及实例

 更新时间:2016年12月26日 11:03:11   投稿:lqh  
这篇文章主要介绍了Android AlertDialog对话框详解及实例的相关资料,需要的朋友可以参考下

Android  AlertDialog

关系图如下:

Android主要提供四种对话框:

1:AlertDialog:功能最丰富,实际应用最广的对话框。
2:ProgressDialog:进度条对话框
3:DatePickerDialog:日期选择器对话框
4:TimePickerDialog:时间选择器对话框

创建一个对话框的步骤:

AlertDialog.Builder builder = new AlertDialog.Builder(this)
        // 1:设置对话框标题
        .setTitle("自定义列表项对话框")
            // 2:设置图标
        .setIcon(R.drawable.tools)
            // 3:设置内容
        .setMessage("对话框的测试内容\n第二行内容");
    // 为AlertDialog.Builder添加“确定”按钮
    setPositiveButton(builder);
    // 为AlertDialog.Builder添加“取消”按钮
    setNegativeButton(builder)
        .create()
        .show();

代码区:

main.xml代码区:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:orientation="vertical"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:gravity="center_horizontal">
<!-- 显示一个普通的文本编辑框组件 -->
<EditText 
  android:id="@+id/show"
  android:layout_width="match_parent" 
  android:layout_height="wrap_content" 
  android:editable="false"/>
<!-- 定义一个普通的按钮组件 -->
<Button
  android:layout_width="match_parent" 
  android:layout_height="wrap_content" 
  android:text="简单对话框"
  android:onClick="simple"
  />
<!-- 定义一个普通的按钮组件 -->
<Button
  android:layout_width="match_parent" 
  android:layout_height="wrap_content" 
  android:text="简单列表项对话框"
  android:onClick="simpleList"
  /> 
<!-- 定义一个普通的按钮组件 -->
<Button
  android:layout_width="match_parent" 
  android:layout_height="wrap_content" 
  android:text="单选列表项对话框"
  android:onClick="singleChoice"
  /> 
<!-- 定义一个普通的按钮组件 -->
<Button
  android:layout_width="match_parent" 
  android:layout_height="wrap_content" 
  android:text="多选列表项对话框"
  android:onClick="multiChoice"
  /> 
<!-- 定义一个普通的按钮组件 -->
<Button
  android:layout_width="match_parent" 
  android:layout_height="wrap_content" 
  android:text="自定义列表项对话框"
  android:onClick="customList"
  /> 
<!-- 定义一个普通的按钮组件 -->
<Button
  android:layout_width="match_parent" 
  android:layout_height="wrap_content" 
  android:text="自定义View对话框"
  android:onClick="customView"
  />         
</LinearLayout>

Activity代码区:

public class MainActivity extends Activity {
  TextView show;
  String[] items = new String[] {
      "aserbao", "Android",
      " Java",
      "IOS" };

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    show = (TextView) findViewById(R.id.show);
  }

  public void simple(View source)
  {
    AlertDialog.Builder builder = new AlertDialog.Builder(this)
      // 设置对话框标题
      .setTitle("简单对话框")
      // 设置图标
      .setIcon(R.drawable.tools)
      .setMessage("对话框的测试内容\n第二行内容");
    // 为AlertDialog.Builder添加“确定”按钮
    setPositiveButton(builder);
    // 为AlertDialog.Builder添加“取消”按钮
    setNegativeButton(builder)
      .create()
      .show();
  }

  public void simpleList(View source)
  {
    AlertDialog.Builder builder = new AlertDialog.Builder(this)
        // 设置对话框标题
        .setTitle("简单列表对话框")
            // 设置图标
        .setIcon(R.drawable.tools)
            // 设置简单的列表项内容
        .setItems(items, new OnClickListener()
        {
          @Override
          public void onClick(DialogInterface dialog, int which)
          {
            show.setText("你选中了《" + items[which] + "》");
          }
        });
    // 为AlertDialog.Builder添加“确定”按钮
    setPositiveButton(builder);
    // 为AlertDialog.Builder添加“取消”按钮
    setNegativeButton(builder)
        .create()
        .show();
  }

  public void singleChoice(View source)
  {
    AlertDialog.Builder builder = new AlertDialog.Builder(this)
        // 设置对话框标题
        .setTitle("单选列表项对话框")
            // 设置图标
        .setIcon(R.drawable.tools)
            // 设置单选列表项,默认选中第二项(索引为1)
        .setSingleChoiceItems(items, 1, new OnClickListener()
        {
          @Override
          public void onClick(DialogInterface dialog, int which)
          {
            show.setText("你选中了《" + items[which] + "》");
          }
        });
      // 为AlertDialog.Builder添加“确定”按钮
      setPositiveButton(builder);
      // 为AlertDialog.Builder添加“取消”按钮
      setNegativeButton(builder)
        .create()
        .show();
  }

  public void multiChoice(View source)
  {
    AlertDialog.Builder builder = new AlertDialog.Builder(this)
        // 设置对话框标题
        .setTitle("多选列表项对话框")
            // 设置图标
        .setIcon(R.drawable.tools)
            // 设置多选列表项,设置勾选第2项、第4项
        .setMultiChoiceItems(items
            , new boolean[]{false , true ,false ,true}, null);
    // 为AlertDialog.Builder添加“确定”按钮
    setPositiveButton(builder);
    // 为AlertDialog.Builder添加“取消”按钮
    setNegativeButton(builder)
        .create()
        .show();
  }

  public void customList(View source)
  {
    AlertDialog.Builder builder = new AlertDialog.Builder(this)
        // 设置对话框标题
        .setTitle("自定义列表项对话框")
            // 设置图标
        .setIcon(R.drawable.tools)
            // 设置自定义列表项
        .setAdapter(new ArrayAdapter<String>(this
            , R.layout.array_item
            , items), null);
    // 为AlertDialog.Builder添加“确定”按钮
    setPositiveButton(builder);
    // 为AlertDialog.Builder添加“取消”按钮
    setNegativeButton(builder)
        .create()
        .show();
  }

  public void customView(View source)
  {
    // 装载app\src\main\res\layout\login.xml界面布局文件
    TableLayout loginForm = (TableLayout)getLayoutInflater()
        .inflate( R.layout.login, null);
    new AlertDialog.Builder(this)
        // 设置对话框的图标
        .setIcon(R.drawable.tools)
        // 设置对话框的标题
        .setTitle("自定义View对话框")
        // 设置对话框显示的View对象
        .setView(loginForm)
        // 为对话框设置一个“确定”按钮
        .setPositiveButton("登录", new OnClickListener() {
          @Override
          public void onClick(DialogInterface dialog,
            int which) {
            // 此处可执行登录处理
          }
        })
        // 为对话框设置一个“取消”按钮
        .setNegativeButton("取消", new OnClickListener()
        {
          @Override
          public void onClick(DialogInterface dialog,
                    int which)
          {
            // 取消登录,不做任何事情
          }
        })
        // 创建并显示对话框
        .create()
        .show();
  }


  private AlertDialog.Builder setPositiveButton(
      AlertDialog.Builder builder)
  {
    // 调用setPositiveButton方法添加“确定”按钮
    return builder.setPositiveButton("确定", new OnClickListener()
    {
      @Override
      public void onClick(DialogInterface dialog, int which)
      {
        show.setText("单击了【确定】按钮!");
      }
    });
  }
  private AlertDialog.Builder setNegativeButton(
      AlertDialog.Builder builder)
  {
    // 调用setNegativeButton方法添加“取消”按钮
    return builder.setNegativeButton("取消", new OnClickListener()
    {
      @Override
      public void onClick(DialogInterface dialog, int which)
      {
        show.setText("单击了【取消】按钮!");
      }
    });
  }
}

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

相关文章

  • Android通过Service实现简单的音乐播放

    Android通过Service实现简单的音乐播放

    这篇文章主要介绍了Android通过Service实现简单的音乐播放,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-05-05
  • Android软件自动更新实现代码

    Android软件自动更新实现代码

    这篇文章主要为大家详细介绍了Android软件自动更新实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • Android Studio中一套代码多渠道打包的实现方法

    Android Studio中一套代码多渠道打包的实现方法

    这篇文章主要介绍了Android Studio中一套代码多渠道打包的实现方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2020-05-05
  • Android ViewFlipper用法实例分析

    Android ViewFlipper用法实例分析

    这篇文章主要介绍了Android ViewFlipper用法,结合实例形式分析了ViewFlipper图片操作的相关技巧,需要的朋友可以参考下
    2016-01-01
  • android手机端与PC端使用adb forword通信

    android手机端与PC端使用adb forword通信

    这篇文章主要介绍了android手机端与PC端使用adb forword通信的相关资料,需要的朋友可以参考下
    2017-04-04
  • 详解Android的登录那点事

    详解Android的登录那点事

    本篇为大家介绍的内容包括:1、用户连续多次输错密码,增加验证码验证;2、Android如何通过http请求达到与服务器之间的通讯。内容简单,便于学习。
    2016-12-12
  • android Listview模拟聊天界面

    android Listview模拟聊天界面

    这篇文章主要为大家详细介绍了android Listview模拟聊天界面的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • 一步步实现自定义View之播放暂停控件

    一步步实现自定义View之播放暂停控件

    本文教大家一步步实现自定义View之播放暂停控件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-06-06
  • android SQLite数据库总结

    android SQLite数据库总结

    本文主要介绍了android SQLite数据库的相关知识。具有一定的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • ViewModel中StateFlow和SharedFlow单元测试使用详解

    ViewModel中StateFlow和SharedFlow单元测试使用详解

    这篇文章主要为大家介绍了ViewModel中StateFlow和SharedFlow单元测试使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01

最新评论