]> git.saurik.com Git - wxWidgets.git/blame_incremental - docs/latex/wx/htcell.tex
define _HPUX_SOURCE under HP-UX, otherwise many things are not defined in standard...
[wxWidgets.git] / docs / latex / wx / htcell.tex
... / ...
CommitLineData
1%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
2%% Name: htcell.tex
3%% Purpose: wxHtmlCell documentation
4%% Author: wxWidgets Team
5%% Modified by:
6%% Created: 21/Mar/99 22:45:23
7%% RCS-ID: $Id$
8%% Copyright: (c) wxWidgets Team
9%% License: wxWindows license
10%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
11
12\section{\class{wxHtmlCell}}\label{wxhtmlcell}
13
14Internal data structure. It represents fragments of parsed HTML
15page, the so-called {\bf cell} - a word, picture, table, horizontal line and so on.
16It is used by \helpref{wxHtmlWindow}{wxhtmlwindow} and
17\helpref{wxHtmlWinParser}{wxhtmlwinparser} to represent HTML page in memory.
18
19You can divide cells into two groups : {\it visible} cells with non-zero width and
20height and {\it helper} cells (usually with zero width and height) that
21perform special actions such as color or font change.
22
23\wxheading{Derived from}
24
25\helpref{wxObject}{wxobject}
26
27\wxheading{Include files}
28
29<wx/html/htmlcell.h>
30
31\wxheading{See Also}
32
33\helpref{Cells Overview}{cells},
34\helpref{wxHtmlContainerCell}{wxhtmlcontainercell}
35
36\latexignore{\rtfignore{\wxheading{Members}}}
37
38\membersection{wxHtmlCell::wxHtmlCell}\label{wxhtmlcellwxhtmlcell}
39
40\func{}{wxHtmlCell}{\void}
41
42Constructor.
43
44\membersection{wxHtmlCell::AdjustPagebreak}\label{wxhtmlcelladjustpagebreak}
45
46\func{virtual bool}{AdjustPagebreak}{\param{int * }{pagebreak}}
47
48This method is used to adjust pagebreak position. The parameter is
49variable that contains y-coordinate of page break (= horizontal line that
50should not be crossed by words, images etc.). If this cell cannot be divided
51into two pieces (each one on another page) then it moves the pagebreak
52few pixels up.
53
54Returns true if pagebreak was modified, false otherwise
55
56Usage:
57\begin{verbatim}
58while (container->AdjustPagebreak(&p)) {}
59\end{verbatim}
60
61\membersection{wxHtmlCell::Draw}\label{wxhtmlcelldraw}
62
63\func{virtual void}{Draw}{\param{wxDC\& }{dc}, \param{int }{x}, \param{int }{y}, \param{int }{view\_y1}, \param{int }{view\_y2}}
64
65Renders the cell.
66
67\wxheading{Parameters}
68
69\docparam{dc}{Device context to which the cell is to be drawn}
70
71\docparam{x,y}{Coordinates of parent's upper left corner (origin). You must
72add this to m\_PosX,m\_PosY when passing coordinates to dc's methods
73Example : {\tt dc -> DrawText("hello", x + m\_PosX, y + m\_PosY)}}
74
75\docparam{view\_y1}{y-coord of the first line visible in window. This is
76used to optimize rendering speed}
77
78\docparam{view\_y2}{y-coord of the last line visible in window. This is
79used to optimize rendering speed}
80
81\membersection{wxHtmlCell::DrawInvisible}\label{wxhtmlcelldrawinvisible}
82
83\func{virtual void}{DrawInvisible}{\param{wxDC\& }{dc}, \param{int }{x}, \param{int }{y}}
84
85This method is called instead of \helpref{Draw}{wxhtmlcelldraw} when the
86cell is certainly out of the screen (and thus invisible). This is not
87nonsense - some tags (like \helpref{wxHtmlColourCell}{wxhtmlcolourcell}
88or font setter) must be drawn even if they are invisible!
89
90\wxheading{Parameters}
91
92\docparam{dc}{Device context to which the cell is to be drawn}
93
94\docparam{x,y}{Coordinates of parent's upper left corner. You must
95add this to m\_PosX,m\_PosY when passing coordinates to dc's methods
96Example : {\tt dc -> DrawText("hello", x + m\_PosX, y + m\_PosY)}}
97
98\membersection{wxHtmlCell::Find}\label{wxhtmlcellfind}
99
100\func{virtual const wxHtmlCell*}{Find}{\param{int }{condition}, \param{const void* }{param}}
101
102Returns pointer to itself if this cell matches condition (or if any of the cells
103following in the list matches), NULL otherwise.
104(In other words if you call top-level container's Find it will
105return pointer to the first cell that matches the condition)
106
107It is recommended way how to obtain pointer to particular cell or
108to cell of some type (e.g. wxHtmlAnchorCell reacts on
109wxHTML\_COND\_ISANCHOR condition)
110
111\wxheading{Parameters}
112
113\docparam{condition}{Unique integer identifier of condition}
114
115\docparam{param}{Optional parameters}
116
117\wxheading{Defined conditions}
118
119\begin{twocollist}\itemsep=0pt
120\twocolitem{{\bf wxHTML\_COND\_ISANCHOR}}{Finds particular anchor.
121{\it param} is pointer to wxString with name of the anchor.}
122\twocolitem{{\bf wxHTML\_COND\_USER}}{User-defined conditions start
123from this number.}
124\end{twocollist}
125
126\membersection{wxHtmlCell::GetDescent}\label{wxhtmlcellgetdescent}
127
128\constfunc{int}{GetDescent}{\void}
129
130Returns descent value of the cell (m\_Descent member).
131\helponly{See explanation:
132
133\image{}{descent.bmp}
134}
135
136\membersection{wxHtmlCell::GetFirstChild}\label{wxhtmlcellgetfirstchild}
137
138\func{wxHtmlCell*}{GetFirstChild}{\void}
139
140Returns pointer to the first cell in the list.
141You can then use child's \helpref{GetNext}{wxhtmlcellgetnext}
142method to obtain pointer to the next cell in list.
143
144{\bf Note:} This shouldn't be used by the end user. If you need some way of
145finding particular cell in the list, try \helpref{Find}{wxhtmlcellfind} method
146instead.
147
148\membersection{wxHtmlCell::GetHeight}\label{wxhtmlcellgetheight}
149
150\constfunc{int}{GetHeight}{\void}
151
152Returns height of the cell (m\_Height member).
153
154\membersection{wxHtmlCell::GetId}\label{wxhtmlcellgetid}
155
156\constfunc{virtual wxString}{GetId}{\void}
157
158Returns unique cell identifier if there is any, empty string otherwise.
159
160\membersection{wxHtmlCell::GetLink}\label{wxhtmlcellgetlink}
161
162\constfunc{virtual wxHtmlLinkInfo*}{GetLink}{\param{int }{x = 0}, \param{int }{y = 0}}
163
164Returns hypertext link if associated with this cell or NULL otherwise.
165See \helpref{wxHtmlLinkInfo}{wxhtmllinkinfo}.
166(Note: this makes sense only for visible tags).
167
168\wxheading{Parameters}
169
170\docparam{x,y}{Coordinates of position where the user pressed mouse button.
171These coordinates are used e.g. by COLORMAP. Values are relative to the
172upper left corner of THIS cell (i.e. from 0 to m\_Width or m\_Height)}
173
174\membersection{wxHtmlCell::GetNext}\label{wxhtmlcellgetnext}
175
176\constfunc{wxHtmlCell*}{GetNext}{\void}
177
178Returns pointer to the next cell in list (see htmlcell.h if you're
179interested in details).
180
181\membersection{wxHtmlCell::GetParent}\label{wxhtmlcellgetparent}
182
183\constfunc{wxHtmlContainerCell*}{GetParent}{\void}
184
185Returns pointer to parent container.
186
187\membersection{wxHtmlCell::GetPosX}\label{wxhtmlcellgetposx}
188
189\constfunc{int}{GetPosX}{\void}
190
191Returns X position within parent (the value is relative to parent's
192upper left corner). The returned value is meaningful only if
193parent's \helpref{Layout}{wxhtmlcelllayout} was called before!
194
195\membersection{wxHtmlCell::GetPosY}\label{wxhtmlcellgetposy}
196
197\constfunc{int}{GetPosY}{\void}
198
199Returns Y position within parent (the value is relative to parent's
200upper left corner). The returned value is meaningful only if
201parent's \helpref{Layout}{wxhtmlcelllayout} was called before!
202
203\membersection{wxHtmlCell::GetWidth}\label{wxhtmlcellgetwidth}
204
205\constfunc{int}{GetWidth}{\void}
206
207Returns width of the cell (m\_Width member).
208
209\membersection{wxHtmlCell::Layout}\label{wxhtmlcelllayout}
210
211\func{virtual void}{Layout}{\param{int }{w}}
212
213This method performs two actions:
214
215\begin{enumerate}\itemsep=0pt
216\item adjusts the cell's width according to the fact that maximal possible width is {\it w}.
217(this has sense when working with horizontal lines, tables etc.)
218\item prepares layout (=fill-in m\_PosX, m\_PosY (and sometimes m\_Height) members)
219based on actual width {\it w}
220\end{enumerate}
221
222It must be called before displaying cells structure because
223m\_PosX and m\_PosY are undefined (or invalid)
224before calling Layout.
225
226\membersection{wxHtmlCell::OnMouseClick}\label{wxhtmlcellonmouseclick}
227
228\func{virtual void}{OnMouseClick}{\param{wxWindow* }{parent}, \param{int}{x}, \param{int }{y}, \param{const wxMouseEvent\& }{event}}
229
230This function is simple event handler. Each time the user clicks mouse button over a cell
231within \helpref{wxHtmlWindow}{wxhtmlwindow} this method of that cell is called. Default behavior is
232that it calls \helpref{wxHtmlWindow::LoadPage}{wxhtmlwindowloadpage}.
233
234\wxheading{Note}
235
236If you need more "advanced" event handling
237you should use wxHtmlBinderCell instead.
238
239\wxheading{Parameters}
240
241\docparam{parent}{parent window (always wxHtmlWindow!)}
242
243\docparam{x, y}{coordinates of mouse click (this is relative to cell's origin}
244
245\docparam{left, middle, right}{boolean flags for mouse buttons. true if the left/middle/right
246button is pressed, false otherwise}
247
248\membersection{wxHtmlCell::SetId}\label{wxhtmlcellsetid}
249
250\func{void}{SetId}{\param{const wxString\& }{id}}
251
252Sets unique cell identifier. Default value is no identifier, i.e. empty string.
253
254\membersection{wxHtmlCell::SetLink}\label{wxhtmlcellsetlink}
255
256\func{void}{SetLink}{\param{const wxHtmlLinkInfo\& }{link}}
257
258Sets the hypertext link associated with this cell. (Default value
259is \helpref{wxHtmlLinkInfo}{wxhtmllinkinfo}("", "") (no link))
260
261\membersection{wxHtmlCell::SetNext}\label{wxhtmlcellsetnext}
262
263\func{void}{SetNext}{\param{wxHtmlCell }{*cell}}
264
265Sets the next cell in the list. This shouldn't be called by user - it is
266to be used only by \helpref{wxHtmlContainerCell::InsertCell}{wxhtmlcontainercellinsertcell}.
267
268\membersection{wxHtmlCell::SetParent}\label{wxhtmlcellsetparent}
269
270\func{void}{SetParent}{\param{wxHtmlContainerCell }{*p}}
271
272Sets parent container of this cell. This is called from
273\helpref{wxHtmlContainerCell::InsertCell}{wxhtmlcontainercellinsertcell}.
274
275\membersection{wxHtmlCell::SetPos}\label{wxhtmlcellsetpos}
276
277\func{void}{SetPos}{\param{int }{x}, \param{int }{y}}
278
279Sets the cell's position within parent container.
280