Jetpack:012-Jetpack中的弹出菜单

文章目录

  • 1. 概念介绍
  • 2. 使用方法
    • 2.1 DropdownMenu
    • 2.2 DropdownMenuItem
  • 3. 示例代码
    • 3.1 代码和注释
    • 3.2 代码难点
    • 3.3 运行效果
  • 4. 内容总结

我们在上一章回中介绍了Jetpack中标题栏相关的内容,本章回中主要 弹出菜单。闲话休提,让我们一起Talk Android Jetpack吧!

1. 概念介绍

我们在本章回中介绍的弹出菜单主要指标题栏右侧的详情菜单,平常不显示,当点击详情图标时才会弹出菜单。在Android的View体系中叫它PopupMenu组件。在Jectpack库中叫DropdownMenu。虽然名字不同,但是显示的效果相同,为了方便介绍,我统一称它们为弹出菜单。

2. 使用方法

弹出菜单通过DropdownMenuDropdownMenuItem这两个可组合函数一起实现,接下来我们分别介绍这两个函数的使用方法。

2.1 DropdownMenu

该函数主要用来显示弹出菜单,它提供了一些参数来控制菜单,下面是常用的参数:

  • expanded参数:主要用来控制是否显示菜单,值为true时显示菜单,否则不显示菜单;
  • offset参数:主要用来控制菜单弹出的位置,默认在action图标左下角显示弹出菜单;
  • onDismissRequest参数:点击菜单外任意位置时是否关闭菜单,值为true时关闭菜单,否则不关闭菜单;

2.2 DropdownMenuItem

该函数主要用来控制弹出菜单中的菜单项,它提供了相关的参数来控制菜单项,下面是常用的参数:

  • text:主要用来控制菜单项显示的文本内容;
  • onClick:主要用来控制菜单项的点击事件;
  • leadingIcon:主用用来控制菜单项的图标,位于菜单项最左侧;
  • trailingIcon:主用用来控制菜单项的图标,位于菜单项最右侧;
  • colors:主要用来控制菜单项中的文本,图标,背景等内容的颜色;

3. 示例代码

介绍完实现弹出菜单的可组合函数后,我们将通过具体的代码来演示这些函数的用法,下面是示例代码,请大家参考:

3.1 代码和注释

//自定义的popupMenu,通过可以组合函数DropdownMenu实现,同时实现了点击功能,不过没有给item添加具体的功能
@Composable
fun ShowPopupMenu() {//是否显示popupMenu,默认显示var show by remember { mutableStateOf(true) }//菜单中显示的内容:包含图标和文字val items = listOf<NavigationItem>(NavigationItem("One",Icons.Default.Done),NavigationItem("Two",Icons.Default.Done),NavigationItem("Three",Icons.Default.Done),)if (show)DropdownMenu(//是否显示菜单expanded = show,//控制菜单的弹出位置,向左和向下进行偏移offset = DpOffset(x = 20.dp, y = 30.dp),//点击菜单外任意位置时,菜单消失onDismissRequest = { show = false }) {Column() {items.forEachIndexed { index, item ->//这个菜单项目比较好,封装了图标、文本和点击事件DropdownMenuItem(leadingIcon = { Icon(imageVector = item.icon, contentDescription = null)},text = { Text(text = item.text) },//点击任意菜单项目时,菜单消失onClick = { show = false})}}}else//action第二次点击弹出菜单,第一次点击在scaffold中控制IconButton(onClick = { show = true}) {Icon(imageVector = Icons.Default.MoreVert, contentDescription = null)}
}

我们在上面代码中的关键位置都添加了注释,这样方便大家理解代码。此外,我们把代码封装成了列表,通过列表来添加菜单项目,这样可以让代码更加简洁一些。

3.2 代码难点

示例代码中的难点在于如何显示和关闭弹出菜单,我们的思路是定义一个状态值,然后依据不同的状态值来显示和关闭弹出菜单,也就是代码中if/else语句控制的内容。
修改状态值的地方有两个:一个是弹出菜单的菜单项,另外一个是详情菜单图标的点击事件,也就是代码中onClick参数对应的内容。

状态值在代码中对应为show变量,它通过remember进行状态管理,状态值发生变化后,系统会重组UI界面,进而实现显示和关闭弹出菜单的功能。状态管理的内容,我们将在后面章回中介绍。

3.3 运行效果

我们把弹出菜单封装成了独立的函数,编译并且运行后可以得到下面的运行效果
在这里插入图片描述

4. 内容总结

最后,我们对本章回的内容做统一的总结:

  • 弹出菜单位于标题栏最右侧,平常不显示,点击详情菜单图标时弹出菜单;
  • 弹出菜单通过可组合函数DropdownMenu和DropdownMenuItem实现;
  • 可组合函数DropdownMenu主要控制弹出菜单显示状态和位置相关的内容;
  • 可组合函数DropdownMenuItem主要控制弹出菜单中菜单项目的具体内容;
  • 关闭和显示弹出菜单通过状态值来控制,涉及到修改状态值和状态管理的知识;

看官们,关于Jetpack中弹出菜单相关的内容就介绍到这里,欢迎大家在评论区交流与讨论!

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

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

相关文章

权威赛事、高额奖金,文心一言插件开发邀你来挑战!

2023 CCF大数据与计算智能大赛&#xff08;CCF BDCI&#xff09;盛大开幕&#xff0c;百度文心赛题“文心一言插件设计与开发”正式上线。权威赛事&#xff0c;高额奖金&#xff0c;等你来挑战。 10月15日&#xff0c;由中国计算机学会主办的第十一届CCF大数据与计算智能大赛启…

10.17七段数码管单个多个(部分)

单个数码管的实现 第一种方式 一端并接称为位码&#xff1b;一端分别接收电平信号以控制灯的亮灭&#xff0c;称为段码 8421BCD码转七段数码管段码是将BCD码表示的十进制数转换成七段LED数码管的7个驱动段码&#xff0c; 段码就是LED灯的信号 a为1表示没用到a&#xff0c;a为…

【ArcGIS绘图系列1】在ArcGIS中制作柱状图与饼状图

成图展示 图形出处&#xff1a;J2023-Assessment of agricultural drought based on multi-source remote sensing data in a major grain producing area of Northwest China 实现步骤 第一步 查看数据信息 数据输入到ArcGIS中&#xff1a;包含数据表和shp文件 1、shp文件…

SpringCloud: feign整合sentinel实现降级

一、加依赖&#xff1a; <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache…

BookStack 详解及 Docker-Compose 部署

BookStack 是一款用于创建文档和文档管理的开源平台。它提供了一个直观且功能丰富的界面&#xff0c;可用于组织和管理各种文档&#xff0c;包括文档编写、编辑和共享。本文将介绍 BookStack 的核心功能&#xff0c;并展示如何使用 Docker-Compose 快速部署 BookStack。 BookS…

【数字人】6、ER-NeRF | 借助空间分解来实现基于 NeRF 的更高效的数字人生成(ICCV2023)

文章目录 一、背景二、方法2.1 问题设定2.2 Tri-Plane Hash Representation2.3 Region Attention Module2.4 训练细节 三、效果3.1 实验设定3.2 定量对比3.3 定性对比3.4 User study3.5 消融实验 四、代码4.1 视频数据预处理4.2 训练4.3 推理 论文&#xff1a;Efficient Region…

XCode15与iOS17/17.1 真机测试问题处理

XCode15与iOS17/17.1 真机测试问题处理&#xff0c;网上相关博客很多&#xff0c;摘录了如下实践后能起作用的地址如下&#xff1a;Xcode 15 报错处理 - 简书iOS17版本适配-CSDN博客 Xcode15适配-六虎 主要介绍下&#xff1a;Assertion failure in void _UIGraphicsBeginImag…

vivado 脚本使用——loogarch指令集 实验exp6

首先从Window-tcl console 调出终端 然后执行进入指定目录 也就是run_vivado 目录 然后打开Tools——Run Tcl script&#xff0c;执行create_project.tcl文件&#xff0c;静待完成。

LoogArch 指令集学习

1 SoC_Lite片上系统结构 mycpu和dram、confreg之间有一个“一分二”部件。这是因为在LoongArch指令系统架构下&#xff0c;所有I/O设备的寄存器都是采用memory mapped方式访问的。我们这里实现的confreg也不例外。Memory mapped的访问方式意味I/O设备中的寄存器各自都有一个唯一…

【k8s】1、基础概念和架构及组件

一、kubernetes概述 K8S是一种开源的容器编排平台&#xff0c;用于自动化部署、扩展和管理容器化的应用程序&#xff0c;它提供了一种容器编排和管理的方式&#xff0c;可以帮助开发人员更轻松的管理容器化的应用程序&#xff0c;并且提供了一种跨多个主机的自动化部署和管理机…

【下载器篇】获取微软应用商店应用安装包的方法

【下载器篇】获取微软应用商店应用安装包的方法 微软应用商店历史版本应用下载方法&#xff0c;部分历史版本无法搜索到—【蘇小沐】 文章目录 【下载器篇】获取微软应用商店应用安装包的方法1.实验环境 &#xff08;一&#xff09;微软商店的在线链接生成器1、复制该应用的在…

CPU设计——Triumphcore——V2版本

版本记录 指令实现情况&#xff1a; 【腾讯文档】Triumphcore指令实现情况 v2.1 先根据opcode确定指令格式类型&#xff0c;