]> git.saurik.com Git - wxWidgets.git/blame - docs/latex/wx/grid.tex
documented wxGetApp()
[wxWidgets.git] / docs / latex / wx / grid.tex
CommitLineData
a660d684
KB
1\section{\class{wxGrid}}\label{wxgrid}
2
78c49c58 3wxGrid and its related classes are used for displaying and editing tabular
2eebb742 4data. They provide a rich set of features for display, editing, and
78c49c58
MB
5interacting with a variety of data sources. For simple applications, and to
6help you get started, wxGrid is the only class you need to refer to
2eebb742
JS
7directly. It will set up default instances of the other classes and manage
8them for you. For more complex applications you can derive your own
78c49c58 9classes for custom grid views, grid data tables, cell editors and
2eebb742 10renderers. The \helpref{wxGrid classes overview}{gridoverview} has
78c49c58
MB
11examples of simple and more complex applications, explains the
12relationship between the various grid classes and has a summary of the
13keyboard shortcuts and mouse functions provided by wxGrid.
14
15wxGrid has been greatly expanded and redesigned for wxWindows 2.2
16onwards. If you have been using the old wxGrid class you will probably
2eebb742
JS
17want to have a look at the \helpref{wxGrid classes overview}{gridoverview} to see
18how things have changed. The new grid classes are reasonably backward-compatible
19but there are some exceptions. There are also easier ways of doing many things compared to
78c49c58 20the previous implementation.
a660d684
KB
21
22\wxheading{Derived from}
23
78c49c58 24\helpref{wxScrolledWindow}{wxscrolledwindow}\\
a660d684
KB
25\helpref{wxWindow}{wxwindow}\\
26\helpref{wxEvtHandler}{wxevthandler}\\
27\helpref{wxObject}{wxobject}
28
954b8ae6
JS
29\wxheading{Include files}
30
31<wx/grid.h>
32
a660d684
KB
33\wxheading{Window styles}
34
78c49c58 35There are presently no specific window styles for wxGrid.
a660d684 36
78c49c58 37\wxheading{Event handling}
a660d684 38
cbc95b2c
MB
39\input gridevt.inc
40
41The event handler for the following functions takes a
42 \helpref{wxGridSizeEvent}{wxgridsizeevent} parameter.
43
44\twocolwidtha{7cm}
45\begin{twocollist}\itemsep=0pt
46\twocolitem{{\bf EVT\_GRID\_COL\_SIZE(func)}}{The user resized a column by dragging it. Processes a wxEVT\_GRID\_COL\_SIZE.}
47\twocolitem{{\bf EVT\_GRID\_ROW\_SIZE(func)}}{The user resized a row by dragging it. Processes a wxEVT\_GRID\_ROW\_SIZE.}
48\end{twocollist}%
49
50The event handler for the following functions takes a
51 \helpref{wxGridRangeSelectEvent}{wxgridrangeselectevent} parameter.
52
53\twocolwidtha{7cm}
54\begin{twocollist}\itemsep=0pt
55\twocolitem{{\bf EVT\_GRID\_RANGE\_SELECT(func)}}{The user selected a group of contiguous cells. Processes a wxEVT\_GRID\_RANGE\_SELECT.}
56\end{twocollist}%
57
58The event handler for the following functions takes a
59 \helpref{wxGridEditorCreatedEvent}{wxgrideditorcreatedevent} parameter.
60
61\twocolwidtha{7cm}
62\begin{twocollist}\itemsep=0pt
63\twocolitem{{\bf EVT\_GRID\_EDITOR\_CREATED(func)}}{The editor for a cell was created. Processes a wxEVT\_GRID\_EDITOR\_CREATED.}
64\end{twocollist}%
65
a660d684
KB
66\wxheading{See also}
67
78c49c58 68\helpref{wxGrid overview}{gridoverview}
a660d684 69
78c49c58
MB
70%%%%%%%%%%% FUNCTION GROUPS %%%%%%%%%%%%%
71\latexignore{\rtfignore{\wxheading{Function groups}}}
a660d684 72
78c49c58 73\membersection{Constructors and initialization}
a660d684 74
2eebb742
JS
75\helpref{wxGrid}{wxgridctor}\\
76\helpref{\destruct{wxGrid}}{wxgriddtor}\\
77\helpref{CreateGrid}{wxgridcreategrid}\\
78c49c58 78\helpref{SetTable}{wxgridsettable}
a660d684 79
78c49c58 80\membersection{Display format}
a660d684 81
78c49c58 82\membersection{Selection functions}
a660d684 83
2eebb742
JS
84\helpref{wxGrid::ClearSelection}{wxgridclearselection}\\
85\helpref{wxGrid::IsSelection}{wxgridisselection}\\
86\helpref{wxGrid::SelectAll}{wxgridselectall}\\
87\helpref{wxGrid::SelectBlock}{wxgridselectblock}\\
88\helpref{wxGrid::SelectCol}{wxgridselectcol}\\
5c69031c
MB
89\helpref{wxGrid::SelectRow}{wxgridselectrow}
90
78c49c58
MB
91%%%%%%%%% MEMBER FUNCTIONS %%%%%%%%%%
92\helponly{\insertatlevel{2}{
a660d684 93
78c49c58
MB
94\wxheading{Members}
95
96}}
97
98\membersection{wxGrid::wxGrid}\label{wxgridctor}
99
100\func{}{wxGrid}{\void}
101
102Default constructor
103
104\func{}{wxGrid}{\param{wxWindow* }{parent}, \param{wxWindowID }{id}, \param{const wxPoint\& }{pos = wxDefaultPosition}, \param{const wxSize\& }{size = wxDefaultSize}, \param{long }{style = wxWANTS\_CHARS}, \param{const wxString\& }{name = wxPanelNameStr}}
105
106Constructor to create a grid object. Call either \helpref{wxGrid::CreateGrid}{wxgridcreategrid} or
107\helpref{wxGrid::SetTable}{wxgridsettable} directly after this to initialize the grid before using
108it.
109
110\membersection{wxGrid::\destruct{wxGrid}}\label{wxgriddtor}
111
112\func{}{\destruct{wxGrid}}{\void}
113
114Destructor. This will also destroy the associated grid table unless you passed a table
115object to the grid and specified that the grid should not take ownership of the
116table (see \helpref{wxGrid::SetTable}{wxgridsettable}).
a660d684
KB
117
118\membersection{wxGrid::AppendCols}\label{wxgridappendcols}
119
cc81d32f 120\func{bool}{AppendCols}{\param{int }{numCols = 1}, \param{bool }{updateLabels = true}}
78c49c58 121
cc81d32f 122Appends one or more new columns to the right of the grid and returns true if
78c49c58 123successful. The updateLabels argument is not used at present.
a660d684 124
78c49c58
MB
125If you are using a derived grid table class you will need to override
126\helpref{wxGridTableBase::AppendCols}{wxgridtablebaseappendcols}. See
127\helpref{wxGrid::InsertCols}{wxgridinsertcols} for further information.
a660d684
KB
128
129\membersection{wxGrid::AppendRows}\label{wxgridappendrows}
130
cc81d32f 131\func{bool}{AppendRows}{\param{int }{numRows = 1}, \param{bool }{updateLabels = true}}
78c49c58 132
cc81d32f 133Appends one or more new rows to the bottom of the grid and returns true if
78c49c58
MB
134successful. The updateLabels argument is not used at present.
135
136If you are using a derived grid table class you will need to override
137\helpref{wxGridTableBase::AppendRows}{wxgridtablebaseappendrows}. See
138\helpref{wxGrid::InsertRows}{wxgridinsertrows} for further information.
139
140\membersection{wxGrid::AutoSize}\label{wxgridautosize}
141
142\func{void}{AutoSize}{\void}
143
144Automatically sets the height and width of all rows and columns to fit their contents.
145
2eebb742 146\wxheading{Note}\\
78c49c58
MB
147wxGrid sets up arrays to store individual row and column sizes when non-default sizes are used.
148The memory requirements for this could become prohibitive if your grid is very large.
a660d684 149
78c49c58
MB
150\membersection{wxGrid::AutoSizeColumn}\label{wxgridautosizecolumn}
151
cc81d32f 152\func{void}{AutoSizeColumn}{\param{int }{col}, \param{bool }{setAsMin = true}}
78c49c58 153
cc81d32f 154Automatically sizes the column to fit its contents. If setAsMin is true the calculated width will
78c49c58
MB
155also be set as the minimal width for the column.
156
2eebb742 157\wxheading{Note}\\
78c49c58
MB
158wxGrid sets up arrays to store individual row and column sizes when non-default sizes are used.
159The memory requirements for this could become prohibitive if your grid is very large.
160
161\membersection{wxGrid::AutoSizeColumns}\label{wxgridautosizecolumns}
162
cc81d32f 163\func{void}{AutoSizeColumns}{\param{bool }{setAsMin = true}}
78c49c58 164
cc81d32f 165Automatically sizes all columns to fit their contents. If setAsMin is true the calculated widths will
78c49c58
MB
166also be set as the minimal widths for the columns.
167
2eebb742 168\wxheading{Note}\\
78c49c58
MB
169wxGrid sets up arrays to store individual row and column sizes when non-default sizes are used.
170The memory requirements for this could become prohibitive if your grid is very large.
171
172\membersection{wxGrid::AutoSizeRow}\label{wxgridautosizerow}
173
cc81d32f 174\func{void}{AutoSizeRow}{\param{int }{row}, \param{bool }{setAsMin = true}}
78c49c58 175
cc81d32f 176Automatically sizes the row to fit its contents. If setAsMin is true the calculated height will
78c49c58
MB
177also be set as the minimal height for the row.
178
2eebb742 179\wxheading{Note}\\
78c49c58
MB
180wxGrid sets up arrays to store individual row and column sizes when non-default sizes are used.
181The memory requirements for this could become prohibitive if your grid is very large.
182
183\membersection{wxGrid::AutoSizeRows}\label{wxgridautosizerows}
184
cc81d32f 185\func{void}{AutoSizeRows}{\param{bool }{setAsMin = true}}
78c49c58 186
cc81d32f 187Automatically sizes all rows to fit their contents. If setAsMin is true the calculated heights will
78c49c58
MB
188also be set as the minimal heights for the rows.
189
2eebb742 190\wxheading{Note}\\
78c49c58
MB
191wxGrid sets up arrays to store individual row and column sizes when non-default sizes are used.
192The memory requirements for this could become prohibitive if your grid is very large.
a660d684
KB
193
194\membersection{wxGrid::BeginBatch}\label{wxgridbeginbatch}
195
196\func{void}{BeginBatch}{\void}
197
78c49c58
MB
198Increments the grid's batch count. When the count is greater than zero repainting of
199the grid is suppressed. Each call to BeginBatch must be matched by a later call to
200\helpref{wxGrid::EndBatch}{wxgridendbatch}. Code that does a lot of grid
201modification can be enclosed between BeginBatch and EndBatch calls to avoid
202screen flicker. The final EndBatch will cause the grid to be repainted.
a660d684 203
78c49c58 204\membersection{wxGrid::CanDragColSize}\label{wxgridcandragcolsize}
a660d684 205
78c49c58 206\func{bool}{CanDragColSize}{\void}
a660d684 207
cc81d32f 208Returns true if columns can be resized by dragging with the mouse. Columns can be resized
78c49c58
MB
209by dragging the edges of their labels. If grid line dragging is enabled they can also be
210resized by dragging the right edge of the column in the grid cell area
211(see \helpref{wxGrid::EnableDragGridSize}{wxgridenabledraggridsize}).
a660d684 212
78c49c58 213\membersection{wxGrid::CanDragRowSize}\label{wxgridcandragrowsize}
a660d684 214
78c49c58 215\func{bool}{CanDragRowSize}{\void}
a660d684 216
cc81d32f 217Returns true if rows can be resized by dragging with the mouse. Rows can be resized
78c49c58
MB
218by dragging the edges of their labels. If grid line dragging is enabled they can also be
219resized by dragging the lower edge of the row in the grid cell area
220(see \helpref{wxGrid::EnableDragGridSize}{wxgridenabledraggridsize}).
a660d684 221
78c49c58 222\membersection{wxGrid::CanDragGridSize}\label{wxgridcandraggridsize}
a660d684 223
78c49c58 224\func{bool}{CanDragGridSize}{\void}
a660d684 225
cc81d32f 226Return true if the dragging of grid lines to resize rows and columns is enabled or false otherwise.
21f280f4 227
78c49c58 228\membersection{wxGrid::CanEnableCellControl}\label{wxgridcanenablecellcontrol}
a660d684 229
78c49c58 230\constfunc{bool}{CanEnableCellControl}{\void}
a660d684 231
cc81d32f
VS
232Returns true if the in-place edit control for the current grid cell can be used and
233false otherwise (e.g. if the current cell is read-only).
78c49c58
MB
234
235\membersection{wxGrid::CellToRect}\label{wxgridcelltorect}
236
237\func{wxRect}{CellToRect}{\param{int }{row}, \param{int }{col}}
238
239\func{wxRect}{CellToRect}{\param{const wxGridCellCoords\& }{coords}}
240
241Return the rectangle corresponding to the grid cell's size and position in logical
242coordinates.
243
244\membersection{wxGrid::ClearGrid}\label{wxgridcleargrid}
245
246\func{void}{ClearGrid}{\void}
247
248Clears all data in the underlying grid table and repaints the grid. The table is not deleted by
249this function. If you are using a derived table class then you need to override
250\helpref{wxGridTableBase::Clear}{wxgridtablebaseclear} for this function to have any effect.
251
5c69031c
MB
252\membersection{wxGrid::ClearSelection}\label{wxgridclearselection}
253
254\func{void}{ClearSelection}{\void}
255
256Deselects all cells that are currently selected.
257
78c49c58
MB
258\membersection{wxGrid::CreateGrid}\label{wxgridcreategrid}
259
260\func{bool}{CreateGrid}{\param{int }{numRows}, \param{int }{numCols}, \param{wxGrid::wxGridSelectionModes }{selmode = wxGrid::wxGridSelectCells}}
261
262Creates a grid with the specified initial number of rows and columns.
263Call this directly after the grid constructor. When you use this
264function wxGrid will create and manage a simple table of string values
265for you. All of the grid data will be stored in memory.
266
267For applications with more complex data types or relationships, or for
268dealing with very large datasets, you should derive your own grid table
269class and pass a table object to the grid with \helpref{wxGrid::SetTable}{wxgridsettable}.
a660d684
KB
270
271\membersection{wxGrid::DeleteCols}\label{wxgriddeletecols}
272
cc81d32f 273\func{bool}{DeleteCols}{\param{int }{pos = 0}, \param{int }{numCols = 1}, \param{bool }{updateLabels = true}}
a660d684 274
78c49c58 275Deletes one or more columns from a grid starting at the specified position and returns
cc81d32f 276true if successful. The updateLabels argument is not used at present.
78c49c58
MB
277
278If you are using a derived grid table class you will need to override
279\helpref{wxGridTableBase::DeleteCols}{wxgridtablebasedeletecols}. See
280\helpref{wxGrid::InsertCols}{wxgridinsertcols} for further information.
a660d684
KB
281
282\membersection{wxGrid::DeleteRows}\label{wxgriddeleterows}
283
cc81d32f 284\func{bool}{DeleteRows}{\param{int }{pos = 0}, \param{int }{numRows = 1}, \param{bool }{updateLabels = true}}
78c49c58
MB
285
286Deletes one or more rows from a grid starting at the specified position and returns
cc81d32f 287true if successful. The updateLabels argument is not used at present.
78c49c58
MB
288
289If you are using a derived grid table class you will need to override
290\helpref{wxGridTableBase::DeleteRows}{wxgridtablebasedeleterows}. See
291\helpref{wxGrid::InsertRows}{wxgridinsertrows} for further information.
292
293\membersection{wxGrid::DisableCellEditControl}\label{wxgriddisablecelleditcontrol}
294
295\func{void}{DisableCellEditControl}{\void}
296
297Disables in-place editing of grid cells.
cc81d32f 298Equivalent to calling EnableCellEditControl(false).
78c49c58
MB
299
300\membersection{wxGrid::DisableDragColSize}\label{wxgriddisabledragcolsize}
301
302\func{void}{DisableDragColSize}{\void}
303
cc81d32f 304Disables column sizing by dragging with the mouse. Equivalent to passing false to
78c49c58
MB
305\helpref{wxGrid::EnableDragColSize}{wxgridenabledragcolsize}.
306
307\membersection{wxGrid::DisableDragGridSize}\label{wxgriddisabledraggridsize}
308
309\func{void}{DisableDragGridSize}{\void}
310
311Disable mouse dragging of grid lines to resize rows and columns. Equivalent to passing
cc81d32f 312false to \helpref{wxGrid::EnableDragGridSize}{wxgridenabledraggridsize}
78c49c58
MB
313
314\membersection{wxGrid::DisableDragRowSize}\label{wxgriddisabledragrowsize}
315
316\func{void}{DisableDragRowSize}{\void}
317
cc81d32f 318Disables row sizing by dragging with the mouse. Equivalent to passing false to
78c49c58
MB
319\helpref{wxGrid::EnableDragRowSize}{wxgridenabledragrowsize}.
320
321\membersection{wxGrid::EnableCellEditControl}\label{wxgridenablecelleditcontrol}
322
cc81d32f 323\func{void}{EnableCellEditControl}{\param{bool }{enable = true}}
78c49c58
MB
324
325Enables or disables in-place editing of grid cell data. The grid will issue either a
e7240349 326wxEVT\_GRID\_EDITOR\_SHOWN or wxEVT\_GRID\_EDITOR\_HIDDEN event.
78c49c58
MB
327
328\membersection{wxGrid::EnableDragColSize}\label{wxgridenabledragcolsize}
329
cc81d32f 330\func{void}{EnableDragColSize}{\param{bool }{enable = true}}
a660d684 331
78c49c58
MB
332Enables or disables column sizing by dragging with the mouse.
333
334\membersection{wxGrid::EnableDragGridSize}\label{wxgridenabledraggridsize}
335
cc81d32f 336\func{void}{EnableDragGridSize}{\param{bool }{enable = true}}
78c49c58
MB
337
338Enables or disables row and column resizing by dragging gridlines with the mouse.
339
340\membersection{wxGrid::EnableDragRowSize}\label{wxgridenabledragrowsize}
341
cc81d32f 342\func{void}{EnableDragRowSize}{\param{bool }{enable = true}}
78c49c58
MB
343
344Enables or disables row sizing by dragging with the mouse.
345
346\membersection{wxGrid::EnableEditing}\label{wxgridenableediting}
347
348\func{void}{EnableEditing}{\param{bool }{edit}}
349
cc81d32f
VS
350If the edit argument is false this function sets the whole grid as read-only. If the
351argument is true the grid is set to the default state where cells may be editable. In the
78c49c58
MB
352default state you can set single grid cells and whole rows and columns to be editable or
353read-only via
354\helpref{wxGridCellAttribute::SetReadOnly}{wxgridcellattrsetreadonly}. For single
355cells you can also use the shortcut function
356\helpref{wxGrid::SetReadOnly}{wxgridsetreadonly}.
357
358For more information about controlling grid cell attributes see the
359\helpref{wxGridCellAttr}{wxgridcellattr} cell attribute class and the
360\helpref{wxGrid classes overview}{gridoverview}.
361
362\membersection{wxGrid::EnableGridLines}\label{wxgridenablegridlines}
363
cc81d32f 364\func{void}{EnableGridLines}{\param{bool }{enable = true}}
78c49c58
MB
365
366Turns the drawing of grid lines on or off.
a660d684
KB
367
368\membersection{wxGrid::EndBatch}\label{wxgridendbatch}
369
370\func{void}{EndBatch}{\void}
371
78c49c58
MB
372Decrements the grid's batch count. When the count is greater than zero repainting of
373the grid is suppressed. Each previous call to
374\helpref{wxGrid::BeginBatch}{wxgridbeginbatch} must be matched by a later call to
375EndBatch. Code that does a lot of grid modification can be enclosed between
376BeginBatch and EndBatch calls to avoid screen flicker. The final EndBatch will
377cause the grid to be repainted.
378
379\membersection{wxGrid::ForceRefresh}\label{wxgridforcerefresh}
a660d684 380
78c49c58
MB
381\func{void}{ForceRefresh}{\void}
382
383Causes immediate repainting of the grid. Use this instead of the usual wxWindow::Refresh.
a660d684
KB
384
385\membersection{wxGrid::GetBatchCount}\label{wxgridgetbatchcount}
386
78c49c58 387\func{int}{GetBatchCount}{\void}
a660d684 388
78c49c58
MB
389Returns the number of times that \helpref{wxGrid::BeginBatch}{wxgridbeginbatch} has been called
390without (yet) matching calls to \helpref{wxGrid::EndBatch}{wxgridendbatch}. While
391the grid's batch count is greater than zero the display will not be updated.
a660d684 392
78c49c58 393\membersection{wxGrid::GetCellAlignment}\label{wxgridgetcellalignment}
a660d684 394
78c49c58 395\func{void}{GetCellAlignment}{\param{int }{row}, \param{int }{col}, \param{int* }{horiz}, \param{int* }{vert}}
a660d684 396
78c49c58
MB
397Sets the arguments to the horizontal and vertical text alignment values for the
398grid cell at the specified location.
a660d684 399
e7240349
GT
400Horizontal alignment will be one of wxALIGN\_LEFT, wxALIGN\_CENTRE or wxALIGN\_RIGHT. \\
401Vertical alignment will be one of wxALIGN\_TOP, wxALIGN\_CENTRE or wxALIGN\_BOTTOM.
a660d684 402
9722642d
MB
403\perlnote{This method only takes the parameters {\tt row} and {\tt col} and
404returns a 2-element list {\tt ( horiz, vert )}.}
405
78c49c58 406\membersection{wxGrid::GetCellBackgroundColour}\label{wxgridgetcellbackgroundcolour}
a660d684 407
78c49c58 408\func{wxColour}{GetCellBackgroundColour}{\param{int }{row}, \param{int }{col}}
a660d684 409
78c49c58 410Returns the background colour of the cell at the specified location.
a660d684 411
78c49c58 412\membersection{wxGrid::GetCellEditor}\label{wxgridgetcelleditor}
a660d684 413
78c49c58 414\func{wxGridCellEditor*}{GetCellEditor}{\param{int }{row}, \param{int }{col}}
a660d684 415
78c49c58 416Returns a pointer to the editor for the cell at the specified location.
21f280f4 417
78c49c58
MB
418See \helpref{wxGridCellEditor}{wxgridcelleditor} and
419the \helpref{wxGrid overview}{gridoverview} for more information about cell editors and renderers.
a660d684 420
78c49c58 421\membersection{wxGrid::GetCellFont}\label{wxgridgetcellfont}
a660d684 422
78c49c58 423\func{wxFont}{GetCellFont}{\param{int }{row}, \param{int }{col}}
a660d684 424
78c49c58 425Returns the font for text in the grid cell at the specified location.
a660d684 426
78c49c58 427\membersection{wxGrid::GetCellRenderer}\label{wxgridgetcellrenderer}
21f280f4 428
78c49c58 429\func{wxGridCellRenderer*}{GetCellRenderer}{\param{int }{row}, \param{int }{col}}
a660d684 430
78c49c58 431Returns a pointer to the renderer for the grid cell at the specified location.
a660d684 432
78c49c58
MB
433See \helpref{wxGridCellRenderer}{wxgridcellrenderer} and
434the \helpref{wxGrid overview}{gridoverview} for more information about cell editors and renderers.
a660d684
KB
435
436\membersection{wxGrid::GetCellTextColour}\label{wxgridgetcelltextcolour}
437
78c49c58 438\func{wxColour}{GetCellTextColour}{\param{int }{row}, \param{int }{col}}
a660d684 439
78c49c58 440Returns the text colour for the grid cell at the specified location.
a660d684 441
5c69031c
MB
442\membersection{wxGrid::GetCellValue}\label{wxgridgetcellvalue}
443
444\func{wxString}{GetCellValue}{\param{int }{row}, \param{int }{col}}
445
446\func{wxString}{GetCellValue}{\param{const wxGridCellCoords\&}{coords}}
447
448Returns the string contained in the cell at the specified location. For simple applications where a
449grid object automatically uses a default grid table of string values you use this function together
450with \helpref{wxGrid::SetCellValue}{wxgridsetcellvalue} to access cell values.
451
452For more complex applications where you have derived your own grid table class that contains
453various data types (e.g. numeric, boolean or user-defined custom types) then you only use this
454function for those cells that contain string values.
455
456See \helpref{wxGridTableBase::CanGetValueAs}{wxgridtablebasecangetvalueas}
457and the \helpref{wxGrid overview}{gridoverview} for more information.
458
78c49c58 459\membersection{wxGrid::GetColLabelAlignment}\label{wxgridgetcollabelalignment}
a660d684 460
78c49c58 461\func{void}{GetColLabelAlignment}{\param{int* }{horiz}, \param{int* }{vert}}
21f280f4 462
78c49c58 463Sets the arguments to the current column label alignment values.
a660d684 464
78c49c58
MB
465Horizontal alignment will be one of wxLEFT, wxCENTRE or wxRIGHT. \\
466Vertical alignment will be one of wxTOP, wxCENTRE or wxBOTTOM.
a660d684 467
9722642d
MB
468\perlnote{This method takes no parameters and
469returns a 2-element list {\tt ( horiz, vert )}.}
470
78c49c58 471\membersection{wxGrid::GetColLabelSize}\label{wxgridgetcollabelsize}
a660d684 472
78c49c58 473\func{int}{GetColLabelSize}{\void}
a660d684 474
78c49c58 475Returns the current height of the column labels.
21f280f4 476
78c49c58 477\membersection{wxGrid::GetColLabelValue}\label{wxgridgetcollabelvalue}
a660d684 478
78c49c58 479\func{wxString}{GetColLabelValue}{\param{int }{col}}
a660d684 480
2edb0bde 481Returns the specified column label. The default grid table class provides column labels of
2eebb742 482the form A,B...Z,AA,AB...ZZ,AAA... If you are using a custom grid table you can override
78c49c58
MB
483\helpref{wxGridTableBase::GetColLabelValue}{wxgridtablebasegetcollabelvalue} to provide
484your own labels.
a660d684 485
78c49c58 486\membersection{wxGrid::GetColSize}\label{wxgridgetcolsize}
a660d684 487
78c49c58 488\func{int}{GetColSize}{\param{int }{col}}
a660d684 489
78c49c58 490Returns the width of the specified column.
a660d684 491
78c49c58 492\membersection{wxGrid::GetDefaultCellAlignment}\label{wxgridgetdefaultcellalignment}
a660d684 493
78c49c58 494\func{void}{GetDefaultCellAlignment}{\param{int* }{horiz}, \param{int* }{vert}}
a660d684 495
78c49c58
MB
496Sets the arguments to the current default horizontal and vertical text alignment
497values.
a660d684 498
2eebb742
JS
499Horizontal alignment will be one of wxALIGN\_LEFT, wxALIGN\_CENTRE or wxALIGN\_RIGHT. \\
500Vertical alignment will be one of wxALIGN\_TOP, wxALIGN\_CENTRE or wxALIGN\_BOTTOM.
a660d684 501
78c49c58 502\membersection{wxGrid::GetDefaultCellBackgroundColour}\label{wxgridgetdefaultcellbackgroundcolour}
a660d684 503
78c49c58 504\func{wxColour}{GetDefaultCellBackgroundColour}{\void}
a660d684 505
78c49c58 506Returns the current default background colour for grid cells.
a660d684 507
78c49c58 508\membersection{wxGrid::GetDefaultCellFont}\label{wxgridgetdefaultcellfont}
a660d684 509
78c49c58 510\func{wxFont}{GetDefaultCellFont}{\void}
a660d684 511
78c49c58 512Returns the current default font for grid cell text.
a660d684 513
78c49c58 514\membersection{wxGrid::GetDefaultCellTextColour}\label{wxgridgetdefaultcelltextcolour}
a660d684 515
78c49c58 516\func{wxColour}{GetDefaultCellTextColour}{\void}
a660d684 517
78c49c58 518Returns the current default colour for grid cell text.
a660d684 519
78c49c58 520\membersection{wxGrid::GetDefaultColLabelSize}\label{wxgridgetdefaultcollabelsize}
a660d684 521
78c49c58 522\func{int}{GetDefaultColLabelSize}{\void}
a660d684 523
78c49c58 524Returns the default height for column labels.
c0b042fc 525
78c49c58 526\membersection{wxGrid::GetDefaultColSize}\label{wxgridgetdefaultcolsize}
c0b042fc 527
78c49c58 528\func{int}{GetDefaultColSize}{\void}
c0b042fc 529
78c49c58 530Returns the current default width for grid columns.
a660d684 531
78c49c58 532\membersection{wxGrid::GetDefaultEditor}\label{wxgridgetdefaulteditor}
a660d684 533
78c49c58 534\constfunc{wxGridCellEditor*}{GetDefaultEditor}{\void}
a660d684 535
78c49c58
MB
536Returns a pointer to the current default grid cell editor.
537
538See \helpref{wxGridCellEditor}{wxgridcelleditor} and
539the \helpref{wxGrid overview}{gridoverview} for more information about cell editors and renderers.
540
541\membersection{wxGrid::GetDefaultRenderer}\label{wxgridgetdefaultrenderer}
542
543\constfunc{wxGridCellRenderer*}{GetDefaultRenderer}{\void}
544
545Returns a pointer to the current default grid cell renderer.
546
547See \helpref{wxGridCellRenderer}{wxgridcellrenderer} and
548the \helpref{wxGrid overview}{gridoverview} for more information about cell editors and renderers.
a660d684 549
78c49c58 550\membersection{wxGrid::GetDefaultRowLabelSize}\label{wxgridgetdefaultrowlabelsize}
a660d684 551
78c49c58
MB
552\func{int}{GetDefaultRowLabelSize}{\void}
553
554Returns the default width for the row labels.
555
556\membersection{wxGrid::GetDefaultRowSize}\label{wxgridgetdefaultrowsize}
557
558\func{int}{GetDefaultRowSize}{\void}
559
560Returns the current default height for grid rows.
561
562\membersection{wxGrid::GetGridCursorCol}\label{wxgridgetgridcursorcol}
563
564\func{int}{GetGridCursorCol}{\void}
565
566Returns the current grid cell column position.
567
568\membersection{wxGrid::GetGridCursorRow}\label{wxgridgetgridcursorrow}
569
570\func{int}{GetGridCursorRow}{\void}
571
572Returns the current grid cell row position.
573
574\membersection{wxGrid::GetGridLineColour}\label{wxgridgetgridlinecolour}
575
576\func{wxColour}{GetGridLineColour}{\void}
577
578Returns the colour used for grid lines.
579
580\membersection{wxGrid::GridLinesEnabled}\label{wxgridgridlinesenabled}
581
582\func{bool}{GridLinesEnabled}{\void}
583
cc81d32f 584Returns true if drawing of grid lines is turned on, false otherwise.
a660d684
KB
585
586\membersection{wxGrid::GetLabelBackgroundColour}\label{wxgridgetlabelbackgroundcolour}
587
78c49c58 588\func{wxColour}{GetLabelBackgroundColour}{\void}
a660d684 589
78c49c58 590Returns the colour used for the background of row and column labels.
a660d684 591
78c49c58 592\membersection{wxGrid::GetLabelFont}\label{wxgridgetlabelfont}
a660d684 593
78c49c58 594\func{wxFont}{GetLabelFont}{\void}
a660d684 595
78c49c58 596Returns the font used for row and column labels.
a660d684
KB
597
598\membersection{wxGrid::GetLabelTextColour}\label{wxgridgetlabeltextcolour}
599
78c49c58 600\func{wxColour}{GetLabelTextColour}{\void}
a660d684 601
78c49c58 602Returns the colour used for row and column label text.
a660d684 603
78c49c58 604\membersection{wxGrid::GetNumberCols}\label{wxgridgetnumbercols}
a660d684 605
78c49c58 606\func{int}{GetNumberCols}{\void}
a660d684 607
78c49c58
MB
608Returns the total number of grid columns (actually the number of columns in the underlying grid
609table).
a660d684 610
78c49c58 611\membersection{wxGrid::GetNumberRows}\label{wxgridgetnumberrows}
a660d684 612
78c49c58 613\func{int}{GetNumberRows}{\void}
a660d684 614
78c49c58 615Returns the total number of grid rows (actually the number of rows in the underlying grid table).
a660d684 616
78c49c58 617\membersection{wxGrid::GetRowLabelAlignment}\label{wxgridgetrowlabelalignment}
a660d684 618
78c49c58 619\func{void}{GetRowLabelAlignment}{\param{int* }{horiz}, \param{int* }{vert}}
a660d684 620
78c49c58 621Sets the arguments to the current row label alignment values.
a660d684 622
78c49c58
MB
623Horizontal alignment will be one of wxLEFT, wxCENTRE or wxRIGHT. \\
624Vertical alignment will be one of wxTOP, wxCENTRE or wxBOTTOM.
a660d684 625
9722642d
MB
626\perlnote{This method takes no parameters and
627returns a 2-element list {\tt ( horiz, vert )}.}
628
78c49c58 629\membersection{wxGrid::GetRowLabelSize}\label{wxgridgetrowlabelsize}
a660d684 630
78c49c58 631\func{int}{GetRowLabelSize}{\void}
a660d684 632
78c49c58 633Returns the current width of the row labels.
a660d684 634
78c49c58 635\membersection{wxGrid::GetRowLabelValue}\label{wxgridgetrowlabelvalue}
a660d684 636
78c49c58 637\func{wxString}{GetRowLabelValue}{\param{int }{row}}
a660d684 638
2edb0bde 639Returns the specified row label. The default grid table class provides numeric row labels.
78c49c58
MB
640If you are using a custom grid table you can override
641\helpref{wxGridTableBase::GetRowLabelValue}{wxgridtablebasegetcollabelvalue} to provide
642your own labels.
a660d684 643
78c49c58 644\membersection{wxGrid::GetRowSize}\label{wxgridgetrowsize}
a660d684 645
78c49c58 646\func{int}{GetRowSize}{\param{int }{row}}
a660d684 647
78c49c58 648Returns the height of the specified row.
a660d684 649
aa5b8857
SN
650\membersection{wxGrid::GetSelectionMode}\label{wxgridgetselectionmode}
651
652\constfunc{wxGrid::wxGridSelectionModes}{GetSelectionMode}{\void}
653
654Returns the current selection mode, see \helpref{wxGrid::SetSelectionMode}{wxgridsetselectionmode}.
655
656\membersection{wxGrid::GetSelectedCells}\label{wxgridgetselectedcells}
657
658\constfunc{wxGridCellCoordsArray}{GetSelectedCells}{\void}
659
660Returns an array of singly selected cells.
661
662\membersection{wxGrid::GetSelectedCols}\label{wxgridgetselectedcols}
663
664\constfunc{wxArrayInt}{GetSelectedCols}{\void}
665
666Returns an array of selected cols.
667
668\membersection{wxGrid::GetSelectedRows}\label{wxgridgetselectedrows}
669
670\constfunc{wxArrayInt}{GetSelectedRows}{\void}
671
672Returns an array of selected rows.
673
674\membersection{wxGrid::GetSelectionBlockTopLeft}\label{wxgridgetselectionblocktopleft}
675
676\constfunc{wxGridCellCoordsArray}{GetSelectionBlockTopLeft}{\void}
677
678Returns an array of the top left corners of blocks of selected cells,
679see \helpref{wxGrid::GetSelectionBlockBottomRight}{wxgridgetselectionblockbottomright}.
680
681\membersection{wxGrid::GetSelectionBlockBottomRight}\label{wxgridgetselectionblockbottomright}
682
683\constfunc{wxGridCellCoordsArray}{GetSelectionBlockBottomRight}{\void}
684
685Returns an array of the bottom right corners of blocks of selected cells,
686see \helpref{wxGrid::GetSelectionBlockTopLeft}{wxgridgetselectionblocktopleft}.
687
78c49c58 688\membersection{wxGrid::GetTable}\label{wxgridgettable}
a660d684 689
78c49c58 690\constfunc{wxGridTableBase *}{GetTable}{\void}
a660d684 691
78c49c58 692Returns a base pointer to the current table object.
a660d684 693
78c49c58 694\membersection{wxGrid::HideCellEditControl}\label{wxgridhidecelleditcontrol}
a660d684 695
78c49c58
MB
696\func{void}{HideCellEditControl}{\void}
697
698Hides the in-place cell edit control.
a660d684
KB
699
700\membersection{wxGrid::InsertCols}\label{wxgridinsertcols}
701
cc81d32f 702\func{bool}{InsertCols}{\param{int }{pos = 0}, \param{int }{numCols = 1}, \param{bool }{updateLabels = true}}
78c49c58
MB
703
704Inserts one or more new columns into a grid with the first new column at the
cc81d32f 705specified position and returns true if successful. The updateLabels argument is not
78c49c58 706used at present.
a660d684 707
78c49c58
MB
708The sequence of actions begins with the grid object requesting the underlying grid
709table to insert new columns. If this is successful the table notifies the grid and the
710grid updates the display. For a default grid (one where you have called
711\helpref{wxGrid::CreateGrid}{wxgridcreategrid}) this process is automatic. If you are
712using a custom grid table (specified with \helpref{wxGrid::SetTable}{wxgridsettable})
713then you must override
714\helpref{wxGridTableBase::InsertCols}{wxgridtablebaseinsertcols} in your derived
715table class.
a660d684
KB
716
717\membersection{wxGrid::InsertRows}\label{wxgridinsertrows}
718
cc81d32f 719\func{bool}{InsertRows}{\param{int }{pos = 0}, \param{int }{numRows = 1}, \param{bool }{updateLabels = true}}
a660d684 720
78c49c58 721Inserts one or more new rows into a grid with the first new row at the specified
cc81d32f 722position and returns true if successful. The updateLabels argument is not used at
78c49c58 723present.
a660d684 724
78c49c58
MB
725The sequence of actions begins with the grid object requesting the underlying grid
726table to insert new rows. If this is successful the table notifies the grid and the
727grid updates the display. For a default grid (one where you have called
728\helpref{wxGrid::CreateGrid}{wxgridcreategrid}) this process is automatic. If you are
729using a custom grid table (specified with \helpref{wxGrid::SetTable}{wxgridsettable})
730then you must override
731\helpref{wxGridTableBase::InsertRows}{wxgridtablebaseinsertrows} in your derived
732table class.
733
734\membersection{wxGrid::IsCellEditControlEnabled}\label{wxgridiscelleditcontrolenabled}
735
736\constfunc{bool}{IsCellEditControlEnabled}{\void}
737
cc81d32f 738Returns true if the in-place edit control is currently enabled.
78c49c58
MB
739
740\membersection{wxGrid::IsCurrentCellReadOnly}\label{wxgridiscurrentcellreadonly}
741
742\constfunc{bool}{IsCurrentCellReadOnly}{\void}
743
cc81d32f 744Returns true if the current cell has been set to read-only
78c49c58
MB
745(see \helpref{wxGrid::SetReadOnly}{wxgridsetreadonly}).
746
747\membersection{wxGrid::IsEditable}\label{wxgridiseditable}
a660d684 748
78c49c58 749\func{bool}{IsEditable}{\void}
a660d684 750
cc81d32f 751Returns false if the whole grid has been set as read-only or true otherwise.
78c49c58
MB
752See \helpref{wxGrid::EnableEditing}{wxgridenableediting} for more information about
753controlling the editing status of grid cells.
a660d684 754
aa5b8857
SN
755\membersection{wxGrid::IsInSelection}\label{wxgridisinselection}
756
757\constfunc{bool}{IsInSelection}{\param{int }{row}, \param{int }{col}}
758
759\constfunc{bool}{IsInSelection}{\param{const wxGridCellCoords\& }{coords}}
760
761Is this cell currently selected.
762
5c69031c
MB
763\membersection{wxGrid::IsReadOnly}\label{wxgridisreadonly}
764
765\constfunc{bool}{IsReadOnly}{\param{int }{row}, \param{int }{col}}
766
cc81d32f 767Returns true if the cell at the specified location can't be edited.
5c69031c
MB
768See also \helpref{wxGrid::IsReadOnly}{wxgridisreadonly}.
769
770\membersection{wxGrid::IsSelection}\label{wxgridisselection}
771
772\func{bool}{IsSelection}{\void}
773
cc81d32f 774Returns true if there are currently rows, columns or blocks of cells selected.
5c69031c 775
78c49c58 776\membersection{wxGrid::IsVisible}\label{wxgridisvisible}
a660d684 777
cc81d32f 778\func{bool}{IsVisible}{\param{int }{row}, \param{int }{col}, \param{bool }{wholeCellVisible = true}}
a660d684 779
cc81d32f 780\func{bool}{IsVisible}{\param{const wxGridCellCoords\& }{coords}, \param{bool }{wholeCellVisible = true}}
a660d684 781
cc81d32f 782Returns true if a cell is either wholly visible (the default) or at least partially
78c49c58 783visible in the grid window.
a660d684 784
78c49c58 785\membersection{wxGrid::MakeCellVisible}\label{wxgridmakecellvisible}
a660d684 786
78c49c58 787\func{void}{MakeCellVisible}{\param{int }{row}, \param{int }{col}}
a660d684 788
78c49c58 789\func{void}{MakeCellVisible}{\param{const wxGridCellCoords\& }{coords}}
a660d684 790
78c49c58
MB
791Brings the specified cell into the visible grid cell area with minimal scrolling. Does
792nothing if the cell is already visible.
a660d684 793
78c49c58 794\membersection{wxGrid::MoveCursorDown}\label{wxgridmovecursordown}
a660d684 795
78c49c58 796\func{bool}{MoveCursorDown}{\param{bool }{expandSelection}}
a660d684 797
2eebb742 798Moves the grid cursor down by one row. If a block of cells was previously selected it
cc81d32f 799will expand if the argument is true or be cleared if the argument is false.
a660d684 800
78c49c58
MB
801\wxheading{Keyboard}\\
802This function is called for Down cursor key presses or Shift+Down to expand a selection.
a660d684 803
78c49c58 804\membersection{wxGrid::MoveCursorLeft}\label{wxgridmovecursorleft}
a660d684 805
78c49c58 806\func{bool}{MoveCursorLeft}{\param{bool }{expandSelection}}
a660d684 807
78c49c58 808Moves the grid cursor left by one column. If a block of cells was previously selected it
cc81d32f 809will expand if the argument is true or be cleared if the argument is false.
a660d684 810
78c49c58
MB
811\wxheading{Keyboard}\\
812This function is called for Left cursor key presses or Shift+Left to expand a selection.
a660d684 813
78c49c58 814\membersection{wxGrid::MoveCursorRight}\label{wxgridmovecursorright}
a660d684 815
78c49c58 816\func{bool}{MoveCursorRight}{\param{bool }{expandSelection}}
a660d684 817
78c49c58 818Moves the grid cursor right by one column. If a block of cells was previously selected it
cc81d32f 819will expand if the argument is true or be cleared if the argument is false.
a660d684 820
78c49c58
MB
821\wxheading{Keyboard}\\
822This function is called for Right cursor key presses or Shift+Right to expand a selection.
a660d684 823
78c49c58 824\membersection{wxGrid::MoveCursorUp}\label{wxgridmovecursorup}
a660d684 825
78c49c58 826\func{bool}{MoveCursorUp}{\param{bool }{expandSelection}}
a660d684 827
78c49c58 828Moves the grid cursor up by one row. If a block of cells was previously selected it
cc81d32f 829will expand if the argument is true or be cleared if the argument is false.
a660d684 830
78c49c58
MB
831\wxheading{Keyboard}\\
832This function is called for Up cursor key presses or Shift+Up to expand a selection.
a660d684 833
78c49c58 834\membersection{wxGrid::MoveCursorDownBlock}\label{wxgridmovecursordownblock}
a660d684 835
78c49c58 836\func{bool}{MoveCursorDownBlock}{\param{bool }{expandSelection}}
a660d684 837
78c49c58
MB
838Moves the grid cursor down in the current column such that it skips to the beginning or
839end of a block of non-empty cells. If a block of cells was previously selected it
cc81d32f 840will expand if the argument is true or be cleared if the argument is false.
a660d684 841
78c49c58
MB
842\wxheading{Keyboard}\\
843This function is called for the Ctrl+Down key combination. Shift+Ctrl+Down expands a selection.
a660d684 844
78c49c58 845\membersection{wxGrid::MoveCursorLeftBlock}\label{wxgridmovecursorleftblock}
a660d684 846
78c49c58 847\func{bool}{MoveCursorLeftBlock}{\param{bool }{expandSelection}}
a660d684 848
78c49c58
MB
849Moves the grid cursor left in the current row such that it skips to the beginning or
850end of a block of non-empty cells. If a block of cells was previously selected it
cc81d32f 851will expand if the argument is true or be cleared if the argument is false.
a660d684 852
78c49c58
MB
853\wxheading{Keyboard}\\
854This function is called for the Ctrl+Left key combination. Shift+Ctrl+left expands a selection.
a660d684 855
78c49c58
MB
856\membersection{wxGrid::MoveCursorRightBlock}\label{wxgridmovecursorrightblock}
857
858\func{bool}{MoveCursorRightBlock}{\param{bool }{expandSelection}}
859
860Moves the grid cursor right in the current row such that it skips to the beginning or
861end of a block of non-empty cells. If a block of cells was previously selected it
cc81d32f 862will expand if the argument is true or be cleared if the argument is false.
78c49c58
MB
863
864\wxheading{Keyboard}\\
865This function is called for the Ctrl+Right key combination. Shift+Ctrl+Right expands a selection.
866
867\membersection{wxGrid::MoveCursorUpBlock}\label{wxgridmovecursorupblock}
868
869\func{bool}{MoveCursorUpBlock}{\param{bool }{expandSelection}}
870
871Moves the grid cursor up in the current column such that it skips to the beginning or
872end of a block of non-empty cells. If a block of cells was previously selected it
cc81d32f 873will expand if the argument is true or be cleared if the argument is false.
78c49c58
MB
874
875\wxheading{Keyboard}\\
876This function is called for the Ctrl+Up key combination. Shift+Ctrl+Up expands a selection.
877
878\membersection{wxGrid::MovePageDown}\label{wxgridmovepagedown}
879
880\func{bool}{MovePageDown}{\void}
881
882Moves the grid cursor down by some number of rows so that the previous bottom visible row
883becomes the top visible row.
884
885\wxheading{Keyboard}\\
886This function is called for PgDn keypresses.
887
888\membersection{wxGrid::MovePageUp}\label{wxgridmovepageup}
889
890\func{bool}{MovePageUp}{\void}
891
892Moves the grid cursor up by some number of rows so that the previous top visible row
893becomes the bottom visible row.
894
895\wxheading{Keyboard}\\
896This function is called for PgUp keypresses.
897
898\membersection{wxGrid::SaveEditControlValue}\label{wxgridsaveeditcontrolvalue}
899
900\func{void}{SaveEditControlValue}{\void}
901
902Sets the value of the current grid cell to the current in-place edit control value.
903This is called automatically when the grid cursor moves from the current cell to a
904new cell. It is also a good idea to call this function when closing a grid since
905any edits to the final cell location will not be saved otherwise.
a660d684 906
5c69031c
MB
907\membersection{wxGrid::SelectAll}\label{wxgridselectall}
908
909\func{void}{SelectAll}{\void}
910
911Selects all cells in the grid.
912
913\membersection{wxGrid::SelectBlock}\label{wxgridselectblock}
914
cbb4b02f 915\func{void}{SelectBlock}{\param{int }{topRow}, \param{int }{leftCol},
cc81d32f 916\param{int }{bottomRow}, \param{int }{rightCol}, \param{bool }{addToSelected = false}}
5c69031c 917
cbb4b02f 918\func{void}{SelectBlock}{\param{const wxGridCellCoords\& }{topLeft},
cc81d32f 919\param{const wxGridCellCoords\& }{bottomRight}, \param{bool }{addToSelected = false}}
5c69031c 920
cc81d32f
VS
921Selects a rectangular block of cells. If addToSelected is false then any existing selection will be
922deselected; if true the column will be added to the existing selection.
5c69031c
MB
923
924\membersection{wxGrid::SelectCol}\label{wxgridselectcol}
925
cc81d32f 926\func{void}{SelectCol}{\param{int }{col}, \param{bool }{addToSelected = false}}
5c69031c 927
cc81d32f
VS
928Selects the specified column. If addToSelected is false then any existing selection will be
929deselected; if true the column will be added to the existing selection.
5c69031c
MB
930
931\membersection{wxGrid::SelectRow}\label{wxgridselectrow}
932
cc81d32f 933\func{void}{SelectRow}{\param{int }{row}, \param{bool }{addToSelected = false}}
5c69031c 934
cc81d32f
VS
935Selects the specified row. If addToSelected is false then any existing selection will be
936deselected; if true the row will be added to the existing selection.
5c69031c 937
a660d684
KB
938\membersection{wxGrid::SetCellAlignment}\label{wxgridsetcellalignment}
939
78c49c58 940\func{void}{SetCellAlignment}{\param{int }{row}, \param{int }{col}, \param{int }{horiz}, \param{int }{vert}}
a660d684 941
2eebb742
JS
942\func{void}{SetCellAlignment}{\param{int }{align}, \param{int }{row}, \param{int }{col}}
943
944\func{void}{SetCellAlignment}{\param{int }{align}}
945
2edb0bde 946Sets the horizontal and vertical alignment for grid cell text at the specified location.
a660d684 947
e7240349
GT
948Horizontal alignment should be one of wxALIGN\_LEFT, wxALIGN\_CENTRE or wxALIGN\_RIGHT. \\
949Vertical alignment should be one of wxALIGN\_TOP, wxALIGN\_CENTRE or wxALIGN\_BOTTOM.
a660d684 950
78c49c58 951\membersection{wxGrid::SetCellEditor}\label{wxgridsetcelleditor}
21f280f4 952
78c49c58
MB
953\func{void}{SetCellEditor}{\param{int }{row}, \param{int }{col}, \param{wxGridCellEditor* }{editor}}
954
955Sets the editor for the grid cell at the specified location.
956The grid will take ownership of the pointer.
957
958See \helpref{wxGridCellEditor}{wxgridcelleditor} and
959the \helpref{wxGrid overview}{gridoverview} for more information about cell editors and renderers.
960
961\membersection{wxGrid::SetCellFont}\label{wxgridsetcellfont}
962
deea56b1 963\func{void}{SetCellFont}{\param{int }{row}, \param{int }{col}, \param{const wxFont\&}{ font}}
78c49c58
MB
964
965Sets the font for text in the grid cell at the specified location.
a660d684 966
78c49c58 967\membersection{wxGrid::SetCellRenderer}\label{wxgridsetcellrenderer}
a660d684 968
78c49c58 969\func{void}{SetCellRenderer}{\param{int }{row}, \param{int }{col}, \param{wxGridCellRenderer* }{renderer}}
a660d684 970
78c49c58
MB
971Sets the renderer for the grid cell at the specified location.
972The grid will take ownership of the pointer.
a660d684 973
78c49c58
MB
974See \helpref{wxGridCellRenderer}{wxgridcellrenderer} and
975the \helpref{wxGrid overview}{gridoverview} for more information about cell editors and renderers.
21f280f4 976
a660d684
KB
977\membersection{wxGrid::SetCellTextColour}\label{wxgridsetcelltextcolour}
978
68f30f26 979\func{void}{SetCellTextColour}{\param{int }{row}, \param{int }{col}, \param{const wxColour\&}{ colour}}
a660d684 980
2eebb742
JS
981\func{void}{SetCellTextColour}{\param{const wxColour\& }{val}, \param{int }{row}, \param{int }{col}}
982
deea56b1 983\func{void}{SetCellTextColour}{\param{const wxColour\& }{colour}}
2eebb742 984
78c49c58 985Sets the text colour for the grid cell at the specified location.
a660d684 986
5c69031c
MB
987\membersection{wxGrid::SetCellValue}\label{wxgridsetcellvalue}
988
989\func{void}{SetCellValue}{\param{int }{row}, \param{int }{col}, \param{const wxString\& }{s}}
990
991\func{void}{SetCellValue}{\param{const wxGridCellCoords\& }{coords}, \param{const wxString\& }{s}}
992
2eebb742
JS
993\func{void}{SetCellValue}{\param{const wxString\& }{val}, \param{int }{row}, \param{int }{col}}
994
5c69031c
MB
995Sets the string value for the cell at the specified location. For simple applications where a
996grid object automatically uses a default grid table of string values you use this function together
997with \helpref{wxGrid::GetCellValue}{wxgridgetcellvalue} to access cell values.
998
999For more complex applications where you have derived your own grid table class that contains
1000various data types (e.g. numeric, boolean or user-defined custom types) then you only use this
2eebb742
JS
1001function for those cells that contain string values.
1002
1003The last form is for backward compatibility only.
5c69031c
MB
1004
1005See \helpref{wxGridTableBase::CanSetValueAs}{wxgridtablebasecangetvalueas}
1006and the \helpref{wxGrid overview}{gridoverview} for more information.
1007
78c49c58 1008\membersection{wxGrid::SetColAttr}\label{wxgridsetcolattr}
a660d684 1009
78c49c58 1010\func{void}{SetColAttr}{\param{int }{col}, \param{wxGridCellAttr* }{attr}}
21f280f4 1011
78c49c58 1012Sets the cell attributes for all cells in the specified column.
a660d684 1013
78c49c58
MB
1014For more information about controlling grid cell attributes see the
1015\helpref{wxGridCellAttr}{wxgridcellattr} cell attribute class and the
1016\helpref{wxGrid classes overview}{gridoverview}.
a660d684 1017
78c49c58 1018\membersection{wxGrid::SetColFormatBool}\label{wxgridsetcolformatbool}
a660d684 1019
78c49c58 1020\func{void}{SetColFormatBool}{\param{int }{col}}
a660d684 1021
78c49c58 1022Sets the specified column to display boolean values. wxGrid displays boolean values with a checkbox.
21f280f4 1023
78c49c58 1024\membersection{wxGrid::SetColFormatNumber}\label{wxgridsetcolformatnumber}
a660d684 1025
78c49c58 1026\func{void}{SetColFormatNumber}{\param{int }{col}}
a660d684 1027
78c49c58 1028Sets the specified column to display integer values.
a660d684 1029
78c49c58 1030\membersection{wxGrid::SetColFormatFloat}\label{wxgridsetcolformatfloat}
a660d684 1031
78c49c58 1032\func{void}{SetColFormatFloat}{\param{int }{col}, \param{int }{width = -1}, \param{int }{precision = -1}}
a660d684 1033
78c49c58 1034Sets the specified column to display floating point values with the given width and precision.
a660d684 1035
78c49c58 1036\membersection{wxGrid::SetColFormatCustom}\label{wxgridsetcolformatcustom}
a660d684 1037
78c49c58 1038\func{void}{SetColFormatCustom}{\param{int }{col}, \param{const wxString\& }{typeName}}
a660d684 1039
78c49c58
MB
1040Sets the specified column to display data in a custom format.
1041See the \helpref{wxGrid overview}{gridoverview} for more information on working
1042with custom data types.
a660d684 1043
78c49c58 1044\membersection{wxGrid::SetColLabelAlignment}\label{wxgridsetcollabelalignment}
a660d684 1045
78c49c58 1046\func{void}{SetColLabelAlignment}{\param{int }{horiz}, \param{int }{vert}}
a660d684 1047
78c49c58 1048Sets the horizontal and vertical alignment of column label text.
a660d684 1049
e7240349 1050Horizontal alignment should be one of wxALIGN\_LEFT, wxALIGN\_CENTRE or wxALIGN\_RIGHT.
deea56b1 1051
e7240349 1052Vertical alignment should be one of wxALIGN\_TOP, wxALIGN\_CENTRE or wxALIGN\_BOTTOM.
78c49c58
MB
1053
1054\membersection{wxGrid::SetColLabelSize}\label{wxgridsetcollabelsize}
1055
1056\func{void}{SetColLabelSize}{\param{int }{height}}
1057
1058Sets the height of the column labels.
1059
1060\membersection{wxGrid::SetColLabelValue}\label{wxgridsetcollabelvalue}
1061
deea56b1 1062\func{void}{SetColLabelValue}{\param{int }{col}, \param{const wxString\&}{ value}}
78c49c58
MB
1063
1064Set the value for the given column label. If you are using a derived grid table you must
1065override \helpref{wxGridTableBase::SetColLabelValue}{wxgridtablebasesetcollabelvalue}
1066for this to have any effect.
1067
1068\membersection{wxGrid::SetColMinimalWidth}\label{wxgridsetcolminimalwidth}
1069
1070\func{void}{SetColMinimalWidth}{\param{int }{col}, \param{int }{width}}
1071
1072Sets the minimal width for the specified column. This should normally be called when creating the grid
1073because it will not resize a column that is already narrower than the minimal width.
1074
1075\membersection{wxGrid::SetColSize}\label{wxgridsetcolsize}
1076
1077\func{void}{SetColSize}{\param{int }{col}, \param{int }{width}}
1078
1079Sets the width of the specified column.
1080
1081This function does not refresh the grid. If you are calling it outside of a BeginBatch / EndBatch
1082block you can use \helpref{wxGrid::ForceRefresh}{wxgridforcerefresh} to see the changes.
1083
cc81d32f 1084Automatically sizes the column to fit its contents. If setAsMin is true the calculated width will
78c49c58
MB
1085also be set as the minimal width for the column.
1086
2eebb742 1087\wxheading{Note}\\
78c49c58
MB
1088wxGrid sets up arrays to store individual row and column sizes when non-default sizes are used.
1089The memory requirements for this could become prohibitive if your grid is very large.
1090
1091\membersection{wxGrid::SetDefaultCellAlignment}\label{wxgridsetdefaultcellalignment}
1092
1093\func{void}{SetDefaultCellAlignment}{\param{int }{horiz}, \param{int }{vert}}
1094
2edb0bde 1095Sets the default horizontal and vertical alignment for grid cell text.
78c49c58 1096
e7240349 1097Horizontal alignment should be one of wxALIGN\_LEFT, wxALIGN\_CENTRE or wxALIGN\_RIGHT.
deea56b1 1098
e7240349 1099Vertical alignment should be one of wxALIGN\_TOP, wxALIGN\_CENTRE or wxALIGN\_BOTTOM.
78c49c58
MB
1100
1101\membersection{wxGrid::SetDefaultCellBackgroundColour}\label{wxgridsetdefaultcellbackgroundcolour}
1102
deea56b1 1103\func{void}{SetDefaultCellBackgroundColour}{\param{const wxColour\&}{ colour}}
78c49c58
MB
1104
1105Sets the default background colour for grid cells.
1106
1107\membersection{wxGrid::SetDefaultCellFont}\label{wxgridsetdefaultcellfont}
1108
deea56b1 1109\func{void}{SetDefaultCellFont}{\param{const wxFont\&}{ font}}
78c49c58
MB
1110
1111Sets the default font to be used for grid cell text.
1112
1113\membersection{wxGrid::SetDefaultEditor}\label{wxgridsetdefaulteditor}
1114
1115\func{void}{SetDefaultEditor}{\param{wxGridCellEditor* }{editor}}
1116
1117Sets the default editor for grid cells. The grid will take ownership of the pointer.
1118
1119See \helpref{wxGridCellEditor}{wxgridcelleditor} and
1120the \helpref{wxGrid overview}{gridoverview} for more information about cell editors and renderers.
1121
1122\membersection{wxGrid::SetDefaultRenderer}\label{wxgridsetdefaultrenderer}
1123
1124\func{void}{SetDefaultRenderer}{\param{wxGridCellRenderer* }{renderer}}
1125
1126Sets the default renderer for grid cells. The grid will take ownership of the pointer.
1127
1128See \helpref{wxGridCellRenderer}{wxgridcellrenderer} and
1129the \helpref{wxGrid overview}{gridoverview} for more information about cell editors and renderers.
1130
1131\membersection{wxGrid::SetDefaultColSize}\label{wxgridsetdefaultcolsize}
c0b042fc 1132
cc81d32f 1133\func{void}{SetDefaultColSize}{\param{int }{width}, \param{bool }{resizeExistingCols = false}}
c0b042fc 1134
78c49c58 1135Sets the default width for columns in the grid. This will only affect columns subsequently added to
cc81d32f 1136the grid unless resizeExistingCols is true.
78c49c58
MB
1137
1138\membersection{wxGrid::SetDefaultRowSize}\label{wxgridsetdefaultrowsize}
1139
cc81d32f 1140\func{void}{SetDefaultRowSize}{\param{int }{height}, \param{bool }{resizeExistingRows = false}}
78c49c58
MB
1141
1142Sets the default height for rows in the grid. This will only affect rows subsequently added
cc81d32f 1143to the grid unless resizeExistingRows is true.
c0b042fc 1144
a660d684
KB
1145\membersection{wxGrid::SetGridCursor}\label{wxgridsetgridcursor}
1146
78c49c58 1147\func{void}{SetGridCursor}{\param{int }{row}, \param{int }{col}}
a660d684 1148
78c49c58
MB
1149Set the grid cursor to the specified cell.
1150This function calls \helpref{wxGrid::MakeCellVisible}{wxgridmakecellvisible}.
a660d684 1151
78c49c58 1152\membersection{wxGrid::SetGridLineColour}\label{wxgridsetgridlinecolour}
a660d684 1153
deea56b1 1154\func{void}{SetGridLineColour}{\param{const wxColour\&}{colour}}
a660d684 1155
78c49c58 1156Sets the colour used to draw grid lines.
a660d684
KB
1157
1158\membersection{wxGrid::SetLabelBackgroundColour}\label{wxgridsetlabelbackgroundcolour}
1159
deea56b1 1160\func{void}{SetLabelBackgroundColour}{\param{const wxColour\&}{ colour}}
a660d684 1161
78c49c58 1162Sets the background colour for row and column labels.
a660d684 1163
78c49c58 1164\membersection{wxGrid::SetLabelFont}\label{wxgridsetlabelfont}
a660d684 1165
deea56b1 1166\func{void}{SetLabelFont}{\param{const wxFont\&}{ font}}
a660d684 1167
78c49c58 1168Sets the font for row and column labels.
a660d684
KB
1169
1170\membersection{wxGrid::SetLabelTextColour}\label{wxgridsetlabeltextcolour}
1171
deea56b1 1172\func{void}{SetLabelTextColour}{\param{const wxColour\&}{ colour}}
a660d684 1173
78c49c58 1174Sets the colour for row and column label text.
a660d684 1175
5c69031c
MB
1176\membersection{wxGrid::SetReadOnly}\label{wxgridsetreadonly}
1177
cc81d32f 1178\func{void}{SetReadOnly}{\param{int }{row}, \param{int }{col}, \param{bool }{isReadOnly = true}}
5c69031c
MB
1179
1180Makes the cell at the specified location read-only or editable.
1181See also \helpref{wxGrid::IsReadOnly}{wxgridisreadonly}.
1182
78c49c58 1183\membersection{wxGrid::SetRowAttr}\label{wxgridsetrowattr}
a660d684 1184
78c49c58 1185\func{void}{SetRowAttr}{\param{int }{row}, \param{wxGridCellAttr* }{attr}}
a660d684 1186
78c49c58
MB
1187Sets the cell attributes for all cells in the specified row.
1188See the \helpref{wxGridCellAttr}{wxgridcellattr} class for more information
1189about controlling cell attributes.
a660d684 1190
78c49c58 1191\membersection{wxGrid::SetRowLabelAlignment}\label{wxgridsetrowlabelalignment}
a660d684 1192
78c49c58 1193\func{void}{SetRowLabelAlignment}{\param{int }{horiz}, \param{int }{vert}}
a660d684 1194
78c49c58 1195Sets the horizontal and vertical alignment of row label text.
a660d684 1196
e7240349 1197Horizontal alignment should be one of wxALIGN\_LEFT, wxALIGN\_CENTRE or wxALIGN\_RIGHT.
deea56b1 1198
e7240349 1199Vertical alignment should be one of wxALIGN\_TOP, wxALIGN\_CENTRE or wxALIGN\_BOTTOM.
a660d684 1200
78c49c58 1201\membersection{wxGrid::SetRowLabelSize}\label{wxgridsetrowlabelsize}
a660d684 1202
78c49c58 1203\func{void}{SetRowLabelSize}{\param{int }{width}}
a660d684 1204
78c49c58
MB
1205Sets the width of the row labels.
1206
1207\membersection{wxGrid::SetRowLabelValue}\label{wxgridsetrowlabelvalue}
1208
deea56b1 1209\func{void}{SetRowLabelValue}{\param{int }{row}, \param{const wxString\&}{ value}}
78c49c58
MB
1210
1211Set the value for the given row label. If you are using a derived grid table you must
deea56b1 1212override \helpref{wxGridTableBase::SetRowLabelValue}{wxgridtablebasesetrowlabelvalue}
78c49c58
MB
1213for this to have any effect.
1214
1215\membersection{wxGrid::SetRowMinimalHeight}\label{wxgridsetrowminimalheight}
1216
1217\func{void}{SetRowMinimalHeight}{\param{int }{row}, \param{int }{width}}
1218
1219Sets the minimal height for the specified row. This should normally be called when creating the grid
1220because it will not resize a row that is already shorter than the minimal height.
1221
1222\membersection{wxGrid::SetRowSize}\label{wxgridsetrowsize}
1223
1224\func{void}{SetRowSize}{\param{int }{row}, \param{int }{height}}
1225
1226Sets the height of the specified row.
1227
1228This function does not refresh the grid. If you are calling it outside of a BeginBatch / EndBatch
1229block you can use \helpref{wxGrid::ForceRefresh}{wxgridforcerefresh} to see the changes.
1230
cc81d32f 1231Automatically sizes the column to fit its contents. If setAsMin is true the calculated width will
78c49c58
MB
1232also be set as the minimal width for the column.
1233
deea56b1
JS
1234\wxheading{Note}
1235
78c49c58
MB
1236wxGrid sets up arrays to store individual row and column sizes when non-default sizes are used.
1237The memory requirements for this could become prohibitive if your grid is very large.
1238
1239\membersection{wxGrid::SetSelectionMode}\label{wxgridsetselectionmode}
1240
deea56b1 1241\func{void}{SetSelectionMode}{\param{wxGrid::wxGridSelectionModes}{ selmode}}
78c49c58
MB
1242
1243Set the selection behaviour of the grid.
1244
1245\wxheading{Parameters}
1246
1247\docparam{wxGrid::wxGridSelectCells}{The default mode where individual cells are selected.}
1248
deea56b1 1249\docparam{wxGrid::wxGridSelectRows}{Selections will consist of whole rows.}
78c49c58
MB
1250
1251\docparam{wxGrid::wxGridSelectionColumns}{Selections will consist of whole columns.}
1252
1253\membersection{wxGrid::SetTable}\label{wxgridsettable}
1254
cc81d32f 1255\func{bool}{SetTable}{\param{wxGridTableBase* }{table}, \param{bool }{takeOwnership = false}, \param{wxGrid::wxGridSelectionModes }{selmode = wxGrid::wxGridSelectCells}}
78c49c58 1256
2eebb742 1257Passes a pointer to a custom grid table to be used by the grid. This should be called
78c49c58 1258after the grid constructor and before using the grid object. If takeOwnership is set to
cc81d32f 1259true then the table will be deleted by the wxGrid destructor.
78c49c58
MB
1260
1261Use this function instead of \helpref{wxGrid::CreateGrid}{wxgridcreategrid} when your
1262application involves complex or non-string data or data sets that are too large to fit
1263wholly in memory.
1264
1265\membersection{wxGrid::ShowCellEditControl}\label{wxgridshowcelleditcontrol}
1266
1267\func{void}{ShowCellEditControl}{\void}
1268
1269Displays the in-place cell edit control for the current cell.
1270
1271\membersection{wxGrid::XToCol}\label{wxgridxtocol}
1272
1273\func{int}{XToCol}{\param{int }{x}}
1274
1275Returns the grid column that corresponds to the logical x coordinate. Returns
e7240349 1276wxNOT\_FOUND if there is no column at the x position.
78c49c58
MB
1277
1278\membersection{wxGrid::XToEdgeOfCol}\label{wxgridxtoedgeofcol}
1279
1280\func{int}{XToEdgeOfCol}{\param{int }{x}}
1281
1282Returns the column whose right hand edge is close to the given logical x position.
e7240349 1283If no column edge is near to this position wxNOT\_FOUND is returned.
78c49c58
MB
1284
1285\membersection{wxGrid::YToEdgeOfRow}\label{wxgridytoedgeofrow}
1286
1287\func{int}{YToEdgeOfRow}{\param{int }{y}}
1288
1289Returns the row whose bottom edge is close to the given logical y position.
e7240349 1290If no row edge is near to this position wxNOT\_FOUND is returned.
78c49c58
MB
1291
1292\membersection{wxGrid::YToRow}\label{wxgridytorow}
1293
1294\func{int}{YToRow}{\param{int }{y}}
1295
1296Returns the grid row that corresponds to the logical y coordinate. Returns
e7240349 1297wxNOT\_FOUND if there is no row at the y position.
78c49c58
MB
1298
1299
78c49c58
MB
1300\membersection{wxGrid::BlockToDeviceRect}\label{wxgridblocktodevicerect}
1301
1302\func{wxRect}{BlockToDeviceRect}{\param{const wxGridCellCoords \& }{topLeft}, \param{const wxGridCellCoords \& }{bottomRight}}
1303
1304This function returns the rectangle that encloses the block of cells
1305limited by TopLeft and BottomRight cell in device coords and clipped
1306to the client size of the grid window.
1307
1308
1309\membersection{wxGrid::SelectionToDeviceRect}\label{wxgridselectiontodevicerect}
1310
1311\func{wxRect}{SelectionToDeviceRect}{\void}
1312
1313This function returns the rectangle that encloses the selected cells
1314in device coords and clipped to the client size of the grid window.
1315
1316
1317\membersection{wxGrid::GetSelectionBackground}\label{wxgridgetselectionbackground}
1318
1319\constfunc{wxColour}{GetSelectionBackground}{\void}
1320
1321Access or update the selection fore/back colours
1322
1323
1324\membersection{wxGrid::GetSelectionForeground}\label{wxgridgetselectionforeground}
1325
1326\constfunc{wxColour}{GetSelectionForeground}{\void}
1327
1328
1329\membersection{wxGrid::SetSelectionBackground}\label{wxgridsetselectionbackground}
1330
1331\func{void}{SetSelectionBackground}{\param{const wxColour\& }{c}}
1332
1333
1334\membersection{wxGrid::SetSelectionForeground}\label{wxgridsetselectionforeground}
1335
1336\func{void}{SetSelectionForeground}{\param{const wxColour\& }{c}}
1337
1338
1339\membersection{wxGrid::RegisterDataType}\label{wxgridregisterdatatype}
1340
1341\func{void}{RegisterDataType}{\param{const wxString\& }{typeName}, \param{wxGridCellRenderer* }{renderer}, \param{wxGridCellEditor* }{editor}}
1342
1343Methods for a registry for mapping data types to Renderers/Editors
1344
78c49c58
MB
1345\membersection{wxGrid::GetDefaultEditorForCell}\label{wxgridgetdefaulteditorforcell}
1346
1347\constfunc{wxGridCellEditor*}{GetDefaultEditorForCell}{\param{int }{row}, \param{int }{col}}
1348
1349\constfunc{wxGridCellEditor*}{GetDefaultEditorForCell}{\param{const wxGridCellCoords\& }{c}}
1350
1351
1352\membersection{wxGrid::GetDefaultRendererForCell}\label{wxgridgetdefaultrendererforcell}
1353
1354\constfunc{wxGridCellRenderer*}{GetDefaultRendererForCell}{\param{int }{row}, \param{int }{col}}
1355
1356
1357\membersection{wxGrid::GetDefaultEditorForType}\label{wxgridgetdefaulteditorfortype}
1358
1359\constfunc{wxGridCellEditor*}{GetDefaultEditorForType}{\param{const wxString\& }{typeName}}
1360
1361
1362\membersection{wxGrid::GetDefaultRendererForType}\label{wxgridgetdefaultrendererfortype}
1363
1364\constfunc{wxGridCellRenderer*}{GetDefaultRendererForType}{\param{const wxString\& }{typeName}}
1365
1366
1367\membersection{wxGrid::SetMargins}\label{wxgridsetmargins}
1368
1369\func{void}{SetMargins}{\param{int }{extraWidth}, \param{int }{extraHeight}}
1370
deea56b1 1371A grid may occupy more space than needed for its rows/columns. This
78c49c58
MB
1372function allows to set how big this extra space is
1373
78c49c58
MB
1374\membersection{wxGrid::wxGrid}\label{wxgridwxgrid}
1375
1376\func{}{wxGrid}{\param{wxWindow* }{parent}, \param{int }{x}, \param{int }{y}, \param{int }{w = -1}, \param{int }{h = -1}, \param{long }{style = wxWANTS\_CHARS}, \param{const wxString\& }{name = wxPanelNameStr}}
1377
2eebb742 1378Backward compatibility.
78c49c58
MB
1379
1380\membersection{wxGrid::UpdateDimensions}\label{wxgridupdatedimensions}
1381
1382\func{void}{UpdateDimensions}{\void}
1383
2eebb742 1384Backward compatibility.
78c49c58
MB
1385
1386\membersection{wxGrid::GetRows}\label{wxgridgetrows}
1387
1388\func{int}{GetRows}{\void}
1389
2eebb742 1390Backward compatibility.
78c49c58
MB
1391
1392\membersection{wxGrid::GetCols}\label{wxgridgetcols}
1393
1394\func{int}{GetCols}{\void}
1395
2eebb742 1396Backward compatibility.
78c49c58
MB
1397
1398\membersection{wxGrid::GetCursorRow}\label{wxgridgetcursorrow}
1399
1400\func{int}{GetCursorRow}{\void}
1401
2eebb742 1402Backward compatibility.
78c49c58
MB
1403
1404\membersection{wxGrid::GetCursorColumn}\label{wxgridgetcursorcolumn}
1405
1406\func{int}{GetCursorColumn}{\void}
1407
2eebb742 1408Backward compatibility.
78c49c58
MB
1409
1410\membersection{wxGrid::GetScrollPosX}\label{wxgridgetscrollposx}
1411
1412\func{int}{GetScrollPosX}{\void}
1413
2eebb742 1414Backward compatibility.
78c49c58
MB
1415
1416\membersection{wxGrid::GetScrollPosY}\label{wxgridgetscrollposy}
1417
1418\func{int}{GetScrollPosY}{\void}
1419
2eebb742 1420Backward compatibility.
78c49c58
MB
1421
1422\membersection{wxGrid::SetScrollX}\label{wxgridsetscrollx}
1423
2eebb742 1424\func{void}{SetScrollX}{\param{int }{x}}
78c49c58 1425
2eebb742 1426Backward compatibility.
78c49c58
MB
1427
1428\membersection{wxGrid::SetScrollY}\label{wxgridsetscrolly}
1429
2eebb742 1430\func{void}{SetScrollY}{\param{int }{y}}
78c49c58 1431
2eebb742 1432Backward compatibility.
78c49c58
MB
1433
1434\membersection{wxGrid::SetColumnWidth}\label{wxgridsetcolumnwidth}
1435
1436\func{void}{SetColumnWidth}{\param{int }{col}, \param{int }{width}}
1437
2eebb742 1438Backward compatibility.
78c49c58
MB
1439
1440\membersection{wxGrid::GetColumnWidth}\label{wxgridgetcolumnwidth}
1441
1442\func{int}{GetColumnWidth}{\param{int }{col}}
1443
2eebb742 1444Backward compatibility.
78c49c58
MB
1445
1446\membersection{wxGrid::SetRowHeight}\label{wxgridsetrowheight}
1447
1448\func{void}{SetRowHeight}{\param{int }{row}, \param{int }{height}}
1449
2eebb742 1450Backward compatibility.
78c49c58
MB
1451
1452\membersection{wxGrid::GetViewHeight}\label{wxgridgetviewheight}
1453
1454\func{int}{GetViewHeight}{\void}
1455
2eebb742 1456Backward compatibility.
78c49c58 1457
78c49c58
MB
1458\membersection{wxGrid::GetViewWidth}\label{wxgridgetviewwidth}
1459
1460\func{int}{GetViewWidth}{\void}
1461
2eebb742 1462Returned number of whole cols visible.
78c49c58
MB
1463
1464\membersection{wxGrid::SetLabelSize}\label{wxgridsetlabelsize}
1465
1466\func{void}{SetLabelSize}{\param{int }{orientation}, \param{int }{sz}}
1467
1468
1469\membersection{wxGrid::GetLabelSize}\label{wxgridgetlabelsize}
1470
1471\func{int}{GetLabelSize}{\param{int }{orientation}}
1472
1473
1474\membersection{wxGrid::SetLabelAlignment}\label{wxgridsetlabelalignment}
1475
1476\func{void}{SetLabelAlignment}{\param{int }{orientation}, \param{int }{align}}
1477
1478
1479\membersection{wxGrid::GetLabelAlignment}\label{wxgridgetlabelalignment}
1480
2eebb742 1481\func{int}{GetLabelAlignment}{\param{int }{orientation}, \param{int }{align}}
78c49c58
MB
1482
1483
1484\membersection{wxGrid::SetLabelValue}\label{wxgridsetlabelvalue}
1485
1486\func{void}{SetLabelValue}{\param{int }{orientation}, \param{const wxString\& }{val}, \param{int }{pos}}
1487
1488
1489\membersection{wxGrid::GetLabelValue}\label{wxgridgetlabelvalue}
1490
1491\func{wxString}{GetLabelValue}{\param{int }{orientation}, \param{int }{pos}}
1492
1493
1494\membersection{wxGrid::GetCellTextFont}\label{wxgridgetcelltextfont}
1495
1496\constfunc{wxFont}{GetCellTextFont}{\void}
1497
2eebb742 1498\constfunc{wxFont}{GetCellTextFont}{\param{int }{row}, \param{int }{col}}
78c49c58
MB
1499
1500
1501\membersection{wxGrid::SetCellTextFont}\label{wxgridsetcelltextfont}
1502
1503\func{void}{SetCellTextFont}{\param{const wxFont\& }{fnt}}
1504
78c49c58
MB
1505\func{void}{SetCellTextFont}{\param{const wxFont\& }{fnt}, \param{int }{row}, \param{int }{col}}
1506
1507
78c49c58
MB
1508\membersection{wxGrid::SetCellBackgroundColour}\label{wxgridsetcellbackgroundcolour}
1509
1510\func{void}{SetCellBackgroundColour}{\param{const wxColour\& }{col}}
1511
deea56b1 1512\func{void}{SetCellBackgroundColour}{\param{int }{row}, \param{int }{col}, \param{const wxColour\&}{ colour}}
78c49c58
MB
1513
1514\func{void}{SetCellBackgroundColour}{\param{const wxColour\& }{colour}, \param{int }{row}, \param{int }{col}}
1515
1516
1517\membersection{wxGrid::GetEditable}\label{wxgridgeteditable}
1518
1519\func{bool}{GetEditable}{\void}
1520
1521
1522\membersection{wxGrid::SetEditable}\label{wxgridseteditable}
1523
cc81d32f 1524\func{void}{SetEditable}{\param{bool }{edit = true}}
78c49c58
MB
1525
1526
1527\membersection{wxGrid::GetEditInPlace}\label{wxgridgeteditinplace}
1528
1529\func{bool}{GetEditInPlace}{\void}
1530
1531
1532\membersection{wxGrid::SetEditInPlace}\label{wxgridseteditinplace}
1533
cc81d32f 1534\func{void}{SetEditInPlace}{\param{bool }{edit = true}}
78c49c58
MB
1535
1536
1537\membersection{wxGrid::SetCellBitmap}\label{wxgridsetcellbitmap}
1538
2eebb742 1539\func{void}{SetCellBitmap}{\param{wxBitmap* }{bitmap}, \param{int }{row}, \param{int }{col}}
78c49c58
MB
1540
1541
1542\membersection{wxGrid::SetDividerPen}\label{wxgridsetdividerpen}
1543
2eebb742 1544\func{void}{SetDividerPen}{\param{const wxPen\& }{pen}}
78c49c58
MB
1545
1546
1547\membersection{wxGrid::GetDividerPen}\label{wxgridgetdividerpen}
1548
1549\constfunc{wxPen\&}{GetDividerPen}{\void}
1550
1551
1552\membersection{wxGrid::OnActivate}\label{wxgridonactivate}
1553
2eebb742 1554\func{void}{OnActivate}{\param{bool }{active}}
78c49c58
MB
1555
1556\membersection{wxGrid::Fit}\label{wxgridfit}
1557
1558\func{void}{Fit}{\void}
1559
2eebb742 1560Overridden wxWindow methods
78c49c58
MB
1561
1562\membersection{wxGrid::DoGetBestSize}\label{wxgriddogetbestsize}
1563
1564\constfunc{wxSize}{DoGetBestSize}{\void}
1565
78c49c58
MB
1566\membersection{wxGrid::InitRowHeights}\label{wxgridinitrowheights}
1567
1568\func{void}{InitRowHeights}{\void}
1569
2eebb742
JS
1570NB: {\it never} access m\_row/col arrays directly because they are created
1571on demand, {\it always} use accessor functions instead!
78c49c58 1572
2eebb742 1573Init the m\_rowHeights/Bottoms arrays with default values.
78c49c58
MB
1574
1575\membersection{wxGrid::InitColWidths}\label{wxgridinitcolwidths}
1576
1577\func{void}{InitColWidths}{\void}
1578
2eebb742 1579Init the m\_colWidths/Rights arrays
78c49c58
MB
1580
1581
1582\membersection{wxGrid::GetColWidth}\label{wxgridgetcolwidth}
1583
1584\constfunc{int}{GetColWidth}{\param{int }{col}}
1585
2eebb742 1586Get the col/row coords
78c49c58
MB
1587
1588
1589\membersection{wxGrid::GetColLeft}\label{wxgridgetcolleft}
1590
1591\constfunc{int}{GetColLeft}{\param{int }{col}}
1592
1593
1594\membersection{wxGrid::GetColRight}\label{wxgridgetcolright}
1595
1596\constfunc{int}{GetColRight}{\param{int }{col}}
1597
1598
1599\membersection{wxGrid::GetRowHeight}\label{wxgridgetrowheight}
1600
1601\constfunc{int}{GetRowHeight}{\param{int }{row}}
1602
2eebb742 1603This function must be public for compatibility.
78c49c58
MB
1604
1605\membersection{wxGrid::GetRowTop}\label{wxgridgetrowtop}
1606
1607\constfunc{int}{GetRowTop}{\param{int }{row}}
1608
1609
1610\membersection{wxGrid::GetRowBottom}\label{wxgridgetrowbottom}
1611
1612\constfunc{int}{GetRowBottom}{\param{int }{row}}
1613
1614
1615\membersection{wxGrid::SetOrCalcColumnSizes}\label{wxgridsetorcalccolumnsizes}
1616
cc81d32f 1617\func{int}{SetOrCalcColumnSizes}{\param{bool }{calcOnly}, \param{bool }{setAsMin = true}}
78c49c58 1618
2eebb742 1619Common part of AutoSizeColumn/Row() and GetBestSize()
78c49c58
MB
1620
1621\membersection{wxGrid::SetOrCalcRowSizes}\label{wxgridsetorcalcrowsizes}
1622
cc81d32f 1623\func{int}{SetOrCalcRowSizes}{\param{bool }{calcOnly}, \param{bool }{setAsMin = true}}
78c49c58 1624
78c49c58
MB
1625\membersection{wxGrid::AutoSizeColOrRow}\label{wxgridautosizecolorrow}
1626
1627\func{void}{AutoSizeColOrRow}{\param{int }{n}, \param{bool }{setAsMin}, \param{bool }{column}}
1628
2eebb742 1629Common part of AutoSizeColumn/Row() or row?
78c49c58
MB
1630
1631\membersection{wxGrid::GetColMinimalWidth}\label{wxgridgetcolminimalwidth}
1632
1633\constfunc{int}{GetColMinimalWidth}{\param{int }{col}}
1634
1635get the minimal width of the given column/row
1636
78c49c58
MB
1637\membersection{wxGrid::GetRowMinimalHeight}\label{wxgridgetrowminimalheight}
1638
1639\constfunc{int}{GetRowMinimalHeight}{\param{int }{col}}
1640
78c49c58
MB
1641\membersection{wxGrid::CanHaveAttributes}\label{wxgridcanhaveattributes}
1642
1643\func{bool}{CanHaveAttributes}{\void}
1644
2eebb742 1645Do we have some place to store attributes in?
a660d684 1646
78c49c58 1647\membersection{wxGrid::GetOrCreateCellAttr}\label{wxgridgetorcreatecellattr}
a660d684 1648
2eebb742 1649\constfunc{wxGridCellAttr*}{GetOrCreateCellAttr}{\param{int }{row}, \param{int }{col}}
deea56b1 1650