我是在Windows XP
下學習GTK+
的,下面是環境的配置以及基本的程序開發流程
另外兩種開發環境是:Cygwin
和Linux
,最佳開發環境是使用Gnome
桌面的Linux
系統
開發環境的配置
1、上http://www.gtk.org下載gtk+-bundle_xxxxxxx_win32.zip
(當前最新gtk+-bundle_2.22.1-20101227_win32.zip
)
這個壓縮包包含了開發所需的一切資源,包括運行環境和開發庫;注意:這個文件的下載鏈接並沒有醒目列出,而是夾雜在下載頁的文字說明當中,如果有更新的版本就下載最新的
2、解壓該壓縮包到C:\GTK
具體路徑自定,這裏我是放在C盤
的GTK
目錄下面
3、將C:\GTK\bin
加入到PATH
環境變量
4、在命令行窗口中敲入pkg-config --libs --cflags gtk+-2.0
,如果能夠順利執行並打印出一堆路徑信息,則說明GTK+
開發環境安裝成功
另外一個簡便方法是上http://glade.gnome.org下載gladexxxx-with-GTK+.exe
(當前最新glade3-3.6.7-with-GTK+.exe
),安裝完成後會自動設置好環境變量
基本程序開發流程
- 手動建立一個工程目錄,比如
hello
- 在該目錄下編寫
C語言
源代碼文件,比如hello.c
- 編寫
makefile
文件
- 在該目錄下面執行
make
命令
以上就是最原始也最高效的GTK+
程序開發方法,需要用到的工具有以下兩個:
Gvim
:用來編輯C
源文件和makefile
文件(最好是安裝一個GTK+
語法高亮插件,這可以大大減少編碼錯誤,加快編碼速度)
MinGW
:Windows
下的GCC
編譯器
空白窗體開發演示
1、手動建立一個文件夾,命名爲demo
2、新建C語言
源文件demo.c
,內容如下:
03 | int main( int argc, char * argv[]){ |
05 | gtk_init(&argc, &argv); |
07 | window = gtk_window_new(GTK_WINDOW_TOPLEVEL); |
09 | gtk_widget_show(window); |
3、新建一個makefile
文件,文件名就是makefile
,內容如下:
GTK_FLAGS = $(shell pkg-config --libs --cflags "gtk+-2.0")
all:
gcc -Wall -o demo demo.c ${GTK_FLAGS}
makefile
代碼直接從網頁複製將不能正常使用,最好是手動照着敲出來,all:
下面那一行的最前面是一個Tab
鍵,不是空格
4、在demo
目錄下執行make
命令,如果不出意外則會在demo
目錄下生成demo.exe
可執行文件
5、雙擊demo.exe
就會彈出一個空白窗體(呵呵,還什麼都沒有哦^-^
)
GTK+程序的基本架構
下面以擁有兩個標籤和一條水平分割線的窗體程序來解釋GTK+
程序的基本架構
本程序提供了一個gif
格式的演示視頻:點此進入演示地址
07 | int main( int argc, char ** argv){ |
14 | GtkWidget * hseparator; |
19 | gtk_init(&argc, &argv); |
23 | window = gtk_window_new(GTK_WINDOW_TOPLEVEL); |
24 | gtk_window_set_position(GTK_WINDOW(window), GTK_WIN_POS_CENTER); |
25 | gtk_window_set_title(GTK_WINDOW(window), "GtkHSeparator" ); |
26 | gtk_window_set_resizable(GTK_WINDOW(window), FALSE); |
27 | gtk_container_set_border_width(GTK_CONTAINER(window), 20); |
31 | vbox = gtk_vbox_new(FALSE, 10); |
35 | gtk_container_add(GTK_CONTAINER(window), vbox); |
39 | label1 = gtk_label_new( "Zinc is a moderately reactive, blue gray metal that tarnishes\n" ); |
40 | gtk_label_set_line_wrap(GTK_LABEL(label1), TRUE); |
41 | label2 = gtk_label_new( "Copper is an essential trace nutrient to all high plants and animals" ); |
42 | gtk_label_set_line_wrap(GTK_LABEL(label2), TRUE); |
43 | hseparator = gtk_hseparator_new(); |
47 | gtk_box_pack_start(GTK_BOX(vbox), label1, FALSE, TRUE, 0); |
48 | gtk_box_pack_start(GTK_BOX(vbox), hseparator, FALSE, TRUE, 10); |
49 | gtk_box_pack_start(GTK_BOX(vbox), label2, FALSE, TRUE, 0); |
53 | g_signal_connect_swapped(G_OBJECT(window), "destroy" , |
54 | G_CALLBACK(gtk_main_quit), G_OBJECT(window)); |
58 | gtk_widget_show_all(window); |
上述架構簡述如下:
- 包含頭文件
- 聲明窗體元素
- 初始化
GTK+
程序
- 新建並設置窗體
- 新建並設置容器
- 將容器嵌入窗體
- 新建並設置控件
- 將控件嵌入容器
- 進行信號綁定
- 顯示窗體
- 進入
GTK+
主函數
如果有自定義函數,則統一寫在main
函數之前
以上就是標準的GTK+
程序開發流程,更大型的程序也都可以這麼做
更復雜的界面可以藉助Glade
可視化界面設計工具