}
字体加粗 ☆
Text(
text = value,
fontWeight = FontWeight.W800
)
下图中 左右两边等价
字体 ☆
Text(
text = value,
fontFamily = FontFamily.Default
)
可以使用 fontFamily
属性来处理 res/font
文件夹中定义的自定义字体和字型
- 需要注意 引入的字体库名称 必须仅包含小写字母az,0-9或下划线
- 引入完成就以后需要
rebuild
一下,否则无法找到font
的- 字体下载
val fontFamily = FontFamily(
Font(resId = R.font.myfont, weight = FontWeight.Normal)
)
Text(
text = “Demo Text”,
style = TextStyle(
fontFamily = fontFamily,
)
)
字间隔空 ☆
Text(
text = value,
letterSpacing = 2.sp
)
文字装饰 ☆
Text(
text = value,
textDecoration = TextDecoration.None
)
对齐方式 ☆
相当于传统的 android:gravity='left'
Text(
text = value,
textAlign = TextAlign.Left
)
其中Justify
表示两端贴边
TextAlign.Start
和TextAlign.Left
的区别
有些国家的文字是从右往左。例如阿拉伯语。
TextAlign.Left
表示 不管你是什么语言,都是靠左TextAlign.Start
会根据首选项语言去选择从左还是从右
行高 ☆
Text(
text = value,
lineHeight = 30.sp
)
最大行数
Text("hello ".repeat(50), maxLines = 2)
文字溢出
Text(
text = value,
overflow = TextOverflow.Ellipsis,
maxLines = 1
)
Clip
将溢出的部分裁剪Ellipsis
使用省略号表示溢出部分Visible
指定范围内没有足够的空间。也要显示所有文本
关于最后一个Visible
在官网中可以找到示例去演示器效果。笔者这边简化了一下。示例如下。
Box(modifier = Modifier
.size(300.dp, 150.dp)
.background(Color.Red)) {
Text(
text = “Hello World”.repeat(2),
modifier = Modifier
.size(200.dp, 70.dp)
.background(Color.Yellow),
fontSize = 35.sp,
overflow = TextOverflow.Visible,
)
}
未设置Visible | 设置了Visible |
---|---|
换行处理
Text(
text = value2,
softWrap = false
)
false
被定位为有无限的水平空间true
默认会有边界
onTextLayout
计算新的文本布局时执行的回调.预览是不打印的。只有运行才会打印
@Preview(showBackground = true)
@Composable
fun SimpleText7() {
val value = “hello world”
Column(Modifier.width(200.dp)) {
Text(
text = value,
onTextLayout = {
Log.i(“TAGText”,it.toString())
}
)
}
}
运行以后的结果,可以看到所有的属性都被打印出来了
2021-04-14 11:40:50.016 16830-16830/com.starot.pencase_compose I/TAGText: TextLayoutResult(layoutInput=TextLayoutInput(
text=hello world,
style=TextStyle(color=Color(0.0, 0.0, 0.0, 1.0, sRGB IEC61966-2.1),
fontSize=Unspecified,
fontWeight=null,
fontStyle=null,
fontSynthesis=null,
fontFamily=null,
fontFeatureSettings=null,
letterSpacing=Unspecified,
baselineShift=null,
textGeometricTransform=null,
localeList=null,
background=Color(0.0, 0.0, 0.0, 0.0, None),
textDecoration=null,
shadow=null,
textAlign=null,
textDirection=null,
lineHeight=Unspecified,
textIndent=null),
placeholders=[],
maxLines=2147483647,
softWrap=true,
overflow=Clip,
density=DensityImpl(density=2.75, fontScale=1.0),
layoutDirection=Ltr,
resourceLoader=androidx.compose.ui.platform.AndroidFontResourceLoader@7058a4b,
constraints=Constraints(minWidth = 0, maxWidth = 550, minHeight = 0, maxHeight = 1977)),
multiParagraph=androidx.compose.ui.text.MultiParagraph@e80ec28,
size=184 x 52,
firstBaseline=41.0,
lastBaseline=41.0, placeholderRects=[])
文字样式 🔥
style
属性的TextStyle
类中。有很多就可以在Text
的构造方法中去执行。但是依然有一些特殊的属性
背景颜色
style = TextStyle(
background = Color.Red
)
基线偏移
Text(
text = value,
style = TextStyle(
baselineShift = BaselineShift.Subscript
)
)
说明这个属性之前,要明白什么是基线。用hencoder中描述
每只小鸟的最高点和最低点都不一样,但画面很平衡,而这个用来让所有文字互相对齐的基准线,就是基线(
baseline
)
Android Text 的基线baseline
实际运行效果呢?
笔者这边选择了 3个参数进行演示。
BaselineShift
给我们提供了3个默认的选项
val Superscript = BaselineShift(0.5f)
val Subscript = BaselineShift(-0.5f)
val None = BaselineShift(0.0f)
合成字体
fontSynthesis = FontSynthesis.All
合成字体用于指定当使用的FontFamily
不包含粗体或斜体时,系统是否应该伪造粗体或倾斜字形。
None
关闭字体合成。 如果FontFamily
中不存在粗体和斜体,则不会合成它们Weight
如果FontFamily
中不提供,则仅合成粗体。 倾斜的字体将不会被合成。Style
如果FontFamily
中不可用,则仅合成倾斜的字体。 粗体字体将不被合成。All
如果FontFamily
中不提供粗体和倾斜字体,则系统会合成粗体和倾斜字体
文字缩进
Text(
text = “hello world”.repeat(2),
style = TextStyle(
textIndent = TextIndent(10.sp,10.sp)
)
)
class TextIndent(
//第一行的缩进
val firstLine: TextUnit = 0.sp,
//除了第一行其他行的缩进
val restLine: TextUnit = 0.sp
)
文字方向
style = TextStyle(
textDirection = TextDirection.Ltr
)
一般情况下。我们用到的都是从左往右。也有一些国家的语言是从右往左,例如阿拉伯语
Ltr
从左往右Rtl
从右往左
下面的几个类型都是根据Unicode双向算法,文本方向取决于文本中的第一个强方向字符。适用于文本中有两种不同的文字。
关于Unicode双向算法可以查看 Unicode控制字符
Content
ContentOrLtr
ContentOrRtl
字体阴影
style = TextStyle(
shadow = Shadow(
color = Color.Red,
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
]
[外链图片转存中…(img-CKS4BIO8-1715557476655)]
[外链图片转存中…(img-h9txLaof-1715557476656)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!