make msg boxes without parent owned by top level app window
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@8511 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -46,7 +46,8 @@ wxMessageDialog::wxMessageDialog(wxWindow *parent,
|
|||||||
|
|
||||||
int wxMessageDialog::ShowModal()
|
int wxMessageDialog::ShowModal()
|
||||||
{
|
{
|
||||||
if ( !wxTheApp->GetTopWindow() )
|
wxWindow *winTop = wxTheApp->GetTopWindow();
|
||||||
|
if ( !winTop )
|
||||||
{
|
{
|
||||||
// when the message box is shown from wxApp::OnInit() (i.e. before the
|
// when the message box is shown from wxApp::OnInit() (i.e. before the
|
||||||
// message loop is entered), this must be done or the next message box
|
// message loop is entered), this must be done or the next message box
|
||||||
@@ -56,8 +57,14 @@ int wxMessageDialog::ShowModal()
|
|||||||
wxTheApp->Dispatch();
|
wxTheApp->Dispatch();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// use the top level window as parent if none specified
|
||||||
HWND hWnd = 0;
|
HWND hWnd = 0;
|
||||||
if (m_parent) hWnd = (HWND) m_parent->GetHWND();
|
if ( m_parent )
|
||||||
|
hWnd = GetHwndOf(m_parent);
|
||||||
|
else if ( winTop )
|
||||||
|
hWnd = GetHwndOf(winTop);
|
||||||
|
|
||||||
|
// translate wx style in MSW
|
||||||
unsigned int msStyle = MB_OK;
|
unsigned int msStyle = MB_OK;
|
||||||
if (m_dialogStyle & wxYES_NO)
|
if (m_dialogStyle & wxYES_NO)
|
||||||
{
|
{
|
||||||
@@ -91,11 +98,15 @@ int wxMessageDialog::ShowModal()
|
|||||||
else
|
else
|
||||||
msStyle |= MB_TASKMODAL;
|
msStyle |= MB_TASKMODAL;
|
||||||
|
|
||||||
int msAns = MessageBox(hWnd, (LPCTSTR)m_message.c_str(),
|
// do show the dialog
|
||||||
(LPCTSTR)m_caption.c_str(), msStyle);
|
int msAns = MessageBox(hWnd, m_message.c_str(), m_caption.c_str(), msStyle);
|
||||||
int ans = wxOK;
|
int ans;
|
||||||
switch (msAns)
|
switch (msAns)
|
||||||
{
|
{
|
||||||
|
default:
|
||||||
|
wxFAIL_MSG(_T("unexpected ::MessageBox() return code"));
|
||||||
|
// fall through
|
||||||
|
|
||||||
case IDCANCEL:
|
case IDCANCEL:
|
||||||
ans = wxID_CANCEL;
|
ans = wxID_CANCEL;
|
||||||
break;
|
break;
|
||||||
|
Reference in New Issue
Block a user