Compartilhar via


SrgsDocument Construtores

Definição

Inicializa uma nova instância da classe SrgsDocument.

Sobrecargas

Nome Description
SrgsDocument()

Inicializa uma nova instância da classe SrgsDocument.

SrgsDocument(GrammarBuilder)

Inicializa uma nova instância da classe de SrgsDocument um GrammarBuilder objeto.

SrgsDocument(SrgsRule)

Inicializa uma nova instância da SrgsDocument classe e especifica um SrgsRule objeto para ser a regra raiz da gramática.

SrgsDocument(String)

Inicializa uma nova instância da SrgsDocument classe especificando o local do documento XML que é usado para preencher a SrgsDocument instância.

SrgsDocument(XmlReader)

Inicializa uma nova instância da classe de uma instância que XmlReader faz referência a SrgsDocument um arquivo de gramática de formato XML.

Comentários

Usando os construtores para a SrgsDocument classe, você pode criar uma instância de SrgsDocument um GrammarBuilder, SrgsRuleou XmlReader objeto, de uma cadeia de caracteres que contém o caminho para uma gramática de formato XML ou você pode iniciar uma instância em branco de SrgsDocument.

SrgsDocument()

Origem:
SrgsDocument.cs
Origem:
SrgsDocument.cs
Origem:
SrgsDocument.cs
Origem:
SrgsDocument.cs

Inicializa uma nova instância da classe SrgsDocument.

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

Exemplos

O exemplo a seguir cria um SrgsDocument objeto e cria uma regra pública chamada winnerRule. Em seguida, ele cria um SrgsItem que consiste na cadeia de caracteres "Uma nação que ganhou a Copa do Mundo é:", e adiciona este item à Elements propriedade da regra. Em seguida, o exemplo cria mais duas regras (ruleEurope e ruleSAmerica), cada uma SrgsOneOf delas um objeto que contém três SrgsItem objetos. Depois disso, outro SrgsOneOf objeto é criado que contém objetos que se referem ruleEuropeSrgsRuleRef a e ruleSAmerica. Em seguida, o novo SrgsOneOf objeto é adicionado à Elements propriedade de winnerRule. Depois disso, todas as três regras (winnerRulee ruleEuroperuleSAmerica) são adicionadas à Rules propriedade de SrgsDocument. Por fim, as três regras são compiladas em uma representação binária da gramática.

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

Comentários

Esse construtor cria uma instância vazia SrgsDocument . Para criar uma gramática dentro de uma instância vaziaSrgsDocument, adicione instâncias de classes que representam elementos SRGS, como SrgsRule, SrgsRuleRefe SrgsOneOfSrgsItem.

Aplica-se a

SrgsDocument(GrammarBuilder)

Origem:
SrgsDocument.cs
Origem:
SrgsDocument.cs
Origem:
SrgsDocument.cs
Origem:
SrgsDocument.cs

Inicializa uma nova instância da classe de SrgsDocument um GrammarBuilder objeto.

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)

Parâmetros

builder
GrammarBuilder

O GrammarBuilder objeto usado para criar a SrgsDocument instância.

Exceções

builder é null.

Exemplos

O exemplo a seguir cria uma gramática em uma GrammarBuilder instância usando Choices objetos. Em seguida, ele cria um SrgsDocument a partir do GrammarBuilder objeto.

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

Aplica-se a

SrgsDocument(SrgsRule)

Origem:
SrgsDocument.cs
Origem:
SrgsDocument.cs
Origem:
SrgsDocument.cs
Origem:
SrgsDocument.cs

Inicializa uma nova instância da SrgsDocument classe e especifica um SrgsRule objeto para ser a regra raiz da gramática.

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)

Parâmetros

grammarRootRule
SrgsRule

O root rule no SrgsDocument objeto.

Exceções

grammarRootRule é null.

Exemplos

O exemplo a seguir cria duas regras (chooseCities e destCities) para escolher cidades de origem e destino para um voo. O exemplo inicializa a SrgsDocument instância usando a chooseCities regra como argumento. O exemplo grava o conteúdo da coleção de regras e o nome da regra raiz no console.

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

Comentários

Esse construtor adiciona a regra especificada ao SrgsRulesCollection objeto e a SrgsDocument define como a Root regra da gramática.

Aplica-se a

SrgsDocument(String)

Origem:
SrgsDocument.cs
Origem:
SrgsDocument.cs
Origem:
SrgsDocument.cs
Origem:
SrgsDocument.cs

Inicializa uma nova instância da SrgsDocument classe especificando o local do documento XML que é usado para preencher a SrgsDocument instância.

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)

Parâmetros

path
String

O local do arquivo XML SRGS.

Exceções

path é null.

path é uma cadeia de caracteres vazia.

Exemplos

O exemplo a seguir cria um novo SrgsDocument do arquivo chamado "srgsDocumentFile.xml".

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

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

Comentários

Importante

Usar uma instância desse tipo com dados não confiáveis é um risco à segurança. Use esse objeto somente com dados confiáveis. Para obter mais informações, consulte Validar Todas as Entradas.

Aplica-se a

SrgsDocument(XmlReader)

Origem:
SrgsDocument.cs
Origem:
SrgsDocument.cs
Origem:
SrgsDocument.cs
Origem:
SrgsDocument.cs

Inicializa uma nova instância da classe de uma instância que XmlReader faz referência a SrgsDocument um arquivo de gramática de formato XML.

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)

Parâmetros

srgsGrammar
XmlReader

O XmlReader objeto que foi criado com a SrgsDocument instância XML.

Exceções

srgsGrammar é null.

Exemplos

O exemplo a seguir cria uma nova instância de SrgsDocument uma instância que XmlReader faz referência ao arquivo "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();
}

Comentários

Importante

Usar uma instância desse tipo com dados não confiáveis é um risco à segurança. Use esse objeto somente com dados confiáveis. Para obter mais informações, consulte Validar Todas as Entradas.

Aplica-se a