EventParameterType Enumeration
Definition
Wichtig
Einige Informationen beziehen sich auf Vorabversionen, die vor dem Release ggf. grundlegend überarbeitet werden. Microsoft übernimmt hinsichtlich der hier bereitgestellten Informationen keine Gewährleistungen, seien sie ausdrücklich oder konkludent.
Listet die Datentypen von Datenzeigern auf, die an Sprachsyntheseereignisse übergeben werden.
public enum class EventParameterType
public enum EventParameterType
type EventParameterType =
Public Enum EventParameterType
- Vererbung
Felder
| Name | Wert | Beschreibung |
|---|---|---|
| Undefined | 0 | Gibt an, dass das |
| Token | 1 | Gibt an, dass das Argument für die |
| Object | 2 | Derzeit nicht unterstützt. |
| Pointer | 3 | Derzeit nicht unterstützt. |
| String | 4 | Gibt an, dass das Argument für das |
Beispiele
Das folgende Beispiel ist Teil einer benutzerdefinierten Sprachsyntheseimplementierung, die von TtsEngineSsml, und die Verwendung von TextFragment, , SpeechEventInfo, FragmentStateund TtsEventId.
Die Umsetzung der Speak
Empfängt ein Array von Instanzen und erstellt ein neues Array von TextFragmentTextFragment Instanzen, das an die
SpeakMethode für ein zugrunde liegendes Synthesemodul übergeben werden soll.Wenn der TtsEngineAction Enumerationswert, der von der Action Eigenschaft für die FragmentState von der State Eigenschaft jeder TextFragment Instanz zurückgegeben wird, gefunden wird, lautet Speakdie Implementierung
Übersetzt den Amerikanischen Inserismus in den zu sprechenden Text.
Wenn die Eigenschaft für die EventInterestITtsEngineSite Schnittstellen, die der Implementierung bereitgestellt werden, den WordBoundary Ereignistyp unterstützen, wird eine SpeechEventInfo Instanz verwendet, um ein Ereignis zu erstellen, um eine Synthesizer-Statusanzeige zu steuern.
Die Parameter für SpeechEventInfo, einschließlich des EventParameterType von ParameterTypeihnen zurückgegebenen Memberwerts, werden verwendet, um das durch die
LogSpeechEventMethode generierte Ereignis zu protokollieren.
Anschließend wird ein Sprachrenderingmodul mit dem geänderten TextFragment Array aufgerufen.
private const int WordBoundaryFlag = 1 << (int)TtsEventId.WordBoundary;
private readonly char[] spaces = new char[] { ' ', '\t', '\r', '\n' };
internal struct UsVsUk
{
internal string UK;
internal string US;
}
override public void Speak (TextFragment [] frags, IntPtr wfx, ITtsEngineSite site)
{
TextFragment [] newFrags=new TextFragment[frags.Length];
for (int i=0;i<frags.Length;i++){
newFrags[i].State=frags[i].State;
//truncate
newFrags[i].TextToSpeak = frags[i].TextToSpeak.Substring(frags[i].TextOffset,
frags[i].TextLength);
newFrags[i].TextLength = newFrags[i].TextToSpeak.Length;
newFrags[i].TextOffset = 0;
if (newFrags[i].State.Action == TtsEngineAction.Speak) {
//Us to UK conversion
foreach (UsVsUk term in TransList) {
newFrags[i].TextToSpeak.Replace(term.US, term.UK);
}
//Generate progress meter events if supported
if ((site.EventInterest & WordBoundaryFlag) != 0) {
string[] subs = newFrags[i].TextToSpeak.Split(spaces);
foreach (string s in subs) {
int offset = newFrags[i].TextOffset;
SpeechEventInfo spEvent = new SpeechEventInfo((Int16)TtsEventId.WordBoundary,
(Int16)EventParameterType.Undefined,
s.Length, new IntPtr(offset));
LogSpeechEvent(spEvent.EventId,
spEvent.ParameterType,
spEvent.Param1,
spEvent.Param2);
offset += s.Length;
if (s.Trim().Length > 0) {
SpeechEventInfo[] events = new SpeechEventInfo[1];
events[0] = spEvent;
site.AddEvents(events, 1);
}
}
}
}
}
_baseSynthesize.Speak(newFrags, wfx, site);
}
Hinweise
Die EventParameterType Aufzählung wird beim Erstellen eines SpeechEventInfo Objekts verwendet. Ein Enumerationsmememm EventParameterType , der parameterType als Argument an den Konstruktor übergeben wird, gibt SpeechEventInfo an, wie das param2 Argument des Konstruktors (das ein IntPtr) interpretiert wird.
Die Auswahl EventParameterType wird durch den Typ des angeforderten Ereignisses bestimmt, wie durch ein Mitglied angegeben System.Speech.Synthesis.TtsEngine.TtsEventId.
Ausführliche Informationen zur Verwendung EventParameterTypefinden Sie in der Dokumentation EventId
Hinweis
Derzeit können Instanzen von verwalteten synthetischen Sprachmodulen, die mit den Membern des System.Speech.Synthesis Namespaces geschrieben wurden, ressourcen nach der Erstellung nicht mehr ändern.