Freigeben über


SrgsRule Konstruktoren

Definition

Initialisiert eine neue Instanz der SrgsRule-Klasse.

Überlädt

SrgsRule(String)

Initialisiert eine neue Instanz der SrgsRule-Klasse und gibt den Bezeichner für die Regel an.

SrgsRule(String, SrgsElement[])

Initialisiert eine neue Instanz der SrgsRule-Klasse aus einem Array von SrgsElement-Objekten.

SrgsRule(String)

Quelle:
SrgsRule.cs
Quelle:
SrgsRule.cs
Quelle:
SrgsRule.cs

Initialisiert eine neue Instanz der SrgsRule-Klasse und gibt den Bezeichner für die Regel an.

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

Parameter

id
String

Der Bezeichner der Regel.

Ausnahmen

id ist null.

id ist kein gültiger Regelbezeichner.

Beispiele

Im folgenden Beispiel wird eine Grammatik erstellt, die den Ausdruck "Eine Nation, die die Weltmeisterschaft gewonnen hat" erkennt, gefolgt vom Namen eines Landes, das die Weltmeisterschaft gewonnen hat. Im Beispiel wird ein SrgsRule -Objekt namens winnerRule erstellt und der Bezeichner WorldCupWinner als Stringübergeben. Das SrgsOneOf -Objekt besteht aus einem Array neuer SrgsItem Objekte, die Alternativen enthalten, die von der Regel erkannt werden.

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

Hinweise

Der SrgsRule Konstruktor initialisiert die Id -Eigenschaft. Der Bezeichner muss innerhalb einer bestimmten Grammatik eindeutig sein.

Der SrgsRule Konstruktor löst unter den folgenden Umständen eine aus FormatException :

  • id ist kein gültiger XML-Name, wie in Extensible Markup Language (XML) 1.0 (Fifth Edition) definiert. Um diese Definition zu paraphrasen, muss ein gültiger XML-Name mit einem Buchstaben, einem Unterstrich ('_') oder einem Doppelpunkt (':') beginnen und kann von null oder mehr NameChar-Zeichen gefolgt werden (ebenfalls in der XML-Spezifikation definiert).

  • id ist "NULL" oder "VOID" oder "GARBAGE".

  • id enthält mindestens ein ungültiges Regel-ID-Zeichen. Diese Zeichen sind: '?', '*', '+', '|', '(', '), '^', '$', '/', ';', '.', '=', '<', '>', '[', ']', '{', '}', '\\', ', '\', '\t', '\r' und '\n'.

Weitere Informationen

Gilt für:

SrgsRule(String, SrgsElement[])

Quelle:
SrgsRule.cs
Quelle:
SrgsRule.cs
Quelle:
SrgsRule.cs

Initialisiert eine neue Instanz der SrgsRule-Klasse aus einem Array von SrgsElement-Objekten.

public:
 SrgsRule(System::String ^ id, ... cli::array <System::Speech::Recognition::SrgsGrammar::SrgsElement ^> ^ elements);
public SrgsRule (string id, params System.Speech.Recognition.SrgsGrammar.SrgsElement[] elements);
new System.Speech.Recognition.SrgsGrammar.SrgsRule : string * System.Speech.Recognition.SrgsGrammar.SrgsElement[] -> System.Speech.Recognition.SrgsGrammar.SrgsRule
Public Sub New (id As String, ParamArray elements As SrgsElement())

Parameter

id
String

Der Bezeichner der Regel.

elements
SrgsElement[]

Ein Array von SrgsElement-Elementen.

Ausnahmen

id ist null.

elements ist null.

id ist kein gültiger Regelbezeichner.

Beispiele

Im folgenden Beispiel wird eine Grammatik erstellt, die den Ausdruck "Eine Nation, die die Weltmeisterschaft gewonnen hat" erkennt, gefolgt vom Namen eines Landes, das die Weltmeisterschaft gewonnen hat. Im Beispiel wird eine öffentliche Regel mit dem Namen WorldCupWinnererstellt. Im Beispiel werden dann zwei SrgsRule -Objekte erstellt, ruleEurope und ruleSAmericaübergeben ein String für den Regelbezeichner und ein SrgsElement Array, das ein SrgsOneOf -Objekt enthält. Anschließend fügt das Beispiel Regelverweise auf ruleEurope und ruleSAmerica aus der Regel WorldCupWinnerhinzu.

public void WorldSoccerWinners ()
{
  // Create a grammar from an SRGSDocument, create a new rule
  // and set its scope to public.
  SrgsDocument srgsGrammar = 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 grammar and make winnerRule
  // the root rule of the grammar.
  document.Rules.Add(new SrgsRule[] {winnerRule, ruleEurope, ruleSAmerica});
  srgsGrammar.Root = winnerRule;
}

Die erstellte Grammatik hat das folgende Formular.

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

Hinweise

Der SrgsRule Konstruktor initialisiert die Id -Eigenschaft. Der Bezeichner muss innerhalb einer bestimmten Grammatik eindeutig sein.

Der SrgsRule Konstruktor löst unter den folgenden Umständen eine aus FormatException :

  • id ist kein gültiger XML-Name, wie in Extensible Markup Language (XML) 1.0 (Fifth Edition) definiert. Um diese Definition zu paraphrasen, muss ein gültiger XML-Name mit einem Buchstaben, einem Unterstrich ('_') oder einem Doppelpunkt (':') beginnen und kann von null oder mehr NameChar-Zeichen gefolgt werden (ebenfalls in der XML-Spezifikation definiert).

  • id ist "NULL" oder "VOID" oder "GARBAGE".

  • id enthält mindestens ein ungültiges Regel-ID-Zeichen. Diese Zeichen sind: '?', '*', '+', '|', '(', '), '^', '$', '/', ';', '.', '=', '<', '>', '[', ']', '{', '}', '\\', ', '\', '\t', '\r' und '\n'.

Weitere Informationen

Gilt für: