news 2026/4/23 12:12:09

Android的Compose系列之文本TextView

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Android的Compose系列之文本TextView

文章目录

  • 前言
  • 一、Text介绍
  • 二、使用
    • 1.常用使用方式
    • 2.相关参数设置
    • 3.不同需求的功能实现
      • 多语言下的设置与占位符使用
      • 通过风格统一管理不同的Text显示
      • 文字点击功能
      • 文字超链接
      • 文字复制功能

前言

本文用来介绍有关TextView文本的Compose中使用形式,主要介绍各种场景下的使用方式与本身的属性设置等,同时该文章也会长期更新,添加或更换新的api,以及我发现的新的使用方式,请各位务必收藏,可以随时翻阅。

官方中文文档的地址(需要科学上网):https://developer.android.com/develop/ui/compose/documentation?hl=zh-cn
学习Compose的网站参考(部分内容可能过时):https://jetpackcompose.cn/docs/


一、Text介绍

Text是Compose中用来显示文本内容的UI,等同于TextView,相关属性也很雷同,但是点击事件等设置有所不同,以及使用方式也有所变化。

二、使用

1.常用使用方式

@ComposablefunTextComposeSample(){//5种不同的用法/** * 直接赋予内容 */Text("这是预览界面的内容!")/** * 结合资源使用,推荐 */Text(stringResource(R.string.contents))}

2.相关参数设置

Text的属性详解:

Text(text="文本具体内容",color=Color.Red,//颜色fontSize=20.sp,//字号fontStyle=FontStyle.Italic,//样式,可选Normal普通或Italic斜体fontWeight=FontWeight.W100,//粗细fontFamily=FontFamily.Serif,//字体letterSpacing=12.sp,//文字的间距// textDecoration = TextDecoration.None, //装饰 Underline下划线 LineThrough删除线 None无textDecoration=TextDecoration.combine(//多种装饰合并listOf(//下划线+删除线TextDecoration.Underline,TextDecoration.LineThrough)),textAlign=TextAlign.Center,//相对于父容器的文本对齐方式,设置Modifier.fillMaxWidth()或者父容器不是自适应才能看到效果lineHeight=30.sp,//行高maxLines=2,//显示行数极值,超过部分会被截断overflow=TextOverflow.Ellipsis,//超出部分显示省略号,Clip直接截断显示 Visible强制完整显示softWrap=true,//是否自动换行,默认true,false时会单行显示并可能溢出modifier=Modifier//修饰符,用于控制尺寸、边距、对齐等布局行为.padding(10.dp)//内边距.background(Color.Yellow)//背景.width(120.dp)//宽度.height(120.dp),//长度)

Text中设置style的属性详解:

//样式的设置, 可在data类中定义val BodyNormal = TextStyle()可将不同样式赋值给全项目特定控件来实现复用并统一风格Text(text="文本具体内容",style=TextStyle(//设置样式可以设置统一的风格color=Color.Blue,//颜色fontSize=20.sp,//字号fontWeight=FontWeight.Bold,//粗体fontStyle=FontStyle.Italic,//字体textDecoration=TextDecoration.Underline,// 下划线fontFamily=FontFamily.Serif,// 字体家族letterSpacing=2.sp,// 字间距lineHeight=30.sp// 行高))

3.不同需求的功能实现

多语言下的设置与占位符使用

/** * 用于多语言切换与占位符使用 * 注:需在strings.xml 中设置资源 * <string name="contents_language">这是多语种适配与占位符设置,姓名:%1$s,年龄:%2$d</string> */Text(text=stringResource(id=R.string.contents_language,"张三",//替换 %1$s6//替换 %2$d))

通过风格统一管理不同的Text显示

通常有两种方式,一种是使用自带的MaterialThem中的Medium、Small、Large三种不同的预设对其设置为统一的诸如标题、正文等格式,一种是通过自定义的方式进行统一设置。

官方Text的文档:https://developer.android.com/develop/ui/compose/text/user-interactions?hl=zh-cn

//默认的统一风格Text(text="自带的标题的样式",style=MaterialTheme.typography.headlineMedium)Text(text="自带的正文的样式",style=MaterialTheme.typography.bodyMedium)
//使用自定义风格管理// 1. 主题样式定义(ui/theme/TextStyles.kt)dataclassAppTextStyles(valtitle:TextStyle,valcontent:TextStyle,valhint:TextStyle)valLightTextStyles=AppTextStyles(title=TextStyle(fontSize=18.sp,fontWeight=FontWeight.SemiBold,color=Color.Black,lineHeight=26.sp),content=TextStyle(fontSize=16.sp,color=Color.Gray,lineHeight=24.sp),hint=TextStyle(fontSize=14.sp,color=Color.LightGray,lineHeight=20.sp))valDarkTextStyles=AppTextStyles(title=TextStyle(fontSize=18.sp,fontWeight=FontWeight.SemiBold,color=Color.White,lineHeight=26.sp),content=TextStyle(fontSize=16.sp,color=Color.LightGray,lineHeight=24.sp),hint=TextStyle(fontSize=14.sp,color=Color.Gray,lineHeight=20.sp))//2.使用//主题样式的复用Text(text="标题",style=MaterialTheme.appTextStyles.title)Text(text="内容",style=MaterialTheme.appTextStyles.content)Text(text="提示",style=MaterialTheme.appTextStyles.hint)//主题样式复用时的微调Text(text="微调",style=MaterialTheme.appTextStyles.hint.copy(color=Color.Red,//红色fontWeight=FontWeight.Bold//粗体))

文字点击功能

普通点击事件中点击事件最好放在修饰符中尺寸、背景等之后,偏移与裁剪等设置之前
如:Modifier
.width(200.dp) // 1. 尺寸
.background(Color.Gray) // 2. 背景
.clickable { … } // 3. 点击
.offset(x = 10.dp) // 4. 偏移
.clip(RoundedCornerShape(12.dp)) // 5. 裁剪(圆角矩形)

常用的形式,默认带点击的涟漪效果

Text(text="文本具体内容",fontSize=20.sp,//字号modifier=Modifier//修饰符,用于控制尺寸、边距、对齐等布局行为.clickable(onClick={//普通场景点击,默认带有涟漪效果Toast.makeText(context,"点击",Toast.LENGTH_SHORT).show()}))

取消点击时涟漪效果

Text(text="文本具体内容",fontSize=20.sp,//字号modifier=Modifier//修饰符,用于控制尺寸、边距、对齐等布局行为.clickable(onClick={//普通场景点击,默认带有涟漪效果Toast.makeText(context,"点击",Toast.LENGTH_SHORT).show()},indication=null,//取消涟漪效果interactionSource=remember{MutableInteractionSource()}//取消时必须配合该参数))

文字超链接

注意文字超链接的关键在于这段文字不能使用传统的点击设置,而是需要对可点击部分设置,其他部分则不能设置

/** * 通过AnnotatedString构建带注解处理+样式的富文本 */valannotatedText=buildAnnotatedString{append("请点击")//拼接普通文本pushStringAnnotation(tag="URL",annotation="https://www.baidu.com")//为执行文本片段标记注解//对指定文本片段设置样式withStyle(style=SpanStyle(color=Color.Blue,textDecoration=TextDecoration.Underline)){//蓝色+下划线append("此处")}pop()//结束当前注解的作用域append("访问")}valcontext=LocalContext.current//获取compose提供的ContextText(text=annotatedText,modifier=Modifier.clickable{//从整个文本的start到end中查找tag="URL"的注解,返回List<StringAnnotation>valannotations=annotatedText.getStringAnnotations(//解析tag="URL",start=0,end=annotatedText.length)annotations.firstOrNull()?.let{//获取第一个匹配的注解Toast.makeText(context,"点击了链接",Toast.LENGTH_SHORT).show()}})

文字复制功能

全部可复制:

SelectionContainer(){//长按负值功能,此处时调用了默认的自定义长按选中并复制的功能页面Text(text=stringResource(id=R.string.contents),//文本color=Color.Red,//颜色fontSize=15.sp,//字号)}

部分可复制:

SelectionContainer(){Column(){//进行垂直排列Text(text="可复制部分1")Text(text="可复制部分2")DisableSelection{//内容包裹部分不可复制Text("不可复制部分1")Text("不可复制部分2")}Text(text="可复制部分3")}}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/13 12:58:31

21、深入探索SNMP:从配置到数据中心发现

深入探索SNMP:从配置到数据中心发现 1. Net - SNMP配置 当你要在需要监控的客户端上安装Net - SNMP时,应该使用主机资源MIB来编译Net - SNMP。具体操作步骤如下: ./configure -with-mib-modules=host运行 configure 时,它会尝试运行自动配置脚本,若不想运行,可自行…

作者头像 李华
网站建设 2026/4/17 12:47:06

USB摄像头采集数据

摄像头采集数据 1.winform-sqlite内网数据采集 2.编辑自定义识别模板&#xff0c;根据识别模板&#xff0c;自定义数据库表字段存储 3.自定义数据库字段&#xff0c;渲染表格表头&#xff08;table&#xff09;

作者头像 李华
网站建设 2026/4/19 21:42:43

2、Puppet入门:自动化配置管理解决方案

Puppet入门:自动化配置管理解决方案 为何需要Puppet 在生产环境中管理应用程序和服务是一项艰巨的任务,涉及众多步骤。当你从云提供商处获取一台安装了基础操作系统的服务器后,在部署应用之前,你需要完成以下操作: 1. 添加用户账户和密码 2. 配置安全设置和权限 3. 安…

作者头像 李华
网站建设 2026/4/21 19:13:11

JS深拷贝入门:从浅拷贝到深拷贝的完整指南

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个面向初学者的JS深拷贝教学示例&#xff0c;要求&#xff1a;1. 用生活化比喻解释深浅拷贝区别(如房子钥匙vs克隆房子) 2. 分步骤实现基础深拷贝函数 3. 每个步骤添加图文说…

作者头像 李华
网站建设 2026/4/18 11:20:58

互联网大厂Java小白面试:深入理解Spring Boot与微服务架构

互联网大厂Java小白面试&#xff1a;深入理解Spring Boot与微服务架构 面试场景&#xff1a; 在一家著名的互联网大厂&#xff0c;小白程序员超好吃正面对一位严肃的面试官&#xff0c;面试官名叫张工&#xff0c;负责招聘大数据与AI服务项目的Java开发人员。 第一轮提问&#…

作者头像 李华