РУБРИКИ |
Програмирование на Visual Basic |
РЕКЛАМА |
|
Програмирование на Visual Basic| | | После завершения выполнения данной процедуры на форме изменятся элементы (рис. 2.21). [pic] Рис. 2.21 [pic] Рис. 2.22 На форме активны только четыре элемента: метка с названием “Цвет”, командная кнопка “Конец”, комбинированный список для выбора цвета и текстовое окно “Описание модели”. При щелчке по списку он разворачивается и из него можно выбрать цвет для машины. После выбора цвета его название заносится в текстовое окно “Описание модели”, комбинированный список цветов становится неактивным вместе с меткой “Цвет”, а метка “Исполнение” и комбинированный список для выбора варианта исполнения автомобиля становятся активными (рис. 2.22). Для выполнения указанных действий процедура Combo2_Click() (обработка события “Щелчок по списку”) содержит следующие операторы: [pic] Коды цветов приведены в следующей таблице: |Цвет |Кол цвета | | |&Н 000000 FF& | | | | | |&HOOFFOOOO& | | |&НООСОСОСО& | | | | | |&HOOOOFFOO& | | | | |Голубой |&HOOFFFFOO& | |Черный |&НООООООООО& | |Белый |&HOOFFFFFF& | |Желтый |&HOOOOFFFF& | Коды цветов заданы в шестнадцатеричной системе счисления, в которой для представления чисел используется 16 символов: цифры от 0 до 9 и буквы от А (эквивалент 10) до F (эквивалент 15). Значимость каждой п-й позиции в шестнадцате-ричном числе возрастает пропорционально степени \6”n. Например, десятичное число 419 в шестнадцатеричном представлении записывается 1АЗ: 1*16”2 + 10*16”! + 3*16^0 = 419. В двоичной системе число 15 записывается 1111, т.е. любой символ шестнадцатеричного числа можно кодировать четырьмя битами. Память компьютера разделена на байты (1 байт равен 8 битам) и каждый байт может хранить любое из 256 (16^1) шестна-дцатеричных чисел: от 0 до FF. Такое компактное представление информации на основе шестнадцатеричной системы счисления обусловливает ее широкое использование в программировании. Шестнадцатеричному числу в Visual Basic предшествуют символы &Н. Как видно из рис. 2.22, на форме активны четыре элемента: комбинированный список, соответствующий метке с названием “Исполнение”, командная кнопка “Конец” и текстовое окно “Описание модели”. При щелчке по элементу комбинированного списка можно выбрать соответствующий вариант исполнения для машины. После выбора варианта исполнения его название заносится в текстовое окно “Описание модели”, комбинированный список становится неактивным вместе с меткой, а рамка с названием “Тип кузова” и три переключателя внутри неё - активными (рис. 2.23). Для выполнения указанных действий процедура Combo3_Click() (обработка события “Щелчок по списку”) содержит следующие операторы: [pic] В результате выполнения данной процедуры на форме произойдут изменения, показанные на (рис. 2.23). На форме активны шесть элементов: кнопка “Конец”, рамка “Тип кузова”, текстовое окно “Описание модели” и три переключателя в рамке. [pic] Рис. 2.23 [pic] В результате форма примет вид, показанный на рис. 2.25. На форме активны: текстовое окно с названием “Описание модели”, рамка “Список фирм- дистрибъютеров”, командная кнопка с названием “Очистить список”, командная кнопка с названием “Добавить название”, текстовая строка для добавления нового имени в список продавцов и кнопка “Конец”. При щелчке по флажку “Двухколоночный” список в зависимости от состояния флажка преобразуется в двухколоночный и обратно. Реализующая процедура обработки события Check3_Click() содержит следующие операторы: |Процедура |Комментарии | |Sub Check3 Click() |Свойство Value элемента | |IfCheck3.Value = 0 |Check равно 0, если | |Then List!.Columns = |флажок не взведен. В | |1 Else List 1.Columns|зависимости от значения | |= 2 End If |этого свойства | |End Sub |определяется свойство | | |списка.(Listl.Columns = | | |1 - список | | |одноколоночный, | | |Listl.Columns = 2 | | |-список двухколоночный) | При щелчке по кнопке “Очистить список” из списка фирм удаляются все элементы с помощью метода Clear, а затем кнопка деактивизируется. Реализующая процедура Command l_Click() содержит следующие операторы: |Процедура |Комментарии | |Sub Command I |Очистка списка Деактивация| |ClickQ List [.Clear|кнопки очистки списка | |Command L Enabled =|Деактивация кнопки | |False |удаления элемента списка | |Command3.Enabled = | | |False End Sub | | [pic] Рис. 2.25 При щелчке по кнопке “Добавить элемент” содержимое текстовой строки добавляется в список с помощью метода Additem. Список обладает свойством автосортировки (добавление происходит в соответствии с упорядоченностью по алфавиту). Происходит очищение текстовой строки и активизация кнопок “Удалить элемент” и “Очистить список”. Это обеспечивается следующими операторами: |Процедура |Комментарии | |Sub CoiTimand4Click() |Добавление нового имени| |Listl.AddItem |в список Очистка | |Text2.Text Text2.Text |текстовой строки. | |= “” Command [.Enabled|Активизация кнопок | |= True Command3. |“Удалить элемент” и | |Enabled = True End Sub|“Очистить список” | Для фиксации названия фирмы или удаления его из списка требуется предварительно щелкнуть мышью по элементу списка. При обработке этого события проверяется наличие элементов в списке и активизируются кнопки “Зафиксировать”, “Удалить элемент” и “Очистить список”. Это обеспечивается следующими операторами: |Процедура |Комментарии | |Sub Listi Click() If |Свойство Listlndex | |List 1. Listi ndex >= 0|равно номеру | |Then |выделенного элемента. | |Command3.Enabled = True|Если ни один элемент не| |Command6. Enabled = |выделен, то его | |True End If End Sub |значение - 0 | | |Активизация кнопки | | |удаления элемента и | | |фиксации элемента | В результате обработки события “щелчок мыши” по элементу списка форма примет вид на рис. 2.26. [pic] Рис. 2.26 При щелчке по кнопке “Удалить название” удаляется текущий выбранный элемент из списка, деактивируется кнопка удаления списка и, при условии отсутствия других элементов в списке, деактивируется кнопка “Очистить список”. Проверка на пус тоту списка осуществляется с помощью свойства ListCount, значение которого равно числу элементов в списке. Это обеспечивается следующими операторами: |Процедура |Комментарии | |Private Sub Command3 |Проверка на выбор | |Clic() If Listi. Listi |элемента Удаление | |ndex >= 0 Then List 1. |элемента из списка | |Remove Item List 1. |Деактивация кнопки | |List! ndex |удаления элемента | |Command3.Enabled = |списка, так как нет | |False End If |выделенных элементов в | |If Listi. ListCount = 0|списке Проверка списка | |Then Command [.Enabled |на пустоту. Если список| |= False End If End Sub |пуст, то деактивация | | |кнопки очистки списка | При щелчке по кнопке “Зафиксировать” выбранное название фирмы помещается в текстовое окно “Описание модели”, деактивизируется рамка с названием “Список фирм-дистрибьюторов” и все управляющие элементы, лежащие внутри рамки. Процедура обработки события щелчка по кнопке “Зафиксировать” имеет следующий вид: [pic] В результате выполнения этой процедуры форма примет вид, показанный на рис. 2.27. [pic] Рис. 2.27 На форме остались активными только два управляющих элемента: командная кнопка “Конец” и тестовое окно “Описание модели”. В текстовое окно можно добавлять собственный текст и редактировать имеющийся. При нажатии на кнопку “Конец” работа программы завершается. Это обеспечивается операторами: |Процедура |Комментарии | |Sub Command2 Click() |End - оператор завершения| |End End Sub |программы | Тексты всех процедур обработки событий примера: Private Sub Check2_Click() If Check2.Value = 1 Then Textl.Text = Textl.Text + Check2.Caption + Chr$(13) + Chr$(10) Check2.Enabled = False End If End Sub Private Sub Check3_Cli.ck() If Check3.Value = 0 Then Listi.Columns = 1 Else Listi.Columns = 2 End If End Sub Private Sub Check4_Click () If Check4.Value = 1 Then Check4.Enabled = False Textl.Text = Textl.Text + Check4.Caption + Chr$(13) + Chr$(10) End If End Sub Private Sub Combol_Click() Combol.Enabled = False Textl.Text = Textl.Text + Combol.Text + Chr$(13) + Chr$(10) Labell.Enabled = False Combo2.Enabled = True Label2.Enabled = True End Sub Private Sub Combo2_Click() Combo2.Enabled = False Label2.Enabled = False Private Sub Cornmand4_Click () Listl.AddItem Text2.Text Text2.Text = “” Commandl.Enabled = True End Sub • Private Sub Command2_Click() End End Sub Private Sub Command5_Click() Check2.Enabled = False Check4.Enabled = False Frame2.Enabled = False HScroill.Enabled = False Label4.Enabled = False Label5.Enabled = False Label6.Enabled = False Label7.Enabled = False Lab.el8 .Enabled = False Commands.Enabled = False Textl.Text = Textl.Text + Label5.Caption + “Л.С” + Chr$(13) + Chr$(10) Framel.Enabled = True Listi.Enabled = True Text2.Enabled = True Command4.Enabled = True Check3.Enabled = True Commandl.Enabled = True End Sub Private Sub Command6_Click() ‘If Listl.ListIndex >= 0 Then Textl.Text = Textl.Text + Listl.Text + Chr$(13) + Chr$(10) Framel.Enabled = False Listi.Enabled = False Text2.Enabled = False Command4.Enabled = False Check3.Enabled = False Commandl.Enabled = False Command6.Enabled = False Commands.Enabled = False End If End Sub Textl.Text = Textl.Text + Combo2.Text + Chr$(13) + Chr$(10) If Combo2.Text .= “Красный” Then LabelS.BackColor = &HFF& Elself Combo2.Text = “Белый” Then LabelS.BackColor = &HFFFFFF Elself Combo2.Text = “черный” Then LabelS.BackColor = &HO Elself Combo2.Text = “Синий” Then LabelS.BackColor = &HFFOOOO Elself Combo2.Text = “Зеленый” Then LabelS.BackColor = &HCOOO& End If Combo3.Enabled = True Label3.Enabled = True End Sub Private Sub Combo3_Click() Combo3.Enabled = False Label3.Enabled = False Textl.Text = Textl.Text + Combo3.Text + Chr$(13) + Chr$(10) Frame4.Enabled = True ‘ “ Optioni.Enabled = True Option2.Enabled = True Option3.Enabled = True End Sub Private Sub Commandl Click () Listi.Clear ~ Commandl.Enabled = False End Sub • Private Sub Command3_Click() If Listl.ListIndex >= 0 Then Listi.Removeltem Listl.ListIndex Command3.Enabled = False End If If Listi.ListCount = 0 Then Commandl.Enabled = False End If End Sub Private Sub Form_Load() Label4.Caption = Str$(HScrolll.Value * 735.499 / 1000) Label5.Caption = Str$(HScrolll.Value) Combol.Addltem “Мерседес” Combol.Addltem “Ауди” Combol.Addltem “Фольксваген” Combol.Addltem “Шкода” Combol.Addltem “Рено” Combol.Addltem “Пежо” Combol.Addltem “Запорожец” Combo2.Addltem “Красный” Combo2.Addltem “Бельм” Combo2.Addltem “черный” Combo2.Addltem “Синий” Combo2.Addltem “Зеленый” Combo3.Addltem “Люкс” СотЬоЗ.Addltem “Стандарт” Combo3.Addltem “Минимум” Listl.Addltem “MusaMotors” Listi.Addltem “Savva” Listl.Addltem “A3P” Listl.Addltem “ЛогоВАЗ” Listl.Addltem “ЛадаИнжениринг” End Sub Private Sub HScrolll_Change() Label4.Caption = Str$(HScrolll.Value * 735.499 / 1000) Labels.Caption = Str$(HScrolll.Value) End Sub Private Sub Listl_Click() If Listl.Listlndex >= 0 Then Command3.Enabled = True Command6.Enabled = True End If End Sub Private Sub Optionl_Click() Frame4.Enabled = False Optioni.Enabled = False Option2.Enabled = False Option3.Enabled = False Textl.Text = Textl.Text + Optioni.Caption Chr$(13) + Chr$(10) Check2.Enabled = True Check4.Enabled = True Frame2.Enabled = True HScrolll.Enabled = True Label4.Enabled = True Labels.Enabled = True Label6.Enabled = True Label7.Enabled = True Labei8.Enabled = True Commands.Enabled = True End Sub Private Sub Option2_Click() Frame4.Enabled = False Optionl. Enabled = False Option2.Enabled = False Option3.Enabled = False Textl.Text = Textl.Text + Option2.Caption + Chr$(13) + Chr$ (10) Check2.Enabled = True Check4.Enabled = True Frame2.Enabled = True HScrolll.Enabled = True Label4.Enabled = True Labels.Enabled = True Label6.Enabled = True Label7.Enabled = True Labels.Enabled = True Commands.Enabled = True End Sub Private Sub Option3_Click() Frame4.Enabled = False Optioni.Enabled = False Option2.Enabled = False Option3.Enabled = False Textl.Text = Textl.Text + Option3.Caption > Chr$(13) + Chr$ (10) Check2.Enabled = True Check4.Enabled = True Frame2.Enabled = True HScrolll.Enabled = True Label4.Enabled = True Ldbel5. Ei-icioled = True Ldnei6.EnDied = True LdDpl7 . L.Jt,ied = Tr.Je Lctbel8 . Er.dbied = True CoiTimand . Ј.ndbled = Tru Ei-ici Sub 2.13. МЕНЮ ПОЛЬЗОВАТЕЛЯ Важным элементом GUI является стандартное меню пользователя. Visual Basic имеет специальное средство для создания меню пользоваюлеи приложениями - Menu Editor (Проектировщик меню). Это срелс-жо нозволяег построить меню соответственно общим принципам рассмо1ренного событпиного управления для форм и элементов управления. Меню пользоваге-ля создается выстраиванием элементов меню в соответствии с необходимой их иерархией с помощью Проектировщика меню. Для вызова проектировщика меню нужно вызвать команду Menu Editor... из меню Tools или щелкнуть кнопку Menu Editor на панели инструментов Главного меню. При этом появится окно Menu Editor (рис.2.28). элемешы которою имеюг следующее назначение: . Caption примеияегся для ввода названии элементов списка меню, используемых в диадою (например, Фаил, Edit и т.н.): для создания разделительной черш (разделяет функциональные группы пунктов меню) вместо имени вводтся символ “-“; . Name иснользуегся для ввода имен элементов списка меню, используемых при написании нро1раммы (аналогично свойству Name для форм и элементов управления); . Index - индекс элемеша списка диало1а в массиве (при использовании массива элемента списка диалога); . Shortcut - раскрывающийся список комбинаций клавиш, из которого можно выбрагь комбинацию “горячих” клавиш эле-менюв списка меню; . Windows List - флажок, при установке которого меню содержит список (л крытых окон в многооконном приложении (MDI-приложения): . HelpConiextID - индекс для поиска в HelpFile; . Checked - флажок, при установке когорого помечается пункт выбранною меню; [pic] Рис 2 2S . Enabled - флажок, при установке которого пункт меню доступен; . Visible - флажок, при усгановке которого пункт меню виден; . кнопки изменения уровня пунктов меню; [pic] . кнопки изменения позиции пунктов меню на одном и том же уровне: . Кнопки Next, Insert. Delete обеспечивают переход к следующему пункгу меню, вставку и удаление пункта. Рассмотрим использование проектировщика меню на примере разработки простого редактора, который обеспечивает ввод и редактирование строк символов, запись выделенного фрагмента в буфер и всгавку из буфера. Доступ к буферу обмена можно получить через объект Clipboard, для которого определены следующие методы: . SetText записывает копию выделенного текста в буфер обмена; . GetText () возвращает копию текстового содержимого буфера обмена; . SetData записывает копию выделенного рисунка в буфер обмена; . Get Data () возвращает содержимое (рисунок) буфера обмена; . GetFormat () определяет, является ли содержимое буфера обмена текстом или рисунком; . Clear очищает содержимое буфера обмена. Разместим на форме (имя - Formi, Caption - Редактор) многострочное текстовое окно (имя - txlEdilBox), размеры которого совпадают с размером формы, для ввода и редактирования текста. Меню редактора включает раскрывающиеся меню: Файл (Новый, Открыть..., Сохранить, Сохранить как.... Выход), Правка (Вырезать, Копировать, Вставить), Справка (О программе). В скобках указаны пункты соответствующих раскрывающихся меню. Это меню создается с использованием Menu Editor. На рис. 2.29 показано окно Menu Design Windows в момент проектирования. Выделен элемент меню “Копировать” (свойство Caption - ^.Копировать, имя - mnuEdifCopy, “горячая” клавиша -Ctrl+C). Вставка символа “&” означает задание “горячей” клавиши. Символы “....” обозначают переход на следующий уровень иерархии пунктов меню (“Копировать” является подпунктом меню “Файл”) и задаются кнопками изменения уровня пунктов меню. Аналогично имени mnuEditCopy образуются имена остальных пунктов меню, которые используются для записи программы (nmuEditCut, mnuEditPaste, mnuFileExit, mnuHelpAbout, mnuFileNew, mnuFileOpen, mnuFileSave, mnuFileSaveAs, mnu File Exit}. Тексты процедур обработки событий следующие: Sub Form_Resize () txtEditBox.Height = ScaleHeight txtEditBox.Width = ScaleWidth End Sub Sub mnuEditCopy_Click () Clipboard.Clear 'очистить буфер Clipboard.SetText txtEditBox.SeiText 'поместить 'выделенный текст в буфер End Sub Sub mnuEditCut_Click () Clipboard.Clear 'очистить буфер Clipboard.SetText txtEditBox.SeiText 'поместить 'выделенный текст в буфер txtEditBox.SeiText = “” 'удаление выделенного 'текста End Sub Sub mnuEditPaste_Click () txtEditBox.SeiText = Clipboard.GetText() End Sub Sub mnuFileExit_Click () If MsgBox(“Выход?”,1+32,”Подтвердить”)=lThen End End Sub Sub mnuHelpAbout_Click () MsgBox “Мой редактор на Visual Basic”,64,”О программе” • End Sub Sub Form_Unload (Cancel As Integer) Cancel = 1 mnuFileExit_Click End Sub Процедура Form_Resiy (обработка события изменения размера формы) обеспечивает автоматическое изменение размеров текстового окна при изменении размеров формы. Процедура mnuEditCopy_Click (обработка события щелчка мыши по пункту меню “Копировать”) обеспечивает запись выделенного текста в буфер. Используются рассмотренные выше методы для объекта Clipboard и методы для текстового окна (операторы Clipboard. Clear и Clipboard.SetText txtEditBox. SeiText). Во втором операторе txtEditBox. SeiText присваивается выделенный текст. [pic] Рис. 2.29 Процедура mnuEditCut_Click (обработка события щелчка мыши по пункту меню “Вырезать”) обеспечивает перед удалением сохранение выделенного текста в буфере. Процедура mnuEditPaste_Click (обработка события щелчка мыши по пункту меню “Вставить”) обеспечивает вставку текста из буфера (в данном случае отсутствие при вставке выделения означает вставку в позицию курсора). Процедура mniiFileExit_Click (обработка события щелчка мыши по пункту меню “Выход”) обеспечивает выход из редактора. Оператор End обеспечивает корректный выход из приложения (закрывает файлы и освобождает память). В процедуре используется функция MsgBox для вывода окна сообщения. Синтаксис ее применения следующий: MsgBox сообщение [, тип окна] [, заголовок окна] где сообщение - текст сообщения; тип окна - это сумма значений, определяющих число и тип кнопок на диалоговом окне, стиль пиктограмм, используемых в окне, и др. спецификации. В таблице приведены некоторые значения аргументов и их описание: |Значение |Описание | |типа | | |0 |Выводить только кнопку OK | || |Выводить кнопки OK и Cancel | |2 |Выводить кнопки Abort, Retry, | | |Ignore | |3 |Выводить кнопки Yes, No, Cancel | |4 |Выводить кнопки Yes, No | |5 |Выводить кнопки Retry, Cancel | |16 |Выводить пиктограмму “Стоп” | |32 |Выводить пиктограмму “?” | |48 |Выводить пиктограмму “!” | |64 |Выводить пиктограмму информации | |0 |Кнопка по умолчанию - первая | |256 |Кнопка по умолчанию - вторая | |512 |Кнопка по умолчанию - третья | |0 |Программное ведущее диалоговое окно| |4096 |Системное ведущее диалоговое окно | Первая группа значений (0-5) описывает номер и тип кнопок, отображаемых в диалоговом окне; вторая группа (16, 32, 48, 64) описывает стиль пиктограммы (иконки); третья группа (0, 256, 512) определяет кнопки по умолчанию; четвертая группа (0, 4096) определяет выводимые окна сообщения (0 - окно ввода для окончания работы приложения, 4096 - окно ввода для окончания работы системы). В качестве значения аргумента может указываться сумма значений типа по одному из каждой группы. Например, в операторе MsgBox “Удалить ?”, 52 значение аргумента 52 является суммой 48 и 4 (48 - вывод пиктограммы с восклицательным знаком, 4 - кнопки “Yes” и “No”). Функция MsgBox возвращает следующие значения: |Константа | | | | | | | |vbOK |1 |ОК | | |2 |Cancel | |vbAbort |3 |Abort | |vbRetry |4 |Retry | |vblgnore |5 |Ignore | |vbYes |6 |Yes | |vbNo |7 |No | Эти значения можно использовать для обработки результата работы пользователя с окном MsgBox. Процедура mnuHelpAbout_Click (обработка события щелчка мыши по пункту меню “О программе”) обеспечивает вывод окна сообщения. Процедура Form_Unload (Cancel As Integer) (обработка события щелчка мыши по кнопке “Закрыть” раскрывающегося стандартного меню формы) обеспечивает выход с подтверждением. Закрытие формы не обеспечивает корректного завершения приложения. В этом случае присвоение Cancel =1 предотвращает закрытие формы и обеспечивает корректный выход через процедуру mnuFileExit_Click. [pic] Рис. 2.30 Разработанная программа имеет меню пользователя и обеспечивает функции удаления, вставки и копирования при редактировании и выдачу сообщения о программе (рис. 2.30—2.32). [pic] Рис. 2.31 [pic] Рис. 2.32 Глава 3. Программирование на VISUAL BASIC 4 3.1. АЛФАВИТ Visual Basic является языком программирования. Как любой другой язык, например, русский, английский или язык программирования Pascal, он имеет свой алфавит, используемый для написания операторов или предложений Visual Basic. Алфавит Visual Basic включает: . 26 латинских букв: А, В, С, D, Е, F, G, H, I, J, К, L, М, N, О, Р, Q, R, S, Т, U, V, W, X, Y, Z; . 10 арабских цифр: 1, 2, 3, 4, 5, 6, 7, 8, 9, 0; . 26 символов: !#$%&л*()+-/\<>=?@_|:'.,“ ” пробел. Другие символы, определенные на клавиатуре, включая русские, можно использовать только в строках символов. 3.2. ДАННЫЕ 3.2.1. Классификация данных Данные характеризуются типом и организацией. Тип данных обобщает следующие понятия: . размещение в ЭВМ; . способ представления; . прикладной смысл. Размещение. Данные и программа в момент выполнения размещаются в оперативной памяти (ОП) ЭВМ, которая состоит из пронумерованных ячеек, каждая из которых вмещает 1 байт данных (1 байт состоит из 8 битов, каждый из которых может содержать элемент двоичных данных - 0 или 1). Номер определенной ячейки называется адресом. Одного байта для хранения данного как правило недостаточно и данное занимает непрерывную последовательность байтов (2, 4, 8 байтов). Способ представления. Последовательность битов в байтах данного кодирует всю необходимую информацию, определяющую данное. Правила кодирования и их реализация в разных ЭВМ определяют способ представления данного. Так, для числовых данных существует способ представления с фиксированной точкой и с плавающей точкой. Прикладной смысл. Определяет возможность использования данных для тех или иных целей (с арифметическими данными можно производить вычисления, из символов можно строить слова и предложения). В Visual Basic 4 определены следующие типы данных: . байт (BYTE); . логический (BOOLEAN); . дата (DATE); . короткий целый ( INTEGER); . длинный целый (LONG); . простой вещественный (SINGLE); . удвоенной точности вещественный (DOUBLE); . коммерческий (CURRENCY); . строковый (STRING); . объект (OBJECT); . переменный (VARIANT). В табл. 3.1 приводятся характеристики этих типов данных: Таблица 3.1 |Тип |Описание |Диапазон |Занимаема| |данных| |значении |я память | |Byte |Двоичные |От 0 до 255 |1 байт | | |данные | | | |Boolea|Логический |True или False |2 байта | |n | | | | |Intege|Целые числа |От -32768 до |2 байта | |r | |32767 | | |Long |Целые числа |От -2 147 483 |4 байта | | |(длинные) |648 до +2 147 | | | | |483 647 | | |String|Символьный |От О до |10 байт +| |(varia|(переменной |2000000000 |длина | |ble-le|длины) |символов |строки | |ngth) | | | | |String|Символьный |От 0 до |1 байт на| |(fixed|(фиксированн|2000000000 |1 символ | |-lengt|ой длины) |символов | | |h | | | | |Curren|Число с |От |8 байтов | |cy |фиксированно|-22337203685477,| | | |й десятичной|58 до | | | |точкой |922337203685477,| | | | |58 | | |Date |Дата |От January 1, |8 байтов | | | |100 до December | | | | |31, 9999 | | |Object|Объект | |4 байта | | | | | | |Single|Вещественные|От± 1.4* Ю-45 до|4 байта | | |числа |+ 3.4*104-38 | | |Double|Вещественные|От+ 4.94* Ю-324 |8 байтов | | |числа |до+ 1.79* Ю-“308| | |Varian|Произвольный|Любой из |Зависит | |t |тип |перечисленных |от | | | |выше |значения | Data (Дата) - определяет дату (месяц, день, год). Object (Объект) - ссылка на объект (OLE). String (Строка) - последовательность ASCII-символов. Саггепсу (Валюта) предназначен для финансовых расчетов и имеет фиксированную точность до четвертого знака после запятой (округляется). Variant (Варьируемый) способен принимать любые значения (состоят из двух частей: собственно значения и кода, указывающего исходный тип данного). Под организацией данных понимается независимость отдельных данных (хранятся в отдельных непоследовательных ячейках памяти) или их связанность (хранятся в связанной последовательности ячеек памяти). Связанными данными в Visual Basic 4 являются массивы (совокупность связанных данных одного типа) и записи (совокупность связанных данных разных типов). 3.2.2. Константы Константа - данное, значение которого однозначно определяется написанием и не может быть изменено. Пример: 3.1415926 6.02ЕЗ (значение 60200) 123 “Visual Basic “ “Иванов “ Для хранения постоянных величин Visual Basic позволяет объявить константы, т.е. выделить участки памяти, содержимое которых не меняется (при попытке модификации выдается сообщение об ошибке). Объявление констант осуществляется оператором [Public | Private] Const имя [As type] = выражение Имя констант принято записывать прописными буквами (правила записи имен см. ниже). Значения ключевых слов следующие: Public - константу можно использовать в любых процедурах и функциях; Private - константу можно использовать только внутри модуля (см. ниже), в котором она определена. Пример: Const /V= 3.1415926 Const MY_NAME = “Юра “ Тип константы можно не объявлять (устанавливается на основе значения — Const CODE = 35 автоматически получит тип integer). Однако константа PI в примере может быть любого из трех типов: single, double или currency. По умолчанию принимается тип, занимающий наименьший объём памяти. Поэтому лучше явно указывать тип специальными символами в операторах объявления констант. Используемые символы показаны в таблице: |Символ |Тип данных | |объявления типа| | |% |integer | |& |long | |1 |single | |# |double | |@ |currency | |$ |string | Пример: Const ONE& = / (резервирует 4 байта) Const ONE# = 1 (резервирует 8 байтов, хранится в виде числа двойной точности с плавающей точкой). В Visual Basic имеется большое число встроенных констант, значения которых определены заранее и их можно использовать без предварительного определения. Примерами таких констант являются: vbOKCancel = 1 — аргумент функции MsgBox для вывода в диалоговом окне командных кнопок ОК и Cancel; vbYesNoCancel = 3 — аргумент функции MsgBox для вывода в диалоговом окне командных кнопок Yes, No, Cancel; vbOk = 1 — значение, которое возвращает MsgBox, если пользователь щелкнул по кнопке ОК в диалоговом окне; . vbCancel = 2 - значение, которое возвращает MsgBox, если пользователь щелкнул по кнопке Cancel в диалоговом окне. Полную информацию о встроенных константах можно найти в Object Browser. Кроме того, в комплекте Visual Basic имеется файл CONSTANT.TXT, содержащий десятки часто используемых констант. Необходимые константы могут быть скопированы в программу. 3.2.3. Имена Имена используются для обозначения объектов в программе (константа является объектом программы). Правила образования имен: . первым символом имени должна быть латинская буква; . имя может включать только латинские буквы, цифры и знак подчеркивания (_); . имя может содержать не более 40 символов; . ключевые слова или Reserved word (Зарезервированные слова) не могут использоваться в качестве имен (список ключевых слов содержится в справочной системе Visual Basic в разделе Reserved word). Примеры: Правильные имена Неправильные имена StartTime CM*PER*INCH А2 23В color File (ключевое слово) • VariableName BMW_360 Хорошим тоном при программировании на любом языке является осмысленный выбор имен для объектов программы (присваивать объектам имена, соответствующие контексту и несущие описательную нагрузку). В качестве примера можно привести имя процедуры обработки события, связанного с щелчком мыши по командной кнопке, запускающей программу btnStart_CUck: первая часть имени состоит из сокращения слова кнопка (button — btn) и слова Start, вторая часть определяет событие — Click. 3.2.4. Оператор объявления Оператор объявления резервирует в памяти место для хранения данных определенного типа и организации и присваивает ему имя, по которому производится обращение к данным. Оператор имеет вид: Global имя [({описатель})} [As [New] тип} [, имя [([описатель])] [As [New]w“n] ] . . . Dim, Global, As, New — ключевые слова (Global используется для объявления глобальных данных (см. ниже). New используется для создания нового объекта на основе существующих объектов, например формы); имя — имя объекта (имя переменной, массива); тип - тип данных; описатель — определяет организацию данных (например, массива, см. ниже). Пример: Dim Name, YourName As String, N As Integer, Money As Currency, SiirName As String* 15 (переменная SurName определена как символьная фиксированной длины в 15 символов). При описании имен прописные и строчные буквы воспринимаются одинаково. Однако после определения ссылки на эту переменную должны соответствовать последней форме записи (производится автоматическое преобразование текста программы). Visual Basic допускает использование имен без объявления их типа (в этом случае автоматически определяется тип, требующий для размещения минимальной памяти), однако целесообразно и является признаком хорошего тона явно объявлять типы используемых данных. Из рассмотренных в предыдущей главе примеров программ для работы с формами и управляющими элементами известно, что любая программа состоит из формы и элементов управления, которым поставлены в соответствие процедуры. Более сложные программы могут включать несколько форм. Существует понятие области действия (scope) данных, определяющее возможность доступа к тем или данным (например, к переменной) в отдельных процедурах одной формы или в процедурах, относящихся к разным формам одной программы. Если оператор объявления какой-либо переменной находится внутри процедуры обработки события, то доступ к этой переменной (возможность ее использования) возможен только в рамках данной процедуры. Такая переменная называется локальной (local). Для того чтобы одна и та же переменная могла использоваться в разных процедурах одной формы, оператор объявления переменных должен быть помещен в раздел общих объявлений (general), доступ к которому открывается щелчком мыши по элементу “general” раскрывающегося списка окна Object формы. Объявленная таким образом переменная имеет статус действующей на уровне модуля (modul-level variable) и может использоваться (доступна) в любой процедуре данной формы. Для того чтобы одна и та же переменная могла использоваться в процедурах разных форм одной программы она должна быть объявлена как глобальная переменная (global variable). Используется ключевое слово Global вместо Dim. Пример: Global Name, YourName As String, N As Integer, Money As Currency, SurName As String* 75 Операторы объявления глобальных переменных помещаются в-модулях кода (code modules, см. ниже) и эти переменные могут использоваться во всей программе. Схема, иллюстрирующая области действия переменных, показана на рис. 3.1. В Форме 1 переменная Р объявлена в разделе общих объявлений (general) формы и может быть использована как в Процедуре X, так и в Процедуре Z. Изменение значения переменной в одной из процедур влечет за собой изменение и в другой процедуре. [pic] Рис. 3.1 Объявленные переменные И в Процедуре Х и G в Процедуре Z Формы 1 определены только внутри этих процедур, аналогично переменной G в Процедуре_У Формы 2. Эти переменные определены только в рамках своих процедур. Более того, для одноименных переменных G в Процедуре Z и в Процедуре Y выделяются разные ячейки памяти и изменение значения переменной G в одной из процедур не влечет изменения значения в другой процедуре. Переменные А и В определены как глобальные для всей программы и доступны во всех процедурах Формы 1 и Формы 2. Изменение значения переменных в одной из процедур одной из форм влечет изменение значений в других процедурах и формах. Рассмотренные области действия переменных справедливы и для других объявляемых данных (констант, пользовательских типов данных, массивов и др.). Как было сказано выше, описания глобальных данных помещаются .в модуль кода. Определения формы и все связанные с ней программы хранятся в отдельном файле с расширением .FRM. Программы, состоящие из нескольких форм и соответственно из нескольких таких файлов, размещаются в файлах модулей кода с расширением. Такие файлы создаются при выборе в меню Insert (Вставить) команды Module (Создать модуль) или при щелчке мыши на одноименной кнопке панели инструментов. 3.2.5. Пользовательские типы данных (записи) Данные различных типов можно сгруппировать по какому-либо признаку в удобную для использования одну структуру. В ряде языков программирования такие структуры называются записями (records). Оператор объявления пользовательского типа данных (записи) помещается в модуль и имеет вид: Type имя записи имя элемента записи [(описатель)} As тип [имя элемента записи [(описатель)} As тип} End Type [pic] Оператор создает указанную структуру данных, но не выделяет под неё память. Память выделяется рассмотренным оператором описания, в котором в качестве типа указывается имя записи (имя пользовательского типа данных). Пример: Dim Student_l, Student_2 As Student Описаны два имени (Student_l, Student_2 ), для каждого из которых определены заданные в структуре компоненты (Familia, Name, Voyast, Birthdate, Length, Wegith) и для хранения значений которых выделяется память соответственно заданному типу (длине и способу представления). Для обращения к конкретному свойству (элементу структуры) определенного объекта используется составная запись имя переменной.элемент структуры Например, Student'_]. Birthdate определяет дату рождения студента Student_7. 3.2.6. Массивы Массив - упорядоченный набор однотипных данных, обозначенный одним именем. Массив может строится из однотипных переменных, однородных пользовательских типов данных (одинаковых записей), однотипных элементов пользовательских типов данных. Массив объявляется уже рассмотренным оператором {Dim | Global [ Static) имя [({описатель})} [As [New] тип} [, имя [([описатель])} [As [NewJ/гаил] ] . . . где описатель имеет следующий синтаксис: [нижняя граница То ]верхняя граница[,[нижняя граница То] верхняя граница] . . нижняя граница определяет минимальное значение индекса массива (целого типа); верхняя граница определяет максимальное значение индекса массива (целого типа); То — ключевое слово. Количество повторений [нижняя граница То [верхняя граница определяет размерность массива (количество индексов, используемое для определения элементов массива). Максимальное число индексов равно 60. Static в процедурах и функциях позволяет сохранить значения элементов объявленного таким образом массива между вызовами этих процедур или функций. Пример различного способа объявления одного и того же массива: . Dim A(8,3) As Double Dim A(6>To 8, О То 3) As Double Dim A(8, OTo 3} As Double Объявляется двухмерный массив (два индекса). Нижняя граница обоих индексов равна 0 (принимается по умолчанию). Верхняя граница первого индекса равна 8, второго — 3. Массив состоит из 36 элементов (9*4=36) одинакового типа (вещественный) и каждый элемент занимает 8 байтов. Границы значений индексов: от —32768 до 32767. Примеры: Dim A(—4 То 10} As Integer Dim B(—99 То —5, —3 То 0) As String Элементы массива занимают связанную последовательную область в памяти машины. Массив А в примере занимает в памяти машины последовательность из 15 ячеек памяти, каждая из которых имеет длину 2 байта (тип Integer имеет длину 2 байта, рис. 3.2). [pic] Многомерные массивы также занимают линейную последовательную область памяти. При этом важное значение имеет способ упорядочения элементов многомерных массивов, который отличается для различных языков программирования. В Visual Basic многомерные массивы упорядочиваются в памяти машины так, что быстрее всего меняется левый индекс. Например, двумерный массив (в прикладных математических программах матрицы представляются двумерным массивом) А (2,3), состоящий из 12 элементов, располагается в памяти машины следующим образом: А(0,0), А(1,0), А(2,0), А(0,1), А(1,1), А(2,1), А(0,2), А(1,2), А(2,2), А(0,3), А(1,3), А(2,3) (если данный массив представляет матрицу, то в памяти машины она упорядочивается по столбцам). Для рассмотренного пользовательского типа данных (записи) Student можно также объявить массив оператором Dim MasStudent (25) As Student Объявляется одномерный массив MasStudent, состоящий из 26 элементов, каждый из которых является одной записью: Type Student Familia As String * 20 Name As String * 10 Voyast As Integer Birthdate As Double Length As Integer Wegith As Integer End Type рассмотренной выше. Записи располагаются последовательно в памяти машины и занимают каждая 44 байта. 20 байт занимает Familia (один символ занимает 1 байт), 10 байт - Name, 2 байта -Voyast (целый тип занимает 2 байта), 8 байт - Birthdate (вещественный двойной точности занимает 8 байт) и по 2 байта -Length и Wegith (целый тип). Элемент пользовательского типа данных (записи) может являться массивом. Например, можно объявить массив записей для хранения результатов экзаменов студентов группы. Туре Rezultat Familia As String * 20 NameExam (4) As String * /5 RewltExam (4) As Integer End Type Dim Sesia(25) As Reyiltat Объявлен пользовательский тип данных Rewltat, элементами которого являются Familia фиксированной длины 20 символов (фамилия студента не может состоять более чем из 20 символов), массив NameExam (4) из пяти элементов (число экзаменов в сессии не более 5) для хранения названия экзаменов (название каждого экзамена не может состоять более чем из 15 символов), массив RewltExam (4) из пяти элементов для хранения оценок по каждому экзамену (целого типа). Длина записи Rewltat 105 байтов. На базе пользовательского типа данных Requital объявлен массив Seпъ1 | | | | | | |Binary |Двоичные |До 1,2 Гбайт | |OLE |OLE — объекты |До 1.2 Гбайт | Кроме механизма Jet можно также использовать драйверы связи открытых баз данных (ODBC — Open Database Connectivity) для доступа к другим базам данных. Существуют также разнообразные механизмы баз данных других фирм, которые можно использовать с Visual Basic. Система Visual Basic позволяет хранить и использовать информацию в реляционных системах управления базами данных (английская аббревиатура — RDBMS). 5.2. РЕЛЯЦИОННАЯ СТРУКТУРА ДАННЫХ В подавляющем большинстве существующие СУБД построены на основе реляционной модели данных, которая, несмотря на свою внешнюю простоту, базируется на прочном фундаменте масштабных теоретических исследовании, основы которых были заложены Э. Коддом в 1969 г. Результаты этих теоретических исследований позволяют сделать данные полными непротиворечивыми и не избыточными, чтобы все факты оказав лись учтены, но при этом каждый из них хранился только один' раз. Специалисты в области создания и сопровождения баз данных должны знать и уметь использовать эту теорию. Реляционная база данных это такая база данных, которая состоит из таблиц (и ничего иного, кроме таблиц). Ссылка из одной таблицы на другую через какое- нибудь общее поле (common field) называется отношением (relation) ( отсюда и название реляционная). Рассмотрим пример реляционной базы данных состоящей из трех таблиц или отношений, таблица поставщиков, таблица деталей и таблица поставки деталей. Таблица поставщиков |Номер |Фамилия |Состояние |Город | |постав | | | | |щика | | | | |si |Смит |20 |Лондон | |s2 |Джонс |10 |Париж | |s3 |Блеик |30 |Париж | |s4 |Кларк |20 |Лондон | |s5 |Адаме |30 |Атенс | Каждый поставщик имеет уникальный номер, фамилии могут повторяться. Каждый поставщик находится только в одном городе. Таблица деталей |Номер |Название|Цвет |Вес |Город | |детали | | | | | |Pi |Гайка |Красный |12 |Лондон | |р2 |Болт |Зеленый |17 |Париж | |РЗ |Винт |Голубой |17 |Рим | |р4 |Винт |Красный |14 |Лондон | |р5 |Кулачок |Голубой |12 |Париж | |Р5 |Заклепка|Красный |19 |Лондон | Каждый вид детали имеет уникальный номер. Город — место хранения детали. Предполагается, что каждый вид детали имеет только один цвет и хранится на |
|
© 2000 |
|