GTK+ 2.0 教学-从这里开始

你首先做的第一件事,当然是下载 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;
}

« 

单元首页

Comments are closed.