// if the event object == this because the book control can have other
// subcontrols inside it (e.g. wxSpinButton in case of a notebook in wxUniv)
wxWindow *source = wxStaticCast(event.GetEventObject(), wxWindow);
- while ( source && source->GetParent() != this )
+ while ( source && source != this && source->GetParent() != this )
{
source = source->GetParent();
}
case wxBK_BOTTOM:
rectPage.height -= size.y + GetInternalBorder();
+ if (rectPage.height < 0)
+ rectPage.height = 0;
break;
case wxBK_LEFT:
case wxBK_RIGHT:
rectPage.width -= size.x + GetInternalBorder();
+ if (rectPage.width < 0)
+ rectPage.width = 0;
break;
}
return size;
}
+int wxBookCtrlBase::DoSetSelection(size_t n, int flags)
+{
+ wxCHECK_MSG( n < GetPageCount(), wxNOT_FOUND,
+ wxT("invalid page index in wxBookCtrlBase::DoSetSelection()") );
+
+ const int oldSel = GetSelection();
+
+ if ( oldSel != wxNOT_FOUND && n != (size_t)oldSel )
+ {
+ wxBookCtrlBaseEvent *event = CreatePageChangingEvent();
+ bool allowed = false;
+
+ if ( flags & SetSelection_SendEvent )
+ {
+ event->SetSelection(n);
+ event->SetOldSelection(oldSel);
+ event->SetEventObject(this);
+
+ allowed = !GetEventHandler()->ProcessEvent(*event) || event->IsAllowed();
+ }
+
+ if ( !(flags & SetSelection_SendEvent) || allowed)
+ {
+ if ( oldSel != wxNOT_FOUND )
+ m_pages[oldSel]->Hide();
+
+ wxWindow *page = m_pages[n];
+ page->SetSize(GetPageRect());
+ page->Show();
+
+ // change selection now to ignore the selection change event
+ UpdateSelectedPage(n);
+
+ if ( flags & SetSelection_SendEvent )
+ {
+ // program allows the page change
+ MakeChangedEvent(*event);
+ (void)GetEventHandler()->ProcessEvent(*event);
+ }
+ }
+
+ delete event;
+ }
+
+ return oldSel;
+}
+
+
#endif // wxUSE_BOOKCTRL