2023-08-16 16:02:33 +03:00
|
|
|
|
# conio.h 📑
|
|
|
|
|
|
|
|
|
|
В этом документе представлены описания и работа функций с примерами заголовоного файла `conio.h`.
|
|
|
|
|
|
|
|
|
|
По факту, весь материал спизжен с сайта http://www.c-cpp.ru/funkcii/conioh,
|
|
|
|
|
но из-за наличия на 50% страницы рекламы, читать материал затруднительно.
|
|
|
|
|
|
|
|
|
|
Если считаешь, что я нарушил чьи-то права, то мне как-то ПОХУЙ.
|
|
|
|
|
В интернете всё общее + на всех страницах не было текста, что материал
|
|
|
|
|
копировать запрещено... ПОХУЙ В ДВОЙНЕ!
|
|
|
|
|
|
|
|
|
|
В ходе **Copy-Paste** была поправлена вёрстка кода и другие улучшения.
|
|
|
|
|
|
|
|
|
|
## Содержание
|
|
|
|
|
|
2023-08-16 16:20:44 +03:00
|
|
|
|
* [`_setcursortype`](#void-_setcursortype-int-type)
|
|
|
|
|
* [`getpass`](#char-getpass-const-char-str)
|
|
|
|
|
* [`window`](#void-window-int-left-int-top-int-right-int-bottom)
|
|
|
|
|
* [`wherex`/`wherey`](#int-wherex-void-%D0%B8-int-wherey-void)
|
|
|
|
|
* [`textmode`](#void-textmode-int-mode)
|
|
|
|
|
* [`textcolor`](#void-textcolor-int-color)
|
|
|
|
|
* [`textbackground`](#void-textbackground-int-color)
|
|
|
|
|
* [`textattr`](#void-textattr-int-attr)
|
|
|
|
|
* [`puttext`](#int-puttext-int-left-int-top-int-right-int-bottom-void-buf)
|
|
|
|
|
* [`normvideo`](#void-normvideo-void)
|
|
|
|
|
* [`lowvideo`](#void-lowvideo-void)
|
|
|
|
|
* [`highvideo`](#void-highvideo-void)
|
|
|
|
|
* [`movetext`](#int-movetext-int-left-int-top-int-right-int-bottom-int-newleft-int-newtop)
|
|
|
|
|
* [`insline`](#void-insline-void)
|
|
|
|
|
* [`gotoxy`](#void-gotoxy-int-x-int-y)
|
|
|
|
|
* [`gettextinfo`](#void-gettextinfo-struct-text_info-info)
|
|
|
|
|
* [`gettext`](#int-gettext-int-left-int-top-int-right-int-bottom-void-buf)
|
|
|
|
|
* [`delline`](#void-delline-void)
|
|
|
|
|
* [`cscanf`](#int-cscanf-char-fmt)
|
|
|
|
|
* [`cputs`](#int-cputs-const-char-str)
|
|
|
|
|
* [`cprintf`](#int-cprintf-const-char-fmt)
|
|
|
|
|
* [`clreol`/`clrscr`](#void-clreol-void-%D0%B8-void-clrscr-void)
|
|
|
|
|
* [`kbhit`](#int-kbhit)
|
|
|
|
|
* [`ungetch`](#int-ungetch-int-ch)
|
|
|
|
|
* [`getch`/`getche`](#int-getch-void-%D0%B8-int-getche-void)
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `void _setcursortype(int type)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Эта функция не определена стандартом ANSI С.
|
|
|
|
|
|
|
|
|
|
Функция `_setcursortype()` изменяет внешний вид курсора.
|
|
|
|
|
Она может быть вызвана с передачей ей одного из следующих трех макросов,
|
|
|
|
|
которые определены в файле `conio.h`.
|
|
|
|
|
Вызов функции с макросом `_NOCURSOR` отключает курсор.
|
|
|
|
|
Использование макроса `_SOLIDCURSOR` задает прямоугольный курсор,
|
|
|
|
|
занимающий символьную позицию.
|
|
|
|
|
Использование макроса `_NORMALCURSOR` создает стандартный курсор.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующий фрагмент кода изменяет курсор */
|
|
|
|
|
_setcursortуре(_SOLIDCURSOR);
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `char *getpass(const char *str)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Эта функция не определена стандартом ANSI С.
|
|
|
|
|
|
|
|
|
|
После вывода на экран подсказки `str`, функция `getpass()`
|
|
|
|
|
возвращает указатель на строку, завершающуюся нулевым символом длиной
|
|
|
|
|
не более восьми символов. Эта строка статически размещается
|
|
|
|
|
в памяти функцией `getpass()` и переписывается всякий раз при вызове функции.
|
|
|
|
|
Если необходимо сохранить эту строку, ее нужно скопировать в какое-либо место в памяти.
|
|
|
|
|
Нажатые клавиши не отображаются эхом на экране во время ввода пароля.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующая функция ожидает ввода подходящего пароля */
|
|
|
|
|
#include <conio.h>
|
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
|
|
void pswd(char *pw) {
|
|
|
|
|
char *input;
|
|
|
|
|
|
|
|
|
|
do {
|
|
|
|
|
input = getpass ("Enter your password: ");
|
|
|
|
|
} while (!strcmp("starbar", input));
|
|
|
|
|
|
|
|
|
|
printf("You're in!");
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `void window(int left, int top, int right, int bottom)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Функция `window()` используется для создания прямоугольного текстового окна,
|
|
|
|
|
имеющего левый верхний угол и правый нижний угол в точках с координатами
|
|
|
|
|
`left`, `top` и `right`, `bottom` соответственно.
|
|
|
|
|
Если какая-либо из координат недействительна, то функция `window()` не выполняет никаких действий.
|
|
|
|
|
После успешного вызова функции `window()` все ссылки
|
|
|
|
|
на координаты местоположения интерпретируются относительно окна, а не экрана.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующий фрагмент кода создает окно
|
|
|
|
|
и записывает строку текста в точку
|
|
|
|
|
с координатами 2, 3 относительно окна */
|
|
|
|
|
window (10, 10, 60, 15);
|
|
|
|
|
gotoxy(2, 3);
|
|
|
|
|
cprintf("at location 2, 3");
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `int wherex(void)` и `int wherey(void)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Функции `wherex()` и `wherey()` возвращают текущие координаты курсора
|
|
|
|
|
`х` и `у` по отношению к текущему текстовому окну.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующий фрагмент кода присваивает переменным
|
|
|
|
|
xpos и ypos значения координат х и у */
|
|
|
|
|
int xpos, ypos;
|
|
|
|
|
xpos = wherex();
|
|
|
|
|
ypos = wherey();
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `void textmode(int mode)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Функция `textmode()` используется для изменения видеорежима текстового экрана.
|
|
|
|
|
Аргумент `mode` может принимать одно из значений, показанных в следующей таблице.
|
|
|
|
|
Можно использовать либо целое значение, либо соответствующий макрос,
|
|
|
|
|
который определен в файле `conio.h`:
|
|
|
|
|
|
|
|
|
|
| Макрос | Числовой эквивалент | Описание |
|
|
|
|
|
|----------|---------------------|-------------------------------------|
|
|
|
|
|
| BW40 | 0 | 40-кодоночный черно-белый |
|
|
|
|
|
| С40 | 1 | 40-колоночный цветной |
|
|
|
|
|
| BW80 | 2 | 80-колоночный черно-белый |
|
|
|
|
|
| С80 | 3 | 80-колоночный цветной |
|
|
|
|
|
| MONO | 1 | 80-колоночный монохромный |
|
|
|
|
|
| С4350 | 64 | 43-строчный EGA или 50-строчный VGA |
|
|
|
|
|
| LASTMODE | -1 | Предыдущий режим |
|
|
|
|
|
|
|
|
|
|
После вызова функции `textmode()` экран переустанавливается
|
|
|
|
|
и все атрибуты текстового экрана возвращаются к своим значениям по умолчанию.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующий фрагмент кода переводит видеорежим на 80-колоночный цветной */
|
|
|
|
|
textmode(С80);
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `void textcolor(int color)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Функция `textcolor()` устанавливает цвет символов, выводимых на текстовый экран.
|
|
|
|
|
Работает в старых компиляторах таких, как **Turbo C** и **Dev C**.
|
|
|
|
|
Она также может быть использована для задания мерцающих символов.
|
|
|
|
|
Ниже представлены допустимые значения параметра `color` вместе с именами макросов,
|
|
|
|
|
определенных в файле `conio.h`:
|
|
|
|
|
|
|
|
|
|
| Макрос | Цифровой эквивалент |
|
|
|
|
|
|--------------|---------------------|
|
|
|
|
|
| BLACK | 0 |
|
|
|
|
|
| BLUE | 1 |
|
|
|
|
|
| GREEN | 2 |
|
|
|
|
|
| CYAN | 3 |
|
|
|
|
|
| RED | 4 |
|
|
|
|
|
| MAGENTA | 5 |
|
|
|
|
|
| BROWN | 6 |
|
|
|
|
|
| LIGHTGRAY | 7 |
|
|
|
|
|
| DARKGRAY | 8 |
|
|
|
|
|
| LIGHTBLUE | 9 |
|
|
|
|
|
| LIGHTGREEN | 10 |
|
|
|
|
|
| LIGHTCYAN | 11 |
|
|
|
|
|
| LIGHTRED | 12 |
|
|
|
|
|
| LIGHTMAGENTA | 13 |
|
|
|
|
|
| YELLOW | 14 |
|
|
|
|
|
| WHITE | 15 |
|
|
|
|
|
| BLINK | 128 |
|
|
|
|
|
|
|
|
|
|
Цвет символов на экране не изменяется функцией `textcolor()`.
|
|
|
|
|
Изменения касаются только тех символов, которые будут выведены после функции `textcolor()`.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующий фрагмент кода выводит текст с помощью мерцающих символов */
|
|
|
|
|
textcolor(BLINK);
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `void textbackground(int color)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Функция `textbackground()` устанавливает цвет фона текстового экрана.
|
|
|
|
|
Вызов функции `textbackground()` воздействует только на цвет фона последующих операций записи.
|
|
|
|
|
Допустимые цвета определяются с помощью макросов, содержащихся в файле `conio.h`, и представленных ниже.
|
|
|
|
|
|
|
|
|
|
| Макрос | Цифровой эквивалент |
|
|
|
|
|
|-----------|---------------------|
|
|
|
|
|
| BLACK | 0 |
|
|
|
|
|
| BLUE | 1 |
|
|
|
|
|
| GREEN | 2 |
|
|
|
|
|
| CYAN | 3 |
|
|
|
|
|
| RED | 4 |
|
|
|
|
|
| MAGENTA | 5 |
|
|
|
|
|
| BROWN | 6 |
|
|
|
|
|
| LIGHTGRAY | 7 |
|
|
|
|
|
|
|
|
|
|
Новый цвет фона становится видимым после вызова функции `textbackground()`.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующий фрагмент кода устанавливает цвет фона текстового экрана голубым */
|
|
|
|
|
textbackground(CYAN);
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `void textattr(int attr)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Функция `textattr()` устанавливает одновременно как цвета переднего плана, так и фона.
|
|
|
|
|
Величина параметра `attr` представляет собой закодированную информацию о цвете.
|
|
|
|
|
Способ кодировки представлен ниже.
|
|
|
|
|
|
|
|
|
|
![](
|
|
|
|
|
|
|
|
|
|
При установке значения 1 в разряде 7 текст мерцает.
|
|
|
|
|
Разряды с 6 по 4 определяют цвет фона.
|
|
|
|
|
Разряды с 3 по 0 определяют цвет текста.
|
|
|
|
|
Наиболее простой способ задать цвет фона заключается в том,
|
|
|
|
|
чтобы умножить номер желаемого цвета на 16
|
|
|
|
|
и сложить его с цветом текста с помощью операции побитовое ИЛИ.
|
|
|
|
|
Например, чтобы создать зеленый фон с синим текстом,
|
|
|
|
|
можно использовать `GREEN*16 | BLUE`.
|
|
|
|
|
Для того, чтобы заставить этот текст мерцать, к результату надо применить операцию побитового ИЛИ
|
|
|
|
|
с макросом `BLINK(128)`.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующая инструкция выводит текст,
|
|
|
|
|
мерцающий красным цветом на синем фоне */
|
|
|
|
|
textattr(RED | BLINK | BLUE*16);
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `int puttext(int left, int top, int right, int bottom, void *buf)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Функция `puttext()` копирует текст, предварительно сохраненный с использованием функции `gettext()`.
|
|
|
|
|
Копирование осуществляется из буфера, на который указывает переменная `buf`,
|
|
|
|
|
в область, левая верхняя точка которой имеет координаты `left` и `top`,
|
|
|
|
|
а правая нижняя — `right` и `bottom`.
|
|
|
|
|
|
|
|
|
|
Функция `puttext()` использует абсолютные координаты экрана,
|
|
|
|
|
а не координаты относительно окна. Она возвращает значение `0`,
|
|
|
|
|
если координаты выходят за допустимую область,
|
|
|
|
|
и ненулевое значение — в противном случае.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
|
|
|
|
|
2023-08-16 16:02:33 +03:00
|
|
|
|
```c
|
|
|
|
|
/* Следующий фрагмент кода копирует область экрана в память,
|
|
|
|
|
на которую указывает параметр buf,
|
|
|
|
|
а затем помещает этот текст в новое место на экране */
|
|
|
|
|
buf = malloc (10 * 10 *2);
|
|
|
|
|
gettext(10, 10, 20, 20, buf);
|
|
|
|
|
puttext(0, 0, 30, 30, buf);
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `void normvideo(void)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
После вызова функции `normvideo()` изображенные на экране символы выводятся
|
|
|
|
|
в режиме нормальной интенсивности.
|
|
|
|
|
Эта функция работает только для текстовых экранов.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующий фрагмент кода включает режим вывода с нормальной интенсивностью */
|
|
|
|
|
normvideo();
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `void lowvideo(void)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
**Описание**
|
|
|
|
|
|
|
|
|
|
После вызова функции `lowvideo()` изображенные на экране символы выводятся
|
|
|
|
|
в режиме пониженной яркости.
|
|
|
|
|
Эта функция работает только для текстовых экранов.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующий фрагмент кода включает вывод с пониженной яркостью */
|
|
|
|
|
lowvideo();
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `void highvideo(void)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
После вызова функции `highvideo()` выводимые на экран символы изображаются
|
|
|
|
|
в режиме повышенной яркости. Эта функция работает только для текстовых экранов.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующий фрагмент кода включает вывод с повышенной яркостью */
|
|
|
|
|
highvideo();
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `int movetext(int left, int top, int right, int bottom, int newleft, int newtop)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Функция `movetext()` перемещает часть текста по экрану.
|
|
|
|
|
Текст берется из прямоугольника с левым верхним углом
|
|
|
|
|
в точке с координатами `left`, `top` и правым нижним углом
|
|
|
|
|
в точке с координатами `right`, `bottom`.
|
|
|
|
|
Точка положения нового верхнего угла имеет координаты
|
|
|
|
|
`newleft`, `newtop`. Эта функция относится не к окну, а к экрану.
|
|
|
|
|
Функция `movetext()` возвращает `0`,
|
|
|
|
|
если хотя бы одна из координат выходит за пределы допустимой области,
|
|
|
|
|
и ненулевое значение — в противном случае.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующий фрагмент кода передвигает содержимое прямоугольника
|
|
|
|
|
с левым верхним углом в точке 1, 1
|
|
|
|
|
и правым нижним углом в точке 8, 8 в точку 10, 10 */
|
|
|
|
|
movetext(1, 1, 8, 8, 10, 10);
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:20:44 +03:00
|
|
|
|
## `void insline(void)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Функция `insline()` вставляет пустую строку в текущее положение курсора.
|
|
|
|
|
Все строки ниже курсора сдвигаются вниз.
|
|
|
|
|
Эта функция предназначена только для текстового режима
|
|
|
|
|
и выполняет операцию вставки относительно текущего текстового окна.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующая программа иллюстрирует использование функции insline() */
|
|
|
|
|
#include <conio.h>
|
|
|
|
|
int main(void) {
|
|
|
|
|
register int i;
|
|
|
|
|
|
|
|
|
|
clrscr();
|
|
|
|
|
for (i = 1; i<24; i + + ) {
|
|
|
|
|
gotoxy(1, i);
|
|
|
|
|
cprintf("This is line %d\n\r", i);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
getche();
|
|
|
|
|
gotoxy(1, 10);
|
|
|
|
|
insline();
|
|
|
|
|
getch();
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `void gotoxy(int x, int y)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Функция `gotoxy()` помещает курсор текстового экрана в точку с координатами х, у.
|
|
|
|
|
Если хотя бы одна из координат недействительна, то никаких действий не выполняется.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующая программа выводит символы X по диагонали экрана */
|
|
|
|
|
#include <conio.h>
|
|
|
|
|
int main(void) {
|
|
|
|
|
register int i, j;
|
|
|
|
|
|
|
|
|
|
/* вывод диагонали из Х-ов */
|
|
|
|
|
clrscr ();
|
|
|
|
|
for(i = 1, j = 1; j < 24; i+=3, j++) {
|
|
|
|
|
gotoxy(i, j);
|
|
|
|
|
cprintf("X");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
getche();
|
|
|
|
|
clrscr();
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `void gettextinfo(struct text_info *info)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Функция `gettextinfo()` получает текущие установки текста
|
|
|
|
|
и возвращает их в структуре, на которую указывает параметр `info`.
|
|
|
|
|
Структура `text_info` объявлена следующим образом:
|
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
struct text_info {
|
|
|
|
|
unsigned char winleft; /* координаты */
|
|
|
|
|
unsigned char wintop; /* верхнего левого угола */
|
|
|
|
|
unsigned char winright; /* координаты */
|
|
|
|
|
unsigned char winbottom; /* нижнего правого угола */
|
|
|
|
|
unsigned char attribute; /* текущие атрибуты */
|
|
|
|
|
unsigned char normattr; /* нормальные атрибуты */
|
|
|
|
|
unsigned char currmode; /* активный видеорежим */
|
|
|
|
|
unsigned char screenheight; /* размеры */
|
|
|
|
|
unsigned char screenwidth; /* экрана */
|
|
|
|
|
unsigned char curx; /* текущие координаты */
|
|
|
|
|
unsigned char cury; /* курсора */
|
|
|
|
|
};
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующий фрагмент получает текущие установки текста */
|
|
|
|
|
struct text_info i;
|
|
|
|
|
gettextinfo(&i);
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `int gettext(int left, int top, int right, int bottom, void *buf)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Функция `gettext()` копирует текст из прямоугольника
|
|
|
|
|
с левым верхним углом в точке `left`, `top`
|
|
|
|
|
и с правым нижним углом в точке с координатами `right`, `bottom`.
|
|
|
|
|
Текст копируется в буфер, на который указывает переменная `buf`.
|
|
|
|
|
Координаты относятся не к окну, а к экрану.
|
|
|
|
|
|
|
|
|
|
Необходимое количество памяти для хранения области экрана вычисляется по формуле
|
|
|
|
|
`число_байт = строки * столбцы * 2`.
|
|
|
|
|
Причина, по которой необходимо умножить число столбцов на число строк
|
|
|
|
|
и умножить это произведение на `2`, заключается в том, что каждый символ,
|
|
|
|
|
выводимый на экран, требует для хранения **2 байта**:
|
|
|
|
|
1 байт для самого символа и 1 байт для его атрибутов.
|
|
|
|
|
|
|
|
|
|
Функция возвращает в случае успеха `1` и `0` при ошибке.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующий фрагмент кода копирует область экрана в память,
|
|
|
|
|
на которую указывает параметр buf */
|
|
|
|
|
buf = malloc(10 * 10 *2);
|
|
|
|
|
gettext(10, 10, 20, 20, buf);
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `void delline(void)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Функция `delline()` удаляет строку в активном окне, которая содержит курсор.
|
|
|
|
|
Все линии ниже удаляемой поднимаются вверх.
|
|
|
|
|
Надо помнить, что если текущее окно меньше целого экрана,
|
|
|
|
|
то воздействие оказывается только на текст в окне.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующая программа выводит 24 строки и затем убирает строку 3 */
|
|
|
|
|
#include <conio.h>
|
|
|
|
|
int main(void) {
|
|
|
|
|
register int i; clrscr();
|
|
|
|
|
|
|
|
|
|
for (i = 0; i < 24; i++) cprintf("line %d\n\r", i);
|
|
|
|
|
getch();
|
|
|
|
|
gotoxy(1, 3);
|
|
|
|
|
delline();
|
|
|
|
|
getch();
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `int cscanf(char *fmt, ...)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Функция `cscanf()` работает так же, как и функция scanf(),
|
|
|
|
|
за исключением того, что она читает информацию с консоли вместо `stdin`.
|
|
|
|
|
Она не может быть перенаправлена. Относительно подробностей следует обратиться
|
|
|
|
|
к описанию функции `scanf()`.
|
|
|
|
|
|
|
|
|
|
Функция `cscanf()` возвращает число аргументов, которым были присвоены значения.
|
|
|
|
|
Это число не включает пропущенные поля. Функция `cscanf()` возвращает значение `EOF` в случае,
|
|
|
|
|
если была сделана попытка чтения за пределами конца файла.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующий фрагмент кода читает с консоли строку и число с плавающей точкой */
|
|
|
|
|
char str[80];
|
|
|
|
|
float f;
|
|
|
|
|
cscanf("%s%f", str, &f);
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `int cputs(const char *str)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Функция `cputs()` выводит в текущее текстовое окно строку,
|
|
|
|
|
на которую указывает параметр `str`.
|
|
|
|
|
Ее вывод не может быть перенаправлен,
|
|
|
|
|
и она автоматически предотвращает пересечение границ окна.
|
|
|
|
|
|
|
|
|
|
Функция возвращает последний символ, либо величину `EOF` в случае возникновения ошибки.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующая программа создает окно и использует функцию cputs() для записи строки,
|
|
|
|
|
которая не умещается в окне. Текст фактически переносится на новую строку в конце окна */
|
|
|
|
|
#include <conio.h>
|
|
|
|
|
|
|
|
|
|
void border(int, int, int, int);
|
|
|
|
|
|
|
|
|
|
int main(void) {
|
|
|
|
|
clrscr();
|
|
|
|
|
|
|
|
|
|
/* создание первого окна */
|
|
|
|
|
window(3, 2, 40, 9);
|
|
|
|
|
border(3, 2, 40, 9);
|
|
|
|
|
gotoxy(1,1);
|
|
|
|
|
cputs("This line will be wrapped at the end of the window.");
|
|
|
|
|
getche();
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* вывод границы вокруг первого окна */
|
|
|
|
|
void border(int startx, int starty, int endx, int endy) {
|
|
|
|
|
register int i;
|
|
|
|
|
|
|
|
|
|
gotoxy(1, 1);
|
|
|
|
|
for (i = 0; i <= endx - startx; i++) putch('-');
|
|
|
|
|
|
|
|
|
|
gotoxy(1, endy - starty);
|
|
|
|
|
for(i = 0; i <= endx - startx; i++) putch('-');
|
|
|
|
|
|
|
|
|
|
for(i = 2; i < endy-starty; i++) {
|
|
|
|
|
gotoxy(1, i);
|
|
|
|
|
putch('|');
|
|
|
|
|
gotoxy(endx - startx + 1, i);
|
|
|
|
|
putch('|');
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `int cprintf(const char *fmt, ...)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Функция `cprintf()` работает так же, как и функция `printf()`,
|
|
|
|
|
с тем только отличием, что она пишет в текущее окно вместо `stdout`.
|
|
|
|
|
Ее вывод не может быть перенаправлен, и она автоматически предотвращает вывод за пределы окна.
|
|
|
|
|
Относительно подробностей следует обратиться к описанию функции `printf()`.
|
|
|
|
|
|
|
|
|
|
Функция `cprintf()` не преобразует символ новой строки (`\n`)
|
|
|
|
|
в пару **перевод строки — возврат каретки**,
|
|
|
|
|
как это имеет место в случае функции `printf()`.
|
|
|
|
|
Поэтому необходимо явным образом ставить символ возврата каретки (`\r`),
|
|
|
|
|
если в этом есть необходимость.
|
|
|
|
|
|
|
|
|
|
Функция `cprintf()` возвращает число фактически выведенных символов.
|
|
|
|
|
Отрицательное возвращаемое значение означает наличие ошибки.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующая программа выводит данные, представленные ниже в комментариях */
|
|
|
|
|
#include <conio.h>
|
|
|
|
|
|
|
|
|
|
int main(void) {
|
|
|
|
|
/* выводит выровненное по левому краю
|
|
|
|
|
"this is a test" в 20-символьном поле */
|
|
|
|
|
cprintf("%-20s", "this is a test");
|
|
|
|
|
|
|
|
|
|
/* выводит вещественное значение с тремя цифрами после запятой
|
|
|
|
|
в 10-символьном поле. В результате работы выведется " 12.235" */
|
|
|
|
|
cprintf("%10.3f\n\r", 12.234657);
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `void clreol(void)` и `void clrscr(void)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Функция `clreol()` очищает строку от текущей позиции курсора и до конца строки активного окна.
|
|
|
|
|
Позиция курсора не изменяется.
|
|
|
|
|
|
|
|
|
|
Функция `clrscr()` полностью очищает активное текстовое окно
|
|
|
|
|
и помещает курсор в левый верхний угол (1, 1).
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующая программа иллюстрирует использование функций clreol() и clrscr() */
|
|
|
|
|
#include <conio.h>
|
|
|
|
|
|
|
|
|
|
int main(void) {
|
|
|
|
|
register int i;
|
|
|
|
|
|
|
|
|
|
gotoxy(10, 10);
|
|
|
|
|
cprintf("This is a test of the clreol() function.");
|
|
|
|
|
getch();
|
|
|
|
|
gotoxy(10, 10);
|
|
|
|
|
clreol();
|
|
|
|
|
for(i = 0; i < 20; i++) cprintf("Hello there\n\r");
|
|
|
|
|
getch();
|
|
|
|
|
|
|
|
|
|
/* очистка экрана */
|
|
|
|
|
clrscr();
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `int kbhit()`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Эта функция не определена стандартом ANSI C.
|
|
|
|
|
|
|
|
|
|
Функция `kbhit()` возвращает истину, если нажата какая-либо клавиша на клавиатуре.
|
|
|
|
|
В противном случае возвращается 0.
|
|
|
|
|
В любом случае код клавиши не удаляется из входного буфера.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Следующий фрагмент является циклом, выход из которого осуществляется по нажатию клавиши */
|
|
|
|
|
while(!kbhit()); /* ожидание нажатия клавиши */
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `int ungetch(int ch)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Эта функция не определена стандартом ANSI С. Она не может использоваться в программах Windows.
|
|
|
|
|
|
|
|
|
|
Функция `ungetch()` возвращает символ, заданный младшим байтом `ch`,
|
|
|
|
|
обратно во входной буфер консоли.
|
|
|
|
|
При следующем обращении к функции ввода с консоли этот символ будет считан снова.
|
|
|
|
|
Между двумя последовательными операциями ввода может быть возвращен обратно только один символ.
|
|
|
|
|
|
|
|
|
|
Возвращаемое значение равно `ch` в случае успеха и `EOF` — при неудаче.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* Приведенная ниже программа вводит клавишу, отображает ее на экране,
|
|
|
|
|
затем возвращает ее во входной буфер, снова считывает и выводит на экран */
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
#include <conio.h>
|
|
|
|
|
|
|
|
|
|
int main() {
|
|
|
|
|
char ch;
|
|
|
|
|
ch = getch(); // получение нажатия
|
|
|
|
|
putch(ch); // вывод клавиши
|
|
|
|
|
ungetch(ch); // возврат в буфер
|
|
|
|
|
ch = getch(); // получение той же клавиши еще раз
|
|
|
|
|
putch(ch); // вывод клавиши еще раз
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
## `int getch(void)` и `int getche(void)`
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Описание:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
Функция `getch()` возвращает очередной символ, считанный с консоли,
|
|
|
|
|
но не выводит этот символ на экран.
|
|
|
|
|
|
|
|
|
|
Функция `getche()` возвращает очередной символ, считанный с консоли,
|
|
|
|
|
и выводит этот символ на экран.
|
|
|
|
|
|
|
|
|
|
Ни одна из этих функций не определена стандартом ANSI С.
|
|
|
|
|
|
2023-08-16 16:06:52 +03:00
|
|
|
|
### Пример:
|
2023-08-16 16:02:33 +03:00
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
/* В этом фрагменте getch() используется
|
|
|
|
|
для считывания выбора пользователя для программы проверки орфографии */
|
|
|
|
|
do {
|
|
|
|
|
printf("1: Check spelling\n");
|
|
|
|
|
printf("2: Correct spelling\n");
|
|
|
|
|
printf("3: Look up a word in the dictionary\n");
|
|
|
|
|
printf("4: Quit\n");
|
|
|
|
|
printf("\nEnter your selection: ");
|
|
|
|
|
choice = getch();
|
|
|
|
|
} while(!strchr ("1234", choice));
|
|
|
|
|
```
|