Скачиваний:
55
Добавлен:
01.04.2014
Размер:
960 Кб
Скачать

31.Разработка ф-ций обработки сообщений, связ-х с пиктограммой на панели инструм-в. Класс панели инстр-в.

В большинстве случаев после того, как вы определите ресурсы панели инструментов и свяжете ее пиктограммы с идентификаторами соответствующих команд, ваша работа с панелью инструментов будет закончена. Тексты программ, подготовленные для вас AppWizard, обеспечат создание панели инструментов, a MFC при необходимости позаботится о вызове соответствующих функций обработки сообщений. Но может возникнуть ситуация, при которой вам потребуется изменить принятый по умолчанию порядок работы панели инструментов. В этом случае у вас есть возможность обратиться к функциям, входящим в состав класса СТооlBar. Панель инструментов доступна из класса CMainFrame как переменная-член m_wndToolBar. Как правило, порядок работы панели инструментов корректируется функцией CMainFrame::OnCreate().

Функции-члены класса СТооlBar.

Функция Назначение

CommandToIndex() Возвращает индекс пиктограммы

соответственно ее идентификатору

Create() Создает панель инструментов

GetButtonlnfo() Возвращает информацию о пиктограмме

GetButtonStyle() Возвращает стиль пиктограммы

GetButtonText() Возвращает текст названия пиктограммы

GetItemID() Возвращает идентификатор пиктограммы

соответственно ее индексу в панели

GetItemRect() Возвращает параметры прямоугольника,

ограничивающего элемент, индекс

которого задается как аргумент функции

GetToolBarCtrl() Возвращает ссылку на объект класса

CToolBarCtrl, представленный объектом СТооlBar.

LoadBitmap() Загружает графические изображения пиктограмм

LoadToolBar() Загружает ресурсы панели инструментов

SetBitmap() Задает графические образы пиктограмм новой

панели инструментов

SetButtonlnfo() Определяет идентификатор, стиль и номер

графического образа пиктограммы

SetButtons() Задает идентиф-ры для пиктограмм панели инст-в

SetButtonStyle() Задает стиль пиктограммы

SetButtonText() Задает текст названия пиктограммы

SetHeight() Задает высоту панели инструментов

SetSizes() Задает размеры пиктограмм

Как правило, у вас не возникнет необходимости вызывать методы панели инструментов, но, обращаясь к ним, можно достичь некоторых необычных результатов, например, увеличить размеры панели инструментов. Подобный вид панели инструментов получен путем обращения к методу SetHeightO объекта— панели инструментов.

Методы класса CToolBar : дают возможность выполнять с панелями инструментов различные трюки, но пользоваться ими следует с большой осторожностью.

32. Доступ к базам данных в vs. Классы odbc.

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

Современные версии Visual C++ включают классы, базирующиеся на механизмах ODBC (Open Database Connectivity — открытая связь с базами данных) и DAO (Data Access Objects— объекты доступа к данным).

Основные понятия теории баз данных

Однофайловая модель базы данных:

В простейшем представлении база данных является набором записей. Каждая запись в базе данных состоит из полей, а в каждом поле содержится информация, связанная с этой конкретной записью. В такой базе данных каждому клиенту соответствует одна запись. Она состоит из шести полей: ИМЯ, УЛИЦА, ДОМ, ГОРОД, ИНДЕКС (почтовый индекс) и ТЕЛЕФОН (номер телефона) (пример одной записи). Вся БД будет состоять из большого кол-ва подобных записей. Данный тип СУБД исп-т однофайловую модель базы данных (flat database model). Однако в случае больших баз данных, одноф-я модель может привести к дублир-ю инф-и и нерацион-му исп-ю памяти.

Реляционная модель базы данных:

Реляционная (от relation — отнош-е, связь) БД подобна неск-м связ-м одноф-м БД. При работе с реляционной БД можно не только выполнять поиск отдельн. записей, как это дел-ся в одноф-й БД, но и устанавл-ть связь одного набора записей с другим. Это позволяет организовать гораздо более эф-ное хранение данных. Каждый набор записей в реляц. БД наз-ся таблицей (table). Связи устан-ся с исп-м ключей (key), т.е. полей, значения которых хар-ют запись. (Напр, идентификационный код служащего мог бы быть ключом для таблицы служащих.)

Доступ к базе данных

Доступ к данным в реляц-х СУБД осущ-ся с исп-м опред-го командн. языка. Чаще всего для доступа к БД исп-ся язык SQL, который прим-ся при работе не только с СУБД для настольных комп-в, но и с громадными БД, исп-ми в банках, учебных завед-х, промышл-х корпорациях и других учр-х, в кот-х необх-мо решать сложнейшие задачи обр-ки инф-ции. Используя язык, подобный SQL, можно извлекать данные, представл-е полями записей из одной или неск-х таблиц, кот-е объед-ны в реляц. БД.

Классы ODBC Visual C++

Создавая с помощью мастера Visual C++ AppWizard прог-му, работ-ю с БД, вы получаете в итоге прилож-е, широко использ-е различные классы ODBC из состава библиотеки MFC. Наиболее важными из этих классов являются CDatabase, CRecordset и CRecordView.

Мастер AppWizard автомат-ки генерирует текст прог-мы, необх-й для coздания объекта класса CDatabase. Этот объект обесп-т связь м/у созд-м прилож-м и источником данных, с которым оно работает. В большинстве случаев использование класса CDatabase в прог-х, сгенерир-х AppWizard, прозрачно для программиста. Вся необх-я обр-ка обеспеч-ся самой сист-й упр-я.

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

И наконец, объект класса CRecordView в БД-программе занимает место объекта класса представления, с которым постоянно приходится иметь дело в приложениях, созданных с помощью мастера AppWizard. Окно, создаваемое объектом класса CRecordView, подобно диалоговому окну, выполн-му роль средства общения пользователя с приложением. Это диалоговое окно обеспечивает в приложении связь с объектом класса CRecordset, осуществляя обмен инф-й между программой, элементами управления окна и выборкой данных. Когда с помощью мастера AppWizard создается новое БД-приложение, на программиста возлагается обязанность поместить в окно объекта CRecordView элементы управления, способные выполнять ввод и редактирование данных. Как правило, это текстовые поля. Такие элементы управления следует связать с полями записей базы данных, которые они представляют, для того, чтобы приложение направляло данные, выбранные для просмотра, куда следует.

Создание БД-программы на основе классов ODBC:

Создать с помощью Visual C++ простую БД-программу, использующую классы ODBC, совсем несложно — для этого нужно выполнить всего несколько операций.

1. Зарегистрировать базу данных в системе.

2.Исп-я мастер AppWizard, создать заготовку БД-приложения.

3.Добавить в заготовку приложения программный код, реализующий функции, которые AppWizard автоматически не формирует.