影像及文字按鈕


您可以建立具備影像及文字的按鈕,最基本的方式可以透過gtk_button_new_from_stock(),這可以讓您從GTK既有的影像資源中取用影像給按鈕使用,gtk_button_new_from_stock()使用時的參數與出現的影像,可在 Stock Items 查詢。

以實際的例子來說,將 自 訂 callback 函式 中的按鈕產生程式片段改為以下:
button = gtk_button_new_from_stock(GTK_STOCK_YES);

則程式執行時的參考畫面如下所示:



另一個為按鈕創立影像及文字的方式,是使用gtk_button_new()函式建立一個按鈕元件,利用 GtkHBox 與 GtkVBox 建立Box並內含圖片及文字,再將這個Box透過gtk_container_add()加入建立的按鈕元件之中,下面這個程式是一個簡單的示範:
  • button_with_image_demo.c
#include <gtk/gtk.h>

GtkWidget* buttonWithImage(gchar *filename, gchar *text) {
GtkWidget *box;
GtkWidget *label;
GtkWidget *image;

box = gtk_hbox_new(FALSE, 5);
gtk_container_set_border_width(GTK_CONTAINER(box), 2);

image = gtk_image_new_from_file(filename);
label = gtk_label_new(text);

gtk_box_pack_start(GTK_BOX(box), image, FALSE, FALSE, 5);
gtk_box_pack_start(GTK_BOX(box), label, FALSE, FALSE, 5);

gtk_widget_show (image);
gtk_widget_show (label);

return box;
}

int main(int argc, char *argv[]) {
GtkWidget *window;
GtkWidget *button;
GtkWidget *box;

gtk_init(&argc, &argv);
window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
gtk_window_set_title(GTK_WINDOW(window), "哈囉!GTK+!");
gtk_window_set_default_size(GTK_WINDOW(window), 200, 50);

button = gtk_button_new();
box = buttonWithImage("caterpillar.gif", "caterpillar");

gtk_container_add(GTK_CONTAINER(button), box);
gtk_container_add(GTK_CONTAINER(window), button);

g_signal_connect(GTK_OBJECT(window), "destroy",
G_CALLBACK(gtk_main_quit), NULL);

gtk_widget_show(window);
gtk_widget_show(button);
gtk_widget_show(box);

gtk_main();

return 0;
}

執行的結果畫面如下所示: