alertDialog使用详解

article/2025/10/31 18:56:07

1、设置标题、内容、图标
2、设置按钮
3、使用列表、单选和多选。适配
4、设定弹窗大小
5、自定义view
6、设置点击周边灰色区域弹窗不消失
7、自定义view圆角消除周边白块

1、设置标题、内容、图标

AlertDialog alertDialog = new AlertDialog.Builder(this)        
.setTitle("标题")        
.setMessage("内容")        
.setIcon(R.mipmap.ic_launcher)//图标        
.create();//创建
alertDialog.show();显示

2、设置按钮:

AlertDialog alertDialog = new AlertDialog.Builder(this)              
.setPositiveButton("确定", new DialogInterface.OnClickListener() {            
@Override            
public void onClick(DialogInterface dialogInterface, int i) {                
Toast.makeText(getBaseContext(),"点击了确定按钮",Toast.LENGTH_SHORT).show();            
}        
})        
.setNegativeButton("取消", new DialogInterface.OnClickListener() {            
@Override            
public void onClick(DialogInterface dialogInterface, int i) {                
Toast.makeText(getBaseContext(),"点击了取消按钮",Toast.LENGTH_SHORT).show();            
}        
})        
.setNeutralButton("普通按钮", new DialogInterface.OnClickListener() {            
@Override            
public void onClick(DialogInterface dialogInterface, int i) {                
Toast.makeText(getBaseContext(),"点击了普通按钮",Toast.LENGTH_SHORT).show();            
}        
})        
.create();        
alertDialog.show();

** 3、使用列表、单选和多选**

注:使用列表时不能再设置弹窗的内容

final String[] items = new String[]{"A", "B", "C", "D"};
final boolean[] booleans = new boolean[]{false, false, false, false};
final AlertDialog alertDialog = new AlertDialog.Builder(this)        
//自定义列表        
.setItems(items, new DialogInterface.OnClickListener() {            
@Override            
public void onClick(DialogInterface dialogInterface, int i) {                
Toast.makeText(getBaseContext(), "点击了:" + items[i], Toast.LENGTH_SHORT).show();            
}        
})        
.create();
alertDialog.show();

单选框

final String[] items = new String[]{"A", "B", "C", "D"};
final boolean[] booleans = new boolean[]{false, false, false, false};
final AlertDialog alertDialog = new AlertDialog.Builder(this) 
.setSingleChoiceItems(items, 0, new DialogInterface.OnClickListener() {            
@Override            
public void onClick(DialogInterface dialogInterface, int i) {                
Toast.makeText(getBaseContext(), "选择了:" + items[i], Toast.LENGTH_SHORT).show();            
}        
}) 
.create();
alertDialog.show();

多选框

final String[] items = new String[]{"A", "B", "C", "D"};
final boolean[] booleans = new boolean[]{false, false, false, false};
final AlertDialog alertDialog = new AlertDialog.Builder(this) 
.setMultiChoiceItems(items, booleans, new DialogInterface.OnMultiChoiceClickListener() {            
@Override            
public void onClick(DialogInterface dialogInterface, int i, boolean b) {                
booleans[i] = b;            
}        
})
.create();
alertDialog.show();

适配:添加了适配之后列表的对话框就会被放在R.layout.item_demo这个布局中,就是一个想要的自定义view布局就行

final String[] items = new String[]{"A", "B", "C", "D"};
final boolean[] booleans = new boolean[]{false, false, false, false};
final AlertDialog alertDialog = new AlertDialog.Builder(this) 
.setAdapter(new ArrayAdapter<>(MainActivity.this, R.layout.item_demo, R.id.demoView, items),                
new DialogInterface.OnClickListener() {                    
@Override                    
public void onClick(DialogInterface dialogInterface, int i) {                        
Toast.makeText(getBaseContext(), "点的是:" + items[i], Toast.LENGTH_SHORT).show();                    
}                
})        
.create();
alertDialog.show();

4、设定弹窗大小

在java代码中设置弹窗大小:

final AlertDialog alertDialog = new AlertDialog.Builder(this)        
.create();
alertDialog.show();
WindowManager.LayoutParams params = alertDialog.getWindow().getAttributes();
params.width = 900;
params.height = 1100;
alertDialog.getWindow().setAttributes(params);//设置alertDialog的宽高

5、自定义view

示例如图:
在这里插入图片描述
自定义view中布局:
view1文件:

<?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:background="@drawable/textview_border1"    
android:orientation="vertical"    >    
<TextView        
android:layout_width="match_parent"        
android:layout_height="match_parent"        
android:layout_marginTop="13dp"        
android:layout_marginBottom="13dp"        
android:textSize="18dp"        
android:text="温馨提示"        
android:gravity="center_horizontal"        
android:textColor="@color/text_black" />    
<TextView        
android:layout_width="match_parent"        
android:layout_height="match_parent"        
android:paddingLeft="15dp"        
android:paddingRight="15dp"        
android:layout_marginBottom="13dp"        
android:textSize="16dp"        
android:textColor="@color/text_black"        
android:gravity="left"        
android:text="根据相关规定,xxxxxxxxxxxxxxxxxxx"/>    
<TextView        
android:id="@+id/view"        
android:layout_width="120dp"        
android:layout_height="40dp"        
android:layout_marginTop="13dp"        
android:layout_marginBottom="13dp"        
android:textSize="17dp"        
android:layout_gravity="center"        
android:gravity="center"        
android:background="@drawable/textview_border"        
android:text="好的"/>
</LinearLayout>

其中有两个引用文件 textview_border,textview_border1,用来设置圆角边框
文件如下:

textview_border:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" 
android:shape="rectangle" >         
<solid android:color="#C9A05B"/>
<!-- 设置边框颜色和大小 -->   
<stroke android:width="1dip" android:color="#C9A05B"/>    
<!-- 设置四个圆角度数 -->   
<corners        
android:bottomLeftRadius="10px"        
android:bottomRightRadius="10px"        
android:topLeftRadius="10px"        
android:topRightRadius="10px" />    
<!-- 设置一下边距,让空间大一点 -->    
<padding        
android:bottom="5dp"        
android:left="5dp"        
android:right="5dp"        
android:top="5dp" />
</shape>

textview_border1:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" 
android:shape="rectangle" >         
<solid android:color="#e6ebf0" />         
<stroke android:width="1px" android:color="#e6ebf0"/>    
<corners        
android:bottomLeftRadius="10px"        
android:bottomRightRadius="10px"        
android:topLeftRadius="10px"        
android:topRightRadius="10px" />    
<padding        
android:bottom="5dp"        
android:left="5dp"        
android:right="5dp"        
android:top="5dp" />
</shape>

activity中代码:

View view1 = View.inflate(this,R.layout.view1,null);
final AlertDialog alertDialog = new AlertDialog.Builder(this)        
.setView(view1)        
.create();        
alertDialog.show();
final TextView tv = view1.findViewById(R.id.view);
//自定义
viewtv.setOnClickListener(new View.OnClickListener() {    
@Override    
public void onClick(View view) {        
Toast.makeText(getBaseContext(),"内容:"+tv.getText().toString(),Toast.LENGTH_SHORT).show();        
alertDialog.dismiss();        
return;    
}
});

6、设置点击周边灰色区域弹窗不消失

这个只需要一个属性:

View view1 = View.inflate(this,R.layout.view1,null);
final AlertDialog alertDialog = new AlertDialog.Builder(this)        
.setView(view1)
.setCancelable(false)//设置点击周边灰色区域不消失
.create();        
alertDialog.show();

7、自定义view圆角消除周边白块

在alertDialog加载自定义view时,如果我们设置了view的边框圆角度数的话,就会在四个角形成白块,
解决办法:

//在alertDialog:create()-->show()之后加上下面一句就行
alertDialog.getWindow().setBackgroundDrawable(new BitmapDrawable());//消除白块

http://chatgpt.dhexx.cn/article/dv18GnSo.shtml

相关文章

AlertDialog6种使用方法

AlertDialog 1.AlertDialog的6种创建模式 1.1setMessage 1&#xff09;Java代码 //1.创建构造器AlertDialog.Builder buildernew AlertDialog.Builder(this);//2.设置参数builder.setTitle("弹窗提示").setIcon(R.mipmap.boy).setMessage("选择你的性别&#xf…

Android的AlertDialog详解(7种方式)

需要注意的两点&#xff1a; 1. 在setIcon时&#xff0c;需要使用setTitle方法&#xff0c;否则icon不会显示 2.如果同时调用setMessage 和 setItems(或者setSingleChoiceItems setMultiChoiceItems)函数会导致dialog没有显示内容 AlertDialog的构造方法全部是Protected的&am…

AlertDialog(对话框)详解

AlertDialog可以在当前的界面上显示一个对话框&#xff0c;这个对话框是置顶于所有界面元素之上的&#xff0c;能够屏蔽掉其他控件的交互能力&#xff0c;因此AlertDialog一般是用于提示一些非常重要的内容或者警告信息。 1.创建AlertDialog 首先&#xff0c;我们来了解一下Al…

andoid小游戏开发

apk下载&#xff1a;apk下载&#xff1a;http://download.csdn.net/detail/xiangqiao123/3805861 这是去年用android写的一个小游戏&#xff0c; 我感觉不错&#xff0c;是从事android小游戏开发入门不错的案例&#xff0c; 今天就把它拿出来和大家共享一下。 程序截图&a…

android 2D 游戏的开发的方法

最近学习了android 2D 应用的开发&#xff0c;拿来和大家分享一下&#xff0c;学习2D 开发前我们先了解一下SurfaceView的使用以及贴图技术的使用&#xff0c;最后呢&#xff0c;是一个简单的2的游戏的实现。 1.SurfaceView的一些用法 提供了一个专门的绘图渲染的图形嵌入在一个…

Android手机游戏开发入门教程

Android手机游戏开发入门教程 视频欣赏地址 来自 “ ITPUB博客 ” &#xff0c;链接&#xff1a;http://blog.itpub.net/29597077/viewspace-1139520/&#xff0c;如需转载&#xff0c;请注明出处&#xff0c;否则将追究法律责任。 转载于:http://blog.itpub.net/29597077/vie…

Android 游戏开发速递

作者 / Greg Hartrell, Head of Product Management, Games on Android & Google Play 在今年 3 月举行的 Google 游戏开发者峰会上&#xff0c;我们分享了 Google 为帮助游戏开发者而持续投入研发的数种新工具和服务。这些新工具和服务能够帮助游戏开发者更轻松地查看其 A…

游戏开发相关

游戏开发—图形图像篇 游戏开发--开篇  记得我第一次玩的PC game 是KKND(绝地风暴)&#xff0c;当时的游戏平台是DOS&#xff0c;我只是觉得很好玩&#xff0c;经常和几个小学同学一起厮杀到12点。可是现在回忆起来&#xff0c;KKND无论是从智能设计还是在游戏画面与操作上都…

android小游戏制作基础,View实现游戏布局和方法

在使用android的朋友们&#xff0c;相信大家对android的游戏不陌生吧&#xff0c;像愤怒的小鸟&#xff0c;植物大战僵尸等等优秀的游戏&#xff0c;给我们带来了很好的用户体验 下面我来教大家一点android游戏开发的一点基础&#xff0c;大家可以参照这个方法框架来设计一些像…

android游戏开发的架构

&#xfeff;&#xfeff; 在编写游戏代码之前&#xff0c;必须要仔细地理顺思路&#xff0c;清晰地构建出整个游戏的框架。有的开发者经常抱怨说&#xff0c;游戏开发到最后总是千头万绪&#xff0c;一旦出现bug就不知道该如何修改&#xff0c;身心疲惫甚至是痛不欲生。其实不…

用Unity3d开发Android游戏

Unity3d是个强大的游戏引擎&#xff0c;可以很轻松的将游戏发布到Android平台上&#xff0c;今天我就来讲讲如何用Android来开发Android游戏。 首先我们要下载Android SDK&#xff0c;可以在http://developer.android.com/sdk/index.html这里下载到&#xff0c;运行installer安…

Android游戏开发的入门实例

在Android系统上开发游戏是Android开发学习者所向往的&#xff0c;有成就感也有乐趣&#xff0c;还能取得经济上的报酬。那怎样开发Android游戏呢&#xff1f;下面介绍一个简单的入门实例。 一、创建新工程   首先&#xff0c;我们在Eclipse中新建一个名为Movement的工程&…

如何开发手机游戏?

当今社会&#xff0c;手机游戏无非是当下在旅途中打发时间的最便捷的方式。有关数据显示&#xff0c;62% 的智能手机用户在购买智能手机后的一周内安装了游戏。无论你是参加聚会还是度假&#xff0c;或者周末宅在家里&#xff0c;手机都是玩游戏最方便的设备。这也正是手机游戏…

【Android游戏开发详细过程1】Android平台飞机大战游戏APP设计与实现

【Android游戏】Android平台飞机大战游戏APP设计与实现 前言一、界面设计与功能实现1.1 主界面1.2 登录界面1.2 注册界面1.4 菜单界面1.5 设置界面1.6 商店界面1.7 换机界面1.8 游戏界面1.9 欢迎界面1.10 游戏图标 二、数据库设计与实现三、服务器设计与实现四、其他功能实现 前…

datagridview中使用DataGridViewComboBoxColumn

在datagridview中使用自带的DataGridViewComboBoxColumn&#xff0c;加载数据库中的数据&#xff0c;选中和保存所需要的数据 实现效果如图 加载数据库已保存的数 选择自己所需要的数据 具体代码如下 datagridview命名为&#xff1a;dgvDrugList 添加基本列及对应的设…

DataGridView怎样实现添加、删除、上移、下移一行

场景 在Winform中使用DataGridView实现添加一行、删除一行、上移一行、下移一行。 注&#xff1a; 博客主页&#xff1a;https://blog.csdn.net/badao_liumang_qizhi 关注公众号 霸道的程序猿 获取编程相关电子书、教程推送与免费下载。 实现 添加一行 private void Task…

DataGridview获取选中行数

DataGridview获取选中行数 代码&#xff1a; dataGridView1.CurrentRow.Index//获取选中行数使用Messbox.Show()弹窗&#xff1a;

DataGridview动态初始化

DataGridview动态初始化 this.dataGridView1.Rows.Add("参数"&#xff0c;"参数"...");Add&#xff08;&#xff09;方法里面可以根据列数而添加相应个数的参数 例如&#xff1a; 上图的列数有4个&#xff0c;所以如果要将DataGridview控件里面添加…

C# 解决datagridview控件显示大量数据拖拉卡顿问题

问题描述&#xff1a; 由于在使用SQL查询大量的数据并一次显示到dataGridView控件&#xff0c;出现拖拉的时候卡顿。 解决方法&#xff1a; 1.首先分页。 2.其次把显示控件设置双buffer。 解决过程如下&#xff1a; 1.设置dataGridView双buffer代码如下&#xff0c;需要引用…

DataGridView绑定数据库

背景 今天在做C#实验的时候&#xff0c;遇到了一个难题&#xff1a;需要将数据库中的数据在C#的窗体的DataGridView控件中显示出来。当然老师布置这个作业是在之前做了铺垫的&#xff0c;之前做省县区三级查询时&#xff0c;讲过了SampleData和LiteDB的使用&#xff0c;但是我…