Android开发系列(二)Jetpack Compose 之Text控件

2024-06-17 11:28

本文主要是介绍Android开发系列(二)Jetpack Compose 之Text控件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

   Jetpack Compose是一种全新的声明式UI框架,用于构建Android应用程序。Jetpack Compose Text控件是Compose中用于显示文本的基本UI组件。

   Text是一个可组合函数,函数声明如下所示。

@Composable
fun Text(text: String,modifier: Modifier = Modifier,color: Color = Color.Unspecified,fontSize: TextUnit = TextUnit.Unspecified,fontStyle: FontStyle? = null,fontWeight: FontWeight? = null,fontFamily: FontFamily? = null,letterSpacing: TextUnit = TextUnit.Unspecified,textDecoration: TextDecoration? = null,textAlign: TextAlign? = null,lineHeight: TextUnit = TextUnit.Unspecified,overflow: TextOverflow = TextOverflow.Clip,softWrap: Boolean = true,maxLines: Int = Int.MAX_VALUE,minLines: Int = 1,onTextLayout: (TextLayoutResult) -> Unit = {},style: TextStyle = LocalTextStyle.current
) 

   下面通过示例说明Text的使用方法。

一、简单显示文本

    在Text函数中,参数text用于指定要显示的文本,如下所示

    文本内容可以直接在代码里填入,也可以通过stringResource从资源中读取,如下所示。

二、设置字体颜色

    在Text函数中,参数color用于设置字体颜色,如下所示。

    上面示例将字体设置为红色。

三、设置字体大小

    在Text函数中,参数fontSize用于设置字体大小,如下所示。

    这里用到了Column用于显示列布局。

    fontSize的单位一般使用sp。

四、设置字体样式

    在Text函数中,参数fontStyle用于设置字体样式。

默认情况下字体样式为Normal,斜体对应的值为Italic。

五、设置字体粗细

    在Text函数中,参数fontWeight用于设置字体的粗细。

    从上面的显示效果来看,Thin最细,ExtraBold最粗。

六、设置字体

    在Text函数中,fontFamily用于设置字体,示例如下。

七、设置字符间距

    在Text函数中,参数letterSpacing用于设置字符之间的距离。

    默认情况下字符之间的距离比较小,通过设置letterSpacing可以将字符间的距离拉开。

八、设置文字修饰

    在Text函数中,参数textDecoration用于设置中划线和下划线。

    LineThrouth用于设置中划线。

    UnderLine用于设置下划线。

   通过combine可以同时设置中划线和下划线。

九、设置文字对齐方式

    在Text函数中,参数textAlign用于设置字符在控件中的对齐方式。

    默认情况下,Text控件的大小包含整个字符,在不设置Text宽度的情况下设置对齐方式看不到效果,所以要使用对齐方式,需要通过modifier设置Text控件的宽度。

   Start:左对齐

   Center:中间对齐

   End:右对齐

  Justify:两边对齐

    

十、设置文字溢出效果

   在Text函数中,参数overflow用于设置文字的溢出效果

     默认情况下,Text控件的大小刚刚容下所有的文字,不存在放不下所有文字的情况,要达到文件存放不下,需要指定最大行数及宽度。

  1. Ellipsis在溢出的情况下以省略号表示。
  2. Clip 溢出的情况下直接把溢出的内容截取掉。
  3. Visible 按照官方的说法,经可能显示,如果控件内显示不下,会显示到控件的外面,但是这里的效果与Clip一样,不清楚原因。

 在这里使用maxLines限定最大行数,该参数不单独介绍了。

十一、设置文字样式

    在Text函数中,参数style用于设置文字样式,如下所示

     在样式中,

  1. background 设置背景颜色
  2. shadow 设置阴影
  3. textIndent 设置首先缩进

十二、可复制的文字

  默认情况下 Text 并不能进行复制等操作,需要使用 SelectionContainer 来包装 Text才能使文字可复制。

 使用SelectionContainer包装Text后,文字内容选中后,弹出Copy按钮用于复制文字。

十三、文字包含多种样式

    使用buildAnnotatedString可以给Text设置多种样式

 十四、可点击的文本

    使用ClickableText可以构建可点击的文字

    参数onClick用于接受点击事件,offset返回点击第几个字符。

@Composable
fun TextSample16() {val annotatedString = buildAnnotatedString {append("点击登录代表您知悉和同意")pushStringAnnotation("protocol", annotation = "https://xxx/protocol")withStyle(style = SpanStyle(Color.Blue)) {append("用户协议")}pop()append("和")pushStringAnnotation("privacy", annotation = "https://xxx/private")withStyle(style = SpanStyle(Color.Blue)) {append("隐私政策")}pop()}ClickableText(annotatedString, onClick = { offset ->annotatedString.getStringAnnotations("protocol", start = offset, end = offset).firstOrNull()?.let { annotation ->Log.d("TextSample", "点击了用户协议:${annotation.item}")}annotatedString.getStringAnnotations("privacy", start = offset, end = offset).firstOrNull()?.let { annotation ->Log.d("TextSample", "点击了隐私政策:${annotation.item}")}})
}

 运行后点击效果如下

Text的官方示例

 本示例的工程地址

这篇关于Android开发系列(二)Jetpack Compose 之Text控件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

通过Docker Compose部署MySQL的详细教程

《通过DockerCompose部署MySQL的详细教程》DockerCompose作为Docker官方的容器编排工具,为MySQL数据库部署带来了显著优势,下面小编就来为大家详细介绍一... 目录一、docker Compose 部署 mysql 的优势二、环境准备与基础配置2.1 项目目录结构2.2 基

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

Android自定义Scrollbar的两种实现方式

《Android自定义Scrollbar的两种实现方式》本文介绍两种实现自定义滚动条的方法,分别通过ItemDecoration方案和独立View方案实现滚动条定制化,文章通过代码示例讲解的非常详细,... 目录方案一:ItemDecoration实现(推荐用于RecyclerView)实现原理完整代码实现

Android App安装列表获取方法(实践方案)

《AndroidApp安装列表获取方法(实践方案)》文章介绍了Android11及以上版本获取应用列表的方案调整,包括权限配置、白名单配置和action配置三种方式,并提供了相应的Java和Kotl... 目录前言实现方案         方案概述一、 androidManifest 三种配置方式

基于Python开发批量提取Excel图片的小工具

《基于Python开发批量提取Excel图片的小工具》这篇文章主要为大家详细介绍了如何使用Python中的openpyxl库开发一个小工具,可以实现批量提取Excel图片,有需要的小伙伴可以参考一下... 目前有一个需求,就是批量读取当前目录下所有文件夹里的Excel文件,去获取出Excel文件中的图片,并

基于Python开发PDF转PNG的可视化工具

《基于Python开发PDF转PNG的可视化工具》在数字文档处理领域,PDF到图像格式的转换是常见需求,本文介绍如何利用Python的PyMuPDF库和Tkinter框架开发一个带图形界面的PDF转P... 目录一、引言二、功能特性三、技术架构1. 技术栈组成2. 系统架构javascript设计3.效果图