androidstudio中dialog是直接创建的 非自定义真对以前的方法!
先看自定义对话框,就是让对话框模样按照自己想要的样式来显示。
开撸!
根据自己的要求布局xml;
<code class="hljs xml has-numbering"><span class="hljs-pi"><?xml version="1.0" encoding="utf-8"?></span> <span class="hljs-tag"><<span class="hljs-title">LinearLayout</span> <span class="hljs-attribute">xmlns:android</span>=<span class="hljs-value">"http://schemas.android.com/apk/res/android"</span> <span class="hljs-attribute">android:layout_width</span>=<span class="hljs-value">"match_parent"</span> <span class="hljs-attribute">android:layout_height</span>=<span class="hljs-value">"wrap_content"</span> <span class="hljs-attribute">android:gravity</span>=<span class="hljs-value">"center_horizontal"</span> <span class="hljs-attribute">android:orientation</span>=<span class="hljs-value">"vertical"</span>></span> <span class="hljs-tag"><<span class="hljs-title">TextView </span> <span class="hljs-attribute">android:layout_width</span>=<span class="hljs-value">"match_parent"</span> <span class="hljs-attribute">android:layout_height</span>=<span class="hljs-value">"5dp"</span> <span class="hljs-attribute">android:background</span>=<span class="hljs-value">"#ff0000"</span>/></span> <span class="hljs-tag"><<span class="hljs-title">TextView </span> <span class="hljs-attribute">android:layout_width</span>=<span class="hljs-value">"200dp"</span> <span class="hljs-attribute">android:layout_height</span>=<span class="hljs-value">"wrap_content"</span> <span class="hljs-attribute">android:paddingTop</span>=<span class="hljs-value">"20dp"</span> <span class="hljs-attribute">android:paddingBottom</span>=<span class="hljs-value">"20dp"</span> <span class="hljs-attribute">android:gravity</span>=<span class="hljs-value">"center"</span> <span class="hljs-attribute">android:textSize</span>=<span class="hljs-value">"16sp"</span> <span class="hljs-attribute">android:textColor</span>=<span class="hljs-value">"#000"</span> <span class="hljs-attribute">android:text</span>=<span class="hljs-value">"您还没有登录,不能邀请好友。是否立即登录邀请好友?"</span>/></span> <span class="hljs-tag"><<span class="hljs-title">TextView </span> <span class="hljs-attribute">android:layout_width</span>=<span class="hljs-value">"match_parent"</span> <span class="hljs-attribute">android:layout_height</span>=<span class="hljs-value">"1px"</span> <span class="hljs-attribute">android:background</span>=<span class="hljs-value">"#969696"</span>/></span> <span class="hljs-tag"><<span class="hljs-title">LinearLayout </span> <span class="hljs-attribute">android:layout_width</span>=<span class="hljs-value">"match_parent"</span> <span class="hljs-attribute">android:layout_height</span>=<span class="hljs-value">"wrap_content"</span> <span class="hljs-attribute">android:layout_gravity</span>=<span class="hljs-value">"center_horizontal"</span> <span class="hljs-attribute">android:orientation</span>=<span class="hljs-value">"horizontal"</span>></span> <span class="hljs-tag"><<span class="hljs-title">TextView </span> <span class="hljs-attribute">android:id</span>=<span class="hljs-value">"@+id/no"</span> <span class="hljs-attribute">android:layout_width</span>=<span class="hljs-value">"0dp"</span> <span class="hljs-attribute">android:layout_height</span>=<span class="hljs-value">"wrap_content"</span> <span class="hljs-attribute">android:layout_weight</span>=<span class="hljs-value">"1"</span> <span class="hljs-attribute">android:text</span>=<span class="hljs-value">"暂不"</span> <span class="hljs-attribute">android:paddingBottom</span>=<span class="hljs-value">"15dp"</span> <span class="hljs-attribute">android:paddingTop</span>=<span class="hljs-value">"15dp"</span> <span class="hljs-attribute">android:gravity</span>=<span class="hljs-value">"center"</span> <span class="hljs-attribute">android:textSize</span>=<span class="hljs-value">"16sp"</span>/></span> <span class="hljs-tag"><<span class="hljs-title">TextView </span> <span class="hljs-attribute">android:layout_width</span>=<span class="hljs-value">"1px"</span> <span class="hljs-attribute">android:layout_height</span>=<span class="hljs-value">"match_parent"</span> <span class="hljs-attribute">android:background</span>=<span class="hljs-value">"#969696"</span>/></span> <span class="hljs-tag"><<span class="hljs-title">TextView </span> <span class="hljs-attribute">android:id</span>=<span class="hljs-value">"@+id/login"</span> <span class="hljs-attribute">android:layout_width</span>=<span class="hljs-value">"0dp"</span> <span class="hljs-attribute">android:layout_height</span>=<span class="hljs-value">"wrap_content"</span> <span class="hljs-attribute">android:layout_weight</span>=<span class="hljs-value">"1"</span> <span class="hljs-attribute">android:text</span>=<span class="hljs-value">"登录"</span> <span class="hljs-attribute">android:paddingBottom</span>=<span class="hljs-value">"15dp"</span> <span class="hljs-attribute">android:paddingTop</span>=<span class="hljs-value">"15dp"</span> <span class="hljs-attribute">android:gravity</span>=<span class="hljs-value">"center"</span> <span class="hljs-attribute">android:textColor</span>=<span class="hljs-value">"#ff00"</span> <span class="hljs-attribute">android:textSize</span>=<span class="hljs-value">"16sp"</span>/></span> <span class="hljs-tag"></<span class="hljs-title">LinearLayout</span>></span> <span class="hljs-tag"></<span class="hljs-title">LinearLayout</span>></span></code>
效果图是这样的:
MainActivity.Java代码:
<code class="hljs java has-numbering"><span class="hljs-keyword">package</span> com.example.lenovo.dialog; <span class="hljs-keyword">import</span> android.app.Activity; <span class="hljs-keyword">import</span> android.app.Dialog; <span class="hljs-keyword">import</span> android.os.Bundle; <span class="hljs-keyword">import</span> android.view.LayoutInflater; <span class="hljs-keyword">import</span> android.view.View; <span class="hljs-keyword">import</span> android.view.WindowManager; <span class="hljs-keyword">import</span> Utils.ToastUtils; <span class="hljs-keyword">public</span> <span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">MainActivity</span> <span class="hljs-keyword">extends</span> <span class="hljs-title">Activity</span> <span class="hljs-keyword">implements</span> <span class="hljs-title">View</span>.<span class="hljs-title">OnClickListener</span>{</span> <span class="hljs-keyword">private</span> Dialog dialog; <span class="hljs-annotation">@Override</span> <span class="hljs-keyword">protected</span> <span class="hljs-keyword">void</span> <span class="hljs-title">onCreate</span>(Bundle savedInstanceState) { <span class="hljs-keyword">super</span>.onCreate(savedInstanceState); setContentView(R.layout.activity_main); findViewById(R.id.button).setOnClickListener(<span class="hljs-keyword">this</span>); } <span class="hljs-annotation">@Override</span> <span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">onClick</span>(View v) { <span class="hljs-keyword">switch</span>(v.getId()){ <span class="hljs-keyword">case</span> R.id.button: <span class="hljs-comment">//创建对话框</span> dialog = <span class="hljs-keyword">new</span> Dialog(<span class="hljs-keyword">this</span>); View view = LayoutInflater.from(<span class="hljs-keyword">this</span>).inflate(R.layout.logding,<span class="hljs-keyword">null</span>); <span class="hljs-comment">//给Dialog中的子view设置事件监听</span> view.findViewById(R.id.no).setOnClickListener(<span class="hljs-keyword">this</span>); view.findViewById(R.id.login).setOnClickListener(<span class="hljs-keyword">this</span>); dialog.setContentView(view); <span class="hljs-comment">//自定义宽高(高度一般不用调整,在xml调整好就可以了,这里我只调整了宽度)</span> WindowManager.LayoutParams params = dialog.getWindow().getAttributes(); params.width = <span class="hljs-number">900</span>; dialog.getWindow().setAttributes(params); <span class="hljs-comment">//show之前设置返回键无效,触摸屏无效</span> dialog.setCancelable(<span class="hljs-keyword">false</span>); <span class="hljs-comment">//显示对话框</span> dialog.show(); <span class="hljs-keyword">break</span>; <span class="hljs-keyword">case</span> R.id.no: dialog.dismiss(); <span class="hljs-keyword">break</span>; <span class="hljs-keyword">case</span> R.id.login: dialog.dismiss(); <span class="hljs-comment">//这里实现业务逻辑</span> ToastUtils.showShort(<span class="hljs-keyword">this</span>,<span class="hljs-string">"登录"</span>); <span class="hljs-keyword">break</span>; } } } </code>
OK
再来看普通的用法(eclipse)
一般对话框:
上图:
代码:
- private void dialog1(){
- AlertDialog.Builder builder=new AlertDialog.Builder(this); //先得到构造器
- builder.setTitle("提示"); //设置标题
- builder.setMessage("是否确认退出?"); //设置内容
- builder.setIcon(R.mipmap.ic_launcher);//设置图标,图片id即可
- builder.setPositiveButton("确定", new DialogInterface.OnClickListener() { //设置确定按钮
- @Override
- public void onClick(DialogInterface dialog, int which) {
- dialog.dismiss(); //关闭dialog
- Toast.makeText(MainActivity.this, "确认" + which, Toast.LENGTH_SHORT).show();
- }
- });
- builder.setNegativeButton("取消", new DialogInterface.OnClickListener() { //设置取消按钮
- @Override
- public void onClick(DialogInterface dialog, int which) {
- dialog.dismiss();
- Toast.makeText(MainActivity.this, "取消" + which, Toast.LENGTH_SHORT).show();
- }
- });
- builder.setNeutralButton("忽略", new DialogInterface.OnClickListener() {//设置忽略按钮
- @Override
- public void onClick(DialogInterface dialog, int which) {
- dialog.dismiss();
- Toast.makeText(MainActivity.this, "忽略" + which, Toast.LENGTH_SHORT).show();
- }
- });
- //参数都设置完成了,创建并显示出来
- builder.create().show();
- }
是不是觉得三个按钮写了三遍响应事件,很繁琐呢?注意:onClick的参数中有一个which,这个是什么意思呢?这个which实际上代表的是一个唯一的int型数值。像上面的setPositiveButton中的which代表的是-1,setNegativeButton中的which代表的是-3,setNeutralButton中的which代表的是-2. 到了这里相信大家已经想到怎么简洁的写法了,只要写一个响应事件,用which参数去区分是那个按钮就可以了!
看简洁的代码2:和上面的效果是一样的!
- private void dialog1_1(){
- //先new出一个监听器,设置好监听
- DialogInterface.OnClickListener dialogOnclicListener=new DialogInterface.OnClickListener(){
- @Override
- public void onClick(DialogInterface dialog, int which) {
- switch(which){
- case Dialog.BUTTON_POSITIVE:
- Toast.makeText(MainActivity.this, "确认" + which, Toast.LENGTH_SHORT).show();
- break;
- case Dialog.BUTTON_NEGATIVE:
- Toast.makeText(MainActivity.this, "取消" + which, Toast.LENGTH_SHORT).show();
- break;
- case Dialog.BUTTON_NEUTRAL:
- Toast.makeText(MainActivity.this, "忽略" + which, Toast.LENGTH_SHORT).show();
- break;
- }
- }
- };
- //dialog参数设置
- AlertDialog.Builder builder=new AlertDialog.Builder(this); //先得到构造器
- builder.setTitle("提示"); //设置标题
- builder.setMessage("是否确认退出?"); //设置内容
- builder.setIcon(R.mipmap.ic_launcher);//设置图标,图片id即可
- builder.setPositiveButton("确认",dialogOnclicListener);
- builder.setNegativeButton("取消", dialogOnclicListener);
- builder.setNeutralButton("忽略", dialogOnclicListener);
- builder.create().show();
- }
列表对话框:
代码:
- private void dialog2() {
- final String items[]={"张三","李四","王五"};
- //dialog参数设置
- AlertDialog.Builder builder=new AlertDialog.Builder(this); //先得到构造器
- builder.setTitle("提示"); //设置标题
- //builder.setMessage("是否确认退出?"); //设置内容
- builder.setIcon(R.mipmap.ic_launcher);//设置图标,图片id即可
- //设置列表显示,注意设置了列表显示就不要设置builder.setMessage()了,否则列表不起作用。
- builder.setItems(items,new DialogInterface.OnClickListener() {
- @Override
- public void onClick(DialogInterface dialog, int which) {
- dialog.dismiss();
- Toast.makeText(MainActivity.this, items[which], Toast.LENGTH_SHORT).show();
- }
- });
- builder.setPositiveButton("确定",new DialogInterface.OnClickListener() {
- @Override
- public void onClick(DialogInterface dialog, int which) {
- dialog.dismiss();
- Toast.makeText(MainActivity.this, "确定", Toast.LENGTH_SHORT).show();
- }
- });
- builder.create().show();
- }
说明:列表对话框只需设置Items属性即可,注意不能在设置Message属性,否则只会显示Message,不会显示列表。这里的setItems中的Onclick中的which属性是items数组的下标!
单选按钮对话框:
代码:
- private void dialog3(){
- final String items[]={"男","女"};
- AlertDialog.Builder builder=new AlertDialog.Builder(this); //先得到构造器
- builder.setTitle("提示"); //设置标题
- builder.setIcon(R.mipmap.ic_launcher);//设置图标,图片id即可
- builder.setSingleChoiceItems(items,0,new DialogInterface.OnClickListener() {
- @Override
- public void onClick(DialogInterface dialog, int which) {
- //dialog.dismiss();
- Toast.makeText(MainActivity.this, items[which], Toast.LENGTH_SHORT).show();
- }
- });
- builder.setPositiveButton("确定",new DialogInterface.OnClickListener() {
- @Override
- public void onClick(DialogInterface dialog, int which) {
- dialog.dismiss();
- Toast.makeText(MainActivity.this, "确定", Toast.LENGTH_SHORT).show();
- }
- });
- builder.create().show();
- }
说明:其实也没什么好说的,和上面的差不多,只是设置单选用setSingleChoiceItems,注意这里的参数:items是显示的文本,0表示默认选中是第一个,如图所示是默认选中“男”。
多选列表对话框:
代码:
- private void dialog4(){
- final String items[]={"篮球","足球","排球"};
- final boolean selected[]={true,false,true};
- AlertDialog.Builder builder=new AlertDialog.Builder(this); //先得到构造器
- builder.setTitle("提示"); //设置标题
- builder.setIcon(R.mipmap.ic_launcher);//设置图标,图片id即可
- builder.setMultiChoiceItems(items,selected,new DialogInterface.OnMultiChoiceClickListener() {
- @Override
- public void onClick(DialogInterface dialog, int which, boolean isChecked) {
- // dialog.dismiss();
- Toast.makeText(MainActivity.this, items[which]+isChecked, Toast.LENGTH_SHORT).show();
- }
- });
- builder.setPositiveButton("确定",new DialogInterface.OnClickListener() {
- @Override
- public void onClick(DialogInterface dialog, int which) {
- dialog.dismiss();
- Toast.makeText(MainActivity.this, "确定", Toast.LENGTH_SHORT).show();
- //android会自动根据你选择的改变selected数组的值。
- for (int i=0;i<selected.length;i++){
- Log.e("hongliang",""+selected[i]);
- }
- }
- });
- builder.create().show();
- }
说明:setMultiChoiceItems中的参数:selected是默认的对应的选中状态。当你选择时,系统会自动帮你把selected中的值做相应改变,所以在确定按钮中可以得到所有的选择状态。其他和单选一样。
- <LinearLayout 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:orientation="vertical"
- 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">
- <Button
- android:id="@+id/main_btn1"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:text="普通对话框" />
- <Button
- android:id="@+id/main_btn2"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:text="列表对话框" />
- <Button
- android:id="@+id/main_btn3"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:text="单选列表对话框" />
- <Button
- android:id="@+id/main_btn4"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:text="多选列表对话框" />
- </LinearLayout>