Freigeben über


SrgsRule Konstruktoren

Definition

Initialisiert eine neue Instanz der SrgsRule-Klasse.

Überlädt

Name Beschreibung
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
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 richtiger 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. Das Beispiel erstellt ein SrgsRule Objekt namens winnerRule und übergibt den Bezeichner WorldCupWinner als eine String. Das SrgsOneOf Objekt besteht aus einem Array neuer SrgsItem Objekte, die Alternativen enthalten, die von der Regel erkannt werden sollen.

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 folgenden Umständen ein 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 mit null oder mehr NameChar-Zeichen (auch in der XML-Spezifikation definiert) gefolgt werden.

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

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

Weitere Informationen

Gilt für:

SrgsRule(String, SrgsElement[])

Quelle:
SrgsRule.cs
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 richtiger 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. Das Beispiel erstellt eine öffentliche Regel mit dem Namen WorldCupWinner. Das Beispiel erstellt dann zwei SrgsRule Objekte ruleEurope und ruleSAmericaübergibt einen String Regelbezeichner und ein SrgsElement Array, das ein SrgsOneOf Objekt enthält. Anschließend fügt das Beispiel Regelverweise zu 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 weist das folgende Formular auf.

<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 folgenden Umständen ein 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 mit null oder mehr NameChar-Zeichen (auch in der XML-Spezifikation definiert) gefolgt werden.

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

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

Weitere Informationen

Gilt für: