qmessagebox.3qt - Man Page
Modal dialog with a short message, an icon, and some buttons
Synopsis
#include <qmessagebox.h>
Inherits QDialog.
Public Members
enum Icon { NoIcon = 0, Information = 1, Warning = 2, Critical = 3, Question = 4 }
QMessageBox ( QWidget * parent = 0, const char * name = 0 )
QMessageBox ( const QString & caption, const QString & text, Icon icon, int button0, int button1, int button2, QWidget * parent = 0, const char * name = 0, bool modal = TRUE, WFlags f = WStyle_DialogBorder )
~QMessageBox ()
QString text () const
void setText ( const QString & )
Icon icon () const
void setIcon ( Icon )
const QPixmap * iconPixmap () const
void setIconPixmap ( const QPixmap & )
QString buttonText ( int button ) const
void setButtonText ( int button, const QString & text )
virtual void adjustSize ()
TextFormat textFormat () const
void setTextFormat ( TextFormat )
Static Public Members
int information ( QWidget * parent, const QString & caption, const QString & text, int button0, int button1 = 0, int button2 = 0 )
int information ( QWidget * parent, const QString & caption, const QString & text, const QString & button0Text = QString::null, const QString & button1Text = QString::null, const QString & button2Text = QString::null, int defaultButtonNumber = 0, int escapeButtonNumber = -1 )
int question ( QWidget * parent, const QString & caption, const QString & text, int button0, int button1 = 0, int button2 = 0 )
int question ( QWidget * parent, const QString & caption, const QString & text, const QString & button0Text = QString::null, const QString & button1Text = QString::null, const QString & button2Text = QString::null, int defaultButtonNumber = 0, int escapeButtonNumber = -1 )
int warning ( QWidget * parent, const QString & caption, const QString & text, int button0, int button1, int button2 = 0 )
int warning ( QWidget * parent, const QString & caption, const QString & text, const QString & button0Text = QString::null, const QString & button1Text = QString::null, const QString & button2Text = QString::null, int defaultButtonNumber = 0, int escapeButtonNumber = -1 )
int critical ( QWidget * parent, const QString & caption, const QString & text, int button0, int button1, int button2 = 0 )
int critical ( QWidget * parent, const QString & caption, const QString & text, const QString & button0Text = QString::null, const QString & button1Text = QString::null, const QString & button2Text = QString::null, int defaultButtonNumber = 0, int escapeButtonNumber = -1 )
void about ( QWidget * parent, const QString & caption, const QString & text )
void aboutQt ( QWidget * parent, const QString & caption = QString::null )
int message ( const QString & caption, const QString & text, const QString & buttonText = QString::null, QWidget * parent = 0, const char * = 0 ) (obsolete)
bool query ( const QString & caption, const QString & text, const QString & yesButtonText = QString::null, const QString & noButtonText = QString::null, QWidget * parent = 0, const char * = 0 ) (obsolete)
QPixmap standardIcon ( Icon icon, GUIStyle style ) (obsolete)
QPixmap standardIcon ( Icon icon )
Properties
Icon icon - the message box's icon
QPixmap iconPixmap - the current icon
QString text - the message box text to be displayed
TextFormat textFormat - the format of the text displayed by the message box
Description
The QMessageBox class provides a modal dialog with a short message, an icon, and some buttons.
Message boxes are used to provide informative messages and to ask simple questions.
QMessageBox provides a range of different messages, arranged roughly along two axes: severity and complexity.
Severity is <center>.nf </center>
The message box has a different icon for each of the severity levels.
Complexity is one button (OK) for simple messages, or two or even three buttons for questions.
There are static functions for the most common cases.
Examples:
If a program is unable to find a supporting file, but can do perfectly well without it:
QMessageBox::information( this, "Application name", "Unable to find the user preferences file.\n" "The factory default will be used instead." );
question() is useful for simple yes/no questions:
if ( QFile::exists( filename ) && QMessageBox::question( this, tr("Overwrite File? -- Application Name"), tr("A file called %1 already exists." "Do you want to overwrite it?") .arg( filename ), tr("&Yes"), tr("&No"), QString::null, 0, 1 ) ) return false;
warning() can be used to tell the user about unusual errors, or errors which can't be easily fixed:
switch( QMessageBox::warning( this, "Application name", "Could not connect to the <mumble> server.\n" "This program can't function correctly " "without the server.\n\n", "Retry", "Quit", 0, 0, 1 ) ) { case 0: // The user clicked the Retry again button or pressed Enter // try again break; case 1: // The user clicked the Quit or pressed Escape // exit break; }
The text part of all message box messages can be either rich text or plain text. If you specify a rich text formatted string, it will be rendered using the default stylesheet. See QStyleSheet::defaultSheet() for details. With certain strings that contain XML meta characters, the auto-rich text detection may fail, interpreting plain text incorrectly as rich text. In these rare cases, use QStyleSheet::convertFromPlainText() to convert your plain text string to a visually equivalent rich text string or set the text format explicitly with setTextFormat().
Note that the Microsoft Windows User Interface Guidelines recommend using the application name as the window's caption.
Below are more examples of how to use the static member functions. After these examples you will find an overview of the non-static member functions.
Exiting a program is part of its normal operation. If there is unsaved data the user probably should be asked if they want to save the data. For example:
switch( QMessageBox::information( this, "Application name here", "The document contains unsaved changes\n" "Do you want to save the changes before exiting?", "&Save", "&Discard", "Cancel", 0, // Enter == button 0 2 ) ) { // Escape == button 2 case 0: // Save clicked or Alt+S pressed or Enter pressed. // save break; case 1: // Discard clicked or Alt+D pressed // don't save but exit break; case 2: // Cancel clicked or Escape pressed // don't exit break; }
The Escape button cancels the entire exit operation, and pressing Enter causes the changes to be saved before the exit occurs.
Disk full errors are unusual and they certainly can be hard to correct. This example uses predefined buttons instead of hard-coded button texts:
switch( QMessageBox::warning( this, "Application name here", "Could not save the user preferences,\n" "because the disk is full. You can delete\n" "some files and press Retry, or you can\n" "abort the Save Preferences operation.", QMessageBox::Retry | QMessageBox::Default, QMessageBox::Abort | QMessageBox::Escape )) { case QMessageBox::Retry: // Retry clicked or Enter pressed // try again break; case QMessageBox::Abort: // Abort clicked or Escape pressed // abort break; }
The critical() function should be reserved for critical errors. In this example errorDetails is a QString or const char*, and QString is used to concatenate several strings:
QMessageBox::critical( 0, "Application name here", QString("An internal error occurred. Please ") + "call technical support at 1234-56789 and report\n"+ "these numbers:\n\n" + errorDetails + "\n\nApplication will now exit." );
In this example an OK button is displayed.
QMessageBox provides a very simple About box which displays an appropriate icon and the string you provide:
QMessageBox::about( this, "About <Application>", "<Application> is a <one-paragraph blurb>\n\n" "Copyright 1991-2003 Such-and-such. " "<License words here.>\n\n" "For technical support, call 1234-56789 or see\n" "http://www.such-and-such.com/Application/\n" );
See about() for more information.
If you want your users to know that the application is built using Qt (so they know that you use high quality tools) you might like to add an "About Qt" menu option under the Help menu to invoke aboutQt().
If none of the standard message boxes is suitable, you can create a QMessageBox from scratch and use custom button texts:
QMessageBox mb( "Application name here", "Saving the file will overwrite the original file on the disk.\n" "Do you really want to save?", QMessageBox::Information, QMessageBox::Yes | QMessageBox::Default, QMessageBox::No, QMessageBox::Cancel | QMessageBox::Escape ); mb.setButtonText( QMessageBox::Yes, "Save" ); mb.setButtonText( QMessageBox::No, "Discard" ); switch( mb.exec() ) { case QMessageBox::Yes: // save and exit break; case QMessageBox::No: // exit without saving break; case QMessageBox::Cancel: // don't save and don't exit break; }
QMessageBox defines two enum types: Icon and an unnamed button type. Icon defines the Question, Information, Warning, and Critical icons for each GUI style. It is used by the constructor and by the static member functions question(), information(), warning() and critical(). A function called standardIcon() gives you access to the various icons.
The button types are:
Ok - the default for single-button message boxes
Cancel - note that this is not automatically Escape
Yes
No
Abort
Retry
Ignore
YesAll
NoAll
Button types can be combined with two modifiers by using OR, '|':
Default - makes pressing Enter equivalent to clicking this button. Normally used with Ok, Yes or similar.
Escape - makes pressing Escape equivalent to clicking this button. Normally used with Abort, Cancel or similar.
The text(), icon() and iconPixmap() functions provide access to the current text and pixmap of the message box. The setText(), setIcon() and setIconPixmap() let you change it. The difference between setIcon() and setIconPixmap() is that the former accepts a QMessageBox::Icon and can be used to set standard icons, whereas the latter accepts a QPixmap and can be used to set custom icons.
setButtonText() and buttonText() provide access to the buttons.
QMessageBox has no signals or slots.
[Image Omitted]
[Image Omitted]
See also QDialog, Isys on error messages, GUI Design Handbook: Message Box, and Dialog Classes.
Member Type Documentation
QMessageBox::Icon
This enum has the following values:
QMessageBox::NoIcon
- the message box does not have any icon.
QMessageBox::Question
- an icon indicating that the message is asking a question.
QMessageBox::Information
- an icon indicating that the message is nothing out of the ordinary.
QMessageBox::Warning
- an icon indicating that the message is a warning, but can be dealt with.
QMessageBox::Critical
- an icon indicating that the message represents a critical problem.
Member Function Documentation
QMessageBox::QMessageBox ( QWidget * parent = 0, const char * name = 0 )
Constructs a message box with no text and a button with the label" OK".
If parent is 0, the message box becomes an application-global modal dialog box. If parent is a widget, the message box becomes modal relative to parent.
The parent and name arguments are passed to the QDialog constructor.
QMessageBox::~QMessageBox ()
Destroys the message box.
void QMessageBox::about ( QWidget * parent, const QString & caption, const QString & text ) [static]
Displays a simple about box with caption caption and text text. The about box's parent is parent.
about() looks for a suitable icon in four locations: <ol type=1>
It prefers parent->icon() if that exists.
If not, it tries the top-level widget containing parent.
If that fails, it tries the main widget.
As a last resort it uses the Information icon.
The about box has a single button labelled "OK".
See also QWidget::icon and QApplication::mainWidget().
Examples:
void QMessageBox::aboutQt ( QWidget * parent, const QString & caption = QString::null ) [static]
Displays a simple message box about Qt, with caption caption and centered over parent (if parent is not 0). The message includes the version number of Qt being used by the application.
This is useful for inclusion in the Help menu of an application. See the examples/menu/menu.cpp example.
QApplication provides this functionality as a slot.
See also QApplication::aboutQt().
Examples:
void QMessageBox::adjustSize () [virtual]
Adjusts the size of the message box to fit the contents just before QDialog::exec() or QDialog::show() is called.
This function will not be called if the message box has been explicitly resized before showing it.
Reimplemented from QWidget.
Icon QMessageBox::icon () const
Returns the message box's icon. See the "icon" property for details.
const QPixmap * QMessageBox::iconPixmap () const
Returns the current icon. See the "iconPixmap" property for details.
bool QMessageBox::query ( const QString & caption, const QString & text, const QString & yesButtonText = QString::null, const QString & noButtonText = QString::null, QWidget * parent = 0, const char * = 0 ) [static]
This function is obsolete. It is provided to keep old source working. We strongly advise against using it in new code.
Queries the user using a modal message box with two buttons. Note that caption is not always shown, it depends on the window manager.
Please use information(), question(), warning(), or critical() instead.
void QMessageBox::setIcon ( Icon )
Sets the message box's icon. See the "icon" property for details.
void QMessageBox::setIconPixmap ( const QPixmap & )
Sets the current icon. See the "iconPixmap" property for details.
void QMessageBox::setText ( const QString & )
Sets the message box text to be displayed. See the "text" property for details.
void QMessageBox::setTextFormat ( TextFormat )
Sets the format of the text displayed by the message box. See the "textFormat" property for details.
QPixmap QMessageBox::standardIcon ( Icon icon ) [static]
Returns the pixmap used for a standard icon. This allows the pixmaps to be used in more complex message boxes. icon specifies the required icon, e.g. QMessageBox::Question, QMessageBox::Information, QMessageBox::Warning or QMessageBox::Critical.
QPixmap QMessageBox::standardIcon ( Icon icon, GUIStyle style ) [static]
This function is obsolete. It is provided to keep old source working. We strongly advise against using it in new code.
Returns the pixmap used for a standard icon. This allows the pixmaps to be used in more complex message boxes. icon specifies the required icon, e.g. QMessageBox::Information, QMessageBox::Warning or QMessageBox::Critical.
style is unused.
QString QMessageBox::text () const
Returns the message box text to be displayed. See the "text" property for details.
TextFormat QMessageBox::textFormat () const
Returns the format of the text displayed by the message box. See the "textFormat" property for details.
Icon icon
This property holds the message box's icon.
The icon of the message box can be one of the following predefined icons:
QMessageBox::NoIcon
QMessageBox::Question
QMessageBox::Information
QMessageBox::Warning
QMessageBox::Critical
The actual pixmap used for displaying the icon depends on the current GUI style. You can also set a custom pixmap icon using the QMessageBox::iconPixmap property. The default icon is QMessageBox::NoIcon.
See also iconPixmap.
Set this property's value with setIcon() and get this property's value with icon().
QPixmap iconPixmap
This property holds the current icon.
The icon currently used by the message box. Note that it's often hard to draw one pixmap that looks appropriate in both Motif and Windows GUI styles; you may want to draw two pixmaps.
See also icon.
Set this property's value with setIconPixmap() and get this property's value with iconPixmap().
QString text
This property holds the message box text to be displayed.
The text will be interpreted either as a plain text or as rich text, depending on the text format setting (QMessageBox::textFormat). The default setting is AutoText, i.e. the message box will try to auto-detect the format of the text.
The default value of this property is QString::null.
See also textFormat.
Set this property's value with setText() and get this property's value with text().
TextFormat textFormat
This property holds the format of the text displayed by the message box.
The current text format used by the message box. See the Qt::TextFormat enum for an explanation of the possible options.
The default format is AutoText.
See also text.
Set this property's value with setTextFormat() and get this property's value with textFormat().
See Also
http://doc.trolltech.com/qmessagebox.html http://www.trolltech.com/faq/tech.html
Copyright
Copyright 1992-2007 Trolltech ASA, http://www.trolltech.com. See the license file included in the distribution for a complete license statement.
Author
Generated automatically from the source code.
Bugs
If you find a bug in Qt, please report it as described in http://doc.trolltech.com/bughowto.html. Good bug reports help us to help you. Thank you.
The definitive Qt documentation is provided in HTML format; it is located at $QTDIR/doc/html and can be read using Qt Assistant or with a web browser. This man page is provided as a convenience for those users who prefer man pages, although this format is not officially supported by Trolltech.
If you find errors in this manual page, please report them to qt-bugs@trolltech.com. Please include the name of the manual page (qmessagebox.3qt) and the Qt version (3.3.8).
Referenced By
The man page QMessageBox.3qt(3) is an alias of qmessagebox.3qt(3).