X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/4953f8cf3bd2a91af0df05f7759533a60126ace1..580ca0a4e10dbd2fb0a144065004394b9d5dcc56:/include/wx/aui/auibook.h diff --git a/include/wx/aui/auibook.h b/include/wx/aui/auibook.h index a44977a86f..2bdd020071 100644 --- a/include/wx/aui/auibook.h +++ b/include/wx/aui/auibook.h @@ -27,69 +27,118 @@ #include "wx/control.h" -// tab art class +enum wxAuiNotebookOption +{ + wxAUI_NB_TOP = 1 << 0, + wxAUI_NB_LEFT = 1 << 1, // not implemented yet + wxAUI_NB_RIGHT = 1 << 2, // not implemented yet + wxAUI_NB_BOTTOM = 1 << 3, // not implemented yet + wxAUI_NB_TAB_SPLIT = 1 << 4, + wxAUI_NB_TAB_MOVE = 1 << 5, + wxAUI_NB_SCROLL_BUTTONS = 1 << 6, + wxAUI_NB_WINDOWLIST_BUTTON = 1 << 7, + wxAUI_NB_CLOSE_BUTTON = 1 << 8, + wxAUI_NB_CLOSE_ON_ACTIVE_TAB = 1 << 9, + wxAUI_NB_CLOSE_ON_ALL_TABS = 1 << 10, + + wxAUI_NB_DEFAULT_STYLE = wxAUI_NB_TOP | + wxAUI_NB_TAB_SPLIT | + wxAUI_NB_TAB_MOVE | + wxAUI_NB_SCROLL_BUTTONS | + wxAUI_NB_CLOSE_ON_ACTIVE_TAB +}; + + + + + +// tab art class -class WXDLLIMPEXP_AUI wxTabArt +class WXDLLIMPEXP_AUI wxAuiTabArt { public: - wxTabArt() { } - virtual ~wxTabArt() { } + wxAuiTabArt() { } + virtual ~wxAuiTabArt() { } + + virtual void SetNormalFont(const wxFont& font) = 0; + virtual void SetSelectedFont(const wxFont& font) = 0; + virtual void SetMeasuringFont(const wxFont& font) = 0; virtual void DrawBackground( wxDC* dc, + wxWindow* wnd, const wxRect& rect) = 0; virtual void DrawTab(wxDC* dc, + wxWindow* wnd, const wxRect& in_rect, const wxString& caption, bool active, - wxRect* out_rect, + int close_button_state, + wxRect* out_tab_rect, + wxRect* out_button_rect, int* x_extent) = 0; virtual 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) = 0; + + virtual int ShowWindowList( + wxWindow* wnd, + const wxArrayString& items, + int active_idx) = 0; virtual wxSize GetTabSize( wxDC* dc, + wxWindow* wnd, const wxString& caption, bool active, + int close_button_state, int* x_extent) = 0; - - virtual void SetNormalFont(const wxFont& font) = 0; - virtual void SetSelectedFont(const wxFont& font) = 0; - virtual void SetMeasuringFont(const wxFont& font) = 0; + + virtual int GetBestTabCtrlSize(wxWindow* wnd) = 0; }; -class WXDLLIMPEXP_AUI wxDefaultTabArt : public wxTabArt +class WXDLLIMPEXP_AUI wxAuiDefaultTabArt : public wxAuiTabArt { public: - wxDefaultTabArt(); - virtual ~wxDefaultTabArt(); + wxAuiDefaultTabArt(); + virtual ~wxAuiDefaultTabArt(); + + void SetWindow(wxWindow* wnd); + void SetNormalFont(const wxFont& font); + void SetSelectedFont(const wxFont& font); + void SetMeasuringFont(const wxFont& font); void DrawBackground( wxDC* dc, + wxWindow* wnd, const wxRect& rect); void DrawTab(wxDC* dc, + wxWindow* wnd, const wxRect& in_rect, const wxString& caption, bool active, - wxRect* out_rect, + int close_button_state, + wxRect* out_tab_rect, + wxRect* out_button_rect, int* x_extent); void DrawButton( wxDC* dc, + wxWindow* wnd, const wxRect& in_rect, int bitmap_id, int button_state, @@ -97,16 +146,21 @@ public: const wxBitmap& bitmap_override, wxRect* out_rect); + int ShowWindowList( + wxWindow* wnd, + const wxArrayString& items, + int active_idx); + wxSize GetTabSize( wxDC* dc, + wxWindow* wnd, const wxString& caption, bool active, + int close_button_state, int* x_extent); - - void SetNormalFont(const wxFont& font); - void SetSelectedFont(const wxFont& font); - void SetMeasuringFont(const wxFont& font); - + + int GetBestTabCtrlSize(wxWindow* wnd); + private: wxFont m_normal_font; @@ -123,6 +177,8 @@ private: wxBitmap m_disabled_left_bmp; wxBitmap m_active_right_bmp; wxBitmap m_disabled_right_bmp; + wxBitmap m_active_windowlist_bmp; + wxBitmap m_disabled_windowlist_bmp; }; @@ -146,7 +202,7 @@ public: #endif wxEvent *Clone() const { return new wxAuiNotebookEvent(*this); } - void SetSelection(int s) { selection = s; } + void SetSelection(int s) { selection = s; m_commandInt = s; } void SetOldSelection(int s) { old_selection = s; } int GetSelection() const { return selection; } int GetOldSelection() const { return old_selection; } @@ -178,9 +234,10 @@ public: class WXDLLIMPEXP_AUI wxAuiTabContainerButton { public: + int id; // button's id int cur_state; // current state (normal, hover, pressed, etc.) - int location; // buttons location (wxLEFT or wxRIGHT) + int location; // buttons location (wxLEFT, wxRIGHT, or wxCENTER) wxBitmap bitmap; // button's hover bitmap wxBitmap dis_bitmap; // button's disabled bitmap wxRect rect; // button's hit rectangle @@ -200,11 +257,15 @@ public: wxAuiTabContainer(); virtual ~wxAuiTabContainer(); - void SetArtProvider(wxTabArt* art); - wxTabArt* GetArtProvider(); + void SetArtProvider(wxAuiTabArt* art); + wxAuiTabArt* GetArtProvider(); + + void SetFlags(unsigned int flags); + unsigned int GetFlags() const; bool AddPage(wxWindow* page, const wxAuiNotebookPage& info); bool InsertPage(wxWindow* page, const wxAuiNotebookPage& info, size_t idx); + bool MovePage(wxWindow* page, size_t new_idx); bool RemovePage(wxWindow* page); bool SetActivePage(wxWindow* page); bool SetActivePage(size_t page); @@ -222,6 +283,8 @@ public: void SetMeasuringFont(const wxFont& measuring_font); void DoShowHide(); void SetRect(const wxRect& rect); + + void RemoveButton(int id); void AddButton(int id, int location, const wxBitmap& normal_bitmap = wxNullBitmap, @@ -232,15 +295,17 @@ public: protected: - virtual void Render(wxDC* dc); + virtual void Render(wxDC* dc, wxWindow* wnd); -private: +protected: - wxTabArt* m_art; + wxAuiTabArt* m_art; wxAuiNotebookPageArray m_pages; wxAuiTabContainerButtonArray m_buttons; + wxAuiTabContainerButtonArray m_tab_close_buttons; wxRect m_rect; size_t m_tab_offset; + unsigned int m_flags; }; @@ -256,6 +321,8 @@ public: const wxSize& size = wxDefaultSize, long style = 0); + ~wxAuiTabCtrl(); + protected: void OnPaint(wxPaintEvent& evt); @@ -271,7 +338,7 @@ protected: protected: wxPoint m_click_pt; - int m_click_tab; + wxWindow* m_click_tab; bool m_is_dragging; wxAuiTabContainerButton* m_hover_button; @@ -283,20 +350,20 @@ protected: -class WXDLLIMPEXP_AUI wxAuiMultiNotebook : public wxControl +class WXDLLIMPEXP_AUI wxAuiNotebook : public wxControl { public: - wxAuiMultiNotebook(); + wxAuiNotebook(); - wxAuiMultiNotebook(wxWindow* parent, - wxWindowID id = wxID_ANY, - const wxPoint& pos = wxDefaultPosition, - const wxSize& size = wxDefaultSize, - long style = 0); + wxAuiNotebook(wxWindow* parent, + wxWindowID id = wxID_ANY, + const wxPoint& pos = wxDefaultPosition, + const wxSize& size = wxDefaultSize, + long style = wxAUI_NB_DEFAULT_STYLE); - virtual ~wxAuiMultiNotebook(); + virtual ~wxAuiNotebook(); bool Create(wxWindow* parent, wxWindowID id = wxID_ANY, @@ -317,6 +384,8 @@ public: bool DeletePage(size_t page); bool RemovePage(size_t page); + + void SetWindowStyleFlag(long style); bool SetPageText(size_t page, const wxString& text); size_t SetSelection(size_t new_page); @@ -324,8 +393,9 @@ public: size_t GetPageCount() const; wxWindow* GetPage(size_t page_idx) const; - void SetArtProvider(wxTabArt* art); - wxTabArt* GetArtProvider(); + + void SetArtProvider(wxAuiTabArt* art); + wxAuiTabArt* GetArtProvider(); protected: @@ -338,10 +408,10 @@ protected: protected: void DoSizing(); - void InitNotebook(); + void InitNotebook(long style); void OnChildFocus(wxChildFocusEvent& evt); - void OnRender(wxFrameManagerEvent& evt); + void OnRender(wxAuiManagerEvent& evt); void OnEraseBackground(wxEraseEvent& evt); void OnSize(wxSizeEvent& evt); void OnTabClicked(wxCommandEvent& evt); @@ -352,7 +422,7 @@ protected: protected: - wxFrameManager m_mgr; + wxAuiManager m_mgr; wxAuiTabContainer m_tabs; int m_curpage; int m_tab_id_counter; @@ -361,8 +431,12 @@ protected: wxFont m_selected_font; wxFont m_normal_font; int m_tab_ctrl_height; + + int m_last_drag_x; + unsigned int m_flags; #ifndef SWIG + DECLARE_CLASS(wxAuiNotebook) DECLARE_EVENT_TABLE() #endif };