You've already forked Irene-Voice-Assistant
mirror of
https://github.com/janvarev/Irene-Voice-Assistant.git
synced 2025-11-29 22:58:09 +02:00
core v4.3 - функция say2 для проигрывания через TTS Engine 2 (можно задать в настройках)
plugin_voiceover.py - команды "озвучь (текст)", "буфер" (озвучивает буфер обмена) plugin_tts_silero_v3.py - предобработка символа троеточия, на котором стопорилось.
This commit is contained in:
63
plugins_inactive/plugin_voiceover.py
Normal file
63
plugins_inactive/plugin_voiceover.py
Normal file
@@ -0,0 +1,63 @@
|
||||
# VoiceOver
|
||||
# author: Vladislav Janvarev
|
||||
|
||||
import os
|
||||
|
||||
from vacore import VACore
|
||||
|
||||
modname = os.path.basename(__file__)[:-3] # calculating modname
|
||||
|
||||
# функция на старте
|
||||
def start(core:VACore):
|
||||
manifest = {
|
||||
"name": "Озвучивание текста",
|
||||
"version": "1.3",
|
||||
"require_online": False,
|
||||
|
||||
"default_options": {
|
||||
"wavBeforeGeneration": True, # звук перед генерацией из буфера обмена, которая может быть долгой
|
||||
"wavPath": 'media/timer.wav', # путь к звуковому файлу
|
||||
},
|
||||
|
||||
"commands": {
|
||||
"озвучь|скажи": say,
|
||||
"буфер": say_clipboard, # озвучка буфера обмена
|
||||
}
|
||||
}
|
||||
return manifest
|
||||
|
||||
def start_with_options(core:VACore, manifest:dict):
|
||||
pass
|
||||
|
||||
def say(core:VACore, phrase:str):
|
||||
if phrase == "":
|
||||
core.say2("Нечего сказать")
|
||||
return
|
||||
|
||||
core.say2(phrase)
|
||||
|
||||
def say_clipboard(core:VACore, phrase:str):
|
||||
import win32clipboard
|
||||
|
||||
win32clipboard.OpenClipboard()
|
||||
data = win32clipboard.GetClipboardData()
|
||||
win32clipboard.CloseClipboard()
|
||||
|
||||
text_to_speech = str(data)
|
||||
|
||||
options = core.plugin_options(modname)
|
||||
|
||||
if options["wavBeforeGeneration"]:
|
||||
core.play_wav(options["wavPath"])
|
||||
|
||||
try:
|
||||
core.say2(text_to_speech)
|
||||
except Exception:
|
||||
import traceback
|
||||
traceback.print_exc()
|
||||
core.say("Ошибка при озвучке буфера")
|
||||
|
||||
# sentences = text_to_speech.split(".")
|
||||
# for sentence in sentences:
|
||||
# if sentence != "":
|
||||
# core.say2(sentence+".")
|
||||
Reference in New Issue
Block a user