Applied patch [ 1747059 ] wxAUIDefaultTabArt wxAUI_NB_BOTTOM
Langhammer git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/branches/WX_2_8_BRANCH@48270 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -42,6 +42,8 @@ The theme can be changed by calling \helpref{wxAuiNotebook::SetArtProvider}{wxau
|
||||
\twocolitem{\windowstyle{wxAUI\_NB\_CLOSE\_BUTTON}}{With this style, a close button is available on the tab bar.}
|
||||
\twocolitem{\windowstyle{wxAUI\_NB\_CLOSE\_ON\_ACTIVE\_TAB}}{With this style, the close button is visible on the active tab.}
|
||||
\twocolitem{\windowstyle{wxAUI\_NB\_CLOSE\_ON\_ALL\_TABS}}{With this style, the close button is visible on all tabs.}
|
||||
\twocolitem{\windowstyle{wxAUI\_NB\_TOP}}{With this style, tabs are drawn along the top of the notebook.}
|
||||
\twocolitem{\windowstyle{wxAUI\_NB\_BOTTOM}}{With this style, tabs are drawn along the bottom of the notebook.}
|
||||
\end{twocollist}
|
||||
|
||||
|
||||
|
@@ -35,7 +35,7 @@ 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_BOTTOM = 1 << 3,
|
||||
wxAUI_NB_TAB_SPLIT = 1 << 4,
|
||||
wxAUI_NB_TAB_MOVE = 1 << 5,
|
||||
wxAUI_NB_TAB_EXTERNAL_MOVE = 1 << 6,
|
||||
@@ -468,6 +468,7 @@ protected:
|
||||
void OnMiddleUp(wxMouseEvent& evt);
|
||||
void OnRightDown(wxMouseEvent& evt);
|
||||
void OnRightUp(wxMouseEvent& evt);
|
||||
void OnLeftDClick(wxMouseEvent& evt);
|
||||
void OnSetFocus(wxFocusEvent& event);
|
||||
void OnKillFocus(wxFocusEvent& event);
|
||||
void OnChar(wxKeyEvent& event);
|
||||
@@ -663,6 +664,9 @@ BEGIN_DECLARE_EVENT_TYPES()
|
||||
DECLARE_EXPORTED_EVENT_TYPE(WXDLLIMPEXP_AUI, wxEVT_COMMAND_AUINOTEBOOK_TAB_MIDDLE_UP, 0)
|
||||
DECLARE_EXPORTED_EVENT_TYPE(WXDLLIMPEXP_AUI, wxEVT_COMMAND_AUINOTEBOOK_TAB_RIGHT_DOWN, 0)
|
||||
DECLARE_EXPORTED_EVENT_TYPE(WXDLLIMPEXP_AUI, wxEVT_COMMAND_AUINOTEBOOK_TAB_RIGHT_UP, 0)
|
||||
DECLARE_EXPORTED_EVENT_TYPE(WXDLLIMPEXP_AUI, wxEVT_COMMAND_AUINOTEBOOK_PAGE_CLOSED, 0)
|
||||
DECLARE_EXPORTED_EVENT_TYPE(WXDLLIMPEXP_AUI, wxEVT_COMMAND_AUINOTEBOOK_DRAG_DONE, 0)
|
||||
DECLARE_EXPORTED_EVENT_TYPE(WXDLLIMPEXP_AUI, wxEVT_COMMAND_AUINOTEBOOK_BG_DCLICK, 0)
|
||||
#endif
|
||||
END_DECLARE_EVENT_TYPES()
|
||||
|
||||
@@ -673,6 +677,8 @@ typedef void (wxEvtHandler::*wxAuiNotebookEventFunction)(wxAuiNotebookEvent&);
|
||||
|
||||
#define EVT_AUINOTEBOOK_PAGE_CLOSE(winid, fn) \
|
||||
wx__DECLARE_EVT1(wxEVT_COMMAND_AUINOTEBOOK_PAGE_CLOSE, winid, wxAuiNotebookEventHandler(fn))
|
||||
#define EVT_AUINOTEBOOK_PAGE_CLOSED(winid, fn) \
|
||||
wx__DECLARE_EVT1(wxEVT_COMMAND_AUINOTEBOOK_PAGE_CLOSED, winid, wxAuiNotebookEventHandler(fn))
|
||||
#define EVT_AUINOTEBOOK_PAGE_CHANGED(winid, fn) \
|
||||
wx__DECLARE_EVT1(wxEVT_COMMAND_AUINOTEBOOK_PAGE_CHANGED, winid, wxAuiNotebookEventHandler(fn))
|
||||
#define EVT_AUINOTEBOOK_PAGE_CHANGING(winid, fn) \
|
||||
@@ -697,12 +703,17 @@ typedef void (wxEvtHandler::*wxAuiNotebookEventFunction)(wxAuiNotebookEvent&);
|
||||
wx__DECLARE_EVT1(wxEVT_COMMAND_AUINOTEBOOK_TAB_RIGHT_DOWN, winid, wxAuiNotebookEventHandler(fn))
|
||||
#define EVT_AUINOTEBOOK_TAB_RIGHT_UP(winid, fn) \
|
||||
wx__DECLARE_EVT1(wxEVT_COMMAND_AUINOTEBOOK_TAB_RIGHT_UP, winid, wxAuiNotebookEventHandler(fn))
|
||||
#define EVT_AUINOTEBOOK_DRAG_DONE(winid, fn) \
|
||||
wx__DECLARE_EVT1(wxEVT_COMMAND_AUINOTEBOOK_DRAG_DONE, winid, wxAuiNotebookEventHandler(fn))
|
||||
#define EVT_AUINOTEBOOK_BG_DCLICK(winid, fn) \
|
||||
wx__DECLARE_EVT1(wxEVT_COMMAND_AUINOTEBOOK_BG_DCLICK, winid, wxAuiNotebookEventHandler(fn))
|
||||
#endif
|
||||
|
||||
#else
|
||||
|
||||
// wxpython/swig event work
|
||||
%constant wxEventType wxEVT_COMMAND_AUINOTEBOOK_PAGE_CLOSE;
|
||||
%constant wxEventType wxEVT_COMMAND_AUINOTEBOOK_PAGE_CLOSED;
|
||||
%constant wxEventType wxEVT_COMMAND_AUINOTEBOOK_PAGE_CHANGED;
|
||||
%constant wxEventType wxEVT_COMMAND_AUINOTEBOOK_PAGE_CHANGING;
|
||||
%constant wxEventType wxEVT_COMMAND_AUINOTEBOOK_BUTTON;
|
||||
@@ -710,9 +721,12 @@ typedef void (wxEvtHandler::*wxAuiNotebookEventFunction)(wxAuiNotebookEvent&);
|
||||
%constant wxEventType wxEVT_COMMAND_AUINOTEBOOK_END_DRAG;
|
||||
%constant wxEventType wxEVT_COMMAND_AUINOTEBOOK_DRAG_MOTION;
|
||||
%constant wxEventType wxEVT_COMMAND_AUINOTEBOOK_ALLOW_DND;
|
||||
%constant wxEventType wxEVT_COMMAND_AUINOTEBOOK_DRAG_DONE;
|
||||
%constant wxEventType wxEVT_COMMAND_AUINOTEBOOK_BG_DCLICK;
|
||||
|
||||
%pythoncode {
|
||||
EVT_AUINOTEBOOK_PAGE_CLOSE = wx.PyEventBinder( wxEVT_COMMAND_AUINOTEBOOK_PAGE_CLOSE, 1 )
|
||||
EVT_AUINOTEBOOK_PAGE_CLOSED = wx.PyEventBinder( wxEVT_COMMAND_AUINOTEBOOK_PAGE_CLOSED, 1 )
|
||||
EVT_AUINOTEBOOK_PAGE_CHANGED = wx.PyEventBinder( wxEVT_COMMAND_AUINOTEBOOK_PAGE_CHANGED, 1 )
|
||||
EVT_AUINOTEBOOK_PAGE_CHANGING = wx.PyEventBinder( wxEVT_COMMAND_AUINOTEBOOK_PAGE_CHANGING, 1 )
|
||||
EVT_AUINOTEBOOK_BUTTON = wx.PyEventBinder( wxEVT_COMMAND_AUINOTEBOOK_BUTTON, 1 )
|
||||
@@ -720,6 +734,8 @@ typedef void (wxEvtHandler::*wxAuiNotebookEventFunction)(wxAuiNotebookEvent&);
|
||||
EVT_AUINOTEBOOK_END_DRAG = wx.PyEventBinder( wxEVT_COMMAND_AUINOTEBOOK_END_DRAG, 1 )
|
||||
EVT_AUINOTEBOOK_DRAG_MOTION = wx.PyEventBinder( wxEVT_COMMAND_AUINOTEBOOK_DRAG_MOTION, 1 )
|
||||
EVT_AUINOTEBOOK_ALLOW_DND = wx.PyEventBinder( wxEVT_COMMAND_AUINOTEBOOK_ALLOW_DND, 1 )
|
||||
EVT_AUINOTEBOOK_DRAG_DONE = wx.PyEventBinder( wxEVT_COMMAND_AUINOTEBOOK_DRAG_DONE, 1 )
|
||||
EVT_AUINOTEBOOK_BG_DCLICK = wx.PyEventBinder( wxEVT_COMMAND_AUINOTEBOOK_BG_DCLICK, 1 )
|
||||
}
|
||||
#endif
|
||||
|
||||
|
@@ -371,17 +371,35 @@ void wxAuiDefaultTabArt::DrawBackground(wxDC& dc,
|
||||
const wxRect& rect)
|
||||
{
|
||||
// draw background
|
||||
wxRect r(rect.x, rect.y, rect.width+2, rect.height-3);
|
||||
wxColor top_color = wxAuiStepColour(m_base_colour, 90);
|
||||
wxColor bottom_color = wxAuiStepColour(m_base_colour, 170);
|
||||
wxColor top_color = wxAuiStepColour(m_base_colour, 90);
|
||||
wxColor bottom_color = wxAuiStepColour(m_base_colour, 170);
|
||||
wxRect r;
|
||||
|
||||
if (m_flags &wxAUI_NB_BOTTOM)
|
||||
r = wxRect(rect.x, rect.y, rect.width+2, rect.height);
|
||||
// TODO: else if (m_flags &wxAUI_NB_LEFT) {}
|
||||
// TODO: else if (m_flags &wxAUI_NB_RIGHT) {}
|
||||
else //for wxAUI_NB_TOP
|
||||
r = wxRect(rect.x, rect.y, rect.width+2, rect.height-3);
|
||||
dc.GradientFillLinear(r, top_color, bottom_color, wxSOUTH);
|
||||
|
||||
// draw base lines
|
||||
int y = rect.GetHeight();
|
||||
int w = rect.GetWidth();
|
||||
dc.SetPen(m_border_pen);
|
||||
dc.SetBrush(m_base_colour_brush);
|
||||
dc.DrawRectangle(-1, y-4, w+2, 4);
|
||||
// draw base lines
|
||||
dc.SetPen(m_border_pen);
|
||||
int y = rect.GetHeight();
|
||||
int w = rect.GetWidth();
|
||||
|
||||
if (m_flags &wxAUI_NB_BOTTOM)
|
||||
{
|
||||
dc.SetBrush(wxBrush(bottom_color));
|
||||
dc.DrawRectangle(-1, 0, w+2, 4);
|
||||
}
|
||||
// TODO: else if (m_flags &wxAUI_NB_LEFT) {}
|
||||
// TODO: else if (m_flags &wxAUI_NB_RIGHT) {}
|
||||
else //for wxAUI_NB_TOP
|
||||
{
|
||||
dc.SetBrush(m_base_colour_brush);
|
||||
dc.DrawRectangle(-1, y-4, w+2, 4);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -480,13 +498,26 @@ void wxAuiDefaultTabArt::DrawTab(wxDC& dc,
|
||||
|
||||
|
||||
wxPoint border_points[6];
|
||||
border_points[0] = wxPoint(tab_x, tab_y+tab_height-4);
|
||||
border_points[1] = wxPoint(tab_x, tab_y+2);
|
||||
border_points[2] = wxPoint(tab_x+2, tab_y);
|
||||
border_points[3] = wxPoint(tab_x+tab_width-2, tab_y);
|
||||
border_points[4] = wxPoint(tab_x+tab_width, tab_y+2);
|
||||
border_points[5] = wxPoint(tab_x+tab_width, tab_y+tab_height-4);
|
||||
|
||||
if (m_flags &wxAUI_NB_BOTTOM)
|
||||
{
|
||||
border_points[0] = wxPoint(tab_x, tab_y);
|
||||
border_points[1] = wxPoint(tab_x, tab_y+tab_height-6);
|
||||
border_points[2] = wxPoint(tab_x+2, tab_y+tab_height-4);
|
||||
border_points[3] = wxPoint(tab_x+tab_width-2, tab_y+tab_height-4);
|
||||
border_points[4] = wxPoint(tab_x+tab_width, tab_y+tab_height-6);
|
||||
border_points[5] = wxPoint(tab_x+tab_width, tab_y);
|
||||
}
|
||||
else //if (m_flags & wxAUI_NB_TOP) {}
|
||||
{
|
||||
border_points[0] = wxPoint(tab_x, tab_y+tab_height-4);
|
||||
border_points[1] = wxPoint(tab_x, tab_y+2);
|
||||
border_points[2] = wxPoint(tab_x+2, tab_y);
|
||||
border_points[3] = wxPoint(tab_x+tab_width-2, tab_y);
|
||||
border_points[4] = wxPoint(tab_x+tab_width, tab_y+2);
|
||||
border_points[5] = wxPoint(tab_x+tab_width, tab_y+tab_height-4);
|
||||
}
|
||||
// TODO: else if (m_flags &wxAUI_NB_LEFT) {}
|
||||
// TODO: else if (m_flags &wxAUI_NB_RIGHT) {}
|
||||
|
||||
int drawn_tab_yoff = border_points[1].y;
|
||||
int drawn_tab_height = border_points[0].y - border_points[1].y;
|
||||
@@ -562,8 +593,12 @@ void wxAuiDefaultTabArt::DrawTab(wxDC& dc,
|
||||
// this gets rid of the top one of those lines in the tab control
|
||||
if (page.active)
|
||||
{
|
||||
wxColor start_color = m_base_colour;
|
||||
dc.SetPen(m_base_colour_pen);
|
||||
if (m_flags &wxAUI_NB_BOTTOM)
|
||||
dc.SetPen(wxPen(wxColour(wxAuiStepColour(m_base_colour, 170))));
|
||||
// TODO: else if (m_flags &wxAUI_NB_LEFT) {}
|
||||
// TODO: else if (m_flags &wxAUI_NB_RIGHT) {}
|
||||
else //for wxAUI_NB_TOP
|
||||
dc.SetPen(m_base_colour_pen);
|
||||
dc.DrawLine(border_points[0].x+1,
|
||||
border_points[0].y,
|
||||
border_points[5].x,
|
||||
@@ -2729,9 +2764,21 @@ public:
|
||||
if (!m_tabs)
|
||||
return;
|
||||
|
||||
m_tab_rect = wxRect(m_rect.x, m_rect.y, m_rect.width, m_tab_ctrl_height);
|
||||
m_tabs->SetSize(m_rect.x, m_rect.y, m_rect.width, m_tab_ctrl_height);
|
||||
m_tabs->SetRect(wxRect(0, 0, m_rect.width, m_tab_ctrl_height));
|
||||
if (m_tabs->GetFlags() & wxAUI_NB_BOTTOM)
|
||||
{
|
||||
m_tab_rect = wxRect (m_rect.x, m_rect.y + m_rect.height - m_tab_ctrl_height, m_rect.width, m_tab_ctrl_height);
|
||||
m_tabs->SetSize (m_rect.x, m_rect.y + m_rect.height - m_tab_ctrl_height, m_rect.width, m_tab_ctrl_height);
|
||||
m_tabs->SetRect (wxRect(0, 0, m_rect.width, m_tab_ctrl_height));
|
||||
}
|
||||
else //TODO: if (GetFlags() & wxAUI_NB_TOP)
|
||||
{
|
||||
m_tab_rect = wxRect (m_rect.x, m_rect.y, m_rect.width, m_tab_ctrl_height);
|
||||
m_tabs->SetSize (m_rect.x, m_rect.y, m_rect.width, m_tab_ctrl_height);
|
||||
m_tabs->SetRect (wxRect(0, 0, m_rect.width, m_tab_ctrl_height));
|
||||
}
|
||||
// TODO: else if (GetFlags() & wxAUI_NB_LEFT){}
|
||||
// TODO: else if (GetFlags() & wxAUI_NB_RIGHT){}
|
||||
|
||||
m_tabs->Refresh();
|
||||
m_tabs->Update();
|
||||
|
||||
@@ -2741,8 +2788,18 @@ public:
|
||||
for (i = 0; i < page_count; ++i)
|
||||
{
|
||||
wxAuiNotebookPage& page = pages.Item(i);
|
||||
page.window->SetSize(m_rect.x, m_rect.y + m_tab_ctrl_height,
|
||||
m_rect.width, m_rect.height - m_tab_ctrl_height);
|
||||
if (m_tabs->GetFlags() & wxAUI_NB_BOTTOM)
|
||||
{
|
||||
page.window->SetSize(m_rect.x, m_rect.y,
|
||||
m_rect.width, m_rect.height - m_tab_ctrl_height);
|
||||
}
|
||||
else //TODO: if (GetFlags() & wxAUI_NB_TOP)
|
||||
{
|
||||
page.window->SetSize(m_rect.x, m_rect.y + m_tab_ctrl_height,
|
||||
m_rect.width, m_rect.height - m_tab_ctrl_height);
|
||||
}
|
||||
// TODO: else if (GetFlags() & wxAUI_NB_LEFT){}
|
||||
// TODO: else if (GetFlags() & wxAUI_NB_RIGHT){}
|
||||
|
||||
#if wxUSE_MDI
|
||||
if (page.window->IsKindOf(CLASSINFO(wxAuiMDIChildFrame)))
|
||||
|
Reference in New Issue
Block a user