自定义 Dialog (B)_dialog b-程序员宅基地

技术标签: android-view  

本文所用的知识点很简单,但很实用,非喜勿喷

目录

一、通过 AlertDialog ,快速使用自定义Dialog 。

二、自定义AlertDialog的宽度

三、DialogFragment 创建对话框

重点:AlertDialog 要在主线程才可以显示/隐藏。但DialogFragment可以在子线程中显示 /隐藏

正文:

一、通过 AlertDialog ,快速使用自定义Dialog 。

包含输入框。(等待框,普通的消息展示dialog道理相同。一般一个项目写三个通用的Dialog:等待框,普通的消息,包含输入框)

1、使用方法

MyDialogInputBuilder builder=new MyDialogInputBuilder(this);
//注意方法 setCancelable :alertDialog是否可以点击外围消失
builder.setTitle("title").setMessage("message").setCancelable(false);
builder.setPositiveButton("确认", new MyDialogInputBuilder.MyInputOnClickListener() {
    @Override
    public void onClick(DialogInterface dialog,String str) {
        //String str 的值为用户输入的值
        Log.w("test","PositiveButton onClick");
        Toast.makeText(LoginActivity.this,"点击了确认按钮 str="+str,Toast.LENGTH_SHORT).show();
        dialog.dismiss();
    }
});
builder.setNegativeButton("cancle", null);
alertDialog = builder.create();
alertDialog.show();

2、原码

public class MyDialogInputBuilder {
    private Context context;
    private String title;
    private String message;
    private String strPositive;
    private String strNegative;
    private MyInputOnClickListener positivelistener;
    private MyInputOnClickListener negativelistener;

    private boolean mCancelable = true;

    public MyDialogInputBuilder(Context context) {
        this.context=context;
        deleteDate();
    }
    private void deleteDate(){
        title=null;
        message=null;
        strPositive=null;
        strNegative=null;
        positivelistener=null;
        negativelistener=null;
    }
    public MyDialogInputBuilder setTitle(String title) {
        this.title = title;
        return this;
    }
    public MyDialogInputBuilder setMessage(String message) {
        this.message = message;
        return this;
    }

    /**
     * alertDialog是否可以点击外围消失
     * @param cancelable true 表示可以消失
     * @return
     */
    public MyDialogInputBuilder setCancelable(boolean cancelable) {
        this.mCancelable = cancelable;
        return this;
    }
    public MyDialogInputBuilder setPositiveButton(String text, MyInputOnClickListener listener) {
        this.strPositive = text;
        this.positivelistener = listener;
        return this;
    }
    public MyDialogInputBuilder setNegativeButton(String text, MyInputOnClickListener listener) {
        this.strNegative = text;
        this.negativelistener = listener;
        return this;
    }

    private EditText inputText;
    public AlertDialog create() {
        AlertDialog.Builder builder=new AlertDialog.Builder(this.context);
        View mView = LayoutInflater.from(this.context).inflate(R.layout.common_dialog_input, null);
        TextView tvTitle = (TextView)mView.findViewById(R.id.common_dialog_input_tips_titile);
        inputText = (EditText)mView.findViewById(R.id.common_dialog_input_tips_input);
        Button btnPositive =(Button) mView.findViewById(R.id.common_dialog_input_tips_btn_yes);
        Button btnNegative =(Button) mView.findViewById(R.id.common_dialog_input_tips_btn_no);
        if(isEmpty(title)){
            tvTitle.setVisibility(View.GONE);
        }else{
            tvTitle.setVisibility(View.VISIBLE);
            tvTitle.setText(title.trim());
        }
        if (isEmpty(strPositive)) {
            btnPositive.setVisibility(View.GONE);
        } else {
            btnPositive.setText(strPositive.trim());
        }
        if (isEmpty(strNegative)) {
            btnNegative.setVisibility(View.GONE);
        } else {
            btnNegative.setText(strNegative.trim());
        }
        inputText.setHint(message.trim());
        //tvMessage.setText(message.trim());
        builder.setView(mView).setCancelable(mCancelable);
        final AlertDialog dialog=builder.create();
        dialog.setCancelable(mCancelable);
        if (mCancelable) {
            dialog.setCanceledOnTouchOutside(true);
        }
        if(!isEmpty(strPositive) && positivelistener==null){
            btnPositive.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    dialog.dismiss();
                }
            });
        }else if(!isEmpty(strPositive) && positivelistener!=null){
            btnPositive.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    positivelistener.onClick(dialog,inputText.getText().toString());
                }
            });
        }
        if(!isEmpty(strNegative) && negativelistener==null){
            btnNegative.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    dialog.dismiss();
                }
            });
        }else if(!isEmpty(strNegative) && negativelistener!=null){
            btnNegative.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    negativelistener.onClick(dialog,inputText.getText().toString());
                }
            });
        }
        return dialog;
    }

    private  boolean isEmpty(String str){
        if (str==null || str.trim().equals("")){
            return true;
        }else{
            return false;
        }
    }

    public interface MyInputOnClickListener{
        void onClick(DialogInterface dialog,String inputStr);
    }
}

布局

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

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        android:layout_marginLeft="20dp"
        android:layout_marginTop="15dp"
        android:layout_marginBottom="10dp"
        android:gravity="center"
        >
        <ImageView
            android:id="@+id/common_dialog_input_tips_title_icon"
            android:layout_width="25dp"
            android:layout_height="25dp"
            android:src="@android:drawable/ic_dialog_info"
            />

        <TextView
            android:id="@+id/common_dialog_input_tips_titile"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_marginLeft="5dp"
            android:text="温馨提示"
            android:textColor="@android:color/white"
            android:textSize="18dp" />

    </LinearLayout>


    <TextView
        android:layout_width="match_parent"
        android:layout_height="1dp"
        android:background="@android:color/darker_gray" />

    <EditText
        android:id="@+id/common_dialog_input_tips_input"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_marginLeft="20dp"
        android:layout_marginTop="10dp"
        android:layout_marginRight="20dp"
        android:layout_marginBottom="10dp"
        android:gravity="left"
        android:textColor="@android:color/white"
        android:textSize="16dp"
        />
   

    <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:gravity="center"
        android:layout_marginBottom="10dp"
        android:layout_marginTop="10dp"
        android:layout_marginRight="20dp"
        android:layout_marginLeft="20dp"
        android:orientation="horizontal">

        <Button
            android:id="@+id/common_dialog_input_tips_btn_no"
            android:layout_width="0dp"
            android:layout_height="30dp"
            android:layout_marginRight="7dp"
            android:layout_weight="1"
            android:background="@android:color/holo_green_dark"
            android:gravity="center"
            android:text="否"
            android:textColor="@android:color/white" />


        <Button
            android:id="@+id/common_dialog_input_tips_btn_transfer"
            android:layout_width="0dp"
            android:layout_height="30dp"
            android:layout_weight="1"
            android:background="@android:color/holo_blue_dark"
            android:gravity="center"
            android:text="转移"
            android:textColor="@android:color/white"
            android:visibility="gone"
        />

        <Button
            android:id="@+id/common_dialog_input_tips_btn_yes"
            android:layout_width="0dp"
            android:layout_height="30dp"
            android:layout_marginLeft="7dip"
            android:layout_weight="1"
            android:background="@android:color/holo_red_dark"
            android:gravity="center"
            android:text="是"
            android:textColor="@android:color/white" />

        <!-- android:background="@android:color/holo_red_dark"-->

    </LinearLayout>


</LinearLayout>

 

二、自定义AlertDialog的宽度

1、方法1 alertDialog.getWindow().setAttributes(LayoutParams );

if (window != null) {
    window.getDecorView().setPadding(0, 0, 0, 0);
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN) {
        window.getDecorView().setBackground(context.getResources().getDrawable(res));
    }
   int width=0;
   if(context instanceof Activity){
       WindowManager manager = ((Activity)context).getWindowManager();
       Display defaultDisplay = manager.getDefaultDisplay();
       Point point = new Point();
       defaultDisplay.getSize(point);
       //int x = point.x;
       width=point.x * 5 / 6;
   }else{
       width= Tools.dipTopx(context,300);
   }
    android.view.WindowManager.LayoutParams lp = alertDialog.getWindow()
            .getAttributes();
    lp.gravity = Gravity.CENTER;
    lp.width = width;
    lp.height = WindowManager.LayoutParams.WRAP_CONTENT;
    alertDialog.getWindow().setAttributes(lp);
    alertDialog.setCancelable(touchCancel);
    alertDialog.setCanceledOnTouchOutside(touchCancel);
    window.setWindowAnimations(R.style.alertDialogStyle01);
}

2、方法2 。

 dialog.getWindow().setLayout(DensityUtil.dip2px(context,300), LinearLayout.LayoutParams.WRAP_CONTENT);

DensityUtil.dip2px是dp转px的工具类

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/tantion/article/details/103822156

智能推荐

spark2原理分析-RDD的shuffle简介_rdd shuffle-程序员宅基地

文章浏览阅读868次。概述本文介绍RDD的Shuffle原理,并分析shuffle过程的实现。RDD Shuffle简介spark的某些操作会触发被称为shuffle的事件。shuffle是Spark重新分配数据的机制,它可以对数据进行分组,该操作可以跨不同分区。该操作通常会在不同的执行器(executor)和主机之间复制数据,这使shuffle成为复杂且非常消耗资源的操作。Shuffle背景为了理解shuf..._rdd shuffle

python3 os.system 异步执行_Python执行系统命令的方法 os.system(),os.popen(),commands-程序员宅基地

文章浏览阅读3.8k次。最近在做那个测试框架的时候发现 Python 的另一个获得系统执行命令的返回值和输出的类。1.最开始的时候用 Python 学会了 os.system() 。这个方法是拥塞的。os.system('ping www.baidu.com')2.通过 os.popen() 返回的是 file read 的对象,对其进行读取 read() 的操作可以看到执行的输出。这个方法是后台执行,不影响后续脚本运行..._os.system异步执行

CM+CDH安装搭建全过程(总结版)_cloudera manager server gc cpu usage is at 10% or -程序员宅基地

文章浏览阅读2.9k次。目录第一次搭建CM、CDH第二次搭建CM、CDH搭建环境:搭建过程:报错过程:总结复盘:第三次搭建CM、CDH搭建环境:搭建过程:报错过程:总结复盘:第四次搭建CM、CDH搭建环境:搭建过程:报错过程:总结复盘:第一次搭建CM、CD..._cloudera manager server gc cpu usage is at 10% or more of total process time

内核开发调试printk_printk 头文件-程序员宅基地

文章浏览阅读706次。进行内核开发调试在进行驱动开发的过程中往往要打印一些信息来查看是否正确类似于printf,以下将介绍在内核开发常用的调试方法。.(第一次写文章,内容可能不咋样勿喷呀)内容一、printk介绍二、如何查看并修改消息级别在应用程序采用printf打印调试、内核驱动采用printk打印调试。printk函数打印数据到console缓冲区,打印的格式方类似printf。printk函数说明头文件:<linux/kernel.h>int printk(KERN_XXX const_printk 头文件

Kafka原理、部署与实践——深入理解Kafka的工作原理和使用场景,全面介绍Kafka在实际生产环境中的部署_kafka如何负载使用一台对外的机器-程序员宅基地

文章浏览阅读2.5k次。随着互联网的发展,网站的流量呈爆炸性增长,传统的基于关系型数据库的数据处理无法快速响应。而NoSQL技术如HBase、MongoDB等被广泛应用于分布式数据存储与处理,却没有提供像关系型数据库一样的ACID特性、JOIN操作及完整性约束。因此,很多公司或组织开始转向Apache Spark、Flink、Beam等新一代大数据处理框架来处理海量数据。然而,由于新一代大数据处理框架依赖于HDFS等文件系统,导致集群规模扩容困难、成本高昂。另一方面,云计算平台的出现让用户可以快速部署、扩展大数据处理集群。_kafka如何负载使用一台对外的机器

麒麟KYLINOS桌面操作系统2303上安装tigervnc_麒麟系统电脑安装vncserver-程序员宅基地

文章浏览阅读1.4k次。hello,大家好啊,今天给大家带来在麒麟桌面操作系统2303上安装tigervnc的文章,本篇文章给大家讲述如何安装并且远程连接使用,后面会给大家更新如何将tigervnc做成桌面图标点击即可开启及关闭,欢迎大家浏览分享转发。_麒麟系统电脑安装vncserver

随便推点

设备驱动模型:总线-设备-驱动_总线设备驱动模型-程序员宅基地

文章浏览阅读1.3k次,点赞5次,收藏12次。总线是连接处理器和设备之间的桥梁代表着同类设备需要共同遵循的工作时序。总线驱动:负责实现总线行为,管理两个链表。name:指定总线的名称,当新注册一种总线类型时,会在 /sys/bus 目录创建一个新的目录,目录名就是该参数的值;bus_groups、dev_groups、drv_groups:分别表示 总线、设备、驱动的属性。通常会在对应的 /sys 目录下在以文件的形式存在,对于驱动而言,在目录 /sys/bus//driver/ 存放了驱动的默认属性;_总线设备驱动模型

TensorFlow精进之路(十五):深度神经网络简介_tensorflow 精进之路-程序员宅基地

文章浏览阅读265次。1、概述本来想用卷积神经网络来预测点东西,但是效果嘛......,还是继续学习图像类的应用吧~前面学习的神经网络都是一些基础的结构,这些网络在各自的领域中都有一定效果,但是解决复杂问题肯定不够的,这就需要用到深度神经网络。深度神经网络是将前面所学的网络组合起来,利用各自网络的优势,使整体效果达到最优。这一节就简单的记下一些常用的深度神经网络模型,因为tensorflow等框架都将这些网络实现..._tensorflow 精进之路

第九十四篇 Spark+HDFS centos7环境搭建_spark写入hdfs需要用户名密码吗-程序员宅基地

文章浏览阅读2.6k次。一、安装包下载:Spark 官网下载: https://spark.apache.org/downloads.htmlHadoop 官网下载: https://hadoop.apache.org/releases.html目前使用Spark 版本为: spark-2.4.3 Hadoop版本为: hadoop-2.10.1二、配置自登陆检测是否可以自登陆,不需要密码则配置正常:ssh localhost在搭建Hadoop环境时,出现localhost.localdomain: Permis_spark写入hdfs需要用户名密码吗

Node.js_node可以使用什么命令 ,它会自动找到该文件下的start指令,执行入口文件。-程序员宅基地

文章浏览阅读280次。nodejs。_node可以使用什么命令 ,它会自动找到该文件下的start指令,执行入口文件。

linux图片相似度检测软件下载,移动端图像相似度算法选型-程序员宅基地

文章浏览阅读293次。概述电商场景中,卖家为获取流量,常常出现重复铺货现象,当用户发布上传图像或视频时,在客户端进行图像特征提取和指纹生成,再将其上传至云端指纹库对比后,找出相似图片,杜绝重复铺货造成的计算及存储资源浪费。该方法基于图像相似度计算,可广泛应用于安全、版权保护、电商等领域。摘要端上的图像相似度计算与传统图像相似度计算相比,对计算复杂度及检索效率有更高的要求。本文通过设计实验,对比三类图像相似度计算方法:感..._linux 图片相似度对比

java isprime函数_判断质数(isPrime)的方法——Java代码实现-程序员宅基地

文章浏览阅读3.8k次。判断质数(isPrime)的方法——Java代码实现/** 质数又称素数。一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数叫做质数;否则称为合数* 100以内质数表2 3 5 7 11 13 17 19 23 29 31 37 41 43 4753 59 61 67 71 73 79 83 89 97质数具有许多独特的性质:(1)质数p的约数只有两个:1和p。(2)初等数学基本定理:..._java isprime

推荐文章

热门文章

相关标签