Udostępnij za pośrednictwem


SemanticValue.ContainsKey(String) Metoda

Definicja

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.

Dotyczy