SrgsRuleRef Constructors

Definitie

Initialiseert een nieuw exemplaar van de SrgsRuleRef klasse.

Overloads

Name Description
SrgsRuleRef(SrgsRule)

Initialiseert een nieuw exemplaar van de SrgsRuleRef klasse en geeft de regel op waarnaar moet worden verwezen.

SrgsRuleRef(Uri)

Initialiseert een nieuw exemplaar van de SrgsRuleRef klasse en geeft de locatie op van het externe grammaticabestand waarnaar moet worden verwezen.

SrgsRuleRef(SrgsRule, String)

Initialiseert een nieuw exemplaar van de SrgsRuleRef klasse, waarbij de regel wordt opgegeven waarnaar moet worden verwezen en een tekenreeks die een semantische sleutel bevat.

SrgsRuleRef(Uri, String)

Initialiseert een nieuw exemplaar van de SrgsRuleRef klasse, waarbij de locatie van het externe grammaticabestand en de id van de regel waarnaar moet worden verwezen, wordt opgegeven.

SrgsRuleRef(SrgsRule, String, String)

Initialiseert een nieuw exemplaar van de SrgsRuleRef klasse, waarbij de regel wordt opgegeven waarnaar moet worden verwezen, de tekenreeksalias van de semantische woordenlijst en initialisatieparameters.

SrgsRuleRef(Uri, String, String)

Initialiseert een nieuw exemplaar van de SrgsRuleRef klasse, waarbij de locatie van het externe grammaticabestand, de id van de regel en de tekenreeksalias van de semantische woordenlijst wordt opgegeven.

SrgsRuleRef(Uri, String, String, String)

Initialiseert een nieuw exemplaar van de SrgsRuleRef klasse, waarbij de locatie van het externe grammaticabestand, de id van de regel, de tekenreeksalias van de semantische woordenlijst en initialisatieparameters wordt opgegeven.

SrgsRuleRef(SrgsRule)

Initialiseert een nieuw exemplaar van de SrgsRuleRef klasse en geeft de regel op waarnaar moet worden verwezen.

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)

Parameters

rule
SrgsRule

Het object waarnaar moet worden verwezen.

Uitzonderingen

rule is null.

Voorbeelden

In het volgende voorbeeld wordt een grammatica gemaakt die de zin 'Een natie die de Wereldbeker heeft gewonnen' herkent, gevolgd door de naam van een land dat de Wereldbeker heeft gewonnen. Nadat u het SrgsRule object winnerRule hebt gemaakt en deze de tekenreeks-id WorldCupWinnerhebt gegeven, voegt het voorbeeld de tekenreeks 'Een natie die de Wereldbeker heeft gewonnen is' toe aan de regel. Met behulp van SrgsOneOf objecten bouwt het voorbeeld vervolgens een lijst met Europese landen/regio's en een lijst met Zuid-Amerikaanse landen/regio's en voegt elke lijst toe aan de respectieve regel, ruleEurope of ruleSAmerica. In het voorbeeld worden vervolgens regelverwijzingen gemaakt voor ruleEurope en ruleSAmerica toegevoegd aan de WorldCupWinner regel.

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

De gemaakte grammatica heeft het volgende formulier.

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

Opmerkingen

Met deze constructor wordt een regelverwijzing gemaakt naar een SrgsRule object binnen de grammatica. Als u een regelreferentie wilt maken naar een rule element in een extern grammaticabestand, gebruikt u een van de volgende constructors:

Zie ook

Van toepassing op

SrgsRuleRef(Uri)

Initialiseert een nieuw exemplaar van de SrgsRuleRef klasse en geeft de locatie op van het externe grammaticabestand waarnaar moet worden verwezen.

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)

Parameters

uri
Uri

De locatie van een grammaticabestand buiten de grammatica met grammatica.

Uitzonderingen

uri is null.

Voorbeelden

In het volgende voorbeeld wordt een grammatica gemaakt voor een toepassing die informatie retourneert over de pendeldienst van de bus. De eerste methode, GrammarUrlForRouteneemt een tekenreeks die een route opgeeft en voegt deze toe aan een tekenreeks die de locatie van een grammatica opgeeft. Hiermee geeft u een bepaalde regel in die grammatica op. De methode retourneert een Uri voor die regel.

Met de tweede methode maakt CreateGrammarForRouteu een SrgsDocument element met de naam grammar met een regelreferentie die is opgegeven door de Uri doorgegeven GrammarUrlForRoutemethode. Houd er rekening mee dat de variabele met de naam _route lid is van een insluitklasse.

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

Note

De variabele met de naam _route is niet gedeclareerd en niet gedefinieerd in het voorgaande voorbeeld. Het moet worden gedeclareerd als een String en bevatten het routenummer voor een bepaalde busroute voordat het voorgaande voorbeeld wordt gecompileerd en uitgevoerd.

Opmerkingen

Met deze constructor maakt u een regelreferentie naar een extern grammaticabestand. De URI kan bijvoorbeeld http://www.contoso.com/ExternalGrammar.grxml#targetRuleook de id van een regel bevatten waarnaar moet worden verwezen. Als de uri parameter geen regel-id opgeeft, verwijst de regelreferentie naar de hoofdregel van de doel grammatica. Als u een regelverwijzing naar een SrgsRule object binnen dezelfde grammatica wilt maken, gebruikt u een van de volgende constructors:

Important

Het gebruik van een exemplaar van dit type met niet-vertrouwde gegevens is een beveiligingsrisico. Gebruik dit object alleen met vertrouwde gegevens. Zie Alle invoergegevens validerenvoor meer informatie.

Zie ook

Van toepassing op

SrgsRuleRef(SrgsRule, String)

Initialiseert een nieuw exemplaar van de SrgsRuleRef klasse, waarbij de regel wordt opgegeven waarnaar moet worden verwezen en een tekenreeks die een semantische sleutel bevat.

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)

Parameters

rule
SrgsRule

Het object waarnaar moet worden verwezen.

semanticKey
String

De semantische sleutel.

Voorbeelden

In het volgende voorbeeld wordt een grammatica gemaakt voor het kiezen van de steden voor een vlucht. In het voorbeeld worden twee SrgsRuleRef exemplaren gemaakt, die elk een semantische sleutel opgeven. Beide regelverwijzingen richten zich op hetzelfde SrgsRule object met de naam cities, maar tag het herkenningsresultaat van de regelverwijzing met een andere semantische sleutel. De semantische sleutel identificeert een herkende stad als de vertrekstad of de aankomstplaats voor de vlucht. De handler voor de SpeechRecognized gebeurtenis gebruikt de sleutels om de semantiekwaarden op te halen die zijn gemaakt met behulp SrgsNameValueTag van het herkenningsresultaat.

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

Opmerkingen

Met deze constructor wordt een regelverwijzing gemaakt naar een SrgsRule object binnen de grammatica. Als u een regelreferentie wilt maken naar een rule element in een extern grammaticabestand, gebruikt u een van de volgende constructors:

Zie ook

Van toepassing op

SrgsRuleRef(Uri, String)

Initialiseert een nieuw exemplaar van de SrgsRuleRef klasse, waarbij de locatie van het externe grammaticabestand en de id van de regel waarnaar moet worden verwezen, wordt opgegeven.

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)

Parameters

uri
Uri

De locatie van een grammaticabestand buiten de grammatica met grammatica.

rule
String

De id van de regel waarnaar moet worden verwezen.

Uitzonderingen

uri is null.

rule is null.

Opmerkingen

Met deze constructor wordt een regelreferentie gemaakt naar een rule element in een extern grammaticabestand. Als u een regelverwijzing naar een SrgsRule object binnen dezelfde grammatica wilt maken, gebruikt u een van de volgende constructors:

Important

Het gebruik van een exemplaar van dit type met niet-vertrouwde gegevens is een beveiligingsrisico. Gebruik dit object alleen met vertrouwde gegevens. Zie Alle invoergegevens validerenvoor meer informatie.

Zie ook

Van toepassing op

SrgsRuleRef(SrgsRule, String, String)

Initialiseert een nieuw exemplaar van de SrgsRuleRef klasse, waarbij de regel wordt opgegeven waarnaar moet worden verwezen, de tekenreeksalias van de semantische woordenlijst en initialisatieparameters.

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)

Parameters

rule
SrgsRule

Het object waarnaar moet worden verwezen.

semanticKey
String

De semantische sleutel.

parameters
String

De initialisatieparameters voor een SrgsRuleRef object.

Opmerkingen

Met deze constructor wordt een regelverwijzing gemaakt naar een SrgsRule object binnen de grammatica. Als u een regelreferentie wilt maken naar een rule element in een extern grammaticabestand, gebruikt u een van de volgende constructors:

Zie ook

Van toepassing op

SrgsRuleRef(Uri, String, String)

Initialiseert een nieuw exemplaar van de SrgsRuleRef klasse, waarbij de locatie van het externe grammaticabestand, de id van de regel en de tekenreeksalias van de semantische woordenlijst wordt opgegeven.

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)

Parameters

uri
Uri

De locatie van een grammaticabestand buiten de grammatica met grammatica.

rule
String

De id van de regel waarnaar moet worden verwezen.

semanticKey
String

Een aliastekenreeks voor de semantische woordenlijst.

Uitzonderingen

uri is null.

semanticKey is null.

semanticKey is leeg.

Opmerkingen

Met deze constructor wordt een regelreferentie gemaakt naar een rule element in een extern grammaticabestand. Als u een regelverwijzing naar een SrgsRule object binnen dezelfde grammatica wilt maken, gebruikt u een van de volgende constructors:

Important

Het gebruik van een exemplaar van dit type met niet-vertrouwde gegevens is een beveiligingsrisico. Gebruik dit object alleen met vertrouwde gegevens. Zie Alle invoergegevens validerenvoor meer informatie.

Zie ook

Van toepassing op

SrgsRuleRef(Uri, String, String, String)

Initialiseert een nieuw exemplaar van de SrgsRuleRef klasse, waarbij de locatie van het externe grammaticabestand, de id van de regel, de tekenreeksalias van de semantische woordenlijst en initialisatieparameters wordt opgegeven.

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)

Parameters

uri
Uri

De locatie van een grammaticabestand buiten de grammatica met grammatica.

rule
String

De id van de regel waarnaar moet worden verwezen.

semanticKey
String

De semantische sleutel.

parameters
String

De initialisatieparameters voor een SrgsRuleRef object.

Opmerkingen

Met deze constructor wordt een regelreferentie gemaakt naar een rule element in een extern grammaticabestand. Als u een regelverwijzing naar een SrgsRule object binnen dezelfde grammatica wilt maken, gebruikt u een van de volgende constructors:

Important

Het gebruik van een exemplaar van dit type met niet-vertrouwde gegevens is een beveiligingsrisico. Gebruik dit object alleen met vertrouwde gegevens. Zie Alle invoergegevens validerenvoor meer informatie.

Zie ook

Van toepassing op