Android实现底部弹出的对话框功能

环境:

  1. 主机:WIN10
  2. 开发环境:Android Studio 2.2 Preview 3

说明:
两种方法实现底部弹出的对话框:

  1. Dialog
  2. DialogFragment

推荐用DialogFragment

效果图:

布局文件dialog_select_call.xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:orientation="vertical" android:layout_width="match_parent"
  android:layout_height="match_parent"> 

  <RelativeLayout
    android:id="@+id/layout_voice"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="@color/white"> 

    <TextView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_alignParentStart="true"
      android:layout_centerInParent="true"
      android:textSize="16sp"
      android:textColor="@color/black"
      android:layout_marginLeft="16dp"
      android:layout_marginRight="16dp"
      android:layout_marginTop="16dp"
      android:layout_marginBottom="16dp"
      android:text="语音课堂"/>
  </RelativeLayout> 

  <View
    android:layout_width="fill_parent"
    android:layout_height="0.1dp"
    android:background="#b4b4b4"
    android:layout_marginLeft="16dp"
    android:layout_marginRight="16dp"/> 

  <RelativeLayout
    android:id="@+id/layout_video"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="@color/white"> 

    <TextView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_alignParentStart="true"
      android:layout_centerInParent="true"
      android:textSize="16sp"
      android:textColor="@color/black"
      android:layout_marginLeft="16dp"
      android:layout_marginRight="16dp"
      android:layout_marginTop="16dp"
      android:layout_marginBottom="16dp"
      android:text="视频课堂"/>
  </RelativeLayout> 

  <View
    android:layout_width="fill_parent"
    android:layout_height="0.1dp"
    android:background="#b4b4b4"
    android:layout_marginLeft="16dp"
    android:layout_marginRight="16dp"/> 

  <RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="@color/white"> 

    <Button
      android:id="@+id/cancel"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:text="取消"
      android:layout_marginLeft="16dp"
      android:layout_marginRight="16dp"
      android:layout_marginTop="16dp"
      android:layout_marginBottom="16dp"/>
  </RelativeLayout> 

</LinearLayout>

Dialog实现源码:

初始化:

private void dialogSelectCallInit() {
    dialogSelectCall = new Dialog(this, R.style.DialogPopBottom);
    View inflate = LayoutInflater.from(this).inflate(R.layout.dialog_select_call, null);
    dialogSelectCall.setContentView(inflate); 

    Window dialogWindow = dialogSelectCall.getWindow();
    dialogWindow.setGravity(Gravity.BOTTOM); 

    WindowManager.LayoutParams lp = dialogWindow.getAttributes();
    lp.x = 0;
    lp.y = 0;
    lp.width = getResources().getDisplayMetrics().widthPixels;
    dialogWindow.setAttributes(lp); 

    RelativeLayout layoutVoice = (RelativeLayout) inflate.findViewById(R.id.layout_voice);
    RelativeLayout layoutVideo = (RelativeLayout) inflate.findViewById(R.id.layout_video);
    Button buttonCancel = (Button) inflate.findViewById(R.id.cancel); 

    RxView.clicks(layoutVoice)
        .throttleFirst(2, TimeUnit.SECONDS)
        .compose(this.bindUntilEvent(ActivityEvent.DESTROY))
        .subscribe(v -> {
//          dialogSelectCall.cancel();
          VoiceSessionActivity.startActivityCallOut(this, userId);
        }); 

    RxView.clicks(layoutVideo)
        .throttleFirst(2, TimeUnit.SECONDS)
        .compose(this.bindUntilEvent(ActivityEvent.DESTROY))
        .subscribe(v -> {
//          dialogSelectCall.cancel();
//          VideoSessionActivity.startActivityCallOut(this, userId);
        }); 

    RxView.clicks(buttonCancel)
        .throttleFirst(2, TimeUnit.SECONDS)
        .compose(this.bindUntilEvent(ActivityEvent.DESTROY))
        .subscribe(v -> dialogSelectCall.cancel()); 

    RxView.touches(layoutVoice, motionEvent -> {
      dealLayoutTouch(layoutVoice, motionEvent);
      return false;
    }).compose(this.bindUntilEvent(ActivityEvent.DESTROY)).subscribe(motionEvent -> {}); 

    RxView.touches(layoutVideo, motionEvent -> {
      dealLayoutTouch(layoutVideo, motionEvent);
      return false;
    }).compose(this.bindUntilEvent(ActivityEvent.DESTROY)).subscribe(motionEvent -> {});
  } 

  private void dealLayoutTouch(View v, MotionEvent event) {
    switch (event.getAction()) {
      case MotionEvent.ACTION_DOWN:
        v.setBackgroundColor(Color.rgb(200, 200, 200));
        break;
      case MotionEvent.ACTION_UP:
        v.setBackgroundColor(Color.WHITE);
        break;
    }
  }

显示对话框:

dialogSelectCall.show() 

DialogFragment实现源码:

定义了一个类SelectCallDialog.Java继承DialogFragment

package com.bazhangkeji.classroom.common; 

import android.app.Dialog;
import android.app.FragmentManager;
import android.graphics.Color;
import android.os.Bundle;
import android.support.annotation.NonNull;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.view.ViewGroup;
import android.view.Window;
import android.view.WindowManager;
import android.widget.Button;
import android.widget.RelativeLayout; 

import com.bazhangkeji.classroom.R;
import com.bazhangkeji.classroom.session.VideoSessionActivity;
import com.bazhangkeji.classroom.session.VoiceSessionActivity;
import com.jakewharton.rxbinding2.view.RxView;
import com.trello.rxlifecycle2.android.FragmentEvent;
import com.trello.rxlifecycle2.components.RxDialogFragment; 

import java.util.concurrent.TimeUnit; 

public class SelectCallDialog extends RxDialogFragment {
  private Dialog dialog;
  private String userId; 

  /**
   * 初始化.必须调用一次
   * @param userId: 目标用户id
   */
  public void init(String userId) {
    this.userId = userId;
  } 

  @NonNull
  @Override
  public Dialog onCreateDialog(Bundle savedInstanceState) {
    dialog = new Dialog(getActivity(), R.style.DialogPopBottom); 

    View inflate = LayoutInflater.from(getActivity()).inflate(R.layout.dialog_select_call, null);
    dialog.setContentView(inflate);
    dialog.setCanceledOnTouchOutside(true); 

    Window window = dialog.getWindow();
    WindowManager.LayoutParams lp = window.getAttributes();
    lp.gravity = Gravity.BOTTOM;
    lp.width = WindowManager.LayoutParams.MATCH_PARENT;
    window.setAttributes(lp); 

    RelativeLayout layoutVoice = (RelativeLayout) inflate.findViewById(R.id.layout_voice);
    RelativeLayout layoutVideo = (RelativeLayout) inflate.findViewById(R.id.layout_video);
    Button buttonCancel = (Button) dialog.findViewById(R.id.cancel); 

    RxView.clicks(layoutVoice)
        .throttleFirst(2, TimeUnit.SECONDS)
        .compose(this.bindUntilEvent(FragmentEvent.DESTROY))
        .subscribe(v -> {
          dialog.cancel();
          VoiceSessionActivity.startActivityCallOut(getActivity(), userId);
        }); 

    RxView.clicks(layoutVideo)
        .throttleFirst(2, TimeUnit.SECONDS)
        .compose(this.bindUntilEvent(FragmentEvent.DESTROY))
        .subscribe(v -> {
          dialog.cancel();
          VideoSessionActivity.startActivityCallOut(getActivity(), userId);
        }); 

    RxView.clicks(buttonCancel)
        .throttleFirst(2, TimeUnit.SECONDS)
        .compose(this.bindUntilEvent(FragmentEvent.DESTROY))
        .subscribe(v -> dialog.cancel()); 

    RxView.touches(layoutVoice, motionEvent -> {
      dealLayoutTouch(layoutVoice, motionEvent);
      return false;
    }).compose(this.bindUntilEvent(FragmentEvent.DESTROY)).subscribe(motionEvent -> {}); 

    RxView.touches(layoutVideo, motionEvent -> {
      dealLayoutTouch(layoutVideo, motionEvent);
      return false;
    }).compose(this.bindUntilEvent(FragmentEvent.DESTROY)).subscribe(motionEvent -> {}); 

    return dialog;
  } 

  private void dealLayoutTouch(View v, MotionEvent event) {
    switch (event.getAction()) {
      case MotionEvent.ACTION_DOWN:
        v.setBackgroundColor(Color.rgb(200, 200, 200));
        break;
      case MotionEvent.ACTION_UP:
        v.setBackgroundColor(Color.WHITE);
        break;
    }
  }
}

显示对话框前初始化参数:

selectCallDialog.init(userId); 

显示对话框后:

selectCallDialog.show(getFragmentManager(), "");

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

(0)

相关推荐

  • Android中AlertDialog各种对话框的用法实例详解

    目标效果: 程序运行,显示图一的几个按钮,点击按钮分别显示图二到图六的对话框,点击对话框的某一项或者按钮,也会显示相应的吐司输出. 1.activity_main.xml页面存放五个按钮. activity_main.xml页面: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools&

  • Android编程实现对话框Dialog背景透明功能示例

    本文实例讲述了Android编程实现对话框Dialog背景透明功能.分享给大家供大家参考,具体如下: 先看效果:   这是我做的一个拨号器强的面板,拨号的时候会查询手机中的联系人,显示在拨号面板上方,点击弹出透明对话框供选择. 这次重点是透明对话框. 先看对话框的theme,style文件: <?xml version="1.0" encoding="utf-8"?> <resources> <style name="sele

  • 详解Android应用中DialogFragment的基本用法

    DialogFragment的基本用法 1. 创建DialogFragment public class DialogA extends DialogFragment implements DialogInterface.OnClickListener { @Override public Dialog onCreateDialog(Bundle savedInstanceState) { AlertDialog.Builder builder = new AlertDialog.Builder

  • 实例详解Android自定义ProgressDialog进度条对话框的实现

    Android SDK已经提供有进度条组件ProgressDialog组件,但用的时候我们会发现可能风格与我们应用的整体风格不太搭配,而且ProgressDialog的可定制行也不太强,这时就需要我们自定义实现一个ProgressDialog. 通过看源码我们发现,ProgressDialog继承自Alertdialog,有一个ProgressBar和两个TextView组成的,通过对ProgressDialog的源码进行改进就可以实现一个自定义的ProgressDialog. 1.效果: 首先

  • Android加载对话框同时异步执行实现方法

    Android中通过子线程连接网络获取资料,同时显示加载进度对话框给用户的操作,需要Thread和Handler来完成,在Thread中执行比较耗时的代码,完成后再通过Handler发送消息给主线程,由主线程刷新UI. 在实现上比较的烦琐,为简化此方法,花了点时间封装了Thread和Handler,现在通过简单的代码就可以实现相同的功能,而把更多精力放到业务逻辑处理上! 效果如图:   复制代码 代码如下: LoadingDialog loadingDialog = new LoadingDia

  • Android中使用DialogFragment编写对话框的实例教程

    Android提供alert.prompt.pick-list,单选.多选,progress.time-picker和date-picker对话框,并提供自定义的dialog.在Android 3.0后,dialog基于fragment,并对之前版本提供兼容支持库,也就是说对于开发者而言,dialog是基于DialogFragment的,但此时需要在应用中加入相关的兼容库. 和Windows或者网页JS的Dialog不同,Android的dialog是异步的,而不是同步的.对于同步的dialog

  • Android编程自定义对话框(Dialog)位置及大小的方法

    本文实例讲述了Android编程自定义对话框(Dialog)位置及大小的方法.分享给大家供大家参考,具体如下: 代码: package angel.devil; import android.app.Activity; import android.app.Dialog; import android.os.Bundle; import android.view.Gravity; import android.view.Window; import android.view.WindowMana

  • Android中自定义对话框(Dialog)的实例代码

    1.修改系统默认的Dialog样式(风格.主题) 2.自定义Dialog布局文件 3.可以自己封装一个类,继承自Dialog或者直接使用Dialog类来实现,为了方便以后重复使用,建议自己封装一个Dialog类 第一步: 我们知道Android定义个控件或View的样式都是通过定义其style来实现的,查看Android框架中的主题文件,在源码中的路径:/frameworks/base/core/res/res/values/themes.xml,我们可以看到,Android为Dialog定义了

  • Android开发之基于DialogFragment创建对话框的方法示例

    本文实例讲述了Android基于DialogFragment创建对话框的方法.分享给大家供大家参考,具体如下: /** * 使用DialogFragment创建对话框 * @description: * @author ldm * @date 2016-5-12 下午2:00:01 */ public class FragmentAlertDialog extends Activity { private Button button; @Override protected void onCre

  • Android实现点击AlertDialog上按钮时不关闭对话框的方法

    本文实例讲述了Android实现点击AlertDialog上按钮时不关闭对话框的方法.分享给大家供大家参考.具体如下: 开发过程中,有时候会有这样的需求: 点击某个按钮之后显示一个对话框,对话框上面有一个输入框,并且有"确认"和"取消"两个按钮.当用户点击确认按钮时,需要对输入框的内容进行判断.如果内容为空则不关闭对话框,并toast提示. 使用AlertDialog.Builder创建对话框时,可以使用builder.setNegativeButton和build

  • Android中创建一个透明的进度对话框实例

    首先我们看一下什么叫做透明的进度对话框: 接下来我们讲一下如何创建:1.使用Eclipse创建一个新的Andr​​oid 项目,使用Android 2.2或以上.2.在/res/layout文件夹,创建线性布局activity_main.xml文件,主要是为了添加一个文本标签和一个按钮 复制代码 代码如下: activity_main.xml<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android&quo

随机推荐