File size: 1,024 Bytes
9d9a30b d80aa52 9d9a30b d80aa52 9d9a30b 003c48c 9d9a30b d0e6987 d80aa52 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
import gradio as gr
import edge_tts
async def tts(text, language):
tts = edge_tts.Communicate(text, voice=language)
await tts.save("output.mp3")
return "output.mp3"
def generate_tts(text, language):
import asyncio
return asyncio.run(tts(text, language))
languages = {
"English": "en-US-JennyNeural",
"Indonesian": "id-ID-GadisNeural",
"Korean": "ko-KR-SunHiNeural",
"Japanese": "ja-JP-NanamiNeural",
"Malaysian": "ms-MY-OsmanNeural"
}
def get_audio_file(text, lang_key):
language = languages[lang_key]
return generate_tts(text, language)
with gr.Blocks(theme="Blane187/fuchsia") as demo:
gr.Markdown("# Blane TTS")
text_input = gr.Textbox(label="Input Text", lines=4)
language_input = gr.Dropdown(list(languages.keys()), label="Select Language")
tts_button = gr.Button("Generate TTS")
audio_output = gr.Audio(label="Generated Audio")
tts_button.click(get_audio_file, inputs=[text_input, language_input], outputs=audio_output)
demo.launch()
|