Chuyển đến nội dung chính

Documentation Index

Fetch the complete documentation index at: https://docs2.openclaw.ai/llms.txt

Use this file to discover all available pages before exploring further.

OpenClaw có thể chuyển đổi các phản hồi gửi đi thành âm thanh qua 14 nhà cung cấp giọng nói và gửi tin nhắn thoại gốc trên Feishu, Matrix, Telegram và WhatsApp, tệp đính kèm âm thanh ở mọi nơi khác, và luồng PCM/Ulaw cho điện thoại và Talk. TTS là nửa đầu ra giọng nói của chế độ stt-tts trong Talk. Các phiên Talk realtime gốc của nhà cung cấp sẽ tổng hợp giọng nói bên trong nhà cung cấp thời gian thực thay vì gọi đường dẫn TTS này, còn các phiên transcription không tổng hợp phản hồi giọng nói của trợ lý.

Bắt đầu nhanh

1

Chọn nhà cung cấp

OpenAI và ElevenLabs là các lựa chọn được lưu trữ đáng tin cậy nhất. Microsoft và Local CLI hoạt động mà không cần khóa API. Xem ma trận nhà cung cấp để biết danh sách đầy đủ.
2

Đặt khóa API

Xuất biến môi trường cho nhà cung cấp của bạn (ví dụ OPENAI_API_KEY, ELEVENLABS_API_KEY). Microsoft và Local CLI không cần khóa.
3

Bật trong cấu hình

Đặt messages.tts.auto: "always"messages.tts.provider:
{
  messages: {
    tts: {
      auto: "always",
      provider: "elevenlabs",
    },
  },
}
4

Thử trong trò chuyện

/tts status hiển thị trạng thái hiện tại. /tts audio Hello from OpenClaw gửi một phản hồi âm thanh dùng một lần.
Auto-TTS mặc định tắt. Khi messages.tts.provider chưa được đặt, OpenClaw chọn nhà cung cấp đã cấu hình đầu tiên theo thứ tự tự động chọn của registry. Công cụ agent tts tích hợp chỉ dành cho ý định rõ ràng: trò chuyện thông thường vẫn là văn bản trừ khi người dùng yêu cầu âm thanh, dùng /tts, hoặc bật giọng nói Auto-TTS/directive.

Nhà cung cấp được hỗ trợ

Nhà cung cấpXác thựcGhi chú
Azure SpeechAZURE_SPEECH_KEY + AZURE_SPEECH_REGION (cũng có AZURE_SPEECH_API_KEY, SPEECH_KEY, SPEECH_REGION)Đầu ra ghi chú thoại Ogg/Opus gốc và điện thoại.
DeepInfraDEEPINFRA_API_KEYTTS tương thích OpenAI. Mặc định là hexgrad/Kokoro-82M.
ElevenLabsELEVENLABS_API_KEY hoặc XI_API_KEYNhân bản giọng nói, đa ngôn ngữ, xác định qua seed; được truyền phát cho phát lại giọng nói Discord.
Google GeminiGEMINI_API_KEY hoặc GOOGLE_API_KEYTTS theo lô của API Gemini; nhận biết persona qua promptTemplate: "audio-profile-v1".
GradiumGRADIUM_API_KEYĐầu ra ghi chú thoại và điện thoại.
InworldINWORLD_API_KEYAPI TTS truyền phát. Ghi chú thoại Opus gốc và điện thoại PCM.
Local CLIkhông cóChạy một lệnh TTS cục bộ đã cấu hình.
Microsoftkhông cóTTS neural Edge công khai qua node-edge-tts. Nỗ lực tối đa, không có SLA.
MiniMaxMINIMAX_API_KEY (hoặc Token Plan: MINIMAX_OAUTH_TOKEN, MINIMAX_CODE_PLAN_KEY, MINIMAX_CODING_API_KEY)API T2A v2. Mặc định là speech-2.8-hd.
OpenAIOPENAI_API_KEYCũng dùng cho tự động tóm tắt; hỗ trợ persona instructions.
OpenRouterOPENROUTER_API_KEY (có thể dùng lại models.providers.openrouter.apiKey)Mô hình mặc định hexgrad/kokoro-82m.
VolcengineVOLCENGINE_TTS_API_KEY hoặc BYTEPLUS_SEED_SPEECH_API_KEY (AppID/token cũ: VOLCENGINE_TTS_APPID/_TOKEN)API HTTP BytePlus Seed Speech.
VydraVYDRA_API_KEYNhà cung cấp hình ảnh, video và giọng nói dùng chung.
xAIXAI_API_KEYTTS theo lô của xAI. Ghi chú thoại Opus gốc không được hỗ trợ.
Xiaomi MiMoXIAOMI_API_KEYTTS MiMo thông qua hoàn tất trò chuyện của Xiaomi.
Nếu nhiều nhà cung cấp được cấu hình, nhà cung cấp đã chọn sẽ được dùng trước và các nhà cung cấp khác là tùy chọn dự phòng. Tự động tóm tắt dùng summaryModel (hoặc agents.defaults.model.primary), vì vậy nhà cung cấp đó cũng phải được xác thực nếu bạn tiếp tục bật tóm tắt.
Nhà cung cấp Microsoft đi kèm dùng dịch vụ TTS neural trực tuyến của Microsoft Edge qua node-edge-tts. Đây là dịch vụ web công khai không có SLA hoặc hạn mức được công bố — hãy xem như nỗ lực tối đa. Id nhà cung cấp cũ edge được chuẩn hóa thành microsoftopenclaw doctor --fix ghi lại cấu hình đã lưu; cấu hình mới nên luôn dùng microsoft.

Cấu hình

Cấu hình TTS nằm dưới messages.tts trong ~/.openclaw/openclaw.json. Chọn một preset và điều chỉnh khối nhà cung cấp:
{
  messages: {
    tts: {
      auto: "always",
      provider: "azure-speech",
      providers: {
        "azure-speech": {
          apiKey: "${AZURE_SPEECH_KEY}",
          region: "eastus",
          voice: "en-US-JennyNeural",
          lang: "en-US",
          outputFormat: "audio-24khz-48kbitrate-mono-mp3",
          voiceNoteOutputFormat: "ogg-24khz-16bit-mono-opus",
        },
      },
    },
  },
}

Ghi đè giọng nói theo từng agent

Dùng agents.list[].tts khi một agent cần nói bằng nhà cung cấp, giọng nói, mô hình, persona hoặc chế độ Auto-TTS khác. Khối agent được trộn sâu lên trên messages.tts, vì vậy thông tin xác thực nhà cung cấp có thể nằm trong cấu hình nhà cung cấp toàn cục:
{
  messages: {
    tts: {
      auto: "always",
      provider: "elevenlabs",
      providers: {
        elevenlabs: { apiKey: "${ELEVENLABS_API_KEY}", model: "eleven_multilingual_v2" },
      },
    },
  },
  agents: {
    list: [
      {
        id: "reader",
        tts: {
          providers: {
            elevenlabs: { voiceId: "EXAVITQu4vr4xnSDxMaL" },
          },
        },
      },
    ],
  },
}
Để ghim một persona theo từng agent, hãy đặt agents.list[].tts.persona cùng với cấu hình nhà cung cấp — nó chỉ ghi đè messages.tts.persona toàn cục cho agent đó. Thứ tự ưu tiên cho trả lời tự động, /tts audio, /tts status và công cụ agent tts:
  1. messages.tts
  2. agents.list[].tts đang hoạt động
  3. ghi đè kênh, khi kênh hỗ trợ channels.<channel>.tts
  4. ghi đè tài khoản, khi kênh truyền channels.<channel>.accounts.<id>.tts
  5. tùy chọn /tts cục bộ cho máy chủ này
  6. chỉ thị nội tuyến [[tts:...]] khi bật ghi đè theo mô hình
Ghi đè kênh và tài khoản dùng cùng cấu trúc với messages.tts và hợp nhất sâu lên các lớp trước đó, để thông tin xác thực nhà cung cấp dùng chung có thể nằm trong messages.tts trong khi một kênh hoặc tài khoản bot chỉ thay đổi giọng nói, mô hình, persona hoặc chế độ tự động:
{
  messages: {
    tts: {
      provider: "openai",
      providers: {
        openai: { apiKey: "${OPENAI_API_KEY}", model: "gpt-4o-mini-tts" },
      },
    },
  },
  channels: {
    feishu: {
      accounts: {
        english: {
          tts: {
            providers: {
              openai: { voice: "shimmer" },
            },
          },
        },
      },
    },
  },
}

Persona

Một persona là một danh tính giọng nói ổn định có thể được áp dụng một cách xác định trên nhiều nhà cung cấp. Nó có thể ưu tiên một nhà cung cấp, định nghĩa ý định prompt trung lập với nhà cung cấp, và mang các liên kết riêng theo nhà cung cấp cho giọng nói, mô hình, mẫu prompt, seed và cài đặt giọng nói.

Persona tối thiểu

{
  messages: {
    tts: {
      auto: "always",
      persona: "narrator",
      personas: {
        narrator: {
          label: "Narrator",
          provider: "elevenlabs",
          providers: {
            elevenlabs: { voiceId: "EXAVITQu4vr4xnSDxMaL", modelId: "eleven_multilingual_v2" },
          },
        },
      },
    },
  },
}

Persona đầy đủ (prompt trung lập với nhà cung cấp)

{
  messages: {
    tts: {
      auto: "always",
      persona: "alfred",
      personas: {
        alfred: {
          label: "Alfred",
          description: "Dry, warm British butler narrator.",
          provider: "google",
          fallbackPolicy: "preserve-persona",
          prompt: {
            profile: "A brilliant British butler. Dry, witty, warm, charming, emotionally expressive, never generic.",
            scene: "A quiet late-night study. Close-mic narration for a trusted operator.",
            sampleContext: "The speaker is answering a private technical request with concise confidence and dry warmth.",
            style: "Refined, understated, lightly amused.",
            accent: "British English.",
            pacing: "Measured, with short dramatic pauses.",
            constraints: ["Do not read configuration values aloud.", "Do not explain the persona."],
          },
          providers: {
            google: {
              model: "gemini-3.1-flash-tts-preview",
              voiceName: "Algieba",
              promptTemplate: "audio-profile-v1",
            },
            openai: { model: "gpt-4o-mini-tts", voice: "cedar" },
            elevenlabs: {
              voiceId: "voice_id",
              modelId: "eleven_multilingual_v2",
              seed: 42,
              voiceSettings: {
                stability: 0.65,
                similarityBoost: 0.8,
                style: 0.25,
                useSpeakerBoost: true,
                speed: 0.95,
              },
            },
          },
        },
      },
    },
  },
}

Phân giải persona

Persona đang hoạt động được chọn một cách xác định:
  1. tùy chọn cục bộ /tts persona <id>, nếu đã đặt.
  2. messages.tts.persona, nếu đã đặt.
  3. Không có persona.
Việc chọn nhà cung cấp chạy theo thứ tự ưu tiên lựa chọn tường minh:
  1. Ghi đè trực tiếp (CLI, gateway, Talk, các chỉ thị TTS được phép).
  2. tùy chọn cục bộ /tts provider <id>.
  3. provider của persona đang hoạt động.
  4. messages.tts.provider.
  5. Tự động chọn từ registry.
Với mỗi lần thử nhà cung cấp, OpenClaw hợp nhất cấu hình theo thứ tự này:
  1. messages.tts.providers.<id>
  2. messages.tts.personas.<persona>.providers.<id>
  3. Ghi đè yêu cầu đáng tin cậy
  4. Ghi đè từ chỉ thị TTS do mô hình phát ra và được phép

Cách nhà cung cấp dùng prompt persona

Các trường prompt persona (profile, scene, sampleContext, style, accent, pacing, constraints) là trung lập với nhà cung cấp. Mỗi nhà cung cấp quyết định cách dùng chúng:
Bọc các trường prompt persona trong cấu trúc prompt Gemini TTS chỉ khi cấu hình nhà cung cấp Google hiệu dụng đặt promptTemplate: "audio-profile-v1" hoặc personaPrompt. Các trường cũ hơn audioProfilespeakerName vẫn được thêm vào đầu dưới dạng văn bản prompt riêng cho Google. Các thẻ âm thanh nội tuyến như [whispers] hoặc [laughs] bên trong khối [[tts:text]] được giữ nguyên trong bản chép lời Gemini; OpenClaw không tạo các thẻ này.
Ánh xạ các trường prompt persona vào trường yêu cầu instructions chỉ khi chưa cấu hình instructions tường minh cho OpenAI. instructions tường minh luôn thắng.
Chỉ dùng các liên kết persona riêng theo nhà cung cấp bên dưới personas.<id>.providers.<provider>. Các trường prompt persona bị bỏ qua trừ khi nhà cung cấp triển khai ánh xạ persona-prompt riêng.

Chính sách dự phòng

fallbackPolicy kiểm soát hành vi khi một persona không có liên kết cho nhà cung cấp được thử:
Chính sáchHành vi
preserve-personaMặc định. Các trường prompt trung lập với nhà cung cấp vẫn khả dụng; nhà cung cấp có thể dùng hoặc bỏ qua chúng.
provider-defaultsPersona bị bỏ qua khỏi bước chuẩn bị prompt cho lần thử đó; nhà cung cấp dùng mặc định trung lập của mình trong khi tiếp tục dự phòng sang nhà cung cấp khác.
failBỏ qua lần thử nhà cung cấp đó với reasonCode: "not_configured"personaBinding: "missing". Các nhà cung cấp dự phòng vẫn được thử.
Toàn bộ yêu cầu TTS chỉ thất bại khi mọi nhà cung cấp được thử đều bị bỏ qua hoặc thất bại. Việc chọn nhà cung cấp cho phiên Talk có phạm vi theo phiên. Một client Talk nên chọn id nhà cung cấp, id mô hình, id giọng nói và locale từ talk.catalog rồi truyền chúng qua phiên Talk hoặc yêu cầu bàn giao. Việc mở một phiên thoại không nên thay đổi messages.tts hoặc các mặc định nhà cung cấp Talk toàn cục.

Chỉ thị do mô hình điều khiển

Theo mặc định, trợ lý có thể phát ra các chỉ thị [[tts:...]] để ghi đè giọng nói, mô hình hoặc tốc độ cho một câu trả lời duy nhất, cùng với một khối [[tts:text]]...[[/tts:text]] tùy chọn cho các gợi ý biểu cảm chỉ nên xuất hiện trong âm thanh:
Here you go.

[[tts:voiceId=pMsXgVXv3BLzUgSXRplE model=eleven_v3 speed=1.1]]
[[tts:text]](laughs) Read the song once more.[[/tts:text]]
Khi messages.tts.auto"tagged", bắt buộc có chỉ thị để kích hoạt âm thanh. Việc phân phối khối streaming loại bỏ chỉ thị khỏi văn bản hiển thị trước khi kênh nhìn thấy chúng, ngay cả khi chúng bị tách qua các khối liền kề. provider=... bị bỏ qua trừ khi modelOverrides.allowProvider: true. Khi một câu trả lời khai báo provider=..., các khóa khác trong chỉ thị đó chỉ được phân tích bởi nhà cung cấp đó; các khóa không được hỗ trợ sẽ bị loại bỏ và được báo cáo dưới dạng cảnh báo chỉ thị TTS. Các khóa chỉ thị khả dụng:
  • provider (id nhà cung cấp đã đăng ký; yêu cầu allowProvider: true)
  • voice / voiceName / voice_name / google_voice / voiceId
  • model / google_model
  • stability, similarityBoost, style, speed, useSpeakerBoost
  • vol / volume (âm lượng MiniMax, 0–10)
  • pitch (cao độ số nguyên MiniMax, −12 đến 12; giá trị thập phân bị cắt bỏ phần lẻ)
  • emotion (thẻ cảm xúc Volcengine)
  • applyTextNormalization (auto|on|off)
  • languageCode (ISO 639-1)
  • seed
Tắt hoàn toàn ghi đè mô hình:
{ messages: { tts: { modelOverrides: { enabled: false } } } }
Cho phép chuyển đổi nhà cung cấp trong khi vẫn giữ các nút điều chỉnh khác có thể cấu hình:
{ messages: { tts: { modelOverrides: { enabled: true, allowProvider: true, allowSeed: false } } } }

Lệnh dấu gạch chéo

Một lệnh duy nhất /tts. Trên Discord, OpenClaw cũng đăng ký /voice/tts là một lệnh tích hợp sẵn của Discord — văn bản /tts ... vẫn hoạt động.
/tts off | on | status
/tts chat on | off | default
/tts latest
/tts provider <id>
/tts persona <id> | off
/tts limit <chars>
/tts summary off
/tts audio <text>
Các lệnh yêu cầu người gửi được ủy quyền (áp dụng quy tắc danh sách cho phép/chủ sở hữu) và phải bật commands.text hoặc đăng ký lệnh gốc.
Ghi chú hành vi:
  • /tts on ghi tùy chọn TTS cục bộ thành always; /tts off ghi thành off.
  • /tts chat on|off|default ghi một ghi đè auto-TTS theo phạm vi phiên cho cuộc trò chuyện hiện tại.
  • /tts persona <id> ghi tùy chọn persona cục bộ; /tts persona off xóa tùy chọn đó.
  • /tts latest đọc câu trả lời trợ lý mới nhất từ bản ghi phiên hiện tại và gửi nó dưới dạng âm thanh một lần. Nó chỉ lưu một hash của câu trả lời đó trên mục phiên để ngăn gửi giọng nói trùng lặp.
  • /tts audio tạo một câu trả lời âm thanh một lần (không bật TTS).
  • limitsummary được lưu trong tùy chọn cục bộ, không phải cấu hình chính.
  • /tts status bao gồm chẩn đoán dự phòng cho lần thử mới nhất — Fallback: <primary> -> <used>, Attempts: ..., và chi tiết từng lần thử (provider:outcome(reasonCode) latency).
  • /status hiển thị chế độ TTS đang hoạt động cùng nhà cung cấp, mô hình, giọng nói đã cấu hình và siêu dữ liệu endpoint tùy chỉnh đã được làm sạch khi TTS được bật.

Tùy chọn theo người dùng

Các lệnh dấu gạch chéo ghi ghi đè cục bộ vào prefsPath. Mặc định là ~/.openclaw/settings/tts.json; ghi đè bằng biến môi trường OPENCLAW_TTS_PREFS hoặc messages.tts.prefsPath.
Trường đã lưuTác động
autoGhi đè auto-TTS cục bộ (always, off, …)
providerGhi đè nhà cung cấp chính cục bộ
personaGhi đè persona cục bộ
maxLengthNgưỡng tóm tắt (mặc định 1500 ký tự)
summarizeCông tắc tóm tắt (mặc định true)
Những giá trị này ghi đè cấu hình hiệu dụng từ messages.tts cộng với khối agents.list[].tts đang hoạt động cho máy chủ đó.

Định dạng đầu ra (cố định)

Việc phân phối giọng nói TTS được điều khiển bởi capability của kênh. Các Plugin kênh quảng bá liệu TTS kiểu tin nhắn thoại có nên yêu cầu nhà cung cấp tạo mục tiêu voice-note gốc hay giữ tổng hợp audio-file bình thường và chỉ đánh dấu đầu ra tương thích để phân phối dưới dạng giọng nói.
  • Các kênh hỗ trợ tin nhắn thoại: phản hồi bằng tin nhắn thoại ưu tiên Opus (opus_48000_64 từ ElevenLabs, opus từ OpenAI).
    • 48kHz / 64kbps là mức đánh đổi tốt cho tin nhắn thoại.
  • Feishu / WhatsApp: khi phản hồi bằng tin nhắn thoại được tạo dưới dạng MP3/WebM/WAV/M4A hoặc một tệp có nhiều khả năng là âm thanh khác, Plugin kênh sẽ chuyển mã tệp đó sang Ogg/Opus 48kHz bằng ffmpeg trước khi gửi tin nhắn thoại gốc. WhatsApp gửi kết quả qua payload audio của Baileys với ptt: trueaudio/ogg; codecs=opus. Nếu chuyển đổi thất bại, Feishu nhận tệp gốc dưới dạng tệp đính kèm; WhatsApp gửi thất bại thay vì đăng payload PTT không tương thích.
  • Các kênh khác: MP3 (mp3_44100_128 từ ElevenLabs, mp3 từ OpenAI).
    • 44.1kHz / 128kbps là mức cân bằng mặc định cho độ rõ của giọng nói.
  • MiniMax: MP3 (mô hình speech-2.8-hd, tần số lấy mẫu 32kHz) cho tệp đính kèm âm thanh thông thường. Với các mục tiêu tin nhắn thoại do kênh công bố, OpenClaw chuyển mã MP3 của MiniMax sang Opus 48kHz bằng ffmpeg trước khi phân phối khi kênh công bố khả năng chuyển mã.
  • Xiaomi MiMo: mặc định là MP3, hoặc WAV khi được cấu hình. Với các mục tiêu tin nhắn thoại do kênh công bố, OpenClaw chuyển mã đầu ra của Xiaomi sang Opus 48kHz bằng ffmpeg trước khi phân phối khi kênh công bố khả năng chuyển mã.
  • CLI cục bộ: sử dụng outputFormat đã cấu hình. Các mục tiêu tin nhắn thoại được chuyển đổi sang Ogg/Opus và đầu ra điện thoại được chuyển đổi sang PCM mono 16 kHz thô bằng ffmpeg.
  • Google Gemini: TTS của Gemini API trả về PCM 24kHz thô. OpenClaw bọc nó dưới dạng WAV cho tệp đính kèm âm thanh, chuyển mã nó sang Opus 48kHz cho mục tiêu tin nhắn thoại, và trả về PCM trực tiếp cho Talk/điện thoại.
  • Gradium: WAV cho tệp đính kèm âm thanh, Opus cho mục tiêu tin nhắn thoại, và ulaw_8000 ở 8 kHz cho điện thoại.
  • Inworld: MP3 cho tệp đính kèm âm thanh thông thường, OGG_OPUS gốc cho mục tiêu tin nhắn thoại, và PCM thô ở 22050 Hz cho Talk/điện thoại.
  • xAI: mặc định là MP3; responseFormat có thể là mp3, wav, pcm, mulaw, hoặc alaw. OpenClaw sử dụng endpoint TTS REST batch của xAI và trả về một tệp đính kèm âm thanh hoàn chỉnh; WebSocket TTS phát trực tuyến của xAI không được đường dẫn nhà cung cấp này sử dụng. Định dạng tin nhắn thoại Opus gốc không được đường dẫn này hỗ trợ.
  • Microsoft: sử dụng microsoft.outputFormat (mặc định audio-24khz-48kbitrate-mono-mp3).
    • Transport đi kèm chấp nhận outputFormat, nhưng không phải tất cả định dạng đều có sẵn từ dịch vụ.
    • Giá trị định dạng đầu ra tuân theo các định dạng đầu ra Microsoft Speech (bao gồm Ogg/WebM Opus).
    • sendVoice của Telegram chấp nhận OGG/MP3/M4A; hãy dùng OpenAI/ElevenLabs nếu bạn cần tin nhắn thoại Opus được đảm bảo.
    • Nếu định dạng đầu ra Microsoft đã cấu hình thất bại, OpenClaw thử lại bằng MP3.
Định dạng đầu ra OpenAI/ElevenLabs được cố định theo từng kênh (xem ở trên).

Hành vi Auto-TTS

Khi messages.tts.auto được bật, OpenClaw:
  • Bỏ qua TTS nếu phản hồi đã chứa phương tiện hoặc chỉ thị MEDIA:.
  • Bỏ qua các phản hồi rất ngắn (dưới 10 ký tự).
  • Tóm tắt các phản hồi dài khi tóm tắt được bật, bằng cách sử dụng summaryModel (hoặc agents.defaults.model.primary).
  • Đính kèm âm thanh đã tạo vào phản hồi.
  • Trong mode: "final", vẫn gửi TTS chỉ có âm thanh cho các phản hồi cuối được phát trực tuyến sau khi luồng văn bản hoàn tất; phương tiện đã tạo đi qua cùng quy trình chuẩn hóa phương tiện của kênh như các tệp đính kèm phản hồi thông thường.
Nếu phản hồi vượt quá maxLength và tóm tắt bị tắt (hoặc không có khóa API cho mô hình tóm tắt), âm thanh sẽ bị bỏ qua và phản hồi văn bản thông thường được gửi.
Reply -> TTS enabled?
  no  -> send text
  yes -> has media / MEDIA: / short?
          yes -> send text
          no  -> length > limit?
                   no  -> TTS -> attach audio
                   yes -> summary enabled?
                            no  -> send text
                            yes -> summarize -> TTS -> attach audio

Định dạng đầu ra theo kênh

Mục tiêuĐịnh dạng
Feishu / Matrix / Telegram / WhatsAppPhản hồi ghi âm thoại ưu tiên Opus (opus_48000_64 từ ElevenLabs, opus từ OpenAI). 48 kHz / 64 kbps cân bằng độ rõ và kích thước.
Các kênh khácMP3 (mp3_44100_128 từ ElevenLabs, mp3 từ OpenAI). 44.1 kHz / 128 kbps là mặc định cho giọng nói.
Talk / điện thoạiPCM gốc của nhà cung cấp (Inworld 22050 Hz, Google 24 kHz), hoặc ulaw_8000 từ Gradium cho điện thoại.
Ghi chú theo từng nhà cung cấp:
  • Chuyển mã Feishu / WhatsApp: Khi phản hồi ghi âm thoại đến dưới dạng MP3/WebM/WAV/M4A, Plugin kênh chuyển mã sang Ogg/Opus 48 kHz bằng ffmpeg. WhatsApp gửi qua Baileys với ptt: trueaudio/ogg; codecs=opus. Nếu chuyển đổi thất bại: Feishu quay về đính kèm tệp gốc; WhatsApp gửi thất bại thay vì đăng một payload PTT không tương thích.
  • MiniMax / Xiaomi MiMo: MP3 mặc định (32 kHz cho MiniMax speech-2.8-hd); được chuyển mã sang Opus 48 kHz cho mục tiêu ghi âm thoại qua ffmpeg.
  • CLI cục bộ: Sử dụng outputFormat đã cấu hình. Mục tiêu ghi âm thoại được chuyển đổi sang Ogg/Opus và đầu ra điện thoại sang PCM mono 16 kHz thô.
  • Google Gemini: Trả về PCM 24 kHz thô. OpenClaw bọc thành WAV cho tệp đính kèm, chuyển mã sang Opus 48 kHz cho mục tiêu ghi âm thoại, trả về PCM trực tiếp cho Talk/điện thoại.
  • Inworld: Tệp đính kèm MP3, ghi âm thoại OGG_OPUS gốc, PCM thô 22050 Hz cho Talk/điện thoại.
  • xAI: MP3 theo mặc định; responseFormat có thể là mp3|wav|pcm|mulaw|alaw. Sử dụng endpoint REST theo lô của xAI — TTS WebSocket phát trực tuyến không được sử dụng. Định dạng ghi âm thoại Opus gốc không được hỗ trợ.
  • Microsoft: Sử dụng microsoft.outputFormat (mặc định audio-24khz-48kbitrate-mono-mp3). sendVoice của Telegram chấp nhận OGG/MP3/M4A; dùng OpenAI/ElevenLabs nếu bạn cần bảo đảm tin nhắn thoại Opus. Nếu định dạng Microsoft đã cấu hình thất bại, OpenClaw thử lại bằng MP3.
Định dạng đầu ra OpenAI và ElevenLabs được cố định theo từng kênh như liệt kê ở trên.

Tham chiếu trường

auto
"off" | "always" | "inbound" | "tagged"
Chế độ Auto-TTS. inbound chỉ gửi âm thanh sau một tin nhắn thoại đến; tagged chỉ gửi âm thanh khi phản hồi bao gồm các chỉ thị [[tts:...]] hoặc một khối [[tts:text]].
enabled
boolean
không còn sử dụng
Công tắc kế thừa. openclaw doctor --fix di chuyển giá trị này sang auto.
mode
"final" | "all"
mặc định:"final"
"all" bao gồm phản hồi công cụ/khối ngoài các phản hồi cuối cùng.
provider
string
ID nhà cung cấp giọng nói. Khi không đặt, OpenClaw dùng nhà cung cấp đầu tiên đã cấu hình theo thứ tự tự động chọn của registry. provider: "edge" kế thừa được openclaw doctor --fix viết lại thành "microsoft".
persona
string
ID persona đang hoạt động từ personas. Được chuẩn hóa thành chữ thường.
personas.<id>
object
Danh tính nói ổn định. Trường: label, description, provider, fallbackPolicy, prompt, providers.<provider>. Xem Personas.
summaryModel
string
Mô hình rẻ cho tự động tóm tắt; mặc định là agents.defaults.model.primary. Chấp nhận provider/model hoặc một bí danh mô hình đã cấu hình.
modelOverrides
object
Cho phép mô hình phát ra chỉ thị TTS. enabled mặc định là true; allowProvider mặc định là false.
providers.<id>
object
Cài đặt do nhà cung cấp sở hữu, được khóa theo ID nhà cung cấp giọng nói. Các khối trực tiếp kế thừa (messages.tts.openai, .elevenlabs, .microsoft, .edge) được openclaw doctor --fix viết lại; chỉ commit messages.tts.providers.<id>.
maxTextLength
number
Giới hạn cứng cho số ký tự đầu vào TTS. /tts audio thất bại nếu vượt quá.
timeoutMs
number
Thời gian chờ yêu cầu tính bằng mili giây.
prefsPath
string
Ghi đè đường dẫn JSON tùy chọn cục bộ (nhà cung cấp/giới hạn/tóm tắt). Mặc định ~/.openclaw/settings/tts.json.
apiKey
string
Env: AZURE_SPEECH_KEY, AZURE_SPEECH_API_KEY, hoặc SPEECH_KEY.
region
string
Vùng Azure Speech (ví dụ eastus). Env: AZURE_SPEECH_REGION hoặc SPEECH_REGION.
endpoint
string
Ghi đè endpoint Azure Speech tùy chọn (bí danh baseUrl).
voice
string
ShortName giọng nói Azure. Mặc định en-US-JennyNeural.
lang
string
Mã ngôn ngữ SSML. Mặc định en-US.
outputFormat
string
Azure X-Microsoft-OutputFormat cho âm thanh tiêu chuẩn. Mặc định audio-24khz-48kbitrate-mono-mp3.
voiceNoteOutputFormat
string
Azure X-Microsoft-OutputFormat cho đầu ra ghi âm thoại. Mặc định ogg-24khz-16bit-mono-opus.
apiKey
string
Quay về ELEVENLABS_API_KEY hoặc XI_API_KEY.
model
string
ID mô hình (ví dụ eleven_multilingual_v2, eleven_v3).
voiceId
string
ID giọng nói ElevenLabs.
voiceSettings
object
stability, similarityBoost, style (mỗi giá trị 0..1), useSpeakerBoost (true|false), speed (0.5..2.0, 1.0 = bình thường).
applyTextNormalization
"auto" | "on" | "off"
Chế độ chuẩn hóa văn bản.
languageCode
string
ISO 639-1 gồm 2 chữ cái (ví dụ en, de).
seed
number
Số nguyên 0..4294967295 để cố gắng đạt tính xác định tốt nhất.
baseUrl
string
Ghi đè URL cơ sở API ElevenLabs.
apiKey
string
Quay về GEMINI_API_KEY / GOOGLE_API_KEY. Nếu bỏ qua, TTS có thể dùng lại models.providers.google.apiKey trước khi quay về env.
model
string
Mô hình TTS Gemini. Mặc định gemini-3.1-flash-tts-preview.
voiceName
string
Tên giọng nói dựng sẵn của Gemini. Mặc định Kore. Bí danh: voice.
audioProfile
string
Prompt phong cách bằng ngôn ngữ tự nhiên được thêm trước văn bản sẽ đọc.
speakerName
string
Nhãn người nói tùy chọn được thêm trước văn bản sẽ đọc khi prompt của bạn dùng người nói có tên.
promptTemplate
"audio-profile-v1"
Đặt thành audio-profile-v1 để bọc các trường prompt persona đang hoạt động trong một cấu trúc prompt TTS Gemini xác định.
personaPrompt
string
Văn bản prompt persona bổ sung dành riêng cho Google, được thêm vào Ghi chú của đạo diễn trong mẫu.
baseUrl
string
Chỉ chấp nhận https://generativelanguage.googleapis.com.
apiKey
string
Env: GRADIUM_API_KEY.
baseUrl
string
Mặc định https://api.gradium.ai.
voiceId
string
Mặc định Emma (YTpq7expH9539ERJ).

Inworld chính

apiKey
string
Env: INWORLD_API_KEY.
baseUrl
string
Mặc định https://api.inworld.ai.
modelId
string
Mặc định inworld-tts-1.5-max. Cũng có: inworld-tts-1.5-mini, inworld-tts-1-max, inworld-tts-1.
voiceId
string
Mặc định Sarah.
temperature
number
Nhiệt độ lấy mẫu 0..2.
command
string
Tệp thực thi cục bộ hoặc chuỗi lệnh cho CLI TTS.
args
string[]
Đối số lệnh. Hỗ trợ các phần giữ chỗ {{Text}}, {{OutputPath}}, {{OutputDir}}, {{OutputBase}}.
outputFormat
"mp3" | "opus" | "wav"
Định dạng đầu ra CLI dự kiến. Mặc định mp3 cho tệp đính kèm âm thanh.
timeoutMs
number
Thời gian chờ lệnh tính bằng mili giây. Mặc định 120000.
cwd
string
Thư mục làm việc tùy chọn của lệnh.
env
Record<string, string>
Các ghi đè môi trường tùy chọn cho lệnh.
enabled
boolean
mặc định:"true"
Cho phép sử dụng giọng nói Microsoft.
voice
string
Tên giọng nói neural của Microsoft (ví dụ: en-US-MichelleNeural).
lang
string
Mã ngôn ngữ (ví dụ: en-US).
outputFormat
string
Định dạng đầu ra Microsoft. Mặc định audio-24khz-48kbitrate-mono-mp3. Không phải mọi định dạng đều được hỗ trợ bởi phương thức truyền tải tích hợp dựa trên Edge.
rate / pitch / volume
string
Chuỗi phần trăm (ví dụ: +10%, -5%).
saveSubtitles
boolean
Ghi phụ đề JSON cùng với tệp âm thanh.
proxy
string
URL proxy cho yêu cầu giọng nói Microsoft.
timeoutMs
number
Ghi đè thời gian chờ yêu cầu (ms).
edge.*
object
không còn sử dụng
Bí danh cũ. Chạy openclaw doctor --fix để ghi lại cấu hình đã lưu thành providers.microsoft.
apiKey
string
Dự phòng về MINIMAX_API_KEY. Xác thực Token Plan qua MINIMAX_OAUTH_TOKEN, MINIMAX_CODE_PLAN_KEY, hoặc MINIMAX_CODING_API_KEY.
baseUrl
string
Mặc định https://api.minimax.io. Env: MINIMAX_API_HOST.
model
string
Mặc định speech-2.8-hd. Env: MINIMAX_TTS_MODEL.
voiceId
string
Mặc định English_expressive_narrator. Env: MINIMAX_TTS_VOICE_ID.
speed
number
0.5..2.0. Mặc định 1.0.
vol
number
(0, 10]. Mặc định 1.0.
pitch
number
Số nguyên -12..12. Mặc định 0. Giá trị thập phân bị cắt bỏ trước yêu cầu.
apiKey
string
Dự phòng về OPENAI_API_KEY.
model
string
ID mô hình OpenAI TTS (ví dụ: gpt-4o-mini-tts).
voice
string
Tên giọng nói (ví dụ: alloy, cedar).
instructions
string
Trường OpenAI instructions rõ ràng. Khi được đặt, các trường lời nhắc persona không được tự động ánh xạ.
extraBody / extra_body
Record<string, unknown>
Các trường JSON bổ sung được hợp nhất vào phần thân yêu cầu /audio/speech sau các trường OpenAI TTS đã tạo. Dùng mục này cho các endpoint tương thích OpenAI như Kokoro cần các khóa riêng theo nhà cung cấp như lang; các khóa prototype không an toàn bị bỏ qua.
baseUrl
string
Ghi đè endpoint OpenAI TTS. Thứ tự phân giải: cấu hình → OPENAI_TTS_BASE_URLhttps://api.openai.com/v1. Các giá trị không mặc định được xem là endpoint TTS tương thích OpenAI, nên tên mô hình và giọng nói tùy chỉnh được chấp nhận.
apiKey
string
Env: OPENROUTER_API_KEY. Có thể dùng lại models.providers.openrouter.apiKey.
baseUrl
string
Mặc định https://openrouter.ai/api/v1. Giá trị cũ https://openrouter.ai/v1 được chuẩn hóa.
model
string
Mặc định hexgrad/kokoro-82m. Bí danh: modelId.
voice
string
Mặc định af_alloy. Bí danh: voiceId.
responseFormat
"mp3" | "pcm"
Mặc định mp3.
speed
number
Ghi đè tốc độ gốc của nhà cung cấp.
apiKey
string
Env: VOLCENGINE_TTS_API_KEY hoặc BYTEPLUS_SEED_SPEECH_API_KEY.
resourceId
string
Mặc định seed-tts-1.0. Env: VOLCENGINE_TTS_RESOURCE_ID. Dùng seed-tts-2.0 khi dự án của bạn có quyền TTS 2.0.
appKey
string
Header khóa ứng dụng. Mặc định aGjiRDfUWi. Env: VOLCENGINE_TTS_APP_KEY.
baseUrl
string
Ghi đè endpoint HTTP Seed Speech TTS. Env: VOLCENGINE_TTS_BASE_URL.
voice
string
Loại giọng nói. Mặc định en_female_anna_mars_bigtts. Env: VOLCENGINE_TTS_VOICE.
speedRatio
number
Tỷ lệ tốc độ gốc của nhà cung cấp.
emotion
string
Thẻ cảm xúc gốc của nhà cung cấp.
appId / token / cluster
string
không còn sử dụng
Các trường Volcengine Speech Console cũ. Env: VOLCENGINE_TTS_APPID, VOLCENGINE_TTS_TOKEN, VOLCENGINE_TTS_CLUSTER (mặc định volcano_tts).
apiKey
string
Env: XAI_API_KEY.
baseUrl
string
Mặc định https://api.x.ai/v1. Env: XAI_BASE_URL.
voiceId
string
Mặc định eve. Giọng nói trực tiếp: ara, eve, leo, rex, sal, una.
language
string
Mã ngôn ngữ BCP-47 hoặc auto. Mặc định en.
responseFormat
"mp3" | "wav" | "pcm" | "mulaw" | "alaw"
Mặc định mp3.
speed
number
Ghi đè tốc độ gốc của nhà cung cấp.
apiKey
string
Env: XIAOMI_API_KEY.
baseUrl
string
Mặc định https://api.xiaomimimo.com/v1. Env: XIAOMI_BASE_URL.
model
string
Mặc định mimo-v2.5-tts. Env: XIAOMI_TTS_MODEL. Cũng hỗ trợ mimo-v2-tts.
voice
string
Mặc định mimo_default. Env: XIAOMI_TTS_VOICE.
format
"mp3" | "wav"
Mặc định mp3. Env: XIAOMI_TTS_FORMAT.
style
string
Chỉ dẫn phong cách bằng ngôn ngữ tự nhiên tùy chọn được gửi dưới dạng tin nhắn người dùng; không được đọc thành tiếng.

Công cụ agent

Công cụ tts chuyển văn bản thành giọng nói và trả về tệp đính kèm âm thanh để gửi trả lời. Trên Feishu, Matrix, Telegram và WhatsApp, âm thanh được gửi dưới dạng tin nhắn thoại thay vì tệp đính kèm. Feishu và WhatsApp có thể chuyển mã đầu ra TTS không phải Opus trên đường dẫn này khi có ffmpeg. WhatsApp gửi âm thanh qua Baileys dưới dạng ghi chú thoại PTT (audio với ptt: true) và gửi văn bản hiển thị riêng biệt với âm thanh PTT vì các ứng dụng khách không hiển thị chú thích nhất quán trên ghi chú thoại. Công cụ chấp nhận các trường tùy chọn channeltimeoutMs; timeoutMs là thời gian chờ yêu cầu nhà cung cấp theo từng lần gọi, tính bằng mili giây.

Gateway RPC

Phương thứcMục đích
tts.statusĐọc trạng thái TTS hiện tại và lần thử gần nhất.
tts.enableĐặt tùy chọn tự động cục bộ thành always.
tts.disableĐặt tùy chọn tự động cục bộ thành off.
tts.convertChuyển một lần văn bản → âm thanh.
tts.setProviderĐặt tùy chọn nhà cung cấp cục bộ.
tts.setPersonaĐặt tùy chọn persona cục bộ.
tts.providersLiệt kê các nhà cung cấp đã cấu hình và trạng thái.

Liên kết dịch vụ

Liên quan