X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/6a415c9a1f1d06e9bcd73b0826b2f153ae6b7dd8..7df9fbc3f11f6239ed7417964c0c50ea77b7b7e7:/include/wx/notebook.h diff --git a/include/wx/notebook.h b/include/wx/notebook.h index e84263f72d..f1e119ff4a 100644 --- a/include/wx/notebook.h +++ b/include/wx/notebook.h @@ -1,13 +1,124 @@ -#ifndef __NOTEBOOKH_BASE__ -#define __NOTEBOOKH_BASE__ +#ifndef _WX_NOTEBOOK_H_BASE_ +#define _WX_NOTEBOOK_H_BASE_ -#if defined(__WINDOWS__) +// ---------------------------------------------------------------------------- +// headers +// ---------------------------------------------------------------------------- + +#include "wx/event.h" // the base class: wxNotifyEvent + +// ---------------------------------------------------------------------------- +// notebook event class (used by NOTEBOOK_PAGE_CHANGED/ING events) +// ---------------------------------------------------------------------------- + +class WXDLLEXPORT wxNotebookEvent : public wxNotifyEvent +{ +public: + wxNotebookEvent(wxEventType commandType = wxEVT_NULL, int id = 0, + int nSel = -1, int nOldSel = -1) + : wxNotifyEvent(commandType, id) + { + m_nSel = nSel; + m_nOldSel = nOldSel; + } + + // accessors + // the currently selected page (-1 if none) + int GetSelection() const { return m_nSel; } + void SetSelection(int nSel) { m_nSel = nSel; } + // the page that was selected before the change (-1 if none) + int GetOldSelection() const { return m_nOldSel; } + void SetOldSelection(int nOldSel) { m_nOldSel = nOldSel; } + +private: + int m_nSel, // currently selected page + m_nOldSel; // previously selected page + + DECLARE_DYNAMIC_CLASS(wxNotebookEvent) +}; + +// ---------------------------------------------------------------------------- +// event types and macros for them +// ---------------------------------------------------------------------------- + +#if defined(__BORLANDC__) && defined(__WIN16__) + // For 16-bit BC++, these 2 would be identical otherwise (truncated) + #define wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGED wxEVT_COMMAND_NB_PAGE_CHANGED + #define wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGING wxEVT_COMMAND_NB_PAGE_CHANGING +#endif + +BEGIN_DECLARE_EVENT_TYPES() + DECLARE_EVENT_TYPE(wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGED, 802) + DECLARE_EVENT_TYPE(wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGING, 803) +END_DECLARE_EVENT_TYPES() + +typedef void (wxEvtHandler::*wxNotebookEventFunction)(wxNotebookEvent&); + +// Truncation in 16-bit BC++ means we need to define these differently +#if defined(__BORLANDC__) && defined(__WIN16__) +#define EVT_NOTEBOOK_PAGE_CHANGED(id, fn) \ + DECLARE_EVENT_TABLE_ENTRY( \ + wxEVT_COMMAND_NB_PAGE_CHANGED, \ + id, \ + -1, \ + (wxObjectEventFunction)(wxEventFunction)(wxNotebookEventFunction) &fn, \ + NULL \ + ), + +#define EVT_NOTEBOOK_PAGE_CHANGING(id, fn) \ + DECLARE_EVENT_TABLE_ENTRY( \ + wxEVT_COMMAND_NB_PAGE_CHANGING, \ + id, \ + -1, \ + (wxObjectEventFunction)(wxEventFunction)(wxNotebookEventFunction) &fn, \ + NULL \ + ), + +#else + +#define EVT_NOTEBOOK_PAGE_CHANGED(id, fn) \ + DECLARE_EVENT_TABLE_ENTRY( \ + wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGED, \ + id, \ + -1, \ + (wxObjectEventFunction)(wxEventFunction)(wxNotebookEventFunction) &fn, \ + NULL \ + ), + +#define EVT_NOTEBOOK_PAGE_CHANGING(id, fn) \ + DECLARE_EVENT_TABLE_ENTRY( \ + wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGING, \ + id, \ + -1, \ + (wxObjectEventFunction)(wxEventFunction)(wxNotebookEventFunction) &fn, \ + NULL \ + ), + +#endif + +// ---------------------------------------------------------------------------- +// wxNotebook class itself +// ---------------------------------------------------------------------------- + +#if defined(__WXMSW__) +#ifdef __WIN16__ + #include "wx/generic/notebook.h" +#else #include "wx/msw/notebook.h" -#elif defined(__MOTIF__) - #error "wxNotebook not implemented under Motif" -#elif defined(__GTK__) +#endif +#elif defined(__WXMOTIF__) + #include "wx/generic/notebook.h" +#elif defined(__WXGTK__) #include "wx/gtk/notebook.h" +#elif defined(__WXQT__) + #include "wx/qt/notebook.h" +#elif defined(__WXMAC__) + #include "wx/mac/notebook.h" +#elif defined(__WXPM__) + #include "wx/os2/notebook.h" +#elif defined(__WXSTUBS__) + #include "wx/stubs/notebook.h" #endif #endif - // __NOTEBOOKH_BASE__ + // _WX_NOTEBOOK_H_BASE_