- •Глава 6
- •Int endwin(void);
- •Int instr(char *string);
- •Int innstr(char *string, int number_of_characters);
- •Int move(int new_y, int new_x);
- •Int leaveok(window *window_ptr, bool leave_flag);
- •Int delwin(window *window_to_delete);
- •Int wnoutrefresh(window *window_ptr);
- •Int doupdate(void);
- •Int start_y, int start_x);
- •Int delwin(window *window_to_delete);
- •Int keypad(window *window_ptr, bool keypad_on);
- •Int start_color(void);
- •Int init_pair(short pair_number, short foreground, short background);
- •Int color_pair(int pair_number);
- •Int pair_content(short pair_number, short *foreground, short *background);
- •Int init_color(short color_number, short red, short green, short blue);
- •Int prefresh(window *pad_ptr, int pad_row, int pad_column, int screen_row_min, int screen_col_min, int screen_row_max, int screen_соl_max);
Int endwin(void);
Функция
initscr
должна вызываться только один раз в каждой программе. В случае успешного завершения она возвращает указатель на структуру
stdscr
. Если функция заканчивается аварийно, она просто выводит диагностическое сообщение об ошибке и вызывает завершение программы.
Функция
endwin
возвращает константу OK в случае успешного завершения и err в случае неудачи. Вы можете вызвать ее для того, чтобы покинуть curses, а позже возобновить функционирование библиотеки curses, вызвав
clearok(stdscr, 1)
и
refresh
. Это позволит библиотеке совершенно забыть, как выглядит физический экран, и заставит ее выполнить полное обновление экрана.
Вывод на экран
Для обновления экрана предоставляется несколько базовых функций.
#include <curses.h>
int addch(const chtype char_to_add);
int addchstr(chtype *const string_to_add);
int printw(char *format, ...);
int refresh(void);
int box(WINDOW *win_ptr, chtype vertical_char, chtype horizontal_char);
int insch(chtype char_to_insert);
int insertln(void);
int delch(void);
int deleteln(void);
int beep(void);
int flash(void);
У библиотеки curses есть свой символьный тип данных
chtype
, который может содержать больше разрядов, чем стандартный тип
char
. В стандартной версии ncurses для ОС Linux
chtype
на самом деле — синоним стандартного типа
unsigned long
.
Функции
addch
и
addchstr
вставляют заданные символ или строку в текущую позицию на экране. Функция
printw
форматирует строку так же, как функция
printf
, и помещает в текущую позицию на экране. Функция
refresh
вызывает обновление физического экрана, возвращая
OK
в случае успеха и
ERR
при возникновении ошибки. Функция
box
позволяет нарисовать рамку вокруг окна.
Примечание
В стандартной библиотеке curses вы можете применять только "обычные" символы для рисования горизонтальных и вертикальных линий. В расширенной версии библиотеки можно использовать два определения,
ASC_VLINE
и
ACS_HLINE
, для вывода символов вертикальных и горизонтальных линий соответственно, которые позволят нарисовать внешне более привлекательную рамку. Для этого ваш терминал должен поддерживать символы псевдографики. Обычно они лучше отображаются в окне эмулятора xterm, чем на стандартной консоли, но их поддержка полна корректировок или "заплат", поэтому мы полагаем, что вы откажетесь от их применения, если важна переносимость вашей программы.
Функция
insch
вставляет символ, сдвигая имеющиеся символы вправо. При этом не определено, что произойдет в конце строки, результат зависит от используемого терминала. Функция
insertln
вставляет пустую строку, перемещая имеющиеся строки на одну вниз. Функции
delch
и
deleteln
аналогичны функциям
insert
.
Для получения звука можно вызвать функцию
beep
. Немногие терминалы не способны издавать звуки, в этом случае некоторые установки библиотеки curses при вызове
beep
заставят экран мигать. Если вы работаете в густонаселенном офисе и звуковые сигналы могут издавать многие компьютеры, возможно, вы сочтете мигание предпочтительным режимом. Как и ожидалось, функция
flash
вызывает мигание экрана, если это невозможно, она попробует заставить терминал издать звуковой сигнал взамен.
Считывание с экрана
Вы можете считывать символы с экрана, хотя эта функциональная возможность применяется нечасто, поскольку гораздо легче отслеживать то, что выводится. Если вам все-таки это потребуется, выполняйте считывание с помощью следующих функций:
#include <curses.h>
chtype inch(void);
