avoid conflict between wxBookCtrlBase::DoSetSelection() and the derived classes; refactor more common code into the base class
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@41843 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -222,22 +222,36 @@ public:
|
|||||||
virtual bool HasMultiplePages() const { return true; }
|
virtual bool HasMultiplePages() const { return true; }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
// typically, wxBookCtrl-derived classes will use DoSetSelection() function
|
// flags for DoSetSelection()
|
||||||
// to implement SetSelection() and ChangeSelection() functions.
|
|
||||||
// these flags make DoSetSelection() more readable
|
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
SetSelection_SendEvent = 1
|
SetSelection_SendEvent = 1
|
||||||
};
|
};
|
||||||
|
|
||||||
// if using DoSetSelection() for implementing [Set|Change]Selection,
|
// set the selection to the given page, sending the events (which can
|
||||||
// then override UpdateSelectedPage() and MakeChangedEvent()
|
// possibly prevent the page change from taking place) if SendEvent flag is
|
||||||
virtual int DoSetSelection(size_t nPage, int flags, wxBookCtrlBaseEvent &event);
|
// included
|
||||||
|
virtual int DoSetSelection(size_t nPage, int flags = 0);
|
||||||
|
|
||||||
|
// if the derived class uses DoSetSelection() for implementing
|
||||||
|
// [Set|Change]Selection, it must override UpdateSelectedPage(),
|
||||||
|
// CreatePageChangingEvent() and MakeChangedEvent(), but as it might not
|
||||||
|
// use it, these functions are not pure virtual
|
||||||
|
|
||||||
|
// called to notify the control about a new current page
|
||||||
virtual void UpdateSelectedPage(size_t WXUNUSED(newsel))
|
virtual void UpdateSelectedPage(size_t WXUNUSED(newsel))
|
||||||
{ wxFAIL_MSG(wxT("Override this function!")); }
|
{ wxFAIL_MSG(wxT("Override this function!")); }
|
||||||
|
|
||||||
|
// create a new "page changing" event
|
||||||
|
virtual wxBookCtrlBaseEvent* CreatePageChangingEvent() const
|
||||||
|
{ wxFAIL_MSG(wxT("Override this function!")); return NULL; }
|
||||||
|
|
||||||
|
// modify the event created by CreatePageChangingEvent() to "page changed"
|
||||||
|
// event, usually by just calling SetEventType() on it
|
||||||
virtual void MakeChangedEvent(wxBookCtrlBaseEvent& WXUNUSED(event))
|
virtual void MakeChangedEvent(wxBookCtrlBaseEvent& WXUNUSED(event))
|
||||||
{ wxFAIL_MSG(wxT("Override this function!")); }
|
{ wxFAIL_MSG(wxT("Override this function!")); }
|
||||||
|
|
||||||
|
|
||||||
// Should we accept NULL page pointers in Add/InsertPage()?
|
// Should we accept NULL page pointers in Add/InsertPage()?
|
||||||
//
|
//
|
||||||
// Default is no but derived classes may override it if they can treat NULL
|
// Default is no but derived classes may override it if they can treat NULL
|
||||||
|
@@ -84,18 +84,14 @@ protected:
|
|||||||
// get the size which the choice control should have
|
// get the size which the choice control should have
|
||||||
virtual wxSize GetControllerSize() const;
|
virtual wxSize GetControllerSize() const;
|
||||||
|
|
||||||
int DoSetSelection(size_t nPage, int flags = 0);
|
|
||||||
|
|
||||||
void UpdateSelectedPage(size_t newsel)
|
void UpdateSelectedPage(size_t newsel)
|
||||||
{
|
{
|
||||||
m_selection = newsel;
|
m_selection = newsel;
|
||||||
GetChoiceCtrl()->Select(newsel);
|
GetChoiceCtrl()->Select(newsel);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MakeChangedEvent(wxBookCtrlBaseEvent &event)
|
wxBookCtrlBaseEvent* CreatePageChangingEvent() const;
|
||||||
{
|
void MakeChangedEvent(wxBookCtrlBaseEvent &event);
|
||||||
event.SetEventType(wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGED);
|
|
||||||
}
|
|
||||||
|
|
||||||
// event handlers
|
// event handlers
|
||||||
void OnChoiceSelected(wxCommandEvent& event);
|
void OnChoiceSelected(wxCommandEvent& event);
|
||||||
|
@@ -85,14 +85,10 @@ protected:
|
|||||||
// return the page corresponding to the tab at the specified position
|
// return the page corresponding to the tab at the specified position
|
||||||
virtual int HitTest(const wxPoint& pt, long *flags = NULL) const;
|
virtual int HitTest(const wxPoint& pt, long *flags = NULL) const;
|
||||||
|
|
||||||
int DoSetSelection(size_t nPage, int flags = 0);
|
|
||||||
|
|
||||||
void UpdateSelectedPage(size_t newsel);
|
void UpdateSelectedPage(size_t newsel);
|
||||||
|
|
||||||
void MakeChangedEvent(wxBookCtrlBaseEvent &event)
|
wxBookCtrlBaseEvent* CreatePageChangingEvent() const;
|
||||||
{
|
void MakeChangedEvent(wxBookCtrlBaseEvent &event);
|
||||||
event.SetEventType(wxEVT_COMMAND_LISTBOOK_PAGE_CHANGED);
|
|
||||||
}
|
|
||||||
|
|
||||||
// event handlers
|
// event handlers
|
||||||
void OnListSelected(wxListEvent& event);
|
void OnListSelected(wxListEvent& event);
|
||||||
|
@@ -101,13 +101,10 @@ protected:
|
|||||||
void OnSize(wxSizeEvent& event);
|
void OnSize(wxSizeEvent& event);
|
||||||
void OnIdle(wxIdleEvent& event);
|
void OnIdle(wxIdleEvent& event);
|
||||||
|
|
||||||
int DoSetSelection(size_t nPage, int flags = 0);
|
|
||||||
void UpdateSelectedPage(size_t newsel);
|
void UpdateSelectedPage(size_t newsel);
|
||||||
|
|
||||||
void MakeChangedEvent(wxBookCtrlBaseEvent &event)
|
wxBookCtrlBaseEvent* CreatePageChangingEvent() const;
|
||||||
{
|
void MakeChangedEvent(wxBookCtrlBaseEvent &event);
|
||||||
event.SetEventType(wxEVT_COMMAND_TOOLBOOK_PAGE_CHANGED);
|
|
||||||
}
|
|
||||||
|
|
||||||
// the currently selected page or wxNOT_FOUND if none
|
// the currently selected page or wxNOT_FOUND if none
|
||||||
int m_selection;
|
int m_selection;
|
||||||
|
@@ -423,7 +423,7 @@ wxSize wxBookCtrlBase::GetControllerSize() const
|
|||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
|
||||||
int wxBookCtrlBase::DoSetSelection(size_t n, int flags, wxBookCtrlBaseEvent &event)
|
int wxBookCtrlBase::DoSetSelection(size_t n, int flags)
|
||||||
{
|
{
|
||||||
wxCHECK_MSG( n < GetPageCount(), wxNOT_FOUND,
|
wxCHECK_MSG( n < GetPageCount(), wxNOT_FOUND,
|
||||||
wxT("invalid page index in wxBookCtrlBase::DoSetSelection()") );
|
wxT("invalid page index in wxBookCtrlBase::DoSetSelection()") );
|
||||||
@@ -432,15 +432,16 @@ int wxBookCtrlBase::DoSetSelection(size_t n, int flags, wxBookCtrlBaseEvent &eve
|
|||||||
|
|
||||||
if ( oldSel != wxNOT_FOUND && n != (size_t)oldSel )
|
if ( oldSel != wxNOT_FOUND && n != (size_t)oldSel )
|
||||||
{
|
{
|
||||||
|
wxBookCtrlBaseEvent *event = CreatePageChangingEvent();
|
||||||
bool allowed = false;
|
bool allowed = false;
|
||||||
|
|
||||||
if ( flags & SetSelection_SendEvent )
|
if ( flags & SetSelection_SendEvent )
|
||||||
{
|
{
|
||||||
event.SetSelection(n);
|
event->SetSelection(n);
|
||||||
event.SetOldSelection(oldSel);
|
event->SetOldSelection(oldSel);
|
||||||
event.SetEventObject(this);
|
event->SetEventObject(this);
|
||||||
|
|
||||||
allowed = !GetEventHandler()->ProcessEvent(event) || event.IsAllowed();
|
allowed = !GetEventHandler()->ProcessEvent(*event) || event->IsAllowed();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( !(flags & SetSelection_SendEvent) || allowed)
|
if ( !(flags & SetSelection_SendEvent) || allowed)
|
||||||
@@ -458,10 +459,12 @@ int wxBookCtrlBase::DoSetSelection(size_t n, int flags, wxBookCtrlBaseEvent &eve
|
|||||||
if ( flags & SetSelection_SendEvent )
|
if ( flags & SetSelection_SendEvent )
|
||||||
{
|
{
|
||||||
// program allows the page change
|
// program allows the page change
|
||||||
MakeChangedEvent(event);
|
MakeChangedEvent(*event);
|
||||||
(void)GetEventHandler()->ProcessEvent(event);
|
(void)GetEventHandler()->ProcessEvent(*event);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
delete event;
|
||||||
}
|
}
|
||||||
|
|
||||||
return oldSel;
|
return oldSel;
|
||||||
|
@@ -209,10 +209,14 @@ int wxChoicebook::GetSelection() const
|
|||||||
return m_selection;
|
return m_selection;
|
||||||
}
|
}
|
||||||
|
|
||||||
int wxChoicebook::DoSetSelection(size_t n, int flags)
|
wxBookCtrlBaseEvent* wxChoicebook::CreatePageChangingEvent() const
|
||||||
{
|
{
|
||||||
wxChoicebookEvent event(wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGING, m_windowId);
|
return new wxChoicebookEvent(wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGING, m_windowId);
|
||||||
return wxBookCtrlBase::DoSetSelection(n, flags, event);
|
}
|
||||||
|
|
||||||
|
void wxChoicebook::MakeChangedEvent(wxBookCtrlBaseEvent &event)
|
||||||
|
{
|
||||||
|
event.SetEventType(wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGED);
|
||||||
}
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
@@ -274,12 +274,17 @@ int wxListbook::GetSelection() const
|
|||||||
return m_selection;
|
return m_selection;
|
||||||
}
|
}
|
||||||
|
|
||||||
int wxListbook::DoSetSelection(size_t n, int flags)
|
wxBookCtrlBaseEvent* wxListbook::CreatePageChangingEvent() const
|
||||||
{
|
{
|
||||||
wxListbookEvent event(wxEVT_COMMAND_LISTBOOK_PAGE_CHANGING, m_windowId);
|
return new wxListbookEvent(wxEVT_COMMAND_LISTBOOK_PAGE_CHANGING, m_windowId);
|
||||||
return wxBookCtrlBase::DoSetSelection(n, flags, event);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxListbook::MakeChangedEvent(wxBookCtrlBaseEvent &event)
|
||||||
|
{
|
||||||
|
event.SetEventType(wxEVT_COMMAND_LISTBOOK_PAGE_CHANGED);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// adding/removing the pages
|
// adding/removing the pages
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
@@ -245,10 +245,14 @@ int wxToolbook::GetSelection() const
|
|||||||
return m_selection;
|
return m_selection;
|
||||||
}
|
}
|
||||||
|
|
||||||
int wxToolbook::DoSetSelection(size_t n, int flags)
|
wxBookCtrlBaseEvent* wxToolbook::CreatePageChangingEvent() const
|
||||||
{
|
{
|
||||||
wxToolbookEvent event(wxEVT_COMMAND_TOOLBOOK_PAGE_CHANGING, m_windowId);
|
return new wxToolbookEvent(wxEVT_COMMAND_TOOLBOOK_PAGE_CHANGING, m_windowId);
|
||||||
return wxBookCtrlBase::DoSetSelection(n, flags, event);
|
}
|
||||||
|
|
||||||
|
void wxToolbook::MakeChangedEvent(wxBookCtrlBaseEvent &event)
|
||||||
|
{
|
||||||
|
event.SetEventType(wxEVT_COMMAND_TOOLBOOK_PAGE_CHANGED);
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxToolbook::UpdateSelectedPage(size_t newsel)
|
void wxToolbook::UpdateSelectedPage(size_t newsel)
|
||||||
|
Reference in New Issue
Block a user