SemanticValue.ContainsKey(String) Metoda
Definicja
Ważny
Niektóre informacje dotyczą produktów przedpremierowych, które mogą zostać znacznie zmodyfikowane przed premierą. Microsoft nie udziela żadnych gwarancji, ani wyraźnych, ani domniemanych, dotyczących informacji podanych tutaj.
Wskazuje, czy bieżąca SemanticValue kolekcja wystąpień zawiera wystąpienie podrzędne SemanticValue z danym ciągiem klucza.
public:
virtual bool ContainsKey(System::String ^ key);
public bool ContainsKey(string key);
abstract member ContainsKey : string -> bool
override this.ContainsKey : string -> bool
Public Function ContainsKey (key As String) As Boolean
Parametry
- key
- String
String zawierający ciąg klucza używany do identyfikowania wystąpienia podrzędnego elementu SemanticValue w bieżącym SemanticValueobiekcie .
Zwraca
Zwraca wartość bool, true jeśli wystąpienie SemanticValue podrzędne oznaczone ciągiem key zostanie znalezione, false jeśli nie.
Implementuje
Przykłady
W poniższym przykładzie przedstawiono procedurę obsługi zdarzenia przeznaczonego SpeechRecognized do obsługi poleceń w celu zmiany koloru pierwszego planu i tła.
Po obsłudze rozpoznanych fraz, ale nie mają struktury semantycznej, program obsługi sprawdza obecność odpowiednich kluczy przy użyciu (ContainsKeyapplyChgToBackground, colorRGBValueListlub colorStringList), a następnie przetwarza semantycznie zorganizowane dane.
newGrammar.SpeechRecognized +=
delegate(object sender, SpeechRecognizedEventArgs eventArgs)
{
// Retrieve the value of the semantic property.
bool changeBackGround = true;
string errorString = "";
SemanticValue semantics = eventArgs.Result.Semantics;
Color newColor = Color.Empty;
try
{
if (semantics.Count == 0 && semantics.Value==null)
{
// Signifies recognition by a grammar with no semantics.
// Parse the string, assuming that the last word is color,
// searching for background or foreground in input.
if (eventArgs.Result.Text.Contains("foreground"))
{
changeBackGround = false;
}
string cName = eventArgs.Result.Words[eventArgs.Result.Words.Count - 1].Text;
newColor = Color.FromName(cName);
}
else if (semantics.ContainsKey("colorStringList") ^ semantics.ContainsKey("colorRGBValueList"))
{
// Determine whether to change background or foreground.
if (semantics.ContainsKey("applyChgToBackground"))
{
changeBackGround = semantics["applyChgToBackground"].Value is bool;
}
// Get the RGB color value.
if (semantics.ContainsKey("colorStringList"))
{
newColor = Color.FromName((string)semantics["colorStringList"].Value);
}
if (semantics.ContainsKey("colorRGBValueList"))
{
newColor = System.Drawing.Color.FromArgb((int)semantics["colorRGBValueList"].Value);
}
}
else
{
// Throw an exception if the semantics do not contain the keys we
// support.
throw(new Exception("Unsupported semantics keys found."));
}
}
catch (Exception exp)
{
MessageBox.Show(String.Format("Unable to process color semantics.:\n{0}\n", exp.Message));
return;
}
// Change colors, either foreground or background.
if (changeBackGround)
{
BackColor = newColor;
float Bright = BackColor.GetBrightness();
float Hue = BackColor.GetHue();
float Sat = BackColor.GetSaturation();
// Make sure that text is readable regardless of background.
if (BackColor.GetBrightness() <= .50)
{
ForeColor = Color.White;
}
else
{
ForeColor = Color.Black;
}
}
else
{
ForeColor = newColor;
float Bright = ForeColor.GetBrightness();
float Hue = ForeColor.GetHue();
float Sat = ForeColor.GetSaturation();
// Make sure that text is readable regardless of Foreground.
if (ForeColor.GetBrightness() <= .50)
{
BackColor = Color.White;
}
else
{
BackColor = Color.Black;
}
}
return;
};
Uwagi
Dostęp do danych można uzyskać tylko według wartości klucza w czasie wykonywania, na przykład w celu sprawdzenia semantyki["myKey"]. Wartość i powoduje wygenerowanie wyjątku. Zalecamy wykonanie zapytania względem obiektu ContainsKey za pomocą polecenia przed użyciem Item[] z danym wystąpieniem klasy SemanticValue.