SemanticValue.Item[String] Свойство
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Возвращает дочерние SemanticValue экземпляры, принадлежащие текущему SemanticValueобъекту .
public:
property System::Speech::Recognition::SemanticValue ^ default[System::String ^] { System::Speech::Recognition::SemanticValue ^ get(System::String ^ key); void set(System::String ^ key, System::Speech::Recognition::SemanticValue ^ value); };
public System.Speech.Recognition.SemanticValue this[string key] { get; set; }
member this.Item(string) : System.Speech.Recognition.SemanticValue with get, set
Default Public Property Item(key As String) As SemanticValue
Параметры
- key
- String
Ключ для KeyValuePair<String, SemanticValue>
, содержащийся в текущем экземпляре SemanticValue.
Значение свойства
Возвращает дочерний элемент текущего SemanticValue объекта , который можно индексировать как часть пары "ключевое значение": KeyValuePair<String,
SemanticValue>
.
Реализации
Исключения
Ни один дочерний элемент текущего экземпляра SemanticValue не имеет ключа, соответствующего параметру key
.
Код попытался изменить по указанному SemanticValue индексу.
Примеры
В следующем примере показан обработчик для события, предназначенного SpeechRecognized для обработки команд для изменения цвета переднего плана и фона.
После обработки распознаваемых фраз, не имеющих семантической структуры, обработчик проверяет наличие соответствующих ключей с помощью ContainsKey (applyChgToBackground
, colorRGBValueList
или , а colorStringList)
затем использует Item[] свойство для получения узлов с необходимой информацией.
Использование выделено Item[] ниже.
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 semantic 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 the foreground.
if (ForeColor.GetBrightness() <= .50)
{
BackColor = Color.White;
}
else
{
BackColor = Color.Black;
}
}
return;
};
Комментарии
Объект Item[] доступен только для чтения и создает исключения при изменении членов.
Доступ к данным можно получить только по значению ключа во время выполнения, но не во время компиляции, например для проверка semantic["myKey"].Value
. При указании ключа, который отсутствует, создается исключение.
Чтобы обнаружить наличие заданного ключа, используйте ContainsKey свойство в экземпляре SemanticValue .