Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
delphi.pdf
Скачиваний:
191
Добавлен:
24.02.2016
Размер:
6.84 Mб
Скачать

программу, а затем запустите ее снова... Будильники на месте. Кстати, утилиту Alarms можно поместить в папку StartUp, тогда она всегда будет у вас под рукой.

9.5. Многостраничные окна диалога

9.5.1. Страницы с закладками

В сложных компьютерных системах предусмотрена настройка десятков различных параметров, которые пользователь просто обязан установить. Это означает либо перегруженность диалоговых окон, либо слишком большое их количество. Решение этой проблемы заключается в организации многостраничных окон диалога. Они создаются с помощью компонента, который изображается в виде множества снабженных закладками страниц, называемых вкладками (рисунок 9.50):

Рисунок 9.50. Пример вкладок в окне диалога

Вкладки относятся к разряду сложных компонентов, но в целом они упрощают пользовательский интерфейс, заменяя несколько связанных по

479

смыслу форм. А чем меньше форм, тем легче пользователю ориентироваться в программе.

Создание вкладок рассмотрим на следующем примере. Представьте, что вкладками являются экзаменационные билеты по трем научным дисциплинам: математике, физике, химии. Каждая вкладка содержит один вопрос с возможными вариантами ответа. Пользователь должен на каждой вкладке выбрать правильный вариант ответа и завершить ввод щелчком на кнопке Result. При всех правильных ответах он получит оценку "отлично", при двух ответах — "хорошо", при ответе лишь на один вопрос — "удовлетворительно", а при всех неправильных ответах — "плохо".

Шаг 1. Приступим к реализации примера. Начните новый проект и установите для главной формы следующие свойства:

Name = ExamForm

Caption = Экзамен

BorderStyle = bsDialog

Position = poScreenCenter

Размеры формы подберите по своему усмотрению.

Шаг 2. Теперь поместите в форму компонент PageControl. Вы найдете его в палитре компонентов на вкладке Win32 (рисунок 9.51).

Характерные таблице 9.16.

Свойство

ActivePage Align

DockSite

HotTrack

Images

Рисунок 9.51. Компонент PageControl

свойства компонента PageControl кратко описаны в

Описание

Активная вкладка (страница).

Способ выравнивания компонента в пределах содержащего компонента.

Определяет, используется ли компонент PageControl для стыковки других компонентов.

Подсвечивает закладку при наведении на нее указателя мыши.

Список значков, отображаемых на закладках. Свойство Images используется совместно со свойством ImageIndex компонентов TabSheet. Компонент PageControl автоматически назначает каждой закладке номер значка в

480

 

соответствии с очередностью добавления вкладок, однако программист может

 

вручную указать номер значка.

MultiLine

Располагает закладки в несколько рядов.

 

Позволяет программно рисовать закладки в обработчике события OnDrawTab.

OwnerDraw

Если свойство OwnerDraw равно значению False, то закладки имеют

 

стандартный вид и событие OnDrawTab не происходит.

Pages

PageCount

RaggedRight

ScrollOpposite

Массив вкладок (страниц). Каждая вкладка является объектом класса TTabSheet. Свойство Pages доступно только из программы.

Общее количество вкладок. Доступно только из программы.

Если равно значению True, то при включенном режиме MultiLine закладки не выравниваются на ширину компонента.

Способ организации рядов закладок. Если равно значению False, то все ряды расположены вместе, например вверху. Если равно значению True, неактивные ряды переносятся на другую сторону компонента, например вниз.

Style

TabIndex

TabPosition

TabWidth,

TabHeight

OnChange

OnChanging

OnDrawTab

OnGetImageIndex

Стиль закладок: tsTabs — обычные трехмерные закладки, tsFlatButtons — плоские закладки, tsButtons — закладки в виде кнопок.

Номер выбранной закладки (первая закладка имеет номер 0).

Местоположение закладок: tpTop — сверху, tpRight — справа, tpLeft — слева, tpBottom — снизу.

Ширина и высота закладок. Если эти свойства равны нулю, то размеры закладок подбираются автоматически, исходя из размеров надписей.

Происходит после смены закладки. Происходит перед сменой закладки.

Происходит при рисовании закладки на экране. Требует, чтобы свойство OwnerDraw содержало значение True.

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

OnGetSiteInfo Происходит, когда у компонента запрашивается место для стыковки.

Таблица 9.16. Важнейшие свойства и события компонента PageControl

Шаг 3. Первоначально компонент PageControl не содержит ни единой вкладки. Для создания вкладки щелкните правой кнопкой мыши на компоненте и выберите в контекстном меню команду New Page (рисунок

9.52).

481

Рисунок 9.52. Создание новой вкладки в компоненте PageControl

Будет создана первая вкладка с заголовком TabSheet1 (рисунок 9.53).

Рисунок 9.53. В компоненте PageControl создана первая вкладка

Каждая вкладка в компоненте PageControl представлена объектом класса TTabSheet. Свойства отдельной вкладки устанавливаются в окне свойств. Характерные свойства кратко описаны в таблице 9.17.

Свойство

Описание

BorderWidth Ширина внутреннего отступа.

Caption Надпись на закладке.

482

Highlighted

ImageIndex

PageControl

PageIndex

TabIndex

TabVisible

OnHide

OnShow

Подсветка закладки цветом.

Номер значка в списке Images компонента PageControl. Значок отображается рядом с названием закладки. Отрицательное значение свойства ImageIndex говорит о том, что для закладки значок не задан.

Ссылка на компонент PageControl, которому принадлежит вкладка. Доступно только из программы.

Номер вкладки в массиве Pages компонента PageControl.

Номер вкладки среди видимых вкладок. Если вкладка не видна, то свойство TabIndex равно -1. Свойство доступно только программно и только для чтения.

Определяет, видна ли закладка.

Происходит при переключении на другую вкладку. Происходит при активизации вкладки.

Таблица 9.17. Важнейшие свойства компонента TTabSheet

Шаг 4. Перейдите к окну свойств и замените текст закладки, вписав в свойстве Caption значение Mathematics. Действуя аналогично, добавьте вкладки Physics и Chemistry (рисунок 9.54).

Рисунок 9.54. В компоненте PageControl созданы три вкладки

Шаг 5. Ну вот, у нас уже есть три пустых вкладки и можно приступать к наполнению их содержанием. Сначала щелчком мыши активизируйте вкладку Mathematics. Затем поместите на нее группу взаимоисключающих переключателей — компонент RadioGroup. Заголовок группы будет содержать условие вопроса, а текст переключателей — возможные варианты ответа. Вопрос по математике будет из области тригонометрии (рисунок

9.55).

483

Рисунок 9.55. Содержимое первой вкладки

Шаг 6. Чтобы группа переключателей выглядела так, как на рисунке, подберите ей соответствующие размеры и установите значения следующих свойств:

Caption = The right expression is (правильным является выражение)

Items = sin 50( < cos 50(

sin 50( > cos 50(

sin 50( = cos 50(

ItemIndex = 0 (номер варианта принимаемый по умолчанию)

Tag = 1 (номер правильного варианта, считая от нуля)

Свойство Tag не несет смысловой нагрузки в компонентах среды Delphi. Поэтому его можно использовать по своему усмотрению. Помещая в него номер правильного ответа, мы заботимся об упрощении подсчета оценки. Когда пользователь укажет ответ, мы сравним значения свойств ItemIndex и Tag. Ответ будет считаться правильным лишь в том случае, если номера совпадут.

Шаг 7. Билет по математике готов, приступим к подготовке билета по физике. Активизируйте вкладку Physics и поместите на нее компонент RadioGroup. Подберите для него подходящие размеры и установите следующие свойства:

484

Caption = When the ice in water dissolves then (когда лед в воде тает)

Items = the level of water becomes higher (уровень воды поднимается)

the level of water becomes lower (уровень воды понижается)

the level of water remains unchanged (уровень воды остается неизменным)

ItemIndex = 0 (номер варианта принимаемый по умолчанию)

Tag = 2 (номер правильного варианта, считая от нуля)

Результат должен быть таким, как на рисунке 9.56:

Рисунок 9.56. Содержимое второй вкладки

Шаг 8. Осталось создать билет по химии. Мы надеемся, что после всех предыдущих испытаний это не составит для вас труда. Кратко поясним, что нужно сделать. Активизируйте вкладку Chemistry и поместите на нее компонент RadioGroup. Подберите для него подходящие размеры и установите следующие свойства:

Caption = The right way of mixing acid and water is (чтобы разбавить кислоту,

нужно)

Items = to add acid to water (добавить кислоту в воду)

to add water to acid (добавить воду в кислоту)

ItemIndex = 0 (номер варианта принимаемый по умолчанию)

485

Tag = 0 (номер правильного варианта, считая от нуля)

После всех ваших действий вкладка Chemistry будет выглядеть так, как на рисунке 9.57.

Рисунок 9.57. Содержимое третьей вкладки

Шаг 9. Все вкладки с экзаменационными билетами вроде бы готовы, но как вы считаете, какая из них будет активной при запуске программы? Конечно та, которая осталась активной при проектировании, т.е. вкладка Chemistry. А надо, чтобы первой оказалась вкладка Mathematics. Поэтому активизируйте ее щелчком мыши. Кроме того, установите у формы свойство ActiveControl в значение RadioGroup1. Компонент, указанный в свойстве ActiveControl первым получает фокус ввода при появлении формы на экране.

Шаг 10. Теперь вас ждет самая ответственная работа — выставление пользователю оценки. Для этого поместите в форму две кнопки (компонент Button). Первая кнопка предназначена для выдачи результата экзамена, сделайте ее свойства такими:

Name = ResultButton

Caption = Result

Default = True

Вторая кнопка служит для закрытия окна, ее сделайте такой:

Name = CloseButton

Caption = Close

486

Cancel = True

Рисунок 9.58. Кнопка Result выдает оценку, кнопка Close завершает диалог

Шаг 11. Создайте для кнопок следующие обработчики события OnClick:

procedure TExamForm.ResultButtonClick(Sender: TObject); const

MarkText: array[0..3] of string =

('Неудовлетворительно', 'Удовлетворительно', 'Хорошо', 'Отлично');

var

Mark: Integer; begin

Mark := 0;

if RadioGroup1.ItemIndex = RadioGroup1.Tag then Mark := Mark + 1;

if RadioGroup2.ItemIndex = RadioGroup2.Tag then Mark := Mark + 1;

if RadioGroup3.ItemIndex = RadioGroup3.Tag then Mark := Mark + 1;

ShowMessage(MarkText[Mark]);

end;

procedure TExamForm.CloseButtonClick(Sender: TObject); begin

Close;

end;

Оценка вычисляется элементарно. Сначала предполагается, что она равна нулю (ни одного правильного ответа), а затем она уточняется в соответствии с тем, дал ли пользователь правильный ответ по математике, физике и химии. Под конец вызывается процедура ShowMessage, которая выдает в маленьком окне диалога заключение экзаменатора (рисунок 9.59).

487

Рисунок 9.59. По щелчку на кнопке Result выставляется оценка

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

Поупражняйтесь с компонентом PageControl, например, измените размеры закладок (свойства TabHeight и TabWidth), добавьте больше страниц. Когда закладки перестанут умещаться в одной строке, обнаружится, что их можно прокручивать (рисунок 9.60). Кнопки прокрутки появляются автоматически.

Рисунок 9.60. Вкладки могут прокручиваться с помощью кнопок со стрелками

Если это вам не нравится, закладки можно расположить в несколько рядов, установив свойство MultiLine в значение True (рисунок 9.61):

488

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]