Improve main and extended messages handling in new wxMSW wxMessageDialog.
Don't use the main message if there is no extended message: this looks bad as the main message is emphasized to contrast with the extended one which doesn't make sense visually if there is no extended message. Also recognize the common use of wxMessageBox() with a multiline text composed of the first string that plays the role of the main message with the rest being the extended one and handle this appropriately automatically. This results in a better appearance by default for a lot of message boxes, including even the one in our own minimal sample. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@65466 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
b8737371e2
commit
aebe0d3b6c
@ -623,6 +623,28 @@ wxMSWTaskDialogConfig::wxMSWTaskDialogConfig(const wxMessageDialogBase& dlg)
|
||||
caption = dlg.GetCaption();
|
||||
message = dlg.GetMessage();
|
||||
extendedMessage = dlg.GetExtendedMessage();
|
||||
|
||||
// Before wxMessageDialog added support for extended message it was common
|
||||
// practice to have long multiline texts in the message box with the first
|
||||
// line playing the role of the main message and the rest of the extended
|
||||
// one. Try to detect such usage automatically here by synthesizing the
|
||||
// extended message on our own if it wasn't given.
|
||||
if ( extendedMessage.empty() )
|
||||
{
|
||||
// Check if there is a blank separating line after the first line (this
|
||||
// is not the same as searching for "\n\n" as we want the automatically
|
||||
// recognized main message be single line to avoid embarrassing false
|
||||
// positives).
|
||||
const size_t posNL = message.find('\n');
|
||||
if ( posNL != wxString::npos &&
|
||||
posNL < message.length() - 1 &&
|
||||
message[posNL + 1 ] == '\n' )
|
||||
{
|
||||
extendedMessage.assign(message, posNL + 2, wxString::npos);
|
||||
message.erase(posNL);
|
||||
}
|
||||
}
|
||||
|
||||
iconId = dlg.GetEffectiveIcon();
|
||||
style = dlg.GetMessageDialogStyle();
|
||||
useCustomLabels = dlg.HasCustomLabels();
|
||||
@ -643,8 +665,23 @@ void wxMSWTaskDialogConfig::MSWCommonTaskDialogInit(TASKDIALOGCONFIG &tdc)
|
||||
|
||||
if ( wxTheApp->GetLayoutDirection() == wxLayout_RightToLeft )
|
||||
tdc.dwFlags |= TDF_RTL_LAYOUT;
|
||||
tdc.pszMainInstruction = message.wx_str();
|
||||
tdc.pszContent = extendedMessage.wx_str();
|
||||
|
||||
// If we have both the main and extended messages, just use them as
|
||||
// intended. However if only one message is given we normally use it as the
|
||||
// content and not as the main instruction because the latter is supposed
|
||||
// to stand out compared to the former and doesn't look good if there is
|
||||
// nothing for it to contrast with. Finally, notice that the extended
|
||||
// message we use here might be automatically extracted from the main
|
||||
// message in our ctor, see comment there.
|
||||
if ( !extendedMessage.empty() )
|
||||
{
|
||||
tdc.pszMainInstruction = message.wx_str();
|
||||
tdc.pszContent = extendedMessage.wx_str();
|
||||
}
|
||||
else
|
||||
{
|
||||
tdc.pszContent = message.wx_str();
|
||||
}
|
||||
|
||||
// set an icon to be used, if possible
|
||||
switch ( iconId )
|
||||
|
Loading…
Reference in New Issue
Block a user