теория
сигналов и обратных вызовов
|
в версии 2.0, система сигналов
перемещена из gtk в glib, поэтому функции
и типы в этой секции имеют приставку
"g_" а не "gtk_". здесь не говорится
о расширениях системы сигналов glib 2.0
по сравнению с системой сигналов gtk
1.2.
|
перед подробным рассмотрением helloworld,
мы обсудим сигналы (signals) и обратные
вызовы (callbacks). gtk - набор инструментов
управляемых событиями, это значит что
процесс находясь в функции gtk_main() ждет
пока не произойдет событие позволяющее
передать управление соответствующей
функции.
такой контроль выполняется с использованием
идеи сигналов (idea of "signals"). (учтите
что эта система сигналов не тоже самое
что система сигналов unix, хотя используется
идентичная терминология). когда происходит
событие, такое как нажатие кнопки мыши,
виджет создаёт ("emitted") сигнал
соответствующий нажатию. так gtk выполняет
большинство своих действий. есть сигналы
которые наследуют все виджеты, например
сигнал закрытия ("destroy"), а есть
специфические сигналы, например сигнал
кнопки переключения ("toggled").
чтобы заставить кнопку работать, нужно
настроить обработчик сигналов, который
при возникновении события запустит
функцию. это делается так:
gulong g_signal_connect( gpointer *object,
const gchar *name,
gcallback func,
gpointer func_data );
|
первый
аргумент - виджет который создаёт сигнал,
второй - имя сигнала, третий - функция
которая должна быть вызвана этим сигналом
и четвертый - данные которые передаются
этой функции.
функция
определенная в третьем аргументе должна
иметь общую форму:
void callback_func( gtkwidget *widget,
gpointer callback_data );
|
где первым
аргументом будет указатель на виджет,
который создал сигнал, а второй - указатель
на данные как последний аргумент функции
g_signal_connect() как показано выше.
выше описанная
форма функции обратного вызова имеет
общий вид, но некоторые виджеты имеют
специфические параметры и сигналы.
другой вызов
использованный в примере helloworld:
gulong g_signal_connect_swapped( gpointer *object,
const gchar *name,
gcallback func,
gpointer *slot_object );
|
g_signal_connect_swapped()
тоже самое, что g_signal_connect() только в
качестве единственного аргумента
используется указатель на gtk объект.
для использования этой функции вызова
сигнала, обратный вызов должен иметь
форму
void callback_func( gtkobject *object );
|
где объектом
обычно является виджет. обычно обратный
вызов не устанавливается для
g_signal_connect_swapped(). они обычно используются
в вызовах gtk функций которые принимают
как единственный аргумент сигнал виджета
или объект, что и показано в примере
helloworld.
наличие двух функций вызова сигналов
объясняется необходимостью обратным
вызовам иметь разное количество
аргументов. многие функции в библиотеке
gtk принимают только указатель gtkwidget как
единственный аргумент, таким образом
используя g_signal_connect_swapped() в ваших функциях,
вам могут понадобится расширенные
данные обратных вызовов.
|