SpeechEventInfo.ParameterType SpeechEventInfo.ParameterType SpeechEventInfo.ParameterType SpeechEventInfo.ParameterType Property

Definición

Devuelve el tipo de datos del objeto al que señala IntPtr devuelto por el parámetro Param2 en el objeto SpeechEventInfo actual.Returns the data type of the object pointed to by the IntPtr returned by the Param2 parameter on the current SpeechEventInfo object.

public:
 property short ParameterType { short get(); };
public short ParameterType { get; }
member this.ParameterType : int16
Public ReadOnly Property ParameterType As Short

Valor de propiedad

Un valor de short correspondiente a un miembro de la enumeración EventParameterType que indica el tipo de datos del objeto al que apunta el IntPtr devuelto por el parámetro Param2 y que se usa como segundo argumento del constructor del objeto SpeechEventInfo actual.A short value corresponding to a member of the EventParameterType enumeration and indicating the data type of the object pointed to by the IntPtr returned by the Param2 parameter and used as the second argument for the constructor of the current SpeechEventInfo object.

Ejemplos

El ejemplo siguiente es parte de una implementación de síntesis de voz personalizado hereda de TtsEngineSsmly el uso de la utilización de TextFragment, SpeechEventInfo, FragmentState, y TtsEventIdThe example below is part of a custom speech synthesis implementation inheriting from TtsEngineSsml, and using the use of TextFragment, SpeechEventInfo, FragmentState, and TtsEventId

La implementación de SpeakThe implementation of Speak

  1. Recibe una matriz de TextFragment instancias y crea una nueva matriz de TextFragment instancias que se pasarán a la Speak método en un motor de síntesis subyacente.Receives an array of TextFragment instances and creates a new array of TextFragment instances to be passed to the Speak method on an underlying synthesis engine.

  2. Si el TtsEngineAction por se encuentra el valor de enumeración de la Action propiedad en el FragmentState devuelto por la State propiedad de cada uno TextFragment instancia es Speak, la implementaciónIf the TtsEngineAction enumeration value by found from the Action property on the FragmentState returned by the State property of each TextFragment instance is Speak, the implementation

    • Americanism a Britishisms se traduce en el texto que se hablará.Translates Americanism to Britishisms in the text to be spoken.

    • Si el EventInterest propiedad en el ITtsEngineSite interfaces proporcionadas con el soporte técnico de implementación el WordBoundary tipo de evento, un SpeechEventInfo instancia se utiliza para crear un evento a la unidad que se crea un indicador de progreso de sintetizador.If the EventInterest property on the ITtsEngineSite interfaces provided to the implementation support the WordBoundary event type, a SpeechEventInfo instance is used to create an event to drive a synthesizer progress meter is created.

      Los parámetros en SpeechEventInfo, incluidos ParameterType se utilizan para iniciar el evento generado mediante la LogSpeechEvent método.The parameters on SpeechEventInfo, including ParameterType are used to log the event generated through the LogSpeechEvent method.

  3. A continuación, se llama a un motor de representación de voz con modificado TextFragment matriz.A speech rendering engine is then called with the modified TextFragment array.

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);  

}  

Comentarios

Los requisitos en el System.IntPtr referencia de la Param2 propiedad de SpeechEventInfo se determinan de forma exclusiva por los valores de la EventId y ParameterType propiedades el SpeechEventInfo instancia.The requirements on the System.IntPtr reference of the Param2 property of SpeechEventInfo are uniquely determined by the values of the EventId and ParameterType properties the SpeechEventInfo instance.

Para obtener información detallada acerca de cómo usar Param2, consulte la documentación de EventId.For detailed information on how use Param2, see documentation for EventId.

Se aplica a