Compatibilità con emoji

Prova il modo di comporre
Jetpack Compose è il toolkit per la UI consigliato per Android. Scopri come supportare le emoji in Composizione.

La libreria di supporto EmojiCompat ha lo scopo di mantenere aggiornati i dispositivi Android con le emoji più recenti. Impedisce alla tua app di mostrare i caratteri emoji mancanti sotto forma di ☐, il che indica che il tuo dispositivo non ha un carattere per visualizzare il testo. Utilizzando la libreria di supporto EmojiCompat, gli utenti della tua app non devono attendere gli aggiornamenti del sistema operativo Android per ricevere le emoji più recenti.

Dispositivi che mostrano le emoji
Figura 1. Confronto tra emoji

Consulta le seguenti risorse correlate:

  • App di esempio per la compatibilità delle emoji Java | Kotlin

Come funziona EmojiCompat?

La libreria di supporto EmojiCompat fornisce classi per implementare il supporto degli emoji compatibile con le versioni precedenti sui dispositivi con Android 4.4 (livello API 19) e versioni successive. Puoi configurare EmojiCompat con caratteri in bundle o scaricabili. Per ulteriori informazioni sulla configurazione, consulta le sezioni seguenti:

EmojiCompat identifica le emoji per un determinato CharSequence, le sostituisce con EmojiSpans, se necessario, e infine esegue il rendering dei glifi delle emoji. La Figura 2 mostra la procedura.

Processo EmojiCompat
Figura 2. Procedura EmojiCompat

Configurazione dei caratteri scaricabili

La configurazione dei caratteri scaricabili utilizza la funzionalità della libreria di supporto dei caratteri scaricabili per scaricare un carattere emoji. Aggiorna anche i metadati delle emoji necessari alla libreria di supporto EmojiCompat per rimanere al passo con le ultime versioni della specifica Unicode.

Aggiunta della dipendenza della libreria di supporto

Per utilizzare la libreria di supporto EmojiCompat, devi modificare le dipendenze del classpath del progetto dell'app all'interno del tuo ambiente di sviluppo.

Per aggiungere una libreria di supporto al progetto dell'applicazione:

  1. Apri il file build.gradle della tua applicazione.
  2. Aggiungi la libreria di supporto alla sezione dependencies.

Groovy

dependencies {
    ...
    implementation "androidx.emoji:emoji:28.0.0"
}

Kotlin

dependencies {
    ...
    implementation("androidx.emoji:emoji:28.0.0")
}

Inizializzazione della configurazione del carattere scaricabile

Devi inizializzare EmojiCompat per caricare i metadati e il carattere. Poiché l'inizializzazione può richiedere un po' di tempo, il processo di inizializzazione viene eseguito su un thread in background.

Per inizializzare EmojiCompat con la configurazione dei caratteri scaricabili, segui questi passaggi:

  1. Crea un'istanza della classe FontRequest e fornisci l'autorità del fornitore di caratteri, il pacchetto del fornitore di caratteri, la query sui caratteri e un elenco di set di hash per il certificato. Per ulteriori informazioni su FontRequest, consulta la sezione Utilizzo dei caratteri scaricabili a livello di programmazione nella documentazione relativa ai caratteri scaricabili.
  2. Crea un'istanza di FontRequestEmojiCompatConfig e fornisci istanze di Context e FontRequest.
  3. Inizializza EmojiCompat chiamando il metodo init() e passa l'istanza di FontRequestEmojiCompatConfig.
  4. Kotlin

    class MyApplication : Application() {
    
        override fun onCreate() {
            super.onCreate()
            val fontRequest = FontRequest(
                    "com.example.fontprovider",
                    "com.example",
                    "emoji compat Font Query",
                    CERTIFICATES
            )
            val config = FontRequestEmojiCompatConfig(this, fontRequest)
            EmojiCompat.init(config)
        }
    }

    Java

    public class MyApplication extends Application {
      @Override
       public void onCreate() {
         super.onCreate();
         FontRequest fontRequest = new FontRequest(
           "com.example.fontprovider",
           "com.example",
           "emoji compat Font Query",
           CERTIFICATES);
         EmojiCompat.Config config = new FontRequestEmojiCompatConfig(this, fontRequest);
         EmojiCompat.init(config);
       }
    }
  5. Utilizzare i widget EmojiCompat nei file XML di layout. Se utilizzi AppCompat, consulta la sezione Utilizzo dei widget EmojiCompat con AppCompat.
  6. <android.support.text.emoji.widget.EmojiTextView
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"/>
    
    <android.support.text.emoji.widget.EmojiEditText
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"/>
    
    <android.support.text.emoji.widget.EmojiButton
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"/>

Per ulteriori informazioni su come configurare EmojiCompat con la configurazione dei caratteri scaricabili, consulta l'app di esempio Compatibilità emoji Java | Kotlin.

Componenti della raccolta

Componenti della libreria nel processo EmojiCompat
Figura 3. Componenti della libreria nel processo EmojiCompat
Widget: EmojiEditText, EmojiTextView, EmojiButton
Implementazioni predefinite dei widget da utilizzare EmojiCompat con TextView, EditText e Button.
EmojiCompat
Superficie pubblica principale per la libreria di assistenza. Esegue tutte le chiamate esterne e si coordina con le altre parti del sistema.
EmojiCompat.Config
Configura la creazione dell'istanza singleton.
EmojiSpan
Una sottoclasse ReplacementSpan che sostituisce i caratteri (sequenze) e visualizza il glifo.
EmojiCompat Carattere
EmojiCompat utilizza un carattere per visualizzare le emoji. Questo carattere è una versione modificata del carattere emoji Android. Il carattere viene modificato come segue:
  • Per garantire la compatibilità con le versioni precedenti per il rendering delle emoji, tutti i caratteri emoji sono rappresentati con un singolo punto di codice Unicode nell'area di utilizzo privato supplementare di Unicode a partire da U+F0001.
  • I metadati delle emoji aggiuntive vengono inseriti in formato binario nel carattere e vengono analizzati in fase di runtime da EmojiCompat. I dati sono incorporati nella tabella meta del carattere, con il tag privato Emji.

Opzioni di configurazione

Puoi utilizzare l'istanza EmojiCompat per modificare il comportamento di EmojiCompat. Puoi utilizzare i seguenti metodi della classe base per impostare la configurazione:

Kotlin

val config = FontRequestEmojiCompatConfig(...)
        .setReplaceAll(true)
        .setEmojiSpanIndicatorEnabled(true)
        .setEmojiSpanIndicatorColor(Color.GREEN)
        .registerInitCallback(object: EmojiCompat.InitCallback() {
            ...
        })

Java

EmojiCompat.Config config = new FontRequestEmojiCompatConfig(...)
       .setReplaceAll(true)
       .setEmojiSpanIndicatorEnabled(true)
       .setEmojiSpanIndicatorColor(Color.GREEN)
       .registerInitCallback(new InitCallback() {...})

Aggiunta di listener di inizializzazione

Le classi EmojiCompat e EmojiCompat forniscono metodi registerInitCallback() e unregisterInitCallback() per registrare un callback di inizializzazione. Per utilizzare questi metodi, crea un'istanza della classe EmojiCompat.InitCallback. Chiama questi metodi e passa l'istanza della classe EmojiCompat.InitCallback. Quando l'inizializzazione della libreria di supporto EmojiCompat va a buon fine, la classe EmojiCompat chiama il metodo onInitialized(). Se la libreria non viene inizializzata, la classe EmojiCompat chiama il metodo onFailed().

Per controllare lo stato di inizializzazione in qualsiasi momento, chiama il metodo getLoadState(). Restituisce uno dei seguenti valori: LOAD_STATE_LOADING, LOAD_STATE_SUCCEEDED, o LOAD_STATE_FAILED.

Utilizzare EmojiCompat con i widget AppCompat

Se utilizzi AppCompat widgets, puoi utilizzare i widget EmojiCompat che si estendono da AppCompat widgets.

  1. Aggiungi la libreria di supporto alla sezione delle dipendenze.

    Groovy

    dependencies {
        ...
        implementation "androidx.emoji:emoji-bundled:$version"
    }

    Kotlin

          dependencies {
              implementation("androidx.emoji:emoji-appcompat:$version")
          }
          

    Groovy

          dependencies {
              implementation "androidx.emoji:emoji-appcompat:$version"
          }
          
  2. Utilizza i widget EmojiCompat AppCompat Widget nei file XML di layout.
  3. <android.support.text.emoji.widget.EmojiAppCompatTextView
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"/>
    
    <android.support.text.emoji.widget.EmojiAppCompatEditText
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"/>
    
    <android.support.text.emoji.widget.EmojiAppCompatButton
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"/>

Configurazione dei caratteri inclusi

La libreria di supporto EmojiCompat è disponibile anche in una versione con caratteri in bundle. Questo pacchetto include il carattere con i metadati incorporati. Il pacchetto include anche un BundledEmojiCompatConfig che utilizza AssetManager per caricare i metadati e i caratteri.

Nota: le dimensioni del carattere sono di diversi megabyte.

Aggiunta della dipendenza della libreria di supporto

Per utilizzare la libreria di supporto EmojiCompat con la configurazione dei caratteri in bundle, devi modificare le dipendenze del classpath del progetto dell'app all'interno dell'ambiente di sviluppo.

Per aggiungere una libreria di supporto al progetto dell'applicazione:

  1. Apri il file build.gradle della tua applicazione.
  2. Aggiungi la libreria di supporto alla sezione dependencies.

Groovy

dependencies {
    ...
    implementation "androidx.emoji:emoji:28.0.0"
}

Kotlin

dependencies {
    ...
    implementation("androidx.emoji:emoji:28.0.0")
}

Utilizzo dei caratteri in bundle per configurare EmojiCompat

Per utilizzare i caratteri in bundle per configurare EmojiCompat, segui questi passaggi:

  1. Utilizza BundledEmojiCompatConfig per creare un'istanza di EmojiCompat e fornire un'istanza di Context.
  2. Chiama il metodo init() per inizializzare EmojiCompat e passa l'istanza di BundledEmojiCompatConfig.

Kotlin

class MyApplication : Application() {

    override fun onCreate() {
        super.onCreate()
        val config = BundledEmojiCompatConfig(this)
        EmojiCompat.init(config)
    }
}

Java

public class MyApplication extends Application {
    @Override
    public void onCreate() {
        super.onCreate();
        EmojiCompat.Config config = new BundledEmojiCompatConfig(this);
        EmojiCompat.init(config);
        ...
    }
}

Utilizzo di EmojiCompat senza widget

EmojiCompat utilizza EmojiSpan per il rendering delle immagini corrette. Pertanto, deve convertire qualsiasi CharSequence in istanze Spanned con EmojiSpans. La classe EmojiCompat fornisce un metodo per convertire CharSequences in istanze Spanned con EmojiSpans. Utilizzando questo metodo, puoi elaborare e memorizzare nella cache le istanze elaborate anziché la stringa non elaborata, il che migliora le prestazioni della tua applicazione.

Kotlin

val processed = EmojiCompat.get().process("neutral face \uD83D\uDE10")

Java

CharSequence processed = EmojiCompat.get().process("neutral face \uD83D\uDE10");

Utilizzo di EmojiCompat per gli IME

Utilizzando la libreria di supporto EmojiCompat, le tastiere possono eseguire il rendering delle emoji supportate dall'applicazione con cui interagiscono. Gli IME possono utilizzare il metodo hasEmojiGlyph() per verificare se EmojiCompat è in grado di eseguire il rendering di un'emoji. Questo metodo accetta un CharSequence di un'emoji e restituisce true se EmojiCompat può rilevare e visualizzare l'emoji.

La tastiera può anche controllare la versione della libreria di supporto EmojiCompat supportata dall'app per determinare quali emoji visualizzare nella tavolozza. Per controllare la versione, se disponibile, la tastiera deve verificare se le seguenti chiavi esistono nel bundle EditorInfo.extras:

Dopo aver ricevuto le chiavi nel bundle EditorInfo.extras, la tastiera può utilizzare il metodo hasEmojiGlyph(), dove metadataVersion è il valore di EDITOR_INFO_METAVERSION_KEY, per verificare se l'app può eseguire il rendering di un'emoji specifica.

Utilizzo di EmojiCompat con widget personalizzati

Puoi sempre utilizzare il metodo process() per preelaborare CharSequence nella tua app e aggiungerlo a qualsiasi widget in grado di eseguire il rendering delle istanze Spanned; ad esempio, TextView. Inoltre, EmojiCompat fornisce le seguenti classi helper per widget per consentirti di arricchire i tuoi widget personalizzati con il supporto delle emoji con uno sforzo minimo.

TextView di esempio

Kotlin

class MyTextView(context: Context) : AppCompatTextView(context) {

    private val emojiTextViewHelper: EmojiTextViewHelper by lazy(LazyThreadSafetyMode.NONE) {
        EmojiTextViewHelper(this).apply {
            updateTransformationMethod()
        }
    }

    override fun setFilters(filters: Array<InputFilter>) {
        super.setFilters(emojiTextViewHelper.getFilters(filters))
    }

    override fun setAllCaps(allCaps: Boolean) {
        super.setAllCaps(allCaps)
        emojiTextViewHelper.setAllCaps(allCaps)
    }
}

Java

public class MyTextView extends AppCompatTextView {
   ...
   public MyTextView(Context context) {
       super(context);
       init();
   }
   ...
   private void init() {
       getEmojiTextViewHelper().updateTransformationMethod();
   }

   @Override
   public void setFilters(InputFilter[] filters) {
       super.setFilters(getEmojiTextViewHelper().getFilters(filters));
   }

   @Override
   public void setAllCaps(boolean allCaps) {
       super.setAllCaps(allCaps);
       getEmojiTextViewHelper().setAllCaps(allCaps);
   }

   private EmojiTextViewHelper getEmojiTextViewHelper() {
       ...
   }
}
Sample EditText

Kotlin

class MyEditText(context: Context) : AppCompatEditText(context) {

    private val emojiEditTextHelper: EmojiEditTextHelper by lazy(LazyThreadSafetyMode.NONE) {
        EmojiEditTextHelper(this).also {
            super.setKeyListener(it.getKeyListener(keyListener))
        }
    }

    override fun setKeyListener(input: KeyListener?) {
        input?.also {
            super.setKeyListener(emojiEditTextHelper.getKeyListener(it))
        }
    }

    override fun onCreateInputConnection(outAttrs: EditorInfo): InputConnection {
        val inputConnection: InputConnection = super.onCreateInputConnection(outAttrs)
        return emojiEditTextHelper.onCreateInputConnection(
                inputConnection,
                outAttrs
        ) as InputConnection
    }
}

Java

public class MyEditText extends AppCompatEditText {
   ...
   public MyEditText(Context context) {
       super(context);
       init();
   }
   ...
   private void init() {
       super.setKeyListener(getEmojiEditTextHelper().getKeyListener(getKeyListener()));
   }

   @Override
   public void setKeyListener(android.text.method.KeyListener keyListener) {
       super.setKeyListener(getEmojiEditTextHelper().getKeyListener(keyListener));
   }

   @Override
   public InputConnection onCreateInputConnection(EditorInfo outAttrs) {
       InputConnection inputConnection = super.onCreateInputConnection(outAttrs);
       return getEmojiEditTextHelper().onCreateInputConnection(inputConnection, outAttrs);
   }

   private EmojiEditTextHelper getEmojiEditTextHelper() {
       ...
   }
}

Domande frequenti

  • Come faccio ad avviare il download del carattere?
  • I caratteri emoji vengono scaricati alla prima richiesta, se non esistono sul dispositivo. La pianificazione dei download è trasparente per l'app.

  • Quanto tempo è necessario per l'inizializzazione?
  • Dopo il download del carattere, sono necessari circa 150 millisecondi per inizializzare EmojiCompat.

  • Quanta memoria utilizza la libreria di supporto EmojiCompat?
  • Al momento, la struttura dei dati per trovare l'emoji viene caricata nella memoria dell'app e utilizza circa 200 KB.

  • Posso utilizzare EmojiCompat per un TextView personalizzato?
  • Sì. EmojiCompat fornisce classi helper per i widget personalizzati. È anche possibile preelaborare una determinata stringa e convertirla in Spanned. Per saperne di più sulle classi helper dei widget, consulta la sezione Utilizzare EmojiCompat con widget personalizzati.

  • Cosa succede se aggiungo widget nei file XML di layout sui dispositivi che eseguono Android 4.4 (livello API 19) o versioni precedenti?
  • Puoi includere la libreria di supporto EmojiCompat o i relativi widget nelle tue applicazioni che supportano dispositivi con Android 4.4 (livello API 19) o versioni precedenti. Tuttavia, se un dispositivo esegue una versione di Android precedente al livello API 19, EmojiCompat e i suoi widget sono in uno stato "nessuna operazione". Ciò significa che EmojiTextView si comporta esattamente come un normale TextView. istanza EmojiCompat; passa immediatamente allo stato LOAD_STATE_SUCCEEDED quando chiami il metodo init().

Risorse aggiuntive

Per ulteriori informazioni sull'utilizzo della libreria EmojiCompat, guarda EmojiCompat.