wxaui notebook style flags added

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@42914 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Benjamin Williams 2006-11-01 17:10:58 +00:00
parent d742155316
commit 702b1c7e8a
3 changed files with 130 additions and 14 deletions

View File

@ -27,8 +27,33 @@
#include "wx/control.h" #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_CLOSE_BUTTON = 1 << 7,
wxAUI_NB_PAGELIST_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_ALL_TABS
};
// tab art class
class WXDLLIMPEXP_AUI wxTabArt class WXDLLIMPEXP_AUI wxTabArt
{ {
@ -49,6 +74,7 @@ public:
const wxRect& in_rect, const wxRect& in_rect,
const wxString& caption, const wxString& caption,
bool active, bool active,
bool with_close_button,
wxRect* out_rect, wxRect* out_rect,
int* x_extent) = 0; int* x_extent) = 0;
@ -65,6 +91,7 @@ public:
wxDC* dc, wxDC* dc,
const wxString& caption, const wxString& caption,
bool active, bool active,
bool with_close_button,
int* x_extent) = 0; int* x_extent) = 0;
virtual int GetBestTabCtrlSize(wxWindow* wnd) = 0; virtual int GetBestTabCtrlSize(wxWindow* wnd) = 0;
@ -91,6 +118,7 @@ public:
const wxRect& in_rect, const wxRect& in_rect,
const wxString& caption, const wxString& caption,
bool active, bool active,
bool with_close_button,
wxRect* out_rect, wxRect* out_rect,
int* x_extent); int* x_extent);
@ -107,6 +135,7 @@ public:
wxDC* dc, wxDC* dc,
const wxString& caption, const wxString& caption,
bool active, bool active,
bool with_close_button,
int* x_extent); int* x_extent);
int GetBestTabCtrlSize(wxWindow* wnd); int GetBestTabCtrlSize(wxWindow* wnd);
@ -207,6 +236,9 @@ public:
void SetArtProvider(wxTabArt* art); void SetArtProvider(wxTabArt* art);
wxTabArt* GetArtProvider(); wxTabArt* GetArtProvider();
void SetFlags(unsigned int flags);
unsigned int GetFlags() const;
bool AddPage(wxWindow* page, const wxAuiNotebookPage& info); bool AddPage(wxWindow* page, const wxAuiNotebookPage& info);
bool InsertPage(wxWindow* page, const wxAuiNotebookPage& info, size_t idx); bool InsertPage(wxWindow* page, const wxAuiNotebookPage& info, size_t idx);
bool MovePage(wxWindow* page, size_t new_idx); bool MovePage(wxWindow* page, size_t new_idx);
@ -246,6 +278,7 @@ private:
wxAuiTabContainerButtonArray m_buttons; wxAuiTabContainerButtonArray m_buttons;
wxRect m_rect; wxRect m_rect;
size_t m_tab_offset; size_t m_tab_offset;
unsigned int m_flags;
}; };
@ -301,7 +334,7 @@ public:
wxWindowID id = wxID_ANY, wxWindowID id = wxID_ANY,
const wxPoint& pos = wxDefaultPosition, const wxPoint& pos = wxDefaultPosition,
const wxSize& size = wxDefaultSize, const wxSize& size = wxDefaultSize,
long style = 0); long style = wxAUI_NB_DEFAULT_STYLE);
virtual ~wxAuiMultiNotebook(); virtual ~wxAuiMultiNotebook();
@ -345,7 +378,7 @@ protected:
protected: protected:
void DoSizing(); void DoSizing();
void InitNotebook(); void InitNotebook(long style);
void OnChildFocus(wxChildFocusEvent& evt); void OnChildFocus(wxChildFocusEvent& evt);
void OnRender(wxFrameManagerEvent& evt); void OnRender(wxFrameManagerEvent& evt);
@ -370,6 +403,7 @@ protected:
int m_tab_ctrl_height; int m_tab_ctrl_height;
int m_last_drag_x; int m_last_drag_x;
unsigned int m_flags;
#ifndef SWIG #ifndef SWIG
DECLARE_EVENT_TABLE() DECLARE_EVENT_TABLE()

View File

@ -1234,7 +1234,8 @@ wxHtmlWindow* MyFrame::CreateHTMLCtrl(wxWindow* parent)
wxAuiMultiNotebook* MyFrame::CreateNotebook() wxAuiMultiNotebook* MyFrame::CreateNotebook()
{ {
wxAuiMultiNotebook* ctrl = new wxAuiMultiNotebook( this, wxID_ANY, wxAuiMultiNotebook* ctrl = new wxAuiMultiNotebook( this, wxID_ANY,
wxDefaultPosition, wxSize(400,300), wxNO_BORDER ); wxDefaultPosition, wxSize(400,300),
wxAUI_NB_DEFAULT_STYLE | wxNO_BORDER );
ctrl->AddPage(CreateHTMLCtrl(ctrl), wxT("Welcome")); ctrl->AddPage(CreateHTMLCtrl(ctrl), wxT("Welcome"));

View File

@ -193,6 +193,7 @@ void wxDefaultTabArt::DrawTab(wxDC* dc,
const wxRect& in_rect, const wxRect& in_rect,
const wxString& caption_text, const wxString& caption_text,
bool active, bool active,
bool with_close_button,
wxRect* out_rect, wxRect* out_rect,
int* x_extent) int* x_extent)
{ {
@ -212,7 +213,7 @@ void wxDefaultTabArt::DrawTab(wxDC* dc,
dc->GetTextExtent(caption, &normal_textx, &normal_texty); dc->GetTextExtent(caption, &normal_textx, &normal_texty);
// figure out the size of the tab // figure out the size of the tab
wxSize tab_size = GetTabSize(dc, caption, active, x_extent); wxSize tab_size = GetTabSize(dc, caption, active, with_close_button, x_extent);
wxCoord tab_height = tab_size.y; wxCoord tab_height = tab_size.y;
wxCoord tab_width = tab_size.x; wxCoord tab_width = tab_size.x;
@ -264,12 +265,42 @@ void wxDefaultTabArt::DrawTab(wxDC* dc,
//dc->DrawLines(active ? 6 : 7, points); //dc->DrawLines(active ? 6 : 7, points);
dc->DrawLines(7, points); dc->DrawLines(7, points);
// -- draw text --
int text_offset;
int close_button_width = 0;
if (with_close_button)
{
close_button_width = m_active_close_bmp.GetWidth();
text_offset = tab_x + (tab_height/2) + ((tab_width-close_button_width)/2) - (textx/2);
}
else
{
text_offset = tab_x + (tab_height/3) + (tab_width/2) - (textx/2);
}
// draw tab text
dc->DrawText(caption, dc->DrawText(caption,
tab_x + (tab_height/3) + (tab_width/2) - (textx/2), text_offset,
(tab_y + tab_height)/2 - (texty/2) + 1); (tab_y + tab_height)/2 - (texty/2) + 1);
// draw close button if necessary
if (with_close_button)
{
wxBitmap bmp;
if (active)
bmp = m_active_close_bmp;
else
bmp = m_disabled_close_bmp;
wxRect rect(tab_x + tab_width - close_button_width - 1, tab_y + 1,
close_button_width, tab_height - 1);
DrawButtonS(*dc, rect, bmp, *wxWHITE, wxAUI_BUTTON_STATE_NORMAL);
}
*out_rect = wxRect(tab_x, tab_y, tab_width, tab_height); *out_rect = wxRect(tab_x, tab_y, tab_width, tab_height);
} }
@ -277,6 +308,7 @@ void wxDefaultTabArt::DrawTab(wxDC* dc,
wxSize wxDefaultTabArt::GetTabSize(wxDC* dc, wxSize wxDefaultTabArt::GetTabSize(wxDC* dc,
const wxString& caption, const wxString& caption,
bool WXUNUSED(active), bool WXUNUSED(active),
bool with_close_button,
int* x_extent) int* x_extent)
{ {
wxCoord measured_textx, measured_texty; wxCoord measured_textx, measured_texty;
@ -287,6 +319,9 @@ wxSize wxDefaultTabArt::GetTabSize(wxDC* dc,
wxCoord tab_height = measured_texty + 4; wxCoord tab_height = measured_texty + 4;
wxCoord tab_width = measured_textx + tab_height + 5; wxCoord tab_width = measured_textx + tab_height + 5;
if (with_close_button)
tab_width += m_active_close_bmp.GetWidth();
*x_extent = tab_width - (tab_height/2) - 1; *x_extent = tab_width - (tab_height/2) - 1;
return wxSize(tab_width, tab_height); return wxSize(tab_width, tab_height);
@ -366,7 +401,7 @@ int wxDefaultTabArt::GetBestTabCtrlSize(wxWindow* wnd)
wxClientDC dc(wnd); wxClientDC dc(wnd);
dc.SetFont(m_measuring_font); dc.SetFont(m_measuring_font);
int x_ext = 0; int x_ext = 0;
wxSize s = GetTabSize(&dc, wxT("ABCDEFGHIj"), true, &x_ext); wxSize s = GetTabSize(&dc, wxT("ABCDEFGHIj"), true, false, &x_ext);
return s.y+3; return s.y+3;
} }
@ -406,6 +441,7 @@ void wxDefaultTabArt::SetMeasuringFont(const wxFont& font)
wxAuiTabContainer::wxAuiTabContainer() wxAuiTabContainer::wxAuiTabContainer()
{ {
m_tab_offset = 0; m_tab_offset = 0;
m_flags = 0;
m_art = new wxDefaultTabArt; m_art = new wxDefaultTabArt;
AddButton(wxAUI_BUTTON_LEFT, wxLEFT); AddButton(wxAUI_BUTTON_LEFT, wxLEFT);
@ -429,6 +465,17 @@ wxTabArt* wxAuiTabContainer::GetArtProvider()
return m_art; return m_art;
} }
void wxAuiTabContainer::SetFlags(unsigned int flags)
{
m_flags = flags;
}
unsigned int wxAuiTabContainer::GetFlags() const
{
return m_flags;
}
void wxAuiTabContainer::SetNormalFont(const wxFont& font) void wxAuiTabContainer::SetNormalFont(const wxFont& font)
{ {
m_art->SetNormalFont(font); m_art->SetNormalFont(font);
@ -650,8 +697,18 @@ void wxAuiTabContainer::Render(wxDC* raw_dc)
for (i = 0; i < page_count; ++i) for (i = 0; i < page_count; ++i)
{ {
wxAuiNotebookPage& page = m_pages.Item(i); wxAuiNotebookPage& page = m_pages.Item(i);
// determine if a close button is on this tab
bool close_button = false;
if ((m_flags & wxAUI_NB_CLOSE_ON_ALL_TABS) != 0 ||
((m_flags & wxAUI_NB_CLOSE_ON_ACTIVE_TAB) != 0 && page.active))
{
close_button = true;
}
int x_extent = 0; int x_extent = 0;
wxSize size = m_art->GetTabSize(&dc, page.caption, page.active, &x_extent); wxSize size = m_art->GetTabSize(&dc, page.caption, page.active, close_button, &x_extent);
if (i+1 < page_count) if (i+1 < page_count)
total_width += x_extent; total_width += x_extent;
@ -783,10 +840,12 @@ void wxAuiTabContainer::Render(wxDC* raw_dc)
offset = left_buttons_width; offset = left_buttons_width;
// set a clipping region to the tabs don't draw over the buttons
dc.SetClippingRegion(left_buttons_width, 0, dc.SetClippingRegion(left_buttons_width, 0,
m_rect.GetWidth() - right_buttons_width - left_buttons_width - 2, m_rect.GetWidth() - right_buttons_width - left_buttons_width - 2,
m_rect.GetHeight()); m_rect.GetHeight());
// draw the tabs // draw the tabs
@ -803,12 +862,21 @@ void wxAuiTabContainer::Render(wxDC* raw_dc)
{ {
wxAuiNotebookPage& page = m_pages.Item(i); wxAuiNotebookPage& page = m_pages.Item(i);
// determine if a close button is on this tab
bool close_button = false;
if ((m_flags & wxAUI_NB_CLOSE_ON_ALL_TABS) != 0 ||
((m_flags & wxAUI_NB_CLOSE_ON_ACTIVE_TAB) != 0 && page.active))
{
close_button = true;
}
rect.x = offset; rect.x = offset;
m_art->DrawTab(&dc, m_art->DrawTab(&dc,
rect, rect,
page.caption, page.caption,
page.active, page.active,
close_button,
&page.rect, &page.rect,
&x_extent); &x_extent);
@ -826,11 +894,20 @@ void wxAuiTabContainer::Render(wxDC* raw_dc)
{ {
wxAuiNotebookPage& page = m_pages.Item(active); wxAuiNotebookPage& page = m_pages.Item(active);
// determine if a close button is on this tab
bool close_button = false;
if ((m_flags & wxAUI_NB_CLOSE_ON_ALL_TABS) != 0 ||
((m_flags & wxAUI_NB_CLOSE_ON_ACTIVE_TAB) != 0 && page.active))
{
close_button = true;
}
rect.x = active_offset; rect.x = active_offset;
m_art->DrawTab(&dc, m_art->DrawTab(&dc,
rect, rect,
page.caption, page.caption,
page.active, page.active,
close_button,
&page.rect, &page.rect,
&x_extent); &x_extent);
} }
@ -1297,7 +1374,7 @@ wxAuiMultiNotebook::wxAuiMultiNotebook(wxWindow *parent,
const wxSize& size, const wxSize& size,
long style) : wxControl(parent, id, pos, size, style) long style) : wxControl(parent, id, pos, size, style)
{ {
InitNotebook(); InitNotebook(style);
} }
bool wxAuiMultiNotebook::Create(wxWindow* parent, bool wxAuiMultiNotebook::Create(wxWindow* parent,
@ -1309,20 +1386,21 @@ bool wxAuiMultiNotebook::Create(wxWindow* parent,
if (!wxControl::Create(parent, id, pos, size, style)) if (!wxControl::Create(parent, id, pos, size, style))
return false; return false;
InitNotebook(); InitNotebook(style);
return true; return true;
} }
// InitNotebook() contains common initialization // InitNotebook() contains common initialization
// code called by all constructors // code called by all constructors
void wxAuiMultiNotebook::InitNotebook() void wxAuiMultiNotebook::InitNotebook(long style)
{ {
m_curpage = -1; m_curpage = -1;
m_tab_id_counter = 10000; m_tab_id_counter = 10000;
m_dummy_wnd = NULL; m_dummy_wnd = NULL;
m_tab_ctrl_height = 20; m_tab_ctrl_height = 20;
m_flags = (unsigned int)style;
m_normal_font = *wxNORMAL_FONT; m_normal_font = *wxNORMAL_FONT;
m_selected_font = *wxNORMAL_FONT; m_selected_font = *wxNORMAL_FONT;
m_selected_font.SetWeight(wxBOLD); m_selected_font.SetWeight(wxBOLD);
@ -1654,6 +1732,7 @@ wxAuiTabCtrl* wxAuiMultiNotebook::GetActiveTabCtrl()
wxDefaultPosition, wxDefaultPosition,
wxDefaultSize, wxDefaultSize,
wxNO_BORDER); wxNO_BORDER);
tabframe->m_tabs->SetFlags(m_flags);
m_mgr.AddPane(tabframe, m_mgr.AddPane(tabframe,
wxPaneInfo().Center().CaptionVisible(false)); wxPaneInfo().Center().CaptionVisible(false));
@ -1824,6 +1903,8 @@ void wxAuiMultiNotebook::OnTabEndDrag(wxCommandEvent& command_evt)
wxDefaultPosition, wxDefaultPosition,
wxDefaultSize, wxDefaultSize,
wxNO_BORDER); wxNO_BORDER);
new_tabs->m_tabs->SetFlags(m_flags);
m_mgr.AddPane(new_tabs, m_mgr.AddPane(new_tabs,
wxPaneInfo().Bottom().CaptionVisible(false), wxPaneInfo().Bottom().CaptionVisible(false),
mouse_client_pt); mouse_client_pt);