qt5信息提示框QMessageBox用法

1.information

QMessageBox::information(NULL, "Title", "Content", 
                         QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes);

這是比較常用的一種用法,效果如下:

information原型:

StandardButton QMessageBox::information(QWidget * parent, const QString & title, const QString & text, StandardButtons buttons = Ok, StandardButton defaultButton = NoButton) [static]
  • 第一個參數是父控件指針
  • 第二個參數是標題
  • 第三個參數是內容
  • 第四個參數是窗口裏面要多少個按鈕(默認爲OK)
  • 第五個參數指定按下Enter時使用的按鈕。(默認爲NoButton,此時QMessageBox會自動選擇合適的默認值。)

示例1:

QMessageBox::information(NULL, "Title", "Content");

此時第四第五爲默認參數,效果

示例2:

QMessageBox::information(NULL, "Title", "Content",QMessageBox::Yes|QMessageBox::No);

此時效果:

示例三:

QMessageBox::information(NULL, "Title", "Content",QMessageBox::Yes|QMessageBox::No|QMessageBox::Abort);

添加多個按鈕用|運算符連接,效果:

按鈕類型參考:

enum StandardButton {
        // keep this in sync with QDialogButtonBox::StandardButton
        NoButton           = 0x00000000,
        Ok                 = 0x00000400,
        Save               = 0x00000800,
        SaveAll            = 0x00001000,
        Open               = 0x00002000,
        Yes                = 0x00004000,
        YesToAll           = 0x00008000,
        No                 = 0x00010000,
        NoToAll            = 0x00020000,
        Abort              = 0x00040000,
        Retry              = 0x00080000,
        Ignore             = 0x00100000,
        Close              = 0x00200000,
        Cancel             = 0x00400000,
        Discard            = 0x00800000,
        Help               = 0x01000000,
        Apply              = 0x02000000,
        Reset              = 0x04000000,
        RestoreDefaults    = 0x08000000,

        FirstButton        = Ok,                // internal
        LastButton         = RestoreDefaults,   // internal

        YesAll             = YesToAll,          // obsolete
        NoAll              = NoToAll,           // obsolete

        Default            = 0x00000100,        // obsolete
        Escape             = 0x00000200,        // obsolete
        FlagMask           = 0x00000300,        // obsolete
        ButtonMask         = ~FlagMask          // obsolete
    };

會創建消息提示框後,我們怎麼知道用戶點了什麼呢,看如下小例子:

QMessageBox:: StandardButton result= QMessageBox::information(NULL, "Title", "Content",QMessageBox::Yes|QMessageBox::No);
switch (result)
{
case QMessageBox::Yes:
    qDebug()<<"Yes";
    break;
case QMessageBox::No:
    qDebug()<<"NO";
    break;
default:
    break;
}

2.critical

critical adj. 關鍵的; 批評的,愛挑剔的; 嚴重的; 極重要的;

QMessageBox::critical(NULL, "critical", "Content", QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes);

效果:

3.warning

QMessageBox::warning(NULL, "warning", "Content", QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes);

效果:

4.question

QMessageBox::question(NULL, "question", "Content", QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes);

效果:

5.about

原型:static void about(QWidget *parent, const QString &title, const QString &text);

QMessageBox::about(NULL, "About", "by hjwblog.com");

效果:

6.使用QMessageBox對象

如果是自己創建的QMessageBox對象,而不是用上面的static函數

示例1:

void MainWindow::on_pushButton_clicked()
{
    QMessageBox messageBox;
    messageBox.show();
}

這裏在按鈕的clicked槽裏面創建了一個QMessageBox,但是這樣會出現消息框一閃而過。這是因爲c++局部變量的生命週期結束了,QMessageBox messageBox是函數局部變量,函數結束後它的生命週期也結束了。

示例2:

void MainWindow::on_pushButton_clicked()
{
    static QMessageBox messageBox;
    messageBox.show();
}

效果:

這樣就好理解了,c++函數裏面的static變量在函數結束時不會被回收。

示例3:

void MainWindow::on_pushButton_clicked()
{
    QMessageBox *messageBox=new QMessageBox;
    messageBox->show();
}

這樣寫也能顯示提示框,但是這樣會內存泄漏。

示例4:

前面的用法都不太完美,我們希望能方便的顯示提示框並且獲取用戶點擊了哪個按鈕。因爲QMessageBox繼承QDialog,而QDialog有一個神奇的函數exec(),調用這個函數後,消息循環會在這個函數裏面進行更新,而調用它的函數是被“暫停”的,就是說等用戶點擊按鈕後,調用exec()的函數才繼續執行。
直接上代碼:

void MainWindow::on_pushButton_clicked()
{
    QMessageBox messageBox(QMessageBox::NoIcon,
                           "退出", "你確定要退出嗎?",
                           QMessageBox::Yes | QMessageBox::No, NULL); ;
    int result=messageBox.exec();


    switch (result)
    {
    case QMessageBox::Yes:
        qDebug()<<"Yes";
        close();
        break;
    case QMessageBox::No:
        qDebug()<<"NO";
        break;
    default:
        break;
    }
}

上面的代碼實現了點擊按鈕退出,並且在退出前確定的功能。
exec()的返回值和前面的information()一樣,是整數(information()是枚舉)。可以通過返回值來確定用戶點擊了哪個按鈕。

QMessageBox對象調用exec()函數能實現與前面的幾個靜態函數相似的功能。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章