2009 г.
Создание кросс-платформенных графических интерфейсов на wxPerl
Александр Симаков, alexander-simakov.blogspot.com
Введение
wxPerl - это Perl-интерфейс к C++ библиотеке wxWidgets.
wxWidgets, в свою очередь, является OpenSource тулкитом для постоения
кросс-платформенных графических интерфейсов. Лейтмотив wxWidgets -
"Native Look and Feel". Достигается это за счет использования
стандартных виджетов той платформы, на которой в данный момент работает
программа. К примеру, wx-приложение под Windows будет выглядеть так же
как и остальные Windows-приложения, а в Mac OS X - как другие
приложения Mac OS X. К слову, для некоторых платформ существует сразу
несколько портов wxWidgets. Так в Linux, wxWidgets может работать
"поверх" GTK+, X11 или Motif. Первый вариант, однако, наиболее
распространен. Не смотря на то, что wxWidgets является надстройкой над
другими графическими тулкитами, разработчики уверяют, что накладные
расходы будут минимальны.
Ещё
одна примечательная черта wxWidgets - удобный механизм для создания
специализированных виджетов на базе существующих. Сам механизм
чрезвычайно прост: достаточно отнаследоваться от базового класса и
добавить к нему необходимый функционал. Разумеется, подобные
возможности предоставляют и другие тулкиты, такие как Tk или GTK+, но в
wxWidgets это делается проще чем в Tk и документировано лучше чем в
GTK+. К слову, widget subclassing является стандартной идиомой при
программировании на wxWidgets.
Обзор wxWidgets
Для
того чтобы лучше понять wxPerl полезно представлять себе окружающий его
контекст, прежде всего, проект wxWidgets. Первоначальным автором
wxWidgets является Джулиан Смарт (Julian Smart). Джулиан начал работать
над wxWidgets (раньше wxWidgets назывался wxWindows) в 1992 году,
будучи студентом Artificial Intelligence Applications Institute в
Эдинбурге. Изначально, целью его работы было создание
специализированного CASE-инструмента, который, по задумке, должен был
работать как в Windows так и в UNIX-системах. Спустя некоторое время, к
проекту начали присоединяться и другие энтузиасты, которые, общими
усилиями и превратили wxWidgets в то, чем он является сегодня. В
настоящий момент над wxWidgets трудится целая команда
программистов, включая и Джулиана. Примечательно, что три наиболее
активных разработчика руководят собственными консалтинговыми
компаниями, специализирующимися на wxWidgets.
Из
приятных вещей стоит отметить наличие хорошей документации,
предкомпилированных версий wxWidgets для разных платформ, а также
наличие соответствующих RPM и DEB пакетов в большинстве
Linux-дистрибутивов. Есть и достаточно популярные приложения,
написанные на wxWidgets: например, аудио редактор Audacity и медиа-плеер VLC. Подборку скриншотов различных wx-приложений можно посмотреть тут.
Обзор wxPerl
Если
вы программируете на C++, то можете "разговаривать" с wxWidgets без
переводчика: этот язык является для него родным. В противном случае
придется воспользоваться библиотеками-обёртками: для языка Perl - это
wxPerl. Автором проекта wxPerl является Маттиа Бэрбон (Mattia Barbon).
Проект стартовал в 2001 году и продолжает развиваться. Так последний
релиз wxPerl (0.93) датируется 24 сентября 2009. С предкомпилированными
версиями wxPerl не всё так гладко: иногда они отстают от последней
версии wxPerl, особенно это относится к Windows. В самых свежих Linux-
и BSD-дистрибутивах ситуация несколько лучше: так пакет с wxPerl версии
0.93 есть в Mandriva 2010, в портах OpenBSD, в Debian unstable (sid).
В любом случае, собрать wxPerl в UNIX намного проще чем в Windows.
Более подробно об установке wxPerl читайте в следующих разделах.
Из неприятных моментов следует отметить документацию
по wxPerl, а точнее её отсутствие. На сайте wxPerl рекомендуется
использовать документацию по wxWidgets и мысленно транслировать её на
Perl, руководствуясь рядом правил. Также имеется несколько tutorial-ов
и wxPerl Wiki. Последняя встречает посетителей следующим сообщением:
The
previous wxPerl wiki was not only spammed, but someone managed to
entirely erase everything on disk that had to do with the kwiki-wiki.
It's now reinstalled and recovered as far as possible.
So...
please feel free to, create an account and start adding information!
Cheers.
Страница со скриншотами
wxPerl также давно не обновлялась: на ней представлен wxPerl версий от
0.14 (апрель 2003) до 0.21 (декабрь 2004). Ну и, наконец, обидно, что
по wxPerl нет книги, хотя по тому-же wxPython книга есть.
Установка в Linux
Если
вам повезло и в вашем дистрибутиве оказался соответствующий пакет, то
можете смело пропустить этот раздел. Если нет, то придется собрать
wxPerl вручную из CPAN. Для начала необходимо установить саму
библиотеку wxWidgets с заголовочными файлами. К примеру, в Mandriva
Linux 2008 необходимые пакеты называются libwxgtku2.8 и libwxgtku2.8-devel
соответственно. Обратите внимание на букву "u" в названиях пакетов. Она
означает, что wxWidgets скомпилирован с поддержкой Unicode. После того
как библиотеки поставлены, установите следующие Perl-модули: Wx, Alien::wxWidgets и ExtUtils::XSpp.
Установка в Windows
Прежде чем приступить к установке wxPerl, необходимо скачать
и проинсталлировать библиотеку wxWidgets. Почти наверняка этот шаг не
вызовет никаких сложностей. Далее следует установить wxPerl. Если вы
пользуетесь дистрибутивом ActivePerl, то проще всего подключить PPM-репозиторий, который поддерживает Марк Дутсон (Mark Dootson), и установить модуль Wx отдуда. Однако, необходимо иметь в виду две вещи: во-первых, в репозитории может быть не самая последняя версия Wx (на момент написания этих строк - 0.89.1), а во-вторых, необходимо установить правильную версию пакета Alien-wxWidgets, от которого зависит Wx. На момент написания этих строк в репозитории находятся две версии Alien-wxWidgets: 0.39 и 0.44 По умолчанию, разрешая зависимости программа PPM выберет самую свежую версию - 0.44. Проблема в том, Alien-wxWidgets версии 0.44 не будет работать с Wx версии 0.89.1! Для того чтобы обойти эту неприятность следует явно установить Alien-wxWidgets версии 0.39, а затем уже установить Wx.
На выяснение этого "очевидного" факта ушло более часа поисков. Впрочем,
возможно на момент прочтения этих строк данная проблема будет уже
устранена.
Минимальное приложение на wxPerl
Теперь,
когда wxPerl установлен, можно опробовать его в действии. Тестовое
приложение состоит из двух файлов (файлы должны находиться в одной
директории).
wx-minimal.pl:
#!/usr/bin/perl
#
# Александр Симаков, <xdr (тчк) box на Google Mail>
# http://alexander-simakov.blogspot.com/
#
# Простейшая программа использующая wxPerl
#
use strict;
use warnings;
use FindBin;
use lib "$FindBin::Bin";
use Wx;
use MinimalApp;
sub main() {
# Создаём экземпляр приложения и ...
my $minimal_app = MinimalApp->new();
# ... запускаем цикл обработки событий.
$minimal_app->MainLoop();
}
main();
MinimalApp.pm:
package MinimalApp;
#
# Александр Симаков, <xdr (тчк) box на Google Mail>
# http://alexander-simakov.blogspot.com/
#
# Минимальный класс приложения wxPerl
#
use strict;
use warnings;
use utf8;
use encoding 'utf8';
use Wx;
use base qw{ Wx::App };
sub OnInit {
# Создаём окно
my $frame = Wx::Frame->new(
undef, # Родительское окно
-1, # ID окна (-1 значит сгенерировать автоматически)
'Минимальное приложение на wxPerl', # Заголовок окна
[ -1, -1 ], # Позиция окна (значение по умолчанию)
[ 450, 100 ], # Размер окна
);
# Отображаем его на экране
$frame->Show( 1 );
}
1;
Вот как выглядит результат запуска этой программы:
Вид в Linux
Вид в Windows
Wx::Demo
Для
изучения wxPerl очень полезно ознакомится с подборкой демонстрационных
программ. Все программы объединены под одним интерфейсом: сразу можно
посмотреть как на внешний вид, так и на исходный текст приложения.
Соответствующий модуль называется Wx::Demo.
Пользователи Windows могут установить этот модуль из упомянутого выше
PPM-репозитория. На этот раз никаких сюрпризов нет. Запускной файл
называется wxperl_demo.pl
Wx::Demo
даёт хорошее представление о возможностях wxPerl, но также обнажает и
некоторые недоработки. Сравните виджет wxComboCtrl в Linux и в Windows:
Вид в Linux
Вид в Windows
А вот ещё пара примеров: при масштабировании окна виджеты "наезжают" друг на друга:
Вид в Linux
Вид в Windows
В
целом, идея использования виджетов хост-системы очень логична. Однако,
встречаются виджеты, специфичные для какой-то конкретной платформы. К
таким виджетам, например, относится GtkExpander. Обратите внимание как
выглядит этот виджет в Linux (напомню, в Linux wxWidgets базируется на
GTK+) и в Windows:
Вид в Linux
Вид в Windows
Выводы
В
целом, wxPerl достаточно интересный и перспективный проект. Вместе с
тем, стоит признать, что пока уровень поддержки тулкита wx в языке Perl
существенно скромнее чем, скажем, в Python или C++. Таким образом,
остановив свой выбор на wxPerl будьте готовы приложить дополнительные
усилия на установку и настройку своего окружения, а также на поиски
документации и дргугих справочных материалов.
Ссылки
Для интереса, вот ссылки на биндинги тулкита wx для других языков программирования: