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

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

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. Использовать обязательно!