wxaui notebook tabs can scroll; notebook themability improved
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@42730 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -48,6 +48,21 @@ public:
|
||||
wxRect* out_rect,
|
||||
int* x_extent) = 0;
|
||||
|
||||
virtual void DrawButton(
|
||||
wxDC* dc,
|
||||
const wxRect& in_rect,
|
||||
int bitmap_id,
|
||||
int button_state,
|
||||
int orientation,
|
||||
const wxBitmap& bitmap_override,
|
||||
wxRect* out_rect) = 0;
|
||||
|
||||
virtual wxSize GetTabSize(
|
||||
wxDC* dc,
|
||||
const wxString& caption,
|
||||
bool active,
|
||||
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;
|
||||
@@ -73,6 +88,21 @@ public:
|
||||
wxRect* out_rect,
|
||||
int* x_extent);
|
||||
|
||||
void DrawButton(
|
||||
wxDC* dc,
|
||||
const wxRect& in_rect,
|
||||
int bitmap_id,
|
||||
int button_state,
|
||||
int orientation,
|
||||
const wxBitmap& bitmap_override,
|
||||
wxRect* out_rect);
|
||||
|
||||
wxSize GetTabSize(
|
||||
wxDC* dc,
|
||||
const wxString& caption,
|
||||
bool active,
|
||||
int* x_extent);
|
||||
|
||||
void SetNormalFont(const wxFont& font);
|
||||
void SetSelectedFont(const wxFont& font);
|
||||
void SetMeasuringFont(const wxFont& font);
|
||||
@@ -87,6 +117,12 @@ private:
|
||||
wxBrush m_normal_bkbrush;
|
||||
wxBrush m_selected_bkbrush;
|
||||
wxBrush m_bkbrush;
|
||||
wxBitmap m_active_close_bmp;
|
||||
wxBitmap m_disabled_close_bmp;
|
||||
wxBitmap m_active_left_bmp;
|
||||
wxBitmap m_disabled_left_bmp;
|
||||
wxBitmap m_active_right_bmp;
|
||||
wxBitmap m_disabled_right_bmp;
|
||||
};
|
||||
|
||||
|
||||
@@ -143,9 +179,10 @@ class WXDLLIMPEXP_AUI wxAuiTabContainerButton
|
||||
{
|
||||
public:
|
||||
int id; // button's id
|
||||
int cur_state; // current state (normal, hover, pressed)
|
||||
int cur_state; // current state (normal, hover, pressed, etc.)
|
||||
int location; // buttons location (wxLEFT or wxRIGHT)
|
||||
wxBitmap bitmap; // button's bitmap
|
||||
wxBitmap bitmap; // button's hover bitmap
|
||||
wxBitmap dis_bitmap; // button's disabled bitmap
|
||||
wxRect rect; // button's hit rectangle
|
||||
};
|
||||
|
||||
@@ -185,7 +222,13 @@ public:
|
||||
void SetMeasuringFont(const wxFont& measuring_font);
|
||||
void DoShowHide();
|
||||
void SetRect(const wxRect& rect);
|
||||
void AddButton(int id, int location, const wxBitmap& bmp);
|
||||
void AddButton(int id,
|
||||
int location,
|
||||
const wxBitmap& normal_bitmap = wxNullBitmap,
|
||||
const wxBitmap& disabled_bitmap = wxNullBitmap);
|
||||
|
||||
size_t GetTabOffset() const;
|
||||
void SetTabOffset(size_t offset);
|
||||
|
||||
protected:
|
||||
|
||||
@@ -197,6 +240,7 @@ private:
|
||||
wxAuiNotebookPageArray m_pages;
|
||||
wxAuiTabContainerButtonArray m_buttons;
|
||||
wxRect m_rect;
|
||||
size_t m_tab_offset;
|
||||
};
|
||||
|
||||
|
||||
@@ -221,6 +265,8 @@ protected:
|
||||
void OnLeftUp(wxMouseEvent& evt);
|
||||
void OnMotion(wxMouseEvent& evt);
|
||||
void OnLeaveWindow(wxMouseEvent& evt);
|
||||
void OnButton(wxAuiNotebookEvent& evt);
|
||||
|
||||
|
||||
protected:
|
||||
|
||||
@@ -346,7 +392,7 @@ typedef void (wxEvtHandler::*wxAuiNotebookEventFunction)(wxAuiNotebookEvent&);
|
||||
wx__DECLARE_EVT1(wxEVT_COMMAND_AUINOTEBOOK_PAGE_CHANGED, winid, wxAuiNotebookEventHandler(fn))
|
||||
#define EVT_AUINOTEBOOK_PAGE_CHANGING(winid, fn) \
|
||||
wx__DECLARE_EVT1(wxEVT_COMMAND_AUINOTEBOOK_PAGE_CHANGING, winid, wxAuiNotebookEventHandler(fn))
|
||||
#define EVT_AUINOTEBOOK_PAGE_BUTTON(winid, fn) \
|
||||
#define EVT_AUINOTEBOOK_BUTTON(winid, fn) \
|
||||
wx__DECLARE_EVT1(wxEVT_COMMAND_AUINOTEBOOK_BUTTON, winid, wxAuiNotebookEventHandler(fn))
|
||||
#define EVT_AUINOTEBOOK_BEGIN_DRAG(winid, fn) \
|
||||
wx__DECLARE_EVT1(wxEVT_COMMAND_AUINOTEBOOK_BEGIN_DRAG, winid, wxAuiNotebookEventHandler(fn))
|
||||
|
@@ -86,8 +86,26 @@ enum wxPaneDockArtGradients
|
||||
enum wxPaneButtonState
|
||||
{
|
||||
wxAUI_BUTTON_STATE_NORMAL = 0,
|
||||
wxAUI_BUTTON_STATE_HOVER = 1,
|
||||
wxAUI_BUTTON_STATE_PRESSED = 2
|
||||
wxAUI_BUTTON_STATE_HOVER = 1 << 1,
|
||||
wxAUI_BUTTON_STATE_PRESSED = 1 << 2,
|
||||
wxAUI_BUTTON_STATE_DISABLED = 1 << 3,
|
||||
wxAUI_BUTTON_STATE_HIDDEN = 1 << 4
|
||||
};
|
||||
|
||||
enum wxAuiButtonId
|
||||
{
|
||||
wxAUI_BUTTON_CLOSE = 101,
|
||||
wxAUI_BUTTON_MAXIMIZE = 102,
|
||||
wxAUI_BUTTON_MINIMIZE = 103,
|
||||
wxAUI_BUTTON_PIN = 104,
|
||||
wxAUI_BUTTON_OPTIONS = 105,
|
||||
wxAUI_BUTTON_LEFT = 106,
|
||||
wxAUI_BUTTON_RIGHT = 107,
|
||||
wxAUI_BUTTON_UP = 108,
|
||||
wxAUI_BUTTON_DOWN = 109,
|
||||
wxAUI_BUTTON_CUSTOM1 = 201,
|
||||
wxAUI_BUTTON_CUSTOM2 = 202,
|
||||
wxAUI_BUTTON_CUSTOM3 = 203
|
||||
};
|
||||
|
||||
enum wxPaneInsertLevel
|
||||
@@ -99,6 +117,7 @@ enum wxPaneInsertLevel
|
||||
|
||||
|
||||
|
||||
|
||||
// forwards and array declarations
|
||||
class wxDockUIPart;
|
||||
class wxPaneButton;
|
||||
|
@@ -1255,10 +1255,28 @@ wxAuiMultiNotebook* MyFrame::CreateNotebook()
|
||||
ctrl->AddPage( panel, wxT("wxPanel") );
|
||||
|
||||
ctrl->AddPage( new wxTextCtrl( ctrl, wxID_ANY, wxT("Some text"),
|
||||
wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE|wxNO_BORDER) , wxT("wxTextCtrl I") );
|
||||
wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE|wxNO_BORDER) , wxT("wxTextCtrl 1") );
|
||||
|
||||
ctrl->AddPage( new wxTextCtrl( ctrl, wxID_ANY, wxT("Some more text"),
|
||||
wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE|wxNO_BORDER) , wxT("wxTextCtrl II") );
|
||||
wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE|wxNO_BORDER) , wxT("wxTextCtrl 2") );
|
||||
|
||||
ctrl->AddPage( new wxTextCtrl( ctrl, wxID_ANY, wxT("Some more text"),
|
||||
wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE|wxNO_BORDER) , wxT("wxTextCtrl 3") );
|
||||
|
||||
ctrl->AddPage( new wxTextCtrl( ctrl, wxID_ANY, wxT("Some more text"),
|
||||
wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE|wxNO_BORDER) , wxT("wxTextCtrl 4") );
|
||||
|
||||
ctrl->AddPage( new wxTextCtrl( ctrl, wxID_ANY, wxT("Some more text"),
|
||||
wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE|wxNO_BORDER) , wxT("wxTextCtrl 5") );
|
||||
|
||||
ctrl->AddPage( new wxTextCtrl( ctrl, wxID_ANY, wxT("Some more text"),
|
||||
wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE|wxNO_BORDER) , wxT("wxTextCtrl 6") );
|
||||
|
||||
ctrl->AddPage( new wxTextCtrl( ctrl, wxID_ANY, wxT("Some more text"),
|
||||
wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE|wxNO_BORDER) , wxT("wxTextCtrl 7") );
|
||||
|
||||
ctrl->AddPage( new wxTextCtrl( ctrl, wxID_ANY, wxT("Some more text"),
|
||||
wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE|wxNO_BORDER) , wxT("wxTextCtrl 8") );
|
||||
|
||||
return ctrl;
|
||||
}
|
||||
|
@@ -71,7 +71,7 @@ static wxBitmap BitmapFromBits(const unsigned char bits[], int w, int h,
|
||||
return wxBitmap(img);
|
||||
}
|
||||
|
||||
static void DrawButton(wxDC& dc,
|
||||
static void DrawButtonS(wxDC& dc,
|
||||
const wxRect& _rect,
|
||||
const wxBitmap& bmp,
|
||||
const wxColour& bkcolour,
|
||||
@@ -123,14 +123,50 @@ wxDefaultTabArt::wxDefaultTabArt()
|
||||
m_normal_bkpen = wxPen(normaltab_colour);
|
||||
m_selected_bkbrush = wxBrush(selectedtab_colour);
|
||||
m_selected_bkpen = wxPen(selectedtab_colour);
|
||||
|
||||
|
||||
#if defined( __WXMAC__ )
|
||||
static unsigned char close_bits[]={
|
||||
0xFF, 0xFF, 0xFF, 0xFF, 0x0F, 0xFE, 0x03, 0xF8, 0x01, 0xF0, 0x19, 0xF3,
|
||||
0xB8, 0xE3, 0xF0, 0xE1, 0xE0, 0xE0, 0xF0, 0xE1, 0xB8, 0xE3, 0x19, 0xF3,
|
||||
0x01, 0xF0, 0x03, 0xF8, 0x0F, 0xFE, 0xFF, 0xFF };
|
||||
#elif defined( __WXGTK__)
|
||||
static unsigned char close_bits[]={
|
||||
0xff, 0xff, 0xff, 0xff, 0x07, 0xf0, 0xfb, 0xef, 0xdb, 0xed, 0x8b, 0xe8,
|
||||
0x1b, 0xec, 0x3b, 0xee, 0x1b, 0xec, 0x8b, 0xe8, 0xdb, 0xed, 0xfb, 0xef,
|
||||
0x07, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };
|
||||
#else
|
||||
static unsigned char close_bits[]={
|
||||
0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xef,0xfb,0xcf,0xf9,
|
||||
0x9f,0xfc,0x3f,0xfe,0x3f,0xfe,0x9f,0xfc,0xcf,0xf9,0xef,0xfb,
|
||||
0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff};
|
||||
#endif
|
||||
|
||||
static unsigned char left_bits[] = {
|
||||
0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x7f, 0xfe, 0x3f, 0xfe,
|
||||
0x1f, 0xfe, 0x0f, 0xfe, 0x1f, 0xfe, 0x3f, 0xfe, 0x7f, 0xfe, 0xff, 0xfe,
|
||||
0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
|
||||
|
||||
static unsigned char right_bits[] = {
|
||||
0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xdf, 0xff, 0x9f, 0xff, 0x1f, 0xff,
|
||||
0x1f, 0xfe, 0x1f, 0xfc, 0x1f, 0xfe, 0x1f, 0xff, 0x9f, 0xff, 0xdf, 0xff,
|
||||
0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
|
||||
|
||||
m_active_close_bmp = BitmapFromBits(close_bits, 16, 16, *wxBLACK);
|
||||
m_disabled_close_bmp = BitmapFromBits(close_bits, 16, 16, wxColour(128,128,128));
|
||||
|
||||
m_active_left_bmp = BitmapFromBits(left_bits, 16, 16, *wxBLACK);
|
||||
m_disabled_left_bmp = BitmapFromBits(left_bits, 16, 16, wxColour(128,128,128));
|
||||
|
||||
m_active_right_bmp = BitmapFromBits(right_bits, 16, 16, *wxBLACK);
|
||||
m_disabled_right_bmp = BitmapFromBits(right_bits, 16, 16, wxColour(128,128,128));
|
||||
}
|
||||
|
||||
wxDefaultTabArt::~wxDefaultTabArt()
|
||||
{
|
||||
}
|
||||
|
||||
void wxDefaultTabArt::DrawBackground(
|
||||
wxDC* dc,
|
||||
void wxDefaultTabArt::DrawBackground(wxDC* dc,
|
||||
const wxRect& rect)
|
||||
{
|
||||
// draw background
|
||||
@@ -143,6 +179,7 @@ void wxDefaultTabArt::DrawBackground(
|
||||
dc->DrawLine(0, rect.GetHeight()-1, rect.GetWidth(), rect.GetHeight()-1);
|
||||
}
|
||||
|
||||
|
||||
// DrawTab() draws an individual tab.
|
||||
//
|
||||
// dc - output dc
|
||||
@@ -244,6 +281,92 @@ void wxDefaultTabArt::DrawTab(wxDC* dc,
|
||||
}
|
||||
|
||||
|
||||
wxSize wxDefaultTabArt::GetTabSize(wxDC* dc,
|
||||
const wxString& caption,
|
||||
bool WXUNUSED(active),
|
||||
int* x_extent)
|
||||
{
|
||||
wxCoord measured_textx, measured_texty;
|
||||
|
||||
dc->SetFont(m_measuring_font);
|
||||
dc->GetTextExtent(caption, &measured_textx, &measured_texty);
|
||||
|
||||
wxCoord tab_height = measured_texty + 4;
|
||||
wxCoord tab_width = measured_textx + tab_height + 5;
|
||||
|
||||
*x_extent = tab_width - (tab_height/2) - 1;
|
||||
|
||||
return wxSize(tab_width, tab_height);
|
||||
}
|
||||
|
||||
|
||||
void wxDefaultTabArt::DrawButton(
|
||||
wxDC* dc,
|
||||
const wxRect& in_rect,
|
||||
int bitmap_id,
|
||||
int button_state,
|
||||
int orientation,
|
||||
const wxBitmap& bitmap_override,
|
||||
wxRect* out_rect)
|
||||
{
|
||||
wxBitmap bmp;
|
||||
wxRect rect;
|
||||
|
||||
if (bitmap_override.IsOk())
|
||||
{
|
||||
bmp = bitmap_override;
|
||||
}
|
||||
else
|
||||
{
|
||||
switch (bitmap_id)
|
||||
{
|
||||
case wxAUI_BUTTON_CLOSE:
|
||||
if (button_state & wxAUI_BUTTON_STATE_DISABLED)
|
||||
bmp = m_disabled_close_bmp;
|
||||
else
|
||||
bmp = m_active_close_bmp;
|
||||
break;
|
||||
case wxAUI_BUTTON_LEFT:
|
||||
if (button_state & wxAUI_BUTTON_STATE_DISABLED)
|
||||
bmp = m_disabled_left_bmp;
|
||||
else
|
||||
bmp = m_active_left_bmp;
|
||||
break;
|
||||
case wxAUI_BUTTON_RIGHT:
|
||||
if (button_state & wxAUI_BUTTON_STATE_DISABLED)
|
||||
bmp = m_disabled_right_bmp;
|
||||
else
|
||||
bmp = m_active_right_bmp;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (!bmp.IsOk())
|
||||
return;
|
||||
|
||||
rect = in_rect;
|
||||
|
||||
if (orientation == wxLEFT)
|
||||
{
|
||||
rect.SetWidth(bmp.GetWidth());
|
||||
rect.SetHeight(bmp.GetHeight());
|
||||
}
|
||||
else
|
||||
{
|
||||
rect = wxRect(in_rect.x + in_rect.width - bmp.GetWidth(), in_rect.y,
|
||||
bmp.GetWidth(), bmp.GetHeight());
|
||||
}
|
||||
|
||||
|
||||
DrawButtonS(*dc, rect, bmp, *wxWHITE, button_state);
|
||||
|
||||
*out_rect = rect;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
void wxDefaultTabArt::SetNormalFont(const wxFont& font)
|
||||
{
|
||||
m_normal_font = font;
|
||||
@@ -279,7 +402,12 @@ void wxDefaultTabArt::SetMeasuringFont(const wxFont& font)
|
||||
|
||||
wxAuiTabContainer::wxAuiTabContainer()
|
||||
{
|
||||
m_tab_offset = 0;
|
||||
m_art = new wxDefaultTabArt;
|
||||
|
||||
AddButton(wxAUI_BUTTON_LEFT, wxLEFT);
|
||||
AddButton(wxAUI_BUTTON_RIGHT, wxRIGHT);
|
||||
AddButton(wxAUI_BUTTON_CLOSE, wxRIGHT);
|
||||
}
|
||||
|
||||
wxAuiTabContainer::~wxAuiTabContainer()
|
||||
@@ -452,18 +580,30 @@ size_t wxAuiTabContainer::GetPageCount() const
|
||||
return m_pages.GetCount();
|
||||
}
|
||||
|
||||
void wxAuiTabContainer::AddButton(int id, int location, const wxBitmap& bmp)
|
||||
void wxAuiTabContainer::AddButton(int id,
|
||||
int location,
|
||||
const wxBitmap& normal_bitmap,
|
||||
const wxBitmap& disabled_bitmap)
|
||||
{
|
||||
wxAuiTabContainerButton button;
|
||||
button.id = id;
|
||||
button.bitmap = bmp;
|
||||
button.bitmap = normal_bitmap;
|
||||
button.dis_bitmap = disabled_bitmap;
|
||||
button.location = location;
|
||||
button.cur_state = wxAUI_BUTTON_STATE_NORMAL;
|
||||
|
||||
m_buttons.Add(button);
|
||||
}
|
||||
|
||||
size_t wxAuiTabContainer::GetTabOffset() const
|
||||
{
|
||||
return m_tab_offset;
|
||||
}
|
||||
|
||||
void wxAuiTabContainer::SetTabOffset(size_t offset)
|
||||
{
|
||||
m_tab_offset = offset;
|
||||
}
|
||||
|
||||
// Render() renders the tab catalog to the specified DC
|
||||
// It is a virtual function and can be overridden to
|
||||
@@ -472,35 +612,93 @@ void wxAuiTabContainer::Render(wxDC* raw_dc)
|
||||
{
|
||||
wxMemoryDC dc;
|
||||
wxBitmap bmp;
|
||||
size_t i;
|
||||
size_t page_count = m_pages.GetCount();
|
||||
size_t button_count = m_buttons.GetCount();
|
||||
|
||||
// create off-screen bitmap
|
||||
bmp.Create(m_rect.GetWidth(), m_rect.GetHeight());
|
||||
dc.SelectObject(bmp);
|
||||
|
||||
|
||||
// find out if size of tabs is larger than can be
|
||||
// afforded on screen
|
||||
int total_width = 0;
|
||||
|
||||
for (i = 0; i < page_count; ++i)
|
||||
{
|
||||
wxAuiNotebookPage& page = m_pages.Item(i);
|
||||
int x_extent = 0;
|
||||
wxSize size = m_art->GetTabSize(&dc, page.caption, page.active, &x_extent);
|
||||
if (i+1 < page_count)
|
||||
total_width += x_extent;
|
||||
else
|
||||
total_width += size.x;
|
||||
}
|
||||
|
||||
if (total_width > m_rect.GetWidth() - 20 || m_tab_offset != 0)
|
||||
{
|
||||
// show left/right buttons
|
||||
for (i = 0; i < button_count; ++i)
|
||||
{
|
||||
wxAuiTabContainerButton& button = m_buttons.Item(i);
|
||||
if (button.id == wxAUI_BUTTON_LEFT ||
|
||||
button.id == wxAUI_BUTTON_RIGHT)
|
||||
{
|
||||
button.cur_state &= ~wxAUI_BUTTON_STATE_HIDDEN;
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
// hide left/right buttons
|
||||
for (i = 0; i < button_count; ++i)
|
||||
{
|
||||
wxAuiTabContainerButton& button = m_buttons.Item(i);
|
||||
if (button.id == wxAUI_BUTTON_LEFT ||
|
||||
button.id == wxAUI_BUTTON_RIGHT)
|
||||
{
|
||||
button.cur_state |= wxAUI_BUTTON_STATE_HIDDEN;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
// draw background
|
||||
m_art->DrawBackground(&dc, m_rect);
|
||||
|
||||
// draw buttons
|
||||
int left_buttons_width = 0;
|
||||
int right_buttons_width = 0;
|
||||
|
||||
int offset = 0;
|
||||
size_t i;
|
||||
|
||||
// draw the buttons on the right side
|
||||
offset = m_rect.x + m_rect.width;
|
||||
size_t button_count = m_buttons.GetCount();
|
||||
for (i = 0; i < button_count; ++i)
|
||||
{
|
||||
wxAuiTabContainerButton& button = m_buttons.Item(button_count - i - 1);
|
||||
|
||||
if (button.location != wxRIGHT)
|
||||
continue;
|
||||
if (button.cur_state & wxAUI_BUTTON_STATE_HIDDEN)
|
||||
continue;
|
||||
|
||||
wxRect button_rect(offset - button.bitmap.GetWidth(), 1,
|
||||
button.bitmap.GetWidth(), button.bitmap.GetHeight());
|
||||
wxRect button_rect = m_rect;
|
||||
button_rect.SetY(1);
|
||||
button_rect.SetWidth(offset);
|
||||
|
||||
button.rect = button_rect;
|
||||
m_art->DrawButton(&dc,
|
||||
button_rect,
|
||||
button.id,
|
||||
button.cur_state,
|
||||
wxRIGHT,
|
||||
wxNullBitmap,
|
||||
&button.rect);
|
||||
|
||||
DrawButton(dc, button.rect, button.bitmap,
|
||||
//m_bkbrush.GetColour(),
|
||||
*wxWHITE,
|
||||
button.cur_state);
|
||||
|
||||
offset -= button.bitmap.GetWidth();
|
||||
offset -= button.rect.GetWidth();
|
||||
right_buttons_width += button.rect.GetWidth();
|
||||
}
|
||||
|
||||
|
||||
@@ -515,24 +713,31 @@ void wxAuiTabContainer::Render(wxDC* raw_dc)
|
||||
|
||||
if (button.location != wxLEFT)
|
||||
continue;
|
||||
if (button.cur_state & wxAUI_BUTTON_STATE_HIDDEN)
|
||||
continue;
|
||||
|
||||
wxRect button_rect(offset, 1,
|
||||
button.bitmap.GetWidth(),
|
||||
button.bitmap.GetHeight());
|
||||
wxRect button_rect(offset, 1, 1000, m_rect.height);
|
||||
|
||||
button.rect = button_rect;
|
||||
m_art->DrawButton(&dc,
|
||||
button_rect,
|
||||
button.id,
|
||||
button.cur_state,
|
||||
wxLEFT,
|
||||
wxNullBitmap,
|
||||
&button.rect);
|
||||
|
||||
DrawButton(dc, button.rect, button.bitmap,
|
||||
//m_bkbrush.GetColour(),
|
||||
*wxWHITE,
|
||||
button.cur_state);
|
||||
|
||||
offset += button.bitmap.GetWidth();
|
||||
offset += button.rect.GetWidth();
|
||||
left_buttons_width += button.rect.GetWidth();
|
||||
}
|
||||
|
||||
offset = left_buttons_width;
|
||||
|
||||
|
||||
dc.SetClippingRegion(left_buttons_width, 0,
|
||||
m_rect.GetWidth() - right_buttons_width - left_buttons_width - 2,
|
||||
m_rect.GetHeight());
|
||||
|
||||
// draw the tabs
|
||||
size_t page_count = m_pages.GetCount();
|
||||
|
||||
size_t active = 999;
|
||||
int active_offset = 0;
|
||||
@@ -543,7 +748,7 @@ void wxAuiTabContainer::Render(wxDC* raw_dc)
|
||||
rect.width = 1000;
|
||||
rect.height = m_rect.height;
|
||||
|
||||
for (i = 0; i < page_count; ++i)
|
||||
for (i = m_tab_offset; i < page_count; ++i)
|
||||
{
|
||||
wxAuiNotebookPage& page = m_pages.Item(i);
|
||||
|
||||
@@ -566,7 +771,7 @@ void wxAuiTabContainer::Render(wxDC* raw_dc)
|
||||
}
|
||||
|
||||
// draw the active tab again so it stands in the foreground
|
||||
if (active < m_pages.GetCount())
|
||||
if (active >= m_tab_offset && active < m_pages.GetCount())
|
||||
{
|
||||
wxAuiNotebookPage& page = m_pages.Item(active);
|
||||
|
||||
@@ -579,8 +784,11 @@ void wxAuiTabContainer::Render(wxDC* raw_dc)
|
||||
&x_extent);
|
||||
}
|
||||
|
||||
dc.DestroyClippingRegion();
|
||||
|
||||
raw_dc->Blit(m_rect.x, m_rect.y, m_rect.GetWidth(), m_rect.GetHeight(), &dc, 0, 0);
|
||||
raw_dc->Blit(m_rect.x, m_rect.y,
|
||||
m_rect.GetWidth(), m_rect.GetHeight(),
|
||||
&dc, 0, 0);
|
||||
}
|
||||
|
||||
|
||||
@@ -592,13 +800,17 @@ bool wxAuiTabContainer::TabHitTest(int x, int y, wxWindow** hit) const
|
||||
if (!m_rect.Contains(x,y))
|
||||
return false;
|
||||
|
||||
if (ButtonHitTest(x, y, NULL))
|
||||
return false;
|
||||
|
||||
size_t i, page_count = m_pages.GetCount();
|
||||
|
||||
for (i = 0; i < page_count; ++i)
|
||||
for (i = m_tab_offset; i < page_count; ++i)
|
||||
{
|
||||
wxAuiNotebookPage& page = m_pages.Item(i);
|
||||
if (page.rect.Contains(x,y))
|
||||
{
|
||||
if (hit)
|
||||
*hit = page.window;
|
||||
return true;
|
||||
}
|
||||
@@ -622,6 +834,7 @@ bool wxAuiTabContainer::ButtonHitTest(int x, int y,
|
||||
wxAuiTabContainerButton& button = m_buttons.Item(i);
|
||||
if (button.rect.Contains(x,y))
|
||||
{
|
||||
if (hit)
|
||||
*hit = &button;
|
||||
return true;
|
||||
}
|
||||
@@ -683,7 +896,6 @@ void wxAuiTabContainer::DoShowHide()
|
||||
// -- wxAuiTabCtrl class implementation --
|
||||
|
||||
|
||||
const int wxAuiButtonClose = 101;
|
||||
|
||||
BEGIN_EVENT_TABLE(wxAuiTabCtrl, wxControl)
|
||||
EVT_PAINT(wxAuiTabCtrl::OnPaint)
|
||||
@@ -693,6 +905,7 @@ BEGIN_EVENT_TABLE(wxAuiTabCtrl, wxControl)
|
||||
EVT_LEFT_UP(wxAuiTabCtrl::OnLeftUp)
|
||||
EVT_MOTION(wxAuiTabCtrl::OnMotion)
|
||||
EVT_LEAVE_WINDOW(wxAuiTabCtrl::OnLeaveWindow)
|
||||
EVT_AUINOTEBOOK_BUTTON(-1, wxAuiTabCtrl::OnButton)
|
||||
END_EVENT_TABLE()
|
||||
|
||||
|
||||
@@ -705,26 +918,6 @@ wxAuiTabCtrl::wxAuiTabCtrl(wxWindow* parent,
|
||||
m_click_pt = wxDefaultPosition;
|
||||
m_is_dragging = false;
|
||||
m_hover_button = NULL;
|
||||
|
||||
// FIXME: copied from dockart-- needs to put in a common place
|
||||
#if defined( __WXMAC__ )
|
||||
static unsigned char close_bits[]={
|
||||
0xFF, 0xFF, 0xFF, 0xFF, 0x0F, 0xFE, 0x03, 0xF8, 0x01, 0xF0, 0x19, 0xF3,
|
||||
0xB8, 0xE3, 0xF0, 0xE1, 0xE0, 0xE0, 0xF0, 0xE1, 0xB8, 0xE3, 0x19, 0xF3,
|
||||
0x01, 0xF0, 0x03, 0xF8, 0x0F, 0xFE, 0xFF, 0xFF };
|
||||
#elif defined( __WXGTK__)
|
||||
static unsigned char close_bits[]={
|
||||
0xff, 0xff, 0xff, 0xff, 0x07, 0xf0, 0xfb, 0xef, 0xdb, 0xed, 0x8b, 0xe8,
|
||||
0x1b, 0xec, 0x3b, 0xee, 0x1b, 0xec, 0x8b, 0xe8, 0xdb, 0xed, 0xfb, 0xef,
|
||||
0x07, 0xf0, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };
|
||||
#else
|
||||
static unsigned char close_bits[]={
|
||||
0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xef,0xfb,0xcf,0xf9,
|
||||
0x9f,0xfc,0x3f,0xfe,0x3f,0xfe,0x9f,0xfc,0xcf,0xf9,0xef,0xfb,
|
||||
0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff};
|
||||
#endif
|
||||
|
||||
AddButton(101, wxRIGHT, BitmapFromBits(close_bits, 16, 16, *wxBLACK));
|
||||
}
|
||||
|
||||
|
||||
@@ -888,6 +1081,33 @@ void wxAuiTabCtrl::OnLeaveWindow(wxMouseEvent& WXUNUSED(event))
|
||||
}
|
||||
}
|
||||
|
||||
void wxAuiTabCtrl::OnButton(wxAuiNotebookEvent& event)
|
||||
{
|
||||
int button = event.GetInt();
|
||||
|
||||
if (button == wxAUI_BUTTON_LEFT || button == wxAUI_BUTTON_RIGHT)
|
||||
{
|
||||
if (button == wxAUI_BUTTON_LEFT)
|
||||
{
|
||||
if (GetTabOffset() > 0)
|
||||
{
|
||||
SetTabOffset(GetTabOffset()-1);
|
||||
Refresh();
|
||||
Update();
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
SetTabOffset(GetTabOffset()+1);
|
||||
Refresh();
|
||||
Update();
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
event.Skip();
|
||||
}
|
||||
}
|
||||
|
||||
// wxTabFrame is an interesting case. It's important that all child pages
|
||||
// of the multi-notebook control are all actually children of that control
|
||||
@@ -1656,7 +1876,7 @@ void wxAuiMultiNotebook::OnTabButton(wxCommandEvent& command_evt)
|
||||
|
||||
int button_id = evt.GetInt();
|
||||
|
||||
if (button_id == wxAuiButtonClose)
|
||||
if (button_id == wxAUI_BUTTON_CLOSE)
|
||||
{
|
||||
int selection = tabs->GetActivePage();
|
||||
|
||||
|
@@ -589,13 +589,13 @@ void wxDefaultDockArt::DrawPaneButton(wxDC& dc, wxWindow *WXUNUSED(window),
|
||||
switch (button)
|
||||
{
|
||||
default:
|
||||
case wxPaneInfo::buttonClose:
|
||||
case wxAUI_BUTTON_CLOSE:
|
||||
if (pane.state & wxPaneInfo::optionActive)
|
||||
bmp = m_active_close_bitmap;
|
||||
else
|
||||
bmp = m_inactive_close_bitmap;
|
||||
break;
|
||||
case wxPaneInfo::buttonPin:
|
||||
case wxAUI_BUTTON_PIN:
|
||||
if (pane.state & wxPaneInfo::optionActive)
|
||||
bmp = m_active_pin_bitmap;
|
||||
else
|
||||
|
@@ -821,7 +821,7 @@ bool wxFrameManager::AddPane(wxWindow* window, const wxPaneInfo& pane_info)
|
||||
pinfo.buttons.size() == 0)
|
||||
{
|
||||
wxPaneButton button;
|
||||
button.button_id = wxPaneInfo::buttonClose;
|
||||
button.button_id = wxAUI_BUTTON_CLOSE;
|
||||
pinfo.buttons.Add(button);
|
||||
}
|
||||
|
||||
@@ -3931,7 +3931,7 @@ void wxFrameManager::OnPaneButton(wxFrameManagerEvent& evt)
|
||||
|
||||
wxPaneInfo& pane = *(evt.pane);
|
||||
|
||||
if (evt.button == wxPaneInfo::buttonClose)
|
||||
if (evt.button == wxAUI_BUTTON_CLOSE)
|
||||
{
|
||||
// fire pane close event
|
||||
wxFrameManagerEvent e(wxEVT_AUI_PANECLOSE);
|
||||
|
Reference in New Issue
Block a user