Some more wxMotif improvements: DrawIcon fixed; generic notebook
implementation used. wxGTK's DrawIcon has 2 args added for wxMSW compatibility. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@1259 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -38,6 +38,13 @@ public:
|
|||||||
wxIcon();
|
wxIcon();
|
||||||
wxIcon( const wxIcon& icon);
|
wxIcon( const wxIcon& icon);
|
||||||
wxIcon( const char **bits, int width=-1, int height=-1 );
|
wxIcon( const char **bits, int width=-1, int height=-1 );
|
||||||
|
|
||||||
|
// For compatibility with wxMSW where desired size is sometimes required to
|
||||||
|
// distinguish between multiple icons in a resource.
|
||||||
|
wxIcon( const wxString& filename, int type = wxBITMAP_TYPE_XPM, int WXUNUSED(desiredWidth)=-1, int WXUNUSED(desiredHeight)=-1 ):
|
||||||
|
wxBitmap(filename, type)
|
||||||
|
{
|
||||||
|
}
|
||||||
wxIcon( char **bits, int width=-1, int height=-1 );
|
wxIcon( char **bits, int width=-1, int height=-1 );
|
||||||
|
|
||||||
wxIcon& operator = (const wxIcon& icon);
|
wxIcon& operator = (const wxIcon& icon);
|
||||||
|
@@ -38,6 +38,13 @@ public:
|
|||||||
wxIcon();
|
wxIcon();
|
||||||
wxIcon( const wxIcon& icon);
|
wxIcon( const wxIcon& icon);
|
||||||
wxIcon( const char **bits, int width=-1, int height=-1 );
|
wxIcon( const char **bits, int width=-1, int height=-1 );
|
||||||
|
|
||||||
|
// For compatibility with wxMSW where desired size is sometimes required to
|
||||||
|
// distinguish between multiple icons in a resource.
|
||||||
|
wxIcon( const wxString& filename, int type = wxBITMAP_TYPE_XPM, int WXUNUSED(desiredWidth)=-1, int WXUNUSED(desiredHeight)=-1 ):
|
||||||
|
wxBitmap(filename, type)
|
||||||
|
{
|
||||||
|
}
|
||||||
wxIcon( char **bits, int width=-1, int height=-1 );
|
wxIcon( char **bits, int width=-1, int height=-1 );
|
||||||
|
|
||||||
wxIcon& operator = (const wxIcon& icon);
|
wxIcon& operator = (const wxIcon& icon);
|
||||||
|
@@ -142,7 +142,7 @@ class WXDLLEXPORT wxDC: public wxObject
|
|||||||
|
|
||||||
virtual bool CanDrawBitmap(void) const = 0;
|
virtual bool CanDrawBitmap(void) const = 0;
|
||||||
|
|
||||||
virtual void DrawIcon( const wxIcon &icon, long x, long y, bool useMask=FALSE );
|
virtual void DrawIcon( const wxIcon &icon, long x, long y);
|
||||||
inline void DrawIcon(const wxIcon& icon, const wxPoint& pt)
|
inline void DrawIcon(const wxIcon& icon, const wxPoint& pt)
|
||||||
{
|
{
|
||||||
DrawIcon(icon, pt.x, pt.y);
|
DrawIcon(icon, pt.x, pt.y);
|
||||||
|
@@ -64,7 +64,7 @@ class WXDLLEXPORT wxWindowDC: public wxDC
|
|||||||
virtual void DrawEllipse( long x, long y, long width, long height );
|
virtual void DrawEllipse( long x, long y, long width, long height );
|
||||||
|
|
||||||
virtual bool CanDrawBitmap(void) const;
|
virtual bool CanDrawBitmap(void) const;
|
||||||
virtual void DrawIcon( const wxIcon &icon, long x, long y, bool useMask=FALSE );
|
virtual void DrawIcon( const wxIcon &icon, long x, long y);
|
||||||
virtual bool Blit( long xdest, long ydest, long width, long height,
|
virtual bool Blit( long xdest, long ydest, long width, long height,
|
||||||
wxDC *source, long xsrc, long ysrc, int logical_func = wxCOPY, bool useMask=FALSE );
|
wxDC *source, long xsrc, long ysrc, int logical_func = wxCOPY, bool useMask=FALSE );
|
||||||
|
|
||||||
|
@@ -1,250 +0,0 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Name: notebook.h
|
|
||||||
// Purpose: wxNotebook class (a.k.a. property sheet, tabbed dialog)
|
|
||||||
// Author: Julian Smart
|
|
||||||
// Modified by:
|
|
||||||
// RCS-ID: $Id$
|
|
||||||
// Copyright: (c) Julian Smart
|
|
||||||
// Licence: wxWindows licence
|
|
||||||
/////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
#ifndef _WX_NOTEBOOK_H_
|
|
||||||
#define _WX_NOTEBOOK_H_
|
|
||||||
|
|
||||||
#ifdef __GNUG__
|
|
||||||
#pragma interface "notebook.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// headers
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
#include "wx/dynarray.h"
|
|
||||||
#include "wx/event.h"
|
|
||||||
#include "wx/control.h"
|
|
||||||
#include "wx/generic/tabg.h"
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// types
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
// fwd declarations
|
|
||||||
class WXDLLEXPORT wxImageList;
|
|
||||||
class WXDLLEXPORT wxWindow;
|
|
||||||
|
|
||||||
// array of notebook pages
|
|
||||||
typedef wxWindow wxNotebookPage; // so far, any window can be a page
|
|
||||||
WX_DEFINE_ARRAY(wxNotebookPage *, wxArrayPages);
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// notebook events
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
class WXDLLEXPORT wxNotebookEvent : public wxCommandEvent
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
wxNotebookEvent(wxEventType commandType = wxEVT_NULL, int id = 0,
|
|
||||||
int nSel = -1, int nOldSel = -1)
|
|
||||||
: wxCommandEvent(commandType, id) { m_nSel = nSel; m_nOldSel = nOldSel; }
|
|
||||||
|
|
||||||
// accessors
|
|
||||||
int GetSelection() const { return m_nSel; }
|
|
||||||
int GetOldSelection() const { return m_nOldSel; }
|
|
||||||
|
|
||||||
void SetSelection(int sel) { m_nSel = sel; }
|
|
||||||
void SetOldSelection(int oldSel) { m_nOldSel = oldSel; }
|
|
||||||
|
|
||||||
private:
|
|
||||||
int m_nSel, // currently selected page
|
|
||||||
m_nOldSel; // previously selected page
|
|
||||||
|
|
||||||
DECLARE_DYNAMIC_CLASS(wxNotebookEvent)
|
|
||||||
};
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// wxNotebook
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
class WXDLLEXPORT wxNotebook;
|
|
||||||
|
|
||||||
// This reuses wxTabView to draw the tabs.
|
|
||||||
class WXDLLEXPORT wxNotebookTabView: public wxTabView
|
|
||||||
{
|
|
||||||
DECLARE_DYNAMIC_CLASS(wxNotebookTabView)
|
|
||||||
public:
|
|
||||||
wxNotebookTabView(wxNotebook* notebook, long style = wxTAB_STYLE_DRAW_BOX | wxTAB_STYLE_COLOUR_INTERIOR);
|
|
||||||
~wxNotebookTabView(void);
|
|
||||||
|
|
||||||
// Called when a tab is activated
|
|
||||||
virtual void OnTabActivate(int activateId, int deactivateId);
|
|
||||||
|
|
||||||
protected:
|
|
||||||
wxNotebook* m_notebook;
|
|
||||||
};
|
|
||||||
|
|
||||||
class wxNotebook : public wxControl
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
// ctors
|
|
||||||
// -----
|
|
||||||
// default for dynamic class
|
|
||||||
wxNotebook();
|
|
||||||
// the same arguments as for wxControl (@@@ any special styles?)
|
|
||||||
wxNotebook(wxWindow *parent,
|
|
||||||
wxWindowID id,
|
|
||||||
const wxPoint& pos = wxDefaultPosition,
|
|
||||||
const wxSize& size = wxDefaultSize,
|
|
||||||
long style = 0,
|
|
||||||
const wxString& name = "notebook");
|
|
||||||
// Create() function
|
|
||||||
bool Create(wxWindow *parent,
|
|
||||||
wxWindowID id,
|
|
||||||
const wxPoint& pos = wxDefaultPosition,
|
|
||||||
const wxSize& size = wxDefaultSize,
|
|
||||||
long style = 0,
|
|
||||||
const wxString& name = "notebook");
|
|
||||||
// dtor
|
|
||||||
~wxNotebook();
|
|
||||||
|
|
||||||
// accessors
|
|
||||||
// ---------
|
|
||||||
// get number of pages in the dialog
|
|
||||||
int GetPageCount() const;
|
|
||||||
|
|
||||||
// Find the position of the wxNotebookPage, -1 if not found.
|
|
||||||
int FindPagePosition(wxNotebookPage* page) const;
|
|
||||||
|
|
||||||
// set the currently selected page, return the index of the previously
|
|
||||||
// selected one (or -1 on error)
|
|
||||||
// NB: this function will _not_ generate wxEVT_NOTEBOOK_PAGE_xxx events
|
|
||||||
int SetSelection(int nPage);
|
|
||||||
// cycle thru the tabs
|
|
||||||
void AdvanceSelection(bool bForward = TRUE);
|
|
||||||
// get the currently selected page
|
|
||||||
int GetSelection() const { return m_nSelection; }
|
|
||||||
|
|
||||||
// set/get the title of a page
|
|
||||||
bool SetPageText(int nPage, const wxString& strText);
|
|
||||||
wxString GetPageText(int nPage) const;
|
|
||||||
|
|
||||||
// image list stuff: each page may have an image associated with it. All
|
|
||||||
// the images belong to an image list, so you have to
|
|
||||||
// 1) create an image list
|
|
||||||
// 2) associate it with the notebook
|
|
||||||
// 3) set for each page it's image
|
|
||||||
// associate image list with a control
|
|
||||||
void SetImageList(wxImageList* imageList);
|
|
||||||
// get pointer (may be NULL) to the associated image list
|
|
||||||
wxImageList* GetImageList() const { return m_pImageList; }
|
|
||||||
|
|
||||||
// sets/returns item's image index in the current image list
|
|
||||||
int GetPageImage(int nPage) const;
|
|
||||||
bool SetPageImage(int nPage, int nImage);
|
|
||||||
|
|
||||||
// currently it's always 1 because wxGTK doesn't support multi-row
|
|
||||||
// tab controls
|
|
||||||
int GetRowCount() const;
|
|
||||||
|
|
||||||
// control the appearance of the notebook pages
|
|
||||||
// set the size (the same for all pages)
|
|
||||||
void SetPageSize(const wxSize& size);
|
|
||||||
// set the padding between tabs (in pixels)
|
|
||||||
void SetPadding(const wxSize& padding);
|
|
||||||
|
|
||||||
// operations
|
|
||||||
// ----------
|
|
||||||
// remove one page from the notebook, and delete the page.
|
|
||||||
bool DeletePage(int nPage);
|
|
||||||
bool DeletePage(wxNotebookPage* page);
|
|
||||||
// remove one page from the notebook, without deleting the page.
|
|
||||||
bool RemovePage(int nPage);
|
|
||||||
bool RemovePage(wxNotebookPage* page);
|
|
||||||
// remove all pages
|
|
||||||
bool DeleteAllPages();
|
|
||||||
// adds a new page to the notebook (it will be deleted ny the notebook,
|
|
||||||
// don't delete it yourself). If bSelect, this page becomes active.
|
|
||||||
bool AddPage(wxNotebookPage *pPage,
|
|
||||||
const wxString& strText,
|
|
||||||
bool bSelect = FALSE,
|
|
||||||
int imageId = -1);
|
|
||||||
// the same as AddPage(), but adds it at the specified position
|
|
||||||
bool InsertPage(int nPage,
|
|
||||||
wxNotebookPage *pPage,
|
|
||||||
const wxString& strText,
|
|
||||||
bool bSelect = FALSE,
|
|
||||||
int imageId = -1);
|
|
||||||
// get the panel which represents the given page
|
|
||||||
wxNotebookPage *GetPage(int nPage) { return m_aPages[nPage]; }
|
|
||||||
|
|
||||||
// callbacks
|
|
||||||
// ---------
|
|
||||||
void OnSize(wxSizeEvent& event);
|
|
||||||
void OnIdle(wxIdleEvent& event);
|
|
||||||
void OnSelChange(wxNotebookEvent& event);
|
|
||||||
void OnSetFocus(wxFocusEvent& event);
|
|
||||||
void OnNavigationKey(wxNavigationKeyEvent& event);
|
|
||||||
|
|
||||||
// base class virtuals
|
|
||||||
// -------------------
|
|
||||||
virtual void Command(wxCommandEvent& event);
|
|
||||||
virtual void SetConstraintSizes(bool recurse = TRUE);
|
|
||||||
virtual bool DoPhase(int nPhase);
|
|
||||||
|
|
||||||
// Implementation
|
|
||||||
|
|
||||||
// wxNotebook on Motif uses a generic wxTabView to implement itself.
|
|
||||||
inline wxTabView *GetTabView() const { return m_tabView; }
|
|
||||||
inline void SetTabView(wxTabView *v) { m_tabView = v; }
|
|
||||||
|
|
||||||
void OnMouseEvent(wxMouseEvent& event);
|
|
||||||
void OnPaint(wxPaintEvent& event);
|
|
||||||
|
|
||||||
virtual void ChangeFont(bool keepOriginalSize = TRUE);
|
|
||||||
virtual void ChangeBackgroundColour();
|
|
||||||
virtual void ChangeForegroundColour();
|
|
||||||
virtual wxRect GetAvailableClientSize();
|
|
||||||
|
|
||||||
// Implementation: calculate the layout of the view rect
|
|
||||||
// and resize the children if required
|
|
||||||
bool RefreshLayout(bool force = TRUE);
|
|
||||||
|
|
||||||
protected:
|
|
||||||
// common part of all ctors
|
|
||||||
void Init();
|
|
||||||
|
|
||||||
// helper functions
|
|
||||||
void ChangePage(int nOldSel, int nSel); // change pages
|
|
||||||
|
|
||||||
wxImageList *m_pImageList; // we can have an associated image list
|
|
||||||
wxArrayPages m_aPages; // array of pages
|
|
||||||
|
|
||||||
int m_nSelection; // the current selection (-1 if none)
|
|
||||||
|
|
||||||
wxTabView* m_tabView;
|
|
||||||
|
|
||||||
DECLARE_DYNAMIC_CLASS(wxNotebook)
|
|
||||||
DECLARE_EVENT_TABLE()
|
|
||||||
};
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// event macros
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
typedef void (wxEvtHandler::*wxNotebookEventFunction)(wxNotebookEvent&);
|
|
||||||
|
|
||||||
#define EVT_NOTEBOOK_PAGE_CHANGED(id, fn) \
|
|
||||||
{ \
|
|
||||||
wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGED, \
|
|
||||||
id, \
|
|
||||||
-1, \
|
|
||||||
(wxObjectEventFunction)(wxEventFunction)(wxNotebookEventFunction) &fn, \
|
|
||||||
NULL \
|
|
||||||
},
|
|
||||||
|
|
||||||
#define EVT_NOTEBOOK_PAGE_CHANGING(id, fn) \
|
|
||||||
{ \
|
|
||||||
wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGING, \ \
|
|
||||||
id, \
|
|
||||||
-1, \
|
|
||||||
(wxObjectEventFunction)(wxEventFunction)(wxNotebookEventFunction) &fn, \
|
|
||||||
NULL \
|
|
||||||
},
|
|
||||||
|
|
||||||
#endif // _WX_NOTEBOOK_H_
|
|
@@ -8,7 +8,7 @@
|
|||||||
#include "wx/msw/notebook.h"
|
#include "wx/msw/notebook.h"
|
||||||
#endif
|
#endif
|
||||||
#elif defined(__WXMOTIF__)
|
#elif defined(__WXMOTIF__)
|
||||||
#include "wx/motif/notebook.h"
|
#include "wx/generic/notebook.h"
|
||||||
#elif defined(__WXGTK__)
|
#elif defined(__WXGTK__)
|
||||||
#include "wx/gtk/notebook.h"
|
#include "wx/gtk/notebook.h"
|
||||||
#elif defined(__WXQT__)
|
#elif defined(__WXQT__)
|
||||||
|
@@ -29,7 +29,8 @@
|
|||||||
|
|
||||||
#include <wx/string.h>
|
#include <wx/string.h>
|
||||||
#include <wx/log.h>
|
#include <wx/log.h>
|
||||||
#include <wx/imaglist.h>
|
#include <wx/settings.h>
|
||||||
|
#include <wx/generic/imaglist.h>
|
||||||
#include <wx/generic/notebook.h>
|
#include <wx/generic/notebook.h>
|
||||||
#include <wx/dcclient.h>
|
#include <wx/dcclient.h>
|
||||||
|
|
||||||
|
@@ -91,7 +91,7 @@ wxDC::~wxDC(void)
|
|||||||
{
|
{
|
||||||
};
|
};
|
||||||
|
|
||||||
void wxDC::DrawIcon( const wxIcon &WXUNUSED(icon), long WXUNUSED(x), long WXUNUSED(y), bool WXUNUSED(useMask) )
|
void wxDC::DrawIcon( const wxIcon &WXUNUSED(icon), long WXUNUSED(x), long WXUNUSED(y))
|
||||||
{
|
{
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@@ -849,12 +849,15 @@ static void XCopyRemote(Display *src_display, Display *dest_display,
|
|||||||
XDestroyImage(image);
|
XDestroyImage(image);
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindowDC::DrawIcon( const wxIcon &icon, long x, long y, bool useMask )
|
void wxWindowDC::DrawIcon( const wxIcon &icon, long x, long y)
|
||||||
{
|
{
|
||||||
if (!Ok()) return;
|
if (!Ok()) return;
|
||||||
|
|
||||||
if (!icon.Ok()) return;
|
if (!icon.Ok()) return;
|
||||||
|
|
||||||
|
DrawBitmap(icon, x, y, TRUE);
|
||||||
|
|
||||||
|
#if 0
|
||||||
// FreeGetPixelCache();
|
// FreeGetPixelCache();
|
||||||
|
|
||||||
// Be sure that foreground pixels (1) of
|
// Be sure that foreground pixels (1) of
|
||||||
@@ -909,7 +912,7 @@ void wxWindowDC::DrawIcon( const wxIcon &icon, long x, long y, bool useMask )
|
|||||||
(int) XLOG2DEV (x), (int) YLOG2DEV (y), FALSE, &cache);
|
(int) XLOG2DEV (x), (int) YLOG2DEV (y), FALSE, &cache);
|
||||||
}
|
}
|
||||||
CalcBoundingBox (x, y);
|
CalcBoundingBox (x, y);
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
bool wxWindowDC::Blit( long xdest, long ydest, long width, long height,
|
bool wxWindowDC::Blit( long xdest, long ydest, long width, long height,
|
||||||
|
@@ -475,7 +475,7 @@ int wxDialog::ShowModal()
|
|||||||
wxModalShowingStack.Insert((wxObject *)TRUE);
|
wxModalShowingStack.Insert((wxObject *)TRUE);
|
||||||
|
|
||||||
m_modalShowing = TRUE;
|
m_modalShowing = TRUE;
|
||||||
// XtAddGrab((Widget) m_mainWidget, TRUE, FALSE);
|
XtAddGrab((Widget) m_mainWidget, TRUE, FALSE);
|
||||||
|
|
||||||
XEvent event;
|
XEvent event;
|
||||||
|
|
||||||
|
@@ -109,7 +109,6 @@ LIB_CPP_SRC=\
|
|||||||
metafile.cpp \
|
metafile.cpp \
|
||||||
minifram.cpp \
|
minifram.cpp \
|
||||||
msgdlg.cpp \
|
msgdlg.cpp \
|
||||||
notebook.cpp \
|
|
||||||
palette.cpp \
|
palette.cpp \
|
||||||
pen.cpp \
|
pen.cpp \
|
||||||
print.cpp \
|
print.cpp \
|
||||||
@@ -143,6 +142,7 @@ LIB_CPP_SRC=\
|
|||||||
../generic/listctrl.cpp \
|
../generic/listctrl.cpp \
|
||||||
../generic/laywin.cpp \
|
../generic/laywin.cpp \
|
||||||
../generic/msgdlgg.cpp \
|
../generic/msgdlgg.cpp \
|
||||||
|
../generic/notebook.cpp \
|
||||||
../generic/panelg.cpp \
|
../generic/panelg.cpp \
|
||||||
../generic/printps.cpp \
|
../generic/printps.cpp \
|
||||||
../generic/prntdlgg.cpp \
|
../generic/prntdlgg.cpp \
|
||||||
|
@@ -1,653 +0,0 @@
|
|||||||
///////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Name: notebook.cpp
|
|
||||||
// Purpose: implementation of wxNotebook
|
|
||||||
// Author: Julian Smart
|
|
||||||
// Modified by:
|
|
||||||
// Created: 17/09/98
|
|
||||||
// RCS-ID: $Id$
|
|
||||||
// Copyright: (c) Julian Smart
|
|
||||||
// Licence: wxWindows licence
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
// ============================================================================
|
|
||||||
// declarations
|
|
||||||
// ============================================================================
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// headers
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
#ifdef __GNUG__
|
|
||||||
#pragma implementation "notebook.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <wx/string.h>
|
|
||||||
#include <wx/log.h>
|
|
||||||
#include <wx/imaglist.h>
|
|
||||||
#include <wx/notebook.h>
|
|
||||||
#include <wx/dcclient.h>
|
|
||||||
|
|
||||||
#include <Xm/Xm.h>
|
|
||||||
#include <wx/motif/private.h>
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// macros
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
// check that the page index is valid
|
|
||||||
#define IS_VALID_PAGE(nPage) (((nPage) >= 0) && ((nPage) < GetPageCount()))
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// event table
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
#if !USE_SHARED_LIBRARIES
|
|
||||||
BEGIN_EVENT_TABLE(wxNotebook, wxControl)
|
|
||||||
EVT_NOTEBOOK_PAGE_CHANGED(-1, wxNotebook::OnSelChange)
|
|
||||||
EVT_SIZE(wxNotebook::OnSize)
|
|
||||||
EVT_PAINT(wxNotebook::OnPaint)
|
|
||||||
EVT_MOUSE_EVENTS(wxNotebook::OnMouseEvent)
|
|
||||||
EVT_SET_FOCUS(wxNotebook::OnSetFocus)
|
|
||||||
EVT_NAVIGATION_KEY(wxNotebook::OnNavigationKey)
|
|
||||||
EVT_IDLE(wxNotebook::OnIdle)
|
|
||||||
END_EVENT_TABLE()
|
|
||||||
|
|
||||||
IMPLEMENT_DYNAMIC_CLASS(wxNotebook, wxControl)
|
|
||||||
IMPLEMENT_DYNAMIC_CLASS(wxNotebookEvent, wxCommandEvent)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// ============================================================================
|
|
||||||
// implementation
|
|
||||||
// ============================================================================
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// wxNotebook construction
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
// common part of all ctors
|
|
||||||
void wxNotebook::Init()
|
|
||||||
{
|
|
||||||
m_tabView = (wxNotebookTabView*) NULL;
|
|
||||||
m_pImageList = NULL;
|
|
||||||
m_nSelection = -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
// default for dynamic class
|
|
||||||
wxNotebook::wxNotebook()
|
|
||||||
{
|
|
||||||
Init();
|
|
||||||
}
|
|
||||||
|
|
||||||
// the same arguments as for wxControl
|
|
||||||
wxNotebook::wxNotebook(wxWindow *parent,
|
|
||||||
wxWindowID id,
|
|
||||||
const wxPoint& pos,
|
|
||||||
const wxSize& size,
|
|
||||||
long style,
|
|
||||||
const wxString& name)
|
|
||||||
{
|
|
||||||
Init();
|
|
||||||
|
|
||||||
Create(parent, id, pos, size, style, name);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create() function
|
|
||||||
bool wxNotebook::Create(wxWindow *parent,
|
|
||||||
wxWindowID id,
|
|
||||||
const wxPoint& pos,
|
|
||||||
const wxSize& size,
|
|
||||||
long style,
|
|
||||||
const wxString& name)
|
|
||||||
{
|
|
||||||
// base init
|
|
||||||
SetName(name);
|
|
||||||
|
|
||||||
m_windowId = id == -1 ? NewControlId() : id;
|
|
||||||
|
|
||||||
// It's like a normal window...
|
|
||||||
if (!wxWindow::Create(parent, id, pos, size, style, name))
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
SetTabView(new wxNotebookTabView(this));
|
|
||||||
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
// dtor
|
|
||||||
wxNotebook::~wxNotebook()
|
|
||||||
{
|
|
||||||
delete m_tabView;
|
|
||||||
}
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// wxNotebook accessors
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
int wxNotebook::GetPageCount() const
|
|
||||||
{
|
|
||||||
return m_aPages.Count();
|
|
||||||
}
|
|
||||||
|
|
||||||
int wxNotebook::GetRowCount() const
|
|
||||||
{
|
|
||||||
// TODO
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int wxNotebook::SetSelection(int nPage)
|
|
||||||
{
|
|
||||||
if (nPage == -1)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
wxASSERT( IS_VALID_PAGE(nPage) );
|
|
||||||
|
|
||||||
wxNotebookPage* pPage = GetPage(nPage);
|
|
||||||
|
|
||||||
m_tabView->SetTabSelection((int) (long) pPage);
|
|
||||||
|
|
||||||
// TODO
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxNotebook::AdvanceSelection(bool bForward)
|
|
||||||
{
|
|
||||||
int nSel = GetSelection();
|
|
||||||
int nMax = GetPageCount() - 1;
|
|
||||||
if ( bForward )
|
|
||||||
SetSelection(nSel == nMax ? 0 : nSel + 1);
|
|
||||||
else
|
|
||||||
SetSelection(nSel == 0 ? nMax : nSel - 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool wxNotebook::SetPageText(int nPage, const wxString& strText)
|
|
||||||
{
|
|
||||||
wxASSERT( IS_VALID_PAGE(nPage) );
|
|
||||||
|
|
||||||
wxNotebookPage* page = GetPage(nPage);
|
|
||||||
if (page)
|
|
||||||
{
|
|
||||||
m_tabView->SetTabText((int) (long) page, strText);
|
|
||||||
Refresh();
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
wxString wxNotebook::GetPageText(int nPage) const
|
|
||||||
{
|
|
||||||
wxASSERT( IS_VALID_PAGE(nPage) );
|
|
||||||
|
|
||||||
wxNotebookPage* page = ((wxNotebook*)this)->GetPage(nPage);
|
|
||||||
if (page)
|
|
||||||
return m_tabView->GetTabText((int) (long) page);
|
|
||||||
else
|
|
||||||
return wxEmptyString;
|
|
||||||
}
|
|
||||||
|
|
||||||
int wxNotebook::GetPageImage(int nPage) const
|
|
||||||
{
|
|
||||||
wxASSERT( IS_VALID_PAGE(nPage) );
|
|
||||||
|
|
||||||
// TODO
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool wxNotebook::SetPageImage(int nPage, int nImage)
|
|
||||||
{
|
|
||||||
wxASSERT( IS_VALID_PAGE(nPage) );
|
|
||||||
|
|
||||||
// TODO
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxNotebook::SetImageList(wxImageList* imageList)
|
|
||||||
{
|
|
||||||
m_pImageList = imageList;
|
|
||||||
// TODO
|
|
||||||
}
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// wxNotebook operations
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
// remove one page from the notebook and delete it
|
|
||||||
bool wxNotebook::DeletePage(int nPage)
|
|
||||||
{
|
|
||||||
wxCHECK( IS_VALID_PAGE(nPage), FALSE );
|
|
||||||
|
|
||||||
if (m_nSelection != -1)
|
|
||||||
{
|
|
||||||
m_aPages[m_nSelection]->Show(FALSE);
|
|
||||||
m_aPages[m_nSelection]->Lower();
|
|
||||||
}
|
|
||||||
|
|
||||||
wxNotebookPage* pPage = GetPage(nPage);
|
|
||||||
m_tabView->RemoveTab((int) (long) pPage);
|
|
||||||
|
|
||||||
delete m_aPages[nPage];
|
|
||||||
m_aPages.Remove(nPage);
|
|
||||||
|
|
||||||
if (m_aPages.GetCount() == 0)
|
|
||||||
{
|
|
||||||
m_nSelection = -1;
|
|
||||||
m_tabView->SetTabSelection(-1, FALSE);
|
|
||||||
}
|
|
||||||
else if (m_nSelection > -1)
|
|
||||||
{
|
|
||||||
m_nSelection = -1;
|
|
||||||
m_tabView->SetTabSelection((int) (long) GetPage(0), FALSE);
|
|
||||||
if (m_nSelection != 0)
|
|
||||||
ChangePage(-1, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
RefreshLayout(FALSE);
|
|
||||||
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool wxNotebook::DeletePage(wxNotebookPage* page)
|
|
||||||
{
|
|
||||||
int pagePos = FindPagePosition(page);
|
|
||||||
if (pagePos > -1)
|
|
||||||
return DeletePage(pagePos);
|
|
||||||
else
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
// remove one page from the notebook
|
|
||||||
bool wxNotebook::RemovePage(int nPage)
|
|
||||||
{
|
|
||||||
wxCHECK( IS_VALID_PAGE(nPage), FALSE );
|
|
||||||
|
|
||||||
m_aPages[nPage]->Show(FALSE);
|
|
||||||
// m_aPages[nPage]->Lower();
|
|
||||||
|
|
||||||
wxNotebookPage* pPage = GetPage(nPage);
|
|
||||||
m_tabView->RemoveTab((int) (long) pPage);
|
|
||||||
|
|
||||||
m_aPages.Remove(nPage);
|
|
||||||
|
|
||||||
if (m_aPages.GetCount() == 0)
|
|
||||||
{
|
|
||||||
m_nSelection = -1;
|
|
||||||
m_tabView->SetTabSelection(-1, TRUE);
|
|
||||||
}
|
|
||||||
else if (m_nSelection > -1)
|
|
||||||
{
|
|
||||||
// Only change the selection if the page we
|
|
||||||
// deleted was the selection.
|
|
||||||
if (nPage == m_nSelection)
|
|
||||||
{
|
|
||||||
m_nSelection = -1;
|
|
||||||
// Select the first tab. Generates a ChangePage.
|
|
||||||
m_tabView->SetTabSelection((int) (long) GetPage(0), TRUE);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// We must adjust which tab we think is selected.
|
|
||||||
// If greater than the page we deleted, it must be moved down
|
|
||||||
// a notch.
|
|
||||||
if (m_nSelection > nPage)
|
|
||||||
m_nSelection -- ;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
RefreshLayout(FALSE);
|
|
||||||
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool wxNotebook::RemovePage(wxNotebookPage* page)
|
|
||||||
{
|
|
||||||
int pagePos = FindPagePosition(page);
|
|
||||||
if (pagePos > -1)
|
|
||||||
return RemovePage(pagePos);
|
|
||||||
else
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Find the position of the wxNotebookPage, -1 if not found.
|
|
||||||
int wxNotebook::FindPagePosition(wxNotebookPage* page) const
|
|
||||||
{
|
|
||||||
int nPageCount = GetPageCount();
|
|
||||||
int nPage;
|
|
||||||
for ( nPage = 0; nPage < nPageCount; nPage++ )
|
|
||||||
if (m_aPages[nPage] == page)
|
|
||||||
return nPage;
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
// remove all pages
|
|
||||||
bool wxNotebook::DeleteAllPages()
|
|
||||||
{
|
|
||||||
m_tabView->ClearTabs(TRUE);
|
|
||||||
|
|
||||||
int nPageCount = GetPageCount();
|
|
||||||
int nPage;
|
|
||||||
for ( nPage = 0; nPage < nPageCount; nPage++ )
|
|
||||||
delete m_aPages[nPage];
|
|
||||||
|
|
||||||
m_aPages.Clear();
|
|
||||||
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
// add a page to the notebook
|
|
||||||
bool wxNotebook::AddPage(wxNotebookPage *pPage,
|
|
||||||
const wxString& strText,
|
|
||||||
bool bSelect,
|
|
||||||
int imageId)
|
|
||||||
{
|
|
||||||
return InsertPage(GetPageCount(), pPage, strText, bSelect, imageId);
|
|
||||||
}
|
|
||||||
|
|
||||||
// same as AddPage() but does it at given position
|
|
||||||
bool wxNotebook::InsertPage(int nPage,
|
|
||||||
wxNotebookPage *pPage,
|
|
||||||
const wxString& strText,
|
|
||||||
bool bSelect,
|
|
||||||
int imageId)
|
|
||||||
{
|
|
||||||
wxASSERT( pPage != NULL );
|
|
||||||
wxCHECK( IS_VALID_PAGE(nPage) || nPage == GetPageCount(), FALSE );
|
|
||||||
|
|
||||||
m_tabView->AddTab((int) (long) pPage, strText);
|
|
||||||
if (!bSelect)
|
|
||||||
pPage->Show(FALSE);
|
|
||||||
|
|
||||||
// save the pointer to the page
|
|
||||||
m_aPages.Insert(pPage, nPage);
|
|
||||||
|
|
||||||
if (bSelect)
|
|
||||||
{
|
|
||||||
// This will cause ChangePage to be called, via OnSelPage
|
|
||||||
m_tabView->SetTabSelection((int) (long) pPage, TRUE);
|
|
||||||
}
|
|
||||||
|
|
||||||
// some page must be selected: either this one or the first one if there is
|
|
||||||
// still no selection
|
|
||||||
if ( m_nSelection == -1 )
|
|
||||||
ChangePage(-1, 0);
|
|
||||||
|
|
||||||
RefreshLayout(FALSE);
|
|
||||||
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// wxNotebook callbacks
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
// @@@ OnSize() is used for setting the font when it's called for the first
|
|
||||||
// time because doing it in ::Create() doesn't work (for unknown reasons)
|
|
||||||
void wxNotebook::OnSize(wxSizeEvent& event)
|
|
||||||
{
|
|
||||||
static bool s_bFirstTime = TRUE;
|
|
||||||
if ( s_bFirstTime ) {
|
|
||||||
// TODO: any first-time-size processing.
|
|
||||||
s_bFirstTime = FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
RefreshLayout();
|
|
||||||
|
|
||||||
// Processing continues to next OnSize
|
|
||||||
event.Skip();
|
|
||||||
}
|
|
||||||
|
|
||||||
// This was supposed to cure the non-display of the notebook
|
|
||||||
// until the user resizes the window.
|
|
||||||
// What's going on?
|
|
||||||
void wxNotebook::OnIdle(wxIdleEvent& event)
|
|
||||||
{
|
|
||||||
static bool s_bFirstTime = TRUE;
|
|
||||||
if ( s_bFirstTime ) {
|
|
||||||
/*
|
|
||||||
wxSize sz(GetSize());
|
|
||||||
sz.x ++;
|
|
||||||
SetSize(sz);
|
|
||||||
sz.x --;
|
|
||||||
SetSize(sz);
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
wxSize sz(GetSize());
|
|
||||||
wxSizeEvent sizeEvent(sz, GetId());
|
|
||||||
sizeEvent.SetEventObject(this);
|
|
||||||
GetEventHandler()->ProcessEvent(sizeEvent);
|
|
||||||
Refresh();
|
|
||||||
*/
|
|
||||||
s_bFirstTime = FALSE;
|
|
||||||
}
|
|
||||||
event.Skip();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Implementation: calculate the layout of the view rect
|
|
||||||
// and resize the children if required
|
|
||||||
bool wxNotebook::RefreshLayout(bool force)
|
|
||||||
{
|
|
||||||
if (m_tabView)
|
|
||||||
{
|
|
||||||
wxRect oldRect = m_tabView->GetViewRect();
|
|
||||||
|
|
||||||
int cw, ch;
|
|
||||||
GetClientSize(& cw, & ch);
|
|
||||||
|
|
||||||
int tabHeight = m_tabView->GetTotalTabHeight();
|
|
||||||
wxRect rect;
|
|
||||||
rect.x = 4;
|
|
||||||
rect.y = tabHeight + 4;
|
|
||||||
rect.width = cw - 8;
|
|
||||||
rect.height = ch - 4 - rect.y ;
|
|
||||||
|
|
||||||
m_tabView->SetViewRect(rect);
|
|
||||||
|
|
||||||
m_tabView->Layout();
|
|
||||||
|
|
||||||
// Need to do it a 2nd time to get the tab height with
|
|
||||||
// the new view width, since changing the view width changes the
|
|
||||||
// tab layout.
|
|
||||||
tabHeight = m_tabView->GetTotalTabHeight();
|
|
||||||
rect.x = 4;
|
|
||||||
rect.y = tabHeight + 4;
|
|
||||||
rect.width = cw - 8;
|
|
||||||
rect.height = ch - 4 - rect.y ;
|
|
||||||
|
|
||||||
m_tabView->SetViewRect(rect);
|
|
||||||
|
|
||||||
m_tabView->Layout();
|
|
||||||
|
|
||||||
if (!force && (rect == oldRect))
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
// fit the notebook page to the tab control's display area
|
|
||||||
|
|
||||||
unsigned int nCount = m_aPages.Count();
|
|
||||||
for ( unsigned int nPage = 0; nPage < nCount; nPage++ ) {
|
|
||||||
wxNotebookPage *pPage = m_aPages[nPage];
|
|
||||||
if (pPage->IsShown())
|
|
||||||
{
|
|
||||||
wxRect clientRect = GetAvailableClientSize();
|
|
||||||
pPage->SetSize(clientRect.x, clientRect.y, clientRect.width, clientRect.height);
|
|
||||||
if ( pPage->GetAutoLayout() )
|
|
||||||
pPage->Layout();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Refresh();
|
|
||||||
}
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxNotebook::OnSelChange(wxNotebookEvent& event)
|
|
||||||
{
|
|
||||||
// is it our tab control?
|
|
||||||
if ( event.GetEventObject() == this )
|
|
||||||
{
|
|
||||||
if (event.GetSelection() != m_nSelection)
|
|
||||||
ChangePage(event.GetOldSelection(), event.GetSelection());
|
|
||||||
}
|
|
||||||
|
|
||||||
// we want to give others a chance to process this message as well
|
|
||||||
event.Skip();
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxNotebook::OnSetFocus(wxFocusEvent& event)
|
|
||||||
{
|
|
||||||
// set focus to the currently selected page if any
|
|
||||||
if ( m_nSelection != -1 )
|
|
||||||
m_aPages[m_nSelection]->SetFocus();
|
|
||||||
|
|
||||||
event.Skip();
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxNotebook::OnNavigationKey(wxNavigationKeyEvent& event)
|
|
||||||
{
|
|
||||||
if ( event.IsWindowChange() ) {
|
|
||||||
// change pages
|
|
||||||
AdvanceSelection(event.GetDirection());
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
// pass to the parent
|
|
||||||
if ( GetParent() ) {
|
|
||||||
event.SetCurrentFocus(this);
|
|
||||||
GetParent()->ProcessEvent(event);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// wxNotebook base class virtuals
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
// override these 2 functions to do nothing: everything is done in OnSize
|
|
||||||
|
|
||||||
void wxNotebook::SetConstraintSizes(bool /* recurse */)
|
|
||||||
{
|
|
||||||
// don't set the sizes of the pages - their correct size is not yet known
|
|
||||||
wxControl::SetConstraintSizes(FALSE);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool wxNotebook::DoPhase(int /* nPhase */)
|
|
||||||
{
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxNotebook::Command(wxCommandEvent& event)
|
|
||||||
{
|
|
||||||
wxFAIL_MSG("wxNotebook::Command not implemented");
|
|
||||||
}
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// wxNotebook helper functions
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
// hide the currently active panel and show the new one
|
|
||||||
void wxNotebook::ChangePage(int nOldSel, int nSel)
|
|
||||||
{
|
|
||||||
// cout << "ChangePage: " << nOldSel << ", " << nSel << "\n";
|
|
||||||
wxASSERT( nOldSel != nSel ); // impossible
|
|
||||||
|
|
||||||
if ( nOldSel != -1 ) {
|
|
||||||
m_aPages[nOldSel]->Show(FALSE);
|
|
||||||
m_aPages[nOldSel]->Lower();
|
|
||||||
}
|
|
||||||
|
|
||||||
wxNotebookPage *pPage = m_aPages[nSel];
|
|
||||||
|
|
||||||
wxRect clientRect = GetAvailableClientSize();
|
|
||||||
pPage->SetSize(clientRect.x, clientRect.y, clientRect.width, clientRect.height);
|
|
||||||
|
|
||||||
pPage->Show(TRUE);
|
|
||||||
pPage->Raise();
|
|
||||||
pPage->SetFocus();
|
|
||||||
|
|
||||||
Refresh();
|
|
||||||
|
|
||||||
m_nSelection = nSel;
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxNotebook::ChangeFont(bool keepOriginalSize)
|
|
||||||
{
|
|
||||||
wxWindow::ChangeFont(keepOriginalSize);
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxNotebook::ChangeBackgroundColour()
|
|
||||||
{
|
|
||||||
wxWindow::ChangeBackgroundColour();
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxNotebook::ChangeForegroundColour()
|
|
||||||
{
|
|
||||||
wxWindow::ChangeForegroundColour();
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxNotebook::OnMouseEvent(wxMouseEvent& event)
|
|
||||||
{
|
|
||||||
if (m_tabView)
|
|
||||||
m_tabView->OnEvent(event);
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxNotebook::OnPaint(wxPaintEvent& WXUNUSED(event) )
|
|
||||||
{
|
|
||||||
wxPaintDC dc(this);
|
|
||||||
if (m_tabView)
|
|
||||||
m_tabView->Draw(dc);
|
|
||||||
}
|
|
||||||
|
|
||||||
wxRect wxNotebook::GetAvailableClientSize()
|
|
||||||
{
|
|
||||||
int cw, ch;
|
|
||||||
GetClientSize(& cw, & ch);
|
|
||||||
|
|
||||||
int tabHeight = m_tabView->GetTotalTabHeight();
|
|
||||||
|
|
||||||
// TODO: these margins should be configurable.
|
|
||||||
wxRect rect;
|
|
||||||
rect.x = 6;
|
|
||||||
rect.y = tabHeight + 6;
|
|
||||||
rect.width = cw - 12;
|
|
||||||
rect.height = ch - 4 - rect.y ;
|
|
||||||
|
|
||||||
return rect;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* wxNotebookTabView
|
|
||||||
*/
|
|
||||||
|
|
||||||
IMPLEMENT_CLASS(wxNotebookTabView, wxTabView)
|
|
||||||
|
|
||||||
wxNotebookTabView::wxNotebookTabView(wxNotebook *notebook, long style): wxTabView(style)
|
|
||||||
{
|
|
||||||
m_notebook = notebook;
|
|
||||||
|
|
||||||
m_notebook->SetTabView(this);
|
|
||||||
|
|
||||||
SetWindow(m_notebook);
|
|
||||||
}
|
|
||||||
|
|
||||||
wxNotebookTabView::~wxNotebookTabView(void)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
// Called when a tab is activated
|
|
||||||
void wxNotebookTabView::OnTabActivate(int activateId, int deactivateId)
|
|
||||||
{
|
|
||||||
if (!m_notebook)
|
|
||||||
return;
|
|
||||||
|
|
||||||
wxNotebookEvent event(wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGED, m_notebook->GetId());
|
|
||||||
|
|
||||||
// Translate from wxTabView's ids (which aren't position-dependent)
|
|
||||||
// to wxNotebook's (which are).
|
|
||||||
wxNotebookPage* pActive = (wxNotebookPage*) activateId;
|
|
||||||
wxNotebookPage* pDeactive = (wxNotebookPage*) deactivateId;
|
|
||||||
|
|
||||||
int activatePos = m_notebook->FindPagePosition(pActive);
|
|
||||||
int deactivatePos = m_notebook->FindPagePosition(pDeactive);
|
|
||||||
|
|
||||||
event.SetEventObject(m_notebook);
|
|
||||||
event.SetSelection(activatePos);
|
|
||||||
event.SetOldSelection(deactivatePos);
|
|
||||||
m_notebook->GetEventHandler()->ProcessEvent(event);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
Reference in New Issue
Block a user