zoukankan      html  css  js  c++  java
  • dialog的各类显示方法

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

         代码:

      创建对话框方法dialog()

    protected void dialog() {
      AlertDialog.Builder builder = new Builder(Main.this);
      builder.setMessage("确认退出吗?");

      builder.setTitle("提示");

      builder.setPositiveButton("确认", new OnClickListener() {

       @Override
       public void onClick(DialogInterface dialog, int which) {
        dialog.dismiss();

        Main.this.finish();
       }
      });

      builder.setNegativeButton("取消", new OnClickListener() {

       @Override
       public void onClick(DialogInterface dialog, int which) {
        dialog.dismiss();
       }
      });

      builder.create().show();
     }

    在onKeyDown(int keyCode, KeyEvent event)方法中调用此方法

    public boolean onKeyDown(int keyCode, KeyEvent event) {
      if (keyCode == KeyEvent.KEYCODE_BACK && event.getRepeatCount() == 0) {
       dialog();
      }
      return false;
     }

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

    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(Main.this, "我很喜欢他的电影。",
             Toast.LENGTH_LONG).show();
          }
         }).setNegativeButton("不喜欢", new OnClickListener() {

        @Override
        public void onClick(DialogInterface dialog, int which) {
         // TODO Auto-generated method stub
         Toast.makeText(Main.this, "我不喜欢他的电影。", Toast.LENGTH_LONG)
           .show();
        }
       }).setNeutralButton("一般", new OnClickListener() {

        @Override
        public void onClick(DialogInterface dialog, int which) {
         // TODO Auto-generated method stub
         Toast.makeText(Main.this, "谈不上喜欢不喜欢。", Toast.LENGTH_LONG)
           .show();
        }
       }).create();

       dialog.show();

    图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();

  • 相关阅读:
    webpack 4.X 基础编译
    一个数组中两个数的和为N,找出这两个数字的下标
    Mybatis自动生成,针对字段类型为text等会默认产生XXXXWithBlobs的方法问题
    Docker Mysql
    Docker镜像Push到DockerHub
    E: Unable to locate package git
    linux解压类型总结
    docker安装gitlab
    Docker应用
    解决github访问及上传慢的问题
  • 原文地址:https://www.cnblogs.com/yuanting/p/4707424.html
Copyright © 2011-2022 走看看