<para>&ktts;, &kde;'s tekst-til-tale system. er en plugin-baseret tjeneste som lader et hvilket somhelst &kde;-program (eller andet program) kunne tale via en &DCOP;-grænseflade. </para>
<para>&ktts; er et delsystem i &kde; til at oprette tekst-til-tale (TTS). Det sørger for en fælles programmeringsgrænseflade for &kde;-programmører som giver mulighed for at bruge tekst-til-tale i deres programmer. Det sørger også for nogle gode funktioner for slutbrugere.</para>
<listitem><para>Læs indholdet i en tekstfil op.</para></listitem>
<listitem><para>Læs &kde;'s meddelelsesbegivenheder op (Knotify).</para></listitem>
<listitem><para>Læs hele eller dele af teksten på en netside i &konqueror; op.</para></listitem>
<listitem><para>Læs hele eller dele af teksten i &kate; teksteditoren op, inklusive tilfælde hvor &kate; er indlejret i et andet &kde;-program.</para></listitem>
<listitem><para>Lang tekst tolkes til sætninger. Brugeren kan gå en sætning tilbage eller en paragraf, læse op igen, holde pause og stoppe oplæsning.</para></listitem>
<listitem><para>Lyd via &arts;, ALSA eller Gstreamer (version 0.8.7 eller senere) eller aKode.</para></listitem>
<listitem><para>Filter som kan indstilles af brugeren til at erstatte forkert udtalte ord, vælge talesyntese og transformere XHTML/&XML;-dokumenter.</para></listitem>
<listitem><para>Prioriteringssystem for oplæsning af skærmudskrift, advarsler og meddelelser, mens oplæsning af almindelig tekst foregår.</para></listitem>
<listitem><para>Arkitektur baseret på plugin med understøttelse for et stort antal forskellige talesynteseprogrammer og drivere.</para></listitem>
<listitem><para>Tillader at generere tale fra kommandolinjen (eller via skalscript) med &kde;'s &DCOP;-redskaber.</para></listitem>
<listitem><para>Sørger for let og letanvendelig grænseflade for programmer at oprette tale.</para></listitem>
<listitem><para>Programmer behøver ikke at bekymre sig om konflikter over oplæsningsenheden.</para></listitem>
<listitem><para>FREMTIDIGT: Sørger for understøttelse for talemarkeringssprog, såsom VoiceXML, Sable, &Java; Speech Markup Language (JSML), og Speech Markup Meta-language (SMML).</para></listitem>
<listitem><para>FREMTIDIGT: Sørger for begrænset understøttelse for indlejrede talemarkører.</para></listitem>
<listitem><para>Asynkront for at forhindre at systemet blokeres.</para></listitem>
<listitem><para>&kde;'s tekst-til-tale dæmon, som er et program uden grafisk grænseflade som sørger for tekst-til-tale tjenester for programmer via DCOP. </para></listitem></varlistentry>
<listitem><para>Et grafisk program for til at indstille og styre kttsd. Programmet kttsmgr er placeret i statusfeltet. </para></listitem></varlistentry>
<listitem><para>Et plugin- for browseren &konqueror; som tillader at hele eller dele af teksten på en netside læses op. </para></listitem></varlistentry>
<para>Udover &kde;'s Bugzilla database ( <ulink url="http://bugs.kde.org/">http://bugs.kde.org/</ulink> ), finder diskussioner om &ktts; for øjeblikket sted i kde-accessibility's e-mail-liste. Abonnér på <ulink url="https://mail.kde.org/mailman/listinfo/kde-accessibility"> https://mail.kde.org/mailman/listinfo/kde-accessibility</ulink>. Udviklerne er også ofte på IRC (irc.kde.org, kanalen #kde-accessibility). </para>
<warning><para>Før du kan bruge &ktts; skal du installere mindst et talesynteseprogram og sikre dig at det fungerer. Se <xref linkend="installation"/>. </para></warning></para>
<para>For at starte &ktts;-systemet, skrives følgende kommando i en terminal </para>
<para><userinput>kttsmgr</userinput></para>
<para>eller klik på kttsmgr i &kde;'s menu.</para>
<para>Hvis dette er første gang <command>kttsmgr</command> køres, eller hvis du endnu ikke har indstillet nogen oplæser, vises siden <guilabel>Oplæsere</guilabel>. Se <xref linkend="configure-plugin"/>. Hvis du allerede har indstillet in mindst en oplæser, vises siden <guilabel>Generelt</guilabel>. Se <xref linkend="general"/>.</para>
<title>Indstil plugin for syntese (Oplæser)</title>
<para>De fleste programmer for tekst-til-talesyntese (TTS) tilbyder flere sprog og stemmer, og kan tilbyde flere oplæsere med forskellige køn, lydstyrke og hastigheder. Du kan indstille mere end en udgave af syntesen. Hver kombination af sprog, syntese, stemme, køn, lydstyrke og hastighed kaldes en oplæser. Du skal indstille mindst en oplæser inden du kan starte &ktts; og begynde læse tekst op.</para>
<note><para>Flere oplæsere med samme synteseprogram ligner flere printerkøer for en enkelt fysisk printer.</para></note>
<para>Når programmer sender tekst til &ktts;, kan de angive egenskaber hos oplæseren de foretrækker for at udføre syntesen. Et program kan for eksempel bede om en engelsksproget kvindelig oplæser. Hvis du har indstiller en oplæser som både er engelsksproget og kvindelig bruges denne oplæser, ellers vælges oplæseren som bedst passer ind automatisk. For at lære dig mere om hvordan &ktts; vælger oplæsere, se <xref linkend="filters"/>.</para>
<para>Når du klikker på fanebladet <guilabel>Oplæser</guilabel> i <command>kttsmgr</command>, vises siden <guilabel>Oplæser</guilabel>. Siden vises også automatisk hvis du starter <guilabel>kttsmgr</guilabel> og endnu ikke har indstillet nogen oplæsere.</para>
<callout arearefs="pt-talker-1"><para>Klik for at tilføje en ny oplæser.</para></callout>
<callout arearefs="pt-talker-2"><para>Alle indstillede <guilabel>Oplæsere</guilabel> er på denne liste. <guilabel>Oplæsere</guilabel> med højest prioritet er øverst på listen. Den øverste oplæser bruges til at udføre oplæsningen når et program ikke angiver en oplæser.</para></callout>
<callout arearefs="pt-talker-3"><para>Klik på en oplæser i listen for at markere den, og klik på denne knap for at fjerne den.</para></callout>
<callout arearefs="pt-talker-4"><para>Klik på en oplæser i listen for at markere den, og klik på denne knap for at vise syntese-plugins indstillingsdialog. Se nedenfor.</para></callout>
<callout arearefs="pt-talker-5"><para>Klik på en oplæser i listen for at markere den, og klik på denne knappen for at flytte den nedad i listen. Jo lavere en oplæser vises i listen, jo lavere er dens prioritering.</para></callout>
<callout arearefs="pt-talker-6"><para>Klik på en af disse knapper for at anvende de ændringer du har lavet i &ktts;-systemet som kører.</para></callout>
<callout arearefs="pt-addtalker-1"><para>Du kan vælge et plugin- for talesyntese enten med navnet på en <guilabel>Talesyntese</guilabel>, eller efter <guilabel>Sprog</guilabel> som talesyntesen kan læse op. Markér radioknappen ved siden af det tilsvarende felt. Når radioknappen <guilabel>Sprog</guilabel> er markeret, viser feltet <guilabel>Sprog</guilabel> alle sprog som understøttes af alle tilgængelige talesyntesprogrammer, og feltet <guilabel>Talesyntese</guilabel> viser kun de talesynteseprogrammer som understøtter det valgte sprog. Når radioknappen <guilabel>Talesyntese</guilabel> er markeret, viser feltet <guilabel>Talesyntese</guilabel> alle tilgængelige talesynteseprogrammer, og feltet <guilabel>Sprog</guilabel> viser kun de sprog som understøttes af det valgte talesynteseprogram.</para></callout>
<callout arearefs="pt-addtalker-2"><para>Vælg sprog og plugin- for syntese her.</para></callout>
<callout arearefs="pt-addtalker-3"><para>Når du klikker her, indstiller de fleste plugin- for talesyntese sig selv automatisk, og vælger en standardindstilling. En ny oplæser> vises i listen under skærmen <guilabel>Oplæsere</guilabel>. Klik på knappen <guibutton>Redigér</guibutton> for at vise eller redigere indstillingen for oplæseren.</para></callout>
<para>Når du klikker på knappen <guibutton>Tilføj</guibutton> i fanebladet <guilabel>Oplæsere</guilabel> og tilføjer en Oplæser, eller klikker på knappen <guibutton>Redigér</guibutton>, vises skærmen <guilabel>Indstilling af Oplæser</guilabel>. Hver plugin for talesyntese har en egen skærm for <guilabel>Indstilling af oplæser</guilabel>. Følgende er et eksempel på indstilling af plugin for interaktiv Festival. For specifikke måder at indstille hvert plugin, se <xref linkend="configuration"/>.</para>
<callout arearefs="pt-prop-1"><para>Angiv søgestien til det kørbare Festival-program. Hvis Festival findes i miljøvariablen PATH, så skriv blot <userinput><replaceable>festival</replaceable></userinput>.</para></callout>
<callout arearefs="pt-prop-2"><para>Klik for at søge efter tilgængelige stemmer.</para></callout>
<callout arearefs="pt-prop-3"><para>Vælg en stemme.</para></callout>
<callout arearefs="pt-prop-4"><para>Vælg et tegnsæt for tekst som sendes til Festival. For stemmer som &ktts; kender til, vælges indstillingen automatisk for dig. I almindelighed bruger vestlige sprog ISO 8859-1. Østeuropæiske sprog såsom tjekkisk eller slovakisk bruger ISO 8859-2.</para></callout>
<callout arearefs="pt-prop-5"><para>Klik for at teste. Du skal høre en testsætning blive læst op.</para></callout>
<callout arearefs="pt-prop-6"><para>Brug skyderne til at indstille den syntetiserede tales lydstyrke, talehastighed og tonehøjde. Hvis nogen af dem er deaktiverede (grå), understøtter den valgte stemme ikke at ændre dem.</para></callout>
<callout arearefs="pt-prop-7"><para>Visse stemmer, såsom MultiSyn-stemmer, er så store at de kræver flere sekunder om at indlæses. Markeres dette felt indlæses de når KTTSD startes, og på den måde spares gemmes tid (på bekostning af brug af mere hukommelse) inden den første sætning syntetiseres.</para></callout>
<para>Klik på knappen <guibutton>O.k.</guibutton> for at gemme Oplæserens indstillinger.</para>
<warning><para>Sørg for at klikke på knappen <guibutton>Anvend</guibutton>, ellers får dine ændringer ingen effekt i &ktts;-systemet som kører. </para></warning>
<para>Under antagelse af at testen fungerede, er du næsten klar til at begynde at bruge &ktts;. Gå nu tilbage til fanebladet <guilabel>Generelt</guilabel> og markér feltet <guilabel>Aktivér tekst-til-tale systemet (KTTSD)</guilabel>. Det starter &kde;'s tekst-til-tale dæmon. Se <xref linkend="general"/>. Du kan nu begynde at bruge &ktts; til at læse tekst op. Klik på fanebladet <guilabel>Job</guilabel> for at oprette og håndtere tekstjob. Se <xref linkend="jobmgr"/>. </para>
<para>Når du har indstillet mindst en Oplæser, kan du starte &kde;'s tekst-til-tale system. Klik på fanebladet <guilabel>Generelt</guilabel>. Så vises siden <guilabel>Generelt</guilabel>. Du kan også indstille nogle generelle tilvalg på denne side. </para>
<callout arearefs="pt-gen-1"><para>Markér dette felt for at aktivere &ktts;-systemet. Det starter &kde;'s tekst-til-tale dæmon (KTTSD). Hvis det lykkes at starte KTTSD, vises fanebladet <guilabel>Job</guilabel>. Når KTTSD er startet, kan du begynde at oprette og læse tekstjob op. Se <xref linkend="jobmgr"/>. Afmarkeres feltet, stoppes KTTSD og &kde;'s tekst-til-tale system deaktiveres. <note><para>Hvis dette felt er deaktiveret, har du endnu ikke indstillet nogen Oplæser (eller også glemte du at klikke på knappen <guibutton>Anvend</guibutton>). Se <xref linkend="configure-plugin"/>.</para></note>
</para></callout>
<callout arearefs="pt-gen-2"><para>Når dette felt er markeret, vises en ikon i statusfeltet så snart <command>kttsmgr</command> kører. Klikkes på <guibutton>Afbryd</guibutton> eller <guibutton>O.k.</guibutton> i denne tilstand, afsluttes <command>kttsmgr</command> ikke. I stedet forsvinder skærmen, men <command>kttsmgr</command> fortsætter med at køre i statusfeltet. Klik på ikonen for at genoprette skærmen. For at afslutte <command>kttsmgr</command>, højreklikkes på ikonen i statusfeltet og <guilabel>Afslut</guilabel> vælges. Når feltet ikke er markeret, vises ikke nogen ikon i statusfeltet. Klikkes på <guibutton>O.k.</guibutton> eller <guibutton>Afbryd</guibutton> afsluttes <command>kttsmgr</command>. <note><para>Når kommandoen <command>kttsmgr</command> afsluttes, fortsætter &ktts; med at køre hvis feltet <guilabel>Aktivér tekst-til-tale (KTTSD)</guilabel> er markeret.</para></note>
<note><para>Dette tilvalg får ingen effekt før næste gang <command>kttsmgr</command> startes.</para></note>
<note><para>Dette tilvalg har ingen effekt når <command>kttsmgr</command> kører i &kde;'s kontrolcenter.</para></note>
</para></callout>
<callout arearefs="pt-gen-3"><para>Når dette felt er markeret, vises skærmen for <command>kttsmgr</command> når du starter <command>kttsmgr</command>. Hvis den ikke er markeret vises ikonen for <command>kttsmgr</command> i statusfeltet når <command>kttsmgr</command> startes, men skærmen vises ikke. Klik på ikonen i statusfeltet for at få skærmen til at blive vist.</para></callout>
<callout arearefs="pt-gen-4"><para>Når feltet er markeret, og <command>kttsmgr</command> ikke allerede kører, vises det i statusfeltet så snart KTTSD læser noget op. Det giver dig mulighed for at stoppe eller på anden måde håndtere oplæsningen.</para></callout>
<callout arearefs="pt-gen-5"><para>Når feltet er markeret, og <command>kttsmgr</command> automatisk vises i statusfeltet så snart oplæsning sker, forsvinder det også automatisk når oplæsningen er færdig.</para></callout>
<callout arearefs="pt-gen-6"><para>Sørg for at klikke her for at gemme dine indstillinger.</para></callout>
<callout arearefs="pt-jobmgr-1"><para>Alle tekstjob som for øjeblikket findes i køen listes her, sammen med programmet som satte jobbet i kø, jobbets nuværende tilstand, antal sætninger i jobbet, og det nuværende meddelelsenummer. <guilabel>Oplæserens identifikation</guilabel> svarer til søjlen <guilabel>Id</guilabel> på siden <guilabel>Oplæser</guilabel>. </para></callout>
<callout arearefs="pt-jobmgr-2"><para>Knapperne i denne linje lader dig starte, fjerne og holde pause i oplæsningsjob. Vælg et job i listen nedenfor, og klik på en af knapperne.</para></callout>
<callout arearefs="pt-jobmgr-3"><para>Knapperne i denne linje lader dig gå en sætning frem eller tilbage i jobbet som er markeret i listen ovenfor. (Ikke alle job har flere dele.)</para></callout>
<callout arearefs="pt-jobmgr-4"><para>Knapperne i denne linje lader dig læse teksten op som for øjeblikket findes på &kde;'s klippebord, eller åbne en tekstfil som skal læses op. Du kan også opdatere listen med tekstjob. Se <xref linkend="selecttalker"/>.</para></callout>
<callout arearefs="pt-jobmgr-5"><para>Sætningen som for øjeblikket læses op vises her.</para></callout>
<callout arearefs="pt-jobmgr-6"><para>Når du klikker på <guibutton>O.k.</guibutton> anvendes alle ændringer af indstillinger på andre sider (hvis der er nogen) og <command>kttsmgr</command> minimeres til statusfeltet. Klik på ikonen i statusfeltet for at genoprette skærmen.</para></callout>
<callout arearefs="pt-jobmgr-7"><para>Træk i opdeleren for at ændre størrelse på joblisten og feltet <guilabel>Nuværende sætning</guilabel>.</para></callout>
<note><para>Fanebladet <guilabel>Job</guilabel> vises kun når KTTSD kører. Hvis du ikke ser fanebladet <guilabel>Job</guilabel>, så klik på fanebladet <guilabel>Generelt</guilabel> og markér feltet <guilabel>Aktivér tekst-til-tale (KTTSD)</guilabel>.</para>
<note><para>Hvis du ikke har installeret lydsystemet &arts;, men har installeret ALSA, Gstreamer eller aKode, så klik på fanebladet <guilabel>Lyd</guilabel>. Se <xref linkend="audio"/>.</para></note>
<note><para>På denne side listes og styres kun tekstjob. Skærmlæsningsudskrift, advarsler og meddelelser vises ikke. For mere information om meddelelsetyper i &ktts;, se <xref linkend="filters"/>.</para></note>
<callout arearefs="pt-audio-1"><para>Vælg lydmetode her. Hvis en komponent er grå, kompileredes enten &ktts; uden støtte for dette lyd-plugin, eller også kunne &ktts; ikke indlæse nødvendige biblioteker. </para></callout>
<callout arearefs="pt-audio-2"><para>Hvis Gstreamer eller aKode er valgt for lyd, vælges metoden for lydsink-metoden her. Hvis ingen sink angives, skal du installere mindst én. Hvis ALSA vælges, skal PCM-enheden vælges her. Se <xref linkend="requirements"/>. </para></callout>
<callout arearefs="pt-audio-3"><para>Justér oplæsningens hastighed. 50 % er cirka dobbelt så langsomt som normalt, mens 200 % er cirka dobbelt så hurtigt. Du skal have <command>sox</command>-redskabet installeret for at denne indstilling skal virke. </para></callout>
<callout arearefs="pt-audio-4"><para>Når dette felt er markeret, kopierer &ktts; midlertidige lydfiler (.wav-filer) til angivet mappe. Vælg hvilken den mappe på harddisken du vil, men du skal kunne skrive i den. Dette kan være nyttigt for at oprette lydfiler med tale for andre formål. Filerne får navn på formen <filename>kttsd-J-M</filename>, hvor <filename>J</filename> er jobnummeret og <filename>M</filename> er sætningsnumret. Eksisterende filer med samme navn fjernes. <emphasis>Glem ikke at afmarkere feltet, ellers fyldes harddisken op</emphasis>. </para></callout>
<callout arearefs="pt-audio-5"><para>Sørg for at klikke på knappen <guibutton>Anvend</guibutton>, for at bruge de nye indstillinger i &ktts;-systemet som kører. </para></callout>
<note><para>Der er to måder at justere talehastigheden i &ktts;. Mange af <guilabel>Oplæserne</guilabel> har indstillingen <guilabel>Hastighed</guilabel> i deres indstillingsdialoger, som du kan vise ved at klikke på <guibutton>Redigér</guibutton> på siden <guilabel>Oplæsere</guilabel>. Indstillingen <guilabel>Hastighed</guilabel> på siden <guilabel>Lyd</guilabel> er der udover oplæserens hastighedsindstilling, og kan i almindelighed bruges også selvom oplæseren ikke understøtter en hastighedsindstilling. For at denne hastighedsindstilling skal fungere, skal du have installeret værktøjet <command>sox</command> på systemet (Debian-brugere: <command>apt-get install sox</command>). Desuden ignoreres hastighedsindstillingen når tekst som indeholder SSML læses op (se <xref linkend="ssml"/>).</para></note>
<note><para>Listen med ALSA-enheder omfatter alle ALSA PCM-enheder og plugin som er indstillede i systemet. Mange af valgene virker ikke. Du skal eksperimentere for at finde en enhed som virker for dig. Hvis du er i tvivl, så vælg <guilabel>default</guilabel>.</para></note>
<para>Denne side lader dig angive specielle handlinger som skal udføres så snart et tekstjob afbrydes af en anden meddelelse med højere prioritet. Der er fire slags talejob som &ktts; håndterer: <itemizedlist>
<para>Skærmlæsningsudskrift har højest prioritering. Den er reserveret til brug af skærmlæsningsprogrammer. Skærmlæsningsudskrift går før alle andre meddelelser, og holder pause i disse job. Så snart skærmlæsningsudskriften er læst op, genoptages jobbet som blev afbrudt automatisk. </para>
<para>Advarsler har følgende prioritering. De er reserverede for meddelelser med høj prioritet, såsom "Processoren er for varm". En advarsel afbryder meddelelser og almindelig tekst, og holder pause i disse job. Så snart advarslen er læst op, genoptages jobbet som blev afbrudt automatisk.</para>
<para>Meddelelser har følgende prioritering. En meddelelse afbryder almindelige tekstjob. &kmouth; er et eksempel på et program somanvender meddelelser. For eksempel, mens en lang tekst fra en netside læses op, kan &kmouth; bruges til at hilse på nogen som kommer ind i rummet.</para>
<para>Alle fire slags job har køer, undtagen skærmlæsningsudskrift. Hvis en skærmlæsningsudskrift sendes fra et program mens &ktts; læser en anden skærmlæsningsudskrift op, stoppes meddelelsen som er ved at blive læst op og smides væk.</para>
<para>Når et tekstjob afbrydes af en meddelelse, en advarsel eller en skærmlæsningsudskrift, tilføjer &ktts; lydudskriften på denne side til strømmen.</para>
<callout arearefs="pt-interruption-1"><para>Denne meddelelse læses op så snart et almindeligt tekstjob afbrydes.</para></callout>
<callout arearefs="pt-interruption-2"><para>Denne lydfil afspilles så snart et almindeligt tekstjob afbrydes. Hvis både <guilabel>Indledende lyd</guilabel> og <guilabel>Inden meddelelsen</guilabel> er angivne, afspilles <guilabel>Indledende lyd</guilabel> inden <guilabel>Inden meddelelsen</guilabel> læses op.</para></callout>
<callout arearefs="pt-interruption-3"><para>Denne meddelelse læses op så snart et afbrudt tekstjob genoptages.</para></callout>
<callout arearefs="pt-interruption-4"><para>Denne lydfil afspilles så snart et afbrudt tekstjob genoptages. Den afspilles sidst.</para></callout>
<note><para>Indstillingerne på denne side gælder kun almindelige tekstjob. Meddelelser, advarsler eller skærmlæsningsudskrifter har ingen særlige handlinger når de afbrydes af en meddelelse med højere prioritering.</para></note>
<para>Når du kører &kde;'s browser &konqueror;, kan du læse teksten op for netsiden som vises. Sørg først for at &ktts; kører. Markér teksten du vil læse op, og vælg <menuchoice><guisubmenu>Værktøjer</guisubmenu> <guisubmenu>Læs tekst op</guisubmenu></menuchoice> i hovedmenuen. <action>Efter et øjeblik, skulle den markerede teksten begynde at blive læst op.</action> </para>
<tip><para>Det er næsten altid en god idé at markere teksten på netsiden som du vil skal læses op. Du kan springe over dette skridt, men så hører du en mængde &HTML;-hoveder og andre usynlige mærker blive læst op.</para></tip>
<para>Når du kører &kde;'s avancerede teksteditor (&kate;), kan du læse teksten op som vises. Sørg først for at &ktts; kører. Markér teksten du vil læse op, og vælg <menuchoice><guisubmenu>Værktøjer</guisubmenu> <guisubmenu>Læs tekst op</guisubmenu></menuchoice> i hovedmenuen. <action>Efter et øjeblik, skulle den markerede tekst begynde at blive læst op.</action> </para>
<tip><para>Du behøver ikke først at markere tekst. I dette tilfælde, læses hele filen op.</para></tip>
<tip><para>Dette fungerer også når &kate; kører indlejret i et andet program, såsom &konqueror; eller &quanta;.</para></tip>
<para>Knotify er meddelelsesystemet i &kde;, som gør dig opmærksom på begivenheder som du indstiller i &kde;-systemet. Du kan indstille &ktts; til at læse tekstmeddelelser op.</para>
<para>For eksempel tillader &konversation;, et IRC-program for &kde;, dig at indstille et stort sæt meddelelser. Du kan for eksempel bede &konversation; om at underrette dig så snart en meddelelse hvor dit alias indgår dukker op i en IRC-kanal. Sammen med &ktts;, kan du lade &kde; læse IRC-meddelelsens tekst op.</para>
<para>I almindelighed, hvis et &kde;-program understøtter , <guilabel>Bekendtgørelser</guilabel> vises menupunktet <guilabel>Indstil meddelelser</guilabel> i menuen <guilabel>Indstillinger</guilabel>. De specifikke måder at indstille hvert program for Knotify varierer fra program til program.</para>
<para>For at gøre det muligt for &ktts; at læse tekstmeddelelser op fra Knotify, start <command>kttsmgr</command> og klik på fanebladet <guilabel>Bekendtgørelser</guilabel>. Så kommer skærmen <guilabel>Bekendtgørelser</guilabel> frem.</para>
<callout arearefs="pt-notify-1"><para>Markér dette felt for at aktivere oplæsning af &kde;'s underretninger. Hvis det ikke er markeret, er alt på siden deaktiveret og &ktts; læser ikke nogen underretninger op.</para></callout>
<callout arearefs="pt-notify-2"><para>Hvis markeret, læser &ktts; nogen begivenheder op med et lyd fra noget program.</para></callout>
<callout arearefs="pt-notify-3"><para>Brug disse knapper til at tilføje eller slette programbegivenheder fra listen nedenfor. Når du klikker på knappen <guibutton>Tilføj</guibutton>, vises et felt hvor du vælger programmer og begivenheder som du vil tilføje til listen. </para></callout>
<callout arearefs="pt-notify-4"><para>Denne begivenhed læser meddelelsen op som &konversation; sender når nogen nævner dit alias i en Internet Relay Chat-meddelelse. </para></callout>
<callout arearefs="pt-notify-5"><para>For alle andre begivenheder som kommer fra &konversation;, gør &ktts; ingenting.</para></callout>
<callout arearefs="pt-notify-6"><para>For alle andre begivenheder som ikke angives på anden måde i listen, gør &ktts; ingenting.</para></callout>
<callout arearefs="pt-notify-7"><para>Brug dette felt til at angive hvad &ktts; skal gøre når en begivenhed modtages. Dine valg er:</para>
<callout arearefs="pt-notify-8"><para>Hvis handlingen er <guilabel>Læs egen tekst op</guilabel>, så skal meddelelseteksten som du vil skal læses op skrives her. Du kan bruge følgende erstatningsstrenge i meddelelsen:</para>
<callout arearefs="pt-notify-9"><para>Test meddelelsen ved at klikke her.</para></callout>
<callout arearefs="pt-notify-10"><para>Du kan angive egenskaber for oplæseren som ønskes til at læse underretningsmeddelelsen her. <command><userinput>standard</userinput></command> bruger den øverste oplæser på siden <guilabel>Oplæser</guilabel>. Se <xref linkend="selecttalker"/>. </para></callout>
<para>Bemærk at der er tre begivenhedniveauer. Hvis en handling for en vis begivenhed fra et vist program angives, udføres denne handling. Ellers, hvis en handling for alle andre begivenheder fra et vist program angives, udføres denne handling. Ellers udføres handlingen som angives for alle andre begivenheder under <guilabel>Standard (alle andre begivenheder)</guilabel>.</para>
<para>Begivenheden <guilabel>alle underretninger</guilabel> for programmet <guilabel>Standard (alle andre begivenheder)</guilabel> kan ikke fjernes fra listen. For standardværdien alle andre begivenheder kan du angive type af underretning som læses op, som følger:</para>
<tip><para>Strengerstatningsfilter er en god måde at gøre rydde op i meddelelser som sendes fra programmer, hvis de har fejlagtig udtale eller læses forkert op i &ktts;. Filen <filename>kmail.xml</filename> som levereres med &ktts;, er et godt eksempel. Den fjerner mærkerne <command>br</command> og <command>b</command> i underretningsmeddelelser fra &kmail;, og fjerner også sætningen <command>/local/inbox/</command>, eftersom det kan forudsættes i de fleste tilfælde. Se <xref linkend="stringreplacer"/>. </para></tip>
<para>Brug knappen <guibutton>Gem</guibutton> til at gemme indstillinger af underretninger i en fil. Brug knappen <guibutton>Indlæs</guibutton> til at indlæse gemte indstillinger fra en fil. De indlæste begivenheder blandes med eksisterende begivenheder i listen. Hvis du vil begynde med en tom liste, klikkes først på knappen <guibutton>Ryd</guibutton>. Alle begivenheder undtagen <guilabel>alle underretninger</guilabel> slettes.</para>
<note><para>Sørg for at klikke på knappen <guibutton>Anvend</guibutton> eller <guibutton>OK</guibutton> for at gemme de nye indstillinger.</para></note>
<para>SSML (Speech Synthesis Markup Language) er en W3C-standard for at markere tekst for oplæsning. Det sørger for mærker til at styre stemmer, talehastighed, lydstyrke, køn og tonehøjde. Det sørger også for mærker til at styre hvordan ord læses op, for eksempel udtalelse af forkortelser. SSML er en del af specifikationen VoiceXML, som også er en W3C-standard.</para>
<listitem><para>Fungerer kun med oplæserne Festival (interaktivt) og Hadifix.</para></listitem>
<listitem><para>Du skal installere stemmen <command>rab_diphone</command> (britisk mand), eftersom det er standardstemmen som Festival bruger ved oplæsning af SSML.</para></listitem>
<listitem><para>Indstillingen <guilabel>Hastighed</guilabel> på siden <guilabel>Lyd</guilabel> ignoreres når tekst som indeholder SSML læses op.</para></listitem>
<listitem><para>Hvis indstillingerne <guilabel>Hastighed</guilabel> eller <guilabel>Tonehøjde</guilabel> i Festivals indstillingsdialog ikke er sat til 100 %, gør det oftest at SSML-teksten læses op monotont.</para></listitem>
<para>Filtre bruges til at forbehandle tekst inden den sendes til talesyntesprogrammet. De er nyttige til at forbedre tale, erstatte forkert oplæste ord eller forkortelser, vælge passende sprog og oplæser, eller komme uden om visse begrænsninger i talesyntesen og dens stemmer.</para>
<para>For at forstå hvordan filtre bruges, hjælper det først at forstå hvordan tekst behandles af &ktts;. Tekst som læses op af &ktts; er af fire mulige typer.</para>
<para>Skærmlæsningsudskrift har højest prioritering. Den er reserveret til brug af skærmlæsningsprogrammer. Skærmlæsningsudskrift går før alle andre meddelelser, og holder pause i disse job. Så snart skærmlæsningsudskriften er læst op, genoptages beskeden som blev afbrudt automatisk. </para>
<para>Advarsler har følgende prioritering. De er reserverede for meddelelser med høj prioritet, såsom "Processoren er for varm". En advarsel afbryder meddelelser og almindelig tekst, og holder pause i disse job. Så snart advarslen er læst op, genoptages beskeden som blev afbrudt automatisk.</para>
<para>Meddelelser har følgende prioritering. En meddelelse afbryder almindelige tekstjob. &kmouth; er et eksempel på et program som anvender meddelelser. For eksempel, mens en lang tekst fra en netside læses op, kan &kmouth; bruges til at hilse på nogen som kommer ind i rummet. &kde;s bekendtgørelser er også beskeder (se <xref linkend="knotify"/>).</para>
<para>Resten er almindelige tekstjob. Alle job som du starter fra fanebladet <guilabel>Job</guilabel> er tekstjob. Ksayit er et eksempel på et program som bruger tekstjob. Tekstjob er beregnede til for længere tale som ikke er skal være lige nu.</para>
<para>Alle fire slags job har køer, undtagen skærmlæsningsudskrift. Hvis en skærmlæsningsudskrift sendes fra et program mens &ktts; læser en anden skærmlæsningsudskrift op, stoppes meddelelsen som er ved at blive læst op og smides væk.</para>
<para>Det første du skal vide om filtre er at de aldrig bruges til skærmlæsningsudtale. De bruges til advarsler, meddelelser og tekstjob, og desuden til &kde;'s underretninger (Knotify).</para>
<para>Der er to slags filtre, almindelige filtre og filter for detektering af sætningsgrænser (SBD-filtre). SBD-filtre deler tekst op i enkelte sætninger. Det gør at &ktts; kan begynde oplæsning hurtigere, eftersom kun den første sætningen behøver at syntetiseres, ikke hele tekstjobbet. Det tillader dig også at gå fremad eller tilbage sætning for sætning i fanebladet <guilabel>Job</guilabel>, eller stoppe og holde pause i tekstjob når talesyntesen ikke direkte understøtter at stoppe oplæsningen. </para>
<para>Strengerstatningsfiltre erstatter tekstdele med anden tekst. De erstattede dele matches enten som ord eller som regulære udtryk. &ktts; levereres med fordefinerede strengerstatningsfiltre for at læse forkortelser og chatsmileys såsom ":-)" op, eller til at omformatere underretningsmeddelelser fra &konversation; eller &kmail; til en form som er nemmere at forstå. </para>
<para>&XML;-transformatører bruger et &XML;-stilsprogfil (XSLT-fil) til at konvertere &XML; i et format til et andet format. &ktts; leveres med et par XSLT-filer til at konvertere &XHTML; til SSML </para>
<para>Valg af oplæser lader dig at sende job til en oplæser baseret på tekstens indhold, eller baseret på programmet som sendte det til &ktts;. Hvis du for eksempel har indstillet en kvindelig oplæser i fanebladet <guilabel>Oplæser</guilabel>, kan du sende tekst som kommer fra KSayit til den oplæser. Se <xref linkend="configure-plugin"/>. </para>
<para>Hver af disse filtertyper har indstillelige regler som afgør hvornår filtret skal påvirke teksten der skal læses op. Hvis filtret afgør at det ikke skal påvirke teksten, sendes teksten videre til næste filter uforandret.</para>
<para>Når et tekstjob, en besked, advarsel, eller &kde;-underretningsmeddelelse sendes til &ktts;, går det gennem alle aktiverede filter som du har indstillet på skærmen nedenfor. Rækkefølgen er oppefra og ned. Efter at være gået gennem alle almindelige filtre på listen i den øvre del af skærmen, sendes tekstjob til filtrene <guilabel>Detektering af sætningsgrænse</guilabel> (SBD-filtrene). &kde;'s underretningsmeddelelser, advarsler og beskeder går aldrig gennem SBD-filtre. I modsætning til almindelige filtre, så stopper det første SBD-filter som udfører ændringer i teksten yderligere filtrering. </para>
<callout arearefs="pt-filters-1"><para>Dette er listen med indstillede almindelige filtre. Hvis det ikke er markeret, er filtret inaktivt og springes over. Filtre bruges i rækkefølgen som angives her, oppefra og ned.</para></callout>
<callout arearefs="pt-filters-2"><para>Klik her for at tilføje et nyt filter. Du bliver spurgt om hvilken slags filter som skal tilføjes. Efter du har valgt slagsen, se indstillingsdialogerne nedenfor.</para></callout>
<callout arearefs="pt-filters-3"><para>Klik her for at fjerne et filter.</para></callout>
<callout arearefs="pt-filters-4"><para>Klik her for at ændre et filters indstilling. Se indstillingsdialogerne nedenfor.</para></callout>
<callout arearefs="pt-filters-5"><para>Klik på knapperne for at flytte et filter op eller ned i listen.</para></callout>
<callout arearefs="pt-filters-6"><para>Dette er filtrene til detektion af sætningsgrænser. Når du starter &ktts; første gang, indstilles standardfiltret automatisk til detektering af sætningsgrænser for dig. Du kan ændre filtrets indstilling, eller tilføje yderligere filtre til detektering af sætningsgrænser, men vi råder nybegyndere til ikke at ændre dem.</para></callout>
<callout arearefs="pt-filters-7"><para>Dette dropned-felt lader dig tilføje, fjerne, redigere eller ændre rækkefølge på filtre til detektering af sætningsgrænser.</para></callout>
<callout arearefs="pt-filters-8"><para>Sørg for at du klikker her, ellers får dine indstillinger ingen effekt.</para></callout>
<para>Du Indstiller strengerstatningsfiltre ved at sørge for en liste med ord eller regulære udtryk som skal matches. Når det matchede ord eller regulære udtryk findes i teksten, erstattes hvert af dem med en erstatningsstreng som du angiver. Matchningen er ikke versalfølsom.</para>
<callout arearefs="pt-stringreplacer-1"><para>Indtast et navn på dit filter. Brug et hvilket som helst navn du vil som adskiller det fra alle andre filtre.</para></callout>
<callout arearefs="pt-stringreplacer-2"><para>Dette er en liste med ord og regulære udtryk. Filtret søger efter matchende strenge for hver streng i søjlen <guilabel>Matche</guilabel>, og erstatter den matchende streng med strengen i søjlen <guilabel>Erstat med</guilabel>. Listen behandles i den rækkefølge den vises, oppefra og nedad.</para></callout>
<callout arearefs="pt-stringreplacer-3"><para>Klik her for at tilføje yderligere et ord eller regulært udtryk til listen.</para></callout>
<callout arearefs="pt-stringreplacer-4"><para>Klik her for at fjerne det eksisterende ord eller regulære udtryk som for øjeblikket er markeret fra listen.</para></callout>
<callout arearefs="pt-stringreplacer-5"><para>Klik for at ændre et eksisterende ord eller regulært udtryk i listen.</para></callout>
<callout arearefs="pt-stringreplacer-6"><para>Klik for at fjerne det eksisterende ord eller regulære udtryk som for øjeblikket er markeret fra listen.</para></callout>
<callout arearefs="pt-stringreplacer-7"><para>Brug disse knapper til at indlæse en liste med ord eller regulære udtryk fra en fil, gemme nuværende liste til en fil, eller rydde hele listen. Når du indlæser fra en fil, tilføjes punkterne i filen til sidst i den eksisterende liste.</para></callout>
<callout arearefs="pt-stringreplacer-8"><para>Hvis ikke tom, bruges filtret kun hvis sproget for jobbets oplæser passer med sproget du skriver ind. Klik på knappen for at vise en liste over sprog. Du kan vælge mere end et sprog ved at trykke på <keycap>&Ctrl;</keycap> når du klikker.</para></callout>
<callout arearefs="pt-stringreplacer-9"><para>Hvis ikke tom, bruges filtret kun hvis teksten kommer fra et af de programmer som er på listen. Du kan indtaste mere end et program adskilt med kommaer. Eksempel: <command><userinput>konversation,kmail</userinput></command>.</para>
<tip><para>Du kan finde ud af <guilabel>Program-id</guilabel> for programmer som kører med programmet <command>&kdcop;</command>. Du skal udelade &DCOP;-nummeret. Hvis &kdcop; for eksempel viser program-id <command>kopete-3234</command>, skal du kun indtaste <command><userinput>kopete</userinput></command>.</para></tip></callout>
<para>Strengerstatningsfiltret bruges kun til tekst hvis alle betingelser som ikke er tomme opfyldes i feltet <guilabel>Brug filtret når</guilabel>. Hvis alle felterne er blanke, vil filtrene blive anvendt på al tekst.</para>
<para>Matchning er ikke versalfølsom.</para>
<para>Når ord matches, bruger strengerstatningsfiltret et regulært udtryk på formen <command>\s<userinput>ord</userinput>\s</command> internt. Med andre ord, skal ordet have ordgrænser (blanke tegn) på begge sider.</para>
<para>En beskrivelse af hvordan man skriver regulære udtryk er udenfor denne håndbogs omfang. Hvis du har &kde;'s editor af regulære udtryk installeret, er der en knap på skærmene <guilabel>Tilføj</guilabel> og <guilabel>Redigér</guilabel> som hjælper dig med at oprette regulære udtryk. &kde;'s editor af regulære udtryk indgår i pakken <command>tdeutils</command>.</para>
<para>&ktts; levereres med nogle filer med ordlister, inklusive en liste med smileys, såsom ":-)", nogle forkortelser som typisk bruges i IRC- og instant message programmer, og en liste med andre forkortelser. Der er også en liste med specialtegn, som den nuværende version af den polske stemme i Festival ikke kan håndtere. Hvis du udvikler nyttige egne ordlister, så brug knappen <guibutton>Gem</guibutton> for at gemme dem i en fil, og sende dem til &ktts;-gruppen så de kan inkluderes i næste version.</para>
<para>Filtret for &XML;-transformator bruger XSLT-filer til at transformere &XML; fra et format til et andet. XSLT, &XML;-stilprog-transformationer, er et W3C standardsprog til at udføre sådant. Det kan kun bruges med velformet &XML;. Du skal have redskabet <command>xsltproc</command> installeret.</para>
<callout arearefs="pt-xmltransformer-1"><para>Indtast et navn på dit filter. Brug et hvilket som helst navn du vil som adskiller det fra alle andre filtre.</para></callout>
<callout arearefs="pt-xmltransformer-2"><para>Indtast fuldstændig søgesti til en eksisterende XSLT-fil, som udfører transformationen.</para></callout>
<callout arearefs="pt-xmltransformer-3"><para>Angiv søgestien til værktøjet <command>xsltproc</command>. Hvis xsltproc findes i miljøvariabeln PATH, skrives blot <command><userinput>xsltproc</userinput></command>.</para></callout>
<callout arearefs="pt-xmltransformer-4"><para>Hvis ikke tom, bruges filtret kun hvis &XML; har det angivne rodelement eller en <command><![CDATA[<!DOCTYPE]]></command> som begynder med den angivne streng. Dette adskiller en form af &XML; fra en anden. For eksempel vil <command><userinput>html</userinput></command> i <guilabel>DOCTYPE</guilabel>-feltetmatche <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-5"><para>Hvis ikke tom, bruges filtret kun hvis teksten kommer fra et af de programmer som er på listen. Du kan indtaste mere end et program adskilt med kommaer. Eksempel: <command><userinput>konversation,kmail</userinput></command>.</para>
<tip><para>Du kan finde ud af <guilabel>Program-id</guilabel> for programmer som kører med programmet <command>&kdcop;</command>. Du skal udelade &DCOP;-nummeret. Hvis &kdcop; for eksempel viser program-id <command>kopete-3234</command>, skal du kun indtaste <command><userinput>kopete</userinput></command>.</para></tip></callout>
<para>Filtret for &XML;-forvandling bruges kun for tekst hvis det angivne rodelement eller den angivne DOCTYPE stemmer og hvis program-id stemmer i feltet <guilabel>Brug filtret når</guilabel>. Hvis et felt er tomt, udføres testen ikke, så hvis alle felter er tomme gælder filtret for al tekst. Du bør dog udfylde mindst et felt, eftersom mange tekstjob ikke har &XML;-format.</para>
<para>Filter til valg af oplæser bruges til at styre teksten hen til en ønsket oplæser indstillet i fanebladet <guilabel>Oplæser</guilabel>, eller til en oplæser som har angivne egenskaber. Du kan for eksempel angive at tekst som kommer fra <command>kmail</command> skal læses op af en oplæser som er indstillet til en kvindelig stemme. Se <xref linkend="configure-plugin"/>.</para>
<para>Lige inden &ktts; begynder at sende tekst til hvert af filtrene, vælger det en oplæser om skal læse teksten op. Valg af oplæser er baseret på oplæserens egenskaber som angives af programmet som sender teksten til &ktts;, og egenskaber ved oplæsere som du har indstillet i fanebladet <guilabel>Oplæser</guilabel>. Filtret til valg af oplæser tillader at du sætter den valgte oplæser ud af kraft. </para>
<callout arearefs="pt-talkerchooser-1"><para>Indtast et navn på dit filter. Brug et hvilket som helst navn du vil som adskiller det fra alle andre filtre.</para></callout>
<callout arearefs="pt-talkerchooser-2"><para>Hvis ikke tom, bruges filtret kun hvis teksten indeholder det indskrevne regulære udtryk. Hvis den er installeret, så klik på søgeknappen til at starte &kde;'s editor af regulære udtryk som hjælper dig med at indtaste det regulære udtryk.</para>
<tip><para>For bedre ydelse, forsøg at "forankre" det regulære udtryk til strengens begyndelse. Med andre ord, indled dit regulære udtryk med <command><userinput><![CDATA[^]]></userinput></command>.</para></tip></callout>
<callout arearefs="pt-talkerchooser-3"><para>Hvis ikke tom, bruges filtret kun hvis teksten kommer fra et af de programmer som er på listen. Du kan indtaste mere end et program adskilt med kommaer. Eksempel: <command><userinput>konversation,kmail</userinput></command>.</para>
<tip><para>Du kan finde ud af <guilabel>Program-id</guilabel> for programmer som kører med programmet <command>&kdcop;</command>. Du skal udelade &DCOP;-nummeret. Hvis &kdcop; for eksempel viser program-id <command>kopete-3234</command>, skal du kun indtaste <command><userinput>kopete</userinput></command>.</para></tip></callout>
<callout arearefs="pt-talkerchooser-4"><para>Angiv egenskaber hos oplæseren som du foretrækker skal læse teksterne op. Hvis teksten opfylder filterbetingelserne ovenfor, vælges en oplæser som passer bedst med de egenskaber du angiver her. Klik på knappen til højre for at vise skærmen <guilabel>Vælg oplæser</guilabel>. Se <xref linkend="selecttalker"/>.</para></callout>
<callout arearefs="pt-talkerchooser-5"><para>Brug disse knapper til at gemme indstillingerne i Valg af oplæser, for at indlæse indstillinger fra en gemt fil, eller rydde alle indstillinger.</para></callout>
<para>Filtret til valg af oplæser bruges kun til tekst hvis alle betingelser som ikke er tomme er opfyldt i feltet <guilabel>Brug filtret når</guilabel>. Du skal udfylde mindst et af filterne.</para>
<para>Den nemmeste måde at lære sig hvordan valg af oplæsere indstilles er at eksperimentere. Deaktivér valg af oplæser og lad noget tekst blive læst op. Bemærk oplæseren som &ktts; vælger i fanebladet <guilabel>Oplæser</guilabel>. Klik på knappen <guibutton>Vælg oplæser</guibutton>, indtast nogle egenskaber, og forsøg igen for at se hvordan valget påvirkes. Du skal naturligvis have mere end en oplæser indstillet for at valg af oplæser skal gøre noget.</para>
<listitem><para>tillader at &ktts; begynder at læse teksten op hurtigere, eftersom det kun behøver at syntetisere den første sætning, i stedet for hele tekstblokken, hvilket kan være meget langt, og</para></listitem>
<listitem><para>tillader dig at gå tilbage eller fremad sætning for sætning på siden <guilabel>Job</guilabel> og</para></listitem>
<listitem><para>lader dig holde pause eller stoppe tekstjob i fanebladet <guilabel>Job</guilabel>, selvom om talesyntesen ikke har mulighed at stoppes.</para></listitem>
<para>Af disse grunde, indstilles standardfiltret for detektering af sætningsgrænser automatisk første gangen du kører <command>kttsmgr</command> og kan ikke deaktiveres (selvom om du kan fjerne det). Vi råder dig til ikke at ændre filtret, med mindre du ved hvad du gør.</para>
<para>Du kan imidlertid tilføje yderligere SBD-filtre for at løse visse problemer. For eksempel har den polske stemme i Festival, på tidspunktet februar 2005, den irriterende egenskab at den læser tegnsætning op. Den læser for eksempel punktummerne i slutningen af hver sætning. Du kan ikke løse problemet ved at oprette et strengerstatningsfilter til at fjerne sætningernes tegnsætning, eftersom hvis du gør det forhindres det almindelige SBD-filter i at genkende nogle sætninger. I stedet kan du oprette en ændret version af det almindelige SBD-filter som genkender sætninger, og samtidigt fjerner sætningernes tegnsætning. For at gøre det, tilføj et SBD-filter og brug knappen <guibutton>Indlæse</guibutton> for at indlæse filen <filename>polish_festival_sbdrc</filename> som levereres med &ktts;.</para>
<para>SBD-filtre virker ved at matche et regulært udtryk for sætningsafslutning og indsætte et tabulatortegn (decimalt 8) ved sætningsgrænserne. (Alle tabulatortegn fjernes automatisk fra teksten inden filtrering begynder.) Bemærk at standardfiltret bevarer sætningens tegnsætning. </para>
<para>Hvis du fjerner standardfiltret til at detektere sætningsgrænser ved en fejl, kan du få tilbage det ved at indlæse filen <filename>standard_sbdrc</filename>, som leveres med &ktts;.</para>
<para>Du kan indstille lige så mange oplæsere som du vil i fanebladet <guilabel>Oplæser</guilabel>. Se <xref linkend="configure-plugin"/>. Når programmer sender tekst til &ktts; kan de angive egenskaber for en ønsket oplæser som skal læse teksten op. &ktts; vælger oplæseren som passer bedst blandt de oplæsere som du har indstillet for at opfylde programmets forespørgsler. Et program kan for eksempel angive at teksten skal læses op af en engelsksproget kvindelig stemme. Hvis du har indstillet en oplæser som er engelsksproget og kvindelig bruges denne oplæser. Hvis du kun har indstillet engelsksprogede mandlige oplæsere, bruges en af dem. Hvis et program ikke angiver nogen egenskaber, bruges standardoplæseren (den øverste) som listes i fanebladet <guilabel>Oplæser</guilabel>.</para>
<para>Når programmer angiver egenskaber for den ønskede oplæser, kan de angive at visse egenskaber "foretrækkes" frem for andre egenskaber. Et program kan for eksempel angive at det ønsker at en høj kvindelig stemme læser teksten op, og at egenskaben høj "foretrækkes" frem for egenskaben kvindelig. Hvis du har en stille kvindelig stemme og en høj mandlig stemme indstillet, vælger &ktts; den stærke mandlige stemme til at udføre oplæsningen. Eftersom sprog er en kritisk parameter for at gøre oplæsning forståelig, er det altid en "foretrukken" egenskab.</para>
<listitem><para>når du klikker på knappen <guibutton>Ændr oplæsere</guibutton> i fanebladet <guilabel>Job</guilabel>, eller</para></listitem>
<listitem><para>når du klikker på knappen <guilabel>Oplæser</guilabel> i dialogen <guilabel>Filterindstilling</guilabel> for et filter for valg af oplæsere, eller</para></listitem>
<listitem><para>når du klikker på knappen <guilabel>Oplæser</guilabel> i fanebladet <guilabel>Underretninger</guilabel>.</para></listitem>
<listitem><para>Brug standardoplæseren (øverst på siden <guilabel>Oplæser</guilabel>). Med andre ord, angives ingen egenskaber for oplæsere.</para></listitem>
<listitem><para>Brug oplæseren som passer bedst ind med en eller flere angivne egenskaber.</para></listitem>
<listitem><para>Brug oplæseren som passer bedst og har alle egenskaber hos en indstillet oplæser. Hvis du ikke fjerner eller ændrer oplæserens indstilling, vælger &ktts; den specifikke oplæser. Hvis du fjerner eller ændrer oplæserens indstillinger, vælger &ktts; oplæseren som passer bedst og har oplæserens oprindelige egenskaber.</para></listitem>
<callout arearefs="pt-selecttalker-1"><para>Vælg måden at indtaste ønskede oplæseregenskaber ved at klikke på en af radioknapperne.</para></callout>
<callout arearefs="pt-selecttalker-2"><para>Vælg egenskaber for ønskede oplæsere her. Lad en egenskab være tom hvis du er ligeglad med denne egenskab.</para></callout>
<callout arearefs="pt-selecttalker-3"><para>Markér feltet hvis du ønsker at egenskaben skal "foretrækkes" frem for andre egenskaber. Du kan markere mere end et felt.</para></callout>
<callout arearefs="pt-selecttalker-4"><para>Eftersom sprog er en kritisk faktor for at gøre tale forståelig, er det altid en foretrukket egenskab. Det er sjældent at bruge denne egenskab. Det eneste tilfælde hvor du kan behøve at angive sprogegenskaben er når du véd at et vist program sender tekst på et sprog som adskiller sig fra desktoppens sprog.</para></callout>
<callout arearefs="pt-selecttalker-5"><para>Dette er en liste over oplæsere som du for øjeblikket har indstillet i &ktts;. Ved at vælge en af dem, angiver du på denne måde alle egenskaber for oplæseren. Hvis oplæseren stadigvæk er indstillet når tekst sendes, får du en nøjagtig træffer og oplæseren vælges. Hvis du alligevel senere fjerner oplæseren, eller ændrer indstillingerne, bliver det måske ikke den valgte oplæseren længere. Oplæseren som passer bedst med på de oprindelige egenskaber vælges.</para></callout>
<para>Egenskaben <guilabel>Sprog</guilabel> er speciel eftersom tekst formodentlig bliver umulig at forstå hvis den læses op af en oplæsere som anvender et sprog som er forskelligt sig fra tekstens. Derfor er sproget automatisk en egenskab som "foretrækkes". Hvis du angiver et sprog, sættes det valgte sprog ud af kraft, men hvis du efterlader det tomt, bruges den eksisterende sprogindstillingen. Hvis programmet som sender teksten til &ktts; ikke angav et sprog, tildeler &ktts; den øverste oplæsers sprog som du har indstillet under fanebladet <guilabel>Oplæser</guilabel>. Med andre ord, den øverste oplæseren antages at tale desktoppens sprog.</para>
<tip><para>For at rydde alle egenskaber i sektionen <guilabel>Brug nærmeste matchende oplæser som har</guilabel>, klikkes først på radioknappen <guilabel>Brug standardoplæser</guilabel>, og klik derefter på radioknappen <guilabel>Brug nærmeste matchende oplæser som har</guilabel>.</para></tip>
<listitem><para>&kde;'s tekst-til-tale programmeringsgrænseflade som bruges af programmører for at give programmerne tekst-til-tale funktioner. Programmer kommunikerer med KTTSD via &DCOP;.</para></listitem>
<listitem><para>KTTSD grænseflade for plugin- som bruges for at tilføje plugin for talesyntese i KTTSD, så &ktts; fungerer med et nyt talesynteseprogram.</para></listitem>
<para>Følgende afsnit giver en kort beskrivelse af &kde;'s tekst-til-tale programmering med &DCOP;-grænseflade. Fuldstændig dokumentation for begge programmeringsgrænseflader er tilgængelig direkte på <ulink url="http://accessibility.kde.org/developer/kttsd/">&kde;'s netsted for tilgængelighed</ulink> (http://accessibility.kde.org). </para>
<para>Programmer sender forespørgsler om tekst-til-tale tjenester via &kde;'s &DCOP;-grænseflade til objektet <command>kspeech</command> i programmet <command>KSpeech</command>. </para>
<para>Indtast følgende kommandoer i en terminal.</para>
<para>Hvis KTTSD ikke allerede kører</para>
<para><userinput>kttsd</userinput></para>
<para>For at sætte et tekstjob i kø som skal læses op</para>
<para>hvor <userinput><replaceable>tekst</replaceable></userinput> er teksten som skal læses op, og <userinput><replaceable>Oplæser</replaceable></userinput> er en sprogkode såsom <userinput><replaceable>en</replaceable></userinput>, <userinput><replaceable>da</replaceable></userinput>, &etc;. Denne kommando læser ikke teksten op, men sætter i stedet et tekstjob i kø for oplæsning.</para>
<para>Eksempel.</para>
<para><userinput>dcop kttsd KSpeech setTekst "Dette er en test." "da"</userinput></para>
<para>For at læse det seneste tekstjob i køen op</para>
<para>I dette tilfælde, henviser <userinput>0</userinput> til det seneste job i køen. Du kan også angive et specifikt jobnummer. (Hvis intet jobnummer angives, kræves <userinput>0</userinput>.)</para>
<para>For at stoppe tekstjobbet som for øjeblikket læses op</para>
<para><command>kttsmgr</command> bryder sammen med det samme når jeg starter det. Jeg kompilerede med fejlsøgningsunderstøttelse, og jag får ikke engang et backtrace.</para>
<para>Gstreamer er brudt sammen og har taget &ktts; med sig. Du skal formodentlig "registrere" Gstreamer. For Gstreamer 0.8x er kommandoen <command>gst-register-0.8</command>. Hvis det ikke løser problemet, har du måske en version af Gstreamer som ikke virker sammen med &ktts; installeret. Du skulle forsøge at opdatere eller at afinstallere Gstreamer.</para>
<para>ALSA-lyd virker ikke hvis jeg spiller musik i et andet program samtidigt. Når jeg holder pause i et tekstjob, fryses &ktts;. Jeg ser "unable to open PCM" i terminaluddata.</para>
<para>Du har problemer med konflikt over enheder i ALSA, som forhindrer at mere end en PCM-enhed åbnes af gangen. Se ALSA's hjemmeside (dmix) for mulige løsninger. <ulink url="www.alsa-project.org">www.alsa-project.org</ulink> </para>
<para>Jeg har en yderligere stemme for Festival som jeg hentede ned fra internettet. Jeg installerede den og kan bruge den i Festival, men den vises ikke i <command>kttsmgr</command>.</para>
<para>Redigér filen <command>$TDEHOME/share/apps/kttsd/festivalint/voices</command> for at tilføje den nye stemme. Øvrige indgange kan bruges som guide. Hvis det lykkes at tilføje en stemme, så send gerne en programrettelse til udviklerne, sammen med den &URL; hvor du hentede stemmefilen.</para>
<para>Ingen af de talesynteseprogrammen som understøttes, håndterer det sprog jeg behøver. Hvor kan jeg få fat i et talesynteseprogram for mit sprog?</para>
<para>Google™ er til stor hjælp. Denne <ulink url="http://tcts.fpms.ac.be/synthesis/mbrola/mbrtts.html">link</ulink> kan også være nyttig. Hvis du finder et frit talesynteseprogram som understøtter dit ønskede sprog, og vil tilføje støtte for det i &ktts;, så kontakt udviklingsgruppen. Programmer med åben kildekode er særligt velkomne. Hvis du kender til et kommercielt synteseprogram, kan du måske overtale fremstilleren at donere en gratis kopi til udviklingsgruppen for &ktts;. Sommetider kan du få synteseprogrammet til at virke med pluginnet ved at bruge <guilabel>Kommando</guilabel>. Se <xref linkend="using-with-command"/>.</para>
<para>Under fanebladet <guilabel>Lyd</guilabel> findes indstillingen <guilabel>Hastighed</guilabel>. For at den skal virke, skal værktøjet <command>sox</command> være installeret og i din søgesti. Visse syntese-plugin, såsom Festival interaktiv sørger for også indstillingen <guilabel>Hastighed</guilabel> i indstillingsdialogen for oplæsere. Afhængig af stemmen som bruges, kan den være aktiveret eller ikke.</para>
<para>Hastighedsindstillingerne ignoreres når &ktts; læser &HTML; op. (Det skyldes at &HTML; konverteres til SSML, som har sine egne hastighedsmærker.) Deaktivér enten filtret for &XML;-konvertering (se <xref linkend="filters"/>), eller hvis du er dristig, redigér .xsl-filen i filtret for konvertering af &HTML; til SSML, og øg standardtalerhastighed.</para>
<para>Jeg kan ikke få netsider til at blive læst op med en kvindelig stemme. Jeg har en kvindelig oplæser indstillet i Festival, men &ktts; læser altid netsider op med en mandlig stemme.</para>
<para>Fra og med Festival 1.95 beta, synes mærket SABLE GENDER ikke at fungere. For at forhindre at Festival giver fejl, tager .xsl-filen for SSML til SABLE kønsmærker væk. Det samme gælder også for stemmemærker.</para>
<para>På grund af en fejl i Festival 1.95 beta, skal du installere stemmen <command>rab_diphone</command> (britisk mand) for at SABLE overhovedet kan virke, også selvom du ikke bruger stemmeen til at læse netsiderne op. Sørg også for at værktøjet <command>xsltproc</command> er installeret og i din søgesti.</para>
<para>Visse tegn eller punktuering synes at give fejl i talesyntesen, hvilket gør at den springer over hele sætninger, eller udtaler nonsens. Hvad kan jeg gøre?</para>
<para>Sørg først for om at tilvalget <guilabel>Tegnsæt</guilabel> i oplæserens indstillingsdialog er rigtigt indstillet for sproget. Hvis visse ord eller tegn forårsager problemer, kan et strengerstatningsfilter hjælpe. Hvis visse punktueringer for sætninger forvirrer talesyntesen, skal du indstille et filter for detektering af sætningsgrænser. Se <xref linkend="filters"/>.</para>
<para>Jeg har tilføjet et eget strengerstatningsfilter og nu lader &ktts; mig ikke gå tilbage eller fremad sætning efter sætning. Under fanebladet <guilabel>Job</guilabel>, påstås at hvert job kun har en sætning. Hvad har jeg gjort forkert?</para>
<para>Du må ikke bortfiltrere tegn for punktuering af sætninger (punktum, spørgsmålstegn, udråbstegn, kolon og semikolon). Brug i stedet et filter for detektering af sætningsgrænser for disse tegn.</para>
&underFDL; &underGPL; <note><para>Talesynteseprogrammer som bruges af &ktts; har deres egne licenser. Se dokumentationen for hvert program eller netsted for detaljer. Nogle stemmer har også deres egne licenser.</para></note>
<para>Du finder link til kildekode og binære pakker på <ulink url="http://accessibility.kde.org/developer/kttsd/">&kde;'s netsted for tilgængelighed</ulink> (http://accessibility.kde.org).</para>
<para>Hvis du har adgang til &kde;'s kodelager, kan du hente &ktts; ved at tjekke modulet <command>tdeaccessibility</command> ud. &ktts; findes i mappen <command>kttsd</command>. Du kan også hente tar-bolde med tdeaccessibilitys kildekode fra <ulink url="ftp://ftp.kde.org/pub/kde/"> ftp://ftp.kde.org/pub/kde/</ulink></para>
<note><para>Sprogene på listen ovenfor er måske ikke er fuldstændige eller opdaterede. Kontrollér hvert programs specifikation for en fuldstændig liste med sprog som understøttes. Tjek også hjemmesiden <ulink url="http://accessibility.kde.org/developer/kttsd/index.php"> &ktts;</ulink> for yderligere information der måske ikke er medtaget i denne håndbog. </para></note>
<para>&ktts; bruger en fleksibel plugin-arkitektur for talesynteseprogrammer. Hvis du vil udvide &ktts; til at understøtte yderligere et program, så kontakt udviklingsgruppen. </para>
<para>I det mindste et af følgende lydsystemer: <itemizedlist>
<listitem><para>&kde;'s lydsystem &arts;. &arts; er oftest installeret med &kde;.</para></listitem>
<listitem><para>ALSA (Avanceret &Linux; lydarkitektur). ALSA er installeret på de fleste &Linux;-systemer. (<ulink url="www.alsa-project.org">www.alsa-project.org</ulink>)</para></listitem>
<listitem><para>Gstreamer version 0.8.7 eller senere. <emphasis>Bemærk</emphasis>: sørg for at registrere dine Gstreamer plugin ved at køre kommandoen <command>gst-register</command> inden Gstreamer bruges i &ktts;. (<ulink url="http://gstreamer.freedesktop.org">http://gstreamer.freedesktop.org</ulink>)</para></listitem>
<listitem><para>aKode-biblioteket. aKode er et afkoderbibliotek som er en del af &kde;. </para></listitem>
<note><para>Visse brugere oplever konflikt over enheder med ALSA. Hvis systemet har problemet, kan du ikke samtidigt afspille musik og læse tekst op. &ktts; fryser også hvis du holder pause i et tekstjob og derefter starter et andet. Se ALSA's hjemmeside (dmix) for mulige løsninger.</para></note>
<note><para>For øjeblikket, juli 2005, understøtter aKode ikke en virkelig pausemulighed. Når du holder pause i et tekstjob i &ktts; fortsætter det med at læse nuværende sætning.</para></note>
<para>Lydværktøjet <command>sox</command> behøves for at justere generel oplæsningshastighed, men kræves ikke. Debian-brugere kan installere sox med kommandoen <command>apt-get install sox</command>. Sox indgår i de fleste distributions-cd'er med &Linux;.</para>
<para>Værktøjet <command>xsltproc</command> behøves for SSML-understøttelse, og for &XML;-Transformator-filter, men kræves ikke. Debian-brugere kan installere xsltproc med kommandoen <command>apt-get install xsltproc</command>.</para>
<para>Hvis du har hentet &ktts; som et komprimeret arkiv, så log på som en almindelig bruger og pak arkivet ud i en passende mappe, gå til mappen, og indtast følgende kommandoer:</para>
<para>Følgende plugin for talesyntese bygges alle normalt. Visse af dem afhænger kun af ikke-frit programmel ved kørsel (ikke-fri ifølge Debians politik). Søjlen "Flag til configure for ikke at bygge" viser kommandoen til configure for ikke at bygge pluginnet.</para>
<para>Normalt installerer kommandoerne ovenfor &ktts; i <command>/opt/kde3</command>. Hvis mappen ikke findes i søgestien <command>TDEDIRS</command>, kan du behøve at tilføje flaget <command>--prefix=<replaceable>mål</replaceable></command>. For eksempel:</para>
<note><para>På Debian-systemer er <filename><replaceable>/usr/local</replaceable></filename> det sædvanlige sted at installere programmer som kompileres fra kildekode. </para></note>
<para>Hvis du hentede kildekoden for &ktts; fra kodelager-modulet <filename>tdeaccessibility</filename>, eller hentede det komprimerede arkiv som laves hver nat, så brug følgende kommandoer for at kompilere og installere. </para>
<para>Festival er et af de bedste frie tekst-til-tale programmer med åben kildekode som er tilgængelige. Stemmekvalitet er i almindelighed god og der er støtte for en hel del sprog og stemmer. For mange stemmer kan du styre lydstyrke, den oplæste tales hastighed og tonehøjde fra &ktts;.</para>
<para>Du skal installere mindst et sprog. Følg instruktionerne som leveres med Festival. Hvis du vil oplæse hjemmesider, må du installere <command>rab_diphone</command> (mandlig britisk) stemme. </para>
<para>Du skal kompilere yderligere et modul for disse stemmer, og derfor skal du have kildekoden for Festival. De tyske stemmer har en begrænset distribution. </para>
<para>Du skal have Festival 1.95 beta eller senere for at bruge denne stemme. Stemmen er stadigvæk i en tidlig udviklingsfase. Pak <filename>festival/lib/voices/russian/</filename> ud. Når du indstiller den russiske oplæser, er stemmekoden <userinput>msu_ru_nsh_diphone</userinput>. Sørg for at vælge et kyrillisk 8+bit tegnsæt, såsom <userinput>KOI8-R</userinput>.</para>
<para>Når sprogene polsk, ungarsk eller tjekkisk bruges, så sørg for at tilvalget <guilabel>Kodning</guilabel> er indstillet til <userinput>ISO 8859-2</userinput>. </para>
<para>Når den russiske stemme bruges, så sørg for at tilvalget <guilabel>Tegnsæt</guilabel> er indstillet til et 8-bit cyrillisk tegnsæt såsom <userinput>KOI8-R</userinput>. </para>
<para>Festival kan bruges i kombination med &mbrola;-talesyntese. I denne tilstand gør Festival leksikalanalysen og &mbrola; laver lyden. den binære &mbrola;-filen og &mbrola;-stemmefiler kan hentes fra</para>
<para>Bemærk at &mbrola; ikke er et fuldstændig system for tekst-til-tale. &mbrola; syntetiserer tale fra difon-filer. Du skal have yderligere programmel som kan oprette difonerne. Ved kombination med Festival, laver Festival difonerne som &mbrola; behøver. <command>txt2pho</command> kan også bruges til at oprette difoner fra tysk tekst. Se <link linkend="using-with-hadifix">Brug med Hadifix</link> for mere information.</para>
<listitem><para><link linkend="mbrola-wrappers">&mbrola;-indpakning</link>. Mens denne håndbogen skrives, er metoden begrænset til engelske stemmer.</para></listitem>
<listitem><para><link linkend="ims-german-festival">IMS tysk Festival</link>.</para></listitem>
<para>Med denne metoden tilføjes yderligere omgivelseskode til i Festival for at muliggøre talesyntese med &mbrola; stemmefiler. Bemærk at &mbrola;-stemmefilerne <emphasis>ikke</emphasis> installeres i &mbrola;-mappetræet. I stedet installeres de i mappetræet <filename>festival/lib</filename>. For instruktioner, se</para>
<para>IMS tysk Festival er en ændret version af Festival som bruger tyske &mbrola;-stemmer. Det virker enten med Festival version 1.4.1 eller Festival 2.0 (1.95 beta). Installér først Festival og &mbrola;, hvis du ikke allerede har gjort det. Hent derefter IMS tysk Festival fra</para>
<para>Følg instruktionerne i filen <filename>README</filename> som indgår i pakken. (Bemærk: hvis dette bruges sammen med Festival 2.0, er det <emphasis>ikke</emphasis> nødvendigt at installere det komprimerede arkiv <filename>fixes</filename>, men du skal alligevel bygge Festival igen.) Tilføj til sidst følgende linjer i filen <filename>festival/lib/siteinit.scm</filename>.</para>
<para>(På visse systemer, er filen du redigerer <filename>/etc/festival.scm</filename>.) Tilføj kun linjerne som svarer til de tyske stemmer som du har installeret. Erstat <userinput><replaceable>/usr/local/mbrola</replaceable></userinput> med den rigtige søgesti. Bemærk også at IMS tysk Festival ikke virker med de tyske stemmer de4, de5 eller de6 (mens dette skrives).</para>
<para>Denne metode bruger en del speciel kode for at aktivere talesyntese ved brug af Festival og en &mbrola; tjekkisk stemme. For at installere den, hentes først Festival og MROLA, de installeres og du sikrer dig at begge virker. Hent derefter tjekkisk Festival fra</para>
<para>Festival Lite er et frit program med åben kildekode som for øjeblikket understøtter et begrænset antal stemmer og sprog. Det er letvægts, men giver lidt op på stemmekvalitet. Du kan ikke styre tonehøjde, lydstyrke eller hastighed for programmet fra &ktts;.</para>
<para>Hadifix er et totrins talesynteseprogram baseret på difoner. Værktøjet <command>txt2pho</command> konverterer tekst til difoner og programmet &mbrola; syntetiserer difonerne til lyd. Stemmekvaliteten er god, men sprogunderstøttelsen er for øjeblikket noget begrænset. Du kan styre stemme, tonehøjde, hastighed og lydstyrke fra <application>kttsmgr</application>. </para>
<step><para>Pak txt2pho ud til <filename>/usr/local/txt2pho</filename>.</para></step>
<step><para>Redigér filen <command>txt2phorc</command>, og tilføj rigtige datastier.</para></step>
<step><para>Kopiér enten <filename>txt2phorc</filename> til <filename>~/.txt2phorc</filename> eller til <filename>/etc/txt2pho</filename>. Bemærk at du fjerner "rc" fra filnavnet.</para></step>
<step><para>Vælg sproget tysk i <application>kttsmgr</application> (<guilabel>de</guilabel>), og tilføj <guilabel>Hadifix</guilabel>.</para></step>
<step><para>På skærmen <guilabel>Indstil Oplæser</guilabel>, indstilles en stemme og søgestierne til &mbrola; og txt2pho.</para></step>
<step><para>Klik på knappen <guibutton>Test</guibutton> for at teste.</para></step>
<para>Epos er et frit tjekkisk og slovakisk program med åben kildekode. Det er letvægts, men har lidt dårligere stemmekvalitet. Du kan ikke styre lydstyrke for programmet fra &ktts;.</para>
<para>Start <application>kttsmgr</application>. Klik på knappen <guibutton>Tilføj</guibutton> på siden <guilabel>Oplæsere</guilabel>. Vælg sproget tjekkisk eller slovakisk og <guilabel>Epos tekst-til-tale syntesesystem</guilabel>. Hvis den kørbare Epos-server og klienten ikke er i din søgesti, indtast den fuldstændige søgestier til disse kørbare programmer på siden <guilabel>Indstil Oplæser</guilabel>. Tilvalgsfelterne tillader dig at sende yderligere flag til serveren og klienten. Skriv <command>epos -h</command> eller <guilabel>say -h</guilabel> i en terminal for information.</para>
<para>FreeTTS er et frit talesynteseprogram med åben kildekode skrevet i &Java;, hvilket betyder at du skal have &Java;s virtuelle maskine installeret på dit system for at bruge den. Den har for øjeblikket begrænset understøttelse for stemmer og sprog. Du kan ikke styre tonehøjde, lydstyrke eller hastighed for programmet fra &ktts;.</para>
<para>Plugin-programmet for kommando tillader at du bruger &ktts; med et hvilket som helst talesyntesprogram, som kan køres som en kommando i en terminal.</para>
<para>Ideelt bør du bruge en kommando som syntetiserer til en midlertidig lydfil (wav), i stedet for at sende talen direkte til lydenheden.</para>
<para>Hvis talesyntesprogrammet kræver at tekst skal have et andet tegnsæt end desktoppens tegnsætindstilling, skal du bruge flaget <command>%f</command> til at sende teksten til programmet. &ktts; koder teksten med indstillingerne du angiver når det skriver teksten til den midlertidige filen. Hvis du forsøger at sende tekst på kommandolinjen med flaget <command>%t</command>, kodes det med tegnsætindstillingen i desktoppens indstilling af land. Du kan også bruge tilvalget <guilabel>Send data som standardindtastning</guilabel> for at løse problemet, hvis programmet accepterer inddata fra standardindtastningen. Her er et eksempel på en kommando til at sende polsk tekst til Festival med kodningen ISO 8859-2 og fjerne tegnsætning som ikke skal læses op.</para>