#include "wx/utils.h"
#include "notebook.h"
-#if !defined(__WXMSW__) && !defined(__WXPM__)
+#ifndef wxHAS_IMAGES_IN_RESOURCES
#include "../sample.xpm"
#endif
EVT_MENU(ID_NEXT_PAGE, MyFrame::OnNextPage)
EVT_MENU(ID_CHANGE_SELECTION, MyFrame::OnChangeSelection)
EVT_MENU(ID_SET_SELECTION, MyFrame::OnSetSelection)
+ EVT_MENU(ID_GET_PAGE_SIZE, MyFrame::OnGetPageSize)
+ EVT_MENU(ID_SET_PAGE_SIZE, MyFrame::OnSetPageSize)
#if wxUSE_HELP
EVT_MENU(ID_CONTEXT_HELP, MyFrame::OnContextHelp)
EVT_TOOLBOOK_PAGE_CHANGED(wxID_ANY, MyFrame::OnToolbook)
EVT_TOOLBOOK_PAGE_CHANGING(wxID_ANY, MyFrame::OnToolbook)
#endif
+#if wxUSE_AUI
+ EVT_AUINOTEBOOK_PAGE_CHANGED(wxID_ANY, MyFrame::OnAuiNotebook)
+ EVT_AUINOTEBOOK_PAGE_CHANGING(wxID_ANY, MyFrame::OnAuiNotebook)
+#endif
// Update title in idle time
EVT_IDLE(MyFrame::OnIdle)
m_type = Type_Treebook;
#elif wxUSE_TOOLBOOK
m_type = Type_Toolbook;
+#elif wxUSE_AUI
+ m_type = Type_Aui;
#else
- #error "Don't use Notebook sample without any book enabled in wxWidgets build!"
+ m_type = Type_Simplebook;
#endif
m_orient = ID_ORIENT_DEFAULT;
#if wxUSE_TOOLBOOK
menuType->AppendRadioItem(ID_BOOK_TOOLBOOK, wxT("T&oolbook\tCtrl-5"));
#endif
+#if wxUSE_AUI
+ menuType->AppendRadioItem(ID_BOOK_AUINOTEBOOK, wxT("&AuiNotebook\tCtrl-6"));
+#endif
+ menuType->AppendRadioItem(ID_BOOK_SIMPLEBOOK, "&Simple book\tCtrl-7");
menuType->Check(ID_BOOK_NOTEBOOK + m_type, true);
menuPageOperations->AppendSeparator();
menuPageOperations->Append(ID_CHANGE_SELECTION, wxT("&Change selection to 0\tCtrl-0"));
menuPageOperations->Append(ID_SET_SELECTION, wxT("&Set selection to 0\tShift-Ctrl-0"));
+ menuPageOperations->AppendSeparator();
+ menuPageOperations->Append(ID_GET_PAGE_SIZE, "Sho&w page size");
+ menuPageOperations->Append(ID_SET_PAGE_SIZE, "Set &page size");
wxMenu *menuOperations = new wxMenu;
#if wxUSE_HELP
#define CASE_TOOLBOOK(x)
#endif
-#define DISPATCH_ON_TYPE(before, nb, lb, cb, tb, toolb, after) \
+#if wxUSE_AUI
+ #define CASE_AUINOTEBOOK(x) case Type_AuiNotebook: x; break;
+#else
+ #define CASE_AUINOTEBOOK(x)
+#endif
+
+#define CASE_SIMPLEBOOK(x) case Type_Simplebook: x; break;
+
+#define DISPATCH_ON_TYPE(before, nb, lb, cb, tb, toolb, aui, sb, after) \
switch ( m_type ) \
{ \
CASE_NOTEBOOK(before nb after) \
CASE_CHOICEBOOK(before cb after) \
CASE_TREEBOOK(before tb after) \
CASE_TOOLBOOK(before toolb after) \
+ CASE_AUINOTEBOOK(before aui after) \
+ CASE_SIMPLEBOOK(before sb after) \
\
default: \
- wxFAIL_MSG( wxT("unknown book control type") ); \
+ wxFAIL_MSG( wxT("unknown book control type") ); \
}
-int MyFrame::TranslateBookFlag(int nb, int lb, int chb, int tbk, int toolbk) const
-{
- int flag = 0;
-
- DISPATCH_ON_TYPE(flag =, nb, lb, chb, tbk, toolbk, + 0);
-
- return flag;
-}
-
void MyFrame::RecreateBook()
{
int flags;
wxChoicebook,
wxTreebook,
wxToolbook,
+ wxAuiNotebook,
+ wxSimplebook,
(m_panel, wxID_ANY, wxDefaultPosition, wxDefaultSize, flags));
if ( !m_bookCtrl )
m_bookCtrl->Hide();
- if ( m_chkShowImages )
+ // wxToolbook doesn't work without icons so always use them for it.
+ if ( m_chkShowImages || m_type == Type_Toolbook )
{
m_bookCtrl->SetImageList(m_imageList);
}
currBook->SetSelection(0);
}
+void MyFrame::OnGetPageSize(wxCommandEvent& WXUNUSED(event))
+{
+ wxBookCtrlBase* const currBook = GetCurrentBook();
+ if ( !currBook )
+ return;
+
+ const wxSize sizePage = currBook->GetPage(0)->GetSize();
+ const wxSize sizeBook = currBook->GetSize();
+
+ wxLogMessage("Page size is (%d, %d), book size (%d, %d)",
+ sizePage.x, sizePage.y,
+ sizeBook.x, sizeBook.y);
+}
+
+void MyFrame::OnSetPageSize(wxCommandEvent& WXUNUSED(event))
+{
+ wxBookCtrlBase* const currBook = GetCurrentBook();
+ if ( !currBook )
+ return;
+
+ const wxSize sizePage(300, 300);
+ currBook->SetPageSize(sizePage);
+
+ wxLogMessage("Page size set to (%d, %d)",
+ sizePage.x, sizePage.y);
+}
+
void MyFrame::OnIdle( wxIdleEvent& WXUNUSED(event) )
{
static int s_nPages = wxNOT_FOUND;
{
#if wxUSE_NOTEBOOK
{
- wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGED,
- wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGING,
+ wxEVT_NOTEBOOK_PAGE_CHANGED,
+ wxEVT_NOTEBOOK_PAGE_CHANGING,
wxT("wxNotebook")
},
#endif // wxUSE_NOTEBOOK
#if wxUSE_LISTBOOK
{
- wxEVT_COMMAND_LISTBOOK_PAGE_CHANGED,
- wxEVT_COMMAND_LISTBOOK_PAGE_CHANGING,
+ wxEVT_LISTBOOK_PAGE_CHANGED,
+ wxEVT_LISTBOOK_PAGE_CHANGING,
wxT("wxListbook")
},
#endif // wxUSE_LISTBOOK
#if wxUSE_CHOICEBOOK
{
- wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGED,
- wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGING,
+ wxEVT_CHOICEBOOK_PAGE_CHANGED,
+ wxEVT_CHOICEBOOK_PAGE_CHANGING,
wxT("wxChoicebook")
},
#endif // wxUSE_CHOICEBOOK
#if wxUSE_TREEBOOK
{
- wxEVT_COMMAND_TREEBOOK_PAGE_CHANGED,
- wxEVT_COMMAND_TREEBOOK_PAGE_CHANGING,
+ wxEVT_TREEBOOK_PAGE_CHANGED,
+ wxEVT_TREEBOOK_PAGE_CHANGING,
wxT("wxTreebook")
},
#endif // wxUSE_TREEBOOK
#if wxUSE_TOOLBOOK
{
- wxEVT_COMMAND_TOOLBOOK_PAGE_CHANGED,
- wxEVT_COMMAND_TOOLBOOK_PAGE_CHANGING,
+ wxEVT_TOOLBOOK_PAGE_CHANGED,
+ wxEVT_TOOLBOOK_PAGE_CHANGING,
wxT("wxToolbook")
},
#endif // wxUSE_TOOLBOOK
+#if wxUSE_AUI
+ {
+ wxEVT_AUINOTEBOOK_PAGE_CHANGED,
+ wxEVT_AUINOTEBOOK_PAGE_CHANGING,
+ wxT("wxAuiNotebook")
+ },
+#endif // wxUSE_AUI
};
nameControl,
veto;
const wxEventType eventType = event.GetEventType();
+
+ // NB: can't use wxStaticCast here as wxBookCtrlBase is not in
+ // wxRTTI
+ const wxBookCtrlBase * const
+ book = static_cast<wxBookCtrlBase *>(event.GetEventObject());
+
for ( size_t n = 0; n < WXSIZEOF(events); n++ )
{
const EventInfo& ei = events[n];
{
const int idx = event.GetOldSelection();
- // NB: can't use wxStaticCast here as wxBookCtrlBase is not in
- // wxRTTI
- const wxBookCtrlBase * const
- book = static_cast<wxBookCtrlBase *>(event.GetEventObject());
if ( idx != wxNOT_FOUND &&
book && book->GetPageText(idx) == VETO_PAGE_NAME )
{
static int s_num = 0;
- wxLogMessage(wxT("Event #%d: %s: %s (%d) new sel %d, old %d%s"),
+ wxLogMessage(wxT("Event #%d: %s: %s (%d) new sel %d, old %d, current %d%s"),
++s_num,
nameControl.c_str(),
nameEvent.c_str(),
eventType,
event.GetSelection(),
event.GetOldSelection(),
+ book->GetSelection(),
veto.c_str());
#if USE_LOG