絵文字を表示

絵文字の標準セットは、あらゆる種類のアプリで絵文字の使用が急増しているため、Unicode で毎年更新されています。

アプリがインターネット コンテンツを表示する場合やテキスト入力を提供する場合、最新の絵文字フォントをサポートすることを強くおすすめします。そうしないと、後で絵文字が豆腐(QUIC)と呼ばれる小さな正方形のボックスとして表示されることがあります(または、その他の正しくレンダリングされない絵文字シーケンス)ことがあります。

Android バージョン 11(API レベル 30)以前では絵文字フォントを更新できないため、これらのバージョンで絵文字を表示するアプリは手動で更新する必要があります。

最新の絵文字の例を以下に示します。

バージョン
🫠 🫱🏼‍🫲🏿 🫰🏽 14.0(2021 年 9 月)
😶‍🌫️ 🧔🏻‍♀️ 🧑🏿‍❤️‍🧑🏾 13.1(2020 年 9 月)
🥲 🥷🏿 🐻‍❄️ 13.0(2020 年 3 月)
🧑🏻‍🦰 🧑🏿‍🦯 👩🏻‍🤝‍👩🏼 12.1(2019 年 10 月)
🦩 🦻🏿 👩🏼‍🤝‍👩🏻 12.0(2019 年 2 月)

2023 年 3 月 BOMCompose UI 1.4)では、最新の絵文字バージョンのサポートが導入されました。これには、API 21 までの古い Android バージョンとの下位互換性が含まれます。

このサポートのためにアプリを変更する必要はありませんTextTextField(マテリアル 2 またはマテリアル 3)、または BasicTextBasicTextField を使用すると、最新の絵文字サポートをすぐに利用できます。

アプリで最新の絵文字をテストする最適な方法は、API 30 以前を搭載した実際のデバイスを使用することです。

カスタム絵文字ソリューションを使用している場合、またはなんらかの理由で Compose のデフォルトの絵文字解像度を無効にする必要がある場合は、PlatformTextStyle(emojiSupportMatch) を使用します。

Text(
    text = "Hello $EMOJI_TEXT",
    style = TextStyle(
        platformStyle = PlatformTextStyle(
            emojiSupportMatch = EmojiSupportMatch.None
        )/* ... */
    )
)

相互運用性

アプリで同じ Activity 内で View と Compose の両方を使用する場合は、適切な API を使用して絵文字を正しく設定していることを確認してください。以降のセクションでは、各 API を使用する状況について説明します。

ComponentActivity から拡張しています

ActivityAppCompatActivity ではなく Compose ComponentActivity から拡張されている場合は、AppCompat なしで絵文字をサポートするの手順に沿って操作します。

AppCompatActivity を拡張していないため、依存関係に Emoji2 ライブラリを追加し、ビューで TextView ウィジェットではなく EmojiTextView を使用します。次のスニペットをご覧ください。

class MainActivity : ComponentActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val emojiTextView: EmojiTextView = findViewById(R.id.emoji_text_view)
        emojiTextView.text = getString(R.string.emoji_text_view, EMOJI_TEXT)

        val composeView: ComposeView = findViewById(R.id.compose_view)

        composeView.apply {
            setContent {
                // compose code
            }
        }
    }
}

XML ファイルで次のようにします。

<androidx.emoji2.widget.EmojiTextView
    android:id="@+id/emoji_text_view"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    />

AppCompatActivity から拡張しています

ActivityAppCompatActivity から拡張されている場合は、ComposeView を使用してコンポーズ可能な関数を呼び出すことができます。テキスト コンポーザブルを使用すると、Android バージョン間で絵文字が正しくレンダリングされます。

AppCompatActivity から拡張する場合は、XML から TextView をインフレートして、絵文字が正しくレンダリングされるようにします。

これは、XML をインフレートする場合に該当します。

  • ComposeView 外の Activity 内。次のスニペットで AppCompatActivityTextView を使用していることに注目してください。

class MyActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val emojiTextView: TextView = findViewById(R.id.emoji_text_view)
        emojiTextView.text = getString(R.string.emoji_text_view, EMOJI_TEXT)

        val composeView: ComposeView = findViewById(R.id.compose_view)

        composeView.apply {
            setContent {
                // compose code
            }
        }
    }
}

class MyActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)

        setContentView(
            ComposeView(this).apply {
                setContent {
                    Column {
                        Text(EMOJI_TEXT)

                        AndroidViewBinding(ExampleViewBinding::inflate) {
                            emojiTextView.text = EMOJI_TEXT
                        }
                    }
                }
            }
        )
    }
}

ComposeView 内で AndroidView を使用してテキストをインフレートするには、AppCompatTextView を使用して絵文字を適切にレンダリングします。

class MyActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)

        setContentView(
            ComposeView(this).apply {
                setContent {
                    Column {
                        Text(EMOJI_TEXT)

                        AndroidView(
                            factory = { context -> AppCompatTextView(context) },
                            update = { it.text = EMOJI_TEXT }
                        )
                    }
                }
            }
        )
    }
}

詳しくは、相互運用 API のドキュメントをご覧ください。

トラブルシューティング

絵文字の代わりに豆腐(ロゴ)が表示される場合は、まず、問題が特定のテストデバイスにあるかどうかを確認します。確認できる主な項目は次のとおりです。