進度顯示器用於顯示正在進行的操作狀態。在下面的程式碼中可以看出,它相當容易使用。下面的內容從創建一個新進度顯示器開始。
GtkWidget *gtk_progress_bar_new( void ); |
創建進度顯示器後就可以使用它了。
void gtk_progress_bar_set_fraction ( GtkProgressBar *pbar, gdouble fraction ); |
第一個參數是希望操作的進度顯示器,第二個參數是「已完成」的百分比,意思是進度顯示器從0-100%已經填充的數量。它以0~1範圍的實數傳遞給函式。
GTK 1.2版已經給進度顯示器添加了一個新的功能,那就是允許它以不同的方法顯示其值,並通知用戶它的當前值和範圍。
進度顯示器可以用以下函式設置它的移動方向:
void gtk_progress_bar_set_orientation( GtkProgressBar *pbar, GtkProgressBarOrientation orientation ); |
orientation參數可以取下列值之一,以指示進度顯示器的移動方向:
GTK_PROGRESS_LEFT_TO_RIGHT 從左向右 GTK_PROGRESS_RIGHT_TO_LEFT 從右向左 GTK_PROGRESS_BOTTOM_TO_TOP 從下向上 GTK_PROGRESS_TOP_TO_BOTTOM 從上向下 |
除了指示進度已經發生的數量以外,進度顯示器還可以設置為僅僅指示有活動在繼續,即活動狀態。這在進度無法按數值度量的情況下很有用。用下面的函式來表明進度有了些進展。
void gtk_progress_bar_pulse ( GtkProgressBar *progress ); |
活動指示的步數由以下函式設置:
void gtk_progress_bar_set_pulse_step( GtkProgressBar *pbar, gdouble fraction ); |
在非活動狀態下,進度顯示器可以用下列函式在滑槽裡顯示一個可配置的文字:
void gtk_progress_bar_set_text( GtkProgressBar *progress, const gchar *text ); |
注意,gtk_progress_set_text()不再支持 GTK+ 1.2版進度顯示器裡那種類似printf()的格式參數 |
你可以通過呼叫 gtk_progess_bar_set_text() 並把 NULL 作為第二個參數來關閉字串的顯示.
進度顯示器的當前文字設置能由下面的函式取得。不要釋放傳回的字串.
const gchar *gtk_progress_bar_get_text( GtkProgressBar *pbar ); |
進度顯示器通常和timeouts或其它類似函式同時使用(詳見逾時、I/O 和 Idle 函式這一章),使應用程式就像是多任務一樣。一般都以同樣的方式呼叫 gtk_progress_bar_set_fraction() 或 gtk_progress_bar_pulse() 函式。
下面是一個進度顯示器的範例,用timeout函式更新進度顯示器的值。程式碼告訴你如何重設進度顯示器。
#include <gtk/gtk.h> typedef struct _ProgressData { GtkWidget *window; GtkWidget *pbar; int timer; gboolean activity_mode; } ProgressData; /* 更新進度顯示器,這樣就能夠看到進度顯示器的移動 */ static gboolean progress_timeout( gpointer data ) { ProgressData *pdata = (ProgressData *)data; gdouble new_val; if (pdata->activity_mode) gtk_progress_bar_pulse (GTK_PROGRESS_BAR (pdata->pbar)); else { /* 使用在調整物件中設置的取值範圍計算進度顯示器的值 */ new_val = gtk_progress_bar_get_fraction (GTK_PROGRESS_BAR (pdata->pbar)) + 0.01; if (new_val > 1.0) new_val = 0.0; /* 設置進度顯示器的新值 */ gtk_progress_bar_set_fraction (GTK_PROGRESS_BAR (pdata->pbar), new_val); } /* 這是一個timeout函式,傳回 TRUE,這樣它就能夠繼續被呼叫 */ return TRUE; } /* 回呼函式,切換在進度顯示器你的滑槽上的文字顯示 */ static void toggle_show_text( GtkWidget *widget, ProgressData *pdata ) { const gchar *text; text = gtk_progress_bar_get_text (GTK_PROGRESS_BAR (pdata->pbar)); if (text && *text) gtk_progress_bar_set_text (GTK_PROGRESS_BAR (pdata->pbar), ""); else gtk_progress_bar_set_text (GTK_PROGRESS_BAR (pdata->pbar), "some text"); } /* 回呼函式,切換進度顯示器的活動模式 */ static void toggle_activity_mode( GtkWidget *widget, ProgressData *pdata ) { pdata->activity_mode = !pdata->activity_mode; if (pdata->activity_mode) gtk_progress_bar_pulse (GTK_PROGRESS_BAR (pdata->pbar)); else gtk_progress_bar_set_fraction (GTK_PROGRESS_BAR (pdata->pbar), 0.0); } /* 回呼函式,切換進度顯示器的移動方向 */ static void toggle_orientation( GtkWidget *widget, ProgressData *pdata ) { switch (gtk_progress_bar_get_orientation (GTK_PROGRESS_BAR (pdata->pbar))) { case GTK_PROGRESS_LEFT_TO_RIGHT: gtk_progress_bar_set_orientation (GTK_PROGRESS_BAR (pdata->pbar), GTK_PROGRESS_RIGHT_TO_LEFT); break; case GTK_PROGRESS_RIGHT_TO_LEFT: gtk_progress_bar_set_orientation (GTK_PROGRESS_BAR (pdata->pbar), GTK_PROGRESS_LEFT_TO_RIGHT); break; default:; // 什麼也不做 } } /* 清除配置的記憶體,刪除計時器(timer) */ static void destroy_progress( GtkWidget *widget, ProgressData *pdata) { g_source_remove (pdata->timer); pdata->timer = 0; pdata->window = NULL; g_free (pdata); gtk_main_quit (); } int main( int argc, char *argv[]) { ProgressData *pdata; GtkWidget *align; GtkWidget *separator; GtkWidget *table; GtkWidget *button; GtkWidget *check; GtkWidget *vbox; gtk_init (&argc, &argv); /* 為傳遞到回呼函式中的資料配置記憶體 */ pdata = g_malloc (sizeof (ProgressData)); pdata->window = gtk_window_new (GTK_WINDOW_TOPLEVEL); gtk_window_set_resizable (GTK_WINDOW (pdata->window), TRUE); g_signal_connect (pdata->window, "destroy", G_CALLBACK (destroy_progress), (gpointer) pdata); gtk_window_set_title (GTK_WINDOW (pdata->window), "GtkProgressBar"); gtk_container_set_border_width (GTK_CONTAINER (pdata->window), 0); vbox = gtk_vbox_new (FALSE, 5); gtk_container_set_border_width (GTK_CONTAINER (vbox), 10); gtk_container_add (GTK_CONTAINER (pdata->window), vbox); gtk_widget_show (vbox); /* 創建一個居中對齊的物件 */ align = gtk_alignment_new (0.5, 0.5, 0, 0); gtk_box_pack_start (GTK_BOX (vbox), align, FALSE, FALSE, 5); gtk_widget_show (align); /* 創建進度顯示器 */ pdata->pbar = gtk_progress_bar_new (); pdata->activity_mode = FALSE; gtk_container_add (GTK_CONTAINER (align), pdata->pbar); gtk_widget_show (pdata->pbar); /* 加一個計時器(timer),以更新進度顯示器的值 */ pdata->timer = g_timeout_add (100, progress_timeout, pdata); separator = gtk_hseparator_new (); gtk_box_pack_start (GTK_BOX (vbox), separator, FALSE, FALSE, 0); gtk_widget_show (separator); /* 行數、列數、同質性(homogeneous) */ table = gtk_table_new (2, 3, FALSE); gtk_box_pack_start (GTK_BOX (vbox), table, FALSE, TRUE, 0); gtk_widget_show (table); /* 添加一個複選按鈕,以選擇是否顯示在滑槽裡的文字 */ check = gtk_check_button_new_with_label ("Show text"); gtk_table_attach (GTK_TABLE (table), check, 0, 1, 0, 1, GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 5, 5); g_signal_connect (check, "clicked", G_CALLBACK (toggle_show_text), pdata); gtk_widget_show (check); /* 添加一個複選按鈕,切換活動狀態 */ check = gtk_check_button_new_with_label ("Activity mode"); gtk_table_attach (GTK_TABLE (table), check, 0, 1, 1, 2, GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 5, 5); g_signal_connect (check, "clicked", G_CALLBACK (toggle_activity_mode), pdata); gtk_widget_show (check); /* 添加一個複選按鈕,切換移動方向 */ check = gtk_check_button_new_with_label ("Right to Left"); gtk_table_attach (GTK_TABLE (table), check, 0, 1, 2, 3, GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 5, 5); g_signal_connect (check, "clicked", G_CALLBACK (toggle_orientation), pdata); gtk_widget_show (check); /* 添加一個按鈕,用來退出應用程式 */ button = gtk_button_new_with_label ("close"); g_signal_connect_swapped (button, "clicked", G_CALLBACK (gtk_widget_destroy), pdata->window); gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0); /* 將按鈕設置為能預設的元件 */ gtk_widget_set_can_default (button, TRUE); /* 將預設焦點設置到這個按鈕上,使之成為預設按鈕,只要按ENTER鍵 * 就相當於點擊了這個按鈕 */ //譯者註: 能預設的元件在獲取焦點後成為預設元件,用戶按方向鍵等可以切換焦點。 gtk_widget_grab_default (button); gtk_widget_show (button); gtk_widget_show (pdata->window); gtk_main (); return 0; } |
2 則留言