首頁 / LinuxDev / GTK+ 2.0 教學-封裝示範程式

GTK+ 2.0 教學-封裝示範程式

/* example-start packbox packbox.c */

#include <stdio.h>
#include <stdlib.h>
#include "/gtk.h"

static gboolean delete_event( GtkWidget *widget,
                              GdkEvent  *event,
                              gpointer   data )
{
    _main_quit ();
    return FALSE;
}

/* 生成一個填滿按鈕-標籤的橫向盒。我們將感興趣的參數傳遞進了這個函式。  
 * 我們不顯示這個盒,但顯示它內部的所有東西。 */
static GtkWidget *make_box( gboolean homogeneous,
                            gint     spacing,
                            gboolean expand,
                            gboolean fill,
                            guint    padding ) 
{
    GtkWidget *box;
    GtkWidget *button;
    char padstr[80];

    /* 以合適的 homogeneous 和 spacing 設定創建一個新的橫向盒 */
    box = _hbox_new (homogeneous, spacing);

    /* 以合適的設定創建一系列的按鈕 */
    button = _button_new_with_label ("_box_pack");
    _box_pack_start (_BOX (box), button, expand, fill, padding);
    _widget_show (button);

    button = _button_new_with_label ("(box,");
    _box_pack_start (_BOX (box), button, expand, fill, padding);
    _widget_show (button);

    button = _button_new_with_label ("button,");
    _box_pack_start (_BOX (box), button, expand, fill, padding);
    _widget_show (button);

    /* 根據 expand 的值創建一個帶標籤的按鈕 */
    if (expand == TRUE)
	    button = _button_new_with_label ("TRUE,");
    else
	    button = _button_new_with_label ("FALSE,");

    _box_pack_start (_BOX (box), button, expand, fill, padding);
    _widget_show (button);

    /* 這個和上面根據 "expand" 創建按鈕一樣,不過用了簡化的形式。 */
    button = _button_new_with_label (fill ? "TRUE," : "FALSE,");
    _box_pack_start (_BOX (box), button, expand, fill, padding);
    _widget_show (button);

    sprintf (padstr, "%d);", padding);

    button = _button_new_with_label (padstr);
    _box_pack_start (_BOX (box), button, expand, fill, padding);
    _widget_show (button);

    return box;
}

int main( int   argc,
          char *argv[]) 
{
    GtkWidget *window;
    GtkWidget *button;
    GtkWidget *box1;
    GtkWidget *box2;
    GtkWidget *separator;
    GtkWidget *label;
    GtkWidget *quitbox;
    int which;

    /* 初始化,不要忘記這個!:) */
    _init (&argc, &argv);

    if (argc != 2) {
	fprintf (stderr, "usage: packbox num, where num is 1, 2, or 3.\n");
	/* 這個在對  進行收尾處理後以退出狀態為 1 退出。 */
	exit (1);
    }

    which = atoi (argv[1]);

    /* 創建視窗 */
    window = _window_new (_WINDOW_TOPLEVEL);

   /* 你應該總是記住連接 delete_event 信號到主視窗。這對適當的直覺行為很重要 */
    g_signal_connect (window, "delete-event",
		      G_CALLBACK (delete_event), NULL);
    _container_set_border_width (_CONTAINER (window), 10);

    /* 我們創建一個縱向盒(vbox)把橫向盒封裝進來。
     * 這使我們可以將填滿按鈕的橫向盒一個個堆疊到這個縱向盒裡。 */
    box1 = _vbox_new (FALSE, 0);

    /* 顯示哪個範例。這些對應於上面的圖片。 */
    switch (which) {
    case 1:
	/* 創建一個新標籤。 */
	label = _label_new ("_hbox_new (FALSE, 0);");

	/* 使標籤靠左排列。我們將在元件屬性部分討論這個函式和其它的函式。 */
	_misc_set_alignment (_MISC (label), 0, 0);

	/* 將標籤封裝到縱向盒(vbox box1)裡。記住加到縱向盒裡的   
         * 元件將依次一個放在另一個上面地封裝。 */
	_box_pack_start (_BOX (box1), label, FALSE, FALSE, 0);

	/* 顯示標籤 */
	_widget_show (label);

	/* 呼叫我們產生盒的函式 - homogeneous = FALSE, spacing = 0,   
         * expand = FALSE, fill = FALSE, padding = 0 */
	box2 = make_box (FALSE, 0, FALSE, FALSE, 0);
	_box_pack_start (_BOX (box1), box2, FALSE, FALSE, 0);
	_widget_show (box2);

	/* 呼叫我們產生盒的函式 - homogeneous = FALSE, spacing = 0,   
         * expand = TRUE, fill = FALSE, padding = 0 */
	box2 = make_box (FALSE, 0, TRUE, FALSE, 0);
	_box_pack_start (_BOX (box1), box2, FALSE, FALSE, 0);
	_widget_show (box2);

	/* 參數是: homogeneous, spacing, expand, fill, padding */
	box2 = make_box (FALSE, 0, TRUE, TRUE, 0);
	_box_pack_start (_BOX (box1), box2, FALSE, FALSE, 0);
	_widget_show (box2);

	/* 創建一個分隔線,以後我們會更詳細地學習這些,但它們確實很簡單。 */
	separator = _hseparator_new ();

        /* 封裝分隔線到縱向盒。記住這些元件每個都被封裝進
           了一個縱向盒,所以它們被垂直地堆疊。 */
	_box_pack_start (_BOX (box1), separator, FALSE, TRUE, 5);
	_widget_show (separator);

	/* 創建另一個新標籤,並顯示它。 */
	label = _label_new ("_hbox_new (TRUE, 0);");
	_misc_set_alignment (_MISC (label), 0, 0);
	_box_pack_start (_BOX (box1), label, FALSE, FALSE, 0);
	_widget_show (label);

	/* 參數是: homogeneous, spacing, expand, fill, padding */
	box2 = make_box (TRUE, 0, TRUE, FALSE, 0);
	_box_pack_start (_BOX (box1), box2, FALSE, FALSE, 0);
	_widget_show (box2);

	/* 參數是: homogeneous, spacing, expand, fill, padding */
	box2 = make_box (TRUE, 0, TRUE, TRUE, 0);
	_box_pack_start (_BOX (box1), box2, FALSE, FALSE, 0);
	_widget_show (box2);

	/* 另一個新分隔線。 */
	separator = _hseparator_new ();
	/* _box_pack_start的最後三個參數是:expand, fill, padding. */
	_box_pack_start (_BOX (box1), separator, FALSE, TRUE, 5);
	_widget_show (separator);

	break;

    case 2:

	/* 創建一個新標籤,記住 box1 是一個縱向盒,它在 main() 前面部分創建 */
	label = _label_new ("_hbox_new (FALSE, 10);");
	_misc_set_alignment (_MISC (label), 0, 0);
	_box_pack_start (_BOX (box1), label, FALSE, FALSE, 0);
	_widget_show (label);

	/* 參數是: homogeneous, spacing, expand, fill, padding */
	box2 = make_box (FALSE, 10, TRUE, FALSE, 0);
	_box_pack_start (_BOX (box1), box2, FALSE, FALSE, 0);
	_widget_show (box2);

	/* 參數是: homogeneous, spacing, expand, fill, padding */
	box2 = make_box (FALSE, 10, TRUE, TRUE, 0);
	_box_pack_start (_BOX (box1), box2, FALSE, FALSE, 0);
	_widget_show (box2);

	separator = _hseparator_new ();
	 /* _box_pack_start的最後三個參數是:expand, fill, padding. */
	_box_pack_start (_BOX (box1), separator, FALSE, TRUE, 5);
	_widget_show (separator);

	label = _label_new ("_hbox_new (FALSE, 0);");
	_misc_set_alignment (_MISC (label), 0, 0);
	_box_pack_start (_BOX (box1), label, FALSE, FALSE, 0);
	_widget_show (label);

	/* 參數是: homogeneous, spacing, expand, fill, padding */
	box2 = make_box (FALSE, 0, TRUE, FALSE, 10);
	_box_pack_start (_BOX (box1), box2, FALSE, FALSE, 0);
	_widget_show (box2);

	/* 參數是: homogeneous, spacing, expand, fill, padding */
	box2 = make_box (FALSE, 0, TRUE, TRUE, 10);
	_box_pack_start (_BOX (box1), box2, FALSE, FALSE, 0);
	_widget_show (box2);

	separator = _hseparator_new ();
	/* _box_pack_start的最後三個參數是: expand, fill, padding。 */
	_box_pack_start (_BOX (box1), separator, FALSE, TRUE, 5);
	_widget_show (separator);
	break;

    case 3:

        /* 這個範例了用 _box_pack_end() 來右對齊元   
         * 件的能力。首先,我們像前面一樣創建一個新盒。 */
	box2 = make_box (FALSE, 0, FALSE, FALSE, 0);

	/* 創建將放在末端的標籤。 */
	label = _label_new ("end");
	 /* 用 _box_pack_end()封裝它,這樣它被放到   
          * 在make_box()呼叫裡創建的橫向盒的右端。 */
	_box_pack_end (_BOX (box2), label, FALSE, FALSE, 0);
	/* 顯示標籤。 */
	_widget_show (label);

	/* 將 box2 封裝進 box1 (vbox記得嗎? :) */
	_box_pack_start (_BOX (box1), box2, FALSE, FALSE, 0);
	_widget_show (box2);

	/* 放在底部的分隔線。 */
	separator = _hseparator_new ();
	/* 這個明確地設置分隔線的寬度為400像素點和5像素點高。這樣我們創建   
         * 的橫向盒也將為400像素點寬,並且"end"標籤將和橫向盒裡其它的標籤   
         * 分開。否則,橫向盒裡的所有元件將儘量緊密地封裝在一起。 */
	_widget_set_size_request (separator, 400, 5);
	/* 將分隔線封裝到在main()前面部分創建的縱向盒(box1)裡。 */
	_box_pack_start (_BOX (box1), separator, FALSE, TRUE, 5);
	_widget_show (separator);    
    }

    /* 創建另一個新的橫向盒.. 記住我們要用多少就能用多少! */
    quitbox = _hbox_new (FALSE, 0);

   /* 退出按鈕。 */
    button = _button_new_with_label ("Quit");

   /* 設置這個信號以在按鈕被點擊時終止程式 */
    g_signal_connect_swapped (button, "clicked",
			      G_CALLBACK (_main_quit),
			      window);
    /* 將按鈕封裝進quitbox。   
     * _box_pack_start的最後三個參數是:expand, fill, padding. */
    _box_pack_start (_BOX (quitbox), button, TRUE, FALSE, 0);
    /* pack the quitbox into the vbox (box1) */
    _box_pack_start (_BOX (box1), quitbox, FALSE, FALSE, 0);

    /* 將現在包含了我們所有元件的縱向盒(box1)封裝進主視窗。 */
    _container_add (_CONTAINER (window), box1);

    /* 並顯示剩下的所有東西 */
    _widget_show (button);
    _widget_show (quitbox);

    _widget_show (box1);
     /* 最後顯示視窗,這樣所有東西可以立刻出現。 */
    _widget_show (window);

    /* 當然,還有我們的主函式。 */
    _main ();

    /* 當 _main_quit() 被呼叫時控制權(Control)返回到   
     * 這裡,但當exit()被使用時並不會。 */

    return 0;
}
« 
單元首頁
 »
Print Friendly, PDF & Email
馬上成為工作達人的Fans

About ㄚ琪

工作達人Fun Taiwan的創辦者及總編,可以在這裡更認識他。

One comment

發表迴響

你的電子郵件位址並不會被公開。 Required fields are marked *

*

這個網站採用 Akismet 服務減少垃圾留言。進一步瞭解 Akismet 如何處理網站訪客的留言資料

Scroll To Top