Android常用的AlertDialog对话框及自定义对话框

 更新时间:2017年04月05日 10:22:11   作者:甄情  
本文主要介绍了android常用的AlertDialog对话框及自定义对话框的相关知识。具有很好的参考价值。下面跟着小编一起来看下吧

常用的Dialog有确认对话框,单选按钮对话框,多选按钮对话框,复选按钮对话框另外还有自定义的对话框

AlertDialog的常用方法

setTitle:为对话框设置标题

setMessage:为对话框设置内容

setIcon:为对话框设置图标

setItems设置对话框要显示的list

setMultiChoiceItems:一般用于复选框显示

setSingleChoiceItem:,设置单选按钮

setNeutralButton:普通按钮

setPositiveButton:添加确定按钮

setNegativeButton:添加取消按钮

setView:设置自定义样式

下面通过一个实例来了解这些方法

这是运行结果:

MainActivity.class

package com.example.alertdialog; 
import android.R.bool; 
import android.os.Bundle; 
import android.app.Activity; 
import android.app.AlertDialog; 
import android.app.AlertDialog.Builder; 
import android.app.Dialog; 
import android.content.DialogInterface; 
import android.content.pm.LabeledIntent; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.View.OnClickListener; 
import android.widget.Button; 
import android.widget.Toast; 
public class MainActivity extends Activity implements OnClickListener { 
 private Button button1; 
 private Button button2; 
 private Button button3; 
 private Button button4; 
 private Button button5; 
 private int mark=0; 
 private String item[] = { "学生", "工人", "教师", "农民" }; 
 private String multChoice[]={"旅游","电影","运动","读书"}; 
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
 super.onCreate(savedInstanceState); 
 setContentView(R.layout.activity_main); 
 button1 = (Button) findViewById(R.id.btn_button1); 
 button2 = (Button) findViewById(R.id.btn_button2); 
 button3 = (Button) findViewById(R.id.btn_button3); 
 button4 = (Button) findViewById(R.id.btn_button4); 
 button5 = (Button) findViewById(R.id.btn_button5); 
 button1.setOnClickListener(this); 
 button2.setOnClickListener(this); 
 button3.setOnClickListener(this); 
 button4.setOnClickListener(this); 
 button5.setOnClickListener(this); 
 } 
 @Override 
 public void onClick(View v) { 
 // TODO Auto-generated method stub 
 switch (v.getId()) { 
 //确认对话框 
 case R.id.btn_button1: { 
 AlertDialog.Builder builder = new Builder(this); 
 builder.setIcon(R.drawable.ic_launcher); 
 builder.setTitle("确认对话框"); 
 builder.setMessage("确认退出?"); 
 builder.setPositiveButton("确定", 
  new DialogInterface.OnClickListener() { 
  @Override 
  public void onClick(DialogInterface dialog, int which) { 
  // TODO Auto-generated method stub 
  Toast.makeText(MainActivity.this, "你单击了确定按钮", 
   Toast.LENGTH_SHORT).show(); 
  } 
  }); 
 builder.setNegativeButton("取消", 
  new DialogInterface.OnClickListener() { 
  @Override 
  public void onClick(DialogInterface dialog, int which) { 
  // TODO Auto-generated method stub 
  Toast.makeText(MainActivity.this, "你单击了取消按钮", 
   Toast.LENGTH_SHORT).show(); 
  } 
  }); 
 builder.create(); 
 builder.show(); 
 break; 
 } 
 //列表对话框 
 case R.id.btn_button2: { 
 AlertDialog.Builder builder = new Builder(this); 
 builder.setIcon(R.drawable.ic_launcher); 
 builder.setTitle("职业"); 
 builder.setItems(item, new DialogInterface.OnClickListener() { 
 @Override 
 public void onClick(DialogInterface dialog, int which) { 
  // TODO Auto-generated method stub 
  Toast.makeText(MainActivity.this, "你的职业是" + item[which], 
  Toast.LENGTH_SHORT).show(); 
 } 
 }); 
 builder.create(); 
 builder.show(); 
 break; 
 } 
 //多选对话框 
 case R.id.btn_button3: { 
 final boolean choose[]=new boolean[multChoice.length]; 
 AlertDialog.Builder builder = new Builder(this); 
 builder.setIcon(R.drawable.ic_launcher); 
 builder.setTitle("爱好"); 
 builder.setMultiChoiceItems(multChoice, null, new DialogInterface.OnMultiChoiceClickListener() { 
 @Override 
 public void onClick(DialogInterface dialog, int which, boolean isChecked) { 
  // TODO Auto-generated method stub 
  choose[which]=isChecked; 
 } 
 }); 
 builder.setPositiveButton("确认", new DialogInterface.OnClickListener() { 
 @Override 
 public void onClick(DialogInterface dialog, int which) { 
  // TODO Auto-generated method stub 
  String result=""; 
  for(int i=0;i<multChoice.length;i++){ 
  if(choose[i]){ 
  result+=multChoice[i]+" "; 
  } 
  } 
  Toast.makeText(MainActivity.this, "你的爱好["+result+"]", Toast.LENGTH_SHORT).show(); 
 } 
 }); 
 builder.create(); 
 builder.show(); 
 break; 
 } 
 //单选对话框 
 case R.id.btn_button4: { 
 mark=0; 
 AlertDialog.Builder builder = new Builder(this); 
 builder.setIcon(R.drawable.ic_launcher); 
 builder.setTitle("职业"); 
 builder.setSingleChoiceItems(item, 0, new DialogInterface.OnClickListener() { 
 @Override 
 public void onClick(DialogInterface dialog, int which) { 
  // TODO Auto-generated method stub 
  mark=which; 
 } 
 }); 
 builder.setPositiveButton("确定", 
  new DialogInterface.OnClickListener() { 
  @Override 
  public void onClick(DialogInterface dialog, int which) { 
  // TODO Auto-generated method stub 
  Toast.makeText(MainActivity.this, "你的职业:"+item[mark], Toast.LENGTH_SHORT).show(); 
  } 
  }); 
 builder.create(); 
 builder.show(); 
 break; 
 } 
 //自定义对话框 
 case R.id.btn_button5: { 
 LayoutInflater inflater=LayoutInflater.from(this); 
 View view=inflater.inflate(R.layout.item, null); 
 AlertDialog.Builder builder = new Builder(this); 
 builder.setIcon(R.drawable.ic_launcher); 
 builder.setTitle("自定义对话框"); 
 builder.setView(view); 
 builder.setNeutralButton("普通按钮", new DialogInterface.OnClickListener() { 
 @Override 
 public void onClick(DialogInterface dialog, int which) { 
  // TODO Auto-generated method stub 
  Toast.makeText(MainActivity.this,"我是自定义的对话框哦",Toast.LENGTH_SHORT).show(); 
 } 
 }); 
 builder.create(); 
 builder.show(); 
 break; 
 } 
 } 
 } 
} 

布局文件

activity_main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 xmlns:tools="http://schemas.android.com/tools" 
 android:layout_width="match_parent" 
 android:layout_height="match_parent" 
android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" 
 tools:context=".MainActivity" > 
 <LinearLayout 
 android:layout_width="fill_parent" 
 android:layout_height="wrap_content" 
 android:orientation="vertical" > 
 <Button 
 android:id="@+id/btn_button1" 
 android:layout_width="fill_parent" 
 android:layout_height="wrap_content" 
 android:text="确认对话框" /> 
 <Button 
 android:id="@+id/btn_button2" 
 android:layout_width="fill_parent" 
 android:layout_height="wrap_content" 
 android:text="列表对话框" /> 
 <Button 
 android:id="@+id/btn_button3" 
 android:layout_width="fill_parent" 
 android:layout_height="wrap_content" 
 android:text="多选对话框" /> 
 <Button 
 android:id="@+id/btn_button4" 
 android:layout_width="fill_parent" 
 android:layout_height="wrap_content" 
 android:text="单选对话框" /> 
 <Button 
 android:id="@+id/btn_button5" 
 android:layout_width="fill_parent" 
 android:layout_height="wrap_content" 
 android:text="自定义对话框" /> 
 </LinearLayout> 
</RelativeLayout> 

自定义的对话框布局文件

item.xml

<?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="match_parent" 
 android:orientation="vertical" > 
 <ImageView 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:scaleType="fitCenter" 
 android:src="@drawable/icon" 
 /> 
 <TextView 
 android:layout_width="fill_parent" 
 android:layout_height="wrap_content" 
 android:text="我是自定义的对话框" 
 /> 
</LinearLayout> 

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!

相关文章

  • Android基于ViewFilpper实现文字LED显示效果示例

    Android基于ViewFilpper实现文字LED显示效果示例

    这篇文章主要介绍了Android基于ViewFilpper实现文字LED显示效果,结合完整实例形式分析了Android使用ViewFilpper实现文字LED显示动画效果的相关步骤与实现技巧,需要的朋友可以参考下
    2017-08-08
  • Android拖拽助手ViewDragHelper的创建与使用实例

    Android拖拽助手ViewDragHelper的创建与使用实例

    ViewDragHelper是针对 ViewGroup 中的拖拽和重新定位 views 操作时提供了一系列非常有用的方法和状态追踪,下面这篇文章主要给大家介绍了关于Android拖拽助手ViewDragHelper的创建与使用的相关资料,需要的朋友可以参考下
    2022-05-05
  • Android编程获取APP应用程序基本信息辅助类【APP名称、包名、图标,版本号等】

    Android编程获取APP应用程序基本信息辅助类【APP名称、包名、图标,版本号等】

    这篇文章主要介绍了Android编程获取APP应用程序基本信息辅助类,可实现针对APP名称、包名、图标,版本号等信息的获取功能,需要的朋友可以参考下
    2017-12-12
  • Android Studio 3.0中mipmap-anydpi-v26是什么东东

    Android Studio 3.0中mipmap-anydpi-v26是什么东东

    在Android Studio 3.0中一旦我们创建了一个项目,一个名为mipmap-anydpi-v26自动创建的文件夹在res文件夹下。它究竟能干什么?为什么我们需要这个?我们在开发时该如何利用它,下面通过本文给大家介绍下
    2017-12-12
  • Android仿支付宝支付从底部弹窗效果

    Android仿支付宝支付从底部弹窗效果

    这篇文章主要为大家详细介绍了Android仿支付宝选择支付方式,实现支付宝付款方式,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • Android使用MediaRecorder实现录音及播放

    Android使用MediaRecorder实现录音及播放

    这篇文章主要为大家详细介绍了Android使用MediaRecorder实现录音及播放,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-02-02
  • Android仿淘宝商品详情页效果

    Android仿淘宝商品详情页效果

    这篇文章主要为大家详细介绍了Android仿淘宝商品详情页效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-10-10
  • Android重写View并自定义属性实例分析

    Android重写View并自定义属性实例分析

    这篇文章主要介绍了Android重写View并自定义属性的方法,结合实例形式较为详细的分析了Android基于重写View实现自定义属性的相关布局与具体技巧,需要的朋友可以参考下
    2016-02-02
  • JetPack Compose底部导航栏的实现方法详解

    JetPack Compose底部导航栏的实现方法详解

    开发一个新项目,底部导航栏一般是首页的标配,在以前的xml布局中,我们可以很轻松的是用谷歌提供的BottomNavigationView或者自定义来实现底部导航的功能,在Compose中也有也提供了一个类似的控件androidx.compose.material.BottomNavigation
    2022-09-09
  • Android基础之获取LinearLayout的宽高

    Android基础之获取LinearLayout的宽高

    LinearLayout是线性布局控件,它包含的子控件将以横向或竖向的方式排列,按照相对位置来排列所有的widgets或者其他的containers,超过边界时,某些控件将缺失或消失。有的时候,我们需要想获取LinearLayout宽高,下面通过这篇文章来跟着小编一起学习学习吧。
    2016-11-11

最新评论