GtkMessageDialog

本文转载自http://openhome.cc/Gossip/GTKGossip/GtkMessageDialog.html


在程式中常出現一些簡單的對話或訊息方塊,有GTK中,它們都是GtkDialog的子類,在這邊先介紹一些GTK內建的對話方塊,常見類型之一是GtkMessageDialog,首先看個簡單的範例,改寫 自 訂 callback 函式 中的例子,按下按鈕後會出現訊息方塊:

  • message_dialog_demo.c
#include <gtk/gtk.h>

void button_clicked(GtkWidget *button, gpointer data) {
    GtkWidget *dialog = gtk_message_dialog_new(GTK_WINDOW(data), 
                             GTK_DIALOG_MODAL, GTK_MESSAGE_INFO, 
                             GTK_BUTTONS_OK, "良葛格學習筆記");
    gtk_window_set_title(GTK_WINDOW(dialog), "GtkMessageDialog");
    gtk_message_dialog_format_secondary_text(
         GTK_MESSAGE_DIALOG(dialog), "http://caterpillar.onlyfun.net");
    gtk_dialog_run(GTK_DIALOG(dialog));
    gtk_widget_destroy(dialog);
}

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

    gtk_init(&argc, &argv);
    window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
    gtk_window_set_title(GTK_WINDOW(window), "GtkMessageDialog");

    button = gtk_button_new_with_label("按我");
    gtk_container_add(GTK_CONTAINER(window), button);

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

    gtk_widget_show(window);
    gtk_widget_show(button);

    gtk_main();

    return 0;
}

gtk_message_dialog_new()的宣告如下:
GtkWidget* gtk_message_dialog_new(GtkWindow *parent,
                                  GtkDialogFlags flags,
                                  GtkMessageType type,
                                  GtkButtonsType buttons,
                                  const gchar *message_format,
                                  ...);

設定parent,當訊息方塊是獨佔式(Modal)時,若不回應訊息方塊,則無法操作其父視窗,GtkDialogFlags則可以設定:
  • GTK_DIALOG_MODAL:設定為獨佔視窗。
  • GTK_DIALOG_DESTROY_WITH_PARENT:如果parent被銷毀,則一併銷毀對話方塊。
  • GTK_DIALOG_NO_SEPARATOR:在對話方塊中不出現分隔線,在 使用 GtkDialog 自訂對話方塊 中會再介紹。

GtkMessageType則指定這是哪個類型的訊息:
  • GTK_MESSAGE_INFO
  • GTK_MESSAGE_WARNING
  • GTK_MESSAGE_QUESTION
  • GTK_MESSAGE_ERROR
  • GTK_MESSAGE_OTHER
    
GtkButtonsType則可以設定幾個預設的按鈕類型:
  • GTK_BUTTONS_NONE
  • GTK_BUTTONS_OK
  • GTK_BUTTONS_CLOSE
  • GTK_BUTTONS_CANCEL
  • GTK_BUTTONS_YES_NO
  • GTK_BUTTONS_OK_CANCEL

message_format的設定,其實是類似printf()的字串格式,例如可以這麼設定:
GtkWidget *dialog = gtk_message_dialog_new(GTK_WINDOW(data), 
                             GTK_DIALOG_MODAL, GTK_MESSAGE_INFO, 
                             GTK_BUTTONS_OK, "%s 已刪除", filename);

要顯示對話方塊,方法之一是使用gtk_dialog_run(),這會將對話方塊以獨佔模式顯示,無論其GtkDialogFlags設定為何,因為這 會呼叫gtk_window_set_modal()函式,將對話方塊設定為獨佔模式,當回應對話方塊之後,您要使用 gtk_widget_destroy()銷毀對話方塊。

以下是一個執行時對話方塊的參考畫面:



gtk_dialog_run()結束後會傳回一個response id,為  GtkResponseType  的enum值,代表使用者按下的按鈕,如果對話方塊只是被關閉(按下X),則會傳回GTK_RESPONSE_NONE,您可以依這個傳回值來決定回應對話方塊後的下一步動作,例如GtkDialog的說明文件中有這麼一段範例程式:
 gint result = gtk_dialog_run (GTK_DIALOG (dialog));
 switch (result)
   {
     case GTK_RESPONSE_ACCEPT:
        do_application_specific_something ();
        break;
     default:
        do_nothing_since_dialog_was_cancelled ();
        break;
   }
 gtk_widget_destroy (dialog);

在软件开发中,经常会用到.ui文件来布局界面。下面给出一个GtkMessageDialog的.ui文件示例
<interface domain='gnome-logs'>
    <object class="GtkMessageDialog" id="system_journal_error_dialog">
        <property name="message-type">GTK_MESSAGE_ERROR</property>
        <property name="buttons">GTK_BUTTONS_CLOSE</property>
        <property name="text" translatable="yes">Unable to read system logs</property>
    </object>
    <object class="GtkMessageDialog" id="user_journal_error_dialog">
        <property name="message-type">GTK_MESSAGE_ERROR</property>
        <property name="buttons">GTK_BUTTONS_CLOSE</property>
        <property name="text" translatable="yes">Unable to read user logs</property>
    </object>
</interface>
然后通过以下两行代码
builder = gtk_builder_new_from_resource ("/org/gnome/Logs/gl-messagedialog.ui");
dialog = GTK_WIDGET (gtk_builder_get_object (builder, "system_journal_error_dialog"));
来构建dialog再进行相关的操作。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值