Android 弹窗 DialogFragment

2024-06-03 05:48

本文主要是介绍Android 弹窗 DialogFragment,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

一直以来 , 做弹窗功能的时候都是使用的Dialog , 布局复杂的弹窗则使用Activity , 把背景设置成透明, 最近了解到一个DialogFragment , 发现使用起来更加方便, 也是谷歌建议的做法.

简介

DialogFragment 继承自Fragment , 所以它的用法基本跟Fragment一致 , 也包含了一些生命周期和上下文context 和 监听之类的东西. 而且fragment可以定义它的布局, 非常适合我们开发时候用做复杂UI弹窗的实现.

DialogFragment内嵌了一个Dialog , 可以在fragment中管理它的dialog , 比普通的Dialog用起来更加方便 .

因为Fragment中有onCreateView展示自己的布局, 又内嵌了一个dialog来展示布局 , 所以其实重写其中一个方法就够了 , 如果重写两个呢?

DialogFragment优先查找Dialog , 如果实现了onCreateDialog则会展示onCreateDialog中的内容 , 否则才会展示onCreateView中的布局.

使用

创建

首先创建一个集成自DiaglogFragment的类 , 并实现onCreateDialog / onCreateView .

class MyDialogFragment constructor(private var title: String = "", private var msg: String = "") :DialogFragment() {companion object {private const val KEY_TITLE = "key_title_extra"private const val KEY_MSG = "key_msg_extra"fun newInstance(title: String = "", msg: String = ""): MyDialogFragment {val fragment = MyDialogFragment()val bundle = Bundle()bundle.putString(KEY_TITLE, title)bundle.putString(KEY_MSG, msg)fragment.arguments = bundlereturn fragment}}override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)val bundle = argumentstitle = bundle?.getString(KEY_TITLE).toString()msg = bundle?.getString(KEY_MSG).toString()}/*** 有[onCreateDialog]的时候优先显示[onCreateDialog]* 如果没有则显示[onCreateView]*/override fun onCreateDialog(savedInstanceState: Bundle?): Dialog {val builder = context?.let { AlertDialog.Builder(it) }builder?.setTitle(title)builder?.setMessage(msg)return builder?.create()!!}@SuppressLint("InflateParams", "SetTextI18n")override fun onCreateView(inflater: LayoutInflater,container: ViewGroup?,savedInstanceState: Bundle?): View? {val view = LayoutInflater.from(context).inflate(R.layout.dialog_test, null)view.dialog_title.text = titleview.dialog_msg.text = msgreturn view}
}

这里我先写了一个简单的MyDialogFragment , 重写了onCreateDialogonCreateView 两个方法

  • onCreateDialog很简单, 只有一个标题和一个内容, 共两个字符串

  • onCreateView中的layout其实也只有两个textview , 分别显示标题和内容.

标题和内容是由调用的地方传进来的, 所以我写了一个默认的方法 , 用来传入参数 , 并在 onCreate 中接收传来的参数.

调用

因为我们已经封装了一个传入参数的方法, 所以调用的时候就很简单了:

 MyDialogFragment.newInstance("hello title", "hello world").show(supportFragmentManager, "1")

其实这个拆开来就是:

val myDialogFragment = MyDialogFragment.newInstance("hello title", "hello world")
myDialogFragment.show(supportFragmentManager, "1")

先创建了MyDialogFragment的实例 , 然后调用了它的show()方法 .
对应的则是有一个dissmiss方法来关闭弹窗 :

myDialogFragment.dismiss()

代码写完, 我们看一下效果:
在这里插入图片描述
这个布局, 很明显是dialog的默认布局了 ,
而我们实现了onCreateDialogonCreateView两个方法, 也证实了我们上面说的会优先显示dialog的UI.
之后 , 我们注释掉onCreateDialog 再看一下:
在这里插入图片描述
这次 , 就只显示了onCreateView中的UI. 然后我们给这个textview添加一个关闭它自己的方法:

    override fun onCreateView(inflater: LayoutInflater,container: ViewGroup?,savedInstanceState: Bundle?): View? {val view = LayoutInflater.from(context).inflate(R.layout.dialog_test, null)view.dialog_title.text = titleview.dialog_msg.text = msg//add thisview.dialog_msg.setOnClickListener { dismiss() }return view}

这次点击这个msgtextview就会关闭这个弹窗了 .
当然了, 它跟dialog的默认逻辑一样 , 可以点击灰色部分关闭弹窗.

我们也可以设置它是否允许点击外部和返回键来关闭弹窗 :
默认为true , 允许关闭.
在kotlin中只需要一行代码

 isCancelable = false

在onCreate中写即可, 如果你想根据onCreateDiakogonCreateiew中使用不同的逻辑 , 也可以分别在这两个方法中写.

在java中则需要调用setCancelable (boolean)方法

设置弹窗位置和尺寸大小

创建弹窗时 .弹窗的位置和大小是固定的. 始终在中间显示, 并且距离左右两侧有一定的边距 .
有时候UI设计出来的会边距更大/更小, 甚至没有边距, 这时候就要设置它的尺寸了 . 但直接在xml中写是没有效果的, 需要代码来控制.
我们可以在dialogFragment中重写onStart方法:

override fun onStart() {super.onStart()val window = dialog!!.window//设置弹窗的背景色,才能设置弹窗的尺寸和位置window?.setBackgroundDrawableResource(zhuoyuan.li.kotlinstudy.R.color.colorAccent)val attributes = window!!.attributes//获取屏幕数据val displayMetrics = resources.displayMetrics//获取屏幕宽高val widthPixels = displayMetrics.widthPixels//指定弹窗内容宽高attributes.width = widthPixelsattributes.height = 600//默认位置就是居中attributes.gravity = Gravity.CENTERwindow.attributes = attributes}

可以看到, 如果想设置弹窗的大小, 一定要给它设置一个背景色, 不过要注意 ,

  • onCreateDialogonCreateView的背景色都会使用这个.

  • onCreateView创建的弹窗, 如果在 xml中布局设置了背景色是会覆盖掉这个颜色的. 使用xml中的颜色

这篇关于Android 弹窗 DialogFragment的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1026147

相关文章

Android WebView无法加载H5页面的常见问题和解决方法

《AndroidWebView无法加载H5页面的常见问题和解决方法》AndroidWebView是一种视图组件,使得Android应用能够显示网页内容,它基于Chromium,具备现代浏览器的许多功... 目录1. WebView 简介2. 常见问题3. 网络权限设置4. 启用 JavaScript5. D

Android如何获取当前CPU频率和占用率

《Android如何获取当前CPU频率和占用率》最近在优化App的性能,需要获取当前CPU视频频率和占用率,所以本文小编就来和大家总结一下如何在Android中获取当前CPU频率和占用率吧... 最近在优化 App 的性能,需要获取当前 CPU视频频率和占用率,通过查询资料,大致思路如下:目前没有标准的

Android开发中gradle下载缓慢的问题级解决方法

《Android开发中gradle下载缓慢的问题级解决方法》本文介绍了解决Android开发中Gradle下载缓慢问题的几种方法,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、网络环境优化二、Gradle版本与配置优化三、其他优化措施针对android开发中Gradle下载缓慢的问

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Android里面的Service种类以及启动方式

《Android里面的Service种类以及启动方式》Android中的Service分为前台服务和后台服务,前台服务需要亮身份牌并显示通知,后台服务则有启动方式选择,包括startService和b... 目录一句话总结:一、Service 的两种类型:1. 前台服务(必须亮身份牌)2. 后台服务(偷偷干

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

Ubuntu 24.04 LTS怎么关闭 Ubuntu Pro 更新提示弹窗?

《Ubuntu24.04LTS怎么关闭UbuntuPro更新提示弹窗?》Ubuntu每次开机都会弹窗提示安全更新,设置里最多只能取消自动下载,自动更新,但无法做到直接让自动更新的弹窗不出现,... 如果你正在使用 Ubuntu 24.04 LTS,可能会注意到——在使用「软件更新器」或运行 APT 命令时,

Android WebView的加载超时处理方案

《AndroidWebView的加载超时处理方案》在Android开发中,WebView是一个常用的组件,用于在应用中嵌入网页,然而,当网络状况不佳或页面加载过慢时,用户可能会遇到加载超时的问题,本... 目录引言一、WebView加载超时的原因二、加载超时处理方案1. 使用Handler和Timer进行超

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo