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

相关文章

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

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

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

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

基于Python开发PPTX压缩工具

《基于Python开发PPTX压缩工具》在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,不便于传输和存储,所以本文将使用Python开发一个PPTX压缩工具,需要的可以了解下... 目录引言全部代码环境准备代码结构代码实现运行结果引言在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,

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

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

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

C#实现WinForm控件焦点的获取与失去

《C#实现WinForm控件焦点的获取与失去》在一个数据输入表单中,当用户从一个文本框切换到另一个文本框时,需要准确地判断焦点的转移,以便进行数据验证、提示信息显示等操作,本文将探讨Winform控件... 目录前言获取焦点改变TabIndex属性值调用Focus方法失去焦点总结最后前言在一个数据输入表单

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

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

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