Android UI设计之AlertDialog弹窗控件

有关android的弹窗界面相信大家见过不少了,手机上很多应用软件都涉及到弹窗控件,比如典型的每次删除一个图片或者卸载一个等都会弹出一个窗口询问是否删除/卸载等,还有我们系统的设置时间/日期等,都用到了这样的控件,下面我将通过代码来总结下常用的几个弹窗控件

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<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"
  tools:context="com.company.alertdialog.MainActivity">

  <Button
    android:id="@+id/btn1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:onClick="onClick"
    android:text="列表弹窗" />

  <Button
    android:id="@+id/btn2"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:onClick="onClick"
    android:text="单选弹窗" />

  <Button
    android:id="@+id/btn3"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:onClick="onClick"
    android:text="多选弹窗" />

  <Button
    android:id="@+id/btn4"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:onClick="onClick"
    android:text="日期弹窗" />

  <Button
    android:id="@+id/btn5"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:onClick="onClick"
    android:text="时间弹窗" />

  <Button
    android:id="@+id/btn6"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:onClick="onClick"
    android:text="进度条弹窗" />
</LinearLayout>

strings.xml

<resources>
  <string name="app_name">AlertDialog</string>
  <string-array name="list">
    <item>列表一</item>
    <item>列表二</item>
    <item>列表三</item>
    <item>列表四</item>
    <item>列表五</item>
    <item>列表六</item>
  </string-array>
</resources>

MainActivity.java

public class MainActivity extends AppCompatActivity implements View.OnClickListener {

  //表示列表弹窗
  private Button mBtn1;

  //表示单选弹窗
  private Button mBtn2;

  //表示多选弹窗
  private Button mBtn3;

  //表示日期弹窗
  private Button mBtn4;

  //表示时间弹窗
  private Button mBtn5;

  //表示进度条弹窗
  private Button mBtn6;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    init();
    event();
  }

  /**
   * 设置监听事件
   */
  private void event() {
    mBtn1.setOnClickListener(this);
    mBtn2.setOnClickListener(this);
    mBtn3.setOnClickListener(this);
    mBtn4.setOnClickListener(this);
    mBtn5.setOnClickListener(this);
    mBtn6.setOnClickListener(this);
  }

  /**
   * 初始化控件
   */
  private void init() {
    mBtn1 = (Button) findViewById(R.id.btn1);
    mBtn2 = (Button) findViewById(R.id.btn2);
    mBtn3 = (Button) findViewById(R.id.btn3);
    mBtn4 = (Button) findViewById(R.id.btn4);
    mBtn5 = (Button) findViewById(R.id.btn5);
    mBtn6 = (Button) findViewById(R.id.btn6);
  }

  @Override
  public void onClick(View v) {
    switch (v.getId()) {
      case R.id.btn1:
        createListDialog();
        break;
      case R.id.btn2:
        createSingleDialog();
        break;
      case R.id.btn3:
        createMutilDialog();
        break;
      case R.id.btn4:
        createDateDialog();
        break;
      case R.id.btn5:
        createTimeDialog();
        break;
      case R.id.btn6:
        createProgressBarDialog();
        break;

    }
  }

  /**
   * 创建一个进度条弹窗
   */
  private void createProgressBarDialog() {
    //创建进度条弹窗对象
    ProgressDialog progressDialog = new ProgressDialog(this);
    //设置标题
    progressDialog.setTitle("进度条弹窗");
    //设置标题图标
    progressDialog.setIcon(R.mipmap.ic_launcher);
    //设置文本
    progressDialog.setMessage("正在加载...");
    //设置最大进度
    progressDialog.setMax(100);
    //设置进度条的类型
    progressDialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);
    //显示进度条弹窗
    progressDialog.show();
    //如果设置这条语句的话,那么无论你点击屏幕外的任何地方或者按返回键都取消不了这个弹窗,
    //除非在完成进度后,设置取消事件。一般情况这种设置方式对界面很不友好
    //不过有时候软件有重大bug,用户不得不更新该软件,如果不更新,就只能
    //强制退出程序了
//    progressDialog.setCancelable(false);//不允许被某些方式取消,比如按对话框之外的区域或者是返回键
    progressDialog.setProgress(50);
  }

  /**
   * 创建一个日期弹窗
   */
  private void createDateDialog() {
    new DatePickerDialog(this, new DatePickerDialog.OnDateSetListener() {
      /**
       *
       * @param view 当前日期选择的 view
       * @param year 当前选择的年
       * @param monthOfYear 当前选择的月,从0开始算
       * @param dayOfMonth,当前选择的日,从1开始算
       */
      @Override
      public void onDateSet(DatePicker view, int year, int monthOfYear, int dayOfMonth) {
        Toast.makeText(MainActivity.this, "view = " + view + "年:" + year + "月:" + monthOfYear + "日" + dayOfMonth, Toast.LENGTH_SHORT).show();
      }
    }, 2016, 7, 15)//这里注意一下的是月份系统表示的是从0开始的,0表示1月,1表示2月.....11表示12月
    .show();
  }

  /**
   * 创建一个时间弹窗
   */
  private void createTimeDialog() {
    new TimePickerDialog(this, new TimePickerDialog.OnTimeSetListener() {
      /**
       *
       * @param view 当前时间选择的view
       * @param hourOfDay 小时
       * @param minute 分钟
       */
      @Override
      public void onTimeSet(TimePicker view, int hourOfDay, int minute) {
        Toast.makeText(MainActivity.this, "时间弹窗 view = " + view + "hourOfDay = " + hourOfDay + "minute = " + minute, Toast.LENGTH_SHORT).show();
      }
    }, 11, 22, true)
    .show();
  }

  /**
   * 创建一个多选弹窗
   */
  private void createMutilDialog() {
    new AlertDialog.Builder(this)
        .setTitle("多选弹框")
        .setIcon(R.mipmap.ic_launcher)
        //第二个参数 boolean数组, 如果写 null 代表默认全部是非选中, 如果想指定某几个选中,
        //需要创建对应长度的数据,按照位置的顺序,将指定位置设置为 true 即可, 数组长度不能小
        //于数据源的长度,否则会越界,但是可以大于数据源的长度
        .setMultiChoiceItems(R.array.list, new boolean[]{true, false, false, true, false, false, false, false, false, false, false, false, false}, new DialogInterface.OnMultiChoiceClickListener() {
          /**
           *
           * @param dialog 当前点击的对话框
           * @param which 当前点击的条目
           * @param isChecked 被点击条目的选中状态
           */
          @Override
          public void onClick(DialogInterface dialog, int which, boolean isChecked) {
            Toast.makeText(MainActivity.this, "当前点击的是" + which + " 是否选中" + isChecked, Toast.LENGTH_SHORT).show();
          }
        })
        //设置取消按钮,并且设置监听事件
        .setNegativeButton("cancel", new DialogInterface.OnClickListener() {
          @Override
          public void onClick(DialogInterface dialog, int which) {
            dialog.dismiss();
          }
        })
        //确认按钮,默认点击会直接取消该窗口
        .setPositiveButton("sure", new DialogInterface.OnClickListener() {
          @Override
          public void onClick(DialogInterface dialog, int which) {

          }
        })
        .setCancelable(false)
        .show();
  }

  /**
   * 创建一个单选弹窗
   */
  private void createSingleDialog() {
    new AlertDialog.Builder(this)
        .setTitle("单选弹窗")
        .setIcon(R.mipmap.ic_launcher)
        //构造参数, 1 数据源,2 默认被选中的索引,3 条目的点击事件
        .setSingleChoiceItems(R.array.list, 1, new DialogInterface.OnClickListener() {
          /**
           *
           * @param dialog 当前的对话框
           * @param which 当前点击的是列表的第几个 item
           */
          @Override
          public void onClick(DialogInterface dialog, int which) {
            Toast.makeText(MainActivity.this, "单选弹窗 dialog = " + dialog + "which = " + which, Toast.LENGTH_SHORT).show();
          }
        })
        .setNegativeButton("cancel", new DialogInterface.OnClickListener() {
          @Override
          public void onClick(DialogInterface dialog, int which) {
            dialog.dismiss();
          }
        })
        .setPositiveButton("sure", new DialogInterface.OnClickListener() {
          @Override
          public void onClick(DialogInterface dialog, int which) {

          }
        })
        .setCancelable(false)//不允许被某些方式取消,比如按对话框之外的区域或者是返回键
        .show();
  }

  /**
   * 创建一个列表弹窗
   */
  private void createListDialog() {
    AlertDialog.Builder builder = new AlertDialog.Builder(this);
    builder.setTitle("列表弹窗");
    builder.setItems(R.array.list, new DialogInterface.OnClickListener() {
      /**
       *
       * @param dialog 当前的对话框
       * @param which 当前点击的是列表的第几个 item
       */
      @Override
      public void onClick(DialogInterface dialog, int which) {
        Toast.makeText(MainActivity.this, "列表 dialog = " + dialog + "which = " + which, Toast.LENGTH_SHORT).show();
      }
    });
    builder.setCancelable(false);//不允许被某些方式取消,比如按对话框之外的区域或者是返回键
    builder.show();
  }
}

列表弹窗:

单选弹窗:

多选弹窗:

日期弹窗:

时间弹窗:

进度条弹窗:

差不多常见的几种都在这里了,至于还有一个PopupWindow这里暂时不作介绍。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android屏幕锁屏弹窗的正确姿势DEMO详解

    在上篇文章给大家介绍了Android程序开发仿新版QQ锁屏下弹窗功能.今天通过本文给大家分享android锁屏弹窗的正确姿势. 最近在做一个关于屏幕锁屏悬浮窗的功能,于是在网上搜索了很多安卓屏幕锁屏的相关资料,鉴于网上的资料比较零碎,所以我在这里进行整理总结.本文将从以下两点对屏幕锁屏进行解析: 1. 如何监听系统屏幕锁屏 2. 如何在锁屏界面弹出悬浮窗 如何监听系统屏幕锁屏 经过总结,监听系统的锁屏可以通过以下两种方式: 1) 代码直接判定 2) 接收广播 1) 代码直接判定 代码判断方式,也

  • Android编程实现的自定义弹窗(PopupWindow)功能示例

    本文实例讲述了Android编程实现的自定义弹窗(PopupWindow)功能.分享给大家供大家参考,具体如下: 在开发过程中,如果要弹出一个对话框,一般是使用AlertDialog,但其使用限制太大,灵活性不够,所以我们常需要用到灵活性更高的PopupWindow, 如图,当点击显示的时候,就会弹出一个对话框,当点击确定或屏幕其它任意地方,就可以将PopupWindow取消了,接下来贴出重要代码. PopupWindow pw = new PopupWindow(view.getContext

  • Android监听输入法弹窗和关闭的实现方法

    用过ios的都知道ios上输入法关闭的同时会自动关闭输入框,那么在android上如何实现监听输入法弹出和关闭呢?本篇文章就为你提供了一种可靠的实现方式. 演示效果视频地址 首先在AndroidManifest中配置 android:windowSoftInputMode="adjustResize" 这样每次输入法弹出和关闭都会重新计算高度实现把布局顶上去的效果 然后我们要自定义一个布局,监听布局大小变化 public class CheckSoftInputLayout exten

  • Android控件PopupWindow模仿ios底部弹窗

    前言 在H5火热的时代,许多框架都出了底部弹窗的控件,在H5被称为弹出菜单ActionSheet,今天我们也来模仿一个ios的底部弹窗,取材于苹果QQ的选择头像功能. 正文 废话不多说,先来个今天要实现的效果图 整个PopupWindow的开启代码 private void openPopupWindow(View v) { //防止重复按按钮 if (popupWindow != null && popupWindow.isShowing()) { return; } //设置Popup

  • Android程序开发仿新版QQ锁屏下弹窗功能

    新版的qq,可以在锁屏下弹窗显示qq消息,正好目前在做的项目也需要这一功能.经过各种试验和资料查找,终于实现,过程不难,但是却有一些地方需要注意. 下面是实现过程. 1.使用Activity,而不是View QQ的弹窗一开始我以为是悬浮View,用WindowManager去添加,但是无论如何就是不显示,后来在朋友提示下换成Activity来实现,在锁屏状态下就能弹窗了. 2.Activity的设置 Activity需要进行以下设置,才可以在锁屏状态下弹窗. 首先是onCreate方法,需要添加

  • Android自定义带增长动画和点击弹窗提示效果的柱状图DEMO

    项目中最近用到各种图表,本来打算用第三方的,例如MPAndroid,这是一个十分强大的图表库,应用起来十分方便,但是最终发现和设计不太一样,没办法,只能自己写了.今天将写好的柱状图的demo贴在这,该柱状图可根据数据的功能有一下几点: 1. 根据数据的多少,动态的绘制柱状图柱子的条数: 2. 柱状图每条柱子的绘制都有动态的动画效果: 3. 每条柱子有点击事件,点击时弹出提示框,显示相关信息,规定时间后,弹窗自动消失. 好了,先上演示图: 下边贴出相关代码: 自定义柱状图类: package co

  • Android仿支付宝支付从底部弹窗效果

    我们再用支付宝支付的时候,会从底部弹上来一个对话框,让我们选择支付方式等等,今天我们就来慢慢实现这个功能 效果图 实现 主界面很简单,就是一个按钮,点击后跳到支付详情的Fragment中 package com.example.hfs.alipayuidemo; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.View; import android.wi

  • Android仿支付宝微信支付密码界面弹窗封装dialog

    一,功能效果 二,实现过程 1,先写xml文件:dialog_keyboard.xml 注意事项 (1),密码部分用的是一个线性布局中6个TextView,并设置android:inputType="numberPassword",外框是用的一个有stroke属性的shape, (2),1-9数字是用的recycleview ,每个item的底部和右边有1dp的黑线,填充后形成分割线. (3),recycleview 要设置属性  android:overScrollMode=&quo

  • Android实现底部弹窗效果

    本文实例为大家分享了Android实现底部弹窗效果的具体代码,供大家参考,具体内容如下 源代码地址:https://github.com/luoye123/Box 东西很简单,我就直接亮代码了: 1.activity_main.xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/

  • Android实现底部支付弹窗效果

    Android底部支付弹窗实现的效果: 实现的思路: 1.通过继承PopupWindow自定义View来达到弹窗的弹出效果: 2.通过回调将输入的密码由弹窗传入到主界面中: 2.恩,这就够了-->有些注意点在代码中备注: 自定义View的代码: public class BottomDialogView extends PopupWindow { private View dialogView; private EditText payPassEt; private Button cancelB

随机推荐