关闭

dialog

177人阅读 评论(0) 收藏 举报

兼容的 AlertDialog

拥有Material风格的Dialog控件在下列类:

android.support.v7.app.AlertDialog

所以想要使用此风格的对话框,需要在Module的build.gradle中导入

dependencies {
    compile 'com.android.support:appcompat-v7:23.1.1'
}

这个 V7 包中的 AlertDialog 在 Android 2.1 以上可以提供兼容性的 Material 风格 Dialog 。

也就是说,使用这个包中的 AlertDialog 的话,从2.1到6.0都是 Material风格的 Dialog 。

当使用这个包中的 AlertDialog 时:

(下图左边为4.4,右边为5.1)



非兼容的 AlertDialog

如果直接使用

android.app.AlertDialog

使用这个包中的 AlertDialog 的话 在 Android 5.0 以下就是原始风格, 5.0 以上为 Material 风格。

我们来看看对比图:

(下图左边为4.4,右边为5.1)



实例

在选择导入包的时候决定了这个是否兼容低版本,因为 Android 碎片化的原因,推荐使用V7包中的AlertDialog达到高低版本统一样式的效果。 这里用一个简单的Demo样式创建一个Dialog并显示的过程。

/**
* 这是兼容的 AlertDialog
*/
private void showDialog() {
  /*
  这里使用了 android.support.v7.app.AlertDialog.Builder
  可以直接在头部写 import android.support.v7.app.AlertDialog
  那么下面就可以写成 AlertDialog.Builder
  */
  android.support.v7.app.AlertDialog.Builder builder = new android.support.v7.app.AlertDialog.Builder(this);
  builder.setTitle("Material Design Dialog");
  builder.setMessage("这是 android.support.v7.app.AlertDialog 中的样式");
  builder.setNegativeButton("取消", null);
  builder.setPositiveButton("确定", null);
  builder.show();
}

常用方法的解释

通过Builder得到对象之后可以进行各种属性的设置,来看看都有哪些属性可供调整。

show

进行显示Dialog。如果在未设置其他属性的情况下直接使用show,会显示一个隐形Dialog,不过背景色会被透明黑色覆盖。


setTitle

设置Dialog的标题,使用一串文本或者。如:
builder.setTitle("这里是Title");


setMessage

设置Dialog的内容,使用一串文本。如:
builder.setMessage("这里是Message");


setNegativeButton

设置否定按钮,第一个参数为按钮文本,第二个参数为按钮被点击的监听器类。如:
builder.setNegativeButton("取消", null);


setPositiveButton

设置肯定按钮,第一个参数为按钮文本,第二个参数为按钮被点击的监听器类。如:
builder.setPositiveButton("确定", null);



谷歌使用这两个方法来定义肯定和否定按钮,一定程度上是为了统一肯定和否定按钮所在的方向,肯定按钮统一在右边,因为通常是右手操作,否定按钮统一在左边。这样对用户来说是比较统一的体验。

以上就是最为常用的几个方法 , 接着往下看一些其他方法。


setNeutralButton

设置中性按钮,第一个参数为按钮文本,第二个参数为按钮被点击的监听器类,这个按钮默认被放置到Dialog的左下角。如: builder.setNeutralButton("中性", null);


setView

设置一个自定义的View放置到message的下方,可以是一个View对象,也可以是一个view资源ID。 如:
builder.setView(new EditText(this));


setView(可设置边距)

对于使用View对象的参数,还可以设置他的边距。 如:
builder.setView(new EditText(this),20,20,20,20);;


setMultiChoiceItems

第一个参数为列表项的文本数组,第二个参数为列表项默认情况下的选中状态,为空则都不选中,第三个是列表项的监听器类。在使用这个方法的时候如果同时使用了setMessage方法会导致此方法无效,而只显示setMessage的内容。 如:
builder.setMultiChoiceItems(new String[]{"233333", "hahahaha"}, null, null);


setItems

第一个参数为列表项的文本数组,第二个参数为列表项的监听器类。在使用这个方法的时候如果同时使用了setMessage方法会导致此方法无效,而只显示setMessage的内容。 如:
builder.setItems(new String[]{"Item1", "Item2"}, null);


setIco

设置Dialog的图标,可以使用资源文件 ID,也可以使用 Drawable 对象。 如: builder.setIcon(R.mipmap.ic_launcher);



自定义Dialog

有时候自带的各种方法并不能满足我们的Dialog的设计需求,这时候我们可以自己写一个 xml 设计符合需求的Dialog。(仅为设计Dialog的Message部分,并不是Dialog整体)

创建一个名为dialog的XML

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:id="@+id/dialog"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:orientation="horizontal">

  <TextView
    android:layout_margin="8dp"
    android:id="@+id/tv"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="你的银行密码:" />
  

  <EditText
    android:layout_margin="8dp"
    android:id="@+id/et"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    />
</LinearLayout>

创建View对象与XML关联

 LayoutInflater inflater = getLayoutInflater();
 View   dialog = inflater.inflate(R.layout.dialog,(ViewGroup) findViewById(R.id.dialog));
 EditText   editText = (EditText) dialog.findViewById(R.id.et);

将View设置到Dialog中

AlertDialog.Builder builder = new AlertDialog.Builder(this);
  builder.setTitle("这里是Title");
  builder.setPositiveButton("确定", new DialogInterface.OnClickListener() {
      @Override
      public void onClick(DialogInterface dialog, int which) {
          Toast.makeText(MainActivity.this, editText.getText().toString(), Toast.LENGTH_SHORT).show();
      }
  });
  builder.setView(dialog);
  builder.setIcon(R.mipmap.ic_launcher);
  builder.show();


文/希灵丶(简书作者)
原文链接:http://www.jianshu.com/p/6caffdbcd5db
著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”。
0
0
查看评论

linux学习笔记之-安装dialog

今天在学习linux下shell中使用dialog的时候,发现我的linux版本中并没有安装dialog开发安装包。查看是否安装的方法,#:dialog 只要输入dialog命令就会提示未按装,且提示sudo apt-get install dialog。于是,我按照提示输入命令,但是老是提示安装...
  • shenwanjiang111
  • shenwanjiang111
  • 2014-12-20 21:42
  • 1967

Android Dialog使用详解

对话框是提示用户作出决定或输入额外信息的小窗口,通常不会填充整个屏幕,用于进行一些额外交互Dialog 类是对话框的基类,但应该避免直接实例化 Dialog,而应使用其子类,比如 AlertDialog 此对话框可显示标题、提示信息、按钮、可选择项列表或自定义布局等 DatePickerDialo...
  • new_one_object
  • new_one_object
  • 2017-02-23 15:47
  • 3197

[Android]自定义万能Dialog

在我们开发Android项目的时候,难免需要制作各式各样的Dialog,例如:
  • u011596810
  • u011596810
  • 2016-05-25 21:36
  • 2376

jQuery UI dialog 参数说明

<br />前段时间碰到个问题 jquery UI dialog弹出层 弹出多个层是 比如弹出两个层A和B  B层如果显示的数据表格太大,伸到了A层的外面,那伸到A层之外的部分就看不到了,因为B层是在A层上弹出的 B的大小受到A层大小的限制<br />于是找到了这个...
  • xue_feitian
  • xue_feitian
  • 2011-06-02 19:13
  • 90888

一次dialog导致的内存泄漏

一次Dialog导致的内存泄漏今天上午10:30来到公司后,一头扎进了张鸿洋大神所写的OkHttpUtils源码中去,继续昨晚未完成的任务,11:30后,终于对整个框架有了一个比较全局、清晰的了解,心里更是对大神充满满满的崇拜和敬意;然后回到公司的工作,打开jira,发现距离我两个工位的美女测试姐姐...
  • u012464435
  • u012464435
  • 2016-03-03 23:30
  • 2236

自定义Dialog接口回调参数

基本上所有的app项目都会有自定义dialog,但有时如果把dialog单独写成一个类,我们就需要考虑到如何将dialog的参数回调到activity或者fragment,当然有很多方法,这里主要讲的是通过接口回调的方式来把dialog中的参数传递到activity或者fragment,主要讲述的是...
  • linzhenxiang123
  • linzhenxiang123
  • 2016-12-22 11:35
  • 859

dialog 删除刷新dialog

<a class="delete" title="确实要删除该条记录吗?" callback="delDialogAjax" target="ajaxTodo" href="/gravida/return...
  • chiperfect
  • chiperfect
  • 2015-04-15 11:17
  • 1975

自定义Dialog的详细步骤(实现自定义样式一般原理)

自定义Dialog的详细步骤(实现自定义样式一般原理)        现在很多App的提示对话框都非常有个性,然而你还用系统的对话框样式,是不是觉得很落后呢,今天我就给大家讲讲怎样自定义自己的Dialog,学会了之后,你就会根据自...
  • oQiHaoGongYuan
  • oQiHaoGongYuan
  • 2016-03-22 22:12
  • 20921

Android 简单的自定义Dialog

效果图 Dialog的详细用法看这篇博客:http://blog.csdn.net/zhuwentao2150/article/details/51478053我们自定义的CustomDialog是通过继承Dialog类并添加自定义的布局来实现的/** * 自定义Dialog弹窗 * Crea...
  • zhuwentao2150
  • zhuwentao2150
  • 2016-08-19 23:25
  • 3762

Android源码解析(十九)-->Dialog加载绘制流程

其实Android系统中所有的显示控件(注意这里是控件,而不是组件)的加载绘制流程都是类似的,包括:Dialog的加载绘制流程,PopupWindow的加载绘制流程,Toast的显示原理等,上一篇文章中,我说在介绍了Activity界面的加载绘制流程之后,就会分析一下剩余几个控件的显示控制流程,这里...
  • qq_23547831
  • qq_23547831
  • 2016-05-02 00:20
  • 20281
    个人资料
    • 访问:34650次
    • 积分:446
    • 等级:
    • 排名:千里之外
    • 原创:14篇
    • 转载:5篇
    • 译文:0篇
    • 评论:1条