Mostrar emojis

O conjunto padrão de emojis é atualizado anualmente pelo Unicode, já que o uso de emojis está aumentando rapidamente para todos os tipos de apps.

Caso seu app mostre conteúdo da Internet ou permita a entrada de texto, recomendamos que você ofereça suporte para as fontes de emojis mais recentes. Caso contrário, emojis mais recentes poderão ser mostrados como um pequeno quadrado chamado de tofu (☐) ou outras sequências de emojis renderizadas incorretamente.

O Android 11 (nível 30 da API) e versões anteriores não podem atualizar a fonte de emojis. Portanto, os apps que as exibem nessas versões precisam ser atualizados manualmente.

Confira a seguir exemplos de emojis modernos.

Exemplos Versão
🫠 🫱🏼‍🫲🏿 🫰🏽 14.0 (setembro de 2021)
😶‍🌫️ 🧔🏻‍♀️ 🧑🏿‍❤️‍🧑🏾 13.1 (setembro de 2020)
🥲 🥷🏿 🐻‍❄️ 13.0 (março de 2020)
🧑🏻‍🦰 🧑🏿‍🦯 👩🏻‍🤝‍👩🏼 12.1 (outubro de 2019)
🦩 🦻🏿 👩🏼‍🤝‍👩🏻 12.0 (fevereiro de 2019)

A BOM de março de 2023 (Compose UI 1.4) oferece suporte à versão mais recente de emojis, incluindo compatibilidade com versões mais antigas do Android até a API 21.

Esse suporte não requer mudanças no app. Se você usa Text e TextField (Material 2 ou Material 3) ou BasicText e BasicTextField, você tem suporte para emoji moderno pronto para uso.

A melhor maneira de testar os emojis mais recentes no seu app é usando um dispositivo real na API 30 ou anterior.

Se você estiver usando uma solução de emoji personalizada ou precisar desativar a resolução padrão de emoji no Compose por qualquer outro motivo, use PlatformTextStyle(emojiSupportMatch):

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

Interoperabilidade

Se o app usar visualizações e o Compose na mesma Activity, verifique se você está usando as APIs adequadas para configurar emojis corretamente. As seções a seguir descrevem quando usar cada API.

Extensão de ComponentActivity

Se o Activity for estendido do Compose ComponentActivity em vez de AppCompatActivity, siga as instruções Oferecer suporte a emojis sem a AppCompat.

Como você não está estendendo AppCompatActivity, adicione a biblioteca Emoji2 às suas dependências e use EmojiTextView nas suas visualizações em vez do widget TextView, conforme mostrado no snippet a seguir:

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

Em seguida, no arquivo XML:

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

Extensão de AppCompatActivity

Se o Activity se estende de AppCompatActivity, use ComposeView para chamar funções combináveis. Os emojis são renderizados corretamente em versões do Android quando você usa elementos combináveis de texto.

Se você estiver estendendo de AppCompatActivity, infle TextView do XML para renderizar os emojis corretamente.

Isso se aplica se você estiver inflando o XML:

  • fora de ComposeView, no Activity. Observe o uso de AppCompatActivity e TextView no snippet a seguir:

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

Para inflar um texto com AndroidView dentro de ComposeView, use AppCompatTextView para renderizar emojis corretamente:

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

Consulte a documentação das APIs de interoperabilidade para mais detalhes.

Solução de problemas

Se você vir um tofu (☐) em vez do emoji, primeiro verifique se o problema está no dispositivo de teste específico. Há alguns pontos principais que você pode verificar: