Android开发系列(十一)Jetpack Compose之Dialog

     Dialogs是在应用程序中显示一些额外信息或进行用户交互的常见功能。Jetpack Compose中的Dialog可以通过使用AlertDialog组件来创建。

基本用法

    下面通过示例来了解Dialog的使用。

@OptIn(ExperimentalMaterial3Api::class)
@Composable
fun AlertDialogExample(onDismissRequest: () -> Unit,onConfirmation: () -> Unit,dialogTitle: String,dialogText: String,icon: ImageVector,
) {AlertDialog(icon = {Icon(icon, contentDescription = "Example Icon")},title = {Text(text = dialogTitle)},text = {Text(text = dialogText)},onDismissRequest = {onDismissRequest()},confirmButton = {TextButton(onClick = {onConfirmation()}) {Text("Confirm")}},dismissButton = {TextButton(onClick = {onDismissRequest()}) {Text("Dismiss")}})
}

    运行效果如下图所示。

在AlertDialog中,

  1. icon用于显示图标
  2. title用于显示标题
  3. text用于显示内容
  4. confirmButton用于显示确认按钮
  5. dismissButton用于显示取消按钮

 

自定义对话框布局

    AlertDialog使用内置的布局,

@Composable
fun DialogWithImage(onDismissRequest: () -> Unit,onConfirmation: () -> Unit,painter: Painter,imageDescription: String,
) {var showDialog by remember {mutableStateOf(true)}if(showDialog){Dialog(onDismissRequest = { onDismissRequest() }) {// Draw a rectangle shape with rounded corners inside the dialogCard(modifier = Modifier.fillMaxWidth().height(375.dp).padding(16.dp),shape = RoundedCornerShape(16.dp),) {Column(modifier = Modifier.fillMaxSize(),verticalArrangement = Arrangement.Center,horizontalAlignment = Alignment.CenterHorizontally,) {Image(painter = painter,contentDescription = imageDescription,contentScale = ContentScale.Fit,modifier = Modifier.height(160.dp))Text(text = "带按钮和图片的弹框",modifier = Modifier.padding(16.dp),)Row(modifier = Modifier.fillMaxWidth(),horizontalArrangement = Arrangement.Center,) {TextButton(onClick = { onDismissRequest()showDialog = !showDialog},modifier = Modifier.padding(8.dp),) {Text("取消")}TextButton(onClick = { onConfirmation()showDialog = !showDialog},modifier = Modifier.padding(8.dp),) {Text("确认")}}}}}}
}

    运行效果如下图所示

    在本例中,Dialog的子控件是一个Card控件,Card控件的子控件为Column,Column的子控件有Image、Text、和Row,Row的子空间是2给TextButton。除了上面的样式,在Card容器中可以根据想要达到的效果添加不同的控件,从而得到自定义布局的Dialog。

示例代码已上传到github,地址如下

示例工程代码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/36678.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Redis 7.x 系列【9】数据类型之自动排重集合(Set)

有道无术,术尚可求,有术无道,止于术。 本系列Redis 版本 7.2.5 源码地址:https://gitee.com/pearl-organization/study-redis-demo 文章目录 1. 前言2. 常用命令2.1 SADD2.2 SCARD2.3 SISMEMBER2.4 SREM2.5 SSCAN2.6 SDIFF2.7 SU…

DiAtom 共生菌固氮作用产生的碳输出(ANACONDAS)

Amazon iNfluence on the Atlantic: CarbOn export from Nitrogen fixation by DiAtom Symbioses (ANACONDAS) 亚马逊对大西洋的影响:DiAtom 共生菌固氮作用产生的碳输出(ANACONDAS) 简介 该研究项目探讨了亚马逊河羽流对热带北大西洋西部…

Java中的lambda表达式与Stream API:高效的函数式编程

Java中的lambda表达式与Stream API:高效的函数式编程 大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!今天我们将探讨Java中的lambda表达式和Stream …

ECharts 源码代码规范

代码规范 - Apache EChartsApache ECharts,一款基于JavaScript的数据可视化图表库,提供直观,生动,可交互,可个性化定制的数据可视化图表。https://echarts.apache.org/zh/coding-standard.html 源文件 [强制] JavaScr…

STM32-hal库学习(4)--usart/uart通信 (同时显示在oled)

前言: 关于usart详解: stm32-USART通信-CSDN博客 因为在oled上显示,我们直接在上一个工程进行修改: STM32_hal库学习(3)-OLED显示-CSDN博客 其他配置与oled显示工程保持不变,打开oled文件的…

装箱问题汇总

一维装箱 整数规划建模 参考 二维装箱 数学建模 参考1 参考2

并发编程工具集——Lock和Condition(上)(十二)

简述:Java SDK 并发包通过 Lock 和 Condition 两个接口来实现管程,其中 Lock 用于解决互斥问题,Condition 用于解决同步问题。 再造管程的理由和期望 理由:synchronized 没有办法解决“破坏不可抢占条件方案”。 原因是synchroniz…

查看Oracle、MySQL、PostGreSQL中的依赖关系

查看Oracle、MySQL、PostGreSQL中的依赖关系 在有些程序员开发习惯中,喜欢为了应用代码的简洁或复用,而在数据库创建一个复杂关连查询的VIEW,甚至是VIEW套VIEW嵌套使用, 这里就有个问题如果上线后如发现依赖的表字段类型或长度不…

Linux kernel 与 设备树

Linux kernel 与 设备树 1 介绍1.1 概述1.2 发展历程1.3 各版本发布时间及特色1.4 Linux 单内核1.5 Linux 内核网址1.6 NXP 官方镜像与 野火 鲁班猫镜像的区别 2 Linux 内核组成2.1 进程管理2.2 内存管理2.3 文件系统2.4 设备管理2.5 网络功能 3 Linux 内核编译3.1 编译 Kernel…

小程序发布必须进行软件测试吗?测试内容有哪些?

在如今移动互联网时代,小程序已成为许多企业广泛采用的一种营销手段,然而,发布小程序之前进行充分的软件测试是至关重要的,因为它不仅可以确保小程序的质量,还可以避免潜在的风险和损失。 在进行小程序发布前进行软件…

可逆质子陶瓷电化学电池(R-PCEC)作为新型能量存储与转换装置开发应用价值大

可逆质子陶瓷电化学电池(R-PCEC)作为新型能量存储与转换装置开发应用价值大 可逆质子陶瓷电化学电池(R-PCEC),同时具有燃料电池与电解槽功能,能够实现电能、化学能相互转化,是最具有发展前景的能…

mongodb(笔记向,有点乱哈)

基于分布式文件存储的数据库,c语言,介于关系与非关系数据库之间的产品。非关系数据库中功能最丰富,最像关系数据库的,存储比较复杂的数据类型。 语法有点类似于面向对象的查询语言,几乎可以实现类似数据库单表查询的绝…

「51媒体」政企活动媒体宣发如何做?

传媒如春雨,润物细无声,大家好,我是51媒体网胡老师。 媒体宣传加速季,100万补贴享不停,一手媒体资源,全国100城线下落地执行。详情请联系胡老师。 政企活动媒体宣发是一个系统性的过程,需要明确…

vue3如何实现一进入vue页面就全屏?

import { onUnmounted } from vue;onMounted(() > {fullscreenElement.value?.requestFullscreen() .then(() > { console.log(全屏成功); }) .catch(err > { console.error(全屏失败:, err); }); });

餐饮冷库安全守护神:可燃气体报警器检定的科学性与有效性

随着餐饮业的快速发展,冷库成为储存食材、保证食品质量的重要场所。 然而,由于冷库环境的特殊性,如密封性强、温度低、湿度大等,一旦冷库内发生可燃气体泄露,后果将不堪设想。因此,在餐饮冷库中安装并合理…

SpringBoot集成道历(实现道历日期查询)

官网地址&#xff1a;官网地址https://6tail.cn/calendar/api.html 1、导入依赖 <dependency><groupId>cn.6tail</groupId><artifactId>lunar</artifactId><version>1.3.9</version></dependency><dependency><group…

大模型微调(finetune)方法

lora adapter prefix-tuning p-tuning prompt-tuning 大模型微调后灾难行遗忘 1、主流解决大模型微调后灾难行遗忘的方法是在微调过程中加入通用的指令数据。 2、自我蒸馏方法主要是通过模型本身对任务数据进行生成引导&#xff0c;构建自我蒸馏数据集&#xff0c;改变任务数…

MQTT遗嘱信息(2)

接前一篇文章&#xff1a;MQTT遗嘱信息&#xff08;1&#xff09; 本文内容参考&#xff1a; 什么是MQTT遗嘱消息&#xff1f;如何配置和处理遗嘱消息&#xff1f;_mqtt last will-CSDN博客 MQTT 协议学习&#xff1a;Retained&#xff08;保留消息&#xff09; 与 LWT&#x…

shark云原生-日志管理体系-filebeat

文章目录 1. deploy 文件1.1 RBAC1.2. DaemonSet1.2.1. Elasticsearch 连接信息1.2.2. Volume 1.3. ConfigMap1.3.1. 日志收集路径1.3.2. 日志事件输出目标 2. 在控制平面节点上运行Filebeat3. 查看输出3.1. 关于处理器 processors 4. 日志收集配置4.1. 手动指定日志收集路径4.…

前端生成循环数组的值

生成循环数组的值可以通过以下方式实现&#xff1a; // 定义一个函数&#xff0c;输入是数组和循环的次数 function generateCircularArray(arr, n) {// 循环n次for (let i 0; i < n; i) {// 每次都从数组尾部取一个元素&#xff0c;移除它&#xff0c;然后添加到数组头部…