]> git.saurik.com Git - wxWidgets.git/blame - docs/latex/wx/dataviewrenderer.tex
Added DrawFocusRect to wxRenderer
[wxWidgets.git] / docs / latex / wx / dataviewrenderer.tex
CommitLineData
b6b9d556
RR
1
2\section{\class{wxDataViewRenderer}}\label{wxdataviewrenderer}
3
4
5This class is used by \helpref{wxDataViewCtrl}{wxdataviewctrl} to
6render the individual cells. One instance of a renderer class is
7owned by \helpref{wxDataViewColumn}{wxdataviewcolumn}. There is
8a number of ready-to-use renderers provided:
9\helpref{wxDataViewTextRenderer}{wxdataviewtextrenderer},
10\helpref{wxDataViewToggleRenderer}{wxdataviewtogglerenderer},
11\helpref{wxDataViewProgressRenderer}{wxdataviewprogressrenderer},
12\helpref{wxDataViewBitmapRenderer}{wxdataviewbitmaprenderer},
13\helpref{wxDataViewDateRenderer}{wxdataviewdaterenderer}.
14
b6b9d556
RR
15Additionally, the user can write own renderers by deriving from
16\helpref{wxDataViewCustomRenderer}{wxdataviewcustomrenderer}.
17
305c49a1 18The {\it wxDataViewCellMode} flag controls, what actions
befba9e4 19the cell data allows. {\it wxDATAVIEW\_CELL\_ACTIVATABLE}
305c49a1
RR
20indicates that the user can double click the cell and
21something will happen (e.g. a window for editing a date
befba9e4 22will pop up). {\it wxDATAVIEW\_CELL\_EDITABLE} indicates
305c49a1
RR
23that the user can edit the data in-place, i.e. an control
24will show up after a slow click on the cell. This behaviour
25is best known from changing the filename in most file
26managers etc.
27
28
b6b9d556
RR
29
30{\small
31\begin{verbatim}
32enum wxDataViewCellMode
33{
34 wxDATAVIEW_CELL_INERT,
35 wxDATAVIEW_CELL_ACTIVATABLE,
36 wxDATAVIEW_CELL_EDITABLE
37};
305c49a1
RR
38\end{verbatim}
39}
40
41The {\it wxDataViewCellRenderState} flag controls how the
42the renderer should display its contents in a cell:
b6b9d556 43
305c49a1
RR
44{\small
45\begin{verbatim}
b6b9d556
RR
46enum wxDataViewCellRenderState
47{
48 wxDATAVIEW_CELL_SELECTED = 1,
49 wxDATAVIEW_CELL_PRELIT = 2,
50 wxDATAVIEW_CELL_INSENSITIVE = 4,
51 wxDATAVIEW_CELL_FOCUSED = 8
52};
53\end{verbatim}
54}
55
56
57\wxheading{Derived from}
58
59\helpref{wxObject}{wxobject}
60
61\wxheading{Include files}
62
63<wx/dataview.h>
64
a7af285d
VZ
65\wxheading{Library}
66
67\helpref{wxAdv}{librarieslist}
68
b6b9d556
RR
69
70\membersection{wxDataViewRenderer::wxDataViewRenderer}\label{wxdataviewrendererwxdataviewrenderer}
71
72\func{}{wxDataViewRenderer}{\param{const wxString\& }{varianttype}, \param{wxDataViewCellMode }{mode = wxDATAVIEW\_CELL\_INERT}}
73
74Constructor.
75
76\membersection{wxDataViewRenderer::GetMode}\label{wxdataviewrenderergetmode}
77
78\func{virtual wxDataViewCellMode}{GetMode}{\void}
79
80Returns the cell mode.
81
82\membersection{wxDataViewRenderer::GetOwner}\label{wxdataviewrenderergetowner}
83
84\func{virtual wxDataViewColumn*}{GetOwner}{\void}
85
86Returns pointer to the owning \helpref{wxDataViewColumn}{wxdataviewcolumn}.
87
88\membersection{wxDataViewRenderer::GetValue}\label{wxdataviewrenderergetvalue}
89
90\func{virtual bool}{GetValue}{\param{wxVariant\& }{value}}
91
92This methods retrieves the value from the renderer in order to
93transfer the value back to the data model. Returns {\it false}
94on failure.
95
96\membersection{wxDataViewRenderer::GetVariantType}\label{wxdataviewrenderergetvarianttype}
97
98\func{virtual wxString}{GetVariantType}{\void}
99
100Returns a string with the type of the \helpref{wxVariant}{wxvariant}
101supported by this renderer.
102
103\membersection{wxDataViewRenderer::SetOwner}\label{wxdataviewrenderersetowner}
104
105\func{virtual void}{SetOwner}{\param{wxDataViewColumn* }{owner}}
106
107Sets the owning \helpref{wxDataViewColumn}{wxdataviewcolumn}. This
108is usually called from within wxDataViewColumn.
109
110\membersection{wxDataViewRenderer::SetValue}\label{wxdataviewrenderersetvalue}
111
112\func{virtual bool}{SetValue}{\param{const wxVariant\& }{value}}
113
114Set the value of the renderer (and thus its cell) to {\it value}.
115The internal code will then render this cell with this data.
116
117
118\membersection{wxDataViewRenderer::Validate}\label{wxdataviewrenderervalidate}
119
120\func{virtual bool}{Validate}{\param{wxVariant\& }{value}}
121
305c49a1
RR
122Before data is committed to the data model, it is passed to this
123method where it can be checked for validity. This can also be
124used for checking a valid range or limiting the user input in
125a certain aspect (e.g. max number of characters or only alphanumeric
126input, ASCII only etc.). Return {\it false} if the value is
127not valid.
128
129Please note that due to implementation limitations, this validation
130is done after the editing control already is destroyed and the
131editing process finished.
b6b9d556
RR
132
133
134\section{\class{wxDataViewTextRenderer}}\label{wxdataviewtextrenderer}
135
305c49a1
RR
136wxDataViewTextRenderer is used for rendering text. It supports
137in-place editing if desired.
b6b9d556
RR
138
139
140\wxheading{Derived from}
141
7376079d
VZ
142\helpref{wxDataViewRenderer}{wxdataviewrenderer}\\
143\helpref{wxObject}{wxobject}
b6b9d556
RR
144
145\wxheading{Include files}
146
147<wx/dataview.h>
148
a7af285d
VZ
149\wxheading{Library}
150
151\helpref{wxAdv}{librarieslist}
152
b6b9d556
RR
153
154\membersection{wxDataViewTextRenderer::wxDataViewTextRenderer}\label{wxdataviewtextrendererwxdataviewtextrenderer}
155
156\func{}{wxDataViewTextRenderer}{\param{const wxString\& }{varianttype = wxT("string")}, \param{wxDataViewCellMode }{mode = wxDATAVIEW\_CELL\_INERT}}
157
158
159
160\section{\class{wxDataViewProgressRenderer}}\label{wxdataviewprogressrenderer}
161
162wxDataViewProgressRenderer
163
164
165\wxheading{Derived from}
166
7376079d
VZ
167\helpref{wxDataViewRenderer}{wxdataviewrenderer}\\
168\helpref{wxObject}{wxobject}
b6b9d556
RR
169
170\wxheading{Include files}
171
172<wx/dataview.h>
173
a7af285d
VZ
174\wxheading{Library}
175
176\helpref{wxAdv}{librarieslist}
177
b6b9d556
RR
178
179\membersection{wxDataViewProgressRenderer::wxDataViewProgressRenderer}\label{wxdataviewprogressrendererwxdataviewprogressrenderer}
180
181\func{}{wxDataViewProgressRenderer}{\param{const wxString\& }{label = wxEmptyString}, \param{const wxString\& }{varianttype = wxT("long")}, \param{wxDataViewCellMode }{mode = wxDATAVIEW\_CELL\_INERT}}
182
183
184
185\section{\class{wxDataViewToggleRenderer}}\label{wxdataviewtogglerenderer}
186
187wxDataViewToggleRenderer
188
189\wxheading{Derived from}
190
7376079d
VZ
191\helpref{wxDataViewRenderer}{wxdataviewrenderer}\\
192\helpref{wxObject}{wxobject}
b6b9d556
RR
193
194\wxheading{Include files}
195
196<wx/dataview.h>
197
a7af285d
VZ
198\wxheading{Library}
199
200\helpref{wxAdv}{librarieslist}
201
b6b9d556
RR
202
203\membersection{wxDataViewToggleRenderer::wxDataViewToggleRenderer}\label{wxdataviewtogglerendererwxdataviewtogglerenderer}
204
205\func{}{wxDataViewToggleRenderer}{\param{const wxString\& }{varianttype = wxT("bool")}, \param{wxDataViewCellMode }{mode = wxDATAVIEW\_CELL\_INERT}}
206
207
208\section{\class{wxDataViewBitmapRenderer}}\label{wxdataviewbitmaprenderer}
209
210wxDataViewBitmapRenderer
211
212\wxheading{Derived from}
213
7376079d
VZ
214\helpref{wxDataViewRenderer}{wxdataviewrenderer}\\
215\helpref{wxObject}{wxobject}
b6b9d556
RR
216
217\wxheading{Include files}
218
219<wx/dataview.h>
220
a7af285d
VZ
221\wxheading{Library}
222
223\helpref{wxAdv}{librarieslist}
224
b6b9d556
RR
225
226\membersection{wxDataViewBitmapRenderer::wxDataViewBitmapRenderer}\label{wxdataviewbitmaprendererwxdataviewbitmaprenderer}
227
228\func{}{wxDataViewBitmapRenderer}{\param{const wxString\& }{varianttype = wxT("wxBitmap")}, \param{wxDataViewCellMode }{mode = wxDATAVIEW\_CELL\_INERT}}
229
230
231\section{\class{wxDataViewDateRenderer}}\label{wxdataviewdaterenderer}
232
233wxDataViewDateRenderer
234
235
236\wxheading{Derived from}
237
7376079d
VZ
238\helpref{wxDataViewRenderer}{wxdataviewrenderer}\\
239\helpref{wxObject}{wxobject}
b6b9d556
RR
240
241\wxheading{Include files}
242
243<wx/dataview.h>
244
a7af285d
VZ
245\wxheading{Library}
246
247\helpref{wxAdv}{librarieslist}
248
b6b9d556
RR
249\membersection{wxDataViewDateRenderer::wxDataViewDateRenderer}\label{wxdataviewdaterendererwxdataviewdaterenderer}
250
251\func{}{wxDataViewDateRenderer}{\param{const wxString\& }{varianttype = wxT("datetime")}, \param{wxDataViewCellMode }{mode = wxDATAVIEW\_CELL\_ACTIVATABLE}}
252
253
254\section{\class{wxDataViewCustomRenderer}}\label{wxdataviewcustomrenderer}
255
81a22037
RR
256You need to derive a new class from wxDataViewCustomRenderer in
257order to write a new renderer. You need to override at least
258\helpref{SetValue}{wxdataviewrenderersetvalue},
305c49a1
RR
259\helpref{GetValue}{wxdataviewrenderergetvalue},
260\helpref{GetSize}{wxdataviewcustomrenderergetsize}
261and \helpref{Render}{wxdataviewcustomrendererrender}.
262
81a22037
RR
263If you want your renderer to support in-place editing then you
264also need to override
305c49a1
RR
265\helpref{HasEditorCtrl}{wxdataviewcustomrendererhaseditorctrl},
266\helpref{CreateEditorCtrl}{wxdataviewcustomrenderercreateeditorctrl}
267and \helpref{GetValueFromEditorCtrl}{wxdataviewcustomrenderergetvaluefromeditorctrl}.
268Note that a special event handler will be pushed onto that
269editor control which handles <ENTER> and focus out events
270in order to end the editing.
b6b9d556
RR
271
272\wxheading{Derived from}
273
7376079d
VZ
274\helpref{wxDataViewRenderer}{wxdataviewrenderer}\\
275\helpref{wxObject}{wxobject}
b6b9d556
RR
276
277\wxheading{Include files}
278
279<wx/dataview.h>
280
a7af285d
VZ
281\wxheading{Library}
282
283\helpref{wxAdv}{librarieslist}
284
b6b9d556
RR
285\membersection{wxDataViewCustomRenderer::wxDataViewCustomRenderer}\label{wxdataviewcustomrendererwxdataviewcustomrenderer}
286
287\func{}{wxDataViewCustomRenderer}{\param{const wxString\& }{varianttype = wxT("string")}, \param{wxDataViewCellMode }{mode = wxDATAVIEW\_CELL\_INERT}, \param{bool }{no\_init = false}}
288
289Constructor.
290
291\membersection{wxDataViewCustomRenderer::\destruct{wxDataViewCustomRenderer}}\label{wxdataviewcustomrendererdtor}
292
293\func{}{\destruct{wxDataViewCustomRenderer}}{\void}
294
295Destructor.
296
305c49a1
RR
297
298\membersection{wxDataViewCustomRenderer::HasEditorCtrl}\label{wxdataviewcustomrendererhaseditorctrl}
299
300\func{virtual bool}{HasEditorCtrl}{\void}
301
302Override this and make it return {\it true} in order to
303indicate that this renderer supports in-place editing.
304
305\membersection{wxDataViewCustomRenderer::CreateEditorCtrl}\label{wxdataviewcustomrenderercreateeditorctrl}
306
befba9e4 307\func{virtual wxControl*}{CreateEditorCtrl}{\param{wxWindow *}{parent}, \param{wxRect }{labelRect}, \param{const wxVariant \& }{value}}
305c49a1
RR
308
309Override this to create the actual editor control once editing
310is about to start. {\it parent} is the parent of the editor
311control, {\it labelRect} indicates the position and
312size of the editor control and {\it value} is its initial value:
313
314{\small
315\begin{verbatim}
316{
317 long l = value;
318 return new wxSpinCtrl( parent, wxID_ANY, wxEmptyString,
319 labelRect.GetTopLeft(), labelRect.GetSize(), 0, 0, 100, l );
320}
321\end{verbatim}
322}
323
324\membersection{wxDataViewCustomRenderer::GetValueFromEditorCtrl}\label{wxdataviewcustomrenderergetvaluefromeditorctrl}
325
7a4523c8 326\func{virtual bool}{GetValueFromEditorCtrl}{\param{wxControl* }{editor}, \param{wxVariant \& }{value}}
305c49a1
RR
327
328Overrride this so that the renderer can get the value
329from the editor control (pointed to by {\it editor}):
330
331{\small
332\begin{verbatim}
333{
334 wxSpinCtrl *sc = (wxSpinCtrl*) editor;
335 long l = sc->GetValue();
336 value = l;
337 return true;
338}
339\end{verbatim}
340}
341
b6b9d556
RR
342\membersection{wxDataViewCustomRenderer::Activate}\label{wxdataviewcustomrendereractivate}
343
344\func{virtual bool}{Activate}{\param{wxRect }{cell}, \param{wxDataViewListModel* }{model}, \param{unsigned int }{col}, \param{unsigned int }{row}}
345
346Override this to react to double clicks or <ENTER>.
347
348\membersection{wxDataViewCustomRenderer::GetDC}\label{wxdataviewcustomrenderergetdc}
349
350\func{virtual wxDC*}{GetDC}{\void}
351
352Create DC on request. Internal.
353
354
355\membersection{wxDataViewCustomRenderer::GetSize}\label{wxdataviewcustomrenderergetsize}
356
357\func{virtual wxSize}{GetSize}{\void}
358
359Return size required to show content.
360
361
362\membersection{wxDataViewCustomRenderer::LeftClick}\label{wxdataviewcustomrendererleftclick}
363
364\func{virtual bool}{LeftClick}{\param{wxPoint }{cursor}, \param{wxRect }{cell}, \param{wxDataViewListModel* }{model}, \param{unsigned int }{col}, \param{unsigned int }{row}}
365
366Overrride this to react to a left click.
367
368\membersection{wxDataViewCustomRenderer::Render}\label{wxdataviewcustomrendererrender}
369
370\func{virtual bool}{Render}{\param{wxRect }{cell}, \param{wxDC* }{dc}, \param{int }{state}}
371
372Override this to render the cell. Before this is called,
373\helpref{SetValue}{wxdataviewrenderersetvalue} was called
374so that this instance knows what to render.
375
376\membersection{wxDataViewCustomRenderer::RightClick}\label{wxdataviewcustomrendererrightclick}
377
378\func{virtual bool}{RightClick}{\param{wxPoint }{cursor}, \param{wxRect }{cell}, \param{wxDataViewListModel* }{model}, \param{unsigned int }{col}, \param{unsigned int }{row}}
379
380Overrride this to react to a right click.
381
382\membersection{wxDataViewCustomRenderer::StartDrag}\label{wxdataviewcustomrendererstartdrag}
383
384\func{virtual bool}{StartDrag}{\param{wxPoint }{cursor}, \param{wxRect }{cell}, \param{wxDataViewListModel* }{model}, \param{unsigned int }{col}, \param{unsigned int }{row}}
385
386Overrride this to start a drag operation.
387
388
389