テキストのスタイルを設定する

Text コンポーザブルには、コンテンツのスタイル設定を行うためのオプションのパラメータが複数用意されています。以下に、テキストに関する最も一般的なユースケースに対応するパラメータを示します。Text のすべてのパラメータについては、Compose Text ソースコードをご覧ください。

これらのパラメータを設定すると、テキスト値全体にスタイルが適用されます。同じ行や段落内に複数のスタイルを適用する必要がある場合は、複数のインライン スタイルのセクションをご覧ください。

一般的なテキストのスタイル設定

以降のセクションでは、テキストにスタイルを設定する一般的な方法について説明します。

テキストの色を変更する

@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
  • SpanStyleRangeList(テキスト値内の位置範囲を使用したインライン スタイル設定と同等です)
  • ParagraphStyleRangeList(テキストの配置、テキスト方向、行の高さ、テキストのインデント スタイルを指定します)

TextStyleText コンポーザブルで使用され、SpanStyleParagraphStyleAnnotatedString で使用されます。段落内の複数のスタイルの詳細については、段落に複数のスタイルを追加するをご覧ください。

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")
        }
    )
}

単語

AnnotatedString.fromHtml() を使用すると、Jetpack Compose アプリケーションにクリック可能なリンクを含む HTML 形式のテキストを表示できます。この関数は、HTML タグを含む文字列を AnnotatedString に変換し、スタイル設定とリンク処理を可能にします。

例: スタイル設定されたリンクを含む HTML

このスニペットは、リンク付きの HTML 形式のテキストをレンダリングし、リンクに特定のスタイルを適用します。

コードに関する主なポイント
  • AnnotatedString.fromHtml() は、htmlText 文字列を AnnotatedString に変換します。linkStyles パラメータは、リンクの外観をカスタマイズします。

  • TextLinkStyles は、HTML 内のリンクのスタイルを定義します。SpanStyle は、リンクのテキスト装飾、フォント スタイル、色を設定します。

  • Text コンポーザブルは、結果の AnnotatedString を表示します。

結果

このスニペットでは、「Jetpack Compose」をクリック可能なリンクとして有効にし、青色で下線を引いて斜体にしています。

H1 見出し「Jetpack Compose」の後に「Jetpack Compose で優れたアプリを構築する」という見出しがあります。ここで、Jetpack Compose は青色、下線、斜体でスタイル設定されたクリック可能なリンクです。
図 2. 見出しと段落。段落内の「Jetpack Compose」は、クリック可能なスタイル設定されたリンクです。

Brush で高度なスタイル設定を有効にする

より高度なテキスト スタイルを有効にするには、Brush API を TextStyleSpanStyle とともに使用します。通常 TextStyle または SpanStyle を使用する場所で、Brush を使用できるようになりました。

ブラシを使用してテキストのスタイルを設定する

TextStyle の組み込みブラシを使用してテキストを構成します。たとえば、次のようにテキストに linearGradient ブラシを設定できます。

val gradientColors = listOf(Cyan, LightBlue, Purple /*...*/)

Text(
    text = text,
    style = TextStyle(
        brush = Brush.linearGradient(
            colors = gradientColors
        )
    )
)

定義された色のリストを使用して、Brush API の linearGradient 関数を使用する。
図 3. 定義された色のリストを使用して Brush API の linearGradient 関数を使用する。

この特定の配色や色付けスタイルに限定されるわけではありません。ハイライト表示の簡単な例を示しましたが、組み込みのブラシSolidColor を使用してテキストを強調することもできます。

統合

BrushTextStyleSpanStyle の両方と一緒に使用できるため、TextFieldbuildAnnotatedString との統合はシームレスです。

TextField 内での Brush API の使用方法については、Brush API を使用したスタイル入力をご覧ください。

SpanStyle を使用した追加のスタイル設定

テキストの範囲にブラシを適用する

ブラシをテキストの一部にのみ適用する場合は、buildAnnotatedStringSpanStyle 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.")
    }
)

デフォルトのブラシと、テキストのスタイルとして linearGradient を使用。
図 4. Text のスタイルとして linearGradient を指定したデフォルトのブラシを使用。
テキストの範囲内の不透明度

特定のテキスト範囲の不透明度を調整するには、SpanStyle のオプションの alpha パラメータを使用します。テキストの両方の部分に同じブラシを使用し、対応するスパンのアルファ パラメータを変更します。コードサンプルでは、最初のテキスト スパンは半透明(alpha =.5f)で表示され、2 つ目のテキスト スパンは完全な透明度(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 ❤️")
    }
}

buildAnnotatedString と SpanStyle の alpha パラメータと linearGradient を使用して、テキストの範囲に不透明度を追加します。
図 5. buildAnnotatedStringSpanStyle の alpha パラメータと linearGradient を使用して、テキストのスパンに不透明度を追加する。

参考情報

その他のカスタマイズの例については、Compose テキストの色付けのブラッシングに関するブログ投稿をご覧ください。Brush を Animations API と統合する方法について詳しくは、Compose でブラシテキストの色をアニメーション化するをご覧ください。

テキストにマーキー効果を適用する

任意のコンポーザブルに 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 修飾子。