SrgsDocument Constructors

Definitie

Initialiseert een nieuw exemplaar van de SrgsDocument klasse.

Overloads

Name Description
SrgsDocument()

Initialiseert een nieuw exemplaar van de SrgsDocument klasse.

SrgsDocument(GrammarBuilder)

Initialiseert een nieuw exemplaar van de SrgsDocument klasse van een GrammarBuilder object.

SrgsDocument(SrgsRule)

Initialiseert een nieuw exemplaar van de SrgsDocument klasse en geeft een SrgsRule object op dat de hoofdregel van de grammatica moet zijn.

SrgsDocument(String)

Initialiseert een nieuw exemplaar van de SrgsDocument klasse waarin de locatie wordt opgegeven van het XML-document dat wordt gebruikt om het SrgsDocument exemplaar in te vullen.

SrgsDocument(XmlReader)

Initialiseert een nieuw exemplaar van de SrgsDocument klasse vanuit een exemplaar van XmlReader die verwijst naar een grammaticabestand in de XML-indeling.

Opmerkingen

Met behulp van de constructors voor de SrgsDocument klasse kunt u een exemplaar van een GrammarBuilder, SrgsRuleof XmlReader object maken op basis van SrgsDocument een tekenreeks die het pad naar een grammatica in XML-indeling bevat, of u kunt een leeg exemplaar van SrgsDocument.

SrgsDocument()

Initialiseert een nieuw exemplaar van de SrgsDocument klasse.

public:
 SrgsDocument();
public SrgsDocument();
Public Sub New ()

Voorbeelden

In het volgende voorbeeld wordt een SrgsDocument object gemaakt en wordt vervolgens een openbare regel gemaakt met de naam winnerRule. Vervolgens wordt er een SrgsItem gemaakt die bestaat uit de tekenreeks "Een natie die de Wereldbeker heeft gewonnen is:", en voegt dit item toe aan de Elements eigenschap van de regel. In het voorbeeld worden vervolgens nog twee regels (ruleEurope en ruleSAmerica) gemaakt, die elk een SrgsOneOf object zijn dat drie SrgsItem objecten bevat. Daarna wordt een ander SrgsOneOf object gemaakt dat objecten bevat SrgsRuleRef die verwijzen naar ruleEurope en ruleSAmerica. Het nieuwe SrgsOneOf object wordt vervolgens toegevoegd aan de Elements eigenschap van winnerRule. Daarna worden alle drie de regels (winnerRule, ruleEuropeen ruleSAmerica) toegevoegd aan de Rules eigenschap van SrgsDocument. Ten slotte worden de drie regels gecompileerd in een binaire weergave van de grammatica.

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;

  String fileName = Path.GetTempFileName();
  using (FileStream stream = new FileStream(fileName, FileMode.Create))
  {

    // Compile the grammar to a binary format.
    SrgsGrammarCompiler.Compile(document, stream);
  }
}

Opmerkingen

Met deze constructor wordt een leeg SrgsDocument exemplaar gemaakt. Als u een grammatica wilt maken binnen een leeg SrgsDocument exemplaar, voegt u exemplaren van klassen toe die SRGS-elementen vertegenwoordigen, zoals SrgsRule, SrgsRuleRef, SrgsOneOfen SrgsItem.

Van toepassing op

SrgsDocument(GrammarBuilder)

Initialiseert een nieuw exemplaar van de SrgsDocument klasse van een GrammarBuilder object.

public:
 SrgsDocument(System::Speech::Recognition::GrammarBuilder ^ builder);
public SrgsDocument(System.Speech.Recognition.GrammarBuilder builder);
new System.Speech.Recognition.SrgsGrammar.SrgsDocument : System.Speech.Recognition.GrammarBuilder -> System.Speech.Recognition.SrgsGrammar.SrgsDocument
Public Sub New (builder As GrammarBuilder)

Parameters

builder
GrammarBuilder

Het GrammarBuilder object dat wordt gebruikt om het SrgsDocument exemplaar te maken.

Uitzonderingen

builder is null.

Voorbeelden

In het volgende voorbeeld wordt een grammatica in een GrammarBuilder exemplaar gebouwd met behulp van Choices objecten. Vervolgens wordt er een SrgsDocument van het GrammarBuilder object gemaakt.

GrammarBuilder builder = null;

// Create new Choices objects and add countries/regions, and create GrammarBuilder objects.
Choices choicesEurope = new Choices(new string[] { "England", "France", "Germany", "Italy" });
GrammarBuilder europe = new GrammarBuilder(choicesEurope);

Choices choicesSAmerica = new Choices(new string[] { "Argentina", "Brazil", "Uruguay" });
GrammarBuilder sAmerica = new GrammarBuilder(choicesSAmerica);

Choices worldCupWinnerChoices = new Choices(new GrammarBuilder[] {choicesEurope, choicesSAmerica});

// Create new GrammarBuilder from a Choices object.
builder = new GrammarBuilder(worldCupWinnerChoices);

// Create an SrgsDocument object from a GrammarBuilder object.
SrgsDocument document = new SrgsDocument(builder);

Van toepassing op

SrgsDocument(SrgsRule)

Initialiseert een nieuw exemplaar van de SrgsDocument klasse en geeft een SrgsRule object op dat de hoofdregel van de grammatica moet zijn.

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

Parameters

grammarRootRule
SrgsRule

Het root rule object SrgsDocument .

Uitzonderingen

grammarRootRule is null.

Voorbeelden

In het volgende voorbeeld worden twee regels (chooseCities en destCities) gemaakt voor het kiezen van steden voor oorsprong en bestemming voor een vlucht. In het voorbeeld wordt het SrgsDocument exemplaar geïnitialiseerd met behulp van de chooseCities regel als argument. In het voorbeeld wordt de inhoud van de regelsverzameling en de naam van de hoofdregel naar de console geschreven.

// Create a rule that contains a list of destination cities.
SrgsRule destCities = new SrgsRule("Destination");
SrgsOneOf toCities = new SrgsOneOf(new string[] { "New York", "Seattle", "Denver" });
destCities.Add(toCities);

// Create a list of origin cities and supporting phrases.
SrgsOneOf fromCities = new SrgsOneOf(new SrgsItem[] {
  new SrgsItem("Dallas"), new SrgsItem("Miami"), new SrgsItem("Chicago") });
SrgsItem intro = new SrgsItem("I want to fly from");
SrgsItem to = new SrgsItem("to");

// Create the root rule of the grammar, and assemble the components.
SrgsRule chooseCities = new SrgsRule("Trip");
chooseCities.Add(intro);
chooseCities.Add(fromCities);
chooseCities.Add(to);
chooseCities.Add(new SrgsRuleRef(destCities));

// Create the SrgsDocument and specify the root rule to add.
SrgsDocument bookFlight = new SrgsDocument(chooseCities);

// Add the rule for the destination cities to the document's rule collection.
bookFlight.Rules.Add(new SrgsRule[] { destCities });

// Display the contents of the Rules collection and the name of the root rule.
foreach (SrgsRule rule in bookFlight.Rules)
{
  Console.WriteLine("Rule " + rule.Id + " is in the rules collection");
}
Console.WriteLine("Root Rule " + bookFlight.Root.Id);

// Create a Grammar object and load it to the recognizer.
Grammar g = new Grammar(bookFlight);
g.Name = ("City Chooser");
recognizer.LoadGrammarAsync(g);

Opmerkingen

Deze constructor voegt de opgegeven regel toe aan het SrgsRulesCollectionSrgsDocument object en stelt deze in als de Root regel voor de grammatica.

Van toepassing op

SrgsDocument(String)

Initialiseert een nieuw exemplaar van de SrgsDocument klasse waarin de locatie wordt opgegeven van het XML-document dat wordt gebruikt om het SrgsDocument exemplaar in te vullen.

public:
 SrgsDocument(System::String ^ path);
public SrgsDocument(string path);
new System.Speech.Recognition.SrgsGrammar.SrgsDocument : string -> System.Speech.Recognition.SrgsGrammar.SrgsDocument
Public Sub New (path As String)

Parameters

path
String

De locatie van het SRGS XML-bestand.

Uitzonderingen

path is null.

path is een lege tekenreeks.

Voorbeelden

In het volgende voorbeeld wordt een nieuw SrgsDocument bestand gemaakt met de naam 'srgsDocumentFile.xml'.

string srgsDocumentFile = Path.Combine(Path.GetTempPath(), "srgsDocumentFile.xml");
SrgsDocument document = null;

if (File.Exists(srgsDocumentFile))
   document = new SrgsDocument(srgsDocumentFile);

Opmerkingen

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.

Van toepassing op

SrgsDocument(XmlReader)

Initialiseert een nieuw exemplaar van de SrgsDocument klasse vanuit een exemplaar van XmlReader die verwijst naar een grammaticabestand in de XML-indeling.

public:
 SrgsDocument(System::Xml::XmlReader ^ srgsGrammar);
public SrgsDocument(System.Xml.XmlReader srgsGrammar);
new System.Speech.Recognition.SrgsGrammar.SrgsDocument : System.Xml.XmlReader -> System.Speech.Recognition.SrgsGrammar.SrgsDocument
Public Sub New (srgsGrammar As XmlReader)

Parameters

srgsGrammar
XmlReader

Het XmlReader object dat is gemaakt met het SrgsDocument XML-exemplaar.

Uitzonderingen

srgsGrammar is null.

Voorbeelden

In het volgende voorbeeld wordt een nieuw exemplaar gemaakt van SrgsDocument een exemplaar van XmlReader dat verwijst naar het bestand 'srgsDocumentFile.xml'.

string srgsDocumentFile = Path.Combine(Path.GetTempPath(), "srgsDocumentFile.xml");
SrgsDocument document = null;

if (File.Exists(srgsDocumentFile))
{
  XmlReader reader = XmlReader.Create(srgsDocumentFile);
  document = new SrgsDocument(reader);
  reader.Close();
}

Opmerkingen

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.

Van toepassing op