Элемент RadioButton
Элемент управления RadioButton
позволяет создавать переключатели, объединенные в группы. Вся группа переключателей должна располагаться в контейнере. Примером такого контейнера может служить сама форма, но чаще используется элемент Panel
.
Когда пользователь выбирает один переключатель, то остальные переключатели в контейнере автоматически переводятся в выключенное состояние. Приложение может иметь несколько групп элементов RadioButton
. В любом случае группы переключателей не зависят друг от друга.
При изменении состояния переключателя в классе RadioButton
инициируются события Click
и CheckedChanged
. Событие Click
возникает, когда пользователь щелкает стилусом на самом переключателе. Событие CheckedChanged
возникает, когда состояние элемента RadioButton
меняется программно или в результате действий пользователя. Событие Click
не инициируется, когда свойство CheckedChanged
меняется программно.
Для демонстрации примера работы с элементом RadioButton
можно создать аналог популярной телеигры «Кто хочет стать миллионером?». На экране будет отображаться вопрос, а пользователь должен выбрать из представленных вариантов единственный правильный ответ. Код, реализующий основную функциональность приложения, приведен в листинге 3.3.
private void radClub1_CheckedChanged(object sender, EventArgs e) {
if (this.radClub1.Checked)
MessageBox.Show("Увы, вы проиграли", "Ошибка!");
}
private void radClub2_CheckedChanged(object sender, EventArgs e) {
if (this.radClub2.Checked)
MessageBox.Show("Поздравляю! Вы выиграли миллион!", "Миллион!");
}
private void radClub3_CheckedChanged(object sender. EventArgs e) {
if (this.radClub3.Checked)
MessageBox.Show("Увы, вы проиграли", "Ошибка!");
}
private void radClub4_CheckedChanged(object sender. EventArgs e) {
if (this.radClub4.Checked)
MessageBox.Show ("Увы, вы проиграли", "Ошибка!");
}
На рис. 3.4 показан внешний вид этого приложения.
Рис. 3.4. Демонстрация работы независимых переключателей
В полной версии .NET Framework в качестве контейнера для переключателей часто используется элемент GroupBox
, который на данный момент не поддерживается в библиотеке .NET Compact Framework. Также не поддерживаются некоторые свойства, к которым относятся Appearance
, Image
и ImageList
.
Элемент Panel
Элемент управления Panel используется в качестве контейнера для размещения других элементов управления. Так как .NET Compact Framework не поддерживает элемент управления GroupBox
, то для группировки таких элементов, как переключатели RadioButton
, приходится использовать именно Panel
.
В версии .NET Compact Framework элемент не поддерживает свойства BorderStyle
, BackGroundImage
и AutoScroll
.
Элемент CheckBox
Элемент управления CheckBox
позволяет создавать независимый переключатель в виде флажка. Элемент CheckBox
имеет свойство CheckState
, позволяющее определить состояние переключателя. Программист может использоваться значения Unchecked
, Checked
и Indeterminate
. Значение Unchecked
свидетельствует о том, что флажок в переключателе не взведен. Если переключатель все же включен, то используется значение Checked
. Но значение Indeterminate
требует некоторых пояснений. Состояние Indeterminate
используется, когда для свойства ThreeState
элемента CheckBox
установлено значение True
. Если свойство CheckState
имеет значение Indeterminate
, то элемент окрашен серым цветом, но, тем не менее, считается помеченным. При этом пользователь не может изменить состояние переключателя.
Также элемент не распознает событие Click
, если свойство AutoCheck
имеет значение False
. Для этого свойства нужно задать значение True
, чтобы пользователь мог пользоваться стилусом для работы с переключателем.
Также элемент также не поддерживает некоторые свойства, в частности, ImageIndex
.
Элемент ComboBox
Элемент управления ComboBox
позволяет создавать поле со списком выбора. Благодаря своей компактности этот элемент управления хорошо подходит для тех задач, когда требуется экономить место на экране. Поле со списком выглядит как обычное текстовое поле TextBox
со стрелкой, которая расположена в правой части поля. Когда пользователь щелкает по стрелке, то открывается список с предварительно заданными элементами. Когда пользователь выбирает определенный пункт списка или снова щелкает по стрелке, то список снова сворачивается.
Добавлять текстовые элементы в ComboBox
можно как в режиме проектирования, так и программно во время работы программы.
В листинге 3.4 приведен пример добавления пунктов программным путем. Для этого нужно вызвать метод Add
в свойстве коллекции Items
элемента ComboBox
. Отдельные пункты можно удалять с помощью метода Remove
, а чтобы удалить все пункты сразу, применяется метод Clear
. Приведенный пример показывает, как можно добавить три строки в элемент ComboBox
с именем comboBox1
.
comboBox1.Items.Add("Мурзик");
comboBox1.Items.Add("Барсик");
comboBox1.Items.Add("Рыжик");
Чтобы узнать, какой элемент выбрал пользователь, применяется свойство SelectedIndex
или SelectedItem
. Свойство SelectedIndex
возвращает порядковый номер выбранного пункта. Этот номер можно использовать для доступа к выбранному пункту при помощи свойства Items
. Следует помнить, что нумерация элементов начинается с нуля. Пример работы со свойством SelectedIndex
приведен в листинге 3.5. Также в этом листинге показано, как можно получить доступ к выбранному пункту при помощи свойства SelectedItem
.
// Получим выделенный пункт с помощью SelectedIndex
string selItem = (string)cmbCats.Items[cmbCats.SelectedIndex];
MessageBox.Show(selItem);
// Второй способ - получим пункт с помощью
SelectedItem string selItem = cmbCats.SelectedItem.ToString();
MessageBox.Show(selItem);
В полной версии .NET Framework у элемента ComboBox
для свойства DropDownStyle
можно задавать значения Simple
, DropDownList
или DropDown
. В .NET Compact Framework
значение Simple
не используется. До выхода .NET Compact Framework 2.0 также не поддерживалось и значение DropDown
. Кроме того, по умолчанию в .NET Compact Framework применяется значение DropDownList
, тогда как в полной версии .NET Framework по умолчанию используется стиль DropDown
. Также не поддерживаются многие методы из основной версии библиотеки. В .NET Compact Framework 2.0 у поля со списком появилась поддержка методов BeginUpdate
и EndUpdate
, которые позволяют избежать мерцания при загрузке большого числа элементов.