Основы создания Windows-приложений в системе Microsoft Visual Studio C++. Процедурный стиль

Программирование в ОС Windows. Базовые понятия оконных приложений и каркасного программирования в системе Microsoft Visual Studio C++. Состав, структура и функционирование типового каркаса оконного приложения. Схема описания, реализации главного окна.

Рубрика Программирование, компьютеры и кибернетика
Вид методичка
Язык русский
Дата добавления 27.09.2017
Размер файла 413,5 K

Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже

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

76

Размещено на http://www.allbest.ru/

50

Министерство образования Республики Беларусь

Учреждение образования "Брестский государственный технический университет"

Методическое пособие

“Основы создания windows-приложений в системе Microsoft Visual Studio C++. Процедурный стиль”,

Часть 1

Муравьев Геннадий Леонидович

Брест 2007

УДК681.3 (075.8)

ББКс57

Учреждение образования “Брестский государственный технический университет”

Кафедра интеллектуальных информационных технологий

Рекомендовано к изданию редакционно-издательским советом

Брестского государственного технического университета

Рецензент: доцент кафедры математического моделирования Брестского государственного университета им.А.С. Пушкина, к. т. н., доцент Пролиско Е. Е.

Автор-составитель: Г.Л. Муравьев, доцент, к. т. н.

ОСНОВЫ СОЗДАНИЯ WINDOWS-ПРИЛОЖЕНИЙ В СИСТЕМЕ MICROSOFT VISUAL STUDIO C++. Процедурный стиль. Г.Л. Муравьев. - Брест.: БрГТУ, 2007. Часть 1. - 48 с.

Целью пособия является знакомство студентов с базовыми понятиями оконных приложений и каркасного программирования в системе Microsoft Visual Studio C++.

УДК 681.3 (075.8)

ББК с57

© Учреждение образования

“Брестский государственный технический университет”, 2007

Оглавление

  • 1. Особенности программирования в ОС Windows
  • 1.1 Особенности применения технологий программирования в операционной системе Windows
  • 1.2 Особенности операционной системы Windows
  • 1.3 Особенности оконных приложений Windows
  • 1.4 Особенности программирования оконных Windows-приложений на языках С, С++
  • 1.5 Заголовочные файлы Windows
  • 1.6 Типы данных Windows
  • 1.7 Венгерская нотация. Префиксы идентификаторов
  • 2. Особенности применения технологий программирования в системе Visual Studio. Каркасное программирование
  • 3. Оконные Windows-Приложения
  • 3.1 Общая структура оконных приложений
  • 3.2 Общая структура оконных приложений (уровень реализации)
  • 3.3 Структура программного обеспечения оконных приложений
  • 4. Состав, структура и функционирование типового каркаса оконного Приложения (ТКП)
  • 4.1 Структура ТКП
  • 4.2 Структура программного обеспечения ТКП
  • 4.3 Сообщения. Общая схема обработки сообщений
  • 4.4 Информационная модель ТКП
  • 4.5 Главная функция ТКП
  • 4.5 Функция-обработчик сообщений главного окна ТКП
  • 4.6 Примерный текст ТКП. Состав функций
  • 4.7 Описание и регистрация класса (стиля) окна. Использование структуры WNDCLASS
  • 4.8 Создание и визуализация окна
  • 4.9 Управление окном приложения
  • 5. Разработка и использование приложений на базе типового каркаса оконного Приложения (ТКП)
  • 5.1 Общая схема технологии разработки приложений на базе ТКП
  • 5.2 Характеристика этапов разработки приложений на базе ТКП
  • 5.3 Общая схема описания, реализации главного окна ТКП
  • 5.4 ТКП. Создание в системе Visual Studio
  • 6. Порядок выполнения работы
  • Литература
  • Приложение 1. Описание полей структуры WNDCLASS
  • Приложение 2. Значения параметра hCursor структуры WNDCLASS (встроенные курсоры)
  • Приложение 3. Значения параметра hbrBackGround структуры WNDCLASS (встроенные кисти и цвета закраски фона окна)
  • Приложение 4. Значения параметра Style структуры WNDCLASS
  • Приложение 5. Значения параметра dwStyle функции CreateWindow (доопределение стиля окна)
  • Приложение 6. Значения параметра nCmdShow функции ShowWindow (доопределение состояния окна при начальном запуске)
  • Приложение 7. Описание ТКП

1. Особенности программирования в ОС Windows

1.1 Особенности применения технологий программирования в операционной системе Windows

При разработке программного обеспечения, ориентированного на исполнение с участием операционной системы Windows, говорят о разработке Windows-приложений или просто приложений (либо, на момент разработки, т.е. до получения готового к исполнению продукта - говорят о разработке проекта приложения - project). Здесь существует два основных подхода (технологических направления) к разработке приложений.

Первый подход - процедурная разработка (процедурное проектирование, программирование, тестирование), базирующаяся на алгоритмической декомпозиции предметной области (автоматизируемых задач) и принципах структурной разработки программ. При разработке Windows-приложений этот подход называют также стилем низкоуровневого программирования, так как он связан с непосредственным использованием функций операционной системы Windows - Win32 API. Результатом применения этого стиля в среде Visual Studio являются Windows-приложения. Это API-приложения как “консольного” так и “оконного" типов.

Второй подход - объектно-ориентированная разработка (проектирование, программирование, тестирование), базирующаяся на объектной декомпозиции предметной области и принципах объектно-ориентированной модели ПО. При разработке Windows-приложений этот подход называют также стилем высокоуровневого программирования, так как он не ориентирован на непосредственное использование функций операционной системы Windows (хотя и допускает их прямое использование), а базируется на использовании библиотек готовых классов (где и эти функции инкапсулированы в соответствующих классах) и пользовательские классы. Это, например, следующие библиотеки: - MFC (Microsoft Foundation Class Library), используемая для создания сложных Windows-приложений с богатым графическим интерфейсом; - ATL (Microsoft Active Template Library) библиотека шаблонов ActiveX для создания СОМ-объектов и элементов управления ActiveX; - STL (Standard Template Library) стандартная библиотека шаблонов. Результатом применения этого стиля в среде Visual Studio являются Windows-приложения. Это оконные MFC-приложения как “статичного" так и “динамического” типов.

1.2 Особенности операционной системы Windows

Операционная система Windows базируется на понятии виртуальная машина. Она воплощает принципы обеспечения независимости пользователя от особенностей конкретных аппаратных средств системы, а также деталей реализации программных компонентов и функций предоставляемого ею программного обеспечения. Это принципы сокрытия от пользователя деталей управления предоставляемыми ресурсами, принципы стандартизации средств управления. Указанная идеология находит отражение в интерфейсе управления ОС - GDI (Graphics Device Interface). Он обеспечивает программиста средствами выстраивания стандартных (оконных) интерфейсов и средствами их реализации (функциями API взамен функций DOS).

Windows отличается так же обеспечением многозадачности. Под его управлением одновременно может выполняться много приложений. Более того, в рамках приложений могут быть определены параллельно выполняемые и при необходимости синхронизируемые участки (потоки). Указанное поддерживается аппаратом DLL-функций (реентерабельных модулей), автоматическим управлением памятью системы в защищенном режиме (на базе виртуальной - линейной, плоской модели памяти в 4 Гб с использованием механизмов страничного скроллинга), стратегией вытесняющей многозадачности с разнообразными дисциплинами обслуживания решаемых задач, включая механизм разделения времени типа RR.

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

1.3 Особенности оконных приложений Windows

Такие приложения предлагают пользователю привычный для ОС Windows интерфейс на базе системы, иерархии окон. Это окна различных типов (“классические” всплывающие окна с клиентской областью, пользовательские и стандартные диалоговые окна, включая специальные окна типа Save As и т.п.) и расположенные в них элементы управления (меню, кнопки, списки и т.п.). Одно из окон является “главным”, поскольку запускается первым. Теперь происходящие сообщения относятся именно к нему. В частном случае приложение может не иметь окон. Типичное оконное Windows-приложение в качестве главного окна выводит “классическое" всплывающее окно. При необходимости в роли главного окна может использоваться диалоговое окно.

Соответственно типичное оконное Windows-приложение, написанное, например, на языке С++, отличается специфической структурой, предусматривающей использование специальной глобальной функции WinMain (аналог функции main языка С) и, как минимум, одной функции типа обработчик сообщений окна. Это, как правило, обработчик сообщений главного окна. Функция WinMain является точкой первого входа в приложение после его запуска пользователем. Она производит интерфейсные настройки и затем переходит в режим ожидания и диспетчирования потока сообщений. А функция обработчик (главного окна), относящаяся к особому типу функций обратного вызова, запускается со стороны ОС посылкой сообщения, обрабатывает его, ждет следующих сообщений. Эта функция может включать вызовы других функций на языке С, в том числе вызовы библиотечных функций С, С++, вызовы функций Windows, пользовательских функций.

1.4 Особенности программирования оконных Windows-приложений на языках С, С++

При программировании приложений традиционно существуют отличия и особенности использования средств языка С и языка С++.

Есть особенности в написании Windows-приложений обусловленные спецификой 16 или 32 разрядной реализаций ОС Windows. Это: - несовпадение разрядностей одних и тех же типов (например, тип int может использовать 16 или 32 бита); - несовпадение типов указателей (в DOS и 16 разрядной реализаций ОС Windows используются как 16 битовые указатели типа near, так и 32 битовые указатели типа far и huge, а в 32 разрядной реализаций ОС Windows все указатели являются ближними - near и занимают 32 бита).

Есть особенности, определяемые самой ОС Windows, связанные с уже упоминавшейся особой структурой приложений, особыми типами функций, обработкой сообщений и организацией взаимодействия через сообщения. Это использование большого числа новых заголовочных файлов, подключаемых, в частности, через хедер windows. h автоматически. Кроме этого существуют и стилевые особенности:

использование переопределенных, дополнительных имен для обозначения типов данных языка С, С++ (наряду со стандартными именами); - использование новых, специфических типов (имен типов) для новых объектов-данных и указателей (дескрипторов, типов результатов, специфических типов указателей на наиболее распространенные типы данных общего назначения и т.п.), определенных на базе стандартных типов данных С++; - широкое применение венгерской нотации - правил записи имен переменных, объектов в соответствии с принципами структурного программирования; - использование специфичных структур данных как для организации функционирования приложений так и для организации пользовательских функций.

1.5 Заголовочные файлы Windows

В системе Visual Studio используется много новых заголовочных файлов (хедеров), подключаемых к приложению. Как правило, если приложение создается программой-мастером на базе специального шаблона, называемого заготовкой, каркасом приложения, то большинство необходимых приложению заголовочных файлов включаются в него мастером автоматически в том числе, например, и через хедер windows. h для оконных приложений. Состав включения зависит от выбранного в системе программирования типа создаваемого приложения и его атрибутов. Заголовочные файлы (несколько сотен) находятся в папке Include системы.

оконное приложение каркасное программирование

Рис. 1. Структура папок

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

#include <windef. h> #ifndef NOGDI

#include <winbase. h> #include <commdlg. h>

#include <wingdi. h> #ifndef _MAC

#include <winuser. h> #include <winspool. h>

… #ifdef INC_OLE1

#include <wincon. h> #include <ole. h>

#include <winver. h> #else

… #include <ole2. h>

#endif,

которые в свою очередь могут подключить следующие заголовочные файлы.

Заголовочный файл windowsx. h осуществляет подключение определений макрофункций API, обработчиков оконных сообщений и функций элементов управления.

Заголовочный файл windef. h определяет новые типы данных для специфичных объектов Windows, например, DWORD, BOOL, BYTE, WORD, PFLOAT и другие.

В заголовочном файле winbase. h определены структуры, прототипы базовых API функций, необходимых для управления ресурсами 32 разрядной реализаций ОС Windows. Например, структуры SYSTEMTIME, PROCESS_INFORMATION, прототипы функций WinMain, CreateThread, WriteFile, ReadFile, GetSystemTime и т.д.

В заголовочном файле wingdi. h декларированы прототипы GDI функций, константы и макросы, необходимые для работы с экраном (операций ввода-вывода), например структуры BITMAP, TEXTMETRICA, функции Arc, CreatePalette, CreatePen и другие.

В заголовочном файле winuser. h определены прототипы функций, константы и макросы, используемые программистом в пользовательских приложениях, например, функции WNDPROC, DLGPROC и другие.

Кроме этого, в папке Include представлены специфические хедеры типа cmath, cstdio, cctype, climits, cstring и другие, позволяющие подключать в новом стиле стандартные функции из старых библиотек. Например, для подключения математических функций, описанных хедером math. h, используется директива #include <cmath>. Здесь хедер cmath включает фрагмент для подключения хедера math. H

#ifdef _STD_USING

#undef _STD_USING

#include <math. h>

#define _STD_USING

#else

#include <math. h>

#endif.

1.6 Типы данных Windows

Дополнительные имена для обозначения типов данных языка С, С++ (наряду с их стандартными именами), введенные путем переопределения командой typedef стандартных названий, представлены и описаны ниже (см. таблицу 1):

typedef unsigned long DWORD; typedef CONST void far *LPCVOID;

typedef int BOOL; typedef int INT;

typedef unsigned char BYTE; typedef unsigned int UINT;

typedef unsigned short WORD; typedef unsigned int *PUINT;

typedef float FLOAT; typedef unsigned long ULONG;

typedef FLOAT *PFLOAT; typedef ULONG *PULONG;

typedef BOOL near *PBOOL; typedef unsigned short USHORT;

typedef BOOL far *LPBOOL; typedef USHORT *PUSHORT;

typedef BYTE near *PBYTE; typedef unsigned char UCHAR;

typedef BYTE far *LPBYTE; typedef UCHAR *PUCHAR;

typedef int near *PINT; typedef UINT WPARAM;

typedef int far *LPINT; typedef LONG LPARAM;

typedef WORD near *PWORD; typedef LONG LRESULT;

typedef WORD far *LPWORD; typedef WORD ATOM;

typedef long far *LPLONG; typedef int HFILE;

typedef DWORD near *PDWORD; typedef void far *LPVOID;.

typedef DWORD far *LPDWORD;

Таблица 1. Типы данных общего назначения

Тип

данного

Тип-аналог

C++

Размер, бит

Описание значений

Диапазон

BOOL

-

32

логическое значение

TRUE (1),

FALSE (0)

BOOLEAN

-

32

логическое значение

TRUE (1), FALSE (0)

BYTE

unsigned char

8

байт без знака для хранения числа или кода символа

0.255

CCHAR

char

8

символ Windows

-128. +127

CHAR

char

8

символ Windows

-128. +127

CONST

const

-

константа

-

DWORD

unsigned long

32

двойное слово без знака

0.42944967295

DWORDLONG

double

64

число с плавающей точкой со знаком

1.7E-308.1.7E+308

FLOAT

float

32

число с плавающей точкой со знаком

3.4E-38.3.4E+38

INT

int, long

32

целое число со знаком

-2147483648. +2147483647

LONG

long, int

32

целое число со знаком

-2147483648. +2147483647

LONGLONG

double

64

число с плавающей точкой со знаком

1.7Е-308.1.7Е+308

SHORT

short

16

короткое целое число со знаком

-32768. +32767

TBYTE

unsigned char

8

байт без знака для хранения числа или кода символа

0.255

TCHAR

char

8

символ Windows или Unicode

-128. +127

UCHAR

unsigned char

8

символ Windows без знака

0.255

UINT

unsigned int

32

целое число без знака

0.4294967295

ULONG

unsigned long

32

целое число без знака

0.4294967295

USHORT

unsigned short

16

короткое целое число без знака

0.65535

VOID

void

-

любой тип

-

WCHAR

wchar_t

16

символ Unicode

0.65535

WORD

-

16

короткое целое число без знака

0.65535

Специфические типы указателей на наиболее распространенные типы данных общего назначения, определенные на базе стандартных типов данных С++ командой typedef (заголовочный файл windef. h), представлены в таблице 2 ниже.

Таблица 2. Типы указателей на типы данных общего назначения

Обозначение

указателей

Тип адресуемого данного

Примечание

LPBOOL, PBOOL

BOOL

LPBYTE, PBYTE

BYTE

LPCCH, РССН

CONST CHAR

константный символ

LPCH, РСН

CHAR

символ

LPCSTR, PCSTR

CONST CHAR

константная строка с завершающим нулем

LPCTSTR

CONST TCHAR

константная строка символов Windows или Unicode с завершающим нулем

LPCWCH, PCWCH

CONST WCHAR

константный символ Unicode

LPCWSTR, PCWSTR

CONST WCHAR

константная строка Unicode с завершающим нулем

LPDWORD, PDWORD

DWORD

LPINT, PINT

INT

LPLONG, PLONG

LONG

LPSTR, PSTR

CHAR

строка символов с завершающим нулем

LPTCH, PTCH

TCHAR

символ Windows или Unicode

LPTSTR, PTSTR

TCHAR

строка символов Windows или Unicode с завершающим нулем

LPVOID, PVOID

VOID

LPWCH, PWCH

WCHAR

символ Unicode

LPWORD, PWORD

WORD

LPWSTR, PWSTR

WCHAR

строка Unicode с завершающим нулем

NPSTR

CHAR

строка символов с завершающим нулем

PBOOLEAN

BOOL

PCHAR

CHAR

символ Windows

PFLOAT

FLOAT

PSHORT

SHORT

PSZ

CHAR

строка символов с завершающим нулем

PTBYTE

TBYTE

символ Windows или Unicode

PTCHAR

TCHAR

символ Windows или Unicode

PUCHAR

UCHAR

символ Windows без знака

PUINT

UINT

PULONG

ULONG

PUSHORT

USHORT

PWCHAR

WCHAR

символ Unicode

Примеры новых типов для описания специфичных объектов Windows, определенных на базе стандартных типов данных С++ (см. заголовочный файл windef. h), представлены ниже. Например, команда typedef LONG LRESULT определяет тип LRESULT, используемый как тип результата работы функции-обработчика сообщений окна; typedef int HFILE определяет тип HFILE, используемый в качестве дескриптора файла и т.п.

1.7 Венгерская нотация. Префиксы идентификаторов

Для повышения читабельности текстов приложений за счет осмысленности используемых в них идентификаторов (имен) в ОС Windows и приложениях Windows применяется венгерская нотация. Это правила записи имен переменных, объектов в соответствии с принципами структурного программирования.

Таблица 3. Типовые префиксы венгерской нотации

Префикс

Полный префикс

Смысловое значение префикса

b

Bool

логическая переменная

с

Character

символ, 1 байт

dw

DoubleWord

двойное слово без знака, 32 бита (целое число)

f / fn

Function

функция

pfn

PointerFunction

указатель на функцию

lpfn

LongPointerFunction

длинный указатель на функцию

h

HANDLE

дескриптор объекта

hDC

HANDLE

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

id

значение ID-идентификатора

l

LONG

длинное целое со знаком, 32 бита

lp

LongPointer

дальний указатель, 32 бита

lpsz

LongPointerStringZero

дальний указатель на строку, заканчивающуюся нуль-символом, 32 бита

n

iNt

короткое целое число со знаком

p / nр

Pointer

ближний указатель, 32 бита

pt

PoinT

х и у координаты точки, упакованные в 64 бита

s

String

строка

sz

StringZero

символьная строка, заканчивающаяся нуль-символом

pst

PointerStruct

указатель на структуру

psz

PointerStringZero

указатель на строку, заканчивающуюся нуль-символом

u

Uint

беззнаковый символ, целое без знака

w

WORD

беззнаковое значение, 16 бит

by

BYTE

беззнаковый символ

i

Integer

целое число, 32 бита

pv

PointerVoid

указатель на тип void

v

Void

тип void

W

Wide

символ UNICODE, 16-бит

Соответственно при описании переменных в С++ при создании Windows-приложений используются специальные правила формирования имен на базе префиксов (см. таблицу 3). Здесь префиксное_ИМЯ_ПЕРЕМЕННОЙ:: = <префикс> < основное_ИМЯ_ПЕРЕМЕННОЙ >, где префиксное_ИМЯ_ПЕРЕМЕННОЙ формируется по правилам венгерской нотации и явно определяет его типовую принадлежность; <префикс>, описываемый строчными буквами, задает тип переменной в виде одного из типовых сокращений; < основное_ИМЯ_ПЕРЕМЕННОЙ > представляет собой составное мнемоническое имя переменной, записанное строчными символами, без подчеркиваний, каждая часть имени пишется с заглавной буквы.

Ниже приведены примеры описания имен, используемых в различных приложениях:

int nCmdShow; LPSTR lpszCmdLine; HINSTANCE hInst;

int cbClsExtra; LPSTR szCmdLine; HANDLE hInst;

UINT nMessage; LPCSTR lpszClassName; HWND hWnd;

DWORD dwStyle; LPCSTR szProgName; HICON hIcon;

LPCSTR lpszMenuName; HCURSOR hCursor;

MSG lpMsg; HMENU hMenu;

WPARAM wParam; WNDPROC lpfnWndProc;

LPARAM lParam;.

2. Особенности применения технологий программирования в системе Visual Studio. Каркасное программирование

Visual Studio - это система программирования, комплект (suite) средств разработки, включающий язык Visual C++, комплекс программ, объединенных в интегрированную среду разработки (Integrated Development Environment), и библиотеки функций. Visual Studio ориентирован на создание как автономных (работающих на отдельной ПЭВМ) так и сетевых приложений под Windows. Это оконные Windows-приложения (в частном случае консольные приложения), создаваемые с использованием как технологии процедурной разработки программ (стиль низкоуровневого программирования) так и технологии объектно-ориентированной разработки программ (стиль высокоуровневого программирования). Соответственно Visual Studio содержит в своем составе два набора программных средств для поддержки указанных технологий, включающих, помимо типового набора средств системы программирования, также готовые каркасы типовых приложений и мастера для их создания.

Каркас приложения это готовая заготовка для каждого типового Windows-приложения (например, каркас консольного приложения и т.п.). Выбор, предварительная настройка конкретного типа каркаса и автоматическая генерация его текста производится с помощью мастеров построения каркасов. Результат - программный текст. Само же программирование в Visual Studio называется каркасным, поскольку базируется на использовании каркасов типовых Windows-приложений с их последующим до программированием.

Результатом применения стиля низкоуровневого программирования в системе Visual Studio являются API-приложения как “консольного” (тип проекта в системе Visual Studio - “Win32 Console Application”) так и “оконного" (тип проекта в системе Visual Studio - “Win32 Application”), а также смешанного типов. При создании таких приложений с помощью средств системы Visual Studio можно использовать следующие типовые каркасы:

1) для консольного API-приложения (тип проекта в системе Visual Studio - “Win32 Console Application”) каркасы типа пустой - Empty (“An empty project”), простой - Simple (“A simple application”), простой с выводом приветствия - Hello (“A “Hello, World" application”);

2) для смешанного консольного API-приложения (тип проекта в системе Visual Studio - “Win32 Console Application”) каркас типа API-MFC (“An application that supports MFC”);

3) для оконного API-приложения (тип проекта в системе Visual Studio - “Win32 Application”) каркасы типа пустой - Empty (“An empty project”), простой - Simple (“A simple Win32 application”), Hello (“A typical “Hello, World" application”).

Результатом применения стиля высокоуровневого программирования в системе Visual Studio являются “статические” (тип проекта в системе Visual Studio - “MFC AppWizard (exe) ”) и “динамические" (тип проекта в системе Visual Studio - “MFC AppWizard (dll) ”) оконные MFC-приложения. При создании таких приложений с помощью системы Visual Studio можно использовать следующие типовые каркасы:

1) для статического MFC-приложения (тип проекта в системе Visual Studio - “MFC AppWizard (exe) ”) каркасы c однодокументным интерфейсом (“Single document”), c многодокументным интерфейсом (“Multiple documents”), с интерфейсом в виде диалогового окна (“Dialog based”);

2) для динамического MFC-приложения (тип проекта в системе Visual Studio - “MFC AppWizard (dll) ”) доступны каркасы “Regular DLL with MFC statically linked”, “Regular DLL using shared MFC DLL), “MFC extension DLL (using shared MFC DLL)).

3. Оконные Windows-Приложения

3.1 Общая структура оконных приложений

С точки зрения пользователя (на уровне применения) приложение может быть описано законом функционирования с помощью поведенческих моделей. Например, в терминах перечня решаемых задач, соответствующей входной и выходной информации и правил получения выходной информации из входной без раскрытия способов реализации задач (закона функционирования приложения) как на рисунках 2,3. Каждая из решаемых задач может быть детализирована в виде сценария использования приложения в терминах поддерживаемого им графического интерфейса пользователя.

На рисунках здесь и далее сплошными линиями показаны направления передачи управления от модуля к модулю (например, от ОС к приложению), пунктирным линиям соответствуют направления передачи сообщений (например, от ОС к приложению и обратно). Ломаные стрелки отображают действия, события, инициирующие сообщения (, например, действия пользователя - нажатие клавиши, перемещение “мыши" и т.п.), полые стрелки показывают направления движения информации, данных (например, от пользователя к приложению и в обратно).

В структуре приложения (рисунок 4) можно выделить часть, видимую пользователем - интерфейс приложения, и сами программы, поддерживающие интерфейс и выполняющие обработку данных в соответствии с принятыми сообщениями, - реализация приложения.

Интерфейс оконного приложения (рисунок 5) в общем случае может быть представлен, как правило, системой окон различных классов и типов с расположенными на их поверхности элементами управления. Пользователь может воздействовать на элементы управления (например, нажатием кнопки, выбором пункта меню и т.д.) и тем самым посылать сообщения. При загрузке приложения, как правило, выводится начальное (главное) окно приложения и начинает работать связанная с ним программа обработчик сообщений, адресуемых этому окну. При этом возможна передача управления (активности) одному из других окон интерфейса (обработчику его сообщений). В текущем времени только одно из окон приложения является активным, а следовательно все полученные в этот момент сообщения адресуются именно этому окну (точнее на обработку программе обработчику сообщений активного окна). Сообщения приложению направляются со стороны ОС.

Более детально Windows-приложение может быть специфицировано в терминах обрабатываемых сообщений. Здесь поведенческое описание может представлять спецификацию сообщений, направляемых приложению, и спецификацию реакций приложения на полученные сообщения (при этом приложение по прежнему рассматривается как “черный" ящик).

76

Размещено на http://www.allbest.ru/

50

76

Размещено на http://www.allbest.ru/

50

76

Размещено на http://www.allbest.ru/

50

76

Размещено на http://www.allbest.ru/

50

Более детально Windows-приложение может быть специфицировано в терминах обрабатываемых сообщений. Здесь поведенческое описание может представлять спецификацию сообщений, направляемых приложению, и спецификацию реакций приложения на полученные сообщения (при этом приложение по прежнему рассматривается как “черный" ящик).

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

С учетом оконного интерфейса приложений схема их взаимодействия может быть представлена как на рисунке 7.

76

Размещено на http://www.allbest.ru/

50

3.2 Общая структура оконных приложений (уровень реализации)

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

76

Размещено на http://www.allbest.ru/

50

Соответственно оконное приложение можно рассматривать как совокупность описаний - основной программы WinMain (аналога main) и набора типовых комплектов. Типовой комплект компонентов приложения представлен на рисунке 8. Он включает описание ресурсов окна (стиля, вида, состава и размещения элементов управления в окне и т.п.) и описание алгоритмов работы программы - обработчика сообщений, адресуемых окну. Оба описания каждого комплекта компонентов связываются при создании приложения.

При активизации окно предоставляется пользователю (визуализируется на основе описания ресурсов окна) системой как элемент интерфейса. Пользователь, совершая события - действия над элементами управления окна, над самим окном либо другие действия, непосредственно не связанные с окном в момент его активизации (перемещение или нажатие клавиш “мыши”, манипуляции с клавиатурой и т.п.) посылает соответствующие сообщения, пересылаемые ОС обработчику сообщений, связанному с окном. Указанное иллюстрируется рисунком 9.

С учетом изложенного структура приложения и состав приложения представлены на рисунках 10, 11.

76

Размещено на http://www.allbest.ru/

50

76

Размещено на http://www.allbest.ru/

50

76

Размещено на http://www.allbest.ru/

50

3.3 Структура программного обеспечения оконных приложений

Примерная структура программ оконного приложения представлена ниже

< Команды_препроцессора >

< Прототип_функции_обработчика_главного_окна >

[< Прототипы_других_функций_обработчиков >]

[< Прототипы_прикладных_функций >]

[< Описания_глобальных_объектов >]

< Описание_главной_функции_WinMain >

< Описание_функции_обработчика_главного_окна >

[< Описание_других_функций_обработчиков >]

[< Описание_прикладных_функций >].

4. Состав, структура и функционирование типового каркаса оконного Приложения (ТКП)

4.1 Структура ТКП

Ниже рассмотрена базовая структура оконных приложений, называемая типовым каркасом приложения (ТКП). Реальное приложение создается путем до программирования и, или модификации типового каркаса.

Примерная структура ТКП представлена ниже на рисунке 12.

Прохождение потоков данных в ТКП представлено ниже на рисунке 13.

76

Размещено на http://www.allbest.ru/

50

4.2 Структура программного обеспечения ТКП

ТКП содержит две основные функции - главную WinMain (аналог main) и обработчик сообщений окна приложения. Они связаны друг с другом ассоциативно (обслуживают одно приложение) и информационно через общее главное окно интерфейса. Главная его создает и визуализирует, передавая активность и управление, и обеспечивая пользователя инструментом взаимодействия с приложением. Функция-обработчик (функция окна, оконная функция) относится к функциям обратного вызова, инициируемых ОС посылкой сообщений с уточняющими параметрами. Обработчик, обрабатывая сообщения окну, реализует нужные пользователю алгоритмы. С точки зрения классического управления в схеме иерархии эти модули стоят на одном уровне, так как не запускают друг друга непосредственно. Примерная структура ТКП оконного приложения представлена ниже, а алгоритмы указанных функций представлены на рисунке 14.

< Команды_препроцессора >

< Прототип_функции_обработчика_главного_окна >

[< Описания_глобальных_объектов >]

< Описание_главной_функции_WinMain >

< Описание_функции_обработчика_главного_окна >.

Ниже представлена структура функции WinMain, вызываемой из ОС,

СОЗДАНИЕ-ГЛАВНОГО-ОКНА-Приложения

Описание стиля главного окна

Регистрация стиля окна

Создание экземпляра окна

Визуализация окна

Обновление окна

РАБОТА-С-СООБЩЕНИЯМИ

ЦИКЛ-ПОКА не завершено приложение (не поступило сообщение WM_QUIT)

Получить очередное сообщение из очереди сообщений приложения

Диспетчировать сообщение (передать обработчику соответствующего окна)

КОНЕЦ-ЦИКЛА

Завершение работы приложения.

4.3 Сообщения. Общая схема обработки сообщений

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

Сообщения обозначаются как WM_SIZE, WM_MOVE, WM_CLOSE, WM_COMMAND, WM_LBUTTONDOWN, WM_DESTROY, WM_QUIT, WM_KEYDOWN, WM_TIMER, WM_CHAR, WM_CUT, WM_COPY и т.п. Непосредственно с приложением, окном, клиентской областью связаны сообщения WM_PAINT (перерисовать окно при изменении его размеров), WM_CLOSE при свертывании клиентского окна, WM_DESTROY при его закрытии, WM_QUIT при закрытии приложения.

Предварительная обработка сообщений с целью их отправки в соответствующие обработчики выполняется фрагментом WinMain, представленным ниже, а общая схема обработки сообщений иллюстрируются рисунком 15.

76

Размещено на http://www.allbest.ru/

50

while (GetMessage (&lpMsg, NULL, …, …))

{

TranslateMessage (&lpMsg);

DispatchMessage (&lpMsg);

}.

4.4 Информационная модель ТКП

С информационной точки зрения приложение может рассматриваться как совокупность специальных структур данных, обеспечивающих его работу. Работа ТКП базируется на использовании структур типа WNDCLASS, PAINTSTRUCT, HDC, MSG и других.

WNDCLASS (См. ПРИЛОЖЕНИЕ А) - структура для хранения информации о стиле окна. Описывается пользователем и после регистрации стиля окна в ОС <ИмяСтиляОкна> может использоваться для создания конкретных экземпляров окна. Описание полей структуры WNDCLASS.

typedef struct tagWNDCLASS

{

LPCSTR lpszClassName;

HINSNANCE hInstance;

WNDPROC lpfnWndProc;

HCURSOR hCursor;

HICON hIcon;

LPCSTR lpszMenuName;

HBRUSH hbrBackground;

UINT Style;

cbClsExtra;

cbWndExtra;

} WNDCLASS.

Здесь

lpszClassName = <ИмяСтиляОкна> - имя класса, стиля окна;

hInstance = <ДескрипторПриложения> - дескриптор приложения, которое регистрирует класс окна (берется из значения соответствующего параметра функции WinMain, которое задается ОС при запуске приложения);

lpfnWndProc = <ИмяОбработчикаОкна> - значение указателя на функцию-обработчик сообщений окна, которая выполняет все задачи, связанные с окном (функция описывается пользователем);

76

Размещено на http://www.allbest.ru/

50

hCursor - ресурс окна, тип курсора окна. См. ПРИЛОЖЕНИЕ Б. Встроенные курсоры;

hIcon - ресурс окна, задает вид пиктограммы при выводе окна в свернутом виде (в виде пиктограммы, обычно NULL);

lpszMenuName = <ИмяРесурсаМеню> - ресурс окна - пользовательское меню;

hbrBackground - ресурс окна, определяет кисть, используемую для закраски фона окна (значением данного параметра может быть как идентификатор физической кисти, так и значение цвета). См. ПРИЛОЖЕНИЕ В. Встроенные кисти (закраски фона окна);

style - доопределяет класс, стиль окна (например, параметр CS_VREDRAW обеспечивает перерисовку содержимого клиентской области окна при изменении размера окна по вертикали и т.п.). См. ПРИЛОЖЕНИЕ Г. Значения параметра Style структуры WNDCLASS;

cbClsExtra - задает количество дополнительных байт, выделяемых структуре WNDCLASS (обычно NULL);

cbWndExtra - задается количество дополнительных байт, выделяемых для всех дополнительных структур, которые создаются с использованием данного класса, стиля окна (обычно NULL).

Использование структуры иллюстрируется ниже

76

Размещено на http://www.allbest.ru/

50

MSG - структура данных для хранения информации о сообщении

typedef struct tagMSG

{

HWND hWnd;

UINT message;

WPARAM wParam;

LPARAM lParam;

DWORD time;

POINT pt;

} MSG.

Здесь

HWND hWnd - <ДескрипторОкна>;

UINT message - код <ТипСообщения>;

WPARAM wParam <ПараметрыСообщения> (ПервыйПараметрСообщения);

LPARAM lParam <РасширенныеПараметрыСообщения> (ВторойПараметрСообщения);

DWORD time время возникновения сообщения;

POINT pt позиция курсора мыши.

PAINTSTRUCT (см. winuser. h) - структура данных (заполняется каждый раз, когда приложение перехватывает сообщение WM_PAINT) для хранения информации о клиентской области окна, с которой связан контекст устройства КУ. КУ - системный ресурс, (область памяти) для хранения атрибутов объектов, связанных с рисованием (информация о кисти, перьях, шрифтах и т.п.). Используется графическими функциями GDI через <ДескрипторКУ>. При этом предполагается последовательность действий: Получить КУ. Изменить атрибуты КУ. Использовать функции GDI (рисовать). Вернуть КУ. Описание

typedef struct tagPAINTSTRUCT

{

HDC hdc;

BOOL fErase;

RECT rcPaint;

BOOL fRestore;

BOOL fIncUpdate;

BYTE rgbReserved [32];

} PAINTSTRUCT.

Здесь

HDC hdc - <ДескрипторКУ>;

BOOL fErase - флаг перерисовки фона окна (0), иначе используется прозрачное окно;

RECT rcPaint - описание прямоугольной области окна, той части, которую надо перерисовать;

RECT - структура данных для описания прямоугольной области, части окна, которую надо перерисовать

typedef struct tagRECT

{

LONG left;

LONG top;

LONG right;

LONG bottom;

} RECT, *PRECT, NEAR *NPRECT, FAR *LPRECT;

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

PAINTSTRUCT ps;

ps. rcPaint = { 0, 0, 290, 73 };

HDC hdc = BeginPaint (hWnd, &ps);.

TEXTMETRIC (см. winuser. h) - информационная структура данных, которая хранит атрибуты (метрики) текущего шрифта, связанного с КУ. Задание атрибутов выполняется функциями SetTextColor (), SetBkColor () и др. Поле tmExternalLeading определяет расстояние между строками, поле tmHeight задает полную высоту символов используемого шрифта и т.д.

typedef struct tagTEXTMETRICA

{

LONG tmHeight; Полная высота символов шрифта

LONG tmAscent;

LONG tmDescent;

LONG tmInternalLeading;

LONG tmExternalLeading; Расстояние между строками

LONG tmAveCharWidth;

LONG tmMaxCharWidth;

LONG tmWeight;

LONG tmOverhang;

LONG tmDigitizedAspectX;

LONG tmDigitizedAspectY;

BYTE tmFirstChar;

BYTE tmLastChar;

BYTE tmDefaultChar;

BYTE tmBreakChar;

BYTE tmItalic;

BYTE tmUnderlined;

BYTE tmStruckOut;

BYTE tmPitchAndFamily;

BYTE tmCharSet;

} TEXTMETRICA, *PTEXTMETRICA, FAR *LPTEXTMETRICA;

4.5 Главная функция ТКП

Прототип главной функции приложения

int WINAPI WinMain (HINSTANCE hInstance,

HINSTANCE hPrevInstance,

LPSTR lpCmdLine,

int nCmdShow);.

Здесь

HINSTANCE hInstance - идентификатор <ДескрипторПриложения> текущего экземпляра приложения (определяется ОС);

HINSTANCE hPrevInstance - всегда NULL;

LPSTR lpszCmdLine - указатель на командную строку приложения;

int nCmdShow - способ <ИзображенияОкнаПриПервомВыводе> (например, параметр SW_SHOWDEFAULT активизирует окно и выводит его с использованием текущих параметров - по умолчанию; параметр SW_SHOWNORMAL активизирует окно и если окно было увеличено или уменьшено до пиктограммы, то оно восстанавливается с учетом начального положения и размера окна).

4.5 Функция-обработчик сообщений главного окна ТКП

Назначение функции - обработка сообщений, адресуемых окну. Соответственно обработчик реагирует на сообщения.

Основные сообщения: - при визуализации окна принимается сообщение WM_CREATE; - при изменении размеров окна принимается сообщение WM_PAINT с требованием перерисовки окна; - при завершении работы приложения принимается сообщение WM_QUIT; - закрытие окна сопровождается сообщением WM_DESTROY, что при закрытии главного окна означает, как правило, и закрытие приложения. Соответственно при обработке сообщения WM_DESTROY системе надо переслать сообщение WM_QUIT; - сообщение WM_COMMAND о выборе пункта пользовательского меню окна приложения и другие.

Функции-обработчики сообщений окон приложения, включая главное и диалоговые окна, имеют общий прототип

LRESULT CALLBACK <ИмяОбработчикаОкна> (HWND hWnd, UINT Message, WPARAM wParam, LPARAM lParam);.

Здесь

HWND hWnd - <ДескрипторОкна> или <ДескрипторДиалоговогоОкна >, чьи сообщения обрабатываются;

UINT Message - <ТипСообщения>, которое обрабатывается;

WPARAM wParam - < ПараметрыСообщения >, которое обрабатывается;

LPARAM lParam - < РасширенныеПараметрыСообщения >, которое обрабатывается.

Для передачи параметров используются типы, определенные как

typedef UINT WPARAM;

typedef LONG LPARAM;.

Тип результата работы функции-обработчика окна (главного окна) определен как

typedef LONG LRESULT;.

Указатели на соответствующую функцию-обработчик описаны как

typedef LRESULT (CALLBACK* WNDPROC) (HWND, UINT, WPARAM, LPARAM);

typedef BOOL (CALLBACK* DLGPROC) (HWND, UINT, WPARAM, LPARAM);

76

Размещено на http://www.allbest.ru/

50

Например, прототип функции-обработчика главного окна WndProc

LRESULT CALLBACK WndProc (HWND, UINT, WPARAM, LPARAM);

и описание функции-обработчика

LRESULT CALLBACK WndProc (HWND hWnd, UINT Message,

WPARAM wParam, LPARAM lParam)

{

HDC hdc;

PAINTSTRUCT ps;

switch (Message)

{

case WM_PAINT:

hdc = BeginPaint (hWnd, &ps);

< Фрагмент_пользователя >

ValidateRect (hWnd,NULL);

EndPaint (hWnd, &ps);

break;

case WM_DESTROY:

PostQuitMessage (0);

break;

default:

return (DefWindowProc (hWnd, Message, wParam, lParam));

}

return 0;

4.6 Примерный текст ТКП. Состав функций

Примерный текст типового каркаса пользователя приведен ниже

#include <windows. h>

LRESULT CALLBACK<ИмяОбработчика> (HWND, UINT, WPARAM, LPARAM);

char szWindowClass [] = <ПользовательскоеИмяСтиляОкна>;

int WINAPI WinMain (HINSTANCE <ДескрипторПриложения>,

HINSTANCE hPreInstance,

LPSTR lpszCmdLine, int nCmdShow)

{

< Описание_главной_функции >

}

LRESULT CALLBACK <ИмяОбработчика> (HWND <ДескрипторОкна>,

UINT <КодСообщения>,

WPARAM wParam, LPARAM lParam)

{

< Описание_обработки_сообщений_главного_окна >

}

Более детальный текст ТКП приведен ниже

#include <windows. h>

LRESULT CALLBACK<ИмяОбработчика> (HWND, UINT, WPARAM, LPARAM);

char szWindowClass [] = <ПользовательскоеИмяСтиляОкна>;

int WINAPI WinMain (HINSTANCE <ДескрипторПриложения>,

HINSTANCE hPreInstance,

LPSTR lpszCmdLine, int nCmdShow)

{

СОЗДАНИЕ-ГЛАВНОГО-ОКНА-Приложения

РАБОТА-С-СООБЩЕНИЯМИ

MSG lpMessage;

while (GetMessage (&lpMessage, NULL, 0, 0))

{

TranslateMessage (&lpMessage);

DispatchMessage (&lpMessage);

}

}.

Здесь полученное приложением сообщение копируется в структуру данных типа MSG, на которую указывает адрес lpMsg, и передает его далее на обработку соответствующей функции-обработчику окна

LRESULT CALLBACK <ИмяОбработчика> (HWND <ДескрипторОкна>,

UINT <КодСообщения>,

WPARAM wParam, LPARAM lParam)

{

HDC <ДескрипторКонтекстаУстройства>;

PAINTSTRUCT <СтруктураКлиентскойОбластиОкна>;

switch (<КодСообщения>)

{

case WM_PAINT:

<ДескрипторКонтекстаУстройства>=BeginPaint (<ДескрипторОкна>,

&ps);

< Фрагмент_пользователя >

ValidateRect (<ДескрипторОкна>, NULL);

EndPaint (<ДескрипторОкна>, <СтруктураКлиентскойОбластиОкна>);

break;

case <ЗначениеКодаСообщения>:

< Обработка_сообщения >

case <ЗначениеКодаСообщения>:

< Обработка_сообщения >

……….

}

……….

}

Состав модулей и структур данных ТКП представлен на рисунке 16.

4.7 Описание и регистрация класса (стиля) окна. Использование структуры WNDCLASS

При создании приложения создается два основных компонента: - окно, как интерфейсное средство общения пользователя с приложением; - функция, обрабатывающая все события (сообщения), происходящие как в окне так и во внешней среде приложения. Окно описывается разработчиком. Данные о каждом окне хранятся в полях структуры

76

Размещено на http://www.allbest.ru/

50

WNDCLASS (в функции WinMain это переменная типа WNDCLASS wcApp). Переменная для обозначения стиля, класса окна, на который можно ссылаться при его инициализации, задается пользователем

char szWindowClass [] = <ИмяСтиляОкна>;.

Например,

char szWindowClass [] = "myWindowClass";.

Пример инициализации структуры WNDCLASS приведен ниже, значения полей структуры указаны в ПРИЛОЖЕНИИ А. Описание полей структуры WNDCLASS. При этом <ИмяСтиляОкна> может использоваться для создания конкретных экземпляров окна

Например,

WNDCLASS wcApp;

wcApp. lpszClassName = myWindowClass;

wcApp. hInstance = hInst;

wcApp. lpfnWndProc = WndProc;

wcApp. hCursor = LoadCursor (NULL, IDC_ARROW); // курсор окна - стрелка

wcApp. hIcon = 0; // без пиктограммы при выводе окна в свернутом видеwcApp. lpszMenuName = 0; // без меню

wcApp. hbrBackground = (HBRUSH) GetStockObject (WHITE_BRUSH);

wcApp. style = CS_HREDRAW|CS_VREDRAW; // перерисовывать окно при изменении размеров

wcApp. cbClsExtra = 0;

wcApp. cbWndExtra = 0;.

Пример ...


Подобные документы

Работы в архивах красиво оформлены согласно требованиям ВУЗов и содержат рисунки, диаграммы, формулы и т.д.
PPT, PPTX и PDF-файлы представлены только в архивах.
Рекомендуем скачать работу.