Panoramica di AppFunctions

AppFunctions consente alla tua app per Android di condividere funzionalità specifiche che il sistema e vari agenti e assistenti AI possono scoprire e richiamare. Definendo queste funzioni, consenti alla tua app di fornire servizi, dati e azioni al sistema operativo Android, consentendo agli utenti di completare le attività tramite agenti AI e interazioni a livello di sistema.

AppFunctions funge da equivalente mobile degli strumenti all'interno del Model Context Protocol (MCP). Mentre MCP standardizza tradizionalmente il modo in cui gli agenti si connettono agli strumenti lato server, AppFunctions fornisce lo stesso meccanismo per le app Android. In questo modo, puoi esporre le funzionalità della tua app come "strumenti" orchestrabili che le app autorizzate (chiamanti) possono scoprire ed eseguire per soddisfare le intenzioni degli utenti. I chiamanti devono disporre dell'EXECUTE_APP_FUNCTIONS autorizzazione per scoprire ed eseguire AppFunctions e possono includere agenti, app, e assistenti AI come Gemini.

AppFunctions funziona con i dispositivi con Android 16 o versioni successive.

Esempi di casi d'uso

AppFunctions fornisce un meccanismo efficace per automatizzare le attività e semplificare le interazioni degli utenti. Esponendo le funzionalità della tua app, consenti agli utenti di raggiungere obiettivi complessi utilizzando il linguaggio naturale, spesso senza la necessità di una navigazione manuale passo passo con la tua UI.

I seguenti scenari illustrano come AppFunctions può essere utilizzato per migliorare le esperienze in una varietà di categorie di app:

  • Gestione delle attività e produttività
    • Richiesta dell'utente: "Ricordami di ritirare il pacco al lavoro oggi alle 17 :00".
    • Azione AppFunction: il chiamante identifica l'app di gestione delle attività pertinente e richiama una funzione per creare un'attività, compilando automaticamente i campi titolo, ora e località in base al prompt dell'utente.
  • Media e intrattenimento
    • Richiesta dell'utente: "Crea una nuova playlist con i migliori album jazz di quest'anno".
    • Azione AppFunction: il chiamante esegue una funzione di creazione di playlist all'interno di un'app musicale, passando il contesto come "i migliori album jazz del 2026" come query per generare e avviare immediatamente i contenuti.
  • Flussi di lavoro tra app
    • Richiesta dell'utente: "Trova la ricetta dei noodle nell'email di Lisa e aggiungi gli ingredienti alla mia lista della spesa".
    • Azione AppFunction: questa richiesta utilizza le funzioni di più app. Innanzitutto, il chiamante utilizza la funzione di ricerca di un'app di posta elettronica per recuperare i contenuti. Poi, estrae gli ingredienti pertinenti e richiama la funzione di un'app per la lista della spesa per compilare l'elenco dell'utente.
  • Calendario e pianificazione
    • Richiesta dell'utente: "Aggiungi la festa di compleanno di mamma al mio calendario per lunedì prossimo alle 18:00".
    • Azione AppFunction: l'app agentica approvata richiama la funzione "Crea evento" dell'app Calendario, analizzando il contesto pertinente come "lunedì prossimo" e "18:00" per creare la voce senza che l'utente debba aprire manualmente il calendario.

Come funziona AppFunctions

AppFunctions è una funzionalità della piattaforma Android 16 e una libreria Jetpack di accompagnamento che consente alle app di esporre funzioni specifiche a cui i chiamanti, come le app agenti, possono accedere ed eseguire sul dispositivo.

Il seguente diagramma illustra il flusso tipico di come le app condividono AppFunctions con un agente e le eseguono successivamente. È probabile che gli agenti prendano in considerazione sia gli strumenti MCP remoti lato server sia AppFunctions locali quando gestiscono le richieste degli utenti. Il flusso dettagliato per l'utilizzo di AppFunctions locali è il seguente:

  • Dichiarazione AppFunction: l'app per Android è progettata per esporre le sue AppFunctions, ad esempio "Crea nota" o "Invia messaggio".
  • Generazione dello schema: la libreria Jetpack AppFunctions genera un file di schema XML che elenca tutte le AppFunctions dichiarate nell'app. Questo file viene utilizzato dal sistema operativo Android per indicizzare le AppFunctions disponibili.
  • Recupero dei metadati: l'agente può recuperare i metadati di AppFunction eseguendo una query.
  • Selezione ed esecuzione di AppFunction: in base ai prompt dell'utente, l'agente selezionerà ed eseguirà l'AppFunction appropriata con i parametri appropriati.
Diagramma che mostra il flusso tipico di AppFunctions dall'esposizione dell'app all'esecuzione dell'agente.
Figura 1: il flusso tipico di come un agente espone ed esegue AppFunctions.

La libreria Jetpack AppFunctions semplifica l'esposizione delle funzionalità della tua app. Con il processore di annotazioni, gli sviluppatori annotano le funzioni che vogliono esporre. I chiamanti possono quindi scoprire e richiamare queste funzioni indicizzate utilizzando AppFunctionManager.

Prima di richiamare una funzione, i chiamanti devono verificare che il dispositivo supporti la funzionalità AppFunctions tentando di recuperare un'istanza di AppFunctionManager. Una volta supportati, i chiamanti possono verificare se una specifica funzione è abilitata all'interno di un'app di destinazione utilizzando isAppFunctionEnabled(packageName, functionId). L'esecuzione di query sullo stato delle funzioni in altri pacchetti richiede l' android.permission.EXECUTE_APP_FUNCTIONS permission.

Non è necessario che la tua app verifichi se la funzionalità AppFunction è supportata. Questa operazione viene gestita automaticamente all'interno della libreria Jetpack. Ad esempio, AppFunctionManager può verificare se la funzionalità è supportata.

Ecco un esempio di AppFunctions per un'app per prendere appunti con funzionalità per creare, modificare ed elencare le note:

/**
 * A note app's [AppFunction]s.
 */
class NoteFunctions(
    private val noteRepository: NoteRepository
) {
    /**
     * Lists all available notes.
     *
     * @param appFunctionContext The context in which the AppFunction is executed.
     */
    @AppFunction(isDescribedByKDoc = true)
    suspend fun listNotes(appFunctionContext: AppFunctionContext): List<Note>? {
        return noteRepository.appNotes.ifEmpty { null }?.toList()
    }

    /**
     * Adds a new note to the app.
     *
     * @param appFunctionContext The context in which the AppFunction is executed.
     * @param title The title of the note.
     * @param content The note's content.
     */
    @AppFunction(isDescribedByKDoc = true)
    suspend fun createNote(
        appFunctionContext: AppFunctionContext,
        title: String,
        content: String
    ): Note {
        return noteRepository.createNote(title, content)
    }

    /**
     * Edits a single note.
     *
     * @param appFunctionContext The context in which the AppFunction is executed.
     * @param noteId The target note's ID.
     * @param title The note's title if it should be updated.
     * @param content The new content if it should be updated.
     */
    @AppFunction(isDescribedByKDoc = true)
    suspend fun editNote(
        appFunctionContext: AppFunctionContext,
        noteId: Int,
        title: String?,
        content: String?,
    ): Note? {
        return noteRepository.updateNote(noteId, title, content)
    }
}

/**
 * A note.
 */
@AppFunctionSerializable(isDescribedByKDoc = true)
data class Note(
    /** The note's identifier */
    val id: Int,
    /** The note's title */
    val title: String,
    /** The note's content */
    val content: String
)

Domande frequenti

La seguente sezione contiene le domande frequenti su AppFunctions.

Sono uno sviluppatore di app. Posso implementare AppFunctions oggi stesso?

Sì, è possibile implementare e testare AppFunctions all'interno della tua app seguendo le indicazioni dettagliate nelle sezioni precedenti.

Ho implementato AppFunctions nella mia app. Perché il mio agente di sistema non può accedervi?

AppFunctions è una funzionalità sperimentale. Per valutare attentamente la qualità dell'esperienza complessiva durante questa fase sperimentale, solo un numero limitato di app e agenti di sistema può accedere all'intera pipeline.

Come posso preparare la mia app per la disponibilità generale di AppFunctions?

Valuta quali funzionalità della tua app vuoi esporre all'automazione agentica. Puoi implementare AppFunctions nella tua app. Per farlo, segui i passaggi descritti nelle sezioni precedenti di questa pagina e verifica che siano registrati sul dispositivo chiamando adb shell cmd app_function list-app-functions.

Posso accedere in anteprima all'esperienza di sviluppo agentica end-to-end?

Stiamo conducendo un programma di accesso in anteprima (EAP) per integrare le app selezionate nel test dell'esperienza di sviluppo end-to-end necessaria per lanciare AppFunctions in produzione su Android. Puoi manifestare il tuo interesse a integrare le tue AppFunctions tramite questo modulo di registrazione all'EAP. La registrazione del tuo interesse NON ti garantisce automaticamente l'accesso all'integrazione completa. Ti invieremo un'email se la tua app viene selezionata per l'EAP o per informarti quando AppFunctions sarà disponibile pubblicamente.

Come faccio a fornire un feedback su AppFunctions?

Puoi fornire un feedback sull'API segnalando un problema e registrando il tuo interesse nel modulo del programma di accesso in anteprima.