<!-- If you are writing original documentation in a language other -->
<!-- than English, change the language above ONLY, not here -->
<book lang="&language;">
<!-- This header contains all of the meta-information for the document such
as Authors, publish date, the abstract, and Keywords -->
<bookinfo>
<title
>O Manual do &kmyapplication;</title>
<authorgroup>
<author
><personname
> <firstname
>Gary</firstname
> <othername
>R.</othername
> <surname
>Cramblitt</surname
> </personname
> <email
>garycramblitt@comcast.net</email
> </author>
</authorgroup>
<othercredit role="translator"
><firstname
>Marcus</firstname
><surname
>Gama</surname
><affiliation
><address
><email
>marcus_gama@uol.com.br</email
></address
></affiliation
><contrib
>Tradução</contrib
></othercredit
>
<copyright>
<year
>2004-2005</year>
<holder
>Gary R. Cramblitt</holder>
</copyright>
<!-- Translators: put here the copyright notice of the translation -->
<!-- Put here the FDL notice. Read the explanation in fdl-notice.docbook
and in the FDL itself on how to use it. -->
<legalnotice
>&FDLNotice;</legalnotice>
<!-- Date and version information of the documentation
Don't forget to include this last date and this last revision number, we
need them for translation coordination !
Please respect the format of the date (YYYY-MM-DD) and of the version
(V.MM.LL), it could be used by automation scripts.
Do NOT change these in the translation. -->
<date
>2005-02-01</date>
<releaseinfo
>1.03.00</releaseinfo>
<!-- Abstract about this handbook -->
<abstract>
<para
>&kmyapplication; - o sistema de Texto-para-Voz do KDE - é um serviço baseado em plugins que permite a qualquer aplicativo (KDE e não-KDE) falar com a interface de DCOP. </para>
<para
>O &kmyapplication; pretende ser a implementação da API de Texto-para-Voz do KDE.</para>
</abstract>
<!-- This is a set of Keywords for indexing by search engines.
Please at least include KDE, the KDE package it is in, the name
of your application, and a few relevant keywords. -->
<!-- The introduction chapter contains a brief introduction for the
application that explains what it does and where to report
problems. Basically a long version of the abstract. Don't include a
revision history. (see installation appendix comment) -->
<para
>O &kmyapplication; é um sub-sistema no KDE para produzir Texto-para-Voz (do inglês, TTS). Ele oferece uma API comum para os programadores do KDE usarem os recursos de TTS para os seus aplicativos. Ele oferece algumas capacidades boas também para os usuários finais.</para>
<para
>Recursos para o usuário:</para>
<itemizedlist>
<listitem
><para
>Falar o conteúdo de um arquivo de texto.</para
></listitem>
<listitem
><para
>Falar os eventos de notificação do KDE (KNotify).</para
></listitem>
<listitem
><para
>Falar todo ou parte do texto de uma página Web no Konqueror.</para
></listitem>
<listitem
><para
>Falar todo ou parte do texto no editor de texto Kate, incluindo as instâncias em que o Kate está embutido noutro aplicativo do KDE.</para
></listitem>
<listitem
><para
>O texto comprido é processado em frases. O usuário poderá salvaguardar por frase ou parágrafo, repetir, pausar e parar a reprodução.</para
></listitem>
<listitem
><para
>Saída de áudio através do aRts ou do GStreamer (versão 0.8.7 ou posterior)</para
></listitem>
<listitem
><para
>Filtros configuráveis pelo usuário para substituição de palavras pronunciadas de maneira errada, selecionando sintetizadores de voz, e transformando documentos XML.</para
></listitem>
</itemizedlist>
<para
>Recursos para o programador:</para>
<itemizedlist>
<listitem
><para
>Um sistema de prioridades para o resultado do leitor da tela, dos avisos e das mensagens, enquanto reproduz ainda os textos normais.</para
></listitem>
<listitem
><para
>Uma arquitetura baseada em plugins para suportar uma grande variedade de sintetizadores e controladores de voz.</para
></listitem>
<listitem
><para
>Permite a geração de fala a partir da linha de comando (ou através de 'scripts'), usando os utilitários de DCOP do KDE.</para
></listitem>
<listitem
><para
>Oferece uma interface leve e fácil de usar para os aplicativos gerarem conteúdos falados.</para
></listitem>
<listitem
><para
>Os aplicativos não precisam se preocupar com a conteção sobre o dispositivo de voz.</para
></listitem>
<listitem
><para
>FUTURO: Oferecer o suporte para as linguagens de formatação de voz, como o VoiceXML, o Sable, a Java Speech Markup Language (JSML) e a Speech Markup Meta-language (SMML).</para
></listitem>
<listitem
><para
>FUTURO: Oferecer um suporte limitado para marcadores de voz embutidos.</para
></listitem>
<listitem
><para
>Assíncrono, para evitar o bloqueio do sistema.</para
></listitem>
</itemizedlist>
<para
>O &kmyapplication; consiste de fato em vários programas: <variablelist>
<varlistentry>
<term
><command
>kttsd</command
></term>
<listitem
><para
>O Servidor de Texto-para-Voz do KDE, que é um aplicativo não-gráfico que oferece os serviços de TTS aos aplicativos através do DCOP. </para
></listitem
></varlistentry>
<varlistentry>
<term
><command
>kttsmgr</command
></term>
<listitem
><para
>um aplicativo gráfico para configurar e controlar o 'kttsd'. O 'kttsmgr' fica na bandeja do sistema. </para
></listitem
></varlistentry>
<varlistentry>
<term
><command
>libkhtmlkttsdplugin</command
></term>
<listitem
><para
>Um plugin para o navegador Web Konqueror que lhe permite falar todo ou parte do texto numa página Web. </para
></listitem
></varlistentry>
<varlistentry>
<term
><command
>ktexteditor_kttsd</command
></term>
<listitem
><para
>Um plugin para o editor de texto Kate que lhe permite falar todo ou parte de um arquivo de texto. </para
>Além da base de dados do Bugzilla do KDE ( <ulink url="http://bugs.kde.org/"
>http://bugs.kde.org/</ulink
> ), as discussões sobre o &kmyapplication; acontecem atualmente na lista de correio 'kde-accessibility'. Inscreva-se em <ulink url="https://mail.kde.org/mailman/listinfo/kde-accessibility"
>Antes de poder usar o &kmyapplication;, você deverá instalar pelo menos um motor de síntese de voz e garantir que ele funcione. Veja em <xref linkend="installation"/>. </para
>Selecionando os Plugins de Síntese (Locutores)</title>
<para
>Quando clica na página de <guilabel
>Locutores</guilabel
> do <command
>kttsmgr</command
>, a tela de <guilabel
>Locutores</guilabel
> aparece.</para>
<para>
<screenshot>
<screeninfo
>O Gerenciador de Texto-para-Voz do KDE (página Locutores).</screeninfo>
<mediaobjectco>
<imageobjectco>
<areaspec units="calspair">
<area id="pt-talker-1" coords="1 1"/>
<area id="pt-talker-2" coords="1 1"/>
<area id="pt-talker-3" coords="1 1"/>
<area id="pt-talker-4" coords="1 1"/>
<area id="pt-talker-5" coords="1 1"/>
<area id="pt-talker-6" coords="1 1"/>
</areaspec>
<imageobject>
<imagedata fileref="talkers.png" format="PNG"/>
</imageobject>
</imageobjectco>
<textobject>
<phrase
>O Gerenciador de Texto-para-Voz do KDE (página Locutores)</phrase>
</textobject>
</mediaobjectco>
</screenshot>
</para>
<para>
<calloutlist>
<callout arearefs="pt-talker-1"
><para
>Clique aqui para adicionar um novo locutor, que é um plugin de síntese de voz.</para
></callout>
<callout arearefs="pt-talker-2"
><para
>Todos os <guilabel
>Locutores</guilabel
> estão listados aqui. Os <guilabel
>Locutores</guilabel
> de maior prioridade encontram-se no topo. O locutor do topo será usado para falar, quando um aplicativo não indicar nenhum locutor específico.</para
></callout>
<callout arearefs="pt-talker-3"
><para
>Clique num locutor da lista para selecioná-lo e clique neste botão para removê-lo.</para
></callout>
<callout arearefs="pt-talker-4"
><para
>Clique num locutor da lista para selecioná-lo e clique neste botão para mostrar o diálogo de configuração do plugin de síntese.</para
></callout>
<callout arearefs="pt-talker-5"
><para
>Clique num locutor da lista para selecioná-lo e clique neste botão para descê-lo uma posição na lista. Quanto mais baixo estiver um locutor na lista, menor a sua prioridade.</para
></callout>
<callout arearefs="pt-talker-6"
><para
>Clique num destes botões para aplicar as alterações que tenha feito ao sistema &kmyapplication; em execução.</para
></callout>
</calloutlist>
</para>
<para
>Quando clicar no botão <guilabel
>Adicionar</guilabel
>, a tela para <guilabel
>Adicionar Locutor</guilabel
> aparece.</para>
<para>
<screenshot>
<screeninfo
>A tela para Adicionar Locutor.</screeninfo>
<mediaobjectco>
<imageobjectco>
<areaspec units="calspair">
<area id="pt-addtalker-1" coords="1 1"/>
<area id="pt-addtalker-2" coords="1 1"/>
<area id="pt-addtalker-3" coords="1 1"/>
</areaspec>
<imageobject>
<imagedata fileref="addtalker.png" format="PNG"/>
</imageobject>
</imageobjectco>
<textobject>
<phrase
>A tela para Adicionar Locutor</phrase>
</textobject>
</mediaobjectco>
</screenshot>
</para>
<para>
<calloutlist>
<callout arearefs="pt-addtalker-1"
><para
>Você poderá selecionar um plugin de síntese de voz pelo nome do <guilabel
>Sintetizador</guilabel
> ou pelo <guilabel
>Idioma</guilabel
> que o sintetizador consegue falar. Assinale a opção ao lado da área correspondente. Quando o botão do <guilabel
>Idioma</guilabel
> estiver assinalado, a área do <guilabel
>Idioma</guilabel
> mostra todos os idiomas suportados por todos os sintetizadores disponíveis e a área do <guilabel
>Sintetizador</guilabel
> mostra apenas os que suportam o idioma escolhido. Quando estiver a opção do <guilabel
>Sintetizador</guilabel
> selecionada, a área do <guilabel
>Sintetizador</guilabel
> mostra todos os que se encontram disponíveis e a do <guilabel
>Idioma</guilabel
> mostra apenas os idiomas suportados pelo sintetizador escolhido.</para
></callout>
<callout arearefs="pt-addtalker-2"
><para
>Escolha aqui o idioma e o plugin de síntese.</para
></callout>
<callout arearefs="pt-addtalker-3"
><para
>Quando clicar aqui, a maioria dos plugins de síntese se configurarão automaticamente eles mesmos, escolhendo uma configuração padrão. Irá aparecer um novo locutor na lista da página <guilabel
>Locutores</guilabel
>. Clique no botão <guilabel
>Configurar</guilabel
> para mostrar ou editar a configuração do locutor. Veja <xref linkend="configure-plugin"/>.</para
></callout>
</calloutlist>
</para>
<warning
><para
>Você precisa de configurar pelo menos um locutor e de clicar nos botões <guilabel
>Aplicar</guilabel
> ou <guilabel
>OK</guilabel
> antes de poder iniciar o sistema do &kmyapplication; e começar a falar o texto. Para iniciar o sistema &kmyapplication;, clique na página <guilabel
>Geral</guilabel
> e assinale a opção <guilabel
>Ativar o Sistema de Texto-para-Voz (KTTSD)</guilabel
>Configurando os Plugins de Síntese (Locutores)</title>
<para
>Quando você clica no botão <guilabel
>Adicionar</guilabel
> da página <guilabel
>Locutores</guilabel
> e adiciona um locutor ou clica no botão <guibutton
>Configurar</guibutton
>, a tela de <guilabel
>Configuração do Locutor</guilabel
> aparece. Cada plugin de voz possui uma tela de <guilabel
>Configuração do Locutor</guilabel
> diferente. O exemplo a seguir é para configuração do Festival Interative. Para mais detalhes específicos sobre cada tipo de plugin, veja <xref linkend="configuration"/>.</para>
>Indique a localização do programa executável do Festival. Se o Festival estiver na sua variável de ambiente PATH, basta inserir <userinput
><replaceable
>festival</replaceable
></userinput
>.</para
></callout>
<callout arearefs="pt-prop-2"
><para
>Clique para procurar por vozes disponíveis.</para
></callout>
<callout arearefs="pt-prop-3"
><para
>Selecione uma voz.</para
></callout>
<callout arearefs="pt-prop-4"
><para
>Clique para testar. Você deverá ouvir agora uma frase de teste falada.</para
></callout>
<callout arearefs="pt-prop-5"
><para
>Use estas opções para controlar o volume, a velocidade da síntese e o tom da voz sintetizada. Se qualquer uma destas opções estiver desabilitada (em cinza), a voz escolhida não suporta mudanças.</para
></callout>
<callout arearefs="pt-prop-6"
><para
>Algumas vozes, como as do MultiSyn, são tão grandes que necessitam de vários segundos para serem carregadas. Se assinalar esta opção, fará com que elas sejam carregadas na inicialização do KTTSD, poupando deste modo algum tempo (com a contrapartida de usar mais memória), antes da primeira frase ser sintetizada.</para
></callout>
</calloutlist>
</para>
<para
>Clique no botão <guibutton
>Ok</guibutton
> para salvar a configuração do locutor.</para>
<warning
><para
>Certifique-se de que clica no botão <guibutton
>Aplicar</guibutton
>, caso contrário as suas alterações não farão efeito no sistema &kmyapplication; em execução. </para
></warning>
<para
>Assumindo que o teste funcionou, já está quase pronto para começar a usar o &kmyapplication;. Volte agora à página <guilabel
>Geral</guilabel
> e assinale a opção <guilabel
>Ativar o Sistema de Texto-para-Voz (KTTSD)</guilabel
>. Isto irá iniciar o Servidor de TTS do KDE. Veja <xref linkend="general"/>. Você poderá começar a usar agora o &kmyapplication; para dizer o texto. Clique na página <guilabel
>Tarefas</guilabel
> para criar e gerenciar as tarefas de texto. Veja em <xref linkend="jobmgr"/>. </para>
>Iniciando o KTTSD e Configurando as Opções Gerais</title>
<para
>Logo que tenha configurado pelo menos um Locutor, você poderá iniciar o Sistema de Texto-para-Voz do KDE. Clique na página <guilabel
>Geral</guilabel
>. Neste caso, aparecerá a tela <guilabel
>Geral</guilabel
>. Você poderá também configurar algumas opções gerais nesta tela. </para>
<para>
<screenshot>
<screeninfo
>O Gerenciador de Texto-para-Voz do KDE (página Geral).</screeninfo>
<mediaobjectco>
<imageobjectco>
<areaspec units="calspair">
<area id="pt-gen-1" coords="1 1"/>
<area id="pt-gen-2" coords="1 1"/>
<area id="pt-gen-3" coords="1 1"/>
<area id="pt-gen-4" coords="1 1"/>
<area id="pt-gen-5" coords="1 1"/>
<area id="pt-gen-6" coords="1 1"/>
<area id="pt-gen-7" coords="1 1"/>
</areaspec>
<imageobject>
<imagedata fileref="general.png" format="PNG"/>
</imageobject>
</imageobjectco>
<textobject>
<phrase
>O Gerenciador de Texto-para-Voz do KDE (página Geral)</phrase>
</textobject>
</mediaobjectco>
</screenshot>
</para>
<para>
<calloutlist>
<callout arearefs="pt-gen-1"
><para
>Assinale esta opção para ativar o sistema &kmyapplication;. Isto irá iniciar o Servidor de TTS do KDE (KTTSD). Se o KTTSD iniciar com sucesso, irá aparecer a página de <guilabel
>Tarefas</guilabel
>. Logo que o KTTSD tenha sido iniciado, você poderá começar a criar e a falar as tarefas de texto. Veja em <xref linkend="jobmgr"/>. Se desligar a opção, irá parar o KTTSD e desativar o sistema de TTS do KDE. <note
><para
>Se esta opção estiver desativada, ainda não configurou nenhum Locutor (ou então esqueceu-se de clicar no botão <guilabel
>Aplicar</guilabel
>). Veja em <xref linkend="select-plugin"/>.</para
></note>
</para
></callout>
<callout arearefs="pt-gen-2"
><para
>Assinale esta opção para falar as notificações do KDE. Veja em <xref linkend="knotify"/> para obter mais informações.</para
></callout>
<callout arearefs="pt-gen-3"
><para
>Assinale esta opção para falar somente as notificações do KDE que sejam exibidas em uma janela instantânea.</para
></callout>
<callout arearefs="pt-gen-4"
><para
>Assinale esta opção para falar somente as notificações do KDE que sejam exibidas em uma janela instantânea passiva.</para
></callout>
<callout arearefs="pt-gen-5"
><para
>Quando esta opção estiver assinalada, aparece um ícone na bandeja do sistema sempre que o <command
>kttsmgr</command
> estiver em execução. Neste modo, se clicar em <guilabel
>OK</guilabel
> ou em <guilabel
>Cancelar</guilabel
> não fará com que o <command
>kttsmgr</command
> saia. Em vez disso, a tela desaparece, mas o <command
>kttsmgr</command
> continua a rodar na bandeja do sistema. Clique no ícone para restaurar a tela. Para sair do <command
>kttsmgr</command
>, clique com o botão direito no ícone da bandeja do sistema e escolha <guilabel
>Sair</guilabel
>. Quando estiver desligada a opção, não aparecerá nenhum ícone na bandeja do sistema. Se clicar em <guilabel
>OK</guilabel
> ou em <guilabel
>Cancelar</guilabel
>, sairá do <command
>kttsmgr</command
>. <note
><para
>Quando o <command
>kttsmgr</command
> sai, o &kmyapplication; mantém-se rodando se a opção para <guilabel
>Ativar o Sistema de Texto-para-Voz (KTTSD)</guilabel
> estiver assinalada.</para
></note>
<note
><para
>Esta opção não fará efeito até à próxima vez em que o <command
>kttsmgr</command
> for iniciado.</para
></note>
<note
><para
>Esta opção não fará efeito quando o <command
>kttsmgr</command
> estiver em execução no Centro de Controle do KDE.</para
></note>
</para
></callout>
<callout arearefs="pt-gen-6"
><para
>Quando esta opção estiver assinalada, a tela do <command
>kttsmgr</command
> aparece quando iniciar o <command
>kttsmgr</command
>. Se estiver desligada, o ícone do <command
>kttsmgr</command
> aparecerá na bandeja do sistema quando o <command
>kttsmgr</command
> for iniciado, apesar da tela não aparecer. Clique no ícone da bandeja para que ela então apareça.</para
></callout>
<callout arearefs="pt-gen-7"
><para
>Certifique-se de clicar aqui para salvar suas configurações.</para
>O Gerenciador de Texto-para-Voz do KDE (página Tarefas).</screeninfo>
<mediaobjectco>
<imageobjectco>
<areaspec units="calspair">
<area id="pt-jobmgr-1" coords="1 1"/>
<area id="pt-jobmgr-2" coords="1 1"/>
<area id="pt-jobmgr-3" coords="1 1"/>
<area id="pt-jobmgr-4" coords="1 1"/>
<area id="pt-jobmgr-5" coords="1 1"/>
</areaspec>
<imageobject>
<imagedata fileref="jobs.png" format="PNG"/>
</imageobject>
</imageobjectco>
<textobject>
<phrase
>O Gerenciador de Texto-para-Voz do KDE (página Tarefas)</phrase>
</textobject>
</mediaobjectco>
</screenshot>
</para>
<para>
<calloutlist>
<callout arearefs="pt-jobmgr-1"
><para
>Os botões nesta barra de ferramentas permitem-lhe iniciar, remover e colocar em pausa as tarefas de texto. Selecione uma tarefa na lista abaixo e clique num destes botões.</para
></callout>
<callout arearefs="pt-jobmgr-2"
><para
>Os botões nesta barra de ferramentas permitem-lhe avançar ou voltar atrás na frase dentro da tarefa selecionada na lista abaixo. (Nem todas as tarefas possuem várias partes).</para
></callout>
<callout arearefs="pt-jobmgr-3"
><para
>Os botões nesta barra de ferramentas permitem-lhe falar o texto na área de transferência do KDE ou abrir um arquivo de texto para falar. Você poderá também atualizar a lista de tarefas de texto.</para
></callout>
<callout arearefs="pt-jobmgr-4"
><para
>A frase atualmente a ser falada aparece aqui. Se necessitar, poderá redimensionar este painel arrastando a divisória para cima ou para baixo.</para
></callout>
<callout arearefs="pt-jobmgr-5"
><para
>Quando clicar em <guibutton
>OK</guibutton
>, todas as alterações de configuração nas outras telas são aplicadas (se existirem) e o <command
>kttsmgr</command
> será minimizado para a bandeja do sistema. Clique no ícone da bandeja do sistema para restaurar a tela.</para
></callout>
</calloutlist>
</para>
<note
><para
>A página de <guilabel
>Tarefas</guilabel
> só aparece quando o KTTSD está em execução. Se não conseguir ver a página <guilabel
>O Gerenciador de Texto-para-Voz do KDE (página Áudio).</screeninfo>
<mediaobjectco>
<imageobjectco>
<areaspec units="calspair">
<area id="pt-audio-1" coords="1 1"/>
<area id="pt-audio-2" coords="1 1"/>
<area id="pt-audio-3" coords="1 1"/>
<area id="pt-audio-4" coords="1 1"/>
<area id="pt-audio-5" coords="1 1"/>
</areaspec>
<imageobject>
<imagedata fileref="audio.png" format="PNG"/>
</imageobject>
</imageobjectco>
<textobject>
<phrase
>O Gerenciador de Texto-para-Voz do KDE (página Áudio)</phrase>
</textobject>
</mediaobjectco>
</screenshot>
</para>
<para>
<calloutlist>
<callout arearefs="pt-audio-1"
><para
>Selecione o método de saída de áudio aqui. Se o <guilabel
>GStreamer</guilabel
> estiver em cinza, ou o &kmyapplication; foi compilado sem o suporte para o GStreamer ou o &kmyapplication; foi incapaz de carregar as bibliotecas do GStreamer necessárias. </para
></callout>
<callout arearefs="pt-audio-2"
><para
>Se o GStreamer estiver selecionado para a saída de áudio, escolha o método de 'sink' (canal) de áudio do GStreamer. Se não estiver listado nenhum 'sink', terá que instalar pelo menos um. Veja em <xref linkend="requirements"/>. </para
></callout>
<callout arearefs="pt-audio-3"
><para
>Ajuste a velocidade da fala aqui. 50% é aproximadamente duas vezes mais lento que o normal, enquanto 200% é aproximadamente duas vezes mais rápido. Você deve ter o utilitário <command
>sox</command
> instalado para esta configuração funcionar. </para
></callout>
<callout arearefs="pt-audio-3"
><para
>Quando esta opção estiver selecionada, o &kmyapplication; copiará os arquivos de áudio temporários (arquivos .wav) para o diretório indicado. Escolha qualquer diretório em seu disco rígido que desejar, mas certifique-se de ter acesso de escrita a ele. Isto pode ser útil para criar arquivos de áudio de fala para outras finalidades. Os arquivos terão nomes no formato <filename
>kttsd-T-FF</filename
> onde <filename
>T</filename
> é o número da tarefa e <filename
>FF</filename
> é o número da frase. Arquivos existentes com o mesmo nome serão excluídos. <emphasis
>Não esqueça de desabilitar esta opção, caso contrário seu disco rígido ficará cheio rapidamente!</emphasis
> </para
></callout>
<callout arearefs="pt-audio-5"
><para
>Certifique-se de clicar no botão <guibutton
>Aplicar</guibutton
> para tornar efetivas as opções novas no sistema &kmyapplication; em execução. </para
></callout>
</calloutlist>
</para>
<note
><para
>Existem duas formas de ajustar a velocidade no &kmyapplication;. Muitos dos <guilabel
>Locutores</guilabel
> possuem uma configuração de <guilabel
>Velocidade</guilabel
> nos seus diálogos de configuração, que poderão ser acessados clicando em <guibutton
>Editar</guibutton
> na tela de <guilabel
>Locutores</guilabel
>. Esta opção de <guilabel
>Velocidade</guilabel
> da tela de <guilabel
>Áudio</guilabel
> é adicional em relação à velocidade do Locutor e pode ser usada de um modo geral, mesmo que o Locutor não suporte uma opção de velocidade. Para ela funcionar, você deverá ter o utilitário <command
>sox</command
> instalado no seu sistema (usuários de Debian: <command
>apt-get install sox</command
>). Da mesma forma, esta opção de velocidade é ignorada ao falar o texto que contenha SSML. (Veja em <xref linkend="ssml"/>)</para
>Filtros são um recurso avançado do &kmyapplication;. Para a operação básica do &kmyapplication; eles não são necessários.</para>
<para
>Filtros são usados para pré-processar o texto antes de enviá-lo para o motor de sintetização de fala. Eles são úteis para melhorar a fala, susbtituindo palavras faladas incorretamente ou abreviaturas, escolhendo o idioma apropriado para o locutor usar, ou contornando determinadas limitações dos sintetizadores de fala e suas vozes.</para>
<para
>Para entender como usar os filtros, é interessante primeiro entender como o texto é processado pelo &kmyapplication;. O texto falado pelo &kmyapplication; pode ser de quatro tipos possíveis.</para>
<para>
<itemizedlist>
<listitem
><para
>Resultado do Leitor da Tela.</para
></listitem>
<listitem
><para
>Avisos.</para
></listitem>
<listitem
><para
>Mensagens</para
></listitem>
<listitem
><para
>Tarefas de Texto</para
></listitem>
</itemizedlist>
</para>
<para
>O tipo é determinado pelo aplicativo que envia o texto para o &kmyapplication;. O Resultado do Leitor de Tela é usado por aplicativos desenhados para pessoas cegas ou com deficiência visual. O Resultado do Leitor de Tela é sempre falado antes de qualquer outro tipo e interromperá qualquer tipo de fala. Avisos e Mensagens são mensagens curtas que lhe alertam sobre informações urgentes. Eles interrompem as Tarefas de Texto. Avisos possuem prioridade maior do que as Mensagens. O KMouth é um exemplo de um aplicativo que usa Mensagens para sua fala. As Notificações do KDE são também Mensagens. O resto são Tarefas de Texto comuns. Qualquer tarefa que você inicie a partir da página <guilabel
>Tarefas</guilabel
> é uma Tarefa de Texto. O KSayit é um exemplo de um aplicativo que usa Tarefas de Texto. Tarefas de Texto tendem a gerar trechos longos de fala que não são urgentes.</para>
<para
>A primeira coisa que você deve saber sobre filtros é que eles são aplicados somente às Tarefas de Texto comuns e às mensagens de Notificação do KDE. O Resultado do Leitor de Tela, Avisos e Mensagens não são afetados pelos filtros.</para>
<para
>Existem dois tipos de filtros -- filtros ordinários e filtros Detectores de Limite de Frase (do inglês, SBD). SBDs quebram o texto em frases individuais. Isto permite que o &kmyapplication; comece a falar mais rapidamente porque ele precisa somente sintetizar a primeira sentença, não toda a Tarefa de Texto. Isto também permite que você avance e recue por sentença na página <guilabel
>Tarefas</guilabel
>, ou para ou pause Tarefas de Texto quando o sintetizador de fala não suporta diretamente a parada da fala. </para>
<para
>Filtros ordinários processam o texto e passam-no para o próximo filtro. Eles são atualmente de três tipos. </para>
<para>
<itemizedlist>
<listitem
><para
>Substituidores de Texto.</para
></listitem>
<listitem
><para
>Transformadores XML</para
></listitem>
<listitem
><para
>Selecionadores de Locutor.</para
></listitem>
</itemizedlist>
</para>
<note
><para
>Filtros são implementados usando uma arquitetura de plugins No futuro, poderão haver tipos de filtros adicionais.</para
></note>
<para
>Filtros para Substituir Texto substituem partes do texto com outro texto. As partes substituídas são correspondidas com palavras ou expressões regulares. O &kmyapplication; vem com filtros Substituidor de Texto pré-definidos para falar abreviaturas, falar ícones emotivos, como o ":-)", ou reformatar mensagens de notificação do Konversation ou KMail para um formato mais compreensível. </para>
<para
>Transformadores XML usam uma Linguagem de Estilo XML - Transformam arquivo (XSLT) para converter XML de um formato para outro formato. O &kmyapplication; vem com um arquivo XSLT para converter XHTML para SSML, mas ele deve ser considerado como ainda muito experimental. </para>
<para
>Selecionadores de Locutor permitem que você redirecione trabalhos para um locutor baseado no conteúdo do texto, ou no aplicativo que o enviou para o &kmyapplication;. Por exemplo, se você tiver configurado um locutor feminino na página <guilabel
>Locutores</guilabel
>, você pode redirecionar texto vindo das Notificações do KDE para este locutor. Veja <xref linkend="select-plugin"/>. </para>
<para
>Cada um destes tipos de filtros possui regras de configuração para quando o filtro deve ser aplicado ao texto a ser falado. Se o filtro determinar que ele não deve ser aplicado, o texto é passado para o próximo filtro sem alterações.</para>
<para
>Quando uma Tarefa de Texto ou mensagem de Notificação do KDE é enviada para o &kmyapplication;, ele passa por cada filtro habilitado que tenha configurado na tela abaixo. A ordem é de cima para baixo. Após passar por cada um dos filtros ordinários listados na porção superior da tela, as Tarefas de Texto são passadas para os filtros de <guilabel
>Detector de Limite de Frase</guilabel
> (SBD). (Notificações do KDE nunca passam pelos filtros SBD.) Diferentemente dos filtros ordinários, o primeiro filtro SBD que fizer mudanças para qualquer filtragem posterior. </para>
<para
>Para usar filtros, clique na página de <guilabel
>Filtros</guilabel
> no <command
>kttsmgr</command
>.</para>
<para>
<screenshot>
<screeninfo
>O Gerenciador de Texto-para-Voz do KDE (página Filtros).</screeninfo>
<mediaobjectco>
<imageobjectco>
<areaspec units="calspair">
<area id="pt-filters-1" coords="1 1"/>
<area id="pt-filters-2" coords="1 1"/>
<area id="pt-filters-3" coords="1 1"/>
<area id="pt-filters-4" coords="1 1"/>
<area id="pt-filters-5" coords="1 1"/>
<area id="pt-filters-6" coords="1 1"/>
<area id="pt-filters-7" coords="1 1"/>
<area id="pt-filters-8" coords="1 1"/>
</areaspec>
<imageobject>
<imagedata fileref="filters.png" format="PNG"/>
</imageobject>
</imageobjectco>
<textobject>
<phrase
>O Gerenciador de Texto-para-Voz do KDE (página Filtros)</phrase>
</textobject>
</mediaobjectco>
</screenshot>
</para>
<para>
<calloutlist>
<callout arearefs="pt-filters-1"
><para
>Esta é a lista dos filtros ordinários configurados. Se você deselecioná-lo, o filtro fica inativa e será pulado. Quando você roda o &kmyapplication; pela primeira vez, isto é automaticamente preenchido com uma instância de cada tipo de filtro, mas eles ficam todos inativos. Os filtros são aplicados na ordem especificada aqui, de cima para baixo.</para
></callout>
<callout arearefs="pt-filters-2"
><para
>Clique aqui para adicionar um novo filtro. Você será perguntado pelo tipo de filtro a adicionar. Após escolher o tipo, veja o diálogo de configuração abaixo.</para
></callout>
<callout arearefs="pt-filters-3"
><para
>Clique aqui para remover um filtro. Se o filtro for o último deste tipo, ele não será removido; ao invés disso, será desativado.</para
></callout>
<callout arearefs="pt-filters-4"
><para
>Clique aqui para mudar a configuração de um filtro. Veja o diálogo de configuração abaixo.</para
></callout>
<callout arearefs="pt-filters-5"
><para
>Clique nestes botões para mover um filtro para cima ou para baixo na lista.</para
></callout>
<callout arearefs="pt-filters-6"
><para
>Estes são os filtros de Detector de Limite de Frase. Quando você inicia pela primeira vez o &kmyapplication;, o Detector de Limite de Frase Padrão é automaticamente configurado para você. Você pode mudar a configuração deste filtro, ou adicionar Detectores de Limite de Frase adicionais, mas nós alertamos aos iniciantes para não mudá-los.</para
></callout>
<callout arearefs="pt-filters-7"
><para
>Este botão de lista suspensa permite adicionar, remover, editar ou mudar a ordem dos filtros de Detector de Limite de Frase.</para
></callout>
<callout arearefs="pt-filters-8"
><para
>Certifique-se de clicar aqui, caso contrário suas configurações não terão efeito.</para
>Configurando Filtros de Substituição de Texto.</title>
<para
>Você configura filtros de Substituição de Texto fornecendo uma lista de palavras ou expressões regulares a serem correspondidas. Quando palavras ou expressões regulares correspondentes forem encontrados no texto, cada uma delas será substituída por um texto de substituição fornecido. A correspondência não é sensível à caixa.</para>
>Insira um nome para seu filtro. Use qualquer nome que desejar para distinguí-lo de todos os outros filtros.</para
></callout>
<callout arearefs="pt-stringreplacer-2"
><para
>Esta é a lista de palavras e expressões regulares. O filtro procura por correspondências de cada texto na coluna <guilabel
>Corresponder</guilabel
>, susbtituindo o texto correspondente com o texto na coluna <guilabel
>Substituir Com</guilabel
>.</para
></callout>
<callout arearefs="pt-stringreplacer-3"
><para
>Clique aqui para adicionar outra palavra ou expressão regula à lista.</para
></callout>
<callout arearefs="pt-stringreplacer-4"
><para
>Clique aqui para mover a palavra ou expressão regular atualmente destacada para cima ou para baixo na lista. A lista é processada na ordem exibida, de cima para baixo.</para
></callout>
<callout arearefs="pt-stringreplacer-5"
><para
>Clique para mudar uma palavra ou expressão regular existente na lista.</para
></callout>
<callout arearefs="pt-stringreplacer-6"
><para
>Clique para remover a palavra ou expressão regular atualmente destacada da lista.</para
></callout>
<callout arearefs="pt-stringreplacer-7"
><para
>Use estes botões para carregar uma lista de palavras ou expressões regulares de um arquivo, salvar a lista atual para um arquivo, ou limpar toda a lista. Ao carregar a partir de um arquivo, os itens no arquivo serão adicionados à lista existente.</para
></callout>
<callout arearefs="pt-stringreplacer-8"
><para
>Se não estiver em branco, o filtro será aplicado somente se o idioma do locutor da Tarefa de Texto corresponder com o idioma inserido aqui. Clique o botão para exibir uma lista de idiomas. Você pode selecionar mais de um idioma pressionando o <keycap
>&Ctrl;</keycap
> enquanto clica.</para
></callout>
<callout arearefs="pt-stringreplacer-9"
><para
>Se não estiver em branco, o filtro será aplicado somente se o texto vier de um dos aplicativos listados. Você pode inserir mais de um aplicativo separado por vírgulas. Exemplo: <command
><userinput
>knotify,konversation</userinput
></command
></para>
<tip
><para
>Você pode descobrir o <guilabel
>ID do Aplicativo</guilabel
> de programas em execução usando o programa <command
>kdcop</command
>. Você deve deixar o número DCOP fora. Por exemplo, se o kdcop mostra um ID de Aplicativo de <command
>kopete-3432</command
>, você deve apenas inserir <command
><userinput
>kopete</userinput
></command
>.</para
></tip
></callout>
</calloutlist>
</para>
<para
>O filtro Substituidor de Texto somente será aplicado ao texto se todas as condições não vazias forem atendidas na caixa <guilabel
>Aplicar Este Filtro Quando</guilabel
>.</para>
<para
>Todas as correspondências são insensíveis à caixa.</para>
<para
>Ao corresponder palavras, o filtro Substituidor de Texto internamente usa uma expressão regular no formato <command
>\s<userinput
>palavra</userinput
>\s</command
>. Em outras palavras, a palavra deve estar rodeada por espaço em ambos os lados.</para>
<para
>Uma discussão sobre como escrever expressões regulares está fora do escopo deste manual. Se você tiver o editor de Expressões Regulares do KDE instalado, existe um botão disponível nas telas <guilabel
>Adicionar</guilabel
> ou <guilabel
>Editar</guilabel
> que lhe auxiliam a construir expressões regulares. O Editor de Expressões Regulares do KDE é parte do pacote <command
>O &kmyapplication; vem com uma pequena lista de arquivos, incluindo uma lista de ícones emotivos, como o ":-)", algumas abreviaturas tipicamente usadas em IRC ou aplicativos de mensagens instantâneas, e uma lista de abreviaturas diversas. Existe também uma lista de caracteres especiais que a versão atual da voz do Polish Festival não pode manipular. Se você criar uma lista de palavras úteis que queira compartilhar, use o botão <guilabel
>Salvar</guilabel
> para salvá-las para um arquivo e envie-as para a equipe do &kmyapplication; para inclusão na próxima versão.</para>
>O filtro Transformador XML usa arquivos XSLT para transformar XML de um formato para outro. O XSLT (do inglês Transformação de Linguagem no Estilo XML), é uma linguagem padrão W3C para realizar estas transformações. Ele somente pode ser usado em XML formado corretamente.</para>
>Insira um nome para seu filtro. Use qualquer nome que desejar para distinguí-lo de todos os outros filtros.</para
></callout>
<callout arearefs="pt-xmltransformer-2"
><para
>Insira o caminho completo para um arquivo XSLT existente, que realizará a transformação.</para
></callout>
<callout arearefs="pt-xmltransformer-3"
><para
>Especifique o caminho para o utilitário <command
>xsltproc</command
>. Se o 'xsltproc' estiver em seu PATH, simplesmente insira <command
><userinput
>xsltproc</userinput
></command
>.</para
></callout>
<callout arearefs="pt-xmltransformer-4"
><para
>Se não estiver em branco, o filtro somente se aplicará se o XML tiver o elemento raiz especificado. Isto diferencia uma forma XML de outra.</para
></callout>
<callout arearefs="pt-xmltransformer-5"
><para
>Se não estiver em branco, o filtro será aplicado somente se o XML tiver uma especificação <command
><![CDATA[<!DOCTYPE]]></command
> iniciando com o texto inserido. Por exemplo, <command
><userinput
>html</userinput
></command
> corresponde à <command
><![CDATA[<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"
>]]></command
>. </para
></callout>
<callout arearefs="pt-xmltransformer-6"
><para
>Se não estiver em branco, o filtro será aplicado somente se o texto vier de um dos aplicativos listados. Você pode inserir mais de um aplicativo separado por vírgulas. Exemplo: <command
><userinput
>knotify,konversation</userinput
></command
></para>
<tip
><para
>Você pode descobrir o <guilabel
>ID do Aplicativo</guilabel
> de programas em execução usando o programa <command
>kdcop</command
>. Você deve deixar o número DCOP fora. Por exemplo, se o kdcop mostra um ID de Aplicativo de <command
>kopete-3432</command
>, você deve apenas inserir <command
><userinput
>kopete</userinput
></command
>.</para
></tip
></callout>
</calloutlist>
</para>
<para
>O filtro Transformador XML somente se aplicará ao texto se todas as condições não vazias forem atendidas na caixa <guilabel
>Configurando Filtros Selecionadores de Locutor.</title>
<para
>Os filtros Selecionadores de Locutor são usados para direcionar o texto para um locutor especificado configurado na página <guilabel
>Locutor</guilabel
>, ou para qualquer locutor que possua determinados atributos. Por exemplo, você pode especificar que o texto vindo do <command
>knotify</command
> deva ser falado usando um locutor configurado como voz feminina. Veja <xref linkend="select-plugin"/>.</para>
<para
>Imediatamente antes do &kmyapplication; começar a enviar o texto para os filtros, ele seleciona um locutor para falar o texto. O locutor escolhido é baseado nos atributos do locutor especificados pelo aplicativo que enviou o texto para o &kmyapplication; e os atributos dos locutores que você configurou na página <guilabel
>Locutores</guilabel
>. O filtro Selecionador de Locutor permite que você sobreponha esta escolha de locutor. </para>
>Insira um nome para seu filtro. Use qualquer nome que desejar para distinguí-lo de todos os outros filtros.</para
></callout>
<callout arearefs="pt-talkerchooser-2"
><para
>Se não estiver em branco, o filtro será aplicado somente se o texto contiver a expressão regular inserida. Se ele estiver instalado, clique o botão de navegação apra iniciar o Editor de Expressão Regular do KDE para auxiliá-lo a inserir a expressão regular.</para>
<tip
><para
>Para um melhor desempenho, tente "ancorar" a expressão regular ao início do texto. Em outras palavras, inicie sua expressão regular com <command
><userinput
><![CDATA[^]]></userinput
></command
>.</para
></tip
></callout>
<callout arearefs="pt-talkerchooser-3"
><para
>Se não estiver em branco, o filtro será aplicado somente se o texto vier de um dos aplicativos listados. Você pode inserir mais de um aplicativo separado por vírgulas. Exemplo: <command
><userinput
>knotify,konversation</userinput
></command
></para>
<tip
><para
>Você pode descobrir o <guilabel
>ID do Aplicativo</guilabel
> de programas em execução usando o programa <command
>kdcop</command
>. Você deve deixar o número DCOP fora. Por exemplo, se o kdcop mostra um ID de Aplicativo de <command
>kopete-3432</command
>, você deve apenas inserir <command
><userinput
>kopete</userinput
></command
>.</para
></tip
></callout>
<callout arearefs="pt-talkerchooser-4"
><para
>Especifique os atributos do locutor que deseja que fale o texto aqui. Se o texto corresponder às condições do filtro acima, um locutor será escolhido que corresponda mais precisamente aos atributos especificados aqui. Você pode especificar um idioma clicando neste botão.</para
></callout>
<callout arearefs="pt-talkerchooser-5"
><para
>De modo semelhante, as entradas que fizer aqui também especificarão os atributos do locutor que deseja que fale o texto. Você não precisa especificar todos os atributos.</para
></callout>
<callout arearefs="pt-talkerchooser-6"
><para
>Você pode especificar que um atributo é mais importante que os outros selecionando estas caixas.</para
></callout>
</calloutlist>
</para>
<para
>O filtro Selecionador de Locutor somente se aplicará ao texto se todas as condições não vazias forem atendidas na caixa <guilabel
>Aplicar Este Filtro Quando</guilabel
>.</para>
<para
>O atributo <guilabel
>Idioma</guilabel
> é especial porque o texto ficará provavelmente ininteligível se falado por um locutor que fala um idioma diferente do texto. Assim, o idioma é automaticamente um atributo <guilabel
>preferencial</guilabel
>. Se você especificar um idioma, ele sobreporá o idioma escolhido, mas se você deixar em branco, o idioma já escolhido pelo &kmyapplication; será usado. Se o aplicativo que enviar o texto para o &kmyapplication; não especificar um idioma, o &kmyapplication; atribuirá o idioma do primeiro locutor (o mais acima) configurado na página <guilabel
>Locutores</guilabel
>. Os outros atributos serão sempre sobrepostos. Em outras palavras, se você deixar o atributo <guilabel
>Taxa</guilabel
> em branco, o Selecionador de Locutor encontrará o locutor mais adequado independete da taxa de fala.</para>
<para
>A maneira mais fácil de aprender como configurar os Selecionadores de Locutor é experimentar. Desabilite o Selecionador de Locutor e envie algum texto. Na página <guilabel
>Tarefas</guilabel
>, observe o locutor que o &kmyapplication; seleciona. Habilite o Selecionador de Locutor, insira alguns atributos, e tente novamente para ver como as opções são afetadas. É claro, você deve possuir mais de um locutor configurado para que o Selecionador de Locutor faça alguma coisa.</para>
>Configurando Filtros de Detector de Limite de Frase.</title>
<para
>Filtros de Detector de Limite de Frase (do inglês SBD) quebram o texto em frases individuais. Isto é importante porque</para>
<itemizedlist>
<listitem
><para
>permite ao &kmyapplication; iniciar a fala mais rapidamente porque ele precisa somente sintetizar a primeira frase, ao invés de todo o bloco de texto, que pode ser muito longo, e</para
></listitem>
<listitem
><para
>permite você voltar atrás ou avançar nas frases na página <guilabel
>Tarefas</guilabel
>, e</para
></listitem>
<listitem
><para
>permite você pausar ou parar Tarefas de Texto na página <guilabel
>Tarefas</guilabel
> mesmo que o sintetizador de fala não seja capaz de ser parado.</para
></listitem>
</itemizedlist>
<para
>Por estas razões, o filtro do Detector de Limite de Frase Padrão é automaticamente configurado na primeira vez que você roda o <command
>kttsmgr</command
> e não pode ser desabilitado (apesar de você poder removê-lo). Nós orientamos que não modifique este filtro a menos que saiba o que está fazendo.</para>
<para
>Você pode, no entanto, adicionar filtros BSD adicionais para resolver determinados problemas. Por exemplo, em Fevereiro de 2005, a voz do Polish Festival possui um atributo irritante de fala da pontuação da frase. Ele fala os pontos finais de cada frase, por exemplo. Você não pode resolver este problema criando um filtro Substituidor de Texto para remover a pontuação da frase, porque fazendo isso você impedirá que o SBD Padrão reconheça qualquer frase. Ao invés disso, você pode criar uma versão modificada do SBD Padrão que reconhece a frase enquanto ao mesmo tempo remove a pontuação da frase. Para fazer isto, adicione um filtro SBD e use o botão <guilabel
>Carregar</guilabel
> para carregar o arquivo <filename
>polish_festival_sbdrc</filename
> que vem com o &kmyapplication;.</para>
<para
>Filtros BSD funcionam correspondendo uma expressão regular de fim de frase e inserindo caracteres de tabulação (8 decimal) nos limites das frases. (Todos os cararcteres são automaticamente removidos do texto antes da filtragem iniciar.) Observe que o SBD Padrão preserva a pontuação da frase. </para>
<para
>Filtros SBD nunca são aplicados à mensagens de Notificação do KDE (knotify).</para>
<para
>Se você remover acidentalmente o filtro de Detector de Limite de Frase Padrão, você pode restaurá-lo carregando o arquivo <filename
>O Gerenciador de Texto-para-Voz do KDE (página Interrupção)</phrase>
</textobject>
</mediaobjectco>
</screenshot>
</para>
<para
>Este tela permite-lhe indicar algumas ações especiais a tomar quando uma tarefa de texto for interrompida por outra de maior prioridade. Existem quatro tipos de tarefas de voz com que o &kmyapplication; lida: <itemizedlist>
<listitem
><para
>Texto normal.</para
></listitem>
<listitem
><para
>Mensagens.</para
></listitem>
<listitem
><para
>Avisos.</para
></listitem>
<listitem
><para
>Resultado do Leitor da Tela.</para
></listitem>
</itemizedlist>
</para>
<para
>O Resultado do Leitor da Tela tem a maior prioridade. Ele está reservado para os aplicativos de Leitura da Tela. O Resultado do Leitor faz a preempção de todas as outras mensagens, fazendo com que essas tarefas fiquem em pausa. Logo que o Resultado do Leitor da Tela tenha sido sintetizado, as tarefas anteriores irão prosseguir automaticamente. </para>
<para
>Os avisos são a próxima prioridade mais elevada. Eles estão reservados para as mensagens de alta prioridade, como "o CPU está super-aquecendo". Um aviso irá interromper as mensagens e o texto normal. Logo que o Aviso tenha sido sintetizado, as tarefas anteriores irão prosseguir automaticamente.</para>
<para
>As mensagens são a próxima prioridade. Uma mensagem irá interromper as tarefas de texto normal. O KMouth é um exemplo de um aplicativo que usa as Mensagens. Por exemplo, ao ler um texto longo de uma página Web, o KMouth pode ser usado para cumprimentar alguém que ande pela sala.</para>
<para
>Todos os tipos de tarefas são filas, exceto o Resultado do Leitor da Tela. Se um Resultado do Leitor da Tela for enviado de um aplicativo enquanto o &kmyapplication; estiver falando outro Resultado destes, a mensagem a ser falada é interrompida e eliminada.</para>
<para
>Quando uma tarefa de texto for interrompida por uma Mensagem, Aviso ou Resultado do Leitor da Tela, o &kmyapplication; irá adicionar o resultado de áudio nesta tela à sequência.</para>
<para>
<calloutlist>
<callout arearefs="pt-interruption-1"
><para
>Esta mensagem é falada sempre que uma tarefa de texto normal for interrompida.</para
></callout>
<callout arearefs="pt-interruption-2"
><para
>Este arquivo de áudio é reproduzido sempre que uma tarefa de texto normal for interrompida. Se tanto existir um <guilabel
>Pré-som</guilabel
> como uma <guilabel
>Pré-mensagem</guilabel
>, o <guilabel
>Pré-som</guilabel
> toca primeiro que a <guilabel
>Pré-mensagem</guilabel
>.</para
></callout>
<callout arearefs="pt-interruption-3"
><para
>Esta mensagem é falada sempre que uma tarefa de texto interrompida prosseguir.</para
></callout>
<callout arearefs="pt-interruption-4"
><para
>Este arquivo de áudio é tocado sempre que uma tarefa de texto interrompida prosseguir. Ele é tocado por último.</para
></callout>
</calloutlist>
</para>
<note
><para
>As opções nesta tela aplicam-se apenas às tarefas de texto normal. As Mensagens, Avisos e Resultados do Leitor da Tela não possuem ações especiais quando forem interrompidos por uma mensagem de prioridade mais elevada.</para
>Ao rodar o navegador Web do KDE, o Konqueror, você poderá falar o texto da página Web apresentada. Primeiro, certifique-se de que o &kmyapplication; está rodando. Selecione o texto que deseja falar e escolha a opção <menuchoice
> <guisubmenu
>Ferramentas</guisubmenu
> <guisubmenu
>Falar o Texto</guisubmenu
> </menuchoice
> do menu principal.<action
>Depois de algum tempo, o texto selecionado irá começar a ser falado.</action
> </para>
<tip
><para
>É quase sempre uma boa idéia selecionar o texto na página Web que deseja falar. Você poderá ignorar este passo, mas irá ouvir um conjunto de cabeçalhos de HTML e outras marcas invisíveis.</para
>Ao rodar o Editor de Texto Avançado do KDE, o Kate, poderá falar o texto apresentado. Primeiro, certifique-se de que o &kmyapplication; está rodando. Selecione o texto que deseja falar e escolha a opção <menuchoice
> <guisubmenu
>Ferramentas</guisubmenu
> <guisubmenu
>Falar o Texto</guisubmenu
> </menuchoice
> do menu principal.<action
>Depois de algum tempo, o texto selecionado irá começar a ser falado.</action
> </para>
<tip
><para
>Não precisa selecionar primeiro o texto. Neste caso, o arquivo inteiro será falado.</para
></tip>
<tip
><para
>Isto também funciona quando o Kate estiver embutido em outro aplicativo, como o Konqueror ou o Quanta.</para
>O KNotify é o subsistema de notificações no KDE que o alerta dos eventos que configurar no sistema do KDE. Você poderá configurar o &kmyapplication; para falar as notificações de texto.</para>
<para
>Por exemplo, o Konversation, um aplicativo de IRC para o KDE, permite-lhe configurar uma variedade grande de notificações. Por exemplo, poderá dizer ao Konversation para o notificar sempre que uma mensagem apareça num canal de IRC com o seu nome ou apelido nela. Em conjunto com o &kmyapplication;, poderá fazer com que o KDE fale o texto da mensagem de IRC para você.</para>
<para
>De um modo geral, se um aplicativo do KDE suportar o KNotify, irá aparecer um item de menu <guilabel
>Notificações</guilabel
> no menu de <guilabel
>Configurações</guilabel
>. Os detalhes específicos para configurar cada um dos aplicativos com o KNotify variam de aplicativo para aplicativo.</para>
<para
>Para ativar o &kmyapplication; para falar as notificações de texto do KNofify, inicie o <command
>A Speech Synthesis Markup Language (SSML) é uma norma da W3C para formatar o texto de forma a ser sintetizado. Ele oferece marcas para controlar as vozes, a taxa de voz, volume, sexo e tom. Oferece também marcas para controlar a forma como as palavras são sintetizadas, como por exemplo para soletrar as abreviaturas. O SSML faz parte da especificação VoiceXML, que é também uma norma da W3C.</para>
<para
>Neste momento, o &kmyapplication; oferece um suporte limitado e muito básico para o SSML. Possui atualmente as restrições a seguir.</para>
<itemizedlist>
<listitem
><para
>Funciona apenas com os locutores do Festival Interative e do Hadifix.</para
></listitem>
<listitem
><para
>Você deverá instalar a voz <command
>rab_diphone</command
> (homem britânico), uma vez que esta é a voz que o Festival usa ao sintetizar o SSML.</para
></listitem>
<listitem
><para
>A opção <guilabel
>Velocidade</guilabel
> da tela de <guilabel
>Áudio</guilabel
> é ignorada quando se fala texto que contenha SSML.</para
></listitem>
<listitem
><para
>Se a <guilabel
>Velocidade</guilabel
> ou o <guilabel
>Tom</guilabel
> no diálogo de configuração do Festival não estiverem a 100%, isto poderá fazer com que o texto em SSML seja falado de forma monotônica.</para
></listitem>
</itemizedlist>
<para
>O seguinte texto de exemplo poderá ser usado para experimentar com o SSML.</para>
<programlisting
><![CDATA[
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE speak PUBLIC "-//W3C//DTD SYNTHESIS 1.0//EN"
>O &kmyapplication; possui duas Interfaces de Programação de Aplicativos (APIs): </para>
<itemizedlist>
<listitem
><para
>A API de Texto-para-Voz do KDE, que é usada pelos programadores dos aplicativos para oferecerem aos seus aplicativos capacidades de TTS. Os aplicativos comunicam-se com o KTTSD através de DCOP.</para
></listitem>
<listitem
><para
>A API de Plugins do KTTSD, que é usada para adicionar plugins de síntese de voz ao KTTSD, para que o &kmyapplication; funcione com motores novos de síntese de voz.</para
></listitem>
</itemizedlist>
<para
>A seção a seguir fornece uma breve descrição da API da Interface em DCOP de Texto-para-Voz do KDE. A documentação completa para ambas as APIs está disponível 'online' na <ulink url="http://accessibility.kde.org/developer/kttsd/"
>Os aplicativos comunicam os pedidos de serviços de Texto-para-Voz através da interface de DCOP do KDE para programar o objeto <command
>KSpeech</command
> do <command
>kttsd</command
>. </para>
<para
>Insira os seguintes comandos num Konsole.</para>
<para
>Se o KTTSD não estiver já rodando</para>
<para
><userinput
>kttsd</userinput
></para>
<para
>Para agendar uma tarefa de texto a ser falada</para>
<para
><userinput
>dcop kttsd KSpeech setText "<replaceable
>texto</replaceable
>" "<replaceable
>locutor</replaceable
>"</userinput
></para>
<para
>onde o <userinput
><replaceable
>texto</replaceable
></userinput
> é o texto que pretende ser sintetizado e o <userinput
><replaceable
>locutor</replaceable
></userinput
> é um código de idioma do tipo <userinput
><replaceable
>en</replaceable
></userinput
>, <userinput
><replaceable
>pt_BR</replaceable
></userinput
>, etc. Este comando não fala o texto; simplesmente coloca-o numa fila de tarefas de texto para ser falado.</para>
<para
>Exemplo.</para>
<para
><userinput
>dcop kttsd KSpeech setText "Isto é um teste." "pt_BR"</userinput
></para>
<para
>Para falar a última tarefa de texto que foi posta na fila.</para>
<para
><userinput
>dcop kttsd KSpeech startText <replaceable
>0</replaceable
></userinput
></para>
<para
>Neste caso, o <userinput
>0</userinput
> refere-se à última tarefa de texto na fila. Você poderá também indicar um número de tarefa específico. (Se não for indicado nenhum número, assume-se o <userinput
>0</userinput
>.)</para>
<para
>Para parar a tarefa de texto sendo falada atualmente</para>
<para
><userinput
>dcop kttsd KSpeech stopText 0</userinput
></para>
<para
>Dependendo do plugin de voz usado, a síntese poderá não parar imediatamente.</para>
<para
>Existem muitos mais comandos que poderão ser enviados. Para ver uma lista dos comandos possíveis,</para>
<para
><userinput
>dcop kttsd KSpeech</userinput
></para>
<para
>ou leia a <ulink url="http://accessibility.kde.org/developer/kttsd/"
> para adicionar a voz nova. Os outros itens poderão ser usados como um guia. Se adicionar com sucesso uma voz, envie por favor uma correção para os programadores, em conjunto com o URL de onde obteve o arquivo de voz.</para>
</answer>
</qandaentry>
<qandaentry>
<question>
<para
>Nenhum dos sintetizadores de voz suportados possui o idioma que eu necessito. Onde poderei obter um sintetizador para o meu idioma?</para>
</question>
<answer>
<para
>O Google(tm) é seu amigo. Esta <ulink url="http://tcts.fpms.ac.be/synthesis/mbrola/mbrtts.html"
>referência</ulink
> também poderá ajudar. Se descobrir um motor aberto que suporte o seu idioma desejado e quiser adicionar o suporte para ele no &kmyapplication;, por favor contacte a equipe de desenvolvimento. Os motores abertos são especialmente bem-vindos. Se conhecer algum sintetizador comercial, talvez consiga persuadir o distribuidor a doar uma cópia gratuita à equipe de desenvolvimento do &kmyapplication;. Entretanto, você poderá conseguir colocar o sintetizador funcionando com o plugin do <guilabel
>Os motores de síntese de voz usados pelo &kmyapplication; possuem as suas próprias licenças. Veja a documentação de cada motor ou a sua página na Web para mais detalhes.</para
>Você poderá encontrar algumas referências para os pacotes de código e binários na págiana Web de <ulink url="http://accessibility.kde.org/developer/kttsd/"
>Acessibilidade do KDE</ulink
> (http://accessibility.kde.org).</para>
<para
>Se tiver acesso ao CVS do KDE, você poderá obter o &kmyapplication; através do módulo <command
>Funciona também com qualquer motor de síntese que possa ser executado com um comando num Konsole.</para>
<note
><para
>Os idiomas indicados acima poderão não ser compreensíveis ou estar desatualizados. Veja as especificações de cada motor para uma lista completa dos idiomas suportados. </para
></note>
<note>
<para
>O &kmyapplication; usa uma arquitetura de plugins flexível para os motores de síntese de voz. Se quiser melhorar o &kmyapplication; de modo a suportar outro motor, contacte a equipe de desenvolvimento. </para>
</note>
<para
>Veja em <xref linkend="configuration"/> as instruções específicas para cada um destes motores. </para>
</listitem>
</itemizedlist>
</para>
<para
>Componentes opcionais:</para>
<para>
<itemizedlist>
<listitem>
<para
>O utilitário de áudio <command
>sox</command
> é necessário para ajustar a velocidade global da voz, mas não é necessário. Os usuários de Debian poderão instalar o 'sox' com o comando <command
>apt-get install sox</command
>. O Sox vem incluído na maioria dos CDs de distribuições de &Linux;.</para>
</listitem>
<listitem>
<para
>O utilitário <command
>xsltproc</command
> é necessário para o suporte de SSML e para o filtro Transformador XML, mas não é obrigatório. Os usuários de Debian poderão instalar o 'xsltproc' com o comando <command
>apt-get install xsltproc</command
>.</para>
</listitem>
<listitem>
<para
>GStreamer versão 0.8.7 ou posterior. Por padrão, o &kmyapplication; usa o aRts para a saída de áudio, mas se instalar o GStreamer, você poderá usá-lo em alternativa. Poderá obter o GStreamer em </para>
>Para compilar o &kmyapplication;, você deve possuir uma cópia recente (KDE 3.4 ou superior) dos arquivos de desenvolvimento do KDE, incluindo o tdelibs e arts.</para>
>Se você obteve o &kmyapplication; como um pacote TAR, logue-se como um usuário normal e descomprima o pacote para uma pasta adequada, entre nesta e introduza os seguintes comandos.</para>
<programlisting
>./configure
make
</programlisting>
<para
>Se você possuir os arquivos de desenvolvimento do GStreamer 0.8.7 ou superior instalados, e desejar compilar o &kmyapplication; com suporte ao GStreamer, insira o seguinte comando em substituição.</para>
<programlisting
>./configure --enable-kttsd-gstreamer
make
</programlisting>
<para
>Por padrão, os comandos acima irão instalar o &kmyapplication; em <filename
>/opt/kde3</filename
>. Se esta pasta não estiver não estiver na sua variável $<envar
>Certifique-se de que o seu motor de síntese de voz está funcionando antes de usar o &kmyapplication;. Siga as instruções que vieram com o motor.</para>
<tip>
<para
>Em alguns casos, é necessário dar acesso de escrita ao dispositivo de áudio.</para>
>O Festival é um dos melhores motores de TTS gratuitos e abertos que se encontram disponíveis. A qualidade da voz é geralmente boa, existem alguns idiomas e vozes suportadas e você poderá controlar a voz, a velocidade do texto gerado e o tom no &kmyapplication;.</para>
>Você deverá, contudo, compilar um módulo adicional para estas vozes, sendo necessário para isso o código-fonte do Festival. As vozes em alemão possuem uma distribuição limitada. </para>
<para
>Está disponível uma voz masculina em finlandês em </para>
>O Festival pode ser usado em conjunto com o sintetizador &mbrola;. Neste modo, o Festival faz a análise léxica e o &mbrola; produz o áudio. O executável &mbrola; e os arquivos de vozes do &mbrola; podem ser obtidos em</para>
<para
><ulink url="http://festvox.org/mbrola/"
>http://festvox.org/mbrola/</ulink
>.</para>
<para
>Siga as instruções no <filename
>readme.txt</filename
> que vem com o pacote obtido.</para>
<para
>Repare que o &mbrola; não é um sistema de Texto-para-Voz completo. O &mbrola; sintetiza a voz a partir de arquivos de difonemas. Você deverá ter um 'software' adicional que possa produzir os difonemas. Ao ser combinado com o Festival, o Festival produz os difonemas necessários para o &mbrola;. O <command
>txt2pho</command
> poderá também ser usado para produzir difonemas a partir de texto em alemão. Veja <xref linkend="using-with-hadifix"/> para mais informações.</para>
<para
>Existem três métodos para combinar o Festival com o &mbrola;.</para>
<para>
<itemizedlist>
<listitem
><para
><link linkend="mbrola-wrappers"
>Interfaces do &mbrola;</link
>. No momento em que este manual foi escrito, este método estava limitado a vozes em Inglês.</para
>Usando o Festival com as Interfaces do &mbrola;</title>
<para
>Neste método, o código adicional das interfaces é adicionado ao Festival para ativar a síntese de voz com os arquivos de vozes do &mbrola;. Lembre-se que os arquivos de vozes do &mbrola; <emphasis
>não</emphasis
> são instalados na árvore de pastas do &mbrola;. Em vez disso, são instalados na árvore de pastas <filename
>O IMS German Festival é uma versão modificada do Festival que usa as vozes em alemão do &mbrola;. Funciona tanto com o Festival versão 1.4.1 como com o Festival 2.0 (1.95beta). Instale primeiro o Festival e o &mbrola;, se não tiver já feito isso. Depois, obtenha o IMS German Festival em</para>
>Este método usa algum código especial para ativar a síntese de voz no Festival com uma voz do &mbrola; em tcheco. Para instalar, obtenha primeiro, instale o Festival e o &mbrola; e certifique-se que ambos funcionam. Depois, obtenha o Festival-Czech em</para>
>O Festival Lite é um motor gratuito e aberto que suporta atualmente um número limitado de vozes e idiomas. É leve, mas sacrifica de certa forma a qualidade da voz. Não pode controlar o tom, o volume ou a velocidade deste motor no &kmyapplication;.</para>
>Usando com o Hadifix (&mbrola; e txt2pho)</title>
<para
>O Hadifix é um motor de síntese de voz baseado em difonemas. O utilitário <command
>txt2pho</command
> converte o texto é difonemas e o motor &mbrola; sintetiza os difonemas a reproduzir. A qualidade da voz é boa, mas o suporte do idioma está atualmente ligeiramente limitado. Você poderá controlar a voz, o tom, a velocidade e o volume no <application
>kttsmgr</application
>. </para>
<para
>Nome do Sintetizador: <guilabel
>Hadifix</guilabel
></para>
<para
>URL: ver abaixo</para>
<para
>Comando de Instalação da Debian: nenhum</para>
<para
>Se não tiver já o Hadifix instalado, faça o seguinte:</para>
<procedure>
<step
><para
>Obtenha o executável do MBROLA em <ulink url="http://festvox.org/mbrola/"
> http://festvox.org/mbrola/</ulink
>.</para
></step>
<step
><para
>Instale o &mbrola; na pasta <filename
>/usr/local/mbrola</filename
>.</para
></step>
<step
><para
>Obtenha pelo menos um arquivo de idioma (alemão, por exemplo), na página do &mbrola;. Descomprima na pasta <filename
>O Epos é um motor aberto e gratuito para Tcheco e Eslovaco. É leve, mas sacrifica de certa forma a qualidade da voz. Você não poderá controlar o tom, o volume ou a velocidade deste motor no &kmyapplication;.</para>
<para
>Nome do Sintetizador: <guilabel
>Epos TTS Synthesis System</guilabel
></para>
<para
>URL: <ulink url="http://epos.ure.cas.cz/"
> http://epos.ure.cas.cz/</ulink
> </para>
<para
>Comando de Instalação da Debian: <userinput
>apt-get install epos</userinput
></para>
<para
>Inicie o <application
>kttsmgr</application
>. Na página de <guilabel
>Locutores</guilabel
>, clique no botão <guilabel
>Adicionar</guilabel
>. Escolha o idioma Tcheco ou Eslovaco e o <guilabel
>Epos TTS Synthesis System</guilabel
>. Se o executável do servidor do Epos e o cliente não estiverem na sua <envar
>PATH</envar
>, indique a localização destes executáveis na tela para <guilabel
>Configurar o Locutor</guilabel
>. As opções permitem-lhe passar argumentos adicionais ao cliente e ao servidor. Num <application
>O FreeTTS é um motor de voz aberto e gratuito feito em Java(tm), o que significa que você precisa de ter a máquina virtual de Java instalada no seu sistema para a usar. Atualmente, tem um suporte de vozes e idiomas limitado. Você não pode controlar o tom, o volume ou a velocidade deste motor no &kmyapplication;.</para>
>O plugin do comando permite-lhe usar o &kmyapplication; com qualquer motor de síntese de voz que possa ser executado como um comando num <application
>Konsole</application
>.</para>
<para
>Nome do Sintetizador: <guilabel
>Comando</guilabel
></para>
<para
>URL: nenhum</para>
<para
>Comando de Instalação da Debian: nenhum</para>
<para
>Idealmente, deverá usar um comando que sintetize para um arquivo de áudio temporário (WAV), em vez de enviar a voz diretamente para o dispositivo de áudio.</para>
<para
>Se o motor do sintetizador de fala precisar que o texto seja codificado de maneira diferente da configuração de codificação do seu ambiente de trabalho, você deve usar o parâmetro <command
>%f</command
> para passar o texto para o motor. O &kmyapplication; codificará o texto na configuração que você especificou quando ele escreveu o texto para o arquivo temporário. Se você passar o texto na linha de comando usando o parâmetro <command
>%t</command
>, ele será codificado usando a configuração local do seu ambiente. Você pode também usar a opção <guilabel
>Enviar os dados como entrada padrão</guilabel
> para resolver este problema, se o motor aceitar entrada de StdIn. Por exemplo, aqui está um comando exemplo para enviar um texto em polonês para o Festival usando a codificação ISO 8859-2 e removendo a fala dos caracteres de pontuação.</para>