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, contribuendo con funzioni che fungono da strumenti per l'utilizzo da parte di funzionalità proattive insieme ad agenti e assistenti, come Google Gemini. A partire da maggio 2026, l'integrazione di AppFunctions con Gemini è in anteprima privata con tester di fiducia. Puoi iniziare a preparare le tue app ora 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 sono l'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 dell'utente. I chiamanti devono disporre dell'autorizzazione EXECUTE_APP_FUNCTIONS per scoprire ed eseguire le 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

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

I seguenti scenari illustrano come le AppFunctions possono essere utilizzate per migliorare le esperienze in varie 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.
    /**
    *   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 musicale, passando il contesto come "i 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
    
  • 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.
    /**
    *   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 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.
    /**
    *   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 come le AppFunctions vengono condivise dalle app con un agente e successivamente eseguite. È probabile che gli agenti prendano in considerazione sia gli strumenti MCP remoti lato server sia le AppFunctions locali quando gestiscono le richieste degli utenti. Il flusso dettagliato per l'utilizzo delle AppFunctions locali è il seguente:

  • Dichiarazione di AppFunction: l'app per Android è progettata per utilizzare le 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 le AppFunctions vengono esposte e successivamente eseguite da un agente.

La libreria Jetpack AppFunctions semplifica l'esposizione delle funzionalità della tua app. Con il processore di annotazioni, puoi annotare 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 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_FUNCTIONSpermission.

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
)

Esempi, skill e agente di test

Abbiamo reso disponibili i seguenti elementi per aiutarti a migliorare le tue competenze in AppFunctions:

  • Esplora l'esempio di AppFunctions per verificare ed esplorare il funzionamento di tutto sui tuoi dispositivi.
  • La skill AppFunctions rileva e consiglia le funzionalità della tua app che potrebbero essere implementate come AppFunctions. Può anche implementare e perfezionare le AppFunctions esistenti per te.
  • Per i test end-to-end, utilizza l'app agente di esempio.

Domande frequenti

La sezione seguente risponde alle domande frequenti su AppFunctions.

Sono uno sviluppatore di app. Posso implementare AppFunctions oggi?

Sì, è possibile implementare e testare le AppFunctions all'interno della tua app seguendo le indicazioni dettagliate 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 i servizi al di fuori dell'app per Android.

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

Le AppFunctions sono 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 le 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 ottenere l'accesso 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 le AppFunctions saranno disponibili pubblicamente.

Come posso 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.