X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f97c9b5bf2452c73434eb548e70115ac7ca60a83..4b37e99afcedd67292c24e93677a83b76dc6b625:/samples/newgrid/griddemo.h diff --git a/samples/newgrid/griddemo.h b/samples/newgrid/griddemo.h index 25aee5965d..8be1e67377 100644 --- a/samples/newgrid/griddemo.h +++ b/samples/newgrid/griddemo.h @@ -37,8 +37,14 @@ class GridFrame : public wxFrame void ToggleRowLabels( wxCommandEvent& ); void ToggleColLabels( wxCommandEvent& ); void ToggleEditing( wxCommandEvent& ); + void ToggleRowSizing( wxCommandEvent& ); + void ToggleColSizing( wxCommandEvent& ); + void ToggleGridSizing( wxCommandEvent& ); + void ToggleGridLines( wxCommandEvent& ); + void AutoSizeCols( wxCommandEvent& ); void SetLabelColour( wxCommandEvent& ); void SetLabelTextColour( wxCommandEvent& ); + void SetLabelFont(wxCommandEvent &); void SetRowLabelHorizAlignment( wxCommandEvent& ); void SetRowLabelVertAlignment( wxCommandEvent& ); void SetColLabelHorizAlignment( wxCommandEvent& ); @@ -53,6 +59,19 @@ class GridFrame : public wxFrame void DeleteSelectedRows( wxCommandEvent& ); void DeleteSelectedCols( wxCommandEvent& ); void ClearGrid( wxCommandEvent& ); + void SelectCells( wxCommandEvent& ); + void SelectRows( wxCommandEvent& ); + void SelectCols( wxCommandEvent& ); + + void DeselectCell(wxCommandEvent& event); + void DeselectCol(wxCommandEvent& event); + void DeselectRow(wxCommandEvent& event); + void DeselectAll(wxCommandEvent& event); + void SelectCell(wxCommandEvent& event); + void SelectCol(wxCommandEvent& event); + void SelectRow(wxCommandEvent& event); + void SelectAll(wxCommandEvent& event); + void OnAddToSelectToggle(wxCommandEvent& event); void OnLabelLeftClick( wxGridEvent& ); void OnCellLeftClick( wxGridEvent& ); @@ -62,6 +81,12 @@ class GridFrame : public wxFrame void OnRangeSelected( wxGridRangeSelectEvent& ); void OnCellValueChanged( wxGridEvent& ); + void OnEditorShown(wxGridEvent&); + void OnEditorHidden(wxGridEvent&); + + void OnSetHighlightWidth(wxCommandEvent&); + void OnSetROHighlightWidth(wxCommandEvent&); + public: GridFrame(); ~GridFrame(); @@ -69,14 +94,21 @@ public: void OnQuit( wxCommandEvent& ); void About( wxCommandEvent& ); void OnVTable( wxCommandEvent& ); + void OnBugsTable( wxCommandEvent& ); enum { ID_TOGGLEROWLABELS = 100, ID_TOGGLECOLLABELS, ID_TOGGLEEDIT, + ID_TOGGLEROWSIZING, + ID_TOGGLECOLSIZING, + ID_TOGGLEGRIDSIZING, + ID_TOGGLEGRIDLINES, + ID_AUTOSIZECOLS, ID_SETLABELCOLOUR, ID_SETLABELTEXTCOLOUR, + ID_SETLABEL_FONT, ID_ROWLABELALIGN, ID_ROWLABELHORIZALIGN, ID_ROWLABELVERTALIGN, @@ -89,14 +121,36 @@ public: ID_DELETEROW, ID_DELETECOL, ID_CLEARGRID, + ID_CHANGESEL, + ID_SELCELLS, + ID_SELROWS, + ID_SELCOLS, ID_SET_CELL_FG_COLOUR, ID_SET_CELL_BG_COLOUR, ID_ABOUT, ID_VTABLE, + ID_BUGS_TABLE, + ID_SELECT_UNSELECT, + ID_SELECT_ALL, + ID_SELECT_ROW, + ID_SELECT_COL, + ID_SELECT_CELL, + ID_DESELECT_ALL, + ID_DESELECT_ROW, + ID_DESELECT_COL, + ID_DESELECT_CELL, + + ID_SET_HIGHLIGHT_WIDTH, + ID_SET_RO_HIGHLIGHT_WIDTH, ID_TESTFUNC }; + wxLog *m_logOld; + + // add the cells to selection when using commands from select menu? + bool m_addToSel; + DECLARE_EVENT_TABLE() }; @@ -111,31 +165,91 @@ public: bool isSelected); }; +// ---------------------------------------------------------------------------- +// demonstration of virtual table which doesn't store all of its data in +// memory +// ---------------------------------------------------------------------------- -class BigGridTable : public wxGridTableBase { +class BigGridTable : public wxGridTableBase +{ public: - long GetNumberRows() { return 10000; } - long GetNumberCols() { return 10000; } + BigGridTable(long sizeGrid) { m_sizeGrid = sizeGrid; } - wxString GetValue( int row, int col ) { - wxString str; - str.Printf("(%d, %d)", row, col); - return str; + int GetNumberRows() { return m_sizeGrid; } + int GetNumberCols() { return m_sizeGrid; } + wxString GetValue( int row, int col ) + { + return wxString::Format(wxT("(%d, %d)"), row, col); } - void SetValue( int , int , const wxString& ) {} + void SetValue( int , int , const wxString& ) { /* ignore */ } bool IsEmptyCell( int , int ) { return FALSE; } + +private: + long m_sizeGrid; }; -class BigGridFrame : public wxFrame { +class BigGridFrame : public wxFrame +{ public: - BigGridFrame(); + BigGridFrame(long sizeGrid); private: wxGrid* m_grid; BigGridTable* m_table; }; +// ---------------------------------------------------------------------------- +// an example of custom attr provider: this one makes all odd rows appear grey +// ---------------------------------------------------------------------------- -#endif +class MyGridCellAttrProvider : public wxGridCellAttrProvider +{ +public: + MyGridCellAttrProvider(); + virtual ~MyGridCellAttrProvider(); + + virtual wxGridCellAttr *GetAttr(int row, int col, + wxGridCellAttr::wxAttrKind kind) const; + +private: + wxGridCellAttr *m_attrForOddRows; +}; + +// ---------------------------------------------------------------------------- +// another, more realistic, grid example: shows typed columns and more +// ---------------------------------------------------------------------------- + +class BugsGridTable : public wxGridTableBase +{ +public: + BugsGridTable(); + + virtual int GetNumberRows(); + virtual int GetNumberCols(); + virtual bool IsEmptyCell( int row, int col ); + virtual wxString GetValue( int row, int col ); + virtual void SetValue( int row, int col, const wxString& value ); + + virtual wxString GetColLabelValue( int col ); + + virtual wxString GetTypeName( int row, int col ); + virtual bool CanGetValueAs( int row, int col, const wxString& typeName ); + virtual bool CanSetValueAs( int row, int col, const wxString& typeName ); + + virtual long GetValueAsLong( int row, int col ); + virtual bool GetValueAsBool( int row, int col ); + + virtual void SetValueAsLong( int row, int col, long value ); + virtual void SetValueAsBool( int row, int col, bool value ); +}; + +class BugsGridFrame : public wxFrame +{ +public: + BugsGridFrame(); +}; + + +#endif // griddemo_h