Activities提供了一种方便管理的创建、保存、回复的对话框机制,例如onCreateDialog(int), onPrepareDialog(int, Dialog), showDialog(int), dismissDialog(int)等方法,如果使用这些方法的话,Activity将通过getOwnerActivity()方法返回该Activity管理的对话框(dialog).

  onCreateDialog(int):当你使用这个回调函数时,Android系统会有效的设置这个Activity为每个对话框的所有者,从而自动管理每个对话框的状态并挂靠到Activity上。这样,每个对话框继承这个Activity的特定属性。比如,当一个对话框打开时,菜单键显示为这个Activity定义的选项菜单,音量键修改Activity使用的音频流。

  showDialog(int):当你想要显示一个对话框时,调用showDialog(int id) 方法并传递一个唯一标识这个对话框的整数。当对话框第一次被请求时,Android从你的Activity中调用onCreateDialog(int id),你应该在这里初始化这个对话框Dialog。这个回调方法被传以和showDialog(int id)相同的ID。当你创建这个对话框后,在Activity的最后返回这个对象。

  onPrepareDialog(int, Dialog):在对话框被显示之前,Android还调用了可选的回调函数onPrepareDialog(int id, Dialog). 如果你想在每一次对话框被打开时改变它的任何属性,你可以定义这个方法。这个方法在每次打开对话框时被调用,而onCreateDialog(int) 仅在对话框第一次打开时被调用。如果你不定义onPrepareDialog(),那么这个对话框将保持和上次打开时一样。这个方法也被传递以对话框的ID,和在onCreateDialog()中创建的对话框对象。

  dismissDialog(int):当你准备关闭对话框时,你可以通过对这个对话框调用dismiss()来消除它。如果需要,你还可以从这个Activity中调用dismissDialog(int id) 方法,这实际上将为你对这个对话框调用dismiss() 方法。 如果你想使用onCreateDialog(int id) 方法来管理你对话框的状态(就如同在前面的章节讨论的那样),然后每次你的对话框消除的时候,这个对话框对象的状态将由该Activity保留。如果你决定不再需要这个对象或者清除该状态是重要的,那么你应该调用removeDialog(int id)。这将删除任何内部对象引用而且如果这个对话框正在显示,它将被消除

效果请看附件

图1效果:该效果是当按返回按钮时弹出一个提示,来确保无误操作,采用常见的对话框样式。

     代码:

  创建带有确定、取消对话框,点击返回或Button时触发dialog方法

package com.hilary.dialog;import android.app.Activity;import android.app.AlertDialog.Builder;import android.content.DialogInterface;import android.content.DialogInterface.OnClickListener;import android.os.Bundle;import android.view.KeyEvent;import android.view.View;import android.widget.Button;public class DialogActivity extends Activity {private Button btn;    /** Called when the activity is first created. */    @Override    public void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.main);                btn = (Button) findViewById(R.id.btn);        btn.setOnClickListener(new Listener());    }    public void dialog(){    Builder builder = new Builder(DialogActivity.this);    builder.setTitle("提示");//设置标题、    builder.setMessage("确认退出吗?");//设置对话框内容    builder.setPositiveButton("确认", new OnClickListener() {@Overridepublic void onClick(DialogInterface dialog, int which) {dialog.dismiss();//关闭对话框DialogActivity.this.finish();//结束Activity生命周期}    });    builder.setNegativeButton("取消", new OnClickListener() {@Overridepublic void onClick(DialogInterface dialog, int which) {//dialog.dismiss();}});    builder.create().show(); //这句话是不可以放在前面的,不然会显示不出来show后面的效果    }    //重写OnClickListener 类    class Listener implements android.view.View.OnClickListener{@Overridepublic void onClick(View v) {dialog();}    }    //当点击返回时,触发onKeyDown方法    public boolean onKeyDown(int keyCode, KeyEvent event) {      if (keyCode == KeyEvent.KEYCODE_BACK && event.getRepeatCount() == 0) {       dialog();      }      return false;     }}

图2效果:改变了对话框的图表,添加了三个按钮

package com.hilary.dialog;import android.app.Activity;import android.app.AlertDialog;import android.app.Dialog;import android.content.DialogInterface;import android.content.DialogInterface.OnClickListener;import android.os.Bundle;import android.view.View;import android.widget.Button;import android.widget.Toast;public class Dialog2Activity extends Activity implements android.view.View.OnClickListener{private Button btn;    /** Called when the activity is first created. */    @Override    public void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.main);        btn = (Button) findViewById(R.id.btn);        btn.setOnClickListener(this);    }    public void dialog(){    Dialog dialog = new AlertDialog.Builder(this).setIcon(         android.R.drawable.btn_star).setTitle("工作情况").setMessage(         "你经常加班吗?").setPositiveButton("经常加班",         new OnClickListener() {          @Override          public void onClick(DialogInterface dialog, int which) {           // TODO Auto-generated method stub           Toast.makeText(Dialog2Activity.this, "经常加班。",             Toast.LENGTH_LONG).show();          }         }).setNegativeButton("偶尔加班", new OnClickListener() {        @Override        public void onClick(DialogInterface dialog, int which) {         // TODO Auto-generated method stub         Toast.makeText(Dialog2Activity.this, "偶尔加班。", Toast.LENGTH_LONG)           .show();        }       }).setNeutralButton("很少加班", new OnClickListener() {        @Override        public void onClick(DialogInterface dialog, int which) {         Toast.makeText(Dialog2Activity.this, "很少加班。", Toast.LENGTH_LONG)           .show();        }       }).create();    dialog.show();    }@Overridepublic void onClick(View v) {dialog();}}

图3效果:信息内容是一个简单的View类型

new AlertDialog.Builder(this).setTitle("请输入").setIcon(     android.R.drawable.ic_dialog_info).setView(     new EditText(this)).setPositiveButton("确定", null)     .setNegativeButton("取消", null).show();

图4效果:信息内容是一组多选框

new AlertDialog.Builder(this).setTitle("复选框").setMultiChoiceItems(     new String[] { "Item1", "Item2" }, null, null)     .setPositiveButton("确定", null)     .setNegativeButton("取消", null).show();

图5效果:信息内容是一组单选框

new AlertDialog.Builder(this).setTitle("单选框").setIcon(     android.R.drawable.ic_dialog_info).setSingleChoiceItems(     new String[] { "Item1", "Item2" }, 0,     new DialogInterface.OnClickListener() {      public void onClick(DialogInterface dialog, int which) {       dialog.dismiss();      }     }).setNegativeButton("取消", null).show();

图6效果:信息内容是一组简单列表项

new AlertDialog.Builder(this).setTitle("列表框").setItems(     new String[] { "Item1", "Item2" }, null).setNegativeButton(     "确定", null).show();

图7效果:信息内容是一个自定义的布局

1.布局文件

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_height="wrap_content" android:layout_width="wrap_content" android:background="#ffffffff" android:orientation="horizontal" android:id="@+id/dialog"> <TextView android:layout_height="wrap_content"   android:layout_width="wrap_content"  android:id="@+id/tvname" android:text="姓名:" /> <EditText android:layout_height="wrap_content"  android:layout_width="wrap_content" android:id="@+id/etname" android:minWidth="100dip"/></LinearLayout>

2.调用代码

LayoutInflater inflater = getLayoutInflater();   View layout = inflater.inflate(R.layout.dialog,     (ViewGroup) findViewById(R.id.dialog));   new AlertDialog.Builder(this).setTitle("自定义布局").setView(layout)     .setPositiveButton("确定", null)     .setNegativeButton("取消", null).show();

更多相关文章

  1. android Google Map获取地理位置信息的方法
  2. android anr分析方法
  3. Activity页面状态保存 持久化
  4. onInterceptTouchEvent和onTouchEvent调用时序2
  5. Android(安卓)多媒体开发相关技巧
  6. Android反射基础
  7. Android(安卓)实现自定义属性 declare-styleable扩展 方法 &Ecli
  8. Android学习笔记(十二)——数据存储(SQLite数据库)
  9. android JNI入门 之helloworld

随机推荐

  1. Android(安卓)Launcher 之 图标加框 优化
  2. android 开机流程
  3. android arm debug
  4. android 编译源码不生成odex
  5. 多媒体框架
  6. Android使用DrawLayout,ToolBar和ActionBa
  7. RecyclerView 实现item点击水波纹动画
  8. 线性布局LinearLayout和相对布局Relative
  9. 一分钟实现TextView高亮效果BabushkaText
  10. android两种方式设置EditText不弹出软键