Uso mucho la función Texto a voz de Mac. En Configuración> Voz> Texto a voz, también configuré una "Clave" para un acceso rápido.
Dado que también quiero que Text to Speech lea alemán y OS Lion ofrece Voices para otros idiomas, me gustaría tener un segundo atajo para alemán.
¿Alguien sabe dónde puedo configurar esto? ¿O es la única forma de cambiar constantemente la voz del sistema antes de que quiera que se lea un texto en alemán? (¿Y luego restablecer la voz a Alex para textos en inglés)? ¿Y el texto en francés?
¿Qué opciones existen para este problema general?
Puede usar el say
comando con otras voces de OS X para obtener diferentes idiomas. Use la Thomas
voz para obtener la pronunciación en francés o Yannick
en alemán.
En este ejemplo, usaré Thomas y French ya que esto es lo que sé, pero Yannick
debería funcionar también para el texto en alemán.
Pruebe el siguiente comando en Aplicaciones > Utilidades > Terminal.app :
say -v Thomas "Bonjour. Je m'appelle Thomas."
Si esto es aceptable, puede encapsular el say
comando en un servicio de Automator; que haremos a continuación.
Para crear el servicio de Automator:
Copie y pegue el AppleScript a continuación:
on run {input, parameters}
do shell script "say -v Thomas " & (quoted form of (input as string))
return input
end run
Para usar el servicio:
Et voila! Hay otros idiomas y voces disponibles.
Este enfoque de Automator le permite mantener la voz predeterminada de su computadora configurada en su idioma preferido. Mientras permite que el texto seleccionado se lea en la voz alternativa.
Puede enumerar las voces disponibles y sus idiomas asociados con el comando:
say -v ?
Las voces disponibles pueden cambiar entre versiones de macOS. En macOS 10.13, el comando devuelve:
Alex en_US # Most people recognize me by my voice.
Alice it_IT # Salve, mi chiamo Alice e sono una voce italiana.
Alva sv_SE # Hej, jag heter Alva. Jag är en svensk röst.
Amelie fr_CA # Bonjour, je m’appelle Amelie. Je suis une voix canadienne.
Anna de_DE # Hallo, ich heiße Anna und ich bin eine deutsche Stimme.
Carmit he_IL # שלום. קוראים לי כרמית, ואני קול בשפה העברית.
Damayanti id_ID # Halo, nama saya Damayanti. Saya berbahasa Indonesia.
Daniel en_GB # Hello, my name is Daniel. I am a British-English voice.
Diego es_AR # Hola, me llamo Diego y soy una voz española.
Ellen nl_BE # Hallo, mijn naam is Ellen. Ik ben een Belgische stem.
Fiona en-scotland # Hello, my name is Fiona. I am a Scottish-English voice.
Fred en_US # I sure like being inside this fancy computer
Ioana ro_RO # Bună, mă cheamă Ioana . Sunt o voce românească.
Joana pt_PT # Olá, chamo-me Joana e dou voz ao português falado em Portugal.
Jorge es_ES # Hola, me llamo Jorge y soy una voz española.
Juan es_MX # Hola, me llamo Juan y soy una voz mexicana.
Kanya th_TH # สวัสดีค่ะ ดิฉันชื่อKanya
Karen en_AU # Hello, my name is Karen. I am an Australian-English voice.
Kyoko ja_JP # こんにちは、私の名前はKyokoです。日本語の音声をお届けします。
Laura sk_SK # Ahoj. Volám sa Laura . Som hlas v slovenskom jazyku.
Lekha hi_IN # नमस्कार, मेरा नाम लेखा है. मैं हिन्दी में बोलने वाली आवाज़ हूँ.
Luca it_IT # Salve, mi chiamo Luca e sono una voce italiana.
Luciana pt_BR # Olá, o meu nome é Luciana e a minha voz corresponde ao português que é falado no Brasil
Maged ar_SA # مرحبًا اسمي Maged. أنا عربي من السعودية.
Mariska hu_HU # Üdvözlöm! Mariska vagyok. Én vagyok a magyar hang.
Mei-Jia zh_TW # 您好,我叫美佳。我說國語。
Melina el_GR # Γεια σας, ονομάζομαι Melina. Είμαι μια ελληνική φωνή.
Milena ru_RU # Здравствуйте, меня зовут Milena. Я – русский голос системы.
Moira en_IE # Hello, my name is Moira. I am an Irish-English voice.
Monica es_ES # Hola, me llamo Monica y soy una voz española.
Nora nb_NO # Hei, jeg heter Nora. Jeg er en norsk stemme.
Paulina es_MX # Hola, me llamo Paulina y soy una voz mexicana.
Samantha en_US # Hello, my name is Samantha. I am an American-English voice.
Sara da_DK # Hej, jeg hedder Sara. Jeg er en dansk stemme.
Satu fi_FI # Hei, minun nimeni on Satu. Olen suomalainen ääni.
Serena en_GB # Hello, my name is Serena. I am a British-English voice.
Sin-ji zh_HK # 您好,我叫 Sin-ji。我講廣東話。
Tessa en_ZA # Hello, my name is Tessa. I am a South African-English voice.
Thomas fr_FR # Bonjour, je m’appelle Thomas. Je suis une voix française.
Ting-Ting zh_CN # 您好,我叫Ting-Ting。我讲中文普通话。
Tom en_US # Hello, my name is Tom. I am an American-English voice.
Veena en_IN # Hello, my name is Veena. I am an Indian-English voice.
Victoria en_US # Isn't it nice to have a computer that will talk to you?
Xander nl_NL # Hallo, mijn naam is Xander. Ik ben een Nederlandse stem.
Yelda tr_TR # Merhaba, benim adım Yelda. Ben Türkçe bir sesim.
Yuna ko_KR # 안녕하세요. 제 이름은 Yuna입니다. 저는 한국어 음성입니다.
Yuri ru_RU # Здравствуйте, меня зовут Yuri. Я – русский голос системы.
Zosia pl_PL # Witaj. Mam na imię Zosia, jestem głosem kobiecym dla języka polskiego.
Zuzana cs_CZ # Dobrý den, jmenuji se Zuzana. Jsem český hlas.
Una especie de publicación antigua y tal vez ya haya encontrado una solución. Una forma de simplificar esto es con Automator.
Abra Automator, elija Servicio, el servicio recibe el texto seleccionado, arrastre la acción "Hablar texto" para crear un flujo de trabajo, seleccione Voz (por ejemplo: Ryan hablando) Guardar
Repita con diferentes voces.
(La lista de servicios se puede editar/limpiar con la aplicación Service Scrubber y, en parte, en Preferencias del sistema > Teclado > Atajos de teclado > Servicios)
Editar: ahora que tiene dos o más voces en el menú Servicios, puede ir a: Preferencias del sistema > Teclado > Atajos de teclado > Atajos de aplicaciones y crear un nuevo atajo para cada voz.
Hasta ahora, funciona así en mi máquina (OS 10.6.8): Voz predeterminada del sistema: Ryan (Infovox) Acceso directo seleccionado en Speech Pref to Control+S. Esto inicia y detiene el texto en inglés.
La voz alemana la he asignado Control+Y (voz de Yannick de Lion OS). Control+Y inicia la voz en alemán para el texto seleccionado en alemán; que se puede detener haciendo clic dos veces en el atajo principal de inicio/parada, aquí Control+S+S. El motivo de dos veces es porque al presionarlo una vez se inicia la voz en inglés sobre la voz en alemán. Eso es lo mejor que pude encontrar hasta ahora. Asegúrese de que los atajos no entren en conflicto con otros atajos. Notará que el atajo adicional le permite iniciar varios subprocesos de voz, hablando entre sí más la voz predeterminada del sistema, lo que aumenta la actividad del procesador, pero no hay problema si uno recuerda detener el habla ejecutando dos veces el atajo para el voz predeterminada.
No estoy seguro de si esto funciona en todo el sistema, pero funciona en mis navegadores, Mail y la aplicación BookReader que estoy usando.
Edición 2: Me di cuenta de que al activar una voz de texto a voz secundaria a través del Servicio de Automator, el proceso de Automator Runner aumenta la actividad del procesador por encima del 100% y los ventiladores se aceleran. No estoy seguro si hay una solución a esto.
Escribí una herramienta para eso, solo ve a:
También puede configurar la voz del sistema en francés.
Vaya a Preferencias del sistema > Dictado y voz > Texto a voz y configure la voz del sistema, Thomas
por ejemplo.
Después:
También hay una opción para configurar un atajo, por lo que puede seleccionar cualquier texto y presionar el atajo para comenzar a hablar en francés.
Inicie Automator.aplicación
Crear un nuevo servicio
Añadir una acción de Leer texto
Seleccionar Samantha
Guarde el servicio como SpeakSamantha
Configurar un atajo de teclado para el servicio
Preferencias del sistema abierto
Seleccionar teclado
Seleccionar accesos directos
Seleccione Servicios
Crea un atajo, Comando + Alt + 1 para SpeakSamantha
Para utilizar el servicio
Abre un navegador
Seleccione algunos textos en inglés
Presione Comando + Alt + 1
Para detener el discurso (Método 1)
Para detener el discurso (Método 2)
Haga clic en el icono de la rueda dentada giratoria en la barra de menú
Haga clic en el ⨂
Para agregar una segunda voz
Repita el proceso anterior agregando los siguientes cambios menores
Seleccione una segunda voz, por ejemplo, Anna , una voz alemana
Guarde el servicio como SpeakAnna
Crea un atajo de teclado, Comando + Alt + 2 para SpeakAnna
Un pequeño problema conocido: no vuelva a presionar un atajo antes de finalizar el discurso o el discurso finaliza. De lo contrario, recibirá un mensaje de error como el siguiente.
El uso de un servicio personalizado con la Speak Text
acción estándar para hablar el texto seleccionado con una voz alternativa específica tiene un gran inconveniente, como se detalla en la respuesta de Mikofox :
No puede detener fácilmente la reproducción de la forma en que lo hace con el servicio TTS incorporado simplemente presionando el atajo de teclado nuevamente.
Hay dos soluciones :
Divulgación: creé los servicios preempaquetados y la voices
CLI
Cree un servicio personalizado con una Run Shell Script
acción en su lugar, en el que use la say
CLI , que permite implementar un cambio de reproducción (detener el habla si se invoca mientras sigue hablando de la invocación anterior)
Alternativamente, cree un servicio que cambie la voz predeterminada a pedido , que luego le permite usar el servicio TTS incorporado con su función de alternancia de reproducción.
voices
CLI : Implementación simple de un servicio con alternancia de reproducción :
Como se indicó, esto no respetará las velocidades de habla personalizadas configuradas para la voz elegida.
Run Shell Script
acción y pegue lo siguiente:# ------- BEGIN: CUSTOMIZE
# Specify the voice to speak with.
voice=Vicki
# ------- END: CUSTOMIZE
# If `say` is running, we assume that a previous invocation is still speaking
# and speaking should be *stopped*.
# Caveat: This will only work if either the original app from which speaking was initiated is still
# frontmost with text selected, or, coincidentally, a now different frontmost app also has
# text selected. Otherwise, this service won't be active.
pgrep -x say && { pkill -x say; exit; }
# Read the text to speak into a variable.
txt=$(</dev/stdin)
# Speak, using the standard `say` CLI.
say -v "$voice" "$txt"
Como mencionó Mikofox, puede crear un servicio de Automator para hablar texto:
Hay un error en 10.8 y 10.7 donde los accesos directos para los servicios de Automator no siempre funcionan hasta que pasas el cursor sobre el menú de servicios desde la barra de menú.
WorkflowServiceRunner también puede usar más del 100 % de la CPU cuando habla texto.
He usado FastScripts para asignar un acceso directo a este script:
try -- if the clipboard is empty, trying to get it results in an error
set old to the clipboard as record
end try
try
tell application "System Events" to keystroke "c" using command down
delay 0.05
set input to the clipboard
try
set the clipboard to old
end try
say input using "Kyoko"
end try
Otra opción es simplemente ejecutar algo como pbpaste | say -v kyoko
.
echo 'Guten Tag. Wie geht es?' | pbcopy && pbpaste | say -v Anna
sin ladera