removed wxDCWindowImpl::m_win; use wxDCImpl::m_window instead (fixes caret-related...
[wxWidgets.git] / interface / aui / auibook.h
index 281692a5428ef7e45ae866de4e9f639cda6020f0..b4d933eab3c631b0889980b63947fcb183330754 100644 (file)
     @headerfile auibook.h wx/aui/auibook.h
 
     wxAuiNotebook is part of the wxAUI class framework.
     @headerfile auibook.h wx/aui/auibook.h
 
     wxAuiNotebook is part of the wxAUI class framework.
-    See also @ref overview_wxauioverview.
+    See also @ref overview_aui.
 
     wxAuiNotebook is a notebook control which implements many features common in
     applications with dockable panes.
     Specifically, wxAuiNotebook implements functionality which allows the user to
 
     wxAuiNotebook is a notebook control which implements many features common in
     applications with dockable panes.
     Specifically, wxAuiNotebook implements functionality which allows the user to
-    rearrange tab order via drag-and-drop,
-    split the tab window into many different splitter configurations, and toggle
-    through different themes to customize
+    rearrange tab order via drag-and-drop, split the tab window into many different
+    splitter configurations, and toggle through different themes to customize
     the control's look and feel.
 
     An effort has been made to try to maintain an API as similar to that of
     the control's look and feel.
 
     An effort has been made to try to maintain an API as similar to that of
     The theme can be changed by calling wxAuiNotebook::SetArtProvider.
 
     @beginStyleTable
     The theme can be changed by calling wxAuiNotebook::SetArtProvider.
 
     @beginStyleTable
-    @style{wxAUI_NB_DEFAULT_STYLE}:
+    @style{wxAUI_NB_DEFAULT_STYLE}
            Defined as wxAUI_NB_TOP | wxAUI_NB_TAB_SPLIT | wxAUI_NB_TAB_MOVE |
            wxAUI_NB_SCROLL_BUTTONS | wxAUI_NB_CLOSE_ON_ACTIVE_TAB.
            Defined as wxAUI_NB_TOP | wxAUI_NB_TAB_SPLIT | wxAUI_NB_TAB_MOVE |
            wxAUI_NB_SCROLL_BUTTONS | wxAUI_NB_CLOSE_ON_ACTIVE_TAB.
-    @style{wxAUI_NB_TAB_SPLIT}:
+    @style{wxAUI_NB_TAB_SPLIT}
            Allows the tab control to be split by dragging a tab.
            Allows the tab control to be split by dragging a tab.
-    @style{wxAUI_NB_TAB_MOVE}:
+    @style{wxAUI_NB_TAB_MOVE}
            Allows a tab to be moved horizontally by dragging.
            Allows a tab to be moved horizontally by dragging.
-    @style{wxAUI_NB_TAB_EXTERNAL_MOVE}:
+    @style{wxAUI_NB_TAB_EXTERNAL_MOVE}
            Allows a tab to be moved to another tab control.
            Allows a tab to be moved to another tab control.
-    @style{wxAUI_NB_TAB_FIXED_WIDTH}:
+    @style{wxAUI_NB_TAB_FIXED_WIDTH}
            With this style, all tabs have the same width.
            With this style, all tabs have the same width.
-    @style{wxAUI_NB_SCROLL_BUTTONS}:
+    @style{wxAUI_NB_SCROLL_BUTTONS}
            With this style, left and right scroll buttons are displayed.
            With this style, left and right scroll buttons are displayed.
-    @style{wxAUI_NB_WINDOWLIST_BUTTON}:
+    @style{wxAUI_NB_WINDOWLIST_BUTTON}
            With this style, a drop-down list of windows is available.
            With this style, a drop-down list of windows is available.
-    @style{wxAUI_NB_CLOSE_BUTTON}:
+    @style{wxAUI_NB_CLOSE_BUTTON}
            With this style, a close button is available on the tab bar.
            With this style, a close button is available on the tab bar.
-    @style{wxAUI_NB_CLOSE_ON_ACTIVE_TAB}:
+    @style{wxAUI_NB_CLOSE_ON_ACTIVE_TAB}
            With this style, the close button is visible on the active tab.
            With this style, the close button is visible on the active tab.
-    @style{wxAUI_NB_CLOSE_ON_ALL_TABS}:
+    @style{wxAUI_NB_CLOSE_ON_ALL_TABS}
            With this style, the close button is visible on all tabs.
            With this style, the close button is visible on all tabs.
-    @style{wxAUI_NB_TOP}:
+    @style{wxAUI_NB_TOP}
            With this style, tabs are drawn along the top of the notebook.
            With this style, tabs are drawn along the top of the notebook.
-    @style{wxAUI_NB_BOTTOM}:
+    @style{wxAUI_NB_BOTTOM}
            With this style, tabs are drawn along the bottom of the notebook.
     @endStyleTable
 
            With this style, tabs are drawn along the bottom of the notebook.
     @endStyleTable
 
 class wxAuiNotebook : public wxControl
 {
 public:
 class wxAuiNotebook : public wxControl
 {
 public:
-    //@{
+    wxAuiNotebook();
+
     /**
         Constructor. Creates a wxAuiNotebok control.
     */
     /**
         Constructor. Creates a wxAuiNotebok control.
     */
-    wxAuiNotebook();
     wxAuiNotebook(wxWindow* parent, wxWindowID id = wxID_ANY,
                   const wxPoint& pos = wxDefaultPosition,
                   const wxSize& size = wxDefaultSize,
                   long style = wxAUI_NB_DEFAULT_STYLE);
     wxAuiNotebook(wxWindow* parent, wxWindowID id = wxID_ANY,
                   const wxPoint& pos = wxDefaultPosition,
                   const wxSize& size = wxDefaultSize,
                   long style = wxAUI_NB_DEFAULT_STYLE);
-    //@}
 
     /**
 
     /**
-        Adds a page.  If the @a select parameter is @true, calling this will generate a
-        page change event.
+        Adds a page.
+        If the @a select parameter is @true, calling this will generate a page change event.
     */
     bool AddPage(wxWindow* page, const wxString& caption,
                  bool select = false,
     */
     bool AddPage(wxWindow* page, const wxString& caption,
                  bool select = false,
@@ -95,8 +93,8 @@ public:
                 long style = 0);
 
     /**
                 long style = 0);
 
     /**
-        Deletes a page at the given index.  Calling this method will generate a page
-        change event.
+        Deletes a page at the given index.
+        Calling this method will generate a page change event.
     */
     bool DeletePage(size_t page);
 
     */
     bool DeletePage(size_t page);
 
@@ -106,9 +104,8 @@ public:
     wxAuiTabArt* GetArtProvider() const;
 
     /**
     wxAuiTabArt* GetArtProvider() const;
 
     /**
-        Returns the desired height of the notebook for the given page height. Use this
-        to fit the notebook to
-        a given page size.
+        Returns the desired height of the notebook for the given page height.
+        Use this to fit the notebook to a given page size.
     */
     int GetHeightForPageHeight(int pageHeight);
 
     */
     int GetHeightForPageHeight(int pageHeight);
 
@@ -128,8 +125,8 @@ public:
     size_t GetPageCount() const;
 
     /**
     size_t GetPageCount() const;
 
     /**
-        Returns the page index for the specified window.  If the window is not found in
-        the notebook, wxNOT_FOUND is returned.
+        Returns the page index for the specified window.
+        If the window is not found in the notebook, wxNOT_FOUND is returned.
     */
     int GetPageIndex(wxWindow* page_wnd) const;
 
     */
     int GetPageIndex(wxWindow* page_wnd) const;
 
@@ -173,7 +170,7 @@ public:
         Sets the font for drawing the tab labels, using a bold version of the font for
         selected tab labels.
     */
         Sets the font for drawing the tab labels, using a bold version of the font for
         selected tab labels.
     */
-    bool SetFont(const wxFont& font);
+    virtual bool SetFont(const wxFont& font);
 
     /**
         Sets the font for measuring tab labels.
 
     /**
         Sets the font for measuring tab labels.
@@ -207,24 +204,24 @@ public:
     size_t SetSelection(size_t new_page);
 
     /**
     size_t SetSelection(size_t new_page);
 
     /**
-        Sets the tab height.  By default, the tab control height is calculated
-        by measuring the text height and bitmap sizes on the tab captions.  Calling this
+        Sets the tab height. By default, the tab control height is calculated
+        by measuring the text height and bitmap sizes on the tab captions. Calling this
         method will override that calculation and set the tab control to the specified
         method will override that calculation and set the tab control to the specified
-        height parameter.  A call to this method will override any call to
+        height parameter. A call to this method will override any call to
         SetUniformBitmapSize().
         SetUniformBitmapSize().
+
         Specifying -1 as the height will return the control to its default auto-sizing
         behaviour.
     */
         Specifying -1 as the height will return the control to its default auto-sizing
         behaviour.
     */
-    void SetTabCtrlHeight(int height);
+    virtual void SetTabCtrlHeight(int height);
 
     //@{
     /**
         Split performs a split operation programmatically. The argument @a page
 
     //@{
     /**
         Split performs a split operation programmatically. The argument @a page
-        indicates
-        the page that will be split off.  This page will also become the active page
-        after the
-        split.  The @a direction argument specifies where the pane should go, it should
-        be one
+        indicates the page that will be split off.  This page will also become the
+        active page after the split.
+
+        The @a direction argument specifies where the pane should go, it should be one
         of the following: wxTOP, wxBOTTOM, wxLEFT, or wxRIGHT.
     */
     void SetUniformBitmapSize(const wxSize& size);
         of the following: wxTOP, wxBOTTOM, wxLEFT, or wxRIGHT.
     */
     void SetUniformBitmapSize(const wxSize& size);
@@ -246,6 +243,8 @@ public:
 
     Tab art class.
 
 
     Tab art class.
 
+    @todo BETTER DESCRIPTION NEEDED
+
     @library{wxaui}
     @category{aui}
 */
     @library{wxaui}
     @category{aui}
 */
@@ -260,85 +259,67 @@ public:
     /**
         Clones the art object.
     */
     /**
         Clones the art object.
     */
-    wxAuiTabArt* Clone();
+    virtual wxAuiTabArt* Clone() = 0;
 
     /**
         Draws a background on the given area.
     */
 
     /**
         Draws a background on the given area.
     */
-    void DrawBackground(wxDC& dc, wxWindow* wnd, const wxRect& rect);
+    virtual void DrawBackground(wxDC& dc, wxWindow* wnd, const wxRect& rect) = 0;
 
     /**
         Draws a button.
     */
 
     /**
         Draws a button.
     */
-    void DrawButton(wxDC& dc, wxWindow* wnd, const wxRect& in_rect,
-                    int bitmap_id,
-                    int button_state,
-                    int orientation,
-                    const wxBitmap& bitmap_override,
-                    wxRect* out_rect);
+    virtual void DrawButton(wxDC& dc, wxWindow* wnd, const wxRect& in_rect,
+                            int bitmap_id, int button_state, int orientation,
+                            wxRect* out_rect) = 0;
 
     /**
         Draws a tab.
     */
 
     /**
         Draws a tab.
     */
-    void DrawTab(wxDC& dc, wxWindow* wnd, const wxRect& in_rect,
-                 const wxString& caption,
-                 const wxBitmap& bitmap,
-                 bool active,
-                 int close_button_state,
-                 wxRect* out_tab_rect,
-                 wxRect* out_button_rect,
-                 int* x_extent);
+    virtual void DrawTab(wxDC& dc, wxWindow* wnd, const wxAuiNotebookPage& page,
+                         const wxRect& rect, int close_button_state,
+                         wxRect* out_tab_rect, wxRect* out_button_rect, int* x_extent) = 0;
 
     /**
         Returns the tab control size.
     */
 
     /**
         Returns the tab control size.
     */
-    int GetBestTabCtrlSize(wxWindow* wnd,
-                           wxAuiNotebookPageArray& pages);
+    virtual int GetBestTabCtrlSize(wxWindow*, const wxAuiNotebookPageArray&, const wxSize&) = 0;
 
     /**
         Returns the indent size.
     */
 
     /**
         Returns the indent size.
     */
-    int GetIndentSize();
+    virtual int GetIndentSize() = 0;
 
     /**
         Returns the tab size for the given caption, bitmap and state.
     */
 
     /**
         Returns the tab size for the given caption, bitmap and state.
     */
-    wxSize GetTabSize(wxDC& dc, wxWindow* wnd,
-                      const wxString& caption,
-                      const wxBitmap& bitmap,
-                      bool active,
-                      int close_button_state,
-                      int* x_extent);
+    virtual wxSize GetTabSize(wxDC& dc, wxWindow* wnd, const wxString& caption,
+                              const wxBitmap& bitmap, bool active,
+                              int close_button_state, int* x_extent) = 0;
 
     /**
         Sets flags.
     */
 
     /**
         Sets flags.
     */
-    void SetFlags(unsigned int flags);
+    virtual void SetFlags(unsigned int flags) = 0;
 
     /**
         Sets the font used for calculating measurements.
     */
 
     /**
         Sets the font used for calculating measurements.
     */
-    void SetMeasuringFont(const wxFont& font);
+    virtual void SetMeasuringFont(const wxFont& font) = 0;
 
     /**
         Sets the normal font for drawing labels.
     */
 
     /**
         Sets the normal font for drawing labels.
     */
-    void SetNormalFont(const wxFont& font);
+    virtual void SetNormalFont(const wxFont& font) = 0;
 
     /**
         Sets the font for drawing text for selected UI elements.
     */
 
     /**
         Sets the font for drawing text for selected UI elements.
     */
-    void SetSelectedFont(const wxFont& font);
+    virtual void SetSelectedFont(const wxFont& font) = 0;
 
     /**
         Sets sizing information.
     */
 
     /**
         Sets sizing information.
     */
-    void SetSizingInfo(const wxSize& tab_ctrl_size, size_t tab_count);
-
-    /**
-        Pops up a menu to show the list of windows managed by wxAui.
-    */
-    int ShowWindowList(wxWindow* wnd, const wxArrayString& items,
-                       int active_idx);
+    virtual void SetSizingInfo(const wxSize& tab_ctrl_size, size_t tab_count) = 0;
 };
 
 };