android中dialog(自定义dialog)的使用方法!!!

来源:互联网 发布:近几年海外代购数据 编辑:程序博客网 时间:2024/05/17 22:12

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)

一般对话框:

上图:

代码:

[java] view plain copy 在CODE上查看代码片派生到我的代码片
  1. private void dialog1(){  
  2.         AlertDialog.Builder builder=new AlertDialog.Builder(this);  //先得到构造器  
  3.         builder.setTitle("提示"); //设置标题  
  4.         builder.setMessage("是否确认退出?"); //设置内容  
  5.         builder.setIcon(R.mipmap.ic_launcher);//设置图标,图片id即可  
  6.         builder.setPositiveButton("确定"new DialogInterface.OnClickListener() { //设置确定按钮  
  7.             @Override  
  8.             public void onClick(DialogInterface dialog, int which) {  
  9.                 dialog.dismiss(); //关闭dialog  
  10.                 Toast.makeText(MainActivity.this"确认" + which, Toast.LENGTH_SHORT).show();  
  11.             }  
  12.         });  
  13.         builder.setNegativeButton("取消"new DialogInterface.OnClickListener() { //设置取消按钮  
  14.             @Override  
  15.             public void onClick(DialogInterface dialog, int which) {  
  16.                 dialog.dismiss();  
  17.                 Toast.makeText(MainActivity.this"取消" + which, Toast.LENGTH_SHORT).show();  
  18.             }  
  19.         });  
  20.   
  21.         builder.setNeutralButton("忽略"new DialogInterface.OnClickListener() {//设置忽略按钮  
  22.             @Override  
  23.             public void onClick(DialogInterface dialog, int which) {  
  24.                 dialog.dismiss();  
  25.                 Toast.makeText(MainActivity.this"忽略" + which, Toast.LENGTH_SHORT).show();  
  26.             }  
  27.         });  
  28.         //参数都设置完成了,创建并显示出来  
  29.         builder.create().show();  
  30.     }  
说明:代码上注释已经比较全了,相信大家都能看得懂!dialog可以设置三个选择按钮,设置时指定按钮响应事件。

是不是觉得三个按钮写了三遍响应事件,很繁琐呢?注意:onClick的参数中有一个which,这个是什么意思呢?这个which实际上代表的是一个唯一的int型数值。像上面的setPositiveButton中的which代表的是-1,setNegativeButton中的which代表的是-3,setNeutralButton中的which代表的是-2. 到了这里相信大家已经想到怎么简洁的写法了,只要写一个响应事件,用which参数去区分是那个按钮就可以了!  


看简洁的代码2:和上面的效果是一样的!

[java] view plain copy 在CODE上查看代码片派生到我的代码片
  1. private void dialog1_1(){  
  2.        //先new出一个监听器,设置好监听  
  3.        DialogInterface.OnClickListener dialogOnclicListener=new DialogInterface.OnClickListener(){  
  4.   
  5.            @Override  
  6.            public void onClick(DialogInterface dialog, int which) {  
  7.                switch(which){  
  8.                    case Dialog.BUTTON_POSITIVE:  
  9.                        Toast.makeText(MainActivity.this"确认" + which, Toast.LENGTH_SHORT).show();  
  10.                        break;  
  11.                    case Dialog.BUTTON_NEGATIVE:  
  12.                        Toast.makeText(MainActivity.this"取消" + which, Toast.LENGTH_SHORT).show();  
  13.                        break;  
  14.                    case Dialog.BUTTON_NEUTRAL:  
  15.                        Toast.makeText(MainActivity.this"忽略" + which, Toast.LENGTH_SHORT).show();  
  16.                        break;  
  17.                }  
  18.            }  
  19.        };  
  20.        //dialog参数设置  
  21.        AlertDialog.Builder builder=new AlertDialog.Builder(this);  //先得到构造器  
  22.        builder.setTitle("提示"); //设置标题  
  23.        builder.setMessage("是否确认退出?"); //设置内容  
  24.        builder.setIcon(R.mipmap.ic_launcher);//设置图标,图片id即可  
  25.        builder.setPositiveButton("确认",dialogOnclicListener);  
  26.        builder.setNegativeButton("取消", dialogOnclicListener);  
  27.        builder.setNeutralButton("忽略", dialogOnclicListener);  
  28.        builder.create().show();  
  29.    }  


列表对话框:



代码:

[java] view plain copy 在CODE上查看代码片派生到我的代码片
  1. private void dialog2() {  
  2.         final String items[]={"张三","李四","王五"};  
  3.         //dialog参数设置  
  4.         AlertDialog.Builder builder=new AlertDialog.Builder(this);  //先得到构造器  
  5.         builder.setTitle("提示"); //设置标题  
  6.         //builder.setMessage("是否确认退出?"); //设置内容  
  7.         builder.setIcon(R.mipmap.ic_launcher);//设置图标,图片id即可  
  8.         //设置列表显示,注意设置了列表显示就不要设置builder.setMessage()了,否则列表不起作用。  
  9.         builder.setItems(items,new DialogInterface.OnClickListener() {  
  10.             @Override  
  11.             public void onClick(DialogInterface dialog, int which) {  
  12.                 dialog.dismiss();  
  13.                 Toast.makeText(MainActivity.this, items[which], Toast.LENGTH_SHORT).show();  
  14.   
  15.             }  
  16.         });  
  17.         builder.setPositiveButton("确定",new DialogInterface.OnClickListener() {  
  18.             @Override  
  19.             public void onClick(DialogInterface dialog, int which) {  
  20.                 dialog.dismiss();  
  21.                 Toast.makeText(MainActivity.this"确定", Toast.LENGTH_SHORT).show();  
  22.             }  
  23.         });  
  24.         builder.create().show();  
  25.     }  

说明:列表对话框只需设置Items属性即可,注意不能在设置Message属性,否则只会显示Message,不会显示列表。这里的setItems中的Onclick中的which属性是items数组的下标!

单选按钮对话框:


代码:

[java] view plain copy 在CODE上查看代码片派生到我的代码片
  1. private void dialog3(){  
  2.         final String items[]={"男","女"};  
  3.         AlertDialog.Builder builder=new AlertDialog.Builder(this);  //先得到构造器  
  4.         builder.setTitle("提示"); //设置标题  
  5.         builder.setIcon(R.mipmap.ic_launcher);//设置图标,图片id即可  
  6.         builder.setSingleChoiceItems(items,0,new DialogInterface.OnClickListener() {  
  7.             @Override  
  8.             public void onClick(DialogInterface dialog, int which) {  
  9.                 //dialog.dismiss();  
  10.                 Toast.makeText(MainActivity.this, items[which], Toast.LENGTH_SHORT).show();  
  11.             }  
  12.         });  
  13.         builder.setPositiveButton("确定",new DialogInterface.OnClickListener() {  
  14.             @Override  
  15.             public void onClick(DialogInterface dialog, int which) {  
  16.                 dialog.dismiss();  
  17.                 Toast.makeText(MainActivity.this"确定", Toast.LENGTH_SHORT).show();  
  18.             }  
  19.         });  
  20.         builder.create().show();  
  21.     }  

说明:其实也没什么好说的,和上面的差不多,只是设置单选用setSingleChoiceItems,注意这里的参数:items是显示的文本,0表示默认选中是第一个,如图所示是默认选中“男”。


多选列表对话框:



代码:

[java] view plain copy 在CODE上查看代码片派生到我的代码片
  1. private void dialog4(){  
  2.         final String items[]={"篮球","足球","排球"};  
  3.         final boolean selected[]={true,false,true};  
  4.         AlertDialog.Builder builder=new AlertDialog.Builder(this);  //先得到构造器  
  5.         builder.setTitle("提示"); //设置标题  
  6.         builder.setIcon(R.mipmap.ic_launcher);//设置图标,图片id即可  
  7.         builder.setMultiChoiceItems(items,selected,new DialogInterface.OnMultiChoiceClickListener() {  
  8.             @Override  
  9.             public void onClick(DialogInterface dialog, int which, boolean isChecked) {  
  10.                // dialog.dismiss();  
  11.                 Toast.makeText(MainActivity.this, items[which]+isChecked, Toast.LENGTH_SHORT).show();  
  12.             }  
  13.         });  
  14.         builder.setPositiveButton("确定",new DialogInterface.OnClickListener() {  
  15.             @Override  
  16.             public void onClick(DialogInterface dialog, int which) {  
  17.                 dialog.dismiss();  
  18.                 Toast.makeText(MainActivity.this"确定", Toast.LENGTH_SHORT).show();  
  19.                 //android会自动根据你选择的改变selected数组的值。  
  20.                 for (int i=0;i<selected.length;i++){  
  21.                     Log.e("hongliang",""+selected[i]);  
  22.                 }  
  23.             }  
  24.         });  
  25.         builder.create().show();  
  26.     }  

说明:setMultiChoiceItems中的参数:selected是默认的对应的选中状态。当你选择时,系统会自动帮你把selected中的值做相应改变,所以在确定按钮中可以得到所有的选择状态。其他和单选一样。


布局文件:

[html] view plain copy 在CODE上查看代码片派生到我的代码片
  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     xmlns:tools="http://schemas.android.com/tools"  
  3.     android:layout_width="match_parent"  
  4.     android:layout_height="match_parent"  
  5.     android:orientation="vertical"  
  6.     android:paddingBottom="@dimen/activity_vertical_margin"  
  7.     android:paddingLeft="@dimen/activity_horizontal_margin"  
  8.     android:paddingRight="@dimen/activity_horizontal_margin"  
  9.     android:paddingTop="@dimen/activity_vertical_margin"  
  10.     tools:context=".MainActivity">  
  11.   
  12.     <Button  
  13.         android:id="@+id/main_btn1"  
  14.         android:layout_width="wrap_content"  
  15.         android:layout_height="wrap_content"  
  16.         android:text="普通对话框" />  
  17.   
  18.     <Button  
  19.         android:id="@+id/main_btn2"  
  20.         android:layout_width="wrap_content"  
  21.         android:layout_height="wrap_content"  
  22.         android:text="列表对话框" />  
  23.   
  24.     <Button  
  25.         android:id="@+id/main_btn3"  
  26.         android:layout_width="wrap_content"  
  27.         android:layout_height="wrap_content"  
  28.         android:text="单选列表对话框" />  
  29.     <Button  
  30.         android:id="@+id/main_btn4"  
  31.         android:layout_width="wrap_content"  
  32.         android:layout_height="wrap_content"  
  33.         android:text="多选列表对话框" />  
  34. </LinearLayout>  


0 0
原创粉丝点击