开始入门
复制安装步骤和完整的 Markdown 指南。
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.
安装
标题为“安装”您可以使用我们的 AI 助手设置来安装插件。将 Capgo 技能添加到您的 AI 工具中,使用以下命令:
npx skills add https://github.com/Cap-go/capgo-skills --skill capacitor-plugins然后使用以下提示:
Use the `capacitor-plugins` skill from `Cap-go/capgo-skills` to install the `@capgo/capacitor-speech-recognition` plugin in my project.如果您更喜欢手动设置,请通过运行以下命令安装插件并按照以下平台特定的说明进行操作:
bun add @capgo/capacitor-speech-recognitionbunx cap syncimport { SpeechRecognition } from '@capgo/capacitor-speech-recognition';API概述
标题为“API概述”的部分available
标题为“可用”的部分检查当前设备上的本地语音识别服务是否可用。
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.available();isOnDeviceRecognitionAvailable
节标题“isOnDeviceRecognitionAvailable”检查当前设备、操作系统版本和语言环境是否支持该平台的新版设备语音识别功能。
这是您应该在启用之前使用的能力检查。 useOnDeviceRecognition。
A true 结果表示当前设备、操作系统版本和语言环境可以使用该平台的新版设备语音识别功能。
返回 false 当设备仅支持旧版语音识别器路径时返回。
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.isOnDeviceRecognitionAvailable();start
标题为“开始”开始捕获音频并识别语音。
当 partialResults 是 true,返回的 promise 立即解析并通过 partialResults listener
更新流式传输,直到会话结束。 useOnDeviceRecognition: true 默认路径保留了 legacy 识别器行为以保持向后兼容性。
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.start();stop
仅在检查
后。传递。停止监听并释放本机资源。
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.stop();forceStop
标题为“forceStop”强制停止当前会话。
在 Android 上,这首先尝试正常停止,然后回退到销毁/重新创建。 timeout在 iOS 上,当前会话立即停止。
如果有部分转录缓存,会通过 partialResults listener forced: true.
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.forceStop();getLastPartialResult
复制到剪贴板标题为“getLastPartialResult”
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.getLastPartialResult();setPTTState
Section titled “setPTTState”更新当前推送对话按钮状态。
Use this together with continuousPTT 或与自定义按住对话流程一起使用。
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.setPTTState({} as PTTStateOptions);getSupportedLanguages
Section titled “getSupportedLanguages”获取底层识别器支持的语言列表。
Android 13+ 设备不再暴露此列表;在这种情况下 languages 是空的。
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.getSupportedLanguages();isListening
Section titled “isListening”返回插件是否正在积极监听语音。
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.isListening();checkPermissions
标题:检查权限获取当前权限状态。
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.checkPermissions();requestPermissions
标题:请求权限请求麦克风 + 语音识别权限。
import { SpeechRecognition } from '@capgo/capacitor-speech-recognition';
await SpeechRecognition.requestPermissions();类型参考
标题:类型参考SpeechRecognitionAvailability
标题:语音识别可用性export interface SpeechRecognitionAvailability { available: boolean;}SpeechRecognitionStartOptions
标题:语音识别启动选项Configure how the recognizer behaves when calling
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
语音识别匹配项export interface SpeechRecognitionMatches { matches?: string[];}ForceStopOptions
强制停止选项选项
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
最后部分结果结果
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
语音识别匹配项选项选项
export interface PTTStateOptions { /** * Whether the PTT button is currently held. */ held: boolean;}SpeechRecognitionLanguages
名为“SpeechRecognitionLanguages”的部分export interface SpeechRecognitionLanguages { languages: string[];}SpeechRecognitionListening
名为“SpeechRecognitionListening”的部分export interface SpeechRecognitionListening { listening: boolean;}SpeechRecognitionPermissionStatus
名为“SpeechRecognitionPermissionStatus”的部分由 checkPermissions 和 requestPermissions.
export interface SpeechRecognitionPermissionStatus { speechRecognition: PermissionState;}SpeechRecognitionSegmentResultEvent
名为“SpeechRecognitionSegmentResultEvent”的部分仅在Android上产生的分段结果时会引发。
export interface SpeechRecognitionSegmentResultEvent { matches: string[];}SpeechRecognitionPartialResultEvent
Section titled “SpeechRecognitionPartialResultEvent”每当产生部分转录时都会引发。
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
Section titled “SpeechRecognitionListeningEvent”当听取状态发生变化时会引发。
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';}本页面是从插件的 src/definitions.ts. 当上游的公共 API 变化时,请重新运行同步。
从开始就继续
Section titled “从开始就继续”If you are using Getting Started 为计划仪表板和API操作而设计 使用@capgo/capacitor-语音识别 为native能力在使用@capgo/capacitor-语音识别 API概述 为API概述的实现细节 简介 为简介的实现细节 API密钥 为API密钥的实现细节 设备 [__CAPGO_KEEP_0__]设备实现细节。