Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Пособие_2_изд_испр.doc
Скачиваний:
3
Добавлен:
01.05.2025
Размер:
2.27 Mб
Скачать

16.1.6. Пример(продолжение)

Приведенные ниже функции включены в файл window.c.

/* Вывод строки в окно */

void out_text(int x, // Начальная позиция курсора по X

int y, // Начальная позиция курсора по Y

int kol, // Число выводимых символов

int reg, // Режим: r-разрядка, p-плотный

char *text){ // Текст сообщения

int i;

gotoxy(x, y);

for(i=0; i<kol && *(text+i) != '\0'; i++){

if(reg=='r')putch(' ');

if(*(text+i)=='\n'){

y++;

gotoxy(x, y);

}else{

putch(*(text+i));

}

}

} // End out_text

Замечание. Символы второй кодовой страницы надо задавать в виде:

\<код символа в 8-й системе счисления>. См. ниже пример.

/* Рисование рамки */

void ramka(int type, // 0-одинарная, 1-двойная

int width, // ширина(в позициях)

int height){ // высота(в строках)

static unsigned char *cont[ ]={// коды символов псевдографики в 8-й системе

"\332\300\331\277\263\304", // одинарная рамка

"\311\310\274\273\272\315" // двойная рамка

};

int i;

gotoxy(1, 1);

putch(cont[type][0]);

for(i=2; i<width; i++)putch(cont[type][5]);

putch(cont[type][3]);

for(i=2; i<height; i++){

gotoxy(1, i);

putch(cont[type][4]);

gotoxy(width, i);

putch(cont[type][4]);

}

gotoxy(1, height);

putch(cont[type][1]);

for(i=2; i<width; i++)putch(cont[type][5]);

putch(cont[type][2]);

} /* End ramka */

16.2. Графический режим

Графический режим характеризуется установленным драйвером экрана и видеорежимом(mode). Поскольку ОС MS DOS достаточно "древняя", то наиболее высокая по разрешению экрана и числу используемых цветов установка соответствует драйверу VGA с разрешением 640*480 пикселей и 16 цветами. Драйверы представляют собой файлы с расширением bgi(Borland Graphics Interface). Для описанного выше видеорежима подходит драйвер egavga.bgi. Возможно существуют для работы в MS DOS и драйверы SVGA с лучшим качеством, однако для решения наших задач указанного видеорежима достаточно. Чтобы работать в данном режиме, необходимо в пункте Options\Linker\Libraries среды разработки установить флажок Graphics Library. Перечень функций, входящих в эту библиотеку, и пояснения к ним можно найти в пункте Help\ContentsFunctionsGraphics routines.

16.2.1. Установка и закрытие

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

void initgraph(int* driver, int* mode, char* path);

Она инициализирует графический режим. Символические константы для параметров driver и mode заданы в файле graphics.h. Если в качестве первого параметра задана символическая константа DETECT, то функция находит установленный драйвер и задает режим с максимальным разрешением для него(настоятельно рекомендуется). Третий параметр функции указывает путь к директории, в которой располагаются драйверы.

Пример.

int gd=DETECT, mode;

initgraph(&gd, &mode, "c:\\bc\\bgi");

Если третий параметр – пустая строка, то драйвер экрана должен находиться в директории, из которой производится запуск приложения(текущей).

Пример. initgraph(&gd, &mode, "");

int graphresult(void);

Функция возвращает информацию об исходе последней графической операции. Если инициализация режима прошла упешно, то возвращается 0. Перечень возможных ошибок при выполнении графических операций можно найти в описании функции graphresult в системе Help по ссылке graphics_errors. Для каждой ошибки определены символические константы. Так для успешного исхода используется константа grOk, равная 0. Эту функцию рекомендуется использовать сразу после вызова функции initgraph для проверки установки графического режима.

Пример.

int gd=DETECT, mode;

……………………………

initgraph(&gd, &mode, "");

gerror=graphresult( );

if(gerror != grOk){ // Ошибка инициализации

printf("Ошибка! %s\n", grapherrormsg(gerror));

getch( );

exit(1);

}

char* grapherrormsg(int errorcode);

Функция возвращает указатель на текст сообщения об ошибке, соответствующей коду ошибки, возвращаемому функцией graphresult.

Пример. Возможный текст сообщения из предыдущего примера.

Error! Device driver file not found (EGAVGA.BGI)Файл драйвера EGAVGA.BGI не найден.

То есть данный файл в текущей директории не обнаружен.

void exit(int status);

Функция завершает задачу. При этом:

- закрывает все файлы;

- выводит незаполненные буферы вывода.

Используется обычно при аварийном завершении задачи. Значение параметра status, равную 0, обычно сигнализирует о нормальном завершении, другое – нет. Прототип функции находится в файлах process.h и stdlib.h.

Она не имеет отношения к графическому режиму и описана здесь в связи с тем, что раньше не упоминалась.

void closegraph(void);

Функция закрывает графический режим. Она освобождает всю память, используемую для обеспечения графического режима и восстанавливает тот режим, который был до вызова функции initgraph. Использовать обязательно!