X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/903f689bf7c3c379cba45881373aa9bdd15d6e70..9f50f9f1a161184359b7ee002d4f6bb7ecd8f04c:/include/wx/generic/gridg.h diff --git a/include/wx/generic/gridg.h b/include/wx/generic/gridg.h index 50795a2115..b7bd11f4be 100644 --- a/include/wx/generic/gridg.h +++ b/include/wx/generic/gridg.h @@ -20,6 +20,7 @@ #include "wx/panel.h" #include "wx/string.h" #include "wx/scrolbar.h" +#include "wx/event.h" #define wxGRID_DEFAULT_EDIT_WIDTH 300 #define wxGRID_DEFAULT_EDIT_HEIGHT 27 @@ -40,8 +41,9 @@ #define wxRIGHT 0x0800 #endif -#define WXGENERIC_GRID_VERSION 0.4 +#define WXGENERIC_GRID_VERSION 0.5 +class WXDLLEXPORT wxGridEvent; class WXDLLEXPORT wxGridCell; class WXDLLEXPORT wxGenericGrid: public wxPanel { @@ -66,12 +68,12 @@ class WXDLLEXPORT wxGenericGrid: public wxPanel bool Create(wxWindow *parent, wxWindowID, const wxPoint& pos, const wxSize& size, long style = 0, const wxString& name = "grid"); - bool CreateGrid(int nRows, int nCols, wxString **cellValues = NULL, short *widths = NULL, + bool CreateGrid(int nRows, int nCols, wxString **cellValues = (wxString **) NULL, short *widths = (short *) NULL, short defaultWidth = wxGRID_DEFAULT_CELL_WIDTH, short defaultHeight = wxGRID_DEFAULT_CELL_HEIGHT); void PaintGrid(wxDC& dc); void ClearGrid(void); - virtual wxGridCell *GetCell(int row, int col); - inline wxGridCell ***GetCells(void) { return m_gridCells; } + virtual wxGridCell *GetCell(int row, int col) const; + inline wxGridCell ***GetCells(void) const { return m_gridCells; } bool InsertCols(int pos = 0, int n = 1, bool updateLabels = TRUE); bool InsertRows(int pos = 0, int n = 1, bool updateLabels = TRUE); bool AppendCols(int n = 1, bool updateLabels = TRUE); @@ -81,66 +83,66 @@ class WXDLLEXPORT wxGenericGrid: public wxPanel // Cell accessors void SetCellValue(const wxString& val, int row, int col); - wxString& GetCellValue(int row, int col); + wxString& GetCellValue(int row, int col) const; void SetCellAlignment(int flag, int row, int col); void SetCellAlignment(int flag); - int GetCellAlignment(int row, int col); - int GetCellAlignment(void); + int GetCellAlignment(int row, int col) const; + int GetCellAlignment(void) const; void SetCellTextColour(const wxColour& val, int row, int col); void SetCellTextColour(const wxColour& col); - wxColour& GetCellTextColour(int row, int col); - inline wxColour& GetCellTextColour(void) { return m_cellTextColour; } + wxColour& GetCellTextColour(int row, int col) const; + inline wxColour& GetCellTextColour(void) const { return (wxColour&) m_cellTextColour; } void SetCellBackgroundColour(const wxColour& col); void SetCellBackgroundColour(const wxColour& colour, int row, int col); - inline wxColour& GetCellBackgroundColour(void) { return m_cellBackgroundColour; } - wxColour& GetCellBackgroundColour(int row, int col); - inline wxFont *GetCellTextFont(void) { return m_cellTextFont; } - wxFont *GetCellTextFont(int row, int col); - void SetCellTextFont(wxFont *fnt); - void SetCellTextFont(wxFont *fnt, int row, int col); - wxBitmap *GetCellBitmap(int row, int col); + inline wxColour& GetCellBackgroundColour(void) const { return (wxColour&) m_cellBackgroundColour; } + wxColour& GetCellBackgroundColour(int row, int col) const; + inline wxFont& GetCellTextFont(void) const { return (wxFont&) m_cellTextFont; } + wxFont& GetCellTextFont(int row, int col) const; + void SetCellTextFont(const wxFont& fnt); + void SetCellTextFont(const wxFont& fnt, int row, int col); + wxBitmap *GetCellBitmap(int row, int col) const; void SetCellBitmap(wxBitmap *bitmap, int row, int col); - + // Size accessors void SetColumnWidth(int col, int width); - int GetColumnWidth(int col); + int GetColumnWidth(int col) const; void SetRowHeight(int row, int height); - int GetRowHeight(int row); - + int GetRowHeight(int row) const; + // Label accessors void SetLabelSize(int orientation, int sz); - int GetLabelSize(int orientation); + int GetLabelSize(int orientation) const; void SetLabelAlignment(int orientation, int alignment); - int GetLabelAlignment(int orientation); - wxGridCell *GetLabelCell(int orientation, int pos); + int GetLabelAlignment(int orientation) const; + wxGridCell *GetLabelCell(int orientation, int pos) const; void SetLabelValue(int orientation, const wxString& val, int pos); - wxString& GetLabelValue(int orientation, int pos); + wxString& GetLabelValue(int orientation, int pos) const; void SetLabelTextColour(const wxColour& colour); void SetLabelBackgroundColour(const wxColour& colour); - inline wxColour& GetLabelTextColour(void) { return m_labelTextColour; } - inline wxColour& GetLabelBackgroundColour(void) { return m_labelBackgroundColour; } - inline wxFont *GetLabelTextFont(void) { return m_labelTextFont; } - inline void SetLabelTextFont(wxFont *fnt) { m_labelTextFont = fnt; } + inline wxColour& GetLabelTextColour(void) const { return (wxColour&) m_labelTextColour; } + inline wxColour& GetLabelBackgroundColour(void) { return (wxColour&) m_labelBackgroundColour; } + inline wxFont& GetLabelTextFont(void) { return (wxFont&) m_labelTextFont; } + inline void SetLabelTextFont(const wxFont& fnt) { m_labelTextFont = fnt; } // Miscellaneous accessors - inline int GetCursorRow(void) { return m_wCursorRow; } - inline int GetCursorColumn(void) { return m_wCursorColumn; } + inline int GetCursorRow(void) const { return m_wCursorRow; } + inline int GetCursorColumn(void) const { return m_wCursorColumn; } void SetGridCursor(int row, int col); - inline int GetRows(void) { return m_totalRows; } - inline int GetCols(void) { return m_totalCols; } - inline int GetScrollPosX(void) { return m_scrollPosX; } - inline int GetScrollPosY(void) { return m_scrollPosY; } + inline int GetRows(void) const { return m_totalRows; } + inline int GetCols(void) const { return m_totalCols; } + inline int GetScrollPosX(void) const { return m_scrollPosX; } + inline int GetScrollPosY(void) const { return m_scrollPosY; } inline void SetScrollPosX(int pos) { m_scrollPosX = pos; } inline void SetScrollPosY(int pos) { m_scrollPosY = pos; } - inline wxTextCtrl *GetTextItem(void) { return m_textItem; } - inline wxScrollBar *GetHorizScrollBar(void) { return m_hScrollBar; } - inline wxScrollBar *GetVertScrollBar(void) { return m_vScrollBar; } - inline bool GetEditable(void) { return m_editable; } + inline wxTextCtrl *GetTextItem(void) const { return m_textItem; } + inline wxScrollBar *GetHorizScrollBar(void) const { return m_hScrollBar; } + inline wxScrollBar *GetVertScrollBar(void) const { return m_vScrollBar; } + inline bool GetEditable(void) const { return m_editable; } void SetEditable(bool edit); - inline wxRectangle& GetCurrentRect(void) { return m_currentRect; } - inline bool CurrentCellVisible(void) { return m_currentRectVisible; } - inline void SetDividerPen(wxPen *pen) { m_divisionPen = pen; } - inline wxPen *GetDividerPen(void) { return m_divisionPen; } + inline wxRect& GetCurrentRect(void) const { return (wxRect&) m_currentRect; } + inline bool CurrentCellVisible(void) const { return m_currentRectVisible; } + inline void SetDividerPen(const wxPen& pen) { m_divisionPen = pen; } + inline wxPen& GetDividerPen(void) const { return (wxPen&) m_divisionPen; } // High-level event handling // Override e.g. to check value of current cell; but call @@ -148,18 +150,22 @@ class WXDLLEXPORT wxGenericGrid: public wxPanel virtual void OnSelectCellImplementation(wxDC *dc, int row, int col); virtual void OnSelectCell(int WXUNUSED(row), int WXUNUSED(col)) {}; + void _OnSelectCell(wxGridEvent& event); // Override to create your own class of grid cell virtual wxGridCell *OnCreateCell(void); - + void _OnCreateCell(wxGridEvent& event); + // Override to change labels e.g. creation of grid, inserting/deleting a row/col. // By default, auto-labels the grid. virtual void OnChangeLabels(void); + void _OnChangeLabels(wxGridEvent& event); // Override to change the label of the edit field when selecting a cell // By default, sets it to e.g. A12 virtual void OnChangeSelectionLabel(void); - + void _OnChangeSelectionLabel(wxGridEvent& event); + // Override for event processing virtual void OnCellChange(int WXUNUSED(row), int WXUNUSED(col)) {}; virtual void OnCellLeftClick(int WXUNUSED(row), int WXUNUSED(col), int WXUNUSED(x), int WXUNUSED(y), bool WXUNUSED(control), bool WXUNUSED(shift)) {}; @@ -167,6 +173,12 @@ class WXDLLEXPORT wxGenericGrid: public wxPanel virtual void OnLabelLeftClick(int WXUNUSED(row), int WXUNUSED(col), int WXUNUSED(x), int WXUNUSED(y), bool WXUNUSED(control), bool WXUNUSED(shift)) {}; virtual void OnLabelRightClick(int WXUNUSED(row), int WXUNUSED(col), int WXUNUSED(x), int WXUNUSED(y), bool WXUNUSED(control), bool WXUNUSED(shift)) {}; + void _OnCellChange(wxGridEvent& event); + void _OnCellLeftClick(wxGridEvent& event); + void _OnCellRightClick(wxGridEvent& event); + void _OnLabelLeftClick(wxGridEvent& event); + void _OnLabelRightClick(wxGridEvent& event); + // Activation: call from wxFrame::OnActivate void OnActivate(bool active); @@ -188,14 +200,14 @@ class WXDLLEXPORT wxGenericGrid: public wxPanel virtual void DrawEditableArea(wxDC *dc); virtual void DrawGridLines(wxDC *dc); virtual void DrawColumnLabels(wxDC *dc); - virtual void DrawColumnLabel(wxDC *dc, wxRectangle *rect, int col); + virtual void DrawColumnLabel(wxDC *dc, wxRect *rect, int col); virtual void DrawRowLabels(wxDC *dc); - virtual void DrawRowLabel(wxDC *dc, wxRectangle *rect, int row); + virtual void DrawRowLabel(wxDC *dc, wxRect *rect, int row); virtual void DrawCells(wxDC *dc); - virtual void DrawCellValue(wxDC *dc, wxRectangle *rect, int row, int col); - virtual void DrawCellBackground(wxDC *dc, wxRectangle *rect, int row, int col); - virtual void DrawTextRect(wxDC *dc, const wxString& text, wxRectangle *rect, int flag); - virtual void DrawBitmapRect(wxDC *dc, wxBitmap *bitmap, wxRectangle *rect, int flag); + virtual void DrawCellValue(wxDC *dc, wxRect *rect, int row, int col); + virtual void DrawCellBackground(wxDC *dc, wxRect *rect, int row, int col); + virtual void DrawTextRect(wxDC *dc, const wxString& text, wxRect *rect, int flag); + virtual void DrawBitmapRect(wxDC *dc, wxBitmap *bitmap, wxRect *rect, int flag); // Refresh cell and optionally set the text field void RefreshCell(int row, int col, bool setText = FALSE); @@ -215,7 +227,7 @@ class WXDLLEXPORT wxGenericGrid: public wxPanel wxScrollBar* m_vScrollBar; int m_wCursorRow; int m_wCursorColumn; - wxRectangle m_currentRect; + wxRect m_currentRect; bool m_currentRectVisible; wxGridCell*** m_gridCells; wxGridCell** m_rowLabelCells; @@ -225,7 +237,7 @@ class WXDLLEXPORT wxGenericGrid: public wxPanel int m_totalRows; int m_totalCols; - + // Row and column we're currently looking at int m_scrollPosX; int m_scrollPosY; @@ -246,28 +258,28 @@ class WXDLLEXPORT wxGenericGrid: public wxPanel short* m_colWidths; // Dynamically allocated short* m_rowHeights; // Dynamically allocated int m_scrollWidth; // Vert. scroll width, horiz. scroll height - + // Colours wxColour m_cellTextColour; wxColour m_cellBackgroundColour; - wxFont* m_cellTextFont; + wxFont m_cellTextFont; wxColour m_labelTextColour; wxColour m_labelBackgroundColour; - wxBrush* m_labelBackgroundBrush; - wxFont* m_labelTextFont; - wxPen* m_divisionPen; + wxBrush m_labelBackgroundBrush; + wxFont m_labelTextFont; + wxPen m_divisionPen; wxBitmap* m_doubleBufferingBitmap; // Position of Edit control - wxRectangle m_editControlPosition; - + wxRect m_editControlPosition; + // Drag status int m_dragStatus; int m_dragRowOrCol; int m_dragStartPosition; int m_dragLastPosition; - wxCursor* m_horizontalSashCursor; - wxCursor* m_verticalSashCursor; + wxCursor m_horizontalSashCursor; + wxCursor m_verticalSashCursor; // To avoid multiple refreshes, use Begin/EndBatch int m_batchCount; @@ -282,29 +294,30 @@ DECLARE_EVENT_TABLE() class WXDLLEXPORT wxGridCell: public wxObject { public: - wxString textValue; - wxFont *font; - wxColour textColour; - wxColour backgroundColour; - wxBrush *backgroundBrush; - wxBitmap *cellBitmap; + wxString textValue; + wxFont font; + wxColour textColour; + wxColour backgroundColour; + wxBrush backgroundBrush; + wxBitmap* cellBitmap; int alignment; - wxGridCell(wxGenericGrid *window = NULL); + wxGridCell(wxGenericGrid *window = (wxGenericGrid *) NULL); ~wxGridCell(void); - - virtual wxString& GetTextValue(void) { return textValue; } + + virtual wxString& GetTextValue(void) const { return (wxString&) textValue; } virtual void SetTextValue(const wxString& str) { textValue = str; } - inline wxFont *GetFont(void) { return font; } - inline void SetFont(wxFont *f) { font = f; } - inline wxColour& GetTextColour(void) { return textColour; } + inline wxFont& GetFont(void) const { return (wxFont&) font; } + inline void SetFont(const wxFont& f) { font = f; } + inline wxColour& GetTextColour(void) const { return (wxColour&) textColour; } inline void SetTextColour(const wxColour& colour) { textColour = colour; } - inline wxColour& GetBackgroundColour(void) { return backgroundColour; } + inline wxColour& GetBackgroundColour(void) const { return (wxColour&) backgroundColour; } void SetBackgroundColour(const wxColour& colour); - inline wxBrush *GetBackgroundBrush(void) { return backgroundBrush; } - inline int GetAlignment(void) { return alignment; } + inline wxBrush& GetBackgroundBrush(void) const { return (wxBrush&) backgroundBrush; } + inline void SetBackgroundBrush(const wxBrush& brush) { backgroundBrush = brush; } + inline int GetAlignment(void) const { return alignment; } inline void SetAlignment(int align) { alignment = align; } - inline wxBitmap *GetCellBitmap(void) { return cellBitmap; } + inline wxBitmap *GetCellBitmap(void) const { return cellBitmap; } inline void SetCellBitmap(wxBitmap *bitmap) { cellBitmap = bitmap; } }; @@ -319,5 +332,55 @@ class WXDLLEXPORT wxGrid: public wxGenericGrid } }; +class WXDLLEXPORT wxGridEvent : public wxCommandEvent { + DECLARE_DYNAMIC_CLASS(wxGridEvent) +public: + wxGridEvent() + : wxCommandEvent(), m_row(-1), m_col(-1), m_x(-1), m_y(-1), + m_control(0), m_shift(0), m_cell(0) + {} + + wxGridEvent(int id, wxEventType type, wxObject* obj, + int row=-1, int col=-1, int x=-1, int y=-1, + bool control=FALSE, bool shift=FALSE) + : wxCommandEvent(type, id), m_row(row), m_col(col), m_x(x), m_y(y), + m_control(control), m_shift(shift), m_cell(0) + { + SetEventObject(obj); + } + + + int m_row; + int m_col; + int m_x; + int m_y; + bool m_control; + bool m_shift; + wxGridCell* m_cell; +}; + +const wxEventType wxEVT_GRID_SELECT_CELL = wxEVT_FIRST + 1575; +const wxEventType wxEVT_GRID_CREATE_CELL = wxEVT_FIRST + 1576; +const wxEventType wxEVT_GRID_CHANGE_LABELS = wxEVT_FIRST + 1577; +const wxEventType wxEVT_GRID_CHANGE_SEL_LABEL = wxEVT_FIRST + 1578; +const wxEventType wxEVT_GRID_CELL_CHANGE = wxEVT_FIRST + 1579; +const wxEventType wxEVT_GRID_CELL_LCLICK = wxEVT_FIRST + 1580; +const wxEventType wxEVT_GRID_CELL_RCLICK = wxEVT_FIRST + 1581; +const wxEventType wxEVT_GRID_LABEL_LCLICK = wxEVT_FIRST + 1582; +const wxEventType wxEVT_GRID_LABEL_RCLICK = wxEVT_FIRST + 1583; + + +typedef void (wxEvtHandler::*wxGridEventFunction)(wxGridEvent&); + +#define EVT_GRID_SELECT_CELL(fn) { wxEVT_GRID_SELECT_CELL, -1, -1, (wxObjectEventFunction) (wxEventFunction) (wxGridEventFunction) &fn, NULL }, +#define EVT_GRID_CREATE_CELL(fn) { wxEVT_GRID_CREATE_CELL, -1, -1, (wxObjectEventFunction) (wxEventFunction) (wxGridEventFunction) &fn, NULL }, +#define EVT_GRID_CHANGE_LABELS(fn) { wxEVT_GRID_CHANGE_LABELS, -1, -1, (wxObjectEventFunction) (wxEventFunction) (wxGridEventFunction) &fn, NULL }, +#define EVT_GRID_CHANGE_SEL_LABEL(fn) { wxEVT_GRID_CHANGE_SEL_LABEL, -1, -1, (wxObjectEventFunction) (wxEventFunction) (wxGridEventFunction) &fn, NULL }, +#define EVT_GRID_CELL_CHANGE(fn) { wxEVT_GRID_CELL_CHANGE, -1, -1, (wxObjectEventFunction) (wxEventFunction) (wxGridEventFunction) &fn, NULL }, +#define EVT_GRID_CELL_LCLICK(fn) { wxEVT_GRID_CELL_LCLICK, -1, -1, (wxObjectEventFunction) (wxEventFunction) (wxGridEventFunction) &fn, NULL }, +#define EVT_GRID_CELL_RCLICK(fn) { wxEVT_GRID_CELL_RCLICK, -1, -1, (wxObjectEventFunction) (wxEventFunction) (wxGridEventFunction) &fn, NULL }, +#define EVT_GRID_LABEL_LCLICK(fn) { wxEVT_GRID_LABEL_LCLICK, -1, -1, (wxObjectEventFunction) (wxEventFunction) (wxGridEventFunction) &fn, NULL }, +#define EVT_GRID_LABEL_RCLICK(fn) { wxEVT_GRID_LABEL_RCLICK, -1, -1, (wxObjectEventFunction) (wxEventFunction) (wxGridEventFunction) &fn, NULL }, + #endif