Iniziare
Copia un prompt di configurazione con i passaggi di installazione e la guida markdown completa per questo plugin.
Set up this Capacitor plugin in the project.
Use the package manager already used by the project.
Install these package(s): `@capgo/capacitor-speech-recognition`
Run the required Capacitor sync/update step after installation.
Read this markdown guide for the full setup steps: https://raw.githubusercontent.com/Cap-go/website/refs/heads/main/apps/docs/src/content/docs/docs/plugins/speech-recognition/getting-started.mdx
Use that guide for platform-specific steps, native file edits, permissions, config changes, imports, and usage setup.
If that guide references other docs pages, read them too.
Puoi utilizzare la nostra configurazione assistita dall'IA per installare il plugin. Aggiungi le Capgo abilità al tuo strumento di IA utilizzando il seguente comando:
npx skills add https://github.com/Cap-go/capgo-skills --skill capacitor-pluginsUsa poi la seguente richiesta:
Use the `capacitor-plugins` skill from `Cap-go/capgo-skills` to install the `@capgo/capacitor-speech-recognition` plugin in my project.Se preferisci l'installazione manuale, installa il plugin eseguendo i seguenti comandi e segui le istruzioni specifiche per la piattaforma riportate di seguito:
bun add @capgo/capacitor-speech-recognitionbunx cap syncImporta
Sezione intitolata “Importa”import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';API Panoramica
Sezione intitolata “API Panoramica”available
Sezione intitolata “disponibile”Verifica se il servizio di riconoscimento vocale nativo è disponibile sul dispositivo corrente.
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.available();isOnDeviceRecognitionAvailable
Sottosezione intitolata “isOnDeviceRecognitionAvailable”Verifica se il percorso di riconoscimento on-device più recente del sistema operativo è disponibile per la selezione di lingua.
Questo è il controllo di capacità che dovresti utilizzare prima di abilitare useOnDeviceRecognition.
A true risultato significa che il dispositivo, la versione del sistema operativo e la lingua possono utilizzare il percorso on-device più recente per quel sistema operativo.
Restituisce false quando il dispositivo supporta solo il percorso di riconoscimento legacy.
Documentazione del SDK del sistema operativo: iOS: Parola chiave: "Riconoscimento vocale" Riconoscitore di Parole
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.isOnDeviceRecognitionAvailable();Inizia a capturare l'audio e a trascrivere la parola.
Quando partialResults è true, la promessa restituita si risolve immediatamente e gli aggiornamenti sono
inoltrati attraverso il partialResults listener fino a quando la sessione non finisce.
Il percorso predefinito mantiene il comportamento del riconoscitore legacy per compatibilità con il passato.
Passa useOnDeviceRecognition: true solo dopo aver controllato
.
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.start();Interrompe l'ascolto e smonta le risorse native.
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.stop();forceStop
Sottosezione intitolata “forceStop”Interrompe forzatamente la sessione corrente.
Sul sistema Android, si tenta prima di fermare normalmente e poi si ricade sulla distruzione/riconfigurazione dopo timeout.
Sul sistema iOS, la sessione corrente viene interrotta immediatamente.
Se è presente un trascrittore parziale memorizzato, viene emesso attraverso il partialResults listener con forced: true.
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.forceStop();getLastPartialResult
Sottosezione intitolata “getLastPartialResult”Ottiene il risultato di trascrizione parziale memorizzato.
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.getLastPartialResult();setPTTState
Sezione intitolata “setPTTState”Aggiorna lo stato del pulsante di parola in tempo reale.
Usa questo insieme con continuousPTT o con un flusso personalizzato di parola in tempo reale.
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.setPTTState({} as PTTStateOptions);getSupportedLanguages
Sezione intitolata “getSupportedLanguages”Ottiene le locuzioni supportate dal riconoscitore sottostante.
I dispositivi Android 13+ non espongono più questa lista; in quel caso languages è vuoto.
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.getSupportedLanguages();isListening
Sezione intitolata “isListening”Restituisce se il plugin sta attivamente ascoltando la parola.
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.isListening();checkPermissions
Sezione intitolata “checkPermissions”Ottenere lo stato di autorizzazione corrente.
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.checkPermissions();requestPermissions
Sezione intitolata “requestPermissions”Richiede le autorizzazioni per il microfono + riconoscimento vocale.
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.requestPermissions();Riferimento di tipo
Sezione intitolata “Type Reference”SpeechRecognitionAvailability
Sezione intitolata “SpeechRecognitionAvailability”export interface SpeechRecognitionAvailability { available: boolean;}SpeechRecognitionStartOptions
Sezione intitolata “SpeechRecognitionStartOptions”Configura come il riconoscitore si comporta quando si chiama .
export interface SpeechRecognitionStartOptions { /** * Locale identifier such as `en-US`. When omitted the device language is used. */ language?: string; /** * Maximum number of final matches returned by native APIs. Defaults to `5`. */ maxResults?: number; /** * Prompt message shown inside the Android system dialog (ignored on iOS). */ prompt?: string; /** * When `true`, Android shows the OS speech dialog instead of running inline recognition. * Defaults to `false`. */ popup?: boolean; /** * Emits partial transcription updates through the `partialResults` listener while audio is captured. */ partialResults?: boolean; /** * Enables native punctuation handling where supported (iOS 16+). */ addPunctuation?: boolean; /** * Opt in to the platform's newer on-device recognition path when available. * * On iOS 26+, this uses Apple's `SpeechAnalyzer` / `SpeechTranscriber` pipeline. * On recent Android versions, this uses the on-device `SpeechRecognizer` path. * * It is intentionally opt-in so existing apps keep the legacy flow unless they choose * to roll out the new behavior. * * Use {@link SpeechRecognitionPlugin.isOnDeviceRecognitionAvailable} before enabling it in production. * * Platform SDK docs: * iOS: [Speech](https://developer.apple.com/documentation/speech), * [SpeechAnalyzer](https://developer.apple.com/documentation/speech/speechanalyzer), * [SpeechTranscriber](https://developer.apple.com/documentation/speech/speechtranscriber) * Android: [SpeechRecognizer](https://developer.android.com/reference/android/speech/SpeechRecognizer) * * Defaults to `false`. */ useOnDeviceRecognition?: boolean; /** * Allow a number of milliseconds of silence before splitting the recognition session into segments. * Required to be greater than zero and currently supported on Android only. */ allowForSilence?: number; /** * EXPERIMENTAL: Keep a PTT session alive across silence by restarting recognition while the button stays held. * * This restart behavior is implemented for Android inline recognition and iOS native recognition. */ continuousPTT?: boolean;}SpeechRecognitionMatches
Sezione intitolata “SpeechRecognitionMatches”export interface SpeechRecognitionMatches { matches?: string[];}ForceStopOptions
Sezione intitolata “ForceStopOptions”Opzioni per .
export interface ForceStopOptions { /** * Android only: timeout in milliseconds before forcing stop via destroy/recreate. * * On iOS, the current session is stopped immediately and this value is ignored. * * Defaults to `1500`. */ timeout?: number;}LastPartialResult
Sezione intitolata “LastPartialResult”Risultato da .
export interface LastPartialResult { /** * Whether a partial result is currently cached. */ available: boolean; /** * The most recent transcript text known to the native recognizer. */ text: string; /** * All current match alternatives when available. */ matches?: string[];}PTTStateOptions
Sezione intitolata “PTTStateOptions”Opzioni per .
export interface PTTStateOptions { /** * Whether the PTT button is currently held. */ held: boolean;}SpeechRecognitionLanguages
Sezione intitolata “Lingue di riconoscimento vocale”export interface SpeechRecognitionLanguages { languages: string[];}SpeechRecognitionListening
Sezione intitolata “Ascolto di riconoscimento vocale”export interface SpeechRecognitionListening { listening: boolean;}SpeechRecognitionPermissionStatus
Sezione intitolata “Stato di autorizzazione di riconoscimento vocale”Mappa di autorizzazione restituita da checkPermissions e requestPermissions.
export interface SpeechRecognitionPermissionStatus { speechRecognition: PermissionState;}SpeechRecognitionSegmentResultEvent
Sezione intitolata “Risultato di segmentazione di riconoscimento vocale”Sollevato ogni volta che viene prodotto un risultato segmentato (solo Android).
export interface SpeechRecognitionSegmentResultEvent { matches: string[];}SpeechRecognitionPartialResultEvent
Sezione intitolata “SpeechRecognitionPartialResultEvent”Sollevata ogni volta che viene prodotta una trascrizione parziale.
export interface SpeechRecognitionPartialResultEvent { /** * Current recognition matches when the native recognizer reports them. * * This can be omitted for forced or accumulated-only payloads. */ matches?: string[]; /** * Accumulated transcription from earlier continuous PTT cycles. */ accumulated?: string; /** * Final accumulated text including the current result. */ accumulatedText?: string; /** * `true` when the plugin is restarting recognition inside a continuous PTT session. */ isRestarting?: boolean; /** * `true` when the payload was emitted by `forceStop()`. */ forced?: boolean;}SpeechRecognitionListeningEvent
Sezione intitolata “SpeechRecognitionListeningEvent”Sollevata quando lo stato di ascolto cambia.
export interface SpeechRecognitionListeningEvent { /** * Finite state of the recognition session. */ state?: ListeningFiniteState; /** * Unique identifier for the current listening session. */ sessionId?: number; /** * Why this state transition occurred. */ reason?: ListeningReason; /** * Error code when the transition is caused by an error. */ errorCode?: string; /** * Backward-compatible binary state used by earlier releases. */ status?: 'started' | 'stopped';}Fonte di Verità
Sezione intitolata “Fonte di Verità”Questa pagina è generata dal plugin’s src/definitions.ts. Riavvia la sincronizzazione quando le informazioni pubbliche API cambiano in fase di sviluppo.
Continua da Iniziare
Sezione intitolata “Continua da Iniziare”Se stai utilizzando Iniziare per pianificare il dashboard e le API operazioni, connettilo con Utilizzare @capgo/capacitor-riconoscimento-parola per la capacità nativa in Utilizzare @capgo/capacitor-riconoscimento-parola API Panoramica per i dettagli di implementazione in API Panoramica Introduzione per i dettagli di implementazione in Introduzione API Chiavi per i dettagli di implementazione in API Chiavi, e Dispositivi per i dettagli di implementazione in dispositivi.