您可以建立具備影像及文字的按鈕,最基本的方式可以透過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;
}
執行的結果畫面如下所示: