[ 1665996 ] Fixes/extensions to wxDataViewCtrl
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@44556 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -53,6 +53,12 @@ extern WXDLLIMPEXP_DATA_ADV(const wxChar) wxDataViewCtrlNameStr[];
|
||||
// the default width of new toggle columns:
|
||||
#define wxDVC_TOGGLE_DEFAULT_WIDTH 30
|
||||
|
||||
// the default minimal width of the columns:
|
||||
#define wxDVC_DEFAULT_MINWIDTH 30
|
||||
|
||||
// the default alignment of wxDataViewRenderers:
|
||||
#define wxDVR_DEFAULT_ALIGNMENT (wxALIGN_LEFT|wxALIGN_TOP)
|
||||
|
||||
|
||||
// ---------------------------------------------------------
|
||||
// wxDataViewModel
|
||||
@@ -124,14 +130,14 @@ class WXDLLIMPEXP_ADV wxDataViewListModel: public wxDataViewModel
|
||||
public:
|
||||
wxDataViewListModel();
|
||||
|
||||
virtual unsigned int GetNumberOfRows() = 0;
|
||||
virtual unsigned int GetNumberOfCols() = 0;
|
||||
virtual unsigned int GetRowCount() const = 0;
|
||||
virtual unsigned int GetColumnCount() const = 0;
|
||||
|
||||
// return type as reported by wxVariant
|
||||
virtual wxString GetColType( unsigned int col ) = 0;
|
||||
virtual wxString GetColumnType( unsigned int col ) const = 0;
|
||||
|
||||
// get value into a wxVariant
|
||||
virtual void GetValue( wxVariant &variant, unsigned int col, unsigned int row ) = 0;
|
||||
virtual void GetValue( wxVariant &variant, unsigned int col, unsigned int row ) const = 0;
|
||||
|
||||
// set value, call ValueChanged() afterwards!
|
||||
virtual bool SetValue( wxVariant &variant, unsigned int col, unsigned int row ) = 0;
|
||||
@@ -170,7 +176,8 @@ protected:
|
||||
typedef int (wxCALLBACK *wxDataViewListModelCompare)
|
||||
(unsigned int row1, unsigned int row2, unsigned int col, wxDataViewListModel* model );
|
||||
|
||||
WX_DEFINE_SORTED_USER_EXPORTED_ARRAY_SIZE_T(unsigned int, wxDataViewSortedIndexArray, WXDLLIMPEXP_ADV);
|
||||
WX_DEFINE_SORTED_USER_EXPORTED_ARRAY_SIZE_T(unsigned int,
|
||||
wxDataViewSortedIndexArray, WXDLLIMPEXP_ADV);
|
||||
|
||||
class WXDLLIMPEXP_ADV wxDataViewSortedListModel: public wxDataViewListModel
|
||||
{
|
||||
@@ -181,14 +188,17 @@ public:
|
||||
virtual ~wxDataViewSortedListModel();
|
||||
|
||||
void SetAscending( bool ascending ) { m_ascending = ascending; }
|
||||
bool GetAscending() { return m_ascending; }
|
||||
bool IsAscending() const { return m_ascending; }
|
||||
|
||||
virtual unsigned int GetRowCount() const;
|
||||
virtual unsigned int GetColumnCount() const;
|
||||
|
||||
virtual unsigned int GetNumberOfRows();
|
||||
virtual unsigned int GetNumberOfCols();
|
||||
// return type as reported by wxVariant
|
||||
virtual wxString GetColType( unsigned int col );
|
||||
virtual wxString GetColumnType( unsigned int col ) const;
|
||||
|
||||
// get value into a wxVariant
|
||||
virtual void GetValue( wxVariant &variant, unsigned int col, unsigned int row );
|
||||
virtual void GetValue( wxVariant &variant, unsigned int col, unsigned int row ) const;
|
||||
|
||||
// set value, call ValueChanged() afterwards!
|
||||
virtual bool SetValue( wxVariant &variant, unsigned int col, unsigned int row );
|
||||
|
||||
@@ -245,23 +255,39 @@ enum wxDataViewCellRenderState
|
||||
class WXDLLIMPEXP_ADV wxDataViewRendererBase: public wxObject
|
||||
{
|
||||
public:
|
||||
wxDataViewRendererBase( const wxString &varianttype, wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT );
|
||||
wxDataViewRendererBase( const wxString &varianttype,
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
|
||||
int alignment = wxDVR_DEFAULT_ALIGNMENT );
|
||||
|
||||
virtual bool SetValue( const wxVariant& WXUNUSED(value) ) { return true; }
|
||||
virtual bool GetValue( wxVariant& WXUNUSED(value) ) { return true; }
|
||||
virtual bool Validate( wxVariant& WXUNUSED(value) ) { return true; }
|
||||
|
||||
wxString GetVariantType() { return m_variantType; }
|
||||
wxDataViewCellMode GetMode() { return m_mode; }
|
||||
virtual bool Validate( wxVariant& WXUNUSED(value) )
|
||||
{ return true; }
|
||||
|
||||
void SetOwner( wxDataViewColumn *owner ) { m_owner = owner; }
|
||||
wxDataViewColumn* GetOwner() { return m_owner; }
|
||||
|
||||
// renderer properties:
|
||||
|
||||
virtual bool SetValue( const wxVariant& WXUNUSED(value) ) = 0;
|
||||
virtual bool GetValue( wxVariant& WXUNUSED(value) ) const = 0;
|
||||
|
||||
wxString GetVariantType() const { return m_variantType; }
|
||||
|
||||
virtual void SetMode( wxDataViewCellMode mode ) = 0;
|
||||
virtual wxDataViewCellMode GetMode() const = 0;
|
||||
|
||||
// NOTE: Set/GetAlignment do not take/return a wxAlignment enum but
|
||||
// rather an "int"; that's because for rendering cells it's allowed
|
||||
// to combine alignment flags (e.g. wxALIGN_LEFT|wxALIGN_BOTTOM)
|
||||
virtual void SetAlignment( int align ) = 0;
|
||||
virtual int GetAlignment() const = 0;
|
||||
|
||||
protected:
|
||||
wxDataViewCellMode m_mode;
|
||||
wxString m_variantType;
|
||||
wxDataViewColumn *m_owner;
|
||||
|
||||
// internal utility:
|
||||
const wxDataViewCtrl* GetView() const;
|
||||
|
||||
protected:
|
||||
DECLARE_DYNAMIC_CLASS_NO_COPY(wxDataViewRendererBase)
|
||||
};
|
||||
@@ -290,40 +316,47 @@ public:
|
||||
int flags = wxDATAVIEW_COL_RESIZABLE );
|
||||
virtual ~wxDataViewColumnBase();
|
||||
|
||||
virtual void SetTitle( const wxString &title );
|
||||
virtual wxString GetTitle();
|
||||
// setters:
|
||||
|
||||
virtual void SetBitmap( const wxBitmap &bitmap );
|
||||
virtual const wxBitmap &GetBitmap();
|
||||
|
||||
virtual void SetTitle( const wxString &title ) = 0;
|
||||
virtual void SetAlignment( wxAlignment align ) = 0;
|
||||
|
||||
virtual void SetSortable( bool sortable ) = 0;
|
||||
virtual bool IsSortable() const
|
||||
{ return (m_flags & wxDATAVIEW_COL_SORTABLE) != 0; }
|
||||
virtual bool IsResizeable() const
|
||||
{ return (m_flags & wxDATAVIEW_COL_RESIZABLE) != 0; }
|
||||
virtual bool IsHidden() const
|
||||
{ return (m_flags & wxDATAVIEW_COL_HIDDEN) != 0; }
|
||||
|
||||
virtual void SetResizeable( bool resizeable ) = 0;
|
||||
virtual void SetHidden( bool hidden ) = 0;
|
||||
virtual void SetSortOrder( bool ascending ) = 0;
|
||||
virtual void SetFlags( int flags );
|
||||
virtual void SetOwner( wxDataViewCtrl *owner )
|
||||
{ m_owner = owner; }
|
||||
virtual void SetBitmap( const wxBitmap &bitmap )
|
||||
{ m_bitmap=bitmap; }
|
||||
|
||||
virtual void SetMinWidth( int minWidth ) = 0;
|
||||
virtual void SetWidth( int width ) = 0;
|
||||
|
||||
|
||||
// getters:
|
||||
|
||||
virtual wxString GetTitle() const = 0;
|
||||
virtual wxAlignment GetAlignment() const = 0;
|
||||
virtual int GetWidth() const = 0;
|
||||
virtual int GetMinWidth() const = 0;
|
||||
|
||||
virtual int GetFlags() const;
|
||||
|
||||
virtual bool IsSortable() const = 0;
|
||||
virtual bool IsResizeable() const = 0;
|
||||
virtual bool IsHidden() const = 0;
|
||||
virtual bool IsSortOrderAscending() const = 0;
|
||||
|
||||
const wxBitmap &GetBitmap() const { return m_bitmap; }
|
||||
unsigned int GetModelColumn() const { return m_model_column; }
|
||||
|
||||
wxDataViewCtrl *GetOwner() { return m_owner; }
|
||||
wxDataViewRenderer* GetRenderer() { return m_renderer; }
|
||||
|
||||
unsigned int GetModelColumn() { return m_model_column; }
|
||||
|
||||
virtual void SetOwner( wxDataViewCtrl *owner ) { m_owner = owner; }
|
||||
wxDataViewCtrl *GetOwner() { return m_owner; }
|
||||
|
||||
virtual int GetWidth() const = 0;
|
||||
|
||||
private:
|
||||
wxDataViewCtrl *m_ctrl;
|
||||
protected:
|
||||
wxDataViewRenderer *m_renderer;
|
||||
int m_model_column;
|
||||
int m_flags;
|
||||
wxString m_title;
|
||||
wxBitmap m_bitmap;
|
||||
wxDataViewCtrl *m_owner;
|
||||
|
||||
@@ -336,7 +369,11 @@ protected:
|
||||
// ---------------------------------------------------------
|
||||
|
||||
#define wxDV_SINGLE 0x0000 // for convenience
|
||||
#define wxDV_MULTIPLE 0x0020 // can select multiple items
|
||||
#define wxDV_MULTIPLE 0x0001 // can select multiple items
|
||||
|
||||
#define wxDV_NO_HEADER 0x0002 // column titles not visible
|
||||
#define wxDV_HORIZ_RULES 0x0004 // light horizontal rules between rows
|
||||
#define wxDV_VERT_RULES 0x0008 // light vertical rules between columns
|
||||
|
||||
class WXDLLIMPEXP_ADV wxDataViewCtrlBase: public wxControl
|
||||
{
|
||||
@@ -390,7 +427,9 @@ public:
|
||||
int flags = wxDATAVIEW_COL_RESIZABLE );
|
||||
|
||||
virtual bool AppendColumn( wxDataViewColumn *col );
|
||||
virtual unsigned int GetNumberOfColumns();
|
||||
|
||||
virtual unsigned int GetColumnCount() const;
|
||||
|
||||
virtual bool DeleteColumn( unsigned int pos );
|
||||
virtual bool ClearColumns();
|
||||
virtual wxDataViewColumn* GetColumn( unsigned int pos );
|
||||
@@ -443,16 +482,19 @@ public:
|
||||
|
||||
int GetColumn() const { return m_col; }
|
||||
void SetColumn( int col ) { m_col = col; }
|
||||
|
||||
int GetRow() const { return m_row; }
|
||||
void SetRow( int row ) { m_row = row; }
|
||||
|
||||
wxDataViewModel* GetModel() const { return m_model; }
|
||||
void SetModel( wxDataViewModel *model ) { m_model = model; }
|
||||
|
||||
const wxVariant &GetValue() const { return m_value; }
|
||||
void SetValue( const wxVariant &value ) { m_value = value; }
|
||||
|
||||
// for wxEVT_DATAVIEW_COLUMN_HEADER_CLICKED only
|
||||
void SetDataViewColumn( wxDataViewColumn *col ) { m_column = col; }
|
||||
wxDataViewColumn *GetDataViewColumn() { return m_column; }
|
||||
wxDataViewColumn *GetDataViewColumn() const { return m_column; }
|
||||
|
||||
// was label editing canceled? (for wxEVT_COMMAND_DATVIEW_END_LABEL_EDIT only)
|
||||
bool IsEditCancelled() const { return m_editCancelled; }
|
||||
|
@@ -33,11 +33,22 @@ class WXDLLIMPEXP_ADV wxDataViewRenderer: public wxDataViewRendererBase
|
||||
{
|
||||
public:
|
||||
wxDataViewRenderer( const wxString &varianttype,
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT );
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
|
||||
int align = wxDVR_DEFAULT_ALIGNMENT );
|
||||
virtual ~wxDataViewRenderer();
|
||||
|
||||
virtual bool Render( wxRect cell, wxDC *dc, int state ) = 0;
|
||||
virtual wxSize GetSize() = 0;
|
||||
virtual wxSize GetSize() const = 0;
|
||||
|
||||
virtual void SetAlignment( int align )
|
||||
{ m_align=align; }
|
||||
virtual int GetAlignment() const
|
||||
{ return m_align; }
|
||||
|
||||
virtual void SetMode( wxDataViewCellMode mode )
|
||||
{ m_mode=mode; }
|
||||
virtual wxDataViewCellMode GetMode() const
|
||||
{ return m_mode; }
|
||||
|
||||
virtual bool Activate( wxRect WXUNUSED(cell),
|
||||
wxDataViewListModel *WXUNUSED(model),
|
||||
@@ -68,7 +79,9 @@ public:
|
||||
virtual wxDC *GetDC();
|
||||
|
||||
private:
|
||||
wxDC *m_dc;
|
||||
wxDC *m_dc;
|
||||
int m_align;
|
||||
wxDataViewCellMode m_mode;
|
||||
|
||||
protected:
|
||||
DECLARE_DYNAMIC_CLASS_NO_COPY(wxDataViewRenderer)
|
||||
@@ -82,7 +95,8 @@ class WXDLLIMPEXP_ADV wxDataViewCustomRenderer: public wxDataViewRenderer
|
||||
{
|
||||
public:
|
||||
wxDataViewCustomRenderer( const wxString &varianttype = wxT("string"),
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT );
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
|
||||
int align = wxDVR_DEFAULT_ALIGNMENT );
|
||||
|
||||
protected:
|
||||
DECLARE_DYNAMIC_CLASS_NO_COPY(wxDataViewCustomRenderer)
|
||||
@@ -96,13 +110,14 @@ class WXDLLIMPEXP_ADV wxDataViewTextRenderer: public wxDataViewCustomRenderer
|
||||
{
|
||||
public:
|
||||
wxDataViewTextRenderer( const wxString &varianttype = wxT("string"),
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT );
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
|
||||
int align = wxDVR_DEFAULT_ALIGNMENT );
|
||||
|
||||
bool SetValue( const wxVariant &value );
|
||||
bool GetValue( wxVariant &value );
|
||||
bool GetValue( wxVariant &value ) const;
|
||||
|
||||
bool Render( wxRect cell, wxDC *dc, int state );
|
||||
wxSize GetSize();
|
||||
wxSize GetSize() const;
|
||||
|
||||
private:
|
||||
wxString m_text;
|
||||
@@ -119,13 +134,14 @@ class WXDLLIMPEXP_ADV wxDataViewBitmapRenderer: public wxDataViewCustomRenderer
|
||||
{
|
||||
public:
|
||||
wxDataViewBitmapRenderer( const wxString &varianttype = wxT("wxBitmap"),
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT );
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
|
||||
int align = wxDVR_DEFAULT_ALIGNMENT );
|
||||
|
||||
bool SetValue( const wxVariant &value );
|
||||
bool GetValue( wxVariant &value );
|
||||
bool GetValue( wxVariant &value ) const;
|
||||
|
||||
bool Render( wxRect cell, wxDC *dc, int state );
|
||||
wxSize GetSize();
|
||||
wxSize GetSize() const;
|
||||
|
||||
private:
|
||||
wxIcon m_icon;
|
||||
@@ -143,15 +159,16 @@ class WXDLLIMPEXP_ADV wxDataViewToggleRenderer: public wxDataViewCustomRenderer
|
||||
{
|
||||
public:
|
||||
wxDataViewToggleRenderer( const wxString &varianttype = wxT("bool"),
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT );
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
|
||||
int align = wxDVR_DEFAULT_ALIGNMENT );
|
||||
|
||||
bool SetValue( const wxVariant &value );
|
||||
bool GetValue( wxVariant &value );
|
||||
bool GetValue( wxVariant &value ) const;
|
||||
|
||||
bool Render( wxRect cell, wxDC *dc, int state );
|
||||
bool Activate( wxRect cell, wxDataViewListModel *model, unsigned int col,
|
||||
unsigned int row );
|
||||
wxSize GetSize();
|
||||
wxSize GetSize() const;
|
||||
|
||||
private:
|
||||
bool m_toggle;
|
||||
@@ -169,13 +186,15 @@ class WXDLLIMPEXP_ADV wxDataViewProgressRenderer: public wxDataViewCustomRendere
|
||||
public:
|
||||
wxDataViewProgressRenderer( const wxString &label = wxEmptyString,
|
||||
const wxString &varianttype = wxT("long"),
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT );
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
|
||||
int align = wxDVR_DEFAULT_ALIGNMENT );
|
||||
virtual ~wxDataViewProgressRenderer();
|
||||
|
||||
bool SetValue( const wxVariant &value );
|
||||
bool GetValue( wxVariant& value ) const;
|
||||
|
||||
virtual bool Render( wxRect cell, wxDC *dc, int state );
|
||||
virtual wxSize GetSize();
|
||||
virtual wxSize GetSize() const;
|
||||
|
||||
private:
|
||||
wxString m_label;
|
||||
@@ -193,12 +212,14 @@ class WXDLLIMPEXP_ADV wxDataViewDateRenderer: public wxDataViewCustomRenderer
|
||||
{
|
||||
public:
|
||||
wxDataViewDateRenderer( const wxString &varianttype = wxT("datetime"),
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_ACTIVATABLE );
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_ACTIVATABLE,
|
||||
int align = wxDVR_DEFAULT_ALIGNMENT );
|
||||
|
||||
bool SetValue( const wxVariant &value );
|
||||
bool GetValue( wxVariant& value ) const;
|
||||
|
||||
virtual bool Render( wxRect cell, wxDC *dc, int state );
|
||||
virtual wxSize GetSize();
|
||||
virtual wxSize GetSize() const;
|
||||
virtual bool Activate( wxRect cell,
|
||||
wxDataViewListModel *model, unsigned int col, unsigned int row );
|
||||
|
||||
@@ -230,32 +251,53 @@ public:
|
||||
int flags = wxDATAVIEW_COL_RESIZABLE );
|
||||
virtual ~wxDataViewColumn();
|
||||
|
||||
virtual void SetTitle( const wxString &title );
|
||||
virtual void SetBitmap( const wxBitmap &bitmap );
|
||||
|
||||
// setters:
|
||||
|
||||
virtual void SetTitle( const wxString &title )
|
||||
{ m_title=title; }
|
||||
virtual void SetAlignment( wxAlignment align )
|
||||
{ m_align=align; }
|
||||
wxAlignment GetAlignment() const
|
||||
{ return m_align; }
|
||||
|
||||
virtual void SetMinWidth( int minWidth )
|
||||
{ m_minWidth=minWidth; }
|
||||
virtual void SetWidth( int width );
|
||||
virtual void SetSortable( bool sortable );
|
||||
virtual void SetResizeable( bool resizeable );
|
||||
virtual void SetHidden( bool hidden );
|
||||
virtual void SetSortOrder( bool ascending );
|
||||
|
||||
|
||||
// getters:
|
||||
|
||||
virtual wxString GetTitle() const
|
||||
{ return m_title; }
|
||||
virtual wxAlignment GetAlignment() const
|
||||
{ return m_align; }
|
||||
virtual int GetWidth() const
|
||||
{ return m_width; }
|
||||
virtual int GetMinWidth() const
|
||||
{ return m_minWidth; }
|
||||
virtual bool IsSortable() const
|
||||
{ return (m_flags & wxDATAVIEW_COL_SORTABLE) != 0; }
|
||||
virtual bool IsResizeable() const
|
||||
{ return (m_flags & wxDATAVIEW_COL_RESIZABLE) != 0; }
|
||||
virtual bool IsHidden() const
|
||||
{ return (m_flags & wxDATAVIEW_COL_HIDDEN) != 0; }
|
||||
virtual bool IsSortOrderAscending() const;
|
||||
|
||||
virtual int GetWidth() const;
|
||||
|
||||
protected:
|
||||
|
||||
void SetWidth(int w)
|
||||
{ m_width=w; }
|
||||
|
||||
private:
|
||||
int m_width;
|
||||
int m_fixedWidth;
|
||||
wxAlignment m_align;
|
||||
int m_minWidth;
|
||||
int m_flags;
|
||||
wxAlignment m_align;
|
||||
wxString m_title;
|
||||
|
||||
void Init(int width);
|
||||
|
||||
// like SetWidth() but does not ask the header window of the
|
||||
// wxDataViewCtrl to reflect the width-change.
|
||||
void SetInternalWidth(int width);
|
||||
|
||||
protected:
|
||||
DECLARE_DYNAMIC_CLASS_NO_COPY(wxDataViewColumn)
|
||||
};
|
||||
@@ -271,6 +313,7 @@ class WXDLLIMPEXP_ADV wxDataViewCtrl: public wxDataViewCtrlBase,
|
||||
friend class wxDataViewHeaderWindowBase;
|
||||
friend class wxDataViewHeaderWindow;
|
||||
friend class wxDataViewHeaderWindowMSW;
|
||||
friend class wxDataViewColumn;
|
||||
|
||||
public:
|
||||
wxDataViewCtrl() : wxScrollHelperNative(this)
|
||||
@@ -308,12 +351,16 @@ public:
|
||||
virtual int GetSelection() const;
|
||||
virtual int GetSelections(wxArrayInt& aSelections) const;
|
||||
|
||||
public: // utility functions not part of the API
|
||||
|
||||
// returns the "best" width for the idx-th column
|
||||
unsigned int GetBestColumnWidth(int WXUNUSED(idx))
|
||||
unsigned int GetBestColumnWidth(int WXUNUSED(idx)) const
|
||||
{
|
||||
return GetClientSize().GetWidth() / GetNumberOfColumns();
|
||||
return GetClientSize().GetWidth() / GetColumnCount();
|
||||
}
|
||||
|
||||
// updates the header window after a change in a column setting
|
||||
void OnColumnChange();
|
||||
|
||||
private:
|
||||
wxDataViewListModelNotifier *m_notifier;
|
||||
|
@@ -30,19 +30,25 @@ class wxDataViewRenderer: public wxDataViewRendererBase
|
||||
{
|
||||
public:
|
||||
wxDataViewRenderer( const wxString &varianttype,
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT );
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
|
||||
int align = wxDVR_DEFAULT_ALIGNMENT );
|
||||
|
||||
// implementation
|
||||
void* GetGtkHandle() { return m_renderer; }
|
||||
GtkWidget* GetGtkHandle() { return m_renderer; }
|
||||
|
||||
virtual void SetMode( wxDataViewCellMode mode );
|
||||
virtual wxDataViewCellMode GetMode() const;
|
||||
|
||||
virtual void SetAlignment( int align );
|
||||
virtual int GetAlignment() const;
|
||||
|
||||
protected:
|
||||
// holds the GTK handle
|
||||
void* m_renderer;
|
||||
GtkWidget *m_renderer;
|
||||
|
||||
protected:
|
||||
DECLARE_DYNAMIC_CLASS_NO_COPY(wxDataViewRenderer)
|
||||
};
|
||||
|
||||
|
||||
// ---------------------------------------------------------
|
||||
// wxDataViewTextRenderer
|
||||
// ---------------------------------------------------------
|
||||
@@ -51,11 +57,14 @@ class wxDataViewTextRenderer: public wxDataViewRenderer
|
||||
{
|
||||
public:
|
||||
wxDataViewTextRenderer( const wxString &varianttype = wxT("string"),
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT );
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
|
||||
int align = wxDVR_DEFAULT_ALIGNMENT );
|
||||
|
||||
bool SetValue( const wxVariant &value );
|
||||
bool GetValue( wxVariant &value );
|
||||
|
||||
bool GetValue( wxVariant &value ) const;
|
||||
|
||||
void SetAlignment( int align );
|
||||
|
||||
protected:
|
||||
DECLARE_DYNAMIC_CLASS_NO_COPY(wxDataViewTextRenderer)
|
||||
};
|
||||
@@ -68,10 +77,11 @@ class wxDataViewBitmapRenderer: public wxDataViewRenderer
|
||||
{
|
||||
public:
|
||||
wxDataViewBitmapRenderer( const wxString &varianttype = wxT("wxBitmap"),
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT );
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
|
||||
int align = wxDVR_DEFAULT_ALIGNMENT );
|
||||
|
||||
bool SetValue( const wxVariant &value );
|
||||
bool GetValue( wxVariant &value );
|
||||
bool GetValue( wxVariant &value ) const;
|
||||
|
||||
protected:
|
||||
DECLARE_DYNAMIC_CLASS_NO_COPY(wxDataViewBitmapRenderer)
|
||||
@@ -85,10 +95,11 @@ class wxDataViewToggleRenderer: public wxDataViewRenderer
|
||||
{
|
||||
public:
|
||||
wxDataViewToggleRenderer( const wxString &varianttype = wxT("bool"),
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT );
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
|
||||
int align = wxDVR_DEFAULT_ALIGNMENT );
|
||||
|
||||
bool SetValue( const wxVariant &value );
|
||||
bool GetValue( wxVariant &value );
|
||||
bool GetValue( wxVariant &value ) const;
|
||||
|
||||
protected:
|
||||
DECLARE_DYNAMIC_CLASS_NO_COPY(wxDataViewToggleRenderer)
|
||||
@@ -103,17 +114,18 @@ class wxDataViewCustomRenderer: public wxDataViewRenderer
|
||||
public:
|
||||
wxDataViewCustomRenderer( const wxString &varianttype = wxT("string"),
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
|
||||
int align = wxDVR_DEFAULT_ALIGNMENT,
|
||||
bool no_init = false );
|
||||
virtual ~wxDataViewCustomRenderer();
|
||||
bool Init();
|
||||
|
||||
|
||||
|
||||
virtual bool Render( wxRect cell, wxDC *dc, int state ) = 0;
|
||||
virtual wxSize GetSize() = 0;
|
||||
|
||||
virtual wxSize GetSize() const = 0;
|
||||
|
||||
virtual bool Activate( wxRect cell,
|
||||
wxDataViewListModel *model, unsigned int col, unsigned int row )
|
||||
{ return false; }
|
||||
|
||||
|
||||
virtual bool LeftClick( wxPoint cursor, wxRect cell,
|
||||
wxDataViewListModel *model, unsigned int col, unsigned int row )
|
||||
{ return false; }
|
||||
@@ -127,6 +139,11 @@ public:
|
||||
// Create DC on request
|
||||
virtual wxDC *GetDC();
|
||||
|
||||
|
||||
protected:
|
||||
|
||||
bool Init(wxDataViewCellMode mode, int align);
|
||||
|
||||
private:
|
||||
wxDC *m_dc;
|
||||
|
||||
@@ -143,13 +160,15 @@ class wxDataViewProgressRenderer: public wxDataViewCustomRenderer
|
||||
public:
|
||||
wxDataViewProgressRenderer( const wxString &label = wxEmptyString,
|
||||
const wxString &varianttype = wxT("long"),
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT );
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
|
||||
int align = wxDVR_DEFAULT_ALIGNMENT );
|
||||
virtual ~wxDataViewProgressRenderer();
|
||||
|
||||
bool SetValue( const wxVariant &value );
|
||||
bool GetValue( wxVariant &value ) const;
|
||||
|
||||
virtual bool Render( wxRect cell, wxDC *dc, int state );
|
||||
virtual wxSize GetSize();
|
||||
virtual wxSize GetSize() const;
|
||||
|
||||
private:
|
||||
wxString m_label;
|
||||
@@ -167,12 +186,14 @@ class wxDataViewDateRenderer: public wxDataViewCustomRenderer
|
||||
{
|
||||
public:
|
||||
wxDataViewDateRenderer( const wxString &varianttype = wxT("datetime"),
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_ACTIVATABLE );
|
||||
wxDataViewCellMode mode = wxDATAVIEW_CELL_ACTIVATABLE,
|
||||
int align = wxDVR_DEFAULT_ALIGNMENT );
|
||||
|
||||
bool SetValue( const wxVariant &value );
|
||||
bool GetValue( wxVariant &value ) const;
|
||||
|
||||
virtual bool Render( wxRect cell, wxDC *dc, int state );
|
||||
virtual wxSize GetSize();
|
||||
virtual wxSize GetSize() const;
|
||||
virtual bool Activate( wxRect cell,
|
||||
wxDataViewListModel *model, unsigned int col, unsigned int row );
|
||||
|
||||
@@ -201,6 +222,9 @@ public:
|
||||
|
||||
virtual ~wxDataViewColumn();
|
||||
|
||||
|
||||
// setters:
|
||||
|
||||
virtual void SetTitle( const wxString &title );
|
||||
virtual void SetBitmap( const wxBitmap &bitmap );
|
||||
|
||||
@@ -211,26 +235,40 @@ public:
|
||||
virtual void SetSortable( bool sortable );
|
||||
virtual void SetSortOrder( bool ascending );
|
||||
|
||||
virtual void SetResizeable( bool resizeable );
|
||||
virtual void SetHidden( bool hidden );
|
||||
|
||||
virtual void SetMinWidth( int minWidth );
|
||||
virtual void SetWidth( int width );
|
||||
|
||||
|
||||
// getters:
|
||||
|
||||
virtual wxString GetTitle() const;
|
||||
virtual wxAlignment GetAlignment() const;
|
||||
|
||||
virtual bool IsSortable() const;
|
||||
virtual bool IsSortOrderAscending() const;
|
||||
virtual bool IsResizeable() const;
|
||||
virtual bool IsHidden() const;
|
||||
|
||||
virtual int GetWidth() const;
|
||||
|
||||
virtual void SetFixedWidth( int width );
|
||||
virtual int GetFixedWidth() const;
|
||||
|
||||
virtual int GetMinWidth() const;
|
||||
|
||||
// implementation
|
||||
void* GetGtkHandle() { return m_column; }
|
||||
GtkWidget* GetGtkHandle() { return m_column; }
|
||||
|
||||
private:
|
||||
// holds the GTK handle
|
||||
void* m_column;
|
||||
GtkWidget *m_column;
|
||||
|
||||
// delayed connection to mouse events
|
||||
friend class wxDataViewCtrl;
|
||||
void OnInternalIdle();
|
||||
bool m_isConnected;
|
||||
|
||||
bool m_isConnected;
|
||||
|
||||
void Init(wxAlignment align, int flags, int width);
|
||||
|
||||
protected:
|
||||
DECLARE_DYNAMIC_CLASS_NO_COPY(wxDataViewColumn)
|
||||
};
|
||||
|
@@ -1,8 +1,8 @@
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
// Name: dataview.cpp
|
||||
// Purpose: DataVewCtrl wxWidgets sample
|
||||
// Purpose: wxDataViewCtrl wxWidgets sample
|
||||
// Author: Robert Roebling
|
||||
// Modified by:
|
||||
// Modified by: Francesco Montorsi
|
||||
// Created: 06/01/06
|
||||
// RCS-ID: $Id$
|
||||
// Copyright: (c) Robert Roebling
|
||||
@@ -23,6 +23,9 @@
|
||||
#include "wx/datetime.h"
|
||||
#include "wx/splitter.h"
|
||||
#include "wx/aboutdlg.h"
|
||||
#include "wx/choicdlg.h"
|
||||
#include "wx/numdlg.h"
|
||||
#include "wx/dataview.h"
|
||||
|
||||
#ifndef __WXMSW__
|
||||
#include "../sample.xpm"
|
||||
@@ -30,7 +33,11 @@
|
||||
|
||||
#include "null.xpm"
|
||||
|
||||
#include "wx/dataview.h"
|
||||
|
||||
#define DEFAULT_ALIGN wxALIGN_LEFT
|
||||
#define DATAVIEW_DEFAULT_STYLE (wxDV_MULTIPLE|wxDV_HORIZ_RULES|wxDV_VERT_RULES)
|
||||
|
||||
|
||||
|
||||
// -------------------------------------
|
||||
// MyTextModel
|
||||
@@ -61,13 +68,13 @@ public:
|
||||
}
|
||||
}
|
||||
|
||||
virtual unsigned int GetNumberOfRows()
|
||||
virtual unsigned int GetRowCount() const
|
||||
{ return 1000; }
|
||||
virtual unsigned int GetNumberOfCols()
|
||||
virtual unsigned int GetColumnCount() const
|
||||
{ return 7; }
|
||||
|
||||
// as reported by wxVariant
|
||||
virtual wxString GetColType( unsigned int col )
|
||||
virtual wxString GetColumnType( unsigned int col ) const
|
||||
{
|
||||
if (col == 6)
|
||||
return wxT("datetime");
|
||||
@@ -81,7 +88,7 @@ public:
|
||||
return wxT("string");
|
||||
}
|
||||
|
||||
virtual void GetValue( wxVariant &variant, unsigned int col, unsigned int row )
|
||||
virtual void GetValue( wxVariant &variant, unsigned int col, unsigned int row ) const
|
||||
{
|
||||
if (col == 6)
|
||||
{
|
||||
@@ -151,6 +158,13 @@ public:
|
||||
m_colour = value.GetString();
|
||||
return true;
|
||||
}
|
||||
|
||||
bool GetValue( wxVariant &value ) const
|
||||
{
|
||||
value = m_colour;
|
||||
return true;
|
||||
}
|
||||
|
||||
bool Render( wxRect rect, wxDC *dc, int WXUNUSED(state) )
|
||||
{
|
||||
dc->SetPen( *wxBLACK_PEN );
|
||||
@@ -163,7 +177,7 @@ public:
|
||||
dc->DrawRectangle( rect );
|
||||
return true;
|
||||
}
|
||||
wxSize GetSize()
|
||||
wxSize GetSize() const
|
||||
{
|
||||
return wxSize(20,8);
|
||||
}
|
||||
@@ -199,10 +213,22 @@ public:
|
||||
m_bitmap = wxBitmap( null_xpm );
|
||||
}
|
||||
|
||||
virtual unsigned int GetNumberOfRows() { return m_list.GetCount(); }
|
||||
virtual unsigned int GetNumberOfCols() { return 2; }
|
||||
virtual wxString GetColType( unsigned int WXUNUSED(col) ) { return wxT("string"); }
|
||||
virtual void GetValue( wxVariant &variant, unsigned int col, unsigned int row )
|
||||
virtual unsigned int GetRowCount() const
|
||||
{
|
||||
return m_list.GetCount();
|
||||
}
|
||||
|
||||
virtual unsigned int GetColumnCount() const
|
||||
{
|
||||
return 2;
|
||||
}
|
||||
|
||||
virtual wxString GetColumnType( unsigned int WXUNUSED(col) ) const
|
||||
{
|
||||
return wxT("string");
|
||||
}
|
||||
|
||||
virtual void GetValue( wxVariant &variant, unsigned int col, unsigned int row ) const
|
||||
{
|
||||
if (col == 0)
|
||||
{
|
||||
@@ -218,6 +244,7 @@ public:
|
||||
tmp.Printf( wxT("item(%d;%d)"), (int)row, (int)col );
|
||||
variant = tmp;
|
||||
}
|
||||
|
||||
virtual bool SetValue( wxVariant &variant, unsigned int col, unsigned int row )
|
||||
{
|
||||
if (col == 0)
|
||||
@@ -282,21 +309,24 @@ public:
|
||||
void OnAbout(wxCommandEvent& event);
|
||||
void OnNewSortingFrame(wxCommandEvent& event);
|
||||
|
||||
void OnSingleSelMode(wxCommandEvent& event);
|
||||
void OnMultipleSelMode(wxCommandEvent& event);
|
||||
void OnResizeableColumn(wxCommandEvent& event);
|
||||
void OnSortableColumn(wxCommandEvent& event);
|
||||
void OnHideColumn(wxCommandEvent& event);
|
||||
void OnChooseAlign(wxCommandEvent& event);
|
||||
void OnStyleChange(wxCommandEvent& event);
|
||||
void OnColumnSetting(wxCommandEvent& event);
|
||||
|
||||
private:
|
||||
wxDataViewCtrl* dataview_left;
|
||||
wxDataViewCtrl* dataview_right;
|
||||
wxSplitterWindow *m_splitter;
|
||||
wxPanel *m_panelLeft, *m_panelRight;
|
||||
|
||||
wxAlignment m_align;
|
||||
// utilities:
|
||||
|
||||
void CreateControls();
|
||||
void CreateDataViewControls();
|
||||
|
||||
wxArrayInt GetFlaggedColumns(int flag);
|
||||
wxAlignment ChooseAlign(const wxString &msg, bool onlyHorizontal);
|
||||
void SetFlag(const wxArrayInt &idx, int flag);
|
||||
void SetAlignment(const wxArrayInt &idx, bool header, wxAlignment align);
|
||||
void SetWidth(const wxArrayInt &idx, bool minwidth, int width);
|
||||
|
||||
private:
|
||||
DECLARE_EVENT_TABLE()
|
||||
@@ -367,8 +397,8 @@ private:
|
||||
wxLog *m_logOld;
|
||||
wxTextCtrl *m_logWindow;
|
||||
|
||||
MyUnsortedTextModel *m_unsorted_model;
|
||||
wxDataViewSortedListModel *m_sorted_model;
|
||||
wxObjectDataPtr<MyUnsortedTextModel> m_unsorted_model;
|
||||
wxObjectDataPtr<wxDataViewSortedListModel> m_sorted_model;
|
||||
|
||||
DECLARE_EVENT_TABLE()
|
||||
};
|
||||
@@ -407,18 +437,25 @@ enum
|
||||
{
|
||||
// file menu
|
||||
ID_ABOUT = wxID_ABOUT,
|
||||
ID_NEW_SORT_FRAME,
|
||||
ID_NEW_SORT_FRAME = wxID_HIGHEST+1,
|
||||
ID_EXIT = wxID_EXIT,
|
||||
|
||||
// dataviewctrl menu
|
||||
ID_SINGLE_SEL_MODE,
|
||||
ID_SINGLE_SEL_MODE = wxID_HIGHEST+2,
|
||||
ID_MULTIPLE_SEL_MODE,
|
||||
ID_NO_HEADER_MODE,
|
||||
ID_HORIZ_RULES_MODE,
|
||||
ID_VERT_RULES_MODE,
|
||||
|
||||
ID_RESIZEABLE_COLUMNS,
|
||||
ID_SORTABLE_COLUMNS,
|
||||
ID_HIDDEN_COLUMNS,
|
||||
|
||||
ID_CHOOSE_ALIGNMENT
|
||||
ID_CHOOSE_COLUMN_ALIGNMENT,
|
||||
ID_CHOOSE_CONTENTS_ALIGNMENT,
|
||||
|
||||
ID_SET_MINWIDTH,
|
||||
ID_SET_WIDTH
|
||||
};
|
||||
|
||||
BEGIN_EVENT_TABLE(MyFrame, wxFrame)
|
||||
@@ -429,14 +466,11 @@ BEGIN_EVENT_TABLE(MyFrame, wxFrame)
|
||||
EVT_MENU( ID_EXIT, MyFrame::OnQuit )
|
||||
|
||||
// dataviewctrl menu
|
||||
EVT_MENU( ID_SINGLE_SEL_MODE, MyFrame::OnSingleSelMode )
|
||||
EVT_MENU( ID_MULTIPLE_SEL_MODE, MyFrame::OnMultipleSelMode )
|
||||
EVT_COMMAND_RANGE( ID_SINGLE_SEL_MODE, ID_VERT_RULES_MODE,
|
||||
wxEVT_COMMAND_MENU_SELECTED, MyFrame::OnStyleChange )
|
||||
|
||||
EVT_MENU( ID_RESIZEABLE_COLUMNS, MyFrame::OnResizeableColumn )
|
||||
EVT_MENU( ID_SORTABLE_COLUMNS, MyFrame::OnSortableColumn )
|
||||
EVT_MENU( ID_HIDDEN_COLUMNS, MyFrame::OnHideColumn )
|
||||
|
||||
EVT_MENU( ID_CHOOSE_ALIGNMENT, MyFrame::OnChooseAlign )
|
||||
EVT_COMMAND_RANGE( ID_RESIZEABLE_COLUMNS, ID_SET_WIDTH,
|
||||
wxEVT_COMMAND_MENU_SELECTED, MyFrame::OnColumnSetting )
|
||||
|
||||
END_EVENT_TABLE()
|
||||
|
||||
@@ -458,11 +492,19 @@ MyFrame::MyFrame(wxFrame *frame, wxChar *title, int x, int y, int w, int h):
|
||||
data_menu->AppendRadioItem(ID_SINGLE_SEL_MODE, _T("&Single selection mode"));
|
||||
data_menu->AppendRadioItem(ID_MULTIPLE_SEL_MODE, _T("&Multiple selection mode"));
|
||||
data_menu->AppendSeparator();
|
||||
data_menu->AppendCheckItem(ID_RESIZEABLE_COLUMNS, _T("Make columns resizeable"));
|
||||
data_menu->AppendCheckItem(ID_SORTABLE_COLUMNS, _T("Make columns sortable"));
|
||||
data_menu->AppendCheckItem(ID_HIDDEN_COLUMNS, _T("Make columns hidden"));
|
||||
data_menu->AppendCheckItem(ID_NO_HEADER_MODE, _T("No header mode"));
|
||||
data_menu->AppendCheckItem(ID_HORIZ_RULES_MODE, _T("Horizontal rules"));
|
||||
data_menu->AppendCheckItem(ID_VERT_RULES_MODE, _T("Vertical rules"));
|
||||
data_menu->AppendSeparator();
|
||||
data_menu->Append(ID_CHOOSE_ALIGNMENT, _T("Set alignment..."));
|
||||
data_menu->Append(ID_RESIZEABLE_COLUMNS, _T("Set column(s) as resizeable..."));
|
||||
data_menu->Append(ID_SORTABLE_COLUMNS, _T("Set column(s) as sortable..."));
|
||||
data_menu->Append(ID_HIDDEN_COLUMNS, _T("Set column(s) as hidden..."));
|
||||
data_menu->AppendSeparator();
|
||||
data_menu->Append(ID_CHOOSE_COLUMN_ALIGNMENT, _T("Set column(s) title alignment..."));
|
||||
data_menu->Append(ID_CHOOSE_CONTENTS_ALIGNMENT, _T("Set column(s) contents alignment..."));
|
||||
data_menu->AppendSeparator();
|
||||
data_menu->Append(ID_SET_MINWIDTH, _T("Set column(s) minimal width..."));
|
||||
data_menu->Append(ID_SET_WIDTH, _T("Set column(s) width..."));
|
||||
|
||||
wxMenuBar *menu_bar = new wxMenuBar;
|
||||
menu_bar->Append(file_menu, _T("&File"));
|
||||
@@ -472,19 +514,52 @@ MyFrame::MyFrame(wxFrame *frame, wxChar *title, int x, int y, int w, int h):
|
||||
CreateStatusBar();
|
||||
|
||||
|
||||
// check the menus for the default wxDataViewCtrl style
|
||||
data_menu->Check(ID_MULTIPLE_SEL_MODE, (DATAVIEW_DEFAULT_STYLE & wxDV_MULTIPLE) != 0);
|
||||
data_menu->Check(ID_NO_HEADER_MODE, (DATAVIEW_DEFAULT_STYLE & wxDV_NO_HEADER) != 0);
|
||||
data_menu->Check(ID_HORIZ_RULES_MODE, (DATAVIEW_DEFAULT_STYLE & wxDV_HORIZ_RULES) != 0);
|
||||
data_menu->Check(ID_VERT_RULES_MODE, (DATAVIEW_DEFAULT_STYLE & wxDV_VERT_RULES) != 0);
|
||||
|
||||
|
||||
// build the other controls:
|
||||
|
||||
m_splitter = new wxSplitterWindow( this, wxID_ANY );
|
||||
m_splitter->SetSashGravity(0.5);
|
||||
|
||||
m_align = wxALIGN_CENTER;
|
||||
dataview_left = dataview_right = NULL;
|
||||
CreateControls();
|
||||
m_panelLeft = new wxPanel( m_splitter, wxID_ANY, wxDefaultPosition, wxDefaultSize,
|
||||
wxNO_BORDER );
|
||||
m_panelRight = new wxPanel( m_splitter, wxID_ANY, wxDefaultPosition, wxDefaultSize,
|
||||
wxNO_BORDER );
|
||||
wxSizer *szLeft = new wxBoxSizer(wxVERTICAL);
|
||||
wxSizer *szRight = new wxBoxSizer(wxVERTICAL);
|
||||
|
||||
m_splitter->SplitVertically(dataview_left, dataview_right);
|
||||
dataview_left = NULL;
|
||||
dataview_right = NULL;
|
||||
CreateDataViewControls();
|
||||
|
||||
// left panel
|
||||
szLeft->Add( dataview_left, 1, wxGROW|wxALL, 5 );
|
||||
m_panelLeft->SetSizerAndFit(szLeft);
|
||||
|
||||
// right panel
|
||||
wxStaticText *stattext =
|
||||
new wxStaticText(m_panelRight, wxID_ANY,
|
||||
wxT("This is another wxDataViewCtrl using the same wxDataViewModel ")
|
||||
wxT("of the wxDataViewCtrl on the left but, unlike it, this window ")
|
||||
wxT("won't react to the style/column changes done through the ")
|
||||
wxT("'DataViewCtrl' menu"));
|
||||
stattext->Wrap(GetClientSize().GetWidth() / 2);
|
||||
|
||||
szRight->Add( stattext, 0, wxALL, 5 );
|
||||
szRight->Add( dataview_right, 1, wxGROW|wxALL, 5 );
|
||||
m_panelRight->SetSizerAndFit(szRight);
|
||||
|
||||
// split the two panels
|
||||
m_splitter->SplitVertically(m_panelLeft, m_panelRight);
|
||||
this->SetMinSize(m_splitter->GetBestSize());
|
||||
}
|
||||
|
||||
void MyFrame::CreateControls()
|
||||
void MyFrame::CreateDataViewControls()
|
||||
{
|
||||
wxDataViewCtrl *old1 = NULL, *old2 = NULL;
|
||||
|
||||
@@ -494,58 +569,52 @@ void MyFrame::CreateControls()
|
||||
old2 = dataview_right;
|
||||
|
||||
// styles:
|
||||
|
||||
long style = 0;
|
||||
if (GetMenuBar()->FindItem(ID_MULTIPLE_SEL_MODE)->IsChecked())
|
||||
style |= wxDV_MULTIPLE;
|
||||
|
||||
int flags = 0;
|
||||
if (GetMenuBar()->FindItem(ID_RESIZEABLE_COLUMNS)->IsChecked())
|
||||
flags |= wxDATAVIEW_COL_RESIZABLE;
|
||||
if (GetMenuBar()->FindItem(ID_SORTABLE_COLUMNS)->IsChecked())
|
||||
flags |= wxDATAVIEW_COL_SORTABLE;
|
||||
if (GetMenuBar()->FindItem(ID_HIDDEN_COLUMNS)->IsChecked())
|
||||
flags |= wxDATAVIEW_COL_HIDDEN;
|
||||
if (GetMenuBar()->FindItem(ID_NO_HEADER_MODE)->IsChecked())
|
||||
style |= wxDV_NO_HEADER;
|
||||
if (GetMenuBar()->FindItem(ID_HORIZ_RULES_MODE)->IsChecked())
|
||||
style |= wxDV_HORIZ_RULES;
|
||||
if (GetMenuBar()->FindItem(ID_VERT_RULES_MODE)->IsChecked())
|
||||
style |= wxDV_VERT_RULES;
|
||||
|
||||
|
||||
// Left wxDataViewCtrl
|
||||
dataview_left = new wxDataViewCtrl( m_splitter, wxID_ANY, wxDefaultPosition,
|
||||
dataview_left = new wxDataViewCtrl( m_panelLeft, wxID_ANY, wxDefaultPosition,
|
||||
wxDefaultSize, style );
|
||||
|
||||
MyTextModel *model = new MyTextModel;
|
||||
dataview_left->AssociateModel( model );
|
||||
model->DecRef(); // don't leak memory
|
||||
|
||||
dataview_left->AppendTextColumn( wxT("first"), 0, wxDATAVIEW_CELL_INERT, -1,
|
||||
m_align, flags );
|
||||
dataview_left->AppendTextColumn( wxT("second"), 1, wxDATAVIEW_CELL_INERT, -1,
|
||||
m_align, flags );
|
||||
wxObjectDataPtr<MyTextModel> model(new MyTextModel);
|
||||
dataview_left->AssociateModel( model.get() );
|
||||
|
||||
dataview_left->AppendTextColumn( wxT("First"), 0, wxDATAVIEW_CELL_INERT, -1,
|
||||
DEFAULT_ALIGN );
|
||||
dataview_left->AppendTextColumn( wxT("Second"), 1, wxDATAVIEW_CELL_INERT, -1,
|
||||
DEFAULT_ALIGN );
|
||||
|
||||
wxDataViewTextRenderer *text_renderer =
|
||||
new wxDataViewTextRenderer( wxT("string"), wxDATAVIEW_CELL_EDITABLE );
|
||||
wxDataViewColumn *column = new wxDataViewColumn( wxT("editable"), text_renderer, 2,
|
||||
-1, m_align, flags );
|
||||
-1, DEFAULT_ALIGN );
|
||||
dataview_left->AppendColumn( column );
|
||||
|
||||
dataview_left->AppendToggleColumn( wxT("fourth"), 3, wxDATAVIEW_CELL_INERT, -1,
|
||||
m_align, flags );
|
||||
dataview_left->AppendToggleColumn( wxT("fourth"), 3, wxDATAVIEW_CELL_INERT, -1,
|
||||
DEFAULT_ALIGN );
|
||||
|
||||
MyCustomRenderer *custom_renderer = new MyCustomRenderer;
|
||||
column = new wxDataViewColumn( wxT("custom"), custom_renderer, 4, -1,
|
||||
m_align, flags );
|
||||
column = new wxDataViewColumn( wxT("custom"), custom_renderer, 4, -1, DEFAULT_ALIGN );
|
||||
dataview_left->AppendColumn( column );
|
||||
|
||||
dataview_left->AppendProgressColumn( wxT("progress"), 5, wxDATAVIEW_CELL_INERT, -1,
|
||||
m_align, flags );
|
||||
dataview_left->AppendProgressColumn( wxT("progress"), 5, wxDATAVIEW_CELL_INERT, -1,
|
||||
DEFAULT_ALIGN );
|
||||
|
||||
dataview_left->AppendDateColumn( wxT("date"), 6, wxDATAVIEW_CELL_INERT, -1,
|
||||
m_align, flags );
|
||||
dataview_left->AppendDateColumn( wxT("date"), 6, wxDATAVIEW_CELL_INERT, -1, DEFAULT_ALIGN );
|
||||
|
||||
|
||||
// Right wxDataViewCtrl using the same model
|
||||
dataview_right = new wxDataViewCtrl( m_splitter, wxID_ANY, wxDefaultPosition,
|
||||
wxDefaultSize, style );
|
||||
dataview_right->AssociateModel( model );
|
||||
dataview_right = new wxDataViewCtrl( m_panelRight, wxID_ANY );
|
||||
dataview_right->AssociateModel( model.get() );
|
||||
|
||||
text_renderer = new wxDataViewTextRenderer( wxT("string"), wxDATAVIEW_CELL_EDITABLE );
|
||||
column = new wxDataViewColumn( wxT("editable"), text_renderer, 2 );
|
||||
@@ -559,17 +628,22 @@ void MyFrame::CreateControls()
|
||||
|
||||
dataview_right->AppendDateColumn( wxT("date"), 6 );
|
||||
|
||||
// layout dataview controls
|
||||
|
||||
// layout the new dataview controls
|
||||
if (old1)
|
||||
{
|
||||
m_splitter->ReplaceWindow(old1, dataview_left);
|
||||
m_panelLeft->GetSizer()->Replace(old1, dataview_left);
|
||||
delete old1;
|
||||
|
||||
m_panelLeft->Layout();
|
||||
}
|
||||
|
||||
if (old2)
|
||||
{
|
||||
m_splitter->ReplaceWindow(old2, dataview_right);
|
||||
m_panelRight->GetSizer()->Replace(old2, dataview_right);
|
||||
delete old2;
|
||||
|
||||
m_panelRight->Layout();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -595,32 +669,102 @@ void MyFrame::OnNewSortingFrame(wxCommandEvent& WXUNUSED(event) )
|
||||
frame2->Show(true);
|
||||
}
|
||||
|
||||
void MyFrame::OnSingleSelMode(wxCommandEvent& event)
|
||||
void MyFrame::OnStyleChange(wxCommandEvent& WXUNUSED(event) )
|
||||
{
|
||||
CreateControls();
|
||||
// recreate the wxDataViewCtrl:
|
||||
CreateDataViewControls();
|
||||
}
|
||||
|
||||
void MyFrame::OnMultipleSelMode(wxCommandEvent& event)
|
||||
void MyFrame::OnColumnSetting(wxCommandEvent& event)
|
||||
{
|
||||
CreateControls();
|
||||
wxArrayInt columns;
|
||||
int flag = 0;
|
||||
bool header = false, minwidth = false;
|
||||
wxString msg;
|
||||
|
||||
switch (event.GetId())
|
||||
{
|
||||
case ID_RESIZEABLE_COLUMNS:
|
||||
flag = wxDATAVIEW_COL_RESIZABLE;
|
||||
columns = GetFlaggedColumns(flag);
|
||||
break;
|
||||
case ID_SORTABLE_COLUMNS:
|
||||
flag = wxDATAVIEW_COL_SORTABLE;
|
||||
columns = GetFlaggedColumns(flag);
|
||||
break;
|
||||
case ID_HIDDEN_COLUMNS:
|
||||
flag = wxDATAVIEW_COL_HIDDEN;
|
||||
columns = GetFlaggedColumns(flag);
|
||||
break;
|
||||
|
||||
case ID_CHOOSE_COLUMN_ALIGNMENT:
|
||||
msg = wxT("Select the columns whose headers' alignment will be modified.");
|
||||
header = true;
|
||||
break;
|
||||
case ID_CHOOSE_CONTENTS_ALIGNMENT:
|
||||
msg = wxT("Select the columns whose contents' alignment will be modified.");
|
||||
header = false;
|
||||
break;
|
||||
|
||||
case ID_SET_MINWIDTH:
|
||||
msg = wxT("Please provide the new minimal width:");
|
||||
minwidth = true;
|
||||
break;
|
||||
case ID_SET_WIDTH:
|
||||
msg = wxT("Please provide the new width:");
|
||||
minwidth = false;
|
||||
break;
|
||||
}
|
||||
|
||||
// get column titles:
|
||||
|
||||
wxArrayString choices;
|
||||
for (size_t i=0; i<dataview_left->GetColumnCount(); i++)
|
||||
choices.Add(dataview_left->GetColumn(i)->GetTitle());
|
||||
|
||||
// ask the user
|
||||
wxGetMultipleChoices(
|
||||
columns,
|
||||
wxT("Choose the columns to which apply the change."),
|
||||
wxT("Choose the column"),
|
||||
choices,
|
||||
this);
|
||||
|
||||
switch (event.GetId())
|
||||
{
|
||||
case ID_RESIZEABLE_COLUMNS:
|
||||
case ID_SORTABLE_COLUMNS:
|
||||
case ID_HIDDEN_COLUMNS:
|
||||
SetFlag(columns, flag);
|
||||
break;
|
||||
|
||||
case ID_CHOOSE_COLUMN_ALIGNMENT:
|
||||
case ID_CHOOSE_CONTENTS_ALIGNMENT:
|
||||
SetAlignment(columns, header, ChooseAlign(msg, header));
|
||||
break;
|
||||
|
||||
case ID_SET_MINWIDTH:
|
||||
case ID_SET_WIDTH:
|
||||
{
|
||||
int def = minwidth ? wxDVC_DEFAULT_MINWIDTH : wxDVC_DEFAULT_WIDTH;
|
||||
|
||||
msg << wxT("\nNOTE: all non-selected columns will be reset to a width of ")
|
||||
<< def << wxT(" pixels.");
|
||||
|
||||
long ret =
|
||||
wxGetNumberFromUser(msg, wxT("New value:"), wxT("Modify width"),
|
||||
def, 0, 300, this);
|
||||
|
||||
if (ret != -1)
|
||||
SetWidth(columns, minwidth, ret);
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
||||
dataview_left->Refresh();
|
||||
}
|
||||
|
||||
void MyFrame::OnResizeableColumn(wxCommandEvent& event)
|
||||
{
|
||||
CreateControls();
|
||||
}
|
||||
|
||||
void MyFrame::OnSortableColumn(wxCommandEvent& event)
|
||||
{
|
||||
CreateControls();
|
||||
}
|
||||
|
||||
void MyFrame::OnHideColumn(wxCommandEvent& event)
|
||||
{
|
||||
CreateControls();
|
||||
}
|
||||
|
||||
void MyFrame::OnChooseAlign(wxCommandEvent& event)
|
||||
wxAlignment MyFrame::ChooseAlign(const wxString &msg, bool onlyHorizontal)
|
||||
{
|
||||
const wxString choices[] =
|
||||
{
|
||||
@@ -644,17 +788,78 @@ void MyFrame::OnChooseAlign(wxCommandEvent& event)
|
||||
wxALIGN_CENTER
|
||||
};
|
||||
|
||||
int n = WXSIZEOF(choices);
|
||||
if (onlyHorizontal)
|
||||
n = 3; // show only the first three choices
|
||||
|
||||
int choice = wxGetSingleChoiceIndex(
|
||||
wxT("Select the alignment for the cells of the wxDataViewCtrl:"),
|
||||
msg + wxT("\nNOTE: _all_ non-selected column's alignment will be reset to wxALIGN_LEFT!"),
|
||||
wxT("Alignment"),
|
||||
WXSIZEOF(choices), choices,
|
||||
n, choices,
|
||||
this);
|
||||
|
||||
if (choice == wxNOT_FOUND)
|
||||
return;
|
||||
return wxALIGN_LEFT;
|
||||
|
||||
m_align = flags[choice];
|
||||
CreateControls();
|
||||
return flags[choice];
|
||||
}
|
||||
|
||||
void MyFrame::SetFlag(const wxArrayInt &idx, int toadd)
|
||||
{
|
||||
for (size_t i=0; i<dataview_left->GetColumnCount(); i++)
|
||||
{
|
||||
int current = dataview_left->GetColumn(i)->GetFlags();
|
||||
|
||||
if (idx.Index(i) != wxNOT_FOUND)
|
||||
dataview_left->GetColumn(i)->SetFlags(current | toadd);
|
||||
else
|
||||
dataview_left->GetColumn(i)->SetFlags(current & ~toadd);
|
||||
}
|
||||
}
|
||||
|
||||
wxArrayInt MyFrame::GetFlaggedColumns(int flag)
|
||||
{
|
||||
wxArrayInt ret;
|
||||
for (size_t i=0; i<dataview_left->GetColumnCount(); i++)
|
||||
if (dataview_left->GetColumn(i)->GetFlags() & flag)
|
||||
ret.Add(i);
|
||||
return ret;
|
||||
}
|
||||
|
||||
void MyFrame::SetAlignment(const wxArrayInt &idx, bool header, wxAlignment align)
|
||||
{
|
||||
// set to DEFAULT_ALIGN all columns except those
|
||||
// contained in 'idx' which are set to 'align'
|
||||
|
||||
for (size_t i=0; i<dataview_left->GetColumnCount(); i++)
|
||||
{
|
||||
wxAlignment toset = DEFAULT_ALIGN;
|
||||
if (idx.Index(i) != wxNOT_FOUND)
|
||||
toset = align;
|
||||
|
||||
if (header)
|
||||
dataview_left->GetColumn(i)->SetAlignment(toset);
|
||||
else
|
||||
dataview_left->GetColumn(i)->GetRenderer()->SetAlignment(toset);
|
||||
}
|
||||
}
|
||||
|
||||
void MyFrame::SetWidth(const wxArrayInt &idx, bool minwidth, int width)
|
||||
{
|
||||
// set to wxDVC_DEFAULT_WIDTH wide all columns except those
|
||||
// contained in 'idx' which are set to 'width'
|
||||
|
||||
for (size_t i=0; i<dataview_left->GetColumnCount(); i++)
|
||||
{
|
||||
int toset = minwidth ? wxDVC_DEFAULT_MINWIDTH : wxDVC_DEFAULT_WIDTH;
|
||||
if (idx.Index(i) != wxNOT_FOUND)
|
||||
toset = width;
|
||||
|
||||
if (minwidth)
|
||||
dataview_left->GetColumn(i)->SetMinWidth(toset);
|
||||
else
|
||||
dataview_left->GetColumn(i)->SetWidth(toset);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -690,9 +895,8 @@ MySortingFrame::MySortingFrame(wxFrame *frame, wxChar *title, int x, int y, int
|
||||
dataview_left = new wxDataViewCtrl( main, ID_UNSORTED, wxDefaultPosition,
|
||||
wxDefaultSize, wxDV_MULTIPLE );
|
||||
|
||||
m_unsorted_model = new MyUnsortedTextModel;
|
||||
dataview_left->AssociateModel( m_unsorted_model );
|
||||
m_unsorted_model->DecRef(); // don't leak memory
|
||||
m_unsorted_model.reset(new MyUnsortedTextModel);
|
||||
dataview_left->AssociateModel( m_unsorted_model.get() );
|
||||
|
||||
wxDataViewTextRenderer *text_renderer =
|
||||
new wxDataViewTextRenderer( wxT("string"), wxDATAVIEW_CELL_EDITABLE );
|
||||
@@ -707,9 +911,8 @@ MySortingFrame::MySortingFrame(wxFrame *frame, wxChar *title, int x, int y, int
|
||||
// Right wxDataViewCtrl using the sorting model
|
||||
dataview_right = new wxDataViewCtrl( main, ID_SORTED );
|
||||
|
||||
m_sorted_model = new wxDataViewSortedListModel( m_unsorted_model );
|
||||
dataview_right->AssociateModel( m_sorted_model );
|
||||
m_sorted_model->DecRef(); // don't leak memory
|
||||
m_sorted_model.reset(new wxDataViewSortedListModel( m_unsorted_model.get() ));
|
||||
dataview_right->AssociateModel( m_sorted_model.get() );
|
||||
|
||||
text_renderer = new wxDataViewTextRenderer( wxT("string"), wxDATAVIEW_CELL_EDITABLE );
|
||||
column = new wxDataViewColumn( wxT("editable"), text_renderer, 0, -1,
|
||||
|
@@ -344,7 +344,7 @@ void wxDataViewSortedListModel::Resort()
|
||||
InitStatics();
|
||||
|
||||
m_array.Clear();
|
||||
unsigned int n = m_child->GetNumberOfRows();
|
||||
unsigned int n = m_child->GetRowCount();
|
||||
unsigned int i;
|
||||
for (i = 0; i < n; i++)
|
||||
m_array.Add( i );
|
||||
@@ -353,7 +353,7 @@ void wxDataViewSortedListModel::Resort()
|
||||
#if 0
|
||||
static void Dump( wxDataViewListModel *model, unsigned int col )
|
||||
{
|
||||
unsigned int n = model->GetNumberOfRows();
|
||||
unsigned int n = model->GetRowCount();
|
||||
unsigned int i;
|
||||
for (i = 0; i < n; i++)
|
||||
{
|
||||
@@ -579,22 +579,22 @@ bool wxDataViewSortedListModel::ChildCleared()
|
||||
return wxDataViewListModel::Cleared();
|
||||
}
|
||||
|
||||
unsigned int wxDataViewSortedListModel::GetNumberOfRows()
|
||||
unsigned int wxDataViewSortedListModel::GetRowCount() const
|
||||
{
|
||||
return m_array.GetCount();
|
||||
}
|
||||
|
||||
unsigned int wxDataViewSortedListModel::GetNumberOfCols()
|
||||
unsigned int wxDataViewSortedListModel::GetColumnCount() const
|
||||
{
|
||||
return m_child->GetNumberOfCols();
|
||||
return m_child->GetColumnCount();
|
||||
}
|
||||
|
||||
wxString wxDataViewSortedListModel::GetColType( unsigned int col )
|
||||
wxString wxDataViewSortedListModel::GetColumnType( unsigned int col ) const
|
||||
{
|
||||
return m_child->GetColType( col );
|
||||
return m_child->GetColumnType( col );
|
||||
}
|
||||
|
||||
void wxDataViewSortedListModel::GetValue( wxVariant &variant, unsigned int col, unsigned int row )
|
||||
void wxDataViewSortedListModel::GetValue( wxVariant &variant, unsigned int col, unsigned int row ) const
|
||||
{
|
||||
unsigned int child_row = m_array[row];
|
||||
m_child->GetValue( variant, col, child_row );
|
||||
@@ -701,10 +701,16 @@ bool wxDataViewSortedListModel::Cleared()
|
||||
|
||||
IMPLEMENT_ABSTRACT_CLASS(wxDataViewRendererBase, wxObject)
|
||||
|
||||
wxDataViewRendererBase::wxDataViewRendererBase( const wxString &varianttype, wxDataViewCellMode mode )
|
||||
wxDataViewRendererBase::wxDataViewRendererBase( const wxString &varianttype,
|
||||
wxDataViewCellMode WXUNUSED(mode),
|
||||
int WXUNUSED(align) )
|
||||
{
|
||||
m_variantType = varianttype;
|
||||
m_mode = mode;
|
||||
}
|
||||
|
||||
const wxDataViewCtrl* wxDataViewRendererBase::GetView() const
|
||||
{
|
||||
return wx_const_cast(wxDataViewRendererBase*, this)->GetOwner()->GetOwner();
|
||||
}
|
||||
|
||||
// ---------------------------------------------------------
|
||||
@@ -713,19 +719,20 @@ wxDataViewRendererBase::wxDataViewRendererBase( const wxString &varianttype, wxD
|
||||
|
||||
IMPLEMENT_ABSTRACT_CLASS(wxDataViewColumnBase, wxObject)
|
||||
|
||||
wxDataViewColumnBase::wxDataViewColumnBase(const wxString& title,
|
||||
wxDataViewColumnBase::wxDataViewColumnBase(const wxString& WXUNUSED(title),
|
||||
wxDataViewRenderer *renderer,
|
||||
unsigned int model_column,
|
||||
int WXUNUSED(width),
|
||||
wxAlignment WXUNUSED(align),
|
||||
int flags )
|
||||
int WXUNUSED(flags))
|
||||
{
|
||||
m_renderer = renderer;
|
||||
m_model_column = model_column;
|
||||
m_flags = flags;
|
||||
m_title = title;
|
||||
m_owner = NULL;
|
||||
m_renderer->SetOwner( (wxDataViewColumn*) this );
|
||||
|
||||
// NOTE: the wxDataViewColumn's ctor must store the width, align, flags
|
||||
// parameters inside the native control!
|
||||
}
|
||||
|
||||
wxDataViewColumnBase::wxDataViewColumnBase(const wxBitmap& bitmap,
|
||||
@@ -733,11 +740,10 @@ wxDataViewColumnBase::wxDataViewColumnBase(const wxBitmap& bitmap,
|
||||
unsigned int model_column,
|
||||
int WXUNUSED(width),
|
||||
wxAlignment WXUNUSED(align),
|
||||
int flags )
|
||||
int WXUNUSED(flags) )
|
||||
{
|
||||
m_renderer = renderer;
|
||||
m_model_column = model_column;
|
||||
m_flags = flags;
|
||||
m_bitmap = bitmap;
|
||||
m_owner = NULL;
|
||||
m_renderer->SetOwner( (wxDataViewColumn*) this );
|
||||
@@ -754,25 +760,27 @@ wxDataViewColumnBase::~wxDataViewColumnBase()
|
||||
}
|
||||
}
|
||||
|
||||
void wxDataViewColumnBase::SetTitle( const wxString &title )
|
||||
int wxDataViewColumnBase::GetFlags() const
|
||||
{
|
||||
m_title = title;
|
||||
int ret = 0;
|
||||
|
||||
if (IsSortable())
|
||||
ret |= wxDATAVIEW_COL_SORTABLE;
|
||||
if (IsResizeable())
|
||||
ret |= wxDATAVIEW_COL_RESIZABLE;
|
||||
if (IsHidden())
|
||||
ret |= wxDATAVIEW_COL_HIDDEN;
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
wxString wxDataViewColumnBase::GetTitle()
|
||||
void wxDataViewColumnBase::SetFlags(int flags)
|
||||
{
|
||||
return m_title;
|
||||
SetSortable((flags & wxDATAVIEW_COL_SORTABLE) != 0);
|
||||
SetResizeable((flags & wxDATAVIEW_COL_RESIZABLE) != 0);
|
||||
SetHidden((flags & wxDATAVIEW_COL_HIDDEN) != 0);
|
||||
}
|
||||
|
||||
void wxDataViewColumnBase::SetBitmap( const wxBitmap &bitmap )
|
||||
{
|
||||
m_bitmap = bitmap;
|
||||
}
|
||||
|
||||
const wxBitmap &wxDataViewColumnBase::GetBitmap()
|
||||
{
|
||||
return m_bitmap;
|
||||
}
|
||||
|
||||
// ---------------------------------------------------------
|
||||
// wxDataViewCtrlBase
|
||||
@@ -822,80 +830,80 @@ bool wxDataViewCtrlBase::AppendTextColumn( const wxString &label, unsigned int m
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewTextRenderer( wxT("string"), mode ), model_column,
|
||||
width, align, flags ) );
|
||||
new wxDataViewTextRenderer( wxT("string"), mode, (int)align ),
|
||||
model_column, width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendToggleColumn( const wxString &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewToggleRenderer( wxT("bool"), mode ), model_column,
|
||||
width, align, flags ) );
|
||||
new wxDataViewToggleRenderer( wxT("bool"), mode, (int)align ),
|
||||
model_column, width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendProgressColumn( const wxString &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewProgressRenderer( wxEmptyString, wxT("long"), mode ), model_column,
|
||||
width, align, flags ) );
|
||||
new wxDataViewProgressRenderer( wxEmptyString, wxT("long"), mode, (int)align ),
|
||||
model_column, width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendDateColumn( const wxString &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewDateRenderer( wxT("datetime"), mode), model_column,
|
||||
width, align, flags ) );
|
||||
new wxDataViewDateRenderer( wxT("datetime"), mode, (int)align ),
|
||||
model_column, width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendBitmapColumn( const wxString &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewBitmapRenderer( wxT("wxBitmap"), mode ), model_column,
|
||||
width, align, flags ) );
|
||||
new wxDataViewBitmapRenderer( wxT("wxBitmap"), mode, (int)align ),
|
||||
model_column, width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendTextColumn( const wxBitmap &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewTextRenderer( wxT("string"), mode ), model_column,
|
||||
width, align, flags ) );
|
||||
new wxDataViewTextRenderer( wxT("string"), mode, (int)align ),
|
||||
model_column, width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendToggleColumn( const wxBitmap &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewToggleRenderer( wxT("bool"), mode ), model_column,
|
||||
width, align, flags ) );
|
||||
new wxDataViewToggleRenderer( wxT("bool"), mode, (int)align ),
|
||||
model_column, width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendProgressColumn( const wxBitmap &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewProgressRenderer( wxEmptyString, wxT("long"), mode ), model_column,
|
||||
width, align, flags ) );
|
||||
new wxDataViewProgressRenderer( wxEmptyString, wxT("long"), mode, (int)align ),
|
||||
model_column, width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendDateColumn( const wxBitmap &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewDateRenderer( wxT("datetime"), mode ), model_column,
|
||||
width, align, flags ) );
|
||||
new wxDataViewDateRenderer( wxT("datetime"), mode, (int)align ),
|
||||
model_column, width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendBitmapColumn( const wxBitmap &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewBitmapRenderer( wxT("wxBitmap"), mode ), model_column,
|
||||
width, align, flags ) );
|
||||
new wxDataViewBitmapRenderer( wxT("wxBitmap"), mode, (int)align ),
|
||||
model_column, width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendColumn( wxDataViewColumn *col )
|
||||
@@ -906,7 +914,7 @@ bool wxDataViewCtrlBase::AppendColumn( wxDataViewColumn *col )
|
||||
return true;
|
||||
}
|
||||
|
||||
unsigned int wxDataViewCtrlBase::GetNumberOfColumns()
|
||||
unsigned int wxDataViewCtrlBase::GetColumnCount() const
|
||||
{
|
||||
return m_cols.GetCount();
|
||||
}
|
||||
|
File diff suppressed because it is too large
Load Diff
@@ -235,7 +235,7 @@ wxgtk_list_store_get_n_columns (GtkTreeModel *tree_model)
|
||||
GtkWxListStore *list_store = (GtkWxListStore *) tree_model;
|
||||
g_return_val_if_fail (GTK_IS_WX_LIST_STORE (tree_model), 0);
|
||||
|
||||
return list_store->model->GetNumberOfCols();
|
||||
return list_store->model->GetColumnCount();
|
||||
}
|
||||
|
||||
static GType
|
||||
@@ -247,7 +247,7 @@ wxgtk_list_store_get_column_type (GtkTreeModel *tree_model,
|
||||
|
||||
GType gtype = G_TYPE_INVALID;
|
||||
|
||||
wxString wxtype = list_store->model->GetColType( (unsigned int) index );
|
||||
wxString wxtype = list_store->model->GetColumnType( (unsigned int) index );
|
||||
|
||||
if (wxtype == wxT("string"))
|
||||
gtype = G_TYPE_STRING;
|
||||
@@ -270,7 +270,7 @@ wxgtk_list_store_get_iter (GtkTreeModel *tree_model,
|
||||
|
||||
unsigned int i = (unsigned int)gtk_tree_path_get_indices (path)[0];
|
||||
|
||||
if (i >= list_store->model->GetNumberOfRows())
|
||||
if (i >= list_store->model->GetRowCount())
|
||||
return FALSE;
|
||||
|
||||
iter->stamp = list_store->stamp;
|
||||
@@ -304,7 +304,7 @@ wxgtk_list_store_get_value (GtkTreeModel *tree_model,
|
||||
g_return_if_fail (GTK_IS_WX_LIST_STORE (tree_model) );
|
||||
|
||||
wxDataViewListModel *model = list_store->model;
|
||||
wxString mtype = model->GetColType( (unsigned int) column );
|
||||
wxString mtype = model->GetColumnType( (unsigned int) column );
|
||||
if (mtype == wxT("string"))
|
||||
{
|
||||
wxVariant variant;
|
||||
@@ -336,7 +336,7 @@ wxgtk_list_store_iter_next (GtkTreeModel *tree_model,
|
||||
if (n == -1)
|
||||
return FALSE;
|
||||
|
||||
if (n >= (int) list_store->model->GetNumberOfRows()-1)
|
||||
if (n >= (int) list_store->model->GetRowCount()-1)
|
||||
return FALSE;
|
||||
|
||||
iter->user_data = (gpointer) ++n;
|
||||
@@ -377,7 +377,7 @@ wxgtk_list_store_iter_n_children (GtkTreeModel *tree_model,
|
||||
GtkWxListStore *list_store = (GtkWxListStore *) tree_model;
|
||||
|
||||
if (iter == NULL)
|
||||
return (gint) list_store->model->GetNumberOfRows();
|
||||
return (gint) list_store->model->GetRowCount();
|
||||
|
||||
g_return_val_if_fail (list_store->stamp == iter->stamp, -1);
|
||||
|
||||
@@ -399,7 +399,7 @@ wxgtk_list_store_iter_nth_child (GtkTreeModel *tree_model,
|
||||
if (n < 0)
|
||||
return FALSE;
|
||||
|
||||
if (n >= (gint) list_store->model->GetNumberOfRows())
|
||||
if (n >= (gint) list_store->model->GetRowCount())
|
||||
return FALSE;
|
||||
|
||||
iter->stamp = list_store->stamp;
|
||||
@@ -727,11 +727,11 @@ public:
|
||||
virtual bool Cleared();
|
||||
|
||||
virtual bool Freed()
|
||||
{
|
||||
m_wx_model = NULL;
|
||||
m_gtk_store = NULL;
|
||||
return wxDataViewListModelNotifier::Freed();
|
||||
}
|
||||
{
|
||||
m_wx_model = NULL;
|
||||
m_gtk_store = NULL;
|
||||
return wxDataViewListModelNotifier::Freed();
|
||||
}
|
||||
|
||||
GtkWxListStore *m_gtk_store;
|
||||
wxDataViewListModel *m_wx_model;
|
||||
@@ -750,7 +750,7 @@ wxGtkDataViewListModelNotifier::wxGtkDataViewListModelNotifier(
|
||||
|
||||
bool wxGtkDataViewListModelNotifier::RowAppended()
|
||||
{
|
||||
unsigned int pos = m_wx_model->GetNumberOfRows()-1;
|
||||
unsigned int pos = m_wx_model->GetRowCount()-1;
|
||||
|
||||
GtkTreeIter iter;
|
||||
iter.stamp = m_gtk_store->stamp;
|
||||
@@ -879,12 +879,130 @@ bool wxGtkDataViewListModelNotifier::Cleared()
|
||||
|
||||
IMPLEMENT_ABSTRACT_CLASS(wxDataViewRenderer, wxDataViewRendererBase)
|
||||
|
||||
wxDataViewRenderer::wxDataViewRenderer( const wxString &varianttype, wxDataViewCellMode mode ) :
|
||||
wxDataViewRendererBase( varianttype, mode )
|
||||
wxDataViewRenderer::wxDataViewRenderer( const wxString &varianttype, wxDataViewCellMode mode,
|
||||
int align ) :
|
||||
wxDataViewRendererBase( varianttype, mode, align )
|
||||
{
|
||||
m_renderer = NULL;
|
||||
|
||||
// NOTE: SetMode() and SetAlignment() needs to be called in the renderer's ctor,
|
||||
// after the m_renderer pointer has been initialized
|
||||
}
|
||||
|
||||
void wxDataViewRenderer::SetMode( wxDataViewCellMode mode )
|
||||
{
|
||||
GtkCellRendererMode gtkMode;
|
||||
switch (mode)
|
||||
{
|
||||
case wxDATAVIEW_CELL_INERT:
|
||||
gtkMode = GTK_CELL_RENDERER_MODE_INERT;
|
||||
break;
|
||||
case wxDATAVIEW_CELL_ACTIVATABLE:
|
||||
gtkMode = GTK_CELL_RENDERER_MODE_ACTIVATABLE;
|
||||
break;
|
||||
case wxDATAVIEW_CELL_EDITABLE:
|
||||
gtkMode = GTK_CELL_RENDERER_MODE_EDITABLE;
|
||||
break;
|
||||
}
|
||||
|
||||
GValue gvalue = { 0, };
|
||||
g_value_init( &gvalue, gtk_cell_renderer_mode_get_type() );
|
||||
g_value_set_enum( &gvalue, gtkMode );
|
||||
g_object_set_property( G_OBJECT(m_renderer), "mode", &gvalue );
|
||||
g_value_unset( &gvalue );
|
||||
}
|
||||
|
||||
wxDataViewCellMode wxDataViewRenderer::GetMode() const
|
||||
{
|
||||
wxDataViewCellMode ret;
|
||||
|
||||
GValue gvalue;
|
||||
g_object_get( G_OBJECT(m_renderer), "mode", &gvalue, NULL);
|
||||
|
||||
switch (g_value_get_enum(&gvalue))
|
||||
{
|
||||
case GTK_CELL_RENDERER_MODE_INERT:
|
||||
ret = wxDATAVIEW_CELL_INERT;
|
||||
break;
|
||||
case GTK_CELL_RENDERER_MODE_ACTIVATABLE:
|
||||
ret = wxDATAVIEW_CELL_ACTIVATABLE;
|
||||
break;
|
||||
case GTK_CELL_RENDERER_MODE_EDITABLE:
|
||||
ret = wxDATAVIEW_CELL_EDITABLE;
|
||||
break;
|
||||
}
|
||||
|
||||
g_value_unset( &gvalue );
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
void wxDataViewRenderer::SetAlignment( int align )
|
||||
{
|
||||
// horizontal alignment:
|
||||
|
||||
gfloat xalign = 0.0;
|
||||
if (align & wxALIGN_RIGHT)
|
||||
xalign = 1.0;
|
||||
else if (align & wxALIGN_CENTER_HORIZONTAL)
|
||||
xalign = 0.5;
|
||||
|
||||
GValue gvalue = { 0, };
|
||||
g_value_init( &gvalue, G_TYPE_FLOAT );
|
||||
g_value_set_float( &gvalue, xalign );
|
||||
g_object_set_property( G_OBJECT(m_renderer), "xalign", &gvalue );
|
||||
g_value_unset( &gvalue );
|
||||
|
||||
// vertical alignment:
|
||||
|
||||
gfloat yalign = 0.0;
|
||||
if (align & wxALIGN_BOTTOM)
|
||||
yalign = 1.0;
|
||||
else if (align & wxALIGN_CENTER_VERTICAL)
|
||||
yalign = 0.5;
|
||||
|
||||
GValue gvalue2 = { 0, };
|
||||
g_value_init( &gvalue2, G_TYPE_FLOAT );
|
||||
g_value_set_float( &gvalue2, yalign );
|
||||
g_object_set_property( G_OBJECT(m_renderer), "yalign", &gvalue2 );
|
||||
g_value_unset( &gvalue2 );
|
||||
}
|
||||
|
||||
int wxDataViewRenderer::GetAlignment() const
|
||||
{
|
||||
int ret = 0;
|
||||
GValue gvalue;
|
||||
|
||||
// horizontal alignment:
|
||||
|
||||
g_object_get( G_OBJECT(m_renderer), "xalign", &gvalue, NULL );
|
||||
float xalign = g_value_get_float( &gvalue );
|
||||
if (xalign < 0.5)
|
||||
ret |= wxALIGN_LEFT;
|
||||
else if (xalign == 0.5)
|
||||
ret |= wxALIGN_CENTER_HORIZONTAL;
|
||||
else
|
||||
ret |= wxALIGN_RIGHT;
|
||||
g_value_unset( &gvalue );
|
||||
|
||||
|
||||
// vertical alignment:
|
||||
|
||||
g_object_get( G_OBJECT(m_renderer), "yalign", &gvalue, NULL );
|
||||
float yalign = g_value_get_float( &gvalue );
|
||||
if (yalign < 0.5)
|
||||
ret |= wxALIGN_TOP;
|
||||
else if (yalign == 0.5)
|
||||
ret |= wxALIGN_CENTER_VERTICAL;
|
||||
else
|
||||
ret |= wxALIGN_BOTTOM;
|
||||
g_value_unset( &gvalue );
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
||||
|
||||
// ---------------------------------------------------------
|
||||
// wxDataViewTextRenderer
|
||||
// ---------------------------------------------------------
|
||||
@@ -918,12 +1036,13 @@ static void wxGtkTextRendererEditedCallback( GtkCellRendererText *renderer,
|
||||
|
||||
IMPLEMENT_CLASS(wxDataViewTextRenderer, wxDataViewRenderer)
|
||||
|
||||
wxDataViewTextRenderer::wxDataViewTextRenderer( const wxString &varianttype, wxDataViewCellMode mode ) :
|
||||
wxDataViewRenderer( varianttype, mode )
|
||||
wxDataViewTextRenderer::wxDataViewTextRenderer( const wxString &varianttype, wxDataViewCellMode mode,
|
||||
int align ) :
|
||||
wxDataViewRenderer( varianttype, mode, align )
|
||||
{
|
||||
m_renderer = (void*) gtk_cell_renderer_text_new();
|
||||
m_renderer = (GtkWidget*) gtk_cell_renderer_text_new();
|
||||
|
||||
if (m_mode & wxDATAVIEW_CELL_EDITABLE)
|
||||
if (mode & wxDATAVIEW_CELL_EDITABLE)
|
||||
{
|
||||
GValue gvalue = { 0, };
|
||||
g_value_init( &gvalue, G_TYPE_BOOLEAN );
|
||||
@@ -933,6 +1052,9 @@ wxDataViewTextRenderer::wxDataViewTextRenderer( const wxString &varianttype, wxD
|
||||
|
||||
g_signal_connect_after( m_renderer, "edited", G_CALLBACK(wxGtkTextRendererEditedCallback), this );
|
||||
}
|
||||
|
||||
SetMode(mode);
|
||||
SetAlignment(align);
|
||||
}
|
||||
|
||||
bool wxDataViewTextRenderer::SetValue( const wxVariant &value )
|
||||
@@ -948,7 +1070,7 @@ bool wxDataViewTextRenderer::SetValue( const wxVariant &value )
|
||||
return true;
|
||||
}
|
||||
|
||||
bool wxDataViewTextRenderer::GetValue( wxVariant &value )
|
||||
bool wxDataViewTextRenderer::GetValue( wxVariant &value ) const
|
||||
{
|
||||
GValue gvalue = { 0, };
|
||||
g_value_init( &gvalue, G_TYPE_STRING );
|
||||
@@ -961,16 +1083,39 @@ bool wxDataViewTextRenderer::GetValue( wxVariant &value )
|
||||
return true;
|
||||
}
|
||||
|
||||
void wxDataViewTextRenderer::SetAlignment( int align )
|
||||
{
|
||||
wxDataViewRenderer::SetAlignment(align);
|
||||
|
||||
// horizontal alignment:
|
||||
|
||||
PangoAlignment pangoAlign = PANGO_ALIGN_LEFT;
|
||||
if (align & wxALIGN_RIGHT)
|
||||
pangoAlign = PANGO_ALIGN_RIGHT;
|
||||
else if (align & wxALIGN_CENTER_HORIZONTAL)
|
||||
pangoAlign = PANGO_ALIGN_CENTER;
|
||||
|
||||
GValue gvalue = { 0, };
|
||||
g_value_init( &gvalue, gtk_cell_renderer_mode_get_type() );
|
||||
g_value_set_enum( &gvalue, pangoAlign );
|
||||
g_object_set_property( G_OBJECT(m_renderer), "alignment", &gvalue );
|
||||
g_value_unset( &gvalue );
|
||||
}
|
||||
|
||||
// ---------------------------------------------------------
|
||||
// wxDataViewBitmapRenderer
|
||||
// ---------------------------------------------------------
|
||||
|
||||
IMPLEMENT_CLASS(wxDataViewBitmapRenderer, wxDataViewRenderer)
|
||||
|
||||
wxDataViewBitmapRenderer::wxDataViewBitmapRenderer( const wxString &varianttype, wxDataViewCellMode mode ) :
|
||||
wxDataViewRenderer( varianttype, mode )
|
||||
wxDataViewBitmapRenderer::wxDataViewBitmapRenderer( const wxString &varianttype, wxDataViewCellMode mode,
|
||||
int align ) :
|
||||
wxDataViewRenderer( varianttype, mode, align )
|
||||
{
|
||||
m_renderer = (void*) gtk_cell_renderer_pixbuf_new();
|
||||
m_renderer = (GtkWidget*) gtk_cell_renderer_pixbuf_new();
|
||||
|
||||
SetMode(mode);
|
||||
SetAlignment(align);
|
||||
}
|
||||
|
||||
bool wxDataViewBitmapRenderer::SetValue( const wxVariant &value )
|
||||
@@ -1014,7 +1159,7 @@ bool wxDataViewBitmapRenderer::SetValue( const wxVariant &value )
|
||||
return false;
|
||||
}
|
||||
|
||||
bool wxDataViewBitmapRenderer::GetValue( wxVariant &value )
|
||||
bool wxDataViewBitmapRenderer::GetValue( wxVariant &value ) const
|
||||
{
|
||||
return false;
|
||||
}
|
||||
@@ -1061,31 +1206,27 @@ static void wxGtkToggleRendererToggledCallback( GtkCellRendererToggle *renderer,
|
||||
IMPLEMENT_CLASS(wxDataViewToggleRenderer, wxDataViewRenderer)
|
||||
|
||||
wxDataViewToggleRenderer::wxDataViewToggleRenderer( const wxString &varianttype,
|
||||
wxDataViewCellMode mode ) :
|
||||
wxDataViewRenderer( varianttype, mode )
|
||||
wxDataViewCellMode mode, int align ) :
|
||||
wxDataViewRenderer( varianttype, mode, align )
|
||||
{
|
||||
m_renderer = (void*) gtk_cell_renderer_toggle_new();
|
||||
m_renderer = (GtkWidget*) gtk_cell_renderer_toggle_new();
|
||||
|
||||
if (m_mode & wxDATAVIEW_CELL_ACTIVATABLE)
|
||||
if (mode & wxDATAVIEW_CELL_ACTIVATABLE)
|
||||
{
|
||||
g_signal_connect_after( m_renderer, "toggled", G_CALLBACK(wxGtkToggleRendererToggledCallback), this );
|
||||
g_signal_connect_after( m_renderer, "toggled",
|
||||
G_CALLBACK(wxGtkToggleRendererToggledCallback), this );
|
||||
}
|
||||
else
|
||||
{
|
||||
|
||||
GValue gvalue = { 0, };
|
||||
g_value_init( &gvalue, G_TYPE_BOOLEAN );
|
||||
g_value_set_boolean( &gvalue, false );
|
||||
g_object_set_property( G_OBJECT(m_renderer), "activatable", &gvalue );
|
||||
g_value_unset( &gvalue );
|
||||
|
||||
GValue gvalue2 = { 0, };
|
||||
g_value_init( &gvalue2, gtk_cell_renderer_mode_get_type() );
|
||||
g_value_set_enum( &gvalue2, GTK_CELL_RENDERER_MODE_INERT );
|
||||
g_object_set_property( G_OBJECT(m_renderer), "mode", &gvalue2 );
|
||||
g_value_unset( &gvalue2 );
|
||||
|
||||
}
|
||||
|
||||
SetMode(mode);
|
||||
SetAlignment(align);
|
||||
}
|
||||
|
||||
bool wxDataViewToggleRenderer::SetValue( const wxVariant &value )
|
||||
@@ -1101,7 +1242,7 @@ bool wxDataViewToggleRenderer::SetValue( const wxVariant &value )
|
||||
return true;
|
||||
}
|
||||
|
||||
bool wxDataViewToggleRenderer::GetValue( wxVariant &value )
|
||||
bool wxDataViewToggleRenderer::GetValue( wxVariant &value ) const
|
||||
{
|
||||
GValue gvalue = { 0, };
|
||||
g_value_init( &gvalue, G_TYPE_BOOLEAN );
|
||||
@@ -1146,32 +1287,27 @@ public:
|
||||
IMPLEMENT_CLASS(wxDataViewCustomRenderer, wxDataViewRenderer)
|
||||
|
||||
wxDataViewCustomRenderer::wxDataViewCustomRenderer( const wxString &varianttype,
|
||||
wxDataViewCellMode mode, bool no_init ) :
|
||||
wxDataViewRenderer( varianttype, mode )
|
||||
wxDataViewCellMode mode, int align,
|
||||
bool no_init ) :
|
||||
wxDataViewRenderer( varianttype, mode, align )
|
||||
{
|
||||
m_dc = NULL;
|
||||
|
||||
if (no_init)
|
||||
m_renderer = NULL;
|
||||
else
|
||||
Init();
|
||||
Init(mode, align);
|
||||
}
|
||||
|
||||
bool wxDataViewCustomRenderer::Init()
|
||||
bool wxDataViewCustomRenderer::Init(wxDataViewCellMode mode, int align)
|
||||
{
|
||||
GtkWxCellRenderer *renderer = (GtkWxCellRenderer *) gtk_wx_cell_renderer_new();
|
||||
renderer->cell = this;
|
||||
|
||||
m_renderer = (void*) renderer;
|
||||
m_renderer = (GtkWidget*) renderer;
|
||||
|
||||
if (m_mode & wxDATAVIEW_CELL_ACTIVATABLE)
|
||||
{
|
||||
GValue gvalue = { 0, };
|
||||
g_value_init( &gvalue, gtk_cell_renderer_mode_get_type() );
|
||||
g_value_set_enum( &gvalue, GTK_CELL_RENDERER_MODE_ACTIVATABLE );
|
||||
g_object_set_property( G_OBJECT(m_renderer), "mode", &gvalue );
|
||||
g_value_unset( &gvalue );
|
||||
}
|
||||
SetMode(mode);
|
||||
SetAlignment(align);
|
||||
|
||||
return true;
|
||||
}
|
||||
@@ -1203,8 +1339,8 @@ wxDC *wxDataViewCustomRenderer::GetDC()
|
||||
IMPLEMENT_CLASS(wxDataViewProgressRenderer, wxDataViewCustomRenderer)
|
||||
|
||||
wxDataViewProgressRenderer::wxDataViewProgressRenderer( const wxString &label,
|
||||
const wxString &varianttype, wxDataViewCellMode mode ) :
|
||||
wxDataViewCustomRenderer( varianttype, mode, true )
|
||||
const wxString &varianttype, wxDataViewCellMode mode, int align ) :
|
||||
wxDataViewCustomRenderer( varianttype, mode, align, true )
|
||||
{
|
||||
m_label = label;
|
||||
m_value = 0;
|
||||
@@ -1212,7 +1348,7 @@ wxDataViewProgressRenderer::wxDataViewProgressRenderer( const wxString &label,
|
||||
#ifdef __WXGTK26__
|
||||
if (!gtk_check_version(2,6,0))
|
||||
{
|
||||
m_renderer = (void*) gtk_cell_renderer_progress_new();
|
||||
m_renderer = (GtkWidget*) gtk_cell_renderer_progress_new();
|
||||
|
||||
GValue gvalue = { 0, };
|
||||
g_value_init( &gvalue, G_TYPE_STRING );
|
||||
@@ -1221,12 +1357,15 @@ wxDataViewProgressRenderer::wxDataViewProgressRenderer( const wxString &label,
|
||||
g_value_set_string( &gvalue, wxGTK_CONV_SYS(m_label) );
|
||||
g_object_set_property( G_OBJECT(m_renderer), "text", &gvalue );
|
||||
g_value_unset( &gvalue );
|
||||
|
||||
SetMode(mode);
|
||||
SetAlignment(align);
|
||||
}
|
||||
else
|
||||
#endif
|
||||
{
|
||||
// Use custom cell code
|
||||
wxDataViewCustomRenderer::Init();
|
||||
wxDataViewCustomRenderer::Init(mode, align);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1258,6 +1397,11 @@ bool wxDataViewProgressRenderer::SetValue( const wxVariant &value )
|
||||
return true;
|
||||
}
|
||||
|
||||
bool wxDataViewProgressRenderer::GetValue( wxVariant &value ) const
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
bool wxDataViewProgressRenderer::Render( wxRect cell, wxDC *dc, int state )
|
||||
{
|
||||
double pct = (double)m_value / 100.0;
|
||||
@@ -1274,7 +1418,7 @@ bool wxDataViewProgressRenderer::Render( wxRect cell, wxDC *dc, int state )
|
||||
return true;
|
||||
}
|
||||
|
||||
wxSize wxDataViewProgressRenderer::GetSize()
|
||||
wxSize wxDataViewProgressRenderer::GetSize() const
|
||||
{
|
||||
return wxSize(40,12);
|
||||
}
|
||||
@@ -1331,9 +1475,11 @@ void wxDataViewDateRendererPopupTransient::OnCalendar( wxCalendarEvent &event )
|
||||
IMPLEMENT_CLASS(wxDataViewDateRenderer, wxDataViewCustomRenderer)
|
||||
|
||||
wxDataViewDateRenderer::wxDataViewDateRenderer( const wxString &varianttype,
|
||||
wxDataViewCellMode mode ) :
|
||||
wxDataViewCustomRenderer( varianttype, mode )
|
||||
wxDataViewCellMode mode, int align ) :
|
||||
wxDataViewCustomRenderer( varianttype, mode, align )
|
||||
{
|
||||
SetMode(mode);
|
||||
SetAlignment(align);
|
||||
}
|
||||
|
||||
bool wxDataViewDateRenderer::SetValue( const wxVariant &value )
|
||||
@@ -1343,6 +1489,11 @@ bool wxDataViewDateRenderer::SetValue( const wxVariant &value )
|
||||
return true;
|
||||
}
|
||||
|
||||
bool wxDataViewDateRenderer::GetValue( wxVariant &value ) const
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
bool wxDataViewDateRenderer::Render( wxRect cell, wxDC *dc, int state )
|
||||
{
|
||||
dc->SetFont( GetOwner()->GetOwner()->GetFont() );
|
||||
@@ -1352,16 +1503,16 @@ bool wxDataViewDateRenderer::Render( wxRect cell, wxDC *dc, int state )
|
||||
return true;
|
||||
}
|
||||
|
||||
wxSize wxDataViewDateRenderer::GetSize()
|
||||
wxSize wxDataViewDateRenderer::GetSize() const
|
||||
{
|
||||
wxDataViewCtrl* view = GetOwner()->GetOwner();
|
||||
wxString tmp = m_date.FormatDate();
|
||||
wxCoord x,y,d;
|
||||
view->GetTextExtent( tmp, &x, &y, &d );
|
||||
GetView()->GetTextExtent( tmp, &x, &y, &d );
|
||||
return wxSize(x,y+d);
|
||||
}
|
||||
|
||||
bool wxDataViewDateRenderer::Activate( wxRect cell, wxDataViewListModel *model, unsigned int col, unsigned int row )
|
||||
bool wxDataViewDateRenderer::Activate( wxRect cell, wxDataViewListModel *model,
|
||||
unsigned int col, unsigned int row )
|
||||
{
|
||||
wxVariant variant;
|
||||
model->GetValue( variant, col, row );
|
||||
@@ -1442,37 +1593,10 @@ wxDataViewColumn::wxDataViewColumn( const wxString &title, wxDataViewRenderer *c
|
||||
wxAlignment align, int flags ) :
|
||||
wxDataViewColumnBase( title, cell, model_column, width, align, flags )
|
||||
{
|
||||
m_isConnected = false;
|
||||
Init( align, flags, width );
|
||||
|
||||
GtkCellRenderer *renderer = (GtkCellRenderer *) cell->GetGtkHandle();
|
||||
|
||||
GtkTreeViewColumn *column = gtk_tree_view_column_new();
|
||||
m_column = (void*) column;
|
||||
|
||||
gtk_tree_view_column_set_clickable( column, true );
|
||||
|
||||
gtk_tree_view_column_set_clickable( GTK_TREE_VIEW_COLUMN(m_column), TRUE );
|
||||
SetTitle( title );
|
||||
|
||||
if (flags & wxDATAVIEW_COL_RESIZABLE)
|
||||
gtk_tree_view_column_set_resizable( column, true );
|
||||
if (flags & wxDATAVIEW_COL_HIDDEN)
|
||||
gtk_tree_view_column_set_visible( column, false );
|
||||
if (flags & wxDATAVIEW_COL_SORTABLE)
|
||||
gtk_tree_view_column_set_sort_indicator( column, true );
|
||||
|
||||
if (width > 0)
|
||||
gtk_tree_view_column_set_fixed_width( column, width );
|
||||
else
|
||||
gtk_tree_view_column_set_fixed_width( column, 70 ); // FIXME
|
||||
|
||||
gtk_tree_view_column_set_sizing( column, GTK_TREE_VIEW_COLUMN_FIXED );
|
||||
|
||||
gtk_tree_view_column_pack_end( column, renderer, FALSE );
|
||||
|
||||
gtk_tree_view_column_set_cell_data_func( column, renderer,
|
||||
wxGtkTreeCellDataFunc, (gpointer) cell, NULL );
|
||||
|
||||
SetAlignment(align);
|
||||
}
|
||||
|
||||
wxDataViewColumn::wxDataViewColumn( const wxBitmap &bitmap, wxDataViewRenderer *cell,
|
||||
@@ -1480,35 +1604,35 @@ wxDataViewColumn::wxDataViewColumn( const wxBitmap &bitmap, wxDataViewRenderer *
|
||||
wxAlignment align, int flags ) :
|
||||
wxDataViewColumnBase( bitmap, cell, model_column, width, align, flags )
|
||||
{
|
||||
m_isConnected = false;
|
||||
|
||||
GtkCellRenderer *renderer = (GtkCellRenderer *) cell->GetGtkHandle();
|
||||
|
||||
GtkTreeViewColumn *column = gtk_tree_view_column_new();
|
||||
m_column = (void*) column;
|
||||
Init( align, flags, width );
|
||||
|
||||
SetBitmap( bitmap );
|
||||
}
|
||||
|
||||
if (flags & wxDATAVIEW_COL_RESIZABLE)
|
||||
gtk_tree_view_column_set_resizable( column, true );
|
||||
if (flags & wxDATAVIEW_COL_HIDDEN)
|
||||
gtk_tree_view_column_set_visible( column, false );
|
||||
if (flags & wxDATAVIEW_COL_SORTABLE)
|
||||
gtk_tree_view_column_set_sort_indicator( column, true );
|
||||
void wxDataViewColumn::Init(wxAlignment align, int flags, int width)
|
||||
{
|
||||
m_isConnected = false;
|
||||
|
||||
if (width > 0)
|
||||
gtk_tree_view_column_set_fixed_width( column, width );
|
||||
else
|
||||
gtk_tree_view_column_set_fixed_width( column, 70 ); // FIXME
|
||||
|
||||
GtkCellRenderer *renderer = (GtkCellRenderer *) GetRenderer()->GetGtkHandle();
|
||||
GtkTreeViewColumn *column = gtk_tree_view_column_new();
|
||||
m_column = (GtkWidget*) column;
|
||||
|
||||
SetFlags( flags );
|
||||
SetAlignment( align );
|
||||
|
||||
// NOTE: we prefer not to call SetMinWidth(wxDVC_DEFAULT_MINWIDTH);
|
||||
// as GTK+ is smart and unless explicitely told, will set the minimal
|
||||
// width to the title's lenght, which is a better default
|
||||
|
||||
// the GTK_TREE_VIEW_COLUMN_FIXED is required by the "fixed height" mode
|
||||
// that we use for the wxDataViewCtrl
|
||||
gtk_tree_view_column_set_fixed_width( column, width < 0 ? wxDVC_DEFAULT_WIDTH : width );
|
||||
gtk_tree_view_column_set_sizing( column, GTK_TREE_VIEW_COLUMN_FIXED );
|
||||
|
||||
gtk_tree_view_column_pack_end( column, renderer, FALSE );
|
||||
gtk_tree_view_column_pack_end( column, renderer, TRUE );
|
||||
|
||||
gtk_tree_view_column_set_cell_data_func( column, renderer,
|
||||
wxGtkTreeCellDataFunc, (gpointer) cell, NULL );
|
||||
|
||||
SetAlignment(align);
|
||||
wxGtkTreeCellDataFunc, (gpointer) GetRenderer(), NULL );
|
||||
}
|
||||
|
||||
wxDataViewColumn::~wxDataViewColumn()
|
||||
@@ -1522,7 +1646,7 @@ void wxDataViewColumn::OnInternalIdle()
|
||||
|
||||
if (GTK_WIDGET_REALIZED(GetOwner()->m_treeview))
|
||||
{
|
||||
GtkTreeViewColumn *column = (GtkTreeViewColumn *)m_column;
|
||||
GtkTreeViewColumn *column = GTK_TREE_VIEW_COLUMN(m_column);
|
||||
if (column->button)
|
||||
{
|
||||
g_signal_connect(column->button, "button_press_event",
|
||||
@@ -1537,22 +1661,20 @@ void wxDataViewColumn::SetOwner( wxDataViewCtrl *owner )
|
||||
{
|
||||
wxDataViewColumnBase::SetOwner( owner );
|
||||
|
||||
GtkTreeViewColumn *column = (GtkTreeViewColumn *)m_column;
|
||||
GtkTreeViewColumn *column = GTK_TREE_VIEW_COLUMN(m_column);
|
||||
|
||||
gtk_tree_view_column_set_title( column, wxGTK_CONV_FONT(GetTitle(), GetOwner()->GetFont() ) );
|
||||
}
|
||||
|
||||
void wxDataViewColumn::SetTitle( const wxString &title )
|
||||
{
|
||||
wxDataViewColumnBase::SetTitle( title );
|
||||
|
||||
GtkTreeViewColumn *column = (GtkTreeViewColumn *)m_column;
|
||||
GtkTreeViewColumn *column = GTK_TREE_VIEW_COLUMN(m_column);
|
||||
|
||||
if (m_isConnected)
|
||||
{
|
||||
// disconnect before column->button gets recreated
|
||||
g_signal_handlers_disconnect_by_func( column->button,
|
||||
(void*) gtk_dataview_header_button_press_callback, this);
|
||||
(GtkWidget*) gtk_dataview_header_button_press_callback, this);
|
||||
|
||||
m_isConnected = false;
|
||||
}
|
||||
@@ -1565,11 +1687,17 @@ void wxDataViewColumn::SetTitle( const wxString &title )
|
||||
gtk_tree_view_column_set_widget( column, NULL );
|
||||
}
|
||||
|
||||
wxString wxDataViewColumn::GetTitle() const
|
||||
{
|
||||
const gchar *str = gtk_tree_view_column_get_title( GTK_TREE_VIEW_COLUMN(m_column) );
|
||||
return wxConvFileName->cMB2WX(str);
|
||||
}
|
||||
|
||||
void wxDataViewColumn::SetBitmap( const wxBitmap &bitmap )
|
||||
{
|
||||
wxDataViewColumnBase::SetBitmap( bitmap );
|
||||
|
||||
GtkTreeViewColumn *column = (GtkTreeViewColumn *)m_column;
|
||||
GtkTreeViewColumn *column = GTK_TREE_VIEW_COLUMN(m_column);
|
||||
if (bitmap.Ok())
|
||||
{
|
||||
GtkImage *gtk_image = GTK_IMAGE( gtk_image_new() );
|
||||
@@ -1598,34 +1726,69 @@ void wxDataViewColumn::SetBitmap( const wxBitmap &bitmap )
|
||||
}
|
||||
}
|
||||
|
||||
void wxDataViewColumn::SetHidden( bool hidden )
|
||||
{
|
||||
gtk_tree_view_column_set_visible( GTK_TREE_VIEW_COLUMN(m_column), !hidden );
|
||||
}
|
||||
|
||||
void wxDataViewColumn::SetResizeable( bool resizeable )
|
||||
{
|
||||
gtk_tree_view_column_set_resizable( GTK_TREE_VIEW_COLUMN(m_column), resizeable );
|
||||
}
|
||||
|
||||
void wxDataViewColumn::SetAlignment( wxAlignment align )
|
||||
{
|
||||
GtkTreeViewColumn *column = (GtkTreeViewColumn *)m_column;
|
||||
GtkTreeViewColumn *column = GTK_TREE_VIEW_COLUMN(m_column);
|
||||
|
||||
gfloat xalign = 0.0;
|
||||
if (align == wxALIGN_RIGHT)
|
||||
xalign = 1.0;
|
||||
if (align == wxALIGN_CENTER)
|
||||
if (align == wxALIGN_CENTER_HORIZONTAL ||
|
||||
align == wxALIGN_CENTER)
|
||||
xalign = 0.5;
|
||||
|
||||
gtk_tree_view_column_set_alignment( column, xalign );
|
||||
gtk_tree_view_column_set_alignment( column, xalign );
|
||||
}
|
||||
|
||||
wxAlignment wxDataViewColumn::GetAlignment() const
|
||||
{
|
||||
gfloat xalign = gtk_tree_view_column_get_alignment( GTK_TREE_VIEW_COLUMN(m_column) );
|
||||
|
||||
if (xalign == 1.0)
|
||||
return wxALIGN_RIGHT;
|
||||
if (xalign == 0.5)
|
||||
return wxALIGN_CENTER_HORIZONTAL;
|
||||
|
||||
return wxALIGN_LEFT;
|
||||
}
|
||||
|
||||
void wxDataViewColumn::SetSortable( bool sortable )
|
||||
{
|
||||
GtkTreeViewColumn *column = (GtkTreeViewColumn *)m_column;
|
||||
GtkTreeViewColumn *column = GTK_TREE_VIEW_COLUMN(m_column);
|
||||
gtk_tree_view_column_set_sort_indicator( column, sortable );
|
||||
}
|
||||
|
||||
bool wxDataViewColumn::IsSortable() const
|
||||
{
|
||||
GtkTreeViewColumn *column = (GtkTreeViewColumn *)m_column;
|
||||
GtkTreeViewColumn *column = GTK_TREE_VIEW_COLUMN(m_column);
|
||||
return gtk_tree_view_column_get_sort_indicator( column );
|
||||
}
|
||||
|
||||
bool wxDataViewColumn::IsResizeable() const
|
||||
{
|
||||
GtkTreeViewColumn *column = GTK_TREE_VIEW_COLUMN(m_column);
|
||||
return gtk_tree_view_column_get_resizable( column );
|
||||
}
|
||||
|
||||
bool wxDataViewColumn::IsHidden() const
|
||||
{
|
||||
GtkTreeViewColumn *column = GTK_TREE_VIEW_COLUMN(m_column);
|
||||
return !gtk_tree_view_column_get_visible( column );
|
||||
}
|
||||
|
||||
void wxDataViewColumn::SetSortOrder( bool ascending )
|
||||
{
|
||||
GtkTreeViewColumn *column = (GtkTreeViewColumn *)m_column;
|
||||
GtkTreeViewColumn *column = GTK_TREE_VIEW_COLUMN(m_column);
|
||||
|
||||
if (ascending)
|
||||
gtk_tree_view_column_set_sort_order( column, GTK_SORT_ASCENDING );
|
||||
@@ -1635,25 +1798,31 @@ void wxDataViewColumn::SetSortOrder( bool ascending )
|
||||
|
||||
bool wxDataViewColumn::IsSortOrderAscending() const
|
||||
{
|
||||
GtkTreeViewColumn *column = (GtkTreeViewColumn *)m_column;
|
||||
GtkTreeViewColumn *column = GTK_TREE_VIEW_COLUMN(m_column);
|
||||
|
||||
return (gtk_tree_view_column_get_sort_order( column ) != GTK_SORT_DESCENDING);
|
||||
}
|
||||
|
||||
void wxDataViewColumn::SetMinWidth( int width )
|
||||
{
|
||||
gtk_tree_view_column_set_min_width( GTK_TREE_VIEW_COLUMN(m_column), width );
|
||||
}
|
||||
|
||||
int wxDataViewColumn::GetMinWidth() const
|
||||
{
|
||||
return gtk_tree_view_column_get_min_width( GTK_TREE_VIEW_COLUMN(m_column) );
|
||||
}
|
||||
|
||||
int wxDataViewColumn::GetWidth() const
|
||||
{
|
||||
return gtk_tree_view_column_get_width( (GtkTreeViewColumn *)m_column );
|
||||
return gtk_tree_view_column_get_width( GTK_TREE_VIEW_COLUMN(m_column) );
|
||||
}
|
||||
|
||||
void wxDataViewColumn::SetFixedWidth( int width )
|
||||
void wxDataViewColumn::SetWidth( int width )
|
||||
{
|
||||
gtk_tree_view_column_set_fixed_width( (GtkTreeViewColumn *)m_column, width );
|
||||
gtk_tree_view_column_set_fixed_width( GTK_TREE_VIEW_COLUMN(m_column), width );
|
||||
}
|
||||
|
||||
int wxDataViewColumn::GetFixedWidth() const
|
||||
{
|
||||
return gtk_tree_view_column_get_fixed_width( (GtkTreeViewColumn *)m_column );
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
// wxDataViewCtrl signal callbacks
|
||||
@@ -1737,6 +1906,27 @@ bool wxDataViewCtrl::Create(wxWindow *parent, wxWindowID id,
|
||||
gtk_tree_selection_set_mode( selection, GTK_SELECTION_MULTIPLE );
|
||||
}
|
||||
|
||||
gtk_tree_view_set_headers_visible( GTK_TREE_VIEW(m_treeview), (style & wxDV_NO_HEADER) == 0 );
|
||||
|
||||
#ifdef __WXGTK210__
|
||||
if (!gtk_check_version(2,10,0))
|
||||
{
|
||||
GtkTreeViewGridLines grid = GTK_TREE_VIEW_GRID_LINES_NONE;
|
||||
|
||||
if ((style & wxDV_HORIZ_RULES) != 0 &&
|
||||
(style & wxDV_VERT_RULES) != 0)
|
||||
grid = GTK_TREE_VIEW_GRID_LINES_BOTH;
|
||||
else if (style & wxDV_VERT_RULES)
|
||||
grid = GTK_TREE_VIEW_GRID_LINES_VERTICAL;
|
||||
else if (style & wxDV_HORIZ_RULES)
|
||||
grid = GTK_TREE_VIEW_GRID_LINES_HORIZONTAL;
|
||||
|
||||
gtk_tree_view_set_grid_lines( GTK_TREE_VIEW(m_treeview), grid );
|
||||
}
|
||||
else
|
||||
#endif
|
||||
gtk_tree_view_set_rules_hint( GTK_TREE_VIEW(m_treeview), (style & wxDV_HORIZ_RULES) != 0 );
|
||||
|
||||
gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (m_widget),
|
||||
GTK_POLICY_AUTOMATIC, GTK_POLICY_ALWAYS);
|
||||
gtk_widget_show (m_treeview);
|
||||
@@ -1758,7 +1948,7 @@ void wxDataViewCtrl::OnInternalIdle()
|
||||
{
|
||||
wxWindow::OnInternalIdle();
|
||||
|
||||
unsigned int cols = GetNumberOfColumns();
|
||||
unsigned int cols = GetColumnCount();
|
||||
unsigned int i;
|
||||
for (i = 0; i < cols; i++)
|
||||
{
|
||||
|
@@ -1770,7 +1770,7 @@ bool wxListCtrl::MSWCommand(WXUINT cmd, WXWORD id)
|
||||
}
|
||||
|
||||
// utility used by wxListCtrl::MSWOnNotify and by wxDataViewHeaderWindowMSW::MSWOnNotify
|
||||
unsigned int wxMSWGetColumnClicked(NMHDR *nmhdr, POINT *ptClick)
|
||||
int wxMSWGetColumnClicked(NMHDR *nmhdr, POINT *ptClick)
|
||||
{
|
||||
wxASSERT(nmhdr && ptClick);
|
||||
|
||||
|
Reference in New Issue
Block a user