Jetpack Compose学习 -------- Text 文本

Text 文字 基本属性

  • text: 显示的文本
  • modifier
  • color: 字体颜色
  • fontSize: 字体大小
  • fontStyle: 字体样式 (比如斜体)
  • fontWeight: 字体样式 (比如粗体)
  • fontFamily: 处理字体 (比如设置宋体等)
  • letterSpacing: 每个字符之间的间距
  • textDecoration: 文本的装饰,比如TextDecoration.Underline 添加下划线,比如TextDecoration.LineThrough 中线划线
  • textAlign: 设置文字对齐 对齐方式
  • lineHeight: 设置行高
  • maxLines: 最大行数
  • overflow: 当文字溢出的时候,比如…设置显示在最后
  • softWrap: 声明是否应在换行符处断开文本,默认是true
  • onTextLayout: 在计算新的文本布局时执行的回调
  • style: 文本样式
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
    @Composable
fun TextDemo() {
//垂直布局
Column() {
//显示资源中的文字
Text(stringResource(id = R.string.app_name))
//最多显示行数 , 溢出处理
Text(
text = "你好呀陌生人,这是一个标题,不是很长,因为我想不出其他什么比较好的标题了",
//宽度
modifier = Modifier.width(200.dp),
//设置 最多显示行数
maxLines = 1,
//溢出处理 省略
overflow = TextOverflow.Ellipsis
)
//文字颜色
Text(text = "Hello World", color = Color.Blue)
//文字大小
Text(text = "Hello World", fontSize = 30.sp)
//斜体
Text(text = "Hello World", fontStyle = FontStyle.Italic)
//粗体
Text(text = "Hello World", fontWeight = FontWeight.Bold)
//文字对齐 (居中)
Text(
text = "Hello World Hello World\nHello World",
//文本的对齐方式
textAlign = TextAlign.Center
)
//设置宽度与高度
Text(
text = "Hello World",
//居中对齐
textAlign = TextAlign.Center,
modifier = Modifier
//宽度
.width(100.dp)
//高度
.height(30.dp)
)
//字体设置
Text(text = "Hello World", fontFamily = FontFamily.Serif)
//字体设置
Text(text = "Hello World", fontFamily = FontFamily.SansSerif)
//自定义 fontFamily
val firaSansFamily = FontFamily(
Font(R.font.firasans_light, FontWeight.Light),
Font(R.font.firasans_regular, FontWeight.Normal)
)
//字体设置
Text(
text = "Hello World",
fontFamily = firaSansFamily,
fontWeight = FontWeight.Light
)
//字体设置
Text(
text = "Hello World",
fontFamily = firaSansFamily,
fontWeight = FontWeight.Normal
)
//文本中间绘制线
Text(
text = "Hello World",
style = TextStyle(textDecoration = TextDecoration.LineThrough)
)
//文本下方绘制线 下划线
Text(
text = "Hello World",
style = TextStyle(textDecoration = TextDecoration.Underline)
)
//设置多个 textDecoration
Text(
text = "Hello World",
style = TextStyle(
textDecoration =
TextDecoration.combine(
listOf(
TextDecoration.LineThrough,
TextDecoration.Underline
)
)
)
)
//设置样式
Text(text = buildAnnotatedString {
withStyle(
style = SpanStyle(
//字体颜色
color = Color.Blue
)
) {
append("H")
}
append("ello ")
withStyle(
style = SpanStyle(
//粗体
fontWeight = FontWeight.Bold,
//字体颜色
color = Color.Green
)
) {
append("W")
}
append("orld")
})
//设置段落样式
Text(text = buildAnnotatedString {
withStyle(
style = ParagraphStyle(
//行高间距
lineHeight = 40.sp
)
) {
withStyle(
style = SpanStyle(
//字体颜色
color = Color.Yellow
)
) {
append("Hello\n")
}
withStyle(
style = SpanStyle(
//粗体
fontWeight = FontWeight.Bold,
//字体颜色
color = Color.Red
)
) {
append("World\n")
}
append("Compose")
}
})
//设置最大行数
Text(
//重复字符串
text = "Hello World ".repeat(20),
//设置行数
maxLines = 3
)
//文字溢出处理
Text(
text = "Hello World".repeat(20),
//设置最大行数
maxLines = 3,
//溢出处理:省略号
overflow = TextOverflow.Ellipsis
)
// 将内部 Text 组件的 alpha 强调程度设置为高
// 注意: MaterialTheme 已经默认将强调程度设置为 high
CompositionLocalProvider(LocalContentAlpha provides ContentAlpha.high) {
Text("这里是high强调效果")
}
// 将内部 Text 组件的 alpha 强调程度设置为中
CompositionLocalProvider(LocalContentAlpha provides ContentAlpha.medium) {
Text("这里是medium强调效果")
}
// 将内部 Text 组件的 alpha 强调程度设置为禁用
CompositionLocalProvider(LocalContentAlpha provides ContentAlpha.disabled) {
Text("这里是禁用后的效果")
}
}
}

SelectionContainer 选择文字

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
//选择文字
//默认情况下,可组合项不可选择,这意味着在默认情况下用户无法从您的应用中选择和复制文字。
//要启用文字选择,需要使用 SelectionContainer 可组合项封装文字元素
@Composable
fun SelectableText() {
Text(text = "Hello World")
}

//DisableSelection 为可选择区域的特定部分停用选择功能
@Composable
fun PartiallySelectableText() {
SelectionContainer {
Column {
Text("This text is selectable")
Text("This one too")
Text("This one as well")
//组合项来封装不可选择的部分
DisableSelection {
Text("But not this one")
Text("Neither this one")
}
Text("But again, you can select this one")
Text("And this one too")
}
}
}

@Composable
fun ComposableSample() {
Text(
text = "Hello World Hello World Hello World",
modifier = Modifier.clickable(
onClick = {
Log.d("onClick", "你点击了此文本")
},
//取消点击波纹
indication = null,
//取消点击波纹
interactionSource = MutableInteractionSource()
)
)
}

//clickable 获取点击文字的位置
@Composable
fun SimpleClickableText() {
ClickableText(
text = AnnotatedString("Click Me"),
onClick = { offset ->
Log.d("ClickableText", "${offset} -th character is clicked.")
}
)
}


//点击注解
@Composable
fun AnnotatedClickableText() {
val annotatedText = buildAnnotatedString {
append("Click ")
//我们将此URL注释附加到以下内容,直到调用`pop()`为止
pushStringAnnotation(
tag = "URL",
annotation = "https://developer.android.com"
)
withStyle(
style = SpanStyle(
//字体颜色
color = Color.Red,
//粗体
fontWeight = FontWeight.Bold
)
) {
append("here")
}
pop()
}
ClickableText(
text = annotatedText,
onClick = { offset ->
//判断点击的位置是否是 url 注解中
annotatedText.getStringAnnotations(
tag = "URL",
start = offset,
end = offset
).firstOrNull()?.let { annotation ->
Log.d("Clicked URL", annotation.item)
}
}
)
}

Jetpack Compose学习 -------- Shape 形状

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36

@Composable
fun ShapeDemo() {
Column(
Modifier
.fillMaxWidth()
) {
//RectangleShape 矩形形状
ExampleBox(shape = RectangleShape)
//CircleShape 圆圈形状
ExampleBox(shape = CircleShape)
//RoundedCornerShape 圆角形状
ExampleBox(shape = RoundedCornerShape(10.dp))
//CutCornerShape 切角形状
ExampleBox(shape = CutCornerShape(10.dp))
}
}

@Composable
fun ExampleBox(shape: Shape) {
Column(
Modifier
.fillMaxWidth()
.padding(10.dp)
.wrapContentSize(Alignment.Center)
)
{
Box(
modifier = Modifier
.size(100.dp)
.clip(shape)
.background(Color.Blue)
)
}
}

Jetpack Compose学习 -------- Modifier

padding 设置各个UI的padding

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

// 给上下左右全部设置成同一个值
Modifier.padding(10.dp)
// 分别为左(开始)、上(上)、右(结束)、下(下)设值
Modifier.padding(10.dp, 20.dp, 30.dp, 40.dp)
// 分别为左右(水平)和上下(垂直)设值
Modifier.padding(10.dp, 20.dp)
//PaddingValues 与 padding 不一样
// 给上下左右全部设置成同一个值
Modifier.padding(PaddingValues(10.dp))
// 分别为左右(水平)和上下(垂直)设值
Modifier.padding(PaddingValues(10.dp, 20.dp))
//分别为左(开始)、上(上)、右(结束)、下(下)设值
Modifier.padding(PaddingValues(10.dp, 20.dp, 30.dp, 40.dp))

fillMaxHeight,fillMaxWidth,fillMaxSize 类似于match_parent,填充整个父layout

1
2
3
4
5
6
7
8

//填充整个父Layout
Modifier.fillMaxSize()
//填充整个父Layout的宽度
Modifier.fillMaxWidth()
//填充整个父Layout的高度
Modifier.fillMaxHeight()

width,heigh,size 设置Content的宽度和高度

1
2
3
4
5
6
7
8
9
10

//设置宽度
Modifier.width(80.dp)
//设置高度
Modifier.height(80.dp)
//设置 宽度和高度
Modifier.size(100.dp)
//设置 宽度,高度
Modifier.size(100.dp, 100.dp)

widthIn, heightIn, sizeIn 设置Content的宽度和高度的最大值和最小值

1
2
3
4
5
6
7
8

//设置 最小宽度 最大宽度
Modifier.widthIn(20.dp, 50.dp)
//设置 最小高度 最大高度
Modifier.heightIn(20.dp, 50.dp)
//设置 最小宽度,最小高度,最大宽度,最大高度
Modifier.sizeIn(20.dp, 20.dp, 50.dp, 50.dp)

wrapContentHeight,wrapContentWidth,wrapContentSize,

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34

// 高度 位于 顶部
Modifier.wrapContentHeight(Alignment.Top)
// 高度 位于 底部
Modifier.wrapContentHeight(Alignment.Bottom)
// 高度 位于 垂直居中
Modifier.wrapContentHeight(Alignment.CenterVertically)
// 高度 位于 水平居中
Modifier.wrapContentHeight(Alignment.CenterHorizontally)
// 宽度 位于 开始(左)
Modifier.wrapContentWidth(Alignment.Start)
// 宽度 位于 结束(右)
Modifier.wrapContentWidth(Alignment.End)
// 宽度 位于 水平居中
Modifier.wrapContentWidth(Alignment.CenterHorizontally)
// 宽度 位于 垂直居中
Modifier.wrapContentWidth(Alignment.CenterVertically)
//位置 位于 顶部 开始(左)
Modifier.wrapContentSize(Alignment.TopStart)
//位置 位于 顶部 结束(右)
Modifier.wrapContentSize(Alignment.TopEnd)
//位置 位于 顶部 水平居中
Modifier.wrapContentSize(Alignment.TopCenter)
//位置 位于 底部 开始(左)
Modifier.wrapContentSize(Alignment.BottomStart)
//位置 位于 底部 结束(右)
Modifier.wrapContentSize(Alignment.BottomEnd)
//位置 位于 底部 水平居中
Modifier.wrapContentSize(Alignment.BottomCenter)
//位置 位于 垂直居中 开始(左)
Modifier.wrapContentSize(Alignment.CenterStart)
//位置 位于 垂直居中 结束(右)
Modifier.wrapContentSize(Alignment.CenterEnd)

Jetpack Compose学习 -------- LazyRow 延迟 水平 布局

LazyRow 延迟 水平 布局 简单使用

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34

@Composable
fun LazyRowDemo() {
val list = listOf("A", "B", "C", "D") + ((0..20).map { it.toString() })
LazyRow(Modifier.fillMaxHeight()) {
items(
key = { list.get(it) },
count = list.size,
itemContent = { item ->
val content = list.get(item)
Log.d("COMPOSE", "This get rendered ${content}")
when (content) {
"A" -> {
Text(text = content, style = TextStyle(fontSize = 80.sp))
}
"B" -> {
Button(onClick = {}) {
Text(text = content, style = TextStyle(fontSize = 80.sp))
}
}
"C" -> {
}
"D" -> {
Text(text = content)
}
else -> {
Text(text = content, style = TextStyle(fontSize = 80.sp))
}
}
}
)
}
}

Jetpack Compose学习 -------- LazyColumn 延迟 垂直 布局

LazyColumn 延迟 垂直 布局 简单使用

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34

@Composable
fun LazyColumnDemo() {
val list = listOf("A", "B", "C", "D") + ((0..20).map { it.toString() })
LazyColumn(Modifier.fillMaxWidth()) {
items(
key = { list.get(it) },
count = list.size,
itemContent = { item ->
val content = list.get(item)
Log.d("COMPOSE", "This get rendered ${content}")
when (content) {
"A" -> {
Text(text = content, style = TextStyle(fontSize = 80.sp))
}
"B" -> {
Button(onClick = {}) {
Text(text = content, style = TextStyle(fontSize = 80.sp))
}
}
"C" -> {
}
"D" -> {
Text(text = content)
}
else -> {
Text(text = content, style = TextStyle(fontSize = 80.sp))
}
}
}
)
}
}