Compartir vía


SrgsRuleRef Constructores

Definición

Inicializa una nueva instancia de la clase SrgsRuleRef.

Sobrecargas

SrgsRuleRef(SrgsRule)

Inicializa una nueva instancia de la clase SrgsRuleRef que y especifica la regla de la referencia.

SrgsRuleRef(Uri)

Inicializa una nueva instancia de la clase SrgsRuleRef y especifica la ubicación del archivo de gramática externo al que se va a hacer referencia.

SrgsRuleRef(SrgsRule, String)

Inicializa una nueva instancia de la clase SrgsRuleRef, que especifica la regla a que se hace referencia y una cadena que contiene una clave semántica.

SrgsRuleRef(Uri, String)

Inicializa una nueva instancia de la clase SrgsRuleRef, que especifica la ubicación del archivo de gramática externo y el identificador de la regla a que se va a hacer referencia.

SrgsRuleRef(SrgsRule, String, String)

Inicializa una nueva instancia de la clase SrgsRuleRef, que especifica la regla a que se hace referencia, el alias de cadena del diccionario de semántica y los parámetros de inicialización.

SrgsRuleRef(Uri, String, String)

Inicializa una nueva instancia de la clase SrgsRuleRef, que especifica la ubicación del archivo de gramática externo, el identificador de la regla y el alias de cadena del diccionario de semántica.

SrgsRuleRef(Uri, String, String, String)

Inicializa una nueva instancia de la clase SrgsRuleRef, que especifica la ubicación del archivo de gramática externo, el identificador de la regla, el alias de cadena del diccionario de semántica y los parámetros de inicialización.

SrgsRuleRef(SrgsRule)

Source:
SrgsRuleRef.cs
Source:
SrgsRuleRef.cs
Source:
SrgsRuleRef.cs

Inicializa una nueva instancia de la clase SrgsRuleRef que y especifica la regla de la referencia.

public:
 SrgsRuleRef(System::Speech::Recognition::SrgsGrammar::SrgsRule ^ rule);
public SrgsRuleRef (System.Speech.Recognition.SrgsGrammar.SrgsRule rule);
new System.Speech.Recognition.SrgsGrammar.SrgsRuleRef : System.Speech.Recognition.SrgsGrammar.SrgsRule -> System.Speech.Recognition.SrgsGrammar.SrgsRuleRef
Public Sub New (rule As SrgsRule)

Parámetros

rule
SrgsRule

El objeto al que se va a hacer referencia.

Excepciones

rule es null.

Ejemplos

En el ejemplo siguiente se crea una gramática que reconoce la frase "Una nación que ha ganado la Copa Mundial" seguida del nombre de un país que ha ganado la Copa Mundial. Después de crear el SrgsRule objeto winnerRule y darle el identificador WorldCupWinnerde cadena , el ejemplo anexa la cadena "A nation that has won the World Cup is" to the rule. Con SrgsOneOf objetos , el ejemplo crea una lista de países o regiones europeos y una lista de países o regiones de América del Sur, y agrega cada lista a su regla respectiva, ruleEurope o ruleSAmerica. A continuación, el ejemplo crea referencias de regla para ruleEurope y ruleSAmerica las agrega a la WorldCupWinner regla.

public void WorldSoccerWinners ()
{

  // Create an SrgsDocument, create a new rule
  // and set its scope to public.
  SrgsDocument document = new SrgsDocument();
  SrgsRule winnerRule = new SrgsRule("WorldCupWinner");
  winnerRule.Scope = SrgsRuleScope.Public;

  // Add the introduction.
  winnerRule.Elements.Add(new SrgsItem("A nation that has won the world cup is: "));

  // Create the rule for the European nations.
  SrgsOneOf oneOfEurope = new SrgsOneOf(new SrgsItem[] {new SrgsItem("England"),
    new SrgsItem("France"), new SrgsItem("Germany"), new SrgsItem("Italy")});
  SrgsRule ruleEurope = (new SrgsRule("EuropeanNations", new SrgsElement[] {oneOfEurope}));

  // Create the rule for the South American nations.
  SrgsOneOf oneOfSAmerica = new SrgsOneOf(new SrgsItem[] {new SrgsItem("Argentina"),
    new SrgsItem("Brazil"), new SrgsItem("Uruguay")});
  SrgsRule ruleSAmerica = (new SrgsRule("SouthAmericanNations", new SrgsElement[] {oneOfSAmerica}));

  // Add references to winnerRule for ruleEurope and ruleSAmerica.
  winnerRule.Elements.Add(new SrgsOneOf(new SrgsItem[] {(new SrgsItem
    (new SrgsRuleRef(ruleEurope))), new SrgsItem(new SrgsRuleRef(ruleSAmerica))}));

  // Add all the rules to the document and make winnerRule
  // the root rule of the document.
  document.Rules.Add(new SrgsRule[] {winnerRule, ruleEurope, ruleSAmerica});
  document.Root = winnerRule;
}

La gramática creada tiene el siguiente formato.

<grammar version="1.0" xml:lang="en-US" xmlns="http://www.w3.org/2001/06/grammar" root="WorldCupWinner">
    <rule id="WorldCupWinner" scope="public">
        <item> A nation that has won the world cup is </item>
        <one-of>
            <item>
                <ruleref uri="#EuropeanNations" />
            </item>
            <item>
                <ruleref uri="#SouthAmericanNations" />
            </item>
        </one-of>
    </rule>
    <rule id="EuropeanNations">
        <one-of>
            <item> England </item>
            <item> France </item>
            <item> Germany </item>
            <item> Italy </item>
        </one-of>
    </rule>
    <rule id="SouthAmericanNations">
        <one-of>
            <item> Argentina </item>
            <item> Brazil </item>
            <item> Uruguay </item>
        </one-of>
    </rule>
</grammar>

Comentarios

Este constructor crea una referencia de regla a un SrgsRule objeto dentro de la gramática contenedora. Para crear una referencia de regla a un rule elemento de un archivo de gramática externo, use cualquiera de los constructores siguientes:

Consulte también

Se aplica a

SrgsRuleRef(Uri)

Source:
SrgsRuleRef.cs
Source:
SrgsRuleRef.cs
Source:
SrgsRuleRef.cs

Inicializa una nueva instancia de la clase SrgsRuleRef y especifica la ubicación del archivo de gramática externo al que se va a hacer referencia.

public:
 SrgsRuleRef(Uri ^ uri);
public SrgsRuleRef (Uri uri);
new System.Speech.Recognition.SrgsGrammar.SrgsRuleRef : Uri -> System.Speech.Recognition.SrgsGrammar.SrgsRuleRef
Public Sub New (uri As Uri)

Parámetros

uri
Uri

La ubicación de un archivo de gramática fuera de la gramática contenedora.

Excepciones

uri es null.

Ejemplos

En el ejemplo siguiente se crea una gramática para una aplicación que devuelve información sobre el servicio de traslado de autobús. El primer método, GrammarUrlForRoute, toma una cadena que especifica una ruta y la anexa a una cadena que especifica la ubicación de una gramática. Esto especifica una regla determinada en esa gramática. El método devuelve un Uri para esa regla.

El segundo método, CreateGrammarForRoute, crea un SrgsDocument elemento denominado grammar con una referencia de regla especificada por el Uri objeto pasado por GrammarUrlForRoute. Tenga en cuenta que la variable denominada _route es miembro de una clase envolvente.

private Uri GrammarUrlForRoute(string route)
{
  return new Uri("http://localhost/MyBus/MyBusLocations.grxml#LocationsForRoute" + route);
}

private SrgsDocument CreateGrammarForRoute()
{
  SrgsDocument grammar = new SrgsDocument();
  grammar.Mode = SrgsGrammarMode.Voice;
  SrgsRule rule = new SrgsRule("LocationsForRoute" + _route);
  SrgsRuleRef ruleref = new SrgsRuleRef(GrammarUrlForRoute(_route));

  SrgsSemanticInterpretationTag tag = new SrgsSemanticInterpretationTag ("$.Location = $$");

  rule.Elements.Add(ruleref);
  rule.Elements.Add(tag);
  grammar.Rules.Add(rule);
  grammar.Root = rule;
  return grammar;
}

Nota:

La variable denominada _route no está declarada y no definida en el ejemplo anterior. Debe declararse como String y contener el número de ruta de una ruta de bus determinada antes de que se compile y ejecute el ejemplo anterior.

Comentarios

Este constructor crea una referencia de regla a un archivo de gramática externo. El URI también puede incluir el identificador de una regla a la que hacer referencia, por ejemplo http://www.contoso.com/ExternalGrammar.grxml#targetRule. Si el uri parámetro no especifica un identificador de regla, la referencia de regla apunta a la regla raíz de la gramática de destino. Para crear una referencia de regla a un SrgsRule objeto dentro de la misma gramática, use cualquiera de los siguientes constructores:

Consulte también

Se aplica a

SrgsRuleRef(SrgsRule, String)

Source:
SrgsRuleRef.cs
Source:
SrgsRuleRef.cs
Source:
SrgsRuleRef.cs

Inicializa una nueva instancia de la clase SrgsRuleRef, que especifica la regla a que se hace referencia y una cadena que contiene una clave semántica.

public:
 SrgsRuleRef(System::Speech::Recognition::SrgsGrammar::SrgsRule ^ rule, System::String ^ semanticKey);
public SrgsRuleRef (System.Speech.Recognition.SrgsGrammar.SrgsRule rule, string semanticKey);
new System.Speech.Recognition.SrgsGrammar.SrgsRuleRef : System.Speech.Recognition.SrgsGrammar.SrgsRule * string -> System.Speech.Recognition.SrgsGrammar.SrgsRuleRef
Public Sub New (rule As SrgsRule, semanticKey As String)

Parámetros

rule
SrgsRule

El objeto al que se va a hacer referencia.

semanticKey
String

La clave semántica.

Ejemplos

En el ejemplo siguiente se crea una gramática para elegir las ciudades de un vuelo. En el ejemplo se crean dos SrgsRuleRef instancias, cada una de las cuales especifica una clave semántica. Ambas referencias de regla tienen como destino el mismo SrgsRule objeto, denominado cities, pero etiquetan el resultado de reconocimiento de la referencia de regla con una clave semántica diferente. La clave semántica identifica una ciudad reconocida como la ciudad de salida o la ciudad de llegada para el vuelo. El controlador del SpeechRecognized evento usa las claves para recuperar los valores semánticos creados mediante SrgsNameValueTag el resultado del reconocimiento.

using System;
using System.Speech.Recognition;
using System.Speech.Recognition.SrgsGrammar;

namespace SampleRecognition
{
  class Program
  {
    static void Main(string[] args)

    // Initialize a SpeechRecognitionEngine object.
    {
      using (SpeechRecognitionEngine recognizer =
         new SpeechRecognitionEngine(new System.Globalization.CultureInfo("en-US")))
      {

        // Build a rule with a list of cities, assign a semantic value to each city.
        SrgsItem chi = new SrgsItem("Chicago");
        chi.Add(new SrgsNameValueTag("ORD"));
        SrgsItem bos = new SrgsItem("Boston");
        bos.Add(new SrgsNameValueTag("BOS"));
        SrgsItem mia = new SrgsItem("Miami");
        mia.Add(new SrgsNameValueTag("MIA"));
        SrgsItem dal = new SrgsItem("Dallas");
        dal.Add(new SrgsNameValueTag("DFW"));

        SrgsOneOf cities = new SrgsOneOf(new SrgsItem[] { chi, bos, mia, dal });
        SrgsRule citiesRule = new SrgsRule("flightCities");
        citiesRule.Add(cities);

        // Build the root rule, add rule references to the cities rule.
        SrgsRule flightBooker = new SrgsRule("bookFlight");
        flightBooker.Add(new SrgsItem("I want to fly from"));
        flightBooker.Add(new SrgsRuleRef(citiesRule, "departureCity"));
        flightBooker.Add(new SrgsItem("to"));
        flightBooker.Add(new SrgsRuleRef(citiesRule, "arrivalCity"));

        // Build an SrgsDocument object from the flightBooker rule and add the cities rule.
        SrgsDocument cityChooser = new SrgsDocument(flightBooker);
        cityChooser.Rules.Add(citiesRule);

        // Create a Grammar object from the SrgsDocument and load it to the recognizer.
        Grammar departArrive = new Grammar(cityChooser);
        departArrive.Name = ("Cities Grammar");
        recognizer.LoadGrammarAsync(departArrive);

        // Configure recognizer input.
        recognizer.SetInputToDefaultAudioDevice();

        // Attach a handler for the SpeechRecognized event.
        recognizer.SpeechRecognized +=
          new EventHandler<SpeechRecognizedEventArgs>(recognizer_SpeechRecognized);

        // Start asynchronous recognition.
        recognizer.RecognizeAsync();
        Console.WriteLine("Starting asynchronous recognition...");

        // Keep the console window open.
        Console.ReadLine();
      }
    }

    // Handle the SpeechRecognized event.
    static void recognizer_SpeechRecognized(object sender, SpeechRecognizedEventArgs e)
    {
      Console.WriteLine("Speech recognized: " + e.Result.Text);
      Console.WriteLine();
      Console.WriteLine("Semantic results:");
      Console.WriteLine("  The departure city is: " + e.Result.Semantics["departureCity"].Value);
      Console.WriteLine("  The destination city is: " + e.Result.Semantics["arrivalCity"].Value);
    }
  }
}

Comentarios

Este constructor crea una referencia de regla a un SrgsRule objeto dentro de la gramática contenedora. Para crear una referencia de regla a un rule elemento de un archivo de gramática externo, use cualquiera de los constructores siguientes:

Consulte también

Se aplica a

SrgsRuleRef(Uri, String)

Source:
SrgsRuleRef.cs
Source:
SrgsRuleRef.cs
Source:
SrgsRuleRef.cs

Inicializa una nueva instancia de la clase SrgsRuleRef, que especifica la ubicación del archivo de gramática externo y el identificador de la regla a que se va a hacer referencia.

public:
 SrgsRuleRef(Uri ^ uri, System::String ^ rule);
public SrgsRuleRef (Uri uri, string rule);
new System.Speech.Recognition.SrgsGrammar.SrgsRuleRef : Uri * string -> System.Speech.Recognition.SrgsGrammar.SrgsRuleRef
Public Sub New (uri As Uri, rule As String)

Parámetros

uri
Uri

La ubicación de un archivo de gramática fuera de la gramática contenedora.

rule
String

El identificador de la regla para hacer referencia.

Excepciones

uri es null.

rule es null.

rule está vacía.

Comentarios

Este constructor crea una referencia de regla a un rule elemento de un archivo de gramática externo. Para crear una referencia de regla a un SrgsRule objeto dentro de la misma gramática, use cualquiera de los siguientes constructores:

Consulte también

Se aplica a

SrgsRuleRef(SrgsRule, String, String)

Source:
SrgsRuleRef.cs
Source:
SrgsRuleRef.cs
Source:
SrgsRuleRef.cs

Inicializa una nueva instancia de la clase SrgsRuleRef, que especifica la regla a que se hace referencia, el alias de cadena del diccionario de semántica y los parámetros de inicialización.

public:
 SrgsRuleRef(System::Speech::Recognition::SrgsGrammar::SrgsRule ^ rule, System::String ^ semanticKey, System::String ^ parameters);
public SrgsRuleRef (System.Speech.Recognition.SrgsGrammar.SrgsRule rule, string semanticKey, string parameters);
new System.Speech.Recognition.SrgsGrammar.SrgsRuleRef : System.Speech.Recognition.SrgsGrammar.SrgsRule * string * string -> System.Speech.Recognition.SrgsGrammar.SrgsRuleRef
Public Sub New (rule As SrgsRule, semanticKey As String, parameters As String)

Parámetros

rule
SrgsRule

El objeto al que se va a hacer referencia.

semanticKey
String

La clave semántica.

parameters
String

Los parámetros de inicialización de un objeto SrgsRuleRef.

Comentarios

Este constructor crea una referencia de regla a un SrgsRule objeto dentro de la gramática contenedora. Para crear una referencia de regla a un rule elemento de un archivo de gramática externo, use cualquiera de los constructores siguientes:

Consulte también

Se aplica a

SrgsRuleRef(Uri, String, String)

Source:
SrgsRuleRef.cs
Source:
SrgsRuleRef.cs
Source:
SrgsRuleRef.cs

Inicializa una nueva instancia de la clase SrgsRuleRef, que especifica la ubicación del archivo de gramática externo, el identificador de la regla y el alias de cadena del diccionario de semántica.

public:
 SrgsRuleRef(Uri ^ uri, System::String ^ rule, System::String ^ semanticKey);
public SrgsRuleRef (Uri uri, string rule, string semanticKey);
new System.Speech.Recognition.SrgsGrammar.SrgsRuleRef : Uri * string * string -> System.Speech.Recognition.SrgsGrammar.SrgsRuleRef
Public Sub New (uri As Uri, rule As String, semanticKey As String)

Parámetros

uri
Uri

La ubicación de un archivo de gramática fuera de la gramática contenedora.

rule
String

El identificador de la regla para hacer referencia.

semanticKey
String

Una cadena de alias para el diccionario de semántica.

Excepciones

uri es null.

semanticKey es null.

semanticKey está vacía.

Comentarios

Este constructor crea una referencia de regla a un rule elemento de un archivo de gramática externo. Para crear una referencia de regla a un SrgsRule objeto dentro de la misma gramática, use cualquiera de los siguientes constructores:

Consulte también

Se aplica a

SrgsRuleRef(Uri, String, String, String)

Source:
SrgsRuleRef.cs
Source:
SrgsRuleRef.cs
Source:
SrgsRuleRef.cs

Inicializa una nueva instancia de la clase SrgsRuleRef, que especifica la ubicación del archivo de gramática externo, el identificador de la regla, el alias de cadena del diccionario de semántica y los parámetros de inicialización.

public:
 SrgsRuleRef(Uri ^ uri, System::String ^ rule, System::String ^ semanticKey, System::String ^ parameters);
public SrgsRuleRef (Uri uri, string rule, string semanticKey, string parameters);
new System.Speech.Recognition.SrgsGrammar.SrgsRuleRef : Uri * string * string * string -> System.Speech.Recognition.SrgsGrammar.SrgsRuleRef
Public Sub New (uri As Uri, rule As String, semanticKey As String, parameters As String)

Parámetros

uri
Uri

La ubicación de un archivo de gramática fuera de la gramática contenedora.

rule
String

El identificador de la regla para hacer referencia.

semanticKey
String

La clave semántica.

parameters
String

Los parámetros de inicialización de un objeto SrgsRuleRef.

Comentarios

Este constructor crea una referencia de regla a un rule elemento de un archivo de gramática externo. Para crear una referencia de regla a un SrgsRule objeto dentro de la misma gramática, use cualquiera de los siguientes constructores:

Consulte también

Se aplica a