信号函数:
gint gtk_signal_connect(GtkObject *object,gchar *name,GtkSignalFuncfunc,gpointer func_data);
回掉函数的格式:
void callback_func(GtkEidget *widget,gpointer callback_data);
GTK的事件:gtk组件的行为或者X服务器发送的事件可以与下列事件联系起来:
button_press_event <wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong> 按钮按下</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong><br>
button_release_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>按钮释放<br>
motion_notify_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>鼠标移动<br>
delete_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>使用窗口管理器关闭<br>
destroy_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>关闭<br>
expose_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>曝光<br>
key_press_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>按键按下<br>
key_release_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>按键释放<br>
enter_notify_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>鼠标指针进入组件<br>
leave_notify_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>鼠标指针离开组件<br>
configure_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>属性改变<br>
focus_in_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>获得聚焦<br>
focus_out_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>失去聚焦<br>
map_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>映射<br>
unmap_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>消失<br>
property_notify_even</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>属性改变<br>
selection_clear_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>选择清除<br>
selection_request_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>选择请求<br>
selection_notify_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>选择通知<br>
proximity_in_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>接近<br>
proximity_out_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>离开<br>
drag_begin_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>拖开始<br>
drag_request_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>拖请求<br>
drag_end_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>拖结束<br>
drop_enter_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>放进入<br>
drop_leave_event</strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong></strong></span><wbr><span style="font-size:18px"><strong>放离开<br>
drop_data_available_event</strong></span><wbr><span style="font-size:18px"><strong> 放数据可用</strong></span></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
除有前面描述的信号机制外,还有一套 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 );
GdkEvent 是一个 C 联合结构,它的类型依赖于上述事件中的哪个事件发生了。为了让我们得知发生了哪个事件,每个可能的类型都有一个 type 成员来反映发生的事件。事件结构的其它部分将依赖于这个事件的类型。类型的可能的值有:
GDK_NOTHING
GDK_DELETE
GDK_DESTROY
GDK_EXPOSE
GDK_MOTION_NOTIFY
GDK_BUTTON_PRESS
GDK_2BUTTON_PRESS
GDK_3BUTTON_PRESS
GDK_BUTTON_RELEASE
GDK_KEY_PRESS
GDK_KEY_RELEASE
GDK_ENTER_NOTIFY
GDK_LEAVE_NOTIFY
GDK_FOCUS_CHANGE
GDK_CONFIGURE
GDK_MAP
GDK_UNMAP
GDK_PROPERTY_NOTIFY
GDK_SELECTION_CLEAR
GDK_SELECTION_REQUEST
GDK_SELECTION_NOTIFY
GDK_PROXIMITY_IN
GDK_PROXIMITY_OUT
GDK_DRAG_ENTER
GDK_DRAG_LEAVE
GDK_DRAG_MOTION
GDK_DRAG_STATUS
GDK_DROP_START
GDK_DROP_FINISHED
GDK_CLIENT_EVENT
GDK_VISIBILITY_NOTIFY
GDK_NO_EXPOSE
GDK_SCROLL
GDK_WINDOW_STATE
GDK_SETTING
|
所以,连接一个回调函数到这些事件之一,我们会这样用:
g_signal_connect (G_OBJECT (button), "button_press_event",
G_CALLBACK (button_press_callback), NULL);
|
这里假定 button 是一个按钮构件。现在,当鼠标位于按钮上并按一下鼠标时,函数 button_press_callback() 会被调用。这个函数应该声明为:
static gint button_press_callback( GtkWidget *widget,
GdkEventButton *event,
gpointer data );
|
注意,我们可以把第二个参数类型声明为 GdkEventButton,因为我们知道哪个类型的事件会发生。
这个函数的返回值指示这个事件是否应该由 GTK 事件处理机制做进一步的传播。返回 TRUE 指示这个事件已经处理了,且不应该做进一步传播。返回 FALSE 继续正常的事件处理。详见高级事件和信号处理这一章。
GdkEvent 数据类型详情请参见附录 GDK 事件类型。
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
分享到:
相关推荐
- **信号(Signal)**:GTK的事件处理机制,控件可以通过发出信号来响应特定事件,而其他对象可以连接到这些信号并执行相应操作。 - **属性(Property)**:控制控件行为和外观的参数,可以动态修改。 - **模型-视图...
- 使用 `g_signal_connect()` 连接信号和回调函数。 通过以上介绍,我们可以了解到 GTK 是一个功能强大、易于使用的 GUI 工具包,适用于各种类型的应用程序开发。无论是对于初学者还是有经验的开发者而言,GTK 都...
GTK提供了信号(Signal)和回调(Callback)机制,通过连接控件的信号到对应的回调函数,可以实现用户交互功能。 对于mp3文件的播放,你可能需要使用如GStreamer或GTK+自带的gstreamer模块这样的多媒体处理库。...
4. **信号(Signal)**:GTK+中的事件处理机制,通过连接信号到回调函数来响应用户行为或内部状态变化。 5. **回调函数(Callback Function)**:当信号被触发时执行的函数,处理事件或更新界面。 6. **布局管理器...
g_signal_connect(window, "delete-event", G_CALLBACK(gtk_main_quit), NULL); gtk_main(); return 0; } ``` 上述代码展示了如何创建一个简单的GTK窗口,并设置标题以及响应删除事件。 2. **布局管理**: ...
GTK还提供了信号(Signal)机制,允许对象之间进行通信,例如,当按钮被按下时,可以发送一个“clicked”信号。 GTK-Doc是一个用于生成高质量API文档的工具,它从源代码注释中提取信息,并将其整理成结构化的HTML...
g_signal_connect(G_OBJECT(window), "destroy", G_CALLBACK(gtk_main_quit), NULL); gpointer button = gtk_builder_get_object(builder, "button1"); g_signal_connect(button, "clicked", G_CALLBACK(button_...
4. **事件处理**:GTK+ 使用信号(Signal)和槽(Slot)机制来处理用户交互。例如,`g_signal_connect()` 函数用于将特定的回调函数连接到控件的某个信号,如按钮的“点击”事件。 5. **布局管理**:GTK+ 有多种...
我们使用`g_signal_connect()`将按钮的“clicked”信号连接到相应的处理函数。例如,数字按钮的点击事件可能更新文本框的显示,而运算符按钮则保存当前的操作数和操作符。 在回调函数中,我们需要处理逻辑运算。这...
- **信号处理和回调函数**:GTK通过信号和槽的机制来处理事件,通常需要定义回调函数来响应特定的信号。 通过以上介绍,我们可以看到GTK不仅是一个功能强大的GUI库,而且其丰富的特性和优秀的社区支持使得它成为...
- **3.2 更多Signal Handlers** - 探讨更多的事件处理函数。 - 如何为不同的GUI元素添加事件处理器。 - **3.3 “Hello World”加强版** - 在基本的“Hello World”程序基础上添加更多的功能。 - 可能包括按钮...
4. **信号处理**:定义事件处理函数,并通过`g_signal_connect()`将其与特定事件关联起来。 5. **显示窗口**:调用`gtk_widget_show_all(window);`使窗口及其所有子控件可见。 6. **运行主循环**:最后,调用`gtk_...
1. **GTK+3 概念**:理解 GTK+3 的核心概念,如 Widget(控件)、Container(容器)、信号(Signal)等,是使用此绑定的前提。GTK+3 提供了大量的预定义控件,如 Button、Label、Entry、TreeView 等,这些控件可以...
最后,程序设置了窗口关闭信号的回调函数`gtk_main_quit()`,以便在用户关闭窗口时结束程序。 #### 编译与运行 编译这个程序,可以使用以下命令: ```sh gcc hello_dubuntu.c -o hello_dubuntu `pkg-config --...
g_signal_connect(GTK_OBJECT(window), "destroy", GTK_SIGNAL_FUNC(quit_win), NULL); // 创建并配置其他GUI组件 // ... } ``` 这里定义了程序的入口点,通过`gtk_init`初始化GTK环境,接着创建顶层窗口,并...
`Gtk::Button` 类提供了多种信号,其中最常用的是 `signal_clicked()`,用于处理按钮被点击的事件。 ##### 4.2 ToggleButton(切换按钮) `Gtk::ToggleButton` 类继承自 `Gtk::Button`,它提供了一个可以在激活和...
例如,创建一个按钮并为其绑定信号处理函数的代码示例: ```c GtkWidget* button = gtk_button_new_with_label("Click Me"); g_signal_connect(button, "clicked", G_CALLBACK(on_button_clicked), NULL); ``` ...
g_signal_connect(button, "clicked", G_CALLBACK(on_button_clicked), window); gtk_container_add(GTK_CONTAINER(window), button); gtk_widget_show_all(window); gtk_main(); return 0; } ``` ##### ...
QT与wxWidgets相比,QT的语法更接近Java的Swing,采用SIGNAL/SLOT机制,使代码结构清晰易懂。然而,这也导致了需要通过qmake预处理才能进行编译的步骤。另外,QT的界面并非原生风格,而是通过style机制模拟本地界面...
3. **信号(Signal)**:GTK+采用信号和槽的概念来处理事件。当用户执行某种操作(如点击按钮),相应的信号会被触发,你可以通过连接信号处理函数来响应这些事件。 4. **布局管理器(LayoutManager)**:PyGTK提供...