Text
可組合函式有多個選用參數,可為內容設定樣式。
以下列出涵蓋最常見的文字使用方式參數。如要查看 Text
的所有參數,請參閱 Compose 文字原始碼。
每當您設定其中一個參數,樣式就會套用至整個 文字值。如果您需要在同一行或同一段落中套用多種樣式,請參閱多種內嵌樣式一節。
常見的文字樣式
以下各節說明設定文字樣式的常見方式。
變更文字顏色
@Composable fun BlueText() { Text("Hello World", color = Color.Blue) }
調整文字大小
@Composable fun BigText() { Text("Hello World", fontSize = 30.sp) }
將文字設定為斜體
使用 fontStyle
參數將文字設為斜體 (或設定另一個 FontStyle
)。
@Composable fun ItalicText() { Text("Hello World", fontStyle = FontStyle.Italic) }
將文字設為粗體
使用 fontWeight
參數將文字變為粗體 (或設定另一個 FontWeight
)。
@Composable fun BoldText() { Text("Hello World", fontWeight = FontWeight.Bold) }
新增陰影
style
參數可讓您設定 TextStyle
類型的物件
並設定多個參數,例如陰影
「Shadow
」收到顏色
陰影、偏移值或與 Text
的相對位置
模糊半徑,也就是圖像的模糊程度
@Composable fun TextShadow() { val offset = Offset(5.0f, 10.0f) Text( text = "Hello world!", style = TextStyle( fontSize = 24.sp, shadow = Shadow( color = Color.Blue, offset = offset, blurRadius = 3f ) ) ) }
在文字中新增多種樣式
在同一 Text
中設定不同樣式
可組合函式、使用 AnnotatedString
、
能以任意註解樣式加註的字串。
AnnotatedString
是包含以下資料類別:
Text
值SpanStyleRange
的List
,相當於設有位置的內嵌樣式 文字值的範圍ParagraphStyleRange
的List
,用於指定文字對齊方式、文字方向、行高和文字縮排樣式
TextStyle
用於 Text
可組合函式,而 SpanStyle
和 ParagraphStyle
適用於 AnnotatedString
。如要進一步瞭解段落中的多種樣式,請參閱「在段落中新增多種樣式」。
AnnotatedString
具有類型安全建構工具,可讓您輕鬆建立:buildAnnotatedString
。
@Composable fun MultipleStylesInText() { Text( buildAnnotatedString { withStyle(style = SpanStyle(color = Color.Blue)) { append("H") } append("ello ") withStyle(style = SpanStyle(fontWeight = FontWeight.Bold, color = Color.Red)) { append("W") } append("orld") } ) }
啟用 Brush
進階樣式
如要啟用進階文字樣式,您可以將 Brush
API 與以下項目搭配使用:
TextStyle
和SpanStyle
。在您通常會使用 TextStyle
或 SpanStyle
的任何位置,現在也可以使用 Brush
。
使用筆刷設定文字樣式
使用 TextStyle
內建的筆刷設定文字。舉例來說,
可依下列方式設定 linearGradient
筆刷:
val gradientColors = listOf(Cyan, LightBlue, Purple /*...*/) Text( text = text, style = TextStyle( brush = Brush.linearGradient( colors = gradientColors ) ) )
不過,系統能夠提供的色彩配置或著色樣式並非侷限於此特定的色彩配置或風格。雖然
這裡提供了簡單的範例
讓您使用其中一項
筆刷或 SolidColor
也能強化文字效果。
整合
由於 Brush
可以同時使用 TextStyle
和 SpanStyle
,
與 TextField
和 buildAnnotatedString
完美整合。
如要進一步瞭解如何在 TextField
中使用 Brush API,請參閱「使用 Brush API 設定樣式輸入內容」。
使用 SpanStyle
的其他樣式
將筆刷套用至文字區段
如果您只要為部分文字套用筆刷,請使用
buildAnnotatedString
、SpanStyle
API,以及筆刷
和選擇的漸層
Text( text = buildAnnotatedString { append("Do not allow people to dim your shine\n") withStyle( SpanStyle( brush = Brush.linearGradient( colors = rainbowColors ) ) ) { append("because they are blinded.") } append("\nTell them to put some sunglasses on.") } )
文字區塊的不透明度
如要調整特定文字段的不透明度,請使用 SpanStyle
的
自選 alpha
參數請為文字的兩個部分使用相同的筆刷,並變更對應區間中的 alpha 參數。在程式碼範例中,第一段文字會以半透明度顯示
(alpha =.5f
) 時,第二個則會以完全不透明度 (alpha = 1f
) 顯示。
val brush = Brush.linearGradient(colors = rainbowColors) buildAnnotatedString { withStyle( SpanStyle( brush = brush, alpha = .5f ) ) { append("Text in ") } withStyle( SpanStyle( brush = brush, alpha = 1f ) ) { append("Compose ❤️") } }
其他資源
如需其他自訂範例,請參閱「Brushing Up on Compose Text Coloring」網誌文章。如想進一步瞭解
Brush
如何與 Animations API 整合,請參閱動畫筆刷文字顏色
。
將跑馬燈效果套用至文字
basicMarquee
修飾符可以套用至
就會產生動畫捲動效果如果內容正常
太寬,超出可用的限制。根據預設,basicMarquee
擁有
某些設定 (例如速率與初始延遲) 的特定設定,但您也可以
並修改這些參數來自訂效果
下列程式碼片段會在 Text
可組合項上實作基本醒目效果:
@Composable fun BasicMarqueeSample() { // Marquee only animates when the content doesn't fit in the max width. Column(Modifier.width(400.dp)) { Text( "Learn about why it's great to use Jetpack Compose", modifier = Modifier.basicMarquee(), fontSize = 50.sp ) } }
圖 6. 文字套用的 basicMarquee
修飾符。
為您推薦
- 注意:系統會在 JavaScript 關閉時顯示連結文字
- 樣式段落
- Compose 中的 Material Design 2
- 圖形修飾符