筆記本元件(The NoteBook Widget)是互相重疊的頁面集合,每一頁都包含不同的訊息,且一次只有一個頁面是可見的。該元件在GUI(圖形用戶介面)程式設計中很常用。要顯示大量的相似訊息,同時把它們分別顯示時,使用這種元件是一個很好的方法。
第一個你要知道的函式呼叫,你可能已經猜到了,是用來創建一個新的筆記本元件。
GtkWidget *gtk_notebook_new( void ); |
一旦創建了筆記本元件,就可以使用一系列的函式操作該元件。下面將對它們進行分別討論。
先看一下怎樣定位頁面指示器—或稱頁標籤,可以有四種位置:上、下、左或右。
void gtk_notebook_set_tab_pos( GtkNotebook *notebook, GtkPositionType pos ); |
GtkPositionType參數可以取以下幾個值,從字面上很容易理解它們的含義:
GTK_POS_LEFT GTK_POS_RIGHT GTK_POS_TOP GTK_POS_BOTTOM |
GTK_POS_TOP是預設值。
下面看一下怎樣向筆記本中添加頁面。有三種方法向筆記本中添加頁面。前兩種方法是非常相似的。
void gtk_notebook_append_page( GtkNotebook *notebook, GtkWidget *child, GtkWidget *tab_label ); void gtk_notebook_prepend_page( GtkNotebook *notebook, GtkWidget *child, GtkWidget *tab_label ); |
這些函式通過向插入頁面到筆記本的後端(append)或前端(prepend)來添加頁面。child是放在筆記本頁面裡的子元件,tab_label是要添加的頁面的標籤。child元件必須另外創建,一般是一個包含一套選項設置的容器元件,比如一個表格。
最後一個添加頁面的函式與前兩個函式類似,不過允許指定頁面插入的位置。
void gtk_notebook_insert_page( GtkNotebook *notebook, GtkWidget *child, GtkWidget *tab_label, gint position ); |
其中的參數與_append_和_prepend_函式一樣,還包含一個額外參數,position。該參數指定頁面應該插入到哪一頁。注意,第一頁位置為0。
前面介紹了怎樣添加一個頁面,下面介紹怎樣從筆記本中刪除一個頁面。
void gtk_notebook_remove_page( GtkNotebook *notebook, gint page_num ); |
這個函式從notebook指定的筆記本中刪除由page_num參數指定的頁面。
用這個函式找出筆記本的當前頁面:
gint gtk_notebook_get_current_page( GtkNotebook *notebook ); |
下面兩個函式將筆記本的頁面向前或向後移動。對要操作的筆記本元件使用以下函式就可以了。注意:當筆記本正在最後一頁時,呼叫 gtk_notebook_next_page() 函式,筆記本會跳到第一頁。同樣,如果筆記本在第一頁,呼叫了函式 gtk_notebook_prev_page(),筆記本元件會跳到最後一頁。
void gtk_notebook_next_page( GtkNoteBook *notebook ); void gtk_notebook_prev_page( GtkNoteBook *notebook ); |
下面這個函式設置「活動」頁面。比如你想筆記本的第5頁被打開,你將使用這個函式。不使用這個函式時筆記本預設顯示第一頁。
void gtk_notebook_set_current_page( GtkNotebook *notebook, gint page_num ); |
下面兩個函式分別顯示或隱藏筆記本的頁標籤以及它的邊框。
void gtk_notebook_set_show_tabs( GtkNotebook *notebook, gboolean show_tabs ); void gtk_notebook_set_show_border( GtkNotebook *notebook, gboolean show_border ); |
如果頁面較多,標籤頁在頁面上排列不下時,可以用下面這個函式。它允許用兩個箭頭按鈕來滾動標籤頁。
void gtk_notebook_set_scrollable( GtkNotebook *notebook, gboolean scrollable ); |
show_tabs, show_border和scrollable參數可以為 TRUE 或 FALSE。
下面看一個範例,它由 GTK 發佈版附帶的testgtk.c擴展而來。這個小程式創建了一個含一個筆記本元件和6個按鈕的視窗。筆記本包含11頁,由三種方式添加進來:追加、插入、前插。點擊按鈕可以改變頁標籤的位置,顯示/隱藏頁標籤和邊框,刪除一頁,向前或向後移動標籤頁,以及退出程式。
#include <stdio.h> #include <gtk/gtk.h> /* 這個函式旋轉頁標籤的位置 */ static void rotate_book( GtkButton *button, GtkNotebook *notebook ) { gtk_notebook_set_tab_pos (notebook, (notebook->tab_pos + 1) % 4); } /* 顯示/隱藏頁標籤和邊框 */ static void tabsborder_book( GtkButton *button, GtkNotebook *notebook ) { gint tval = FALSE; gint bval = FALSE; if (notebook->show_tabs == 0) tval = TRUE; if (notebook->show_border == 0) bval = TRUE; gtk_notebook_set_show_tabs (notebook, tval); gtk_notebook_set_show_border (notebook, bval); } /* 從筆記本上刪除一個頁面 */ static void remove_book( GtkButton *button, GtkNotebook *notebook ) { gint page; page = gtk_notebook_get_current_page (notebook); gtk_notebook_remove_page (notebook, page); /* 需要刷新元件 -- 這會迫使元件重繪自身。 */ gtk_widget_queue_draw (GTK_WIDGET (notebook)); } static gboolean delete( GtkWidget *widget, GtkWidget *event, gpointer data ) { gtk_main_quit (); return FALSE; } int main( int argc, char *argv[] ) { GtkWidget *window; GtkWidget *button; GtkWidget *table; GtkWidget *notebook; GtkWidget *frame; GtkWidget *label; GtkWidget *checkbutton; int i; char bufferf[32]; char bufferl[32]; gtk_init (&argc, &argv); window = gtk_window_new (GTK_WINDOW_TOPLEVEL); g_signal_connect (window, "delete-event", G_CALLBACK (delete), NULL); gtk_container_set_border_width (GTK_CONTAINER (window), 10); table = gtk_table_new (3, 6, FALSE); gtk_container_add (GTK_CONTAINER (window), table); /* 創建一個新的筆記本,將標籤頁放在頂部 */ notebook = gtk_notebook_new (); gtk_notebook_set_tab_pos (GTK_NOTEBOOK (notebook), GTK_POS_TOP); gtk_table_attach_defaults (GTK_TABLE (table), notebook, 0, 6, 0, 1); gtk_widget_show (notebook); /* 在筆記本後面追加幾個頁面 */ for (i = 0; i < 5; i++) { sprintf(bufferf, "Append Frame %d", i + 1); sprintf(bufferl, "Page %d", i + 1); frame = gtk_frame_new (bufferf); gtk_container_set_border_width (GTK_CONTAINER (frame), 10); gtk_widget_set_size_request (frame, 100, 75); gtk_widget_show (frame); label = gtk_label_new (bufferf); gtk_container_add (GTK_CONTAINER (frame), label); gtk_widget_show (label); label = gtk_label_new (bufferl); gtk_notebook_append_page (GTK_NOTEBOOK (notebook), frame, label); } /* 在指定位置添加頁面 */ checkbutton = gtk_check_button_new_with_label ("Check me please!"); gtk_widget_set_size_request (checkbutton, 100, 75); gtk_widget_show (checkbutton); label = gtk_label_new ("Add page"); gtk_notebook_insert_page (GTK_NOTEBOOK (notebook), checkbutton, label, 2); /* 最後向筆記本前插頁面 */ for (i = 0; i < 5; i++) { sprintf (bufferf, "Prepend Frame %d", i + 1); sprintf (bufferl, "PPage %d", i + 1); frame = gtk_frame_new (bufferf); gtk_container_set_border_width (GTK_CONTAINER (frame), 10); gtk_widget_set_size_request (frame, 100, 75); gtk_widget_show (frame); label = gtk_label_new (bufferf); gtk_container_add (GTK_CONTAINER (frame), label); gtk_widget_show (label); label = gtk_label_new (bufferl); gtk_notebook_prepend_page (GTK_NOTEBOOK (notebook), frame, label); } /* 設置起始頁(第4頁) */ gtk_notebook_set_current_page (GTK_NOTEBOOK (notebook), 3); /* 創建一排按鈕 */ button = gtk_button_new_with_label ("close"); g_signal_connect_swapped (button, "clicked", G_CALLBACK (delete), NULL); gtk_table_attach_defaults (GTK_TABLE (table), button, 0, 1, 1, 2); gtk_widget_show (button); button = gtk_button_new_with_label ("next page"); g_signal_connect_swapped (button, "clicked", G_CALLBACK (gtk_notebook_next_page), notebook); gtk_table_attach_defaults (GTK_TABLE (table), button, 1, 2, 1, 2); gtk_widget_show (button); button = gtk_button_new_with_label ("prev page"); g_signal_connect_swapped (button, "clicked", G_CALLBACK (gtk_notebook_prev_page), notebook); gtk_table_attach_defaults (GTK_TABLE (table), button, 2, 3, 1, 2); gtk_widget_show (button); button = gtk_button_new_with_label ("tab position"); g_signal_connect (button, "clicked", G_CALLBACK (rotate_book), notebook); gtk_table_attach_defaults (GTK_TABLE (table), button, 3, 4, 1, 2); gtk_widget_show (button); button = gtk_button_new_with_label ("tabs/border on/off"); g_signal_connect (button, "clicked", G_CALLBACK (tabsborder_book), notebook); gtk_table_attach_defaults (GTK_TABLE (table), button, 4, 5, 1, 2); gtk_widget_show (button); button = gtk_button_new_with_label ("remove page"); g_signal_connect (button, "clicked", G_CALLBACK (remove_book), notebook); gtk_table_attach_defaults (GTK_TABLE (table), button, 5, 6, 1, 2); gtk_widget_show (button); gtk_widget_show (table); gtk_widget_show (window); gtk_main (); return 0; } |
我希望這些能幫你在你自己的應用程式中創建筆記本。
<<< Previous | 單元首頁 | Next >>> |
GTK+ 2.0 教學-工具欄 Toolbar | 向上 | GTK+ 2.0 教學-選單元件 |
1 則留言