你首先做的第一件事,当然是下载 GTK 原始码,并安装它。你总是能从 ftp.gtk.org 得到最新版本。你也可以在 http://www.gtk.org/ 上查看其它 GTK 原始码的讯息。GTK 使用 GNU autoconf 配置。解压缩后,输入 ./configure –help 查看选项列表
GTK 原始码的发行套件中包含教学中所有范例的原始码,每个范例中包含有 Makefiles 文件,用以方便编译。
[adsense]
一开始介绍 GTK,我们会尽可能从简单的程式开始。这个程式创建 200×200 大小的视窗,没有办法退出,除非你从 shell 中将它杀掉。

#include <gtk/gtk.h> int main( int argc,char *argv[]){
GtkWidget *window;
gtk_init (&argc, &argv);
window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
gtk_widget_show (window);
gtk_main ();
return 0;
}
|
你可以用 gcc 编译上面的程式:
gcc base.c -o base `pkg-config –cflags –libs gtk+-2.0`
不常用的编译参数在下面编译 Hello World 程式中解释。
所有程式应该包含 gtk/gtk.h,其中声明了变数、函式以及结构等,这些东西会在你的程式中使用。
下一行:
gtk_init (&argc, &argv); |
这个函式 gtk_init(gint *argc, gchar ***argv) 会在每个 GTK 应用程式中呼叫。该函式设定了预设的视频(visual)和颜色映射模式(color map),接着会呼叫函式 gdk_init(gint *argc, gchar ***argv)。该函式初始化要使用的函式库,设定预设的信号处理,并检查传递给你的程式的命令列参数,寻找下列之一:
- –gtk-module
- –g-fatal-warnings
- –gtk-debug
- –gtk-no-debug
- –gdk-debug
- –gdk-no-debug
- –display
- –sync
- –name
- –class
这些参数将会从参数表中删除,你的程式不会去解析或忽略这些参数。这就创建了可以被所有 GTK 程式接受的一组标准参数。
下面两行程式会创建并显示一个视窗
window = gtk_window_new (GTK_WINDOW_TOPLEVEL); gtk_widget_show (window); |
GTK_WINDOW_TOPLEVEL 参数指定了我们承习视窗管理程式的外观。这里不会创建一个0x0 大小的视窗,而是一个没有子元件的视窗预设大小设置为 200×200,这样你仍然能操作它。
gtk_widget_show() 函式让 GTK 知道,我们已经设置完元件的属性,可以显示它了。
最后一行进入 GTK 主处理回圈。
gtk_main (); |
gtk_main() 是另一个可以在每个 GTK 程式中见到的函式呼叫。当程式执行到这里,GTK 会“睡着”等待 X 事件 (如按钮或键盘按下)、逾时(timeouts)或文件 IO 通知发生。在我们的范例中,事件被忽略。
好,现在来写一个只有一个按钮元件的程式,这是一个标准的 GTK Hello World。

用 GTK 来写 Hello World
#include <gtk/gtk.h>
/* 这是一个回呼函式。data 参数在本范例中被忽略。 * 后面有更多的回呼函式范例。*/
void hello( GtkWidget *widget, gpointer data )
{
g_print ("Hello World\n");
}
gint delete_event( GtkWidget *widget, GdkEvent *event, gpointer data )
{
/* 如果你的 "delete_event" 信号处理函式传回 FALSE,GTK 会发出 "destroy" 信号。
* 传回 TRUE,你不希望关闭视窗。
* 当你想弹出“你确定要退出吗?”对话框时它很有用。*/
g_print ("delete event occurred\n");
/* 改 TRUE 为 FALSE 程式会关闭。*/
return TRUE;
}
/* 另一个回呼函式 */
void destroy( GtkWidget *widget, gpointer data )
{
gtk_main_quit ();
}
int main( int argc,char *argv[] )
{
/* GtkWidget 是元件的存储型态 */
GtkWidget *window;
GtkWidget *button;
/* 这个函式在所有的 GTK 程式都要呼叫。参数由命令列中解析出来并且送到该程式中*/
gtk_init (&argc, &argv);
/* 创建一个新视窗 */
window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
/* 当视窗收到 "delete_event" 信号 (这个信号由视窗管理器发出,通常是“关闭”
* 选项或是标题栏上的关闭按钮发出的),我们让它呼叫在前面定义的 delete_event() 函式。
* 传给回呼函式的 data 参数值是 NULL,它会被回呼函式忽略。*/
g_signal_connect (G_OBJECT (window), "delete_event", G_CALLBACK (delete_event), NULL);
/* 在这里我们连接 "destroy" 事件到一个信号处理函式。
* 对这个视窗呼叫 gtk_widget_destroy() 函式或在 "delete_event" 回呼函式中传回 FALSE 值
* 都会触发这个事件。*/
g_signal_connect (G_OBJECT (window), "destroy", G_CALLBACK (destroy), NULL);
/* 设置视窗边框的宽度。*/
gtk_container_set_border_width (GTK_CONTAINER (window), 10);
/* 创建一个标签为 "Hello World" 的新按钮。*/
button = gtk_button_new_with_label ("Hello World");
/* 当按钮收到 "clicked" 信号时会呼叫 hello() 函式,并将NULL传给
* 它作为参数。hello() 函式在前面定义了。*/
g_signal_connect (G_OBJECT (button), "clicked", G_CALLBACK (hello), NULL);
/* 当点击按钮时,会通过呼叫 gtk_widget_destroy(window) 来关闭视窗。
* "destroy" 信号会从这里或从视窗管理器发出。*/
g_signal_connect_swapped (G_OBJECT (button), "clicked", G_CALLBACK (gtk_widget_destroy), window);
/* 把按钮放入视窗 (一个 gtk 容器) 中。*/
gtk_container_add (GTK_CONTAINER (window), button);
/* 最后一步是显示新创建的按钮和视窗 */
gtk_widget_show (button);
gtk_widget_show (window);
/* 所有的 GTK 程式必须有一个 gtk_main() 函式。程式执行停在这里
* 等待事件 (如键盘事件或滑鼠事件) 的发生。*/
gtk_main ();
return 0;
}
|
2 則留言
Comments are closed.