Работа с фокусом ввода

Объект, обладающий фокусом, способен получать пользовательский ввод, осуществляемый мышью или через клавиатуру. На форме может быть несколько элементов управления, но в каждый момент времени фокус ввода только у одного из них.

Элемент управления, обладающий фокусом, всегда находится на активной форме приложения. У каждого элемента управления есть метод Focus(), который передает фокус ввода вызвавшему его элементу управления. Метод Focus()возвращает булево значение, свидетельствующее об успешной или неудачной передаче фокуса. Деактивированные или невидимые элементы управления не получают фокус ввода. Определить, способен ли данный элемент управления получить фокус ввода, позволяет его свойство CanFocus: если оно возвращает true, элемент управления может получить фокус, а если false нет.

Проверим, может ли элемент управления textBox1 получить фокус ввода и если может, то передадим ему фокус ввода и изменим его фон на зеленый.

private void button1_Click(object sender, EventArgs e)

{

if (textBox1.CanFocus == true)

{

MessageBox.Show("Yes!!!");

textBox1.Focus();

textBox1.BackColor = Color.Green;

}

}

События, связанные с передачей фокуса, генерируются в следующем порядке:

1. Enter

1. Got Focus

3. Leave

4. Validating

5. Validated

6. LostFocus

События Enters, Leaveгенерируются, когда фокус переходит к элементу управления (но еще не получен им) и покидает его.

События GotFocusи LostFocusгенерируются при получении и потере фокуса элементом управления. В принципе, эти события можно применять для проверки вводимых значений на уровне поля, однако события Validatingи Validatedлучшеподходят для этой цели.

Проще всего проверить вводимые данные при помощи события Validating, генерируемого перед потерей фокуса элементом управления. Это событие генерируется, только если у элемента управления, который получит фокус следующим, свойство Causes Validationустановлено в true. Поэтому, если значение элемента управления предполагается проверять при помощи события Validating, для элемента управления, который получит фокус следующим, свойство CausesValidationследует установить в true. Кроме того, использование события Validatingтребует, чтобы свойство CausesValidation у проверяемого элемента управления было установлено в true. У всех элементов управления, созданных во время разработки, свойство CausesValidationустановлено в triteпо умолчанию, обычно исключение составляет лишь кнопка Help.

Событие Validatingпозволяет выполнять довольно сложную проверку значений элементов управления. Обработчик этого события способен, например, проверять соответствие введенного значения некоторому весьма специфическому формату или запрещать передачу фокуса другому элементу управления, пока пользователь не введет какое-либо значение.

Событие Validatingвключает экземпляр CancelEventArgs класса с единственным свойством Cancel. Если введенное значение не отвечает заданным параметрам, проверив свойство Cancelв обработчике события Validating, можно отменить дальнейшую обработку этого события и вернуть фокус исходному элементу управления.

private void textBox1_Validating(object sender, CancelEventArgs e)

{

if (textBox1.Text == "")

{

textBox1.BackColor = Color.Red;

MessageBox.Show("Значение не введено!!!");

e.Cancel = true;

}

}

Событие Validatedгенерируется после успешной проверки значения элемента управления и позволяет выполнить некоторые действия в зависимости от результатов проверки.

private void textBox1_Validated(object sender, EventArgs e)

{

MessageBox.Show("Операция успешно закончена!!!");

}


Понравилась статья? Добавь ее в закладку (CTRL+D) и не забудь поделиться с друзьями:  



double arrow
Сейчас читают про: