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:
Vadim Zeitlin
2006-08-20 14:02:51 +00:00
parent 3857173d3c
commit a9f620daf4
2 changed files with 38 additions and 89 deletions

View File

@@ -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);

View File

@@ -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))
{ {