Литмир - Электронная Библиотека
Содержание  
A
A

#include <curses.h>

#define LOCAL_ESCAPE_KEY 27

int main() {

 int key;

 initscr();

 crmode();

 keypad(stdscr, TRUE);

2. Отключите отображение символов, чтобы помешать перемещению курсора при нажатии клавиш управления курсором. Экран очищается, и выводится некоторый текст. Программа ждет нажатия клавиши и до тех пор, пока не нажата клавиша <Q> или не возникла ошибка. Символ нажатой клавиши выводится на экран. Если нажатые клавиши соответствуют одной из последовательностей для дополнительной клавиатуры терминала, вместо символа выводится эта последовательность.

 noecho();

 clear();

 mvprintw(5, 5, &quot;Key pad demonstration. Press 'q' to quit&quot;);

 move(7, 5);

 refresh();

 key = getch();

 while (key != ERR &amp;&amp; key i= 'q') {

  move(7, 5);

  clrtoeol();

  if ((key &gt;= 'A' &amp;&amp; key &lt;= 'Z') || (key &gt;= 'a' &amp;&amp; key &lt;= 'z')) {

   printw(&quot;Key was%c&quot;, (char)key);

  } else {

   switch(key) {

   case LOCAL_ESCAPE_KEY:

    printw(&quot;%s&quot;, &quot;Escape key&quot;);

    break;

   case KEY_END:

    printw(&quot;%s&quot;, &quot;END key&quot;);

    break;

   case KEY_BEG:

    printw(&quot;%s&quot;, &quot;BEGINNING key&quot;);

    break;

   case KEY_RIGHT:

    printw(&quot;%s&quot;, &quot;RIGHT key&quot;);

    break;

   case KEY_LEFT:

    printw(&quot;%s&quot;, &quot;LEFT key&quot;);

    break;

   case KEY_UP:

    printw(&quot;%s&quot;, &quot;UP key&quot;);

    break;

   case KEY_DOWN:

    printw(&quot;%s&quot;, &quot;DOWN key&quot;);

    break;

   default:

    printw(&quot;Unmatched — %d&quot;, key);

    break;

   } /* switch */

  } /* else */

  refresh();

  key = getch();

 } /* while */

 endwin();

 exit(EXIT_SUCCESS);

}

Как это работает

Включив режим дополнительной клавиатуры, вы увидите, как можно распознать различные функциональные клавиши на дополнительной клавиатуре, генерирующие escape-последовательности. Вы, возможно, сумеете заметить, что распознавание клавиши <Esc> немного медленнее, чем других клавиш.

Применение цвета

В прошлом очень немногие терминалы ввода/вывода поддерживали цвета, поэтому у большей части самых старых версий библиотеки curses не было поддержки цветов. Цвета появились в библиотеке ncurses и других современных реализациях curses. К сожалению, на "неинтеллектуальный экран", первооснову библиотеки curses, повлиял API, и curses используют цвета очень ограниченным способом, отражающим слабые характеристики старых цветных терминалов.

Каждая символьная ячейка на экране может быть записана одним цветом из набора разных цветов на фоне одного цвета из набора различных цветов фона. Например, можно вывести зеленый текст на красном фоне.

Цветовая поддержка в библиотеке curses немного необычна, в том смысле, что цвет символа не определяется независимо от цвета фона. Вы должны задать цвет переднего плана и фона как пару, именуемую, что неудивительно, цветовой парой.

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

has_colors
и
start_color
.

<b>#include &lt;curses.h&gt;</b>

<b>bool has_colors(void);</b>

<b>int start_color(void);</b>

Функция

has_colors
возвращает
true
, если терминал поддерживает цвета. Далее следует вызвать функцию
start_color
, которая вернет
OK
, если цветовая поддержка успешно инициализирована. После вызова
start_color
и инициализации цветов переменная
COLOR_PAIRS
принимает значение, равное максимальному количеству цветовых пар, которые может поддерживать терминал. Переменная
COLORS
определяет максимальное число доступных цветов, которых, как правило, восемь. Внутри компьютера числа от 0 до 63 действуют как уникальные ID для каждого из доступных цветов.

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

init_pair
. Обратиться к атрибутам, задающим цвет, можно с помощью функции
COLOR_PAIR
.

<b>#include &lt;curses.h&gt;</b>

<b>int init_pair(short pair_number, short foreground, short background);</b>

<b>int COLOR_PAIR(int pair_number);</b>

<b>int pair_content(short pair_number, short *foreground, short *background);</b>

В файле curses.h обычно определены некоторые базовые цвета, начинающиеся с префикса

COLOR_
. Дополнительная функция
pair_content
позволяет извлечь сведения о ранее определенной цветовой паре.

104
{"b":"285844","o":1}