Atajos de texto a voz con dos idiomas

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?

¿Probó la funcionalidad ya integrada en OS X?

Respuestas (7)

Saya s …

Puede usar el saycomando con otras voces de OS X para obtener diferentes idiomas. Use la Thomasvoz para obtener la pronunciación en francés o Yannicken alemán.

En este ejemplo, usaré Thomas y French ya que esto es lo que sé, pero Yannickdeberí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 saycomando en un servicio de Automator; que haremos a continuación.

Servicio de automatización

Para crear el servicio de Automator:

  1. Inicie Automator.aplicación
  2. Crear una nueva acción rápida (anteriormente Servicio )
  3. Agregar una acción Ejecutar AppleScript
  4. 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
    
  5. Guarde el servicio como Hablar en francés

Automator dice servicio

Para usar el servicio:

  1. Seleccionar texto en TextEdit o Safari
  2. Control+ Haga clic para revelar el menú contextual
  3. Seleccione Servicios > Hablar en francés

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.

Voces e idiomas disponibles

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.
Según mi propia evaluación (muy subjetiva) como hablante nativo de francés, diría que la voz es muy buena. ¡Me acabo de unir a este sitio para votar tu respuesta!
¡gran respuesta! Supongo que también es fácilmente generalizable a otros idiomas. ¿Cuál sería en este caso el nombre de los narradores? :-)
Muchas otras voces e idiomas están disponibles; consulte la sección Otros idiomas .
He actualizado la respuesta; Creo que Servicio ahora se llama Acción rápida en macOS 10.14.
¿Hay alguna forma de seleccionar la voz de Siri?
@SuperSpy no, la voz de Siri no está disponible para uso general.

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.

¿Puedes agregar una captura de pantalla de tu flujo de trabajo de Automator? Con Automator, esto suele ser más fácil de entender que una descripción textual.

Escribí una herramienta para eso, solo ve a:

https://github.com/Fredmf/polyglot

Hola, bienvenido a Ask Different. Explique un poco qué hace su herramienta y cómo. ¡Gracias!
Gracias por crear esto. Encontré que esta es la herramienta más útil en esta página.

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, Thomaspor ejemplo.

Después:

  1. Seleccione cualquier texto en cualquier aplicación
  2. Control+Haga clic para revelar el menú contextual
  3. Elija Voz > Empezar a hablar

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.

  1. Inicie Automator.aplicación

  2. Crear un nuevo servicio

  3. Añadir una acción de Leer texto

  4. Seleccionar Samantha

  5. Guarde el servicio como SpeakSamantha

Añadir una acción de Leer texto

Configurar un atajo de teclado para el servicio

  1. Preferencias del sistema abierto

  2. Seleccionar teclado

  3. Seleccionar accesos directos

  4. Seleccione Servicios

  5. Crea un atajo, Comando + Alt + 1 para SpeakSamantha

Crear un atajo para SpeakSamantha

Para utilizar el servicio

  1. Abre un navegador

  2. Seleccione algunos textos en inglés

  3. Presione Comando + Alt + 1

Para detener el discurso (Método 1)

  1. Presione Alt + ESC

Para detener el discurso (Método 2)

  1. Haga clic en el icono de la rueda dentada giratoria en la barra de menú

  2. Haga clic en el

Haga clic en el icono de la rueda dentada giratoria en la barra de menú

Para agregar una segunda voz

  1. Repita el proceso anterior agregando los siguientes cambios menores

  2. Seleccione una segunda voz, por ejemplo, Anna , una voz alemana

  3. Guarde el servicio como SpeakAnna

  4. 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.

ingrese la descripción de la imagen aquí

El uso de un servicio personalizado con la Speak Textacció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 voicesCLI

  • Cree un servicio personalizado con una Run Shell Scriptacción en su lugar, en el que use la sayCLI , que permite implementar un cambio de reproducción (detener el habla si se invoca mientras sigue hablando de la invocación anterior)

    • Vea a continuación una implementación simple que funciona, pero no respetará ninguna velocidad de habla personalizada (palabras por minuto) que pueda haber configurado para voces individuales a través de Preferencias del sistema.
    • Una solución que respete las tasas de habla personalizadas requiere un poco más de trabajo; puede encontrar un servicio preempaquetado aquí ; o use el enlace de descarga directa (permanecerá actualizado).
  • 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.

    • Si bien OSX no ofrece una forma programática de cambiar la voz predeterminada, puede usar un servicio preempaquetado integrado en la voicesCLI :
      siga las instrucciones aquí o use el enlace de descarga directa (permanecerá actualizado).

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.

  • Crear un nuevo servicio en Automator
  • Deje los valores predeterminados (el servicio recibe texto en cualquier aplicación)
  • Agregue una Run Shell Scriptacció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.

¿Hay alguna forma de seleccionar la voz de Siri en tus herramientas? ¡Gracias por crear la utilidad de cambio de voz predeterminada!
¡Esta técnica de pbpaste es excelente! ¡Gracias!echo 'Guten Tag. Wie geht es?' | pbcopy && pbpaste | say -v Anna