SpeechEventInfo 结构
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
用于指定事件的类型及其将生成的参数(如果有的话)作为文本呈现到语音一部分由自定义复合语音引擎。
public value class SpeechEventInfo : IEquatable<System::Speech::Synthesis::TtsEngine::SpeechEventInfo>
public struct SpeechEventInfo : IEquatable<System.Speech.Synthesis.TtsEngine.SpeechEventInfo>
type SpeechEventInfo = struct
Public Structure SpeechEventInfo
Implements IEquatable(Of SpeechEventInfo)
- 继承
- 实现
示例
以下示例是继承自 的自定义语音合成实现(使用 TtsEngineSsml TextFragment 、、 和 )的 SpeechEventInfo FragmentState 一部分 TtsEventId
的实现 Speak
接收 实例的数组,并创建要传递到基础合成引擎上的 TextFragment TextFragment
Speak
方法的新实例数组。如果从 每个实例的 属性返回的 的 属性找到 的枚举值为 ,则 TtsEngineAction Action FragmentState State TextFragment Speak 实现
在要说出的文本中将美国语翻译为"英国"。
如果提供给实现的接口上的 属性支持事件类型,则实例用于创建事件,以驱动 EventInterest ITtsEngineSite 合成器 WordBoundary SpeechEventInfo 进度计量的创建。
然后,使用修改后的数组调用语音呈现 TextFragment 引擎。
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));
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);
}
注解
自定义语音合成引擎通过向传递给 、 和 的实现的引擎站点对象的成员提供适当的实例,请求在语音平台下生成 SpeechEventInfo AddEvents ITtsEngineSite Speak AddLexicon 事件 RemoveLexicon 。
构造函数
SpeechEventInfo(Int16, Int16, Int32, IntPtr) |
构造相应的 SpeechEventInfo。 |
属性
EventId |
获取和设置 SpeechEventInfo 实例用于请求的语音平台事件。 |
Param1 |
获取和设置 |
Param2 |
获取和设置 |
ParameterType |
返回当前 Param2 对象上的 SpeechEventInfo 参数返回的 IntPtr 所指向的对象的数据类型。 |
方法
Equals(Object) |
确定指定的对象是否为 |
Equals(SpeechEventInfo) |
确定指定的 |
GetHashCode() |
提供 |
运算符
Equality(SpeechEventInfo, SpeechEventInfo) |
确定两个 |
Inequality(SpeechEventInfo, SpeechEventInfo) |
确定两个 |