Aggiungi funzionalità alle scorciatoie

Le funzionalità in shortcuts.xml ti consentono di dichiarare i tipi di azioni che gli utenti possono intraprendere per avviare la tua app ed eseguire direttamente un'attività specifica.

Ad esempio, le Azioni app dell'Assistente Google utilizzano le funzionalità per consentire agli sviluppatori di estendere le funzionalità in-app agli intent integrati, consentendo agli utenti di attivare e controllare queste funzionalità utilizzando i comandi vocali. Una funzionalità è costituita dal nome dell'azione e da un intent che ha come target la destinazione nella tua app che risolve l'intent dell'utente.

Definisci le funzionalità in shortcuts.xml

Definisci gli elementi capability in un file di risorse shortcuts.xml nel tuo progetto di sviluppo di app per Android. Per definire un elemento capability:

  1. Crea una risorsa shortcuts.xml seguendo le istruzioni riportate in Creare scorciatoie statiche.
  2. Includi le seguenti informazioni obbligatorie nella tua funzionalità:

    • Nome funzionalità:l'azione che vuoi che la tua app supporti. Consulta la documentazione del componente per la funzionalità che richiede definizioni delle funzionalità. I comandi vocali delle Azioni app utilizzano l'intent integrato Action ID per i nomi delle funzionalità, che puoi trovare nel riferimento degli intent integrati. Ad esempio, l'intent integrato GET_THING elenca il suo Action ID come actions.intent.GET_THING.

    • Destinazione app: la destinazione nella tua app in cui viene avviata l'azione per soddisfare la richiesta dell'utente. Definisci le destinazioni delle app utilizzando gli elementi intent nidificati all'interno di capability.

    • Mappature dei parametri:ogni intent potrebbe contenere parametri da trasmettere come dati extra dell'intent. Ad esempio, ogni intent integrato di Azioni app include campi che rappresentano le informazioni che gli utenti forniscono spesso nelle query che attivano l'intent integrato.

L'esempio seguente mostra una definizione di funzionalità in shortcuts.xml per actions.intent.START_EXERCISE, un intent integrato che consente agli utenti di utilizzare comandi vocali con l'assistente per iniziare un allenamento in un'app per il fitness:

<shortcuts xmlns:android="http://schemas.android.com/apk/res/android">
  <capability android:name="actions.intent.START_EXERCISE">
    <intent
      android:action="android.intent.action.VIEW"
      android:targetPackage="com.example.sampleApp"
      android:targetClass="com.example.sampleApp.ExerciseActivity">
      <parameter
        android:name="exercise.name"
        android:key="exerciseType"/>
    </intent>
  </capability>
</shortcuts>

Nell'esempio precedente, l'attributo <capability> android:name si riferisce all'intent integrato START_EXERCISE. Se un utente richiama questo intent integrato chiedendo all'assistente "Hey Google, inizia una corsa in ExampleApp", l'assistente soddisfa la richiesta dell'utente utilizzando le informazioni fornite nell'elemento intent nidificato. intent in questo esempio definisce i seguenti dettagli:

  • android:targetPackage imposta il pacchetto dell'applicazione di destinazione per questo intent.
  • Il campo android:targetClass specifica l'attività di destinazione: com.example.sampleApp.ExerciseActivity.
  • L'intent parameter dichiara il supporto per un parametro BII exercise.name e come passare il valore del parametro, raccolto dall'utente, come dati aggiuntivi in intent.

Associare scorciatoie a una funzionalità

Una volta definita una funzionalità, puoi estenderne la funzionalità associandovi scorciatoie statiche o dinamiche. Il modo in cui le scorciatoie sono collegate a un capability dipende dalla funzionalità implementata e dalle parole effettive incluse nella richiesta di un utente. Ad esempio, quando un utente inizia una corsa nella tua app di monitoraggio dell'attività fisica chiedendo all'assistente: "Hey Google, inizia una corsa in ExampleApp". L'assistente può utilizzare una scorciatoia per avviare un'istanza di un capability che definisce un'entità di esercizio valida di "corsa" per il parametro exercise.name.

Per ulteriori informazioni sull'associazione di scorciatoie alle Azioni app, consulta la panoramica delle Azioni app.