BEGIN_EVENT_TABLE(wxBookCtrlBase, wxControl)
EVT_SIZE(wxBookCtrlBase::OnSize)
+#if wxUSE_HELP
+ EVT_HELP(wxID_ANY, wxBookCtrlBase::OnHelp)
+#endif // wxUSE_HELP
END_EVENT_TABLE()
// ----------------------------------------------------------------------------
bestSize.y = childBestSize.y;
}
}
-
+
if (m_fitToCurrentPage && GetCurrentPage())
bestSize = GetCurrentPage()->GetBestSize();
return best;
}
+#if wxUSE_HELP
+void wxBookCtrlBase::OnHelp(wxHelpEvent& event)
+{
+ // find the corresponding page
+ wxWindow *page = NULL;
+
+ if ( event.GetOrigin() == wxHelpEvent::Origin_HelpButton )
+ {
+ // show help for the page under the mouse
+ const int pagePos = HitTest(ScreenToClient(event.GetPosition()));
+
+ if ( pagePos != wxNOT_FOUND)
+ {
+ page = GetPage((size_t)pagePos);
+ }
+ }
+
+ if ( !page )
+ {
+ page = GetCurrentPage();
+ }
+
+ if ( !page || !page->GetEventHandler()->ProcessEvent(event) )
+ {
+ event.Skip();
+ }
+}
+#endif // wxUSE_HELP
+
// ----------------------------------------------------------------------------
// pages management
// ----------------------------------------------------------------------------
_T("invalid page index in wxBookCtrlBase::InsertPage()") );
m_pages.Insert(page, nPage);
+ if ( page )
+ page->SetSize(GetPageRect());
+
InvalidateBestSize();
return true;
// we're not fully created yet or OnSize() should be hidden by derived class
return;
}
-
+
if (GetSizer())
Layout();
else
m_bookctrl->Move(posCtrl);
}
- // resize the currently shown page
- if (GetSelection() != wxNOT_FOUND )
+ // resize all pages to fit the new control size
+ const wxRect pageRect = GetPageRect();
+ const unsigned pagesCount = m_pages.Count();
+ for ( unsigned int i = 0; i < pagesCount; ++i )
{
- wxWindow *page = m_pages[GetSelection()];
- wxCHECK_RET( page, _T("NULL page?") );
- page->SetSize(GetPageRect());
+ wxWindow * const page = m_pages[i];
+ if ( !page )
+ {
+ wxASSERT_MSG( AllowNullPage(),
+ _T("Null page in a control that does not allow null pages?") );
+ continue;
+ }
+
+ page->SetSize(pageRect);
}
}
void wxBookCtrlBase::OnSize(wxSizeEvent& event)
{
event.Skip();
-
+
DoSize();
}