don't use dynamic handlers for standard buttons as this prevents static event handlers in derived classes from working; just catch all button events in a static handler instead
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@40708 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -41,7 +41,7 @@ public:
|
|||||||
wxDialogBase() { Init(); }
|
wxDialogBase() { Init(); }
|
||||||
virtual ~wxDialogBase() { }
|
virtual ~wxDialogBase() { }
|
||||||
|
|
||||||
// public wxDialog API, to be implemented by the derived classes
|
// define public wxDialog methods to be implemented by the derived classes
|
||||||
virtual int ShowModal() = 0;
|
virtual int ShowModal() = 0;
|
||||||
virtual void EndModal(int retCode) = 0;
|
virtual void EndModal(int retCode) = 0;
|
||||||
virtual bool IsModal() const = 0;
|
virtual bool IsModal() const = 0;
|
||||||
@@ -121,9 +121,7 @@ private:
|
|||||||
void OnCloseWindow(wxCloseEvent& event);
|
void OnCloseWindow(wxCloseEvent& event);
|
||||||
|
|
||||||
// handle the standard buttons
|
// handle the standard buttons
|
||||||
void OnAffirmativeButton(wxCommandEvent& event);
|
void OnButton(wxCommandEvent& event);
|
||||||
void OnApply(wxCommandEvent& event);
|
|
||||||
void OnCancelButton(wxCommandEvent& event);
|
|
||||||
|
|
||||||
// update the background colour
|
// update the background colour
|
||||||
void OnSysColourChanged(wxSysColourChangedEvent& event);
|
void OnSysColourChanged(wxSysColourChangedEvent& event);
|
||||||
|
@@ -99,9 +99,7 @@ private:
|
|||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
BEGIN_EVENT_TABLE(wxDialogBase, wxTopLevelWindow)
|
BEGIN_EVENT_TABLE(wxDialogBase, wxTopLevelWindow)
|
||||||
EVT_BUTTON(wxID_OK, wxDialogBase::OnAffirmativeButton)
|
EVT_BUTTON(wxID_ANY, wxDialogBase::OnButton)
|
||||||
EVT_BUTTON(wxID_APPLY, wxDialogBase::OnApply)
|
|
||||||
EVT_BUTTON(wxID_CANCEL, wxDialogBase::OnCancelButton)
|
|
||||||
|
|
||||||
EVT_CLOSE(wxDialogBase::OnCloseWindow)
|
EVT_CLOSE(wxDialogBase::OnCloseWindow)
|
||||||
|
|
||||||
@@ -427,85 +425,35 @@ wxStdDialogButtonSizer *wxDialogBase::CreateStdDialogButtonSizer( long flags )
|
|||||||
#endif // wxUSE_BUTTON
|
#endif // wxUSE_BUTTON
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// escape/affirmatives button handling
|
// standard buttons handling
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
void wxDialogBase::EndDialog(int rc)
|
||||||
|
{
|
||||||
|
if ( IsModal() )
|
||||||
|
EndModal(rc);
|
||||||
|
else
|
||||||
|
Hide();
|
||||||
|
}
|
||||||
|
|
||||||
void wxDialogBase::AcceptAndClose()
|
void wxDialogBase::AcceptAndClose()
|
||||||
{
|
{
|
||||||
if ( Validate() && TransferDataFromWindow() )
|
if ( Validate() && TransferDataFromWindow() )
|
||||||
{
|
{
|
||||||
EndDialog(wxID_OK);
|
EndDialog(m_affirmativeId);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxDialogBase::SetAffirmativeId(int affirmativeId)
|
void wxDialogBase::SetAffirmativeId(int affirmativeId)
|
||||||
{
|
{
|
||||||
if ( affirmativeId == m_affirmativeId )
|
|
||||||
return;
|
|
||||||
|
|
||||||
// disconnect the handler for the old affirmative button
|
|
||||||
if ( m_affirmativeId != wxID_NONE && m_affirmativeId != wxID_OK )
|
|
||||||
{
|
|
||||||
if ( !Disconnect
|
|
||||||
(
|
|
||||||
m_affirmativeId,
|
|
||||||
wxEVT_COMMAND_BUTTON_CLICKED,
|
|
||||||
wxCommandEventHandler(wxDialogBase::OnAffirmativeButton)
|
|
||||||
) )
|
|
||||||
{
|
|
||||||
wxFAIL_MSG( _T("failed to disconnect old ok handler") );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
//else: wxID_OK is always handled
|
|
||||||
|
|
||||||
m_affirmativeId = affirmativeId;
|
m_affirmativeId = affirmativeId;
|
||||||
|
|
||||||
// connect the handler to the new button
|
|
||||||
if ( m_affirmativeId != wxID_NONE )
|
|
||||||
{
|
|
||||||
Connect(m_affirmativeId,
|
|
||||||
wxEVT_COMMAND_BUTTON_CLICKED,
|
|
||||||
wxCommandEventHandler(wxDialogBase::OnAffirmativeButton));
|
|
||||||
}
|
|
||||||
//else: no affirmative button
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxDialogBase::SetEscapeId(int escapeId)
|
void wxDialogBase::SetEscapeId(int escapeId)
|
||||||
{
|
{
|
||||||
if ( escapeId == m_escapeId )
|
|
||||||
return;
|
|
||||||
|
|
||||||
if ( m_escapeId != wxID_ANY &&
|
|
||||||
m_escapeId != wxID_CANCEL &&
|
|
||||||
m_escapeId != wxID_ANY )
|
|
||||||
{
|
|
||||||
if ( !Disconnect
|
|
||||||
(
|
|
||||||
m_escapeId,
|
|
||||||
wxEVT_COMMAND_BUTTON_CLICKED,
|
|
||||||
wxCommandEventHandler(wxDialogBase::OnCancelButton)
|
|
||||||
) )
|
|
||||||
{
|
|
||||||
wxFAIL_MSG( _T("failed to disconnect old cancel handler") );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
//else: wxID_CANCEL is always handled
|
|
||||||
|
|
||||||
m_escapeId = escapeId;
|
m_escapeId = escapeId;
|
||||||
|
|
||||||
// connect the handler to the new button
|
|
||||||
if ( m_escapeId != wxID_NONE )
|
|
||||||
{
|
|
||||||
Connect(m_escapeId,
|
|
||||||
wxEVT_COMMAND_BUTTON_CLICKED,
|
|
||||||
wxCommandEventHandler(wxDialogBase::OnCancelButton));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// event handling stuff
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
bool wxDialogBase::EmulateButtonClickIfPresent(int id)
|
bool wxDialogBase::EmulateButtonClickIfPresent(int id)
|
||||||
{
|
{
|
||||||
wxButton *btn = wxDynamicCast(FindWindow(id), wxButton);
|
wxButton *btn = wxDynamicCast(FindWindow(id), wxButton);
|
||||||
@@ -520,14 +468,6 @@ bool wxDialogBase::EmulateButtonClickIfPresent(int id)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxDialogBase::EndDialog(int rc)
|
|
||||||
{
|
|
||||||
if ( IsModal() )
|
|
||||||
EndModal(rc);
|
|
||||||
else
|
|
||||||
Hide();
|
|
||||||
}
|
|
||||||
|
|
||||||
bool wxDialogBase::IsEscapeKey(const wxKeyEvent& event)
|
bool wxDialogBase::IsEscapeKey(const wxKeyEvent& event)
|
||||||
{
|
{
|
||||||
// for most platforms, Esc key is used to close the dialogs
|
// for most platforms, Esc key is used to close the dialogs
|
||||||
@@ -564,23 +504,34 @@ void wxDialogBase::OnCharHook(wxKeyEvent& event)
|
|||||||
event.Skip();
|
event.Skip();
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxDialogBase::OnAffirmativeButton(wxCommandEvent& WXUNUSED(event))
|
void wxDialogBase::OnButton(wxCommandEvent& event)
|
||||||
{
|
{
|
||||||
AcceptAndClose();
|
const int id = event.GetId();
|
||||||
|
if ( id == GetAffirmativeId() )
|
||||||
|
{
|
||||||
|
AcceptAndClose();
|
||||||
|
}
|
||||||
|
else if ( id == wxID_APPLY )
|
||||||
|
{
|
||||||
|
if ( Validate() )
|
||||||
|
TransferDataFromWindow();
|
||||||
|
|
||||||
|
// TODO: disable the Apply button until things change again
|
||||||
|
}
|
||||||
|
else if ( id == GetEscapeId() ||
|
||||||
|
(id == wxID_CANCEL && GetEscapeId() == wxID_ANY) )
|
||||||
|
{
|
||||||
|
EndDialog(wxID_CANCEL);
|
||||||
|
}
|
||||||
|
else // not a standard button
|
||||||
|
{
|
||||||
|
event.Skip();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxDialogBase::OnApply(wxCommandEvent& WXUNUSED(event))
|
// ----------------------------------------------------------------------------
|
||||||
{
|
// other event handlers
|
||||||
if ( Validate() )
|
// ----------------------------------------------------------------------------
|
||||||
TransferDataFromWindow();
|
|
||||||
|
|
||||||
// TODO probably need to disable the Apply button until things change again
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxDialogBase::OnCancelButton(wxCommandEvent& WXUNUSED(event))
|
|
||||||
{
|
|
||||||
EndDialog(wxID_CANCEL);
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxDialogBase::OnCloseWindow(wxCloseEvent& WXUNUSED(event))
|
void wxDialogBase::OnCloseWindow(wxCloseEvent& WXUNUSED(event))
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user