GTK学习[一]:GTK中的信号(Signal)与事件

 
标签: 

 

 

 

 

 

分类: 

信号(Signal)是GTK中出现的新的并且比较重要的概念。这里讲的信号不同于UNIX的信号,它像名字一样。当处理X事件时,如鼠标按键按下,GTK组件接收到这个事件,便发出响应的信号。不同的组件相关信号可能不一样。

信号函数:
gint gtk_signal_connect(GtkObject *object,gchar *name,GtkSignalFunc func,gpointer func_data);
回掉函数的格式:
void callback_func(GtkEidget *widget,gpointer callback_data);
GTK的事件:gtk组件的行为或者X服务器发送的事件可以与下列事件联系起来:
button_press_event    按钮按下           
button_release_event    按钮释放
motion_notify_event    鼠标移动
delete_event    使用窗口管理器关闭
destroy_event    关闭
expose_event    曝光
key_press_event    按键按下
key_release_event    按键释放
enter_notify_event    鼠标指针进入组件
leave_notify_event    鼠标指针离开组件
configure_event    属性改变
focus_in_event    获得聚焦
focus_out_event    失去聚焦
map_event    映射
unmap_event    消失
property_notify_even    属性改变
selection_clear_event    选择清除
selection_request_event    选择请求
selection_notify_event    选择通知
proximity_in_event    接近
proximity_out_event    离开
drag_begin_event    拖开始
drag_request_event    拖请求
drag_end_event    拖结束
drop_enter_event    放进入
drop_leave_event    放离开
drop_data_available_event  放数据可用

除有前面描述的信号机制外,还有一套 events 反映 X 事件机制。回调函数可以与这些事件连接。这些事件是:

 

  • event
  • button_press_event
  • button_release_event
  • scroll_event
  • motion_notify_event
  • delete_event
  • destroy_event
  • expose_event
  • key_press_event
  • key_release_event
  • enter_notify_event
  • leave_notify_event
  • configure_event
  • focus_in_event
  • focus_out_event
  • map_event
  • unmap_event
  • property_notify_event
  • selection_clear_event
  • selection_request_event
  • selection_notify_event
  • proximity_in_event
  • proximity_out_event
  • visibility_notify_event
  • client_event
  • no_expose_event
  • window_state_event

为了连接一个回调函数到这些事件之一,你使用函数 g_signal_connect(),像前面介绍的一样,用上面事件名之一作为 name 参数。事件的回调函数与信号的回调函数有一点点不同:

gint callback_func( GtkWidget *widget,GdkEvent *event,gpointer callback_data );
 
所以,连接一个回调函数到这些事件之一,我们会这样用:
 
static gint button_press_callback( GtkWidget *widget, GdkEventButton *event, gpointer data );
注意,我们可以把第二个参数类型声明为 GdkEventButton,因为我们知道哪个类型的事件会发生。 这个函数的返回值指示这个事件是否应该由 GTK 事件处理机制做进一步的传播。返回 TRUE 指示这个事件已经处理了,且不应该做进一步传播。返回 FALSE 继续正常的事件处理。详见这一章。 GdkEvent 数据类型详情请参见附录 。 GDK 选中区和拖放的接口函数也发出许多事件,在 GTK 中用信号来反映。下列信号的内容详见和这两章:
  • selection_received
  • selection_get
  • drag_begin_event
  • drag_end_event
  • drag_data_delete
  • drag_motion
  • drag_drop
  • drag_data_get
  • drag_data_received