А. Полищук - Программирование в X Window средствами Free Pascal Страница 9
- Категория: Компьютеры и Интернет / Программирование
- Автор: А. Полищук
- Год выпуска: неизвестен
- ISBN: нет данных
- Издательство: неизвестно
- Страниц: 16
- Добавлено: 2019-05-29 12:06:30
А. Полищук - Программирование в X Window средствами Free Pascal краткое содержание
Прочтите описание перед тем, как прочитать онлайн книгу «А. Полищук - Программирование в X Window средствами Free Pascal» бесплатно полную версию:А. Полищук - Программирование в X Window средствами Free Pascal читать онлайн бесплатно
*charter-medium-i-*-240-*
соответствуют имена
-hit-charter-medium-i-normal-25-240-75-75-p-136-iso8859-1
-hit-charter-medium-i-normal-33-240-100-75-p-136-iso8859-1
Названия шрифтов, доступных в системе, хранятся в соответствующей базе данных. Получить список имен шрифтов можно с помощью процедуры XListFonts() или XListFontsWithInfo(). Список шрифтов, возвращаемый этими функциями, должен быть освобожден вызовом XFreeFontNames().
Некоторые шрифты, такие как "fixed" или "9x15", доступны всегда.
Получить информацию о загруженном шрифте можно с помощью функции XQueryFont(), которая возвращает заполненную структуру типа XFontInfo. Одновременно загрузить шрифт и получить информацию о нем можно с помощью процедуры XLoadQueryFont().
Когда информация о шрифте больше не нужна, ее следует освободить с помощью XFreeFontInfo(). Когда становится не нужен и сам шрифт, последний надо "сбросить", обратившись к процедуре XUnloadFont(). Функция XFreeFont() объединяет в себе XFreeFontInfo() и XUnloadFont().
Следующий фрагмент кода загружает шрифт "courier", создает GC и выводит с его помощью строку "Hello, world!".
var
prDisplay: PDisplay;
prGC: TGC;
nWnd: TWindow;
prFontInfo: PXFontStruct;
…
(* Загружаем шрифт *)
prFontInfo:= XLoadQueryFont(prDisplay, '*-courier-*');
if (prFontInfo = NIL) then begin
writeln('Font not found!');
halt(1);
end;
…
(* Создаем GC и рисуем строку *)
prGC:= XCreateGC(prDisplay, nWnd, 0, NIL);
XSetForeground(prDisplay, prGC, XBlackPixel(prDisplay, 0));
XSetFont(prDisplay, prGC, prFontInfo^.fid);
XDrawString(prDisplay, nWnd, prGC, 10, 50, 'Hello, world!', strlen('Hello, world!'));
XFreeGC(prDisplay, prGC);
…
(* "Сбрасываем" шрифт *)
XFreeFont (prDisplay, prFontInfo);
…
Для отображения символов кириллицы необходимо использовать один из локализованных шрифтов в той кодировке, которая поддерживается вашей системой (как правило, это koi8-r (koi8-u)). По умолчанию загружается первый из шрифтов, соответствующий шаблону, поэтому для корректного отображения текста с кириллицей необходимо в шаблоне указывать кодировку.
1.2.4 Использование цвета
Во времена не столь отдаленные экранные контроллеры могли поддерживать одновременно ограниченное количество цветов (вначале 16, позже 256). В связи с этим приложение не могло просто запросить рисование ярко-красным цветом, и ожидать, что этот цвет будет доступным. Каждое приложение распределяло цвета, которые ему были нужны, и когда все 16 или 256 цветовых элементов использовались, следующее распределение цвета заканчивалось неудачей.
В связи с этим появилось понятие "цветовой карты" - палитры. Палитра является таблицей того же размера, что и количество одновременно отображаемых данным экранным контроллером цветов. Каждый элемент палитры содержит RGB (Красные, Зеленые и Синие) величины различных цветов (все цвета могут быть нарисованы, используя некоторую комбинацию красного, зеленого и синего).
Для того, чтобы сделать использование цветов близким к тому, которое предполагал программист, были введены функции выделения палитры. Вы можете попросить, выделить вас элемент палитры для цвета, заданного набором RGB-значений. Если он уже существовал, вы получите индекс в таблице. Если цвет не существовал, и таблица не заполнена, должна быть выделена новая ячейка палитры, содержащая данные значения RGB, и возвращен ее индекс. Если таблица была заполнена, процедура должна была закончиться неудачей. Вы могли затем запросить получение элемента палитры с цветом, ближайшим к требуемому. Это означает, что фактически рисование на экране будет произведено с использованием цвета, близкого к желаемому, но не того же самого.
На сегодняшних современных экранах, где работают сервера X с поддержкой миллионов цветов, эти ограничения кажутся устаревшими, но помните, что есть и старые компьютеры со старыми графическими картами внутри, равно как и 256-цветные Х-терминалы. С использованием палитры, поддержка этих экранов становится прозрачной. На дисплее, поддерживающем миллионы цветов, любой запрос распределения цветового элемента будет удовлетворен. На дисплее, поддерживающем ограниченное количество цветов, некоторые цветовые запросы распределения должно возвращать подобные цвета. Они не выглядит столь хорошо, как требуемые, но ваше приложение все еще будет работать.
При рисовании с использованием Xlib можно выбрать стандартную палитру экрана, на котором отображается ваше окно, или создать новую палитру и применить ее для окна. В последнем случае, всякий раз, когда мышь "наезжает" на ваше окно, экранная палитра заменится палитрой вашего окна, и вы увидите, что все другие окна на экране изменят свои цвета на нечто весьма экзотическое.
Для доступа к стандартной экранной палитре, определена функция XDefaultColormap(), возвращающая дескриптор палитры, используемой по умолчанию на первом экране (напоминаем, что сервер X может поддерживать несколько различных экранов, каждый из которых может иметь свои собственные ресурсы).
var
screen_colormap: TColormap;
screen_colormap:= XDefaultColormap(display, XDefaultScreen(display));
Другой макрос, связанный с распределением новой палитры, работает так:
var
default_visual: PVisual;
my_colormap: TColormap;
default_visual:= XDefaultVisual(display, XDefaultScreen(display));
(* Создаем новую палитру, количество цветов в которой определяется количеством цветов, поддерживаемых данным экраном. *)
my_colormap:= XCreateColormap(display, win, default_visual, AllocNone);
Имейте в виду, что дескриптор окна используется только для того, чтобы позволить серверу X создать палитру для данного экрана. Мы можем затем использовать эту палитру для любого окна, нарисованного на том же экране.
Как только мы получили доступ к некоторой палитре, мы можем начать распределять цвета. Это делается с помощью функций XAllocNamedColor() и XAllocColor(). Первая из них - XAllocNamedColor() - принимает имя цвета (например, "red", "blue", "brown" и т.д.) и распределяет ближайший цвет, который может в действительности рисоваться на экране. XAllocColor() принимает цвет RGB, и распределяет ближайший цвет, который может отображаться на экране. Обе функции используют структуру TXColor, содержащую следующие поля:
• pixel: cardinal - индекс палитры, используемый для рисования данным цветом.
• red: word - красная составляющая RGB-значения цвета.
• green: word - зеленая составляющая RGB-значения цвета.
• blue: word - синяя составляющая RGB-значения цвета.
Пример использования этих функций:
var
(* Эта структура будет содержать выделенные цветовые данные *)
system_color_1, system_color_2: TXColor;
(* Эта структура будет содержать точные RGB-значения именованных цветов, которые могут отличаться от выделенных *)
exact_color: TXColor;
rc: TStatus;
(* Выделяем "красный" элемент палитры *)
rc:= XAllocNamedColor(display, screen_colormap, 'red', @system_color_1, @exact_color);
(* проверяем успешность выделения *)
if (rc = 0) then begin
writeln('XAllocNamedColor - выделить "красный" цвет не удалось.');
end
else begin
writeln('Элемент палитры "красный" выделен как (', system_color_1.red, ', ', system_color_1.green, ', ', system_color_1.blue, ') в RGB-значениях.');
end;
(* выделяем цвет со значениями (30000, 10000, 0) в RGB. *)
system_color_2.red:= 30000;
system_color_2.green:= 10000;
system_color_2.blue:= 0;
rc:= XAllocColor(display, screen_colormap, @system_color_2);
(* проверяем успешность выделения *)
if (rc = 0) then begin
writeln('XAllocColor - цвет (30000,10000,0) выделить не удалось.');
end
else begin
(* что-то делаем с выделенным цветом… *)
.
.
end;
После того, как мы распределили желаемые цвета, мы можем использовать их, рисуя текст или графику. Для этого нам нужно установить эти цвета как передний план и цвет фона для некоторого GC (графического контекста), и затем используйте этот GC для рисования. Это делается с помощью функций XSetForeground() и XSetBackground():
XSetForeground(display, my_gc, screen_color_1.pixel);
XSetForeground(display, my_gc, screen_color_2.pixel);
Само же рисование осуществляется с помощью тех же функций, что и ранее. Для использования нескольких цветов, можно сделать одно из двух: мы можем либо изменить передний план и/или цвет фона GC перед любой функцией рисования, либо использовать несколько различных GC. Решение, какой из способов лучше, принимать вам: распределение многих GC будет использовать больше ресурсов X сервера, но где-то это приведет к более компактному коду, и может быть легче, чем замена цветов рисования.
Жалоба
Напишите нам, и мы в срочном порядке примем меры.