Panoramica di AppFunctions

AppFunctions è un'API della piattaforma Android con una libreria Jetpack di accompagnamento per semplificare l'integrazione di Android MCP. Consente alle tue app di comportarsi come server MCP sul dispositivo, fornendo funzioni che fungono da strumenti da utilizzare per funzionalità proattive insieme ad agenti e assistenti, come Google Gemini. A partire da maggio 2026, l'integrazione di AppFunctions con Gemini sarà disponibile in anteprima privata con i trusted tester. Puoi iniziare subito a preparare le tue app per utilizzare AppFunctions e gli strumenti di sviluppo.

Definendo queste AppFunctions, consenti alla tua app di fornire servizi, dati e azioni al registro integrato nel sistema operativo Android, consentendo agli utenti di completare le attività tramite agenti e interazioni a livello di sistema.

Le AppFunctions fungono 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, App Functions fornisce lo stesso meccanismo per le app per 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'autorizzazione EXECUTE_APP_FUNCTIONS per scoprire ed eseguire AppFunctions e possono includere agenti, app e assistenti AI come Gemini.

AppFunctions è disponibile sui dispositivi con Android 16 o versioni successive.

Esempi di casi d'uso

AppFunctions fornisce un meccanismo potente per automatizzare le attività e semplificare le interazioni degli utenti. Se apri le funzionalità della tua app, gli utenti possono raggiungere obiettivi complessi utilizzando il linguaggio naturale, spesso sostituendo la necessità di navigazione manuale passo passo con la tua UI.

I seguenti scenari illustrano come utilizzare App Functions per migliorare l'esperienza in una serie 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 posizione in base al prompt dell'utente.
    /**
    *   Create a new task or reminder with a title, due time, and location.
    *
    *   @param context The execution context provided by the system.
    *   @param title The descriptive title of the task (e.g., "Pick up my package").
    *   @param dueDateTime The specific date and time when the task should be completed.
    *   @param location The physical location associated with the task (e.g., "Work").
    *   @return The created Task
    */
    @AppFunction(isDescribedByKDoc = true)
    suspend fun createTask(
        context: AppFunctionContext,
        title: String,
        dueDateTime: LocalDateTime? = null,
        location: String? = null
    ) : Task
    
  • 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 di musica, passando il contesto come "migliori album jazz del 2026" come query per generare immediatamente la playlist.
    /**
    *   Create a new music playlist based on a natural language query.
    *
    *   @param context The execution context provided by the system.
    *   @param query The description used to generate the playlist (e.g., "top jazz albums from 2026").
    *   @return The final created playlist based on songs.
    */
    @AppFunction(isDescribedByKDoc = true)
    suspend fun createPlaylistFromQuery(
        context: AppFunctionContext,
        query: String
    ): Playlist
    
  • Workflow 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 funzioni di più app. Innanzitutto, il chiamante utilizza la funzione di ricerca di un'app di posta elettronica per recuperare il contenuto. Poi, estrae gli ingredienti pertinenti e richiama una funzione dell'app di lista della spesa per compilare la lista dell'utente.
    /**
    *   Search for emails matching a query or sender name to retrieve content like recipes.
    *
    *   @param context The execution context provided by the system.
    *   @param query The search term or contact name (e.g., "Lisa noodle recipe").
    *   @return A list of matching email summaries containing the requested information.
    */
    @AppFunction(isDescribedByKDoc = true)
    suspend fun searchEmails(
        context: AppFunctionContext,
        query: String
    ): List<EmailSummary>
    
    /**
    *   Add a list of items or ingredients to the user's active shopping list.
    *
    *   @param context The execution context provided by the system.
    *   @param items The names of the ingredients or products to add to the list.
    *   @return The final shopping list with new items added
    */
    @AppFunction(isDescribedByKDoc = true)
    suspend fun addItemsToShoppingList(
        context: AppFunctionContext,
        items: List<String>
    ): ShoppingList
    
  • 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 con agente approvata richiama la funzione "crea evento" dell'app calendario, analizzando il contesto pertinente come "lunedì prossimo" e "ore 18:00" per creare la voce senza che l'utente debba aprire manualmente il calendario.
    /**
    *   Schedule a new event on the user's primary calendar.
    *
    *   @param context The execution context provided by the system.
    *   @param title The name of the calendar event (e.g., "Mom's birthday party").
    *   @param startDateTime The specific date and time the event is scheduled to begin.
    *   @return The created Event object.
    */
    @AppFunction(isDescribedByKDoc = true)
    suspend fun createCalendarEvent(
        context: AppFunctionContext,
        title: String,
        startDateTime: LocalDateTime
    ): Event
    

Come funzionano le AppFunctions

Il seguente diagramma illustra il flusso tipico di condivisione delle AppFunctions dalle app a un agente e la loro successiva esecuzione. È 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 utilizzare AppFunctions per rendere disponibili le sue funzionalità, 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. Il sistema operativo Android utilizza questo file 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 seleziona ed esegue l'AppFunction appropriata con i parametri appropriati.
Flusso tipico di AppFunctions dall&#39;esposizione dell&#39;app all&#39;esecuzione dell&#39;agente.
Figura 1: il flusso tipico di come vengono esposte le AppFunctions e successivamente eseguite da un agente.

La libreria Jetpack AppFunctions semplifica l'esposizione delle funzionalità della tua app. Con il processore di annotazioni, annoti le funzioni che vuoi rendere disponibili agli agenti. 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 supportata, le persone che chiamano possono verificare se una funzione specifica è attivata all'interno di un'app di destinazione utilizzando isAppFunctionEnabled(packageName,functionId). L'esecuzione di query sullo stato delle funzioni in altri pacchetti richiede android.permission.EXECUTE_APP_FUNCTIONSpermission.

La tua app non è tenuta a verificare 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 sezione seguente contiene le domande frequenti su AppFunctions.

Sono uno sviluppatore di app. Posso implementare AppFunctions oggi?

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

Qual è la differenza tra AppFunctions e MCP?

Entrambi consentono agli agenti AI di orchestrare gli strumenti, ma presentano differenze significative in termini di architettura, latenza e impegno richiesto agli sviluppatori. Le AppFunctions sono hook a livello di sistema operativo integrati esclusivi di Android che vengono eseguiti localmente. Al contrario, un server MCP standard è una soluzione indipendente dalla piattaforma che si basa sull'esecuzione nel cloud e sui round trip di rete.

In breve, lo sviluppo con AppFunctions ti consente di utilizzare lo stato dell'app esistente direttamente sul dispositivo e non richiede di gestire servizi al di fuori della tua app per Android.

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 con agenti. Puoi implementare AppFunctions nella tua app. Per farlo, segui i passaggi descritti nelle sezioni precedenti di questa pagina e verifica che siano registrate sul dispositivo chiamando adb shell cmd app_function list-app-functions.

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

Stiamo conducendo un programma di accesso in anteprima (EAP) per integrare app selezionate nei test dell'esperienza end-to-end per gli sviluppatori necessaria per lanciare AppFunctions in produzione su Android. Puoi registrare il tuo interesse a integrare le tue AppFunctions tramite questo modulo di registrazione al programma EAP. Registrando il tuo interesse, NON ottieni automaticamente l'accesso all'integrazione completa. Ti invieremo un'email se la tua app viene selezionata per il programma di accesso anticipato o per comunicarti quando AppFunctions diventerà 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.