Providers
ElevenLabs
OpenClaw 使用 ElevenLabs 進行文字轉語音、透過 Scribe v2 進行批次語音轉文字,以及透過 Scribe v2 Realtime 進行串流 STT。
| 功能 | OpenClaw 介面 | 預設值 |
|---|---|---|
| 文字轉語音 | messages.tts / talk |
eleven_multilingual_v2 |
| 批次語音轉文字 | tools.media.audio |
scribe_v2 |
| 串流語音轉文字 | Voice Call 串流或 Google Meet realtime.transcriptionProvider |
scribe_v2_realtime |
驗證
在環境中設定 ELEVENLABS_API_KEY。也接受 XI_API_KEY,以相容既有的 ElevenLabs 工具。
export ELEVENLABS_API_KEY="..."
文字轉語音
{
messages: {
tts: {
providers: {
elevenlabs: {
apiKey: "${ELEVENLABS_API_KEY}",
voiceId: "pMsXgVXv3BLzUgSXRplE",
modelId: "eleven_multilingual_v2",
},
},
},
},
}
將 modelId 設為 eleven_v3 即可使用 ElevenLabs v3 TTS。OpenClaw 仍將
eleven_multilingual_v2 保留為既有安裝的預設值。
當 ElevenLabs 是選定的 voice.tts/messages.tts 提供者時,Discord 語音頻道會使用 ElevenLabs 的串流 TTS 端點。播放會從傳回的音訊串流開始,而不是先等待 OpenClaw 下載並寫入整個音訊檔案。對於接受該參數的模型,latencyTier 會對應至 ElevenLabs 的
optimize_streaming_latency 查詢參數;OpenClaw 會針對 eleven_v3 省略該參數,因為它會拒絕該參數。
語音轉文字
針對傳入音訊附件和短錄音語音片段使用 Scribe v2:
{
tools: {
media: {
audio: {
enabled: true,
models: [{ provider: "elevenlabs", model: "scribe_v2" }],
},
},
},
}
OpenClaw 會將多部分音訊傳送至 ElevenLabs /v1/speech-to-text,並使用
model_id: "scribe_v2"。語言提示存在時會對應至 language_code。
串流 STT
內建的 elevenlabs Plugin 會為 Voice Call 和 Google Meet agent 模式串流轉錄註冊 Scribe v2 Realtime。
| 設定 | 設定路徑 | 預設值 |
|---|---|---|
| API 金鑰 | plugins.entries.voice-call.config.streaming.providers.elevenlabs.apiKey |
回退至 ELEVENLABS_API_KEY / XI_API_KEY |
| 模型 | ...elevenlabs.modelId |
scribe_v2_realtime |
| 音訊格式 | ...elevenlabs.audioFormat |
ulaw_8000 |
| 取樣率 | ...elevenlabs.sampleRate |
8000 |
| 提交策略 | ...elevenlabs.commitStrategy |
vad |
| 語言 | ...elevenlabs.languageCode |
(未設定) |
{
plugins: {
entries: {
"voice-call": {
config: {
streaming: {
enabled: true,
provider: "elevenlabs",
providers: {
elevenlabs: {
apiKey: "${ELEVENLABS_API_KEY}",
audioFormat: "ulaw_8000",
commitStrategy: "vad",
languageCode: "en",
},
},
},
},
},
},
},
}
若使用 Google Meet agent 模式,請將
plugins.entries.google-meet.config.realtime.transcriptionProvider 設為
"elevenlabs",並在
plugins.entries.google-meet.config.realtime.providers.elevenlabs 下設定相同的提供者區塊。