@kajidog/mcp-tts-voicevox 0.1.2 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -1,416 +1,306 @@
1
- # MCP TTS VOICEVOX
2
-
3
- VOICEVOX を使用した音声合成 MCP サーバー
4
-
5
- ## 特徴
6
-
7
- - **キュー管理機能** - 複数の音声合成リクエストを効率的に処理
8
- - **プリフェッチ** - 次の音声を事前に生成し、再生をスムーズに
9
- - **クロスプラットフォーム対応** - Windows、macOS、Linux で動作
10
- - **Stdio 対応** - 標準入出力による MCP プロトコル通信(Claude Desktop 等で推奨)
11
- - **SSE 対応** - Server-Sent Events によるリアルタイム対話形式音声再生
12
- - **StreamableHTTP 対応** - ストリーミング形式での HTTP 通信による高速音声合成
13
- - **対話形式音声再生** - チャット形式でのリアルタイム音声合成・再生機能
14
- - **複数話者対応** - セグメント単位での個別話者指定が可能
15
- - **テキスト自動分割** - 長文の自動分割による安定した音声合成
16
- - **独立したクライアントライブラリ** - [`@kajidog/voicevox-client`](https://www.npmjs.com/package/@kajidog/voicevox-client) として別パッケージで提供
17
-
18
- ## 必要条件
19
-
20
- - Node.js 18.0.0 以上
21
- - [VOICEVOX エンジン](https://voicevox.hiroshiba.jp/) または互換エンジン
22
-
23
- ## インストール
24
-
25
- ```bash
26
- npm install -g @kajidog/mcp-tts-voicevox
27
- ```
28
-
29
- ## 使い方
30
-
31
- ### MCP サーバーとして
32
-
33
- #### 1. VOICEVOX エンジンを起動
34
-
35
- VOICEVOX エンジンを起動し、デフォルトポート(`http://localhost:50021`)で待機状態にします。
36
-
37
- #### 2. MCP サーバーを起動
38
-
39
- **標準入出力モード(推奨):**
40
-
41
- ```bash
42
- npx @kajidog/mcp-tts-voicevox
43
- ```
44
-
45
- **HTTP サーバーモード:**
46
-
47
- ```bash
48
- # Linux/macOS
49
- MCP_HTTP_MODE=true npx @kajidog/mcp-tts-voicevox
50
-
51
- # Windows PowerShell
52
- $env:MCP_HTTP_MODE='true'; npx @kajidog/mcp-tts-voicevox
53
- ```
54
-
55
- ### MCP ツール一覧
56
-
57
- MCP サーバーは以下のツールを提供します:
58
-
59
- #### `speak` - テキスト読み上げ
60
-
61
- テキストを音声に変換して再生します。
62
-
63
- **パラメータ:**
64
-
65
- - `text`: 文字列(改行区切りで複数テキスト、話者指定は「1:テキスト」形式)
66
- - `speaker` (オプション): 話者 ID
67
- - `speedScale` (オプション): 再生速度
68
- - `query` (オプション): 事前生成済みクエリ
69
-
70
- **使用例:**
71
-
72
- ```javascript
73
- // シンプルなテキスト
74
- { "text": "こんにちは\n今日はいい天気ですね" }
75
-
76
- // 話者指定
77
- { "text": "こんにちは\n今日はいい天気ですね", "speaker": 3 }
78
-
79
- // セグメント別話者指定
80
- { "text": "1:こんにちは\n3:今日はいい天気ですね" }
81
- ```
82
-
83
- #### `generate_query` - クエリ生成
84
-
85
- 音声合成用クエリを生成します。
86
-
87
- **パラメータ:**
88
-
89
- - `text`: 合成するテキスト
90
- - `speaker` (オプション): 話者 ID
91
- - `speedScale` (オプション): 再生速度
92
-
93
- #### `synthesize_file` - ファイル生成
94
-
95
- 音声ファイルを生成し、パスを返します。
96
-
97
- **パラメータ:**
98
-
99
- - `text` (オプション): 合成するテキスト
100
- - `query` (オプション): 事前生成済みクエリ
101
- - `output`: 出力ファイルパス
102
- - `speaker` (オプション): 話者 ID
103
- - `speedScale` (オプション): 再生速度
104
-
105
- #### `stop_speaker` - 再生停止
106
-
107
- 現在の音声合成キューをクリアします。
108
-
109
- #### `get_speakers` - 話者一覧取得
110
-
111
- 利用可能な話者一覧を取得します。
112
-
113
- #### `get_speaker_detail` - 話者詳細取得
114
-
115
- 指定した UUID の話者詳細情報を取得します。
116
-
117
- **パラメータ:**
118
-
119
- - `uuid`: 話者 UUID
120
-
121
- ### 対話形式音声再生の使用例
122
-
123
- #### StreamableHTTP を使用した対話形式再生
124
-
125
- ```javascript
126
- // セッション初期化
127
- const response = await fetch("http://localhost:3000/mcp", {
128
- method: "POST",
129
- headers: {
130
- "Content-Type": "application/json",
131
- },
132
- body: JSON.stringify({
133
- jsonrpc: "2.0",
134
- method: "initialize",
135
- params: {
136
- protocolVersion: "2024-11-05",
137
- capabilities: {},
138
- },
139
- id: 1,
140
- }),
141
- });
142
-
143
- const sessionData = await response.json();
144
- const sessionId = response.headers.get("mcp-session-id");
145
-
146
- // 音声合成・再生リクエスト
147
- const speakResponse = await fetch("http://localhost:3000/mcp", {
148
- method: "POST",
149
- headers: {
150
- "Content-Type": "application/json",
151
- "mcp-session-id": sessionId,
152
- },
153
- body: JSON.stringify({
154
- jsonrpc: "2.0",
155
- method: "tools/call",
156
- params: {
157
- name: "speak",
158
- arguments: {
159
- text: "こんにちは、対話形式で音声を再生します",
160
- speaker: 1,
161
- speedScale: 1.0,
162
- },
163
- },
164
- id: 2,
165
- }),
166
- });
167
-
168
- const result = await speakResponse.json();
169
- console.log("結果:", result);
170
- ```
171
-
172
- #### 複数話者を使用した対話例
173
-
174
- ```javascript
175
- // 複数話者での会話例
176
- const conversationResponse = await fetch("http://localhost:3000/mcp", {
177
- method: "POST",
178
- headers: {
179
- "Content-Type": "application/json",
180
- "mcp-session-id": sessionId,
181
- },
182
- body: JSON.stringify({
183
- jsonrpc: "2.0",
184
- method: "tools/call",
185
- params: {
186
- name: "speak",
187
- arguments: {
188
- text: "1:こんにちは!\n3:お元気ですか?\n1:とても元気です!",
189
- },
190
- },
191
- id: 3,
192
- }),
193
- });
194
- ```
195
-
196
- #### SSE を使用した対話形式再生(レガシー)
197
-
198
- ```javascript
199
- // SSE接続の確立
200
- const eventSource = new EventSource("http://localhost:3000/sse");
201
- let sessionId = null;
202
-
203
- eventSource.onopen = function (event) {
204
- console.log("SSE接続が確立されました");
205
- };
206
-
207
- eventSource.onmessage = function (event) {
208
- const data = JSON.parse(event.data);
209
-
210
- if (data.type === "session") {
211
- sessionId = data.sessionId;
212
- console.log("セッションID:", sessionId);
213
-
214
- // 音声合成リクエストを送信
215
- sendSpeakRequest();
216
- }
217
- };
218
-
219
- async function sendSpeakRequest() {
220
- await fetch(`http://localhost:3000/messages?sessionId=${sessionId}`, {
221
- method: "POST",
222
- headers: {
223
- "Content-Type": "application/json",
224
- },
225
- body: JSON.stringify({
226
- jsonrpc: "2.0",
227
- method: "tools/call",
228
- params: {
229
- name: "speak",
230
- arguments: {
231
- text: "SSEを使用した音声再生です",
232
- speaker: 1,
233
- },
234
- },
235
- id: 1,
236
- }),
237
- });
238
- }
239
- ```
240
-
241
-
242
- ## パッケージ構成
243
-
244
- このプロジェクトは以下の2つのパッケージで構成されています:
245
-
246
- ### @kajidog/mcp-tts-voicevox (このパッケージ)
247
- - **MCPサーバー** - Claude Desktop等のMCPクライアントと通信するサーバー
248
- - **Node.js専用** - デスクトップ環境やCLI環境での使用を想定
249
- - **ツール提供** - `speak`, `generate_query`, `synthesize_file` 等のMCPツール
250
- - **HTTPサーバー** - SSE/StreamableHTTP対応のWebサーバー
251
-
252
- ### [@kajidog/voicevox-client](https://www.npmjs.com/package/@kajidog/voicevox-client) (独立パッケージ)
253
- - **汎用ライブラリ** - VOICEVOXエンジンとの通信機能を提供
254
- - **クロスプラットフォーム** - Node.js(Windows、macOS、Linux)とブラウザ環境の両方で動作
255
- - **キュー管理** - 複数の音声合成リクエストを効率的に処理
256
- - **プリフェッチ機能** - 次の音声を事前に生成し、再生をスムーズに
257
-
258
- ### 使い分けガイド
259
-
260
- **MCPサーバーを使用する場合 (`@kajidog/mcp-tts-voicevox`)**:
261
- - Claude Desktop でTTSツールを使いたい
262
- - コマンドラインからMCPサーバーを起動したい
263
- - Webアプリケーション向けのHTTP APIが必要
264
-
265
- **クライアントライブラリを使用する場合 (`@kajidog/voicevox-client`)**:
266
- - 独自のNode.jsアプリケーションにTTS機能を組み込みたい
267
- - ブラウザアプリケーションでVOICEVOXを使いたい
268
- - MCPプロトコルを使わずに直接VOICEVOX機能を利用したい
269
-
270
- 詳細な使用方法は [`@kajidog/voicevox-client` のドキュメント](https://www.npmjs.com/package/@kajidog/voicevox-client) を参照してください。
271
-
272
- ## MCP 設定例
273
-
274
- ### Claude Desktop での設定
275
-
276
- **⚠️ 重要: Claude Desktop の通信モードについて**
277
-
278
- Claude Desktop は現在 **Stdio モードのみ** をサポートしており、SSE/HTTP モードは直接サポートされていません。
279
-
280
- #### 推奨設定(Stdio モード)
281
-
282
- `claude_desktop_config.json` ファイルに以下の設定を追加:
283
-
284
- ```json
285
- {
286
- "mcpServers": {
287
- "tts-mcp": {
288
- "command": "npx",
289
- "args": ["-y", "@kajidog/mcp-tts-voicevox"],
290
- }
291
- }
292
- }
293
- ```
294
-
295
- #### SSE モードが必要な場合
296
-
297
- SSE モードでの音声合成が必要な場合は、`mcp-remote` を使用して SSE↔Stdio 変換を行えます:
298
-
299
- 1. **Claude Desktop 設定**
300
-
301
- ```json
302
- {
303
- "mcpServers": {
304
- "tts-mcp-proxy": {
305
- "command": "npx",
306
- "args": ["-y", "mcp-remote", "http://localhost:3000/sse"]
307
- }
308
- }
309
- }
310
- ```
311
-
312
- 2. **SSE サーバーの起動**
313
-
314
- **Mac/Linux:**
315
-
316
- ```bash
317
- MCP_HTTP_MODE=true MCP_HTTP_PORT=3000 npx @kajidog/mcp-tts-voicevox
318
- ```
319
-
320
- **Windows:**
321
-
322
- ```powershell
323
- $env:MCP_HTTP_MODE='true'; $env:MCP_HTTP_PORT='3000'; npx @kajidog/mcp-tts-voicevox
324
- ```
325
-
326
- ### AivisSpeech での設定例
327
-
328
- ```json
329
- {
330
- "mcpServers": {
331
- "tts-mcp": {
332
- "command": "npx",
333
- "args": ["-y", "@kajidog/mcp-tts-voicevox"],
334
- "env": {
335
- "VOICEVOX_URL": "http://127.0.0.1:10101",
336
- "VOICEVOX_DEFAULT_SPEAKER": "888753764"
337
- }
338
- }
339
- }
340
- }
341
- ```
342
-
343
- ### HTTP モードでの設定
344
-
345
- ```json
346
- {
347
- "mcpServers": {
348
- "tts-mcp-http": {
349
- "command": "npx",
350
- "args": ["-y", "@kajidog/mcp-tts-voicevox"],
351
- "env": {
352
- "MCP_HTTP_MODE": "true",
353
- "MCP_HTTP_PORT": "3000",
354
- "MCP_HTTP_HOST": "0.0.0.0",
355
- "VOICEVOX_URL": "http://localhost:50021",
356
- "VOICEVOX_DEFAULT_SPEAKER": "1"
357
- }
358
- }
359
- }
360
- }
361
- ```
362
-
363
- ## 環境変数
364
-
365
- ### VOICEVOX 設定
366
-
367
- - `VOICEVOX_URL`: VOICEVOX エンジンの URL(デフォルト: `http://localhost:50021`)
368
- - `VOICEVOX_DEFAULT_SPEAKER`: デフォルト話者 ID(デフォルト: `1`)
369
- - `VOICEVOX_DEFAULT_SPEED_SCALE`: デフォルト再生速度(デフォルト: `1.0`)
370
-
371
- ### サーバー設定
372
-
373
- - `MCP_HTTP_MODE`: HTTP サーバーモードの有効化(`true` で有効)
374
- - `MCP_HTTP_PORT`: HTTP サーバーのポート番号(デフォルト: `3000`)
375
- - `MCP_HTTP_HOST`: HTTP サーバーのホスト(デフォルト: `0.0.0.0`)
376
- - `NODE_ENV`: 開発モード(`development` で有効)
377
-
378
- ## トラブルシューティング
379
-
380
- ### よくある問題
381
-
382
- 1. **VOICEVOX エンジンが起動していない**
383
-
384
- ```bash
385
- curl http://localhost:50021/speakers
386
- ```
387
-
388
- 2. **ポートが既に使用されている (EADDRINUSE エラー)**
389
-
390
- - 別のポート番号を使用するか、既存のプロセスを終了してください
391
-
392
- 3. **MCP クライアントで認識されない**
393
-
394
- - パッケージのインストールを確認:`npm list -g @kajidog/mcp-tts-voicevox`
395
- - 設定ファイルの JSON 構文を確認
396
-
397
- 4. **音声が再生されない**
398
- - システムの音声出力デバイスを確認
399
- - プラットフォーム固有の音声再生ツールの確認:
400
- - **Linux**: `aplay`, `paplay`, `play`, `ffplay` のいずれかがインストールされているか確認
401
- ```bash
402
- # 利用可能な音声プレイヤーの確認
403
- which aplay paplay play ffplay
404
- ```
405
- - **macOS**: `afplay` (標準でインストール済み)
406
- - **Windows**: PowerShell (標準でインストール済み)
407
- - VOICEVOX エンジンの動作確認:
408
- ```bash
409
- curl -X POST "http://localhost:50021/audio_query?text=テスト&speaker=1"
410
- ```
411
-
412
- ## ライセンス
413
-
414
- ISC
415
-
416
- [![MseeP.ai Security Assessment Badge](https://mseep.net/pr/kajidog-mcp-tts-voicevox-badge.png)](https://mseep.ai/app/kajidog-mcp-tts-voicevox)
1
+ # MCP TTS VOICEVOX
2
+
3
+ VOICEVOX を使用した音声合成 MCP サーバー
4
+
5
+ ## 特徴
6
+
7
+ - **高度な再生制御** - キュー管理・即時再生・同期/非同期制御による柔軟な音声処理
8
+ - **プリフェッチ** - 次の音声を事前に生成し、再生をスムーズに
9
+ - **クロスプラットフォーム対応** - Windows、macOS、Linux で動作
10
+ - **Stdio/HTTP 対応** - Claude Desktop(Stdio)や Web API(HTTP)に対応
11
+ - **複数話者対応** - セグメント単位での個別話者指定が可能
12
+ - **テキスト自動分割** - 長文の自動分割による安定した音声合成
13
+ - **独立したクライアントライブラリ** - [`@kajidog/voicevox-client`](https://www.npmjs.com/package/@kajidog/voicevox-client) として別パッケージで提供
14
+
15
+ ## 必要条件
16
+
17
+ - Node.js 18.0.0 以上
18
+ - [VOICEVOX エンジン](https://voicevox.hiroshiba.jp/) または互換エンジン
19
+
20
+ ## インストール
21
+
22
+ ```bash
23
+ npm install -g @kajidog/mcp-tts-voicevox
24
+ ```
25
+
26
+ ## 使い方
27
+
28
+ ### MCP サーバーとして
29
+
30
+ #### 1. VOICEVOX エンジンを起動
31
+
32
+ VOICEVOX エンジンを起動し、デフォルトポート(`http://localhost:50021`)で待機状態にします。
33
+
34
+ #### 2. MCP サーバーを起動
35
+
36
+ **標準入出力モード(推奨):**
37
+
38
+ ```bash
39
+ npx @kajidog/mcp-tts-voicevox
40
+ ```
41
+
42
+ **HTTP サーバーモード:**
43
+
44
+ ```bash
45
+ # Linux/macOS
46
+ MCP_HTTP_MODE=true npx @kajidog/mcp-tts-voicevox
47
+
48
+ # Windows PowerShell
49
+ $env:MCP_HTTP_MODE='true'; npx @kajidog/mcp-tts-voicevox
50
+ ```
51
+
52
+ ## MCP ツール
53
+
54
+ ### `speak` - テキスト読み上げ
55
+
56
+ テキストを音声に変換して再生します。
57
+
58
+ **パラメータ:**
59
+
60
+ - `text`: 文字列(改行区切りで複数テキスト、話者指定は「1:テキスト」形式)
61
+ - `speaker` (オプション): 話者 ID
62
+ - `speedScale` (オプション): 再生速度
63
+ - `immediate` (オプション): 即座に再生開始するか(デフォルト: true)
64
+ - `waitForStart` (オプション): 再生開始まで待機するか(デフォルト: false)
65
+ - `waitForEnd` (オプション): 再生終了まで待機するか(デフォルト: false)
66
+
67
+ **使用例:**
68
+
69
+ ```javascript
70
+ // シンプルなテキスト
71
+ { "text": "こんにちは\n今日はいい天気ですね" }
72
+
73
+ // 話者指定
74
+ { "text": "こんにちは", "speaker": 3 }
75
+
76
+ // セグメント別話者指定
77
+ { "text": "1:こんにちは\n3:今日はいい天気ですね" }
78
+
79
+ // 即座に再生(キューを迂回)
80
+ {
81
+ "text": "緊急メッセージです",
82
+ "immediate": true,
83
+ "waitForEnd": true
84
+ }
85
+
86
+ // 再生終了まで待機(同期処理)
87
+ {
88
+ "text": "この音声の再生が完了するまで次の処理を待機",
89
+ "waitForEnd": true
90
+ }
91
+
92
+ // キューに追加するが自動再生しない
93
+ {
94
+ "text": "手動で再生開始するまで待機",
95
+ "immediate": false
96
+ }
97
+ ```
98
+
99
+ ### 高度な再生制御機能
100
+
101
+ #### 即時再生(`immediate: true`)
102
+
103
+ キューを迂回して音声を即座に再生:
104
+
105
+ - **通常のキューと並行動作**: 既存のキュー再生を妨げません
106
+ - **複数同時再生**: 複数の即時再生を同時に実行可能
107
+ - **緊急通知に最適**: 重要なメッセージを優先的に再生
108
+
109
+ #### 同期再生制御(`waitForEnd: true`)
110
+
111
+ 再生完了まで待機して処理を同期化:
112
+
113
+ - **順次処理**: 音声再生後に次の処理を実行
114
+ - **タイミング制御**: 音声と他の処理の連携が可能
115
+ - **UI 同期**: 画面表示と音声のタイミングを合わせる
116
+
117
+ ```javascript
118
+ // 例1: 緊急メッセージを即座に再生し、完了まで待機
119
+ {
120
+ "text": "緊急!すぐに確認してください",
121
+ "immediate": true,
122
+ "waitForEnd": true
123
+ }
124
+
125
+ // 例2: ステップバイステップの音声ガイド
126
+ {
127
+ "text": "手順1: ファイルを開いてください",
128
+ "waitForEnd": true
129
+ }
130
+ // 上記の音声が完了してから次の処理が実行される
131
+ ```
132
+
133
+ ### その他のツール
134
+
135
+ - `generate_query` - 音声合成用クエリを生成
136
+ - `synthesize_file` - 音声ファイルを生成
137
+ - `stop_speaker` - 再生停止・キュークリア
138
+ - `get_speakers` - 話者一覧取得
139
+ - `get_speaker_detail` - 話者詳細取得
140
+
141
+ ## パッケージ構成
142
+
143
+ ### @kajidog/mcp-tts-voicevox (このパッケージ)
144
+
145
+ - **MCP サーバー** - Claude Desktop 等の MCP クライアントと通信
146
+ - **HTTP サーバー** - REST API 提供
147
+
148
+ ### [@kajidog/voicevox-client](https://www.npmjs.com/package/@kajidog/voicevox-client) (独立パッケージ)
149
+
150
+ - **汎用ライブラリ** - VOICEVOX エンジンとの通信機能
151
+ - **クロスプラットフォーム** - Node.js、ブラウザ環境対応
152
+ - **高度な再生制御** - 即時再生・同期再生・キュー管理機能
153
+
154
+ ## MCP 設定例
155
+
156
+ ### Claude Desktop での設定
157
+
158
+ `claude_desktop_config.json` ファイルに以下の設定を追加:
159
+
160
+ ```json
161
+ {
162
+ "mcpServers": {
163
+ "tts-mcp": {
164
+ "command": "npx",
165
+ "args": ["-y", "@kajidog/mcp-tts-voicevox"]
166
+ }
167
+ }
168
+ }
169
+ ```
170
+
171
+ #### SSE モードが必要な場合
172
+
173
+ SSE モードでの音声合成が必要な場合は、`mcp-remote` を使用して SSE↔Stdio 変換を行えます:
174
+
175
+ 1. **Claude Desktop 設定**
176
+
177
+ ```json
178
+ {
179
+ "mcpServers": {
180
+ "tts-mcp-proxy": {
181
+ "command": "npx",
182
+ "args": ["-y", "mcp-remote", "http://localhost:3000/sse"]
183
+ }
184
+ }
185
+ }
186
+ ```
187
+
188
+ 2. **SSE サーバーの起動**
189
+
190
+ **Mac/Linux:**
191
+
192
+ ```bash
193
+ MCP_HTTP_MODE=true MCP_HTTP_PORT=3000 npx @kajidog/mcp-tts-voicevox
194
+ ```
195
+
196
+ **Windows:**
197
+
198
+ ```powershell
199
+ $env:MCP_HTTP_MODE='true'; $env:MCP_HTTP_PORT='3000'; npx @kajidog/mcp-tts-voicevox
200
+ ```
201
+
202
+ ````
203
+
204
+ ### AivisSpeech での設定例
205
+
206
+ ```json
207
+ {
208
+ "mcpServers": {
209
+ "tts-mcp": {
210
+ "command": "npx",
211
+ "args": ["-y", "@kajidog/mcp-tts-voicevox"],
212
+ "env": {
213
+ "VOICEVOX_URL": "http://127.0.0.1:10101",
214
+ "VOICEVOX_DEFAULT_SPEAKER": "888753764"
215
+ }
216
+ }
217
+ }
218
+ }
219
+ ````
220
+
221
+ ### HTTP モードでの設定
222
+
223
+ ```json
224
+ {
225
+ "mcpServers": {
226
+ "tts-mcp-http": {
227
+ "command": "npx",
228
+ "args": ["-y", "@kajidog/mcp-tts-voicevox"],
229
+ "env": {
230
+ "MCP_HTTP_MODE": "true",
231
+ "MCP_HTTP_PORT": "3000",
232
+ "MCP_HTTP_HOST": "0.0.0.0",
233
+ "VOICEVOX_URL": "http://localhost:50021",
234
+ "VOICEVOX_DEFAULT_SPEAKER": "1"
235
+ }
236
+ }
237
+ }
238
+ }
239
+ ```
240
+
241
+ ## 環境変数
242
+
243
+ ### VOICEVOX 設定
244
+
245
+ - `VOICEVOX_URL`: VOICEVOX エンジンの URL(デフォルト: `http://localhost:50021`)
246
+ - `VOICEVOX_DEFAULT_SPEAKER`: デフォルト話者 ID(デフォルト: `1`)
247
+ - `VOICEVOX_DEFAULT_SPEED_SCALE`: デフォルト再生速度(デフォルト: `1.0`)
248
+
249
+ ### 再生オプション設定
250
+
251
+ - `VOICEVOX_DEFAULT_IMMEDIATE`: キュー追加時に即座に再生開始するか(デフォルト: `true`)
252
+ - `VOICEVOX_DEFAULT_WAIT_FOR_START`: 再生開始まで待機するか(デフォルト: `false`)
253
+ - `VOICEVOX_DEFAULT_WAIT_FOR_END`: 再生終了まで待機するか(デフォルト: `false`)
254
+
255
+ **使用例:**
256
+
257
+ ```bash
258
+ # 例1: 全ての音声再生で完了まで待機(同期処理)
259
+ export VOICEVOX_DEFAULT_WAIT_FOR_END=true
260
+ npx @kajidog/mcp-tts-voicevox
261
+
262
+ # 例2: 再生開始と終了の両方を待機
263
+ export VOICEVOX_DEFAULT_WAIT_FOR_START=true
264
+ export VOICEVOX_DEFAULT_WAIT_FOR_END=true
265
+ npx @kajidog/mcp-tts-voicevox
266
+
267
+ # 例3: 手動制御(自動再生無効)
268
+ export VOICEVOX_DEFAULT_IMMEDIATE=false
269
+ npx @kajidog/mcp-tts-voicevox
270
+ ```
271
+
272
+ これらのオプションにより、アプリケーションの要件に応じて音声再生の挙動を細かく制御できます。
273
+
274
+ ### サーバー設定
275
+
276
+ - `MCP_HTTP_MODE`: HTTP サーバーモードの有効化(`true` で有効)
277
+ - `MCP_HTTP_PORT`: HTTP サーバーのポート番号(デフォルト: `3000`)
278
+ - `MCP_HTTP_HOST`: HTTP サーバーのホスト(デフォルト: `0.0.0.0`)
279
+
280
+ ## トラブルシューティング
281
+
282
+ ### よくある問題
283
+
284
+ 1. **VOICEVOX エンジンが起動していない**
285
+
286
+ ```bash
287
+ curl http://localhost:50021/speakers
288
+ ```
289
+
290
+ 2. **音声が再生されない**
291
+
292
+ - システムの音声出力デバイスを確認
293
+ - プラットフォーム固有の音声再生ツールの確認:
294
+ - **Linux**: `aplay`, `paplay`, `play`, `ffplay` のいずれかが必要
295
+ - **macOS**: `afplay` (標準でインストール済み)
296
+ - **Windows**: PowerShell (標準でインストール済み)
297
+
298
+ 3. **MCP クライアントで認識されない**
299
+ - パッケージのインストールを確認:`npm list -g @kajidog/mcp-tts-voicevox`
300
+ - 設定ファイルの JSON 構文を確認
301
+
302
+ ## ライセンス
303
+
304
+ ISC
305
+
306
+ [![MseeP.ai Security Assessment Badge](https://mseep.net/pr/kajidog-mcp-tts-voicevox-badge.png)](https://mseep.ai/app/kajidog-mcp-tts-voicevox)