2002-01-23 22:10:02 +00:00
|
|
|
\subsection{Cells and Containers}\label{cells}
|
1999-07-10 21:17:24 +00:00
|
|
|
|
|
|
|
This article describes mechanism used by
|
1999-08-05 22:05:15 +00:00
|
|
|
\helpref{wxHtmlWinParser}{wxhtmlwinparser} and
|
|
|
|
\helpref{wxHtmlWindow}{wxhtmlwindow} to parse and display HTML documents.
|
1999-07-10 21:17:24 +00:00
|
|
|
|
|
|
|
\wxheading{Cells}
|
|
|
|
|
|
|
|
You can divide any text (or HTML) into small fragments. Let's call these
|
|
|
|
fragments {\bf cells}. Cell is for example one word, horizontal line, image
|
|
|
|
or any other part of document. Each cell has width and height (except special
|
1999-08-05 22:05:15 +00:00
|
|
|
"magic" cells with zero dimensions - e.g. colour changers or font changers).
|
1999-07-10 21:17:24 +00:00
|
|
|
|
|
|
|
See \helpref{wxHtmlCell}{wxhtmlcell}.
|
|
|
|
|
|
|
|
\wxheading{Containers}
|
|
|
|
|
|
|
|
Container is kind of cell that may contain sub-cells. Its size depends
|
|
|
|
on number and sizes of its sub-cells (and also depends on width of window).
|
|
|
|
|
|
|
|
See \helpref{wxHtmlContainerCell}{wxhtmlcontainercell},
|
|
|
|
\helpref{wxHtmlCell::Layout}{wxhtmlcelllayout}.
|
|
|
|
|
2007-03-13 15:08:30 +00:00
|
|
|
This image shows the cells and containers:
|
1999-12-24 23:40:13 +00:00
|
|
|
\helponly{\image{}{contbox.bmp}}
|
2007-03-13 15:08:30 +00:00
|
|
|
|
1999-07-10 21:17:24 +00:00
|
|
|
\wxheading{Using Containers in Tag Handler}
|
|
|
|
|
1999-08-05 22:05:15 +00:00
|
|
|
\helpref{wxHtmlWinParser}{wxhtmlwinparser} provides a user-friendly way
|
2000-07-15 19:51:35 +00:00
|
|
|
of managing containers. It is based on the idea of opening and closing containers.
|
1999-07-10 21:17:24 +00:00
|
|
|
|
|
|
|
Use \helpref{OpenContainer}{wxhtmlwinparseropencontainer} to open new
|
1999-08-05 22:05:15 +00:00
|
|
|
a container {\it within an already opened container}. This new container is a
|
|
|
|
{\it sub-container} of the old one. (If you want to create a new container with
|
|
|
|
the same depth level you can call {\tt CloseContainer(); OpenContainer();}.)
|
1999-07-10 21:17:24 +00:00
|
|
|
|
2002-06-07 20:15:28 +00:00
|
|
|
Use \helpref{CloseContainer}{wxhtmlwinparserclosecontainer} to close the
|
1999-08-05 22:05:15 +00:00
|
|
|
container. This doesn't create a new container with same depth level but
|
1999-07-10 21:17:24 +00:00
|
|
|
it returns "control" to the parent container.
|
|
|
|
|
|
|
|
See explanation:
|
1999-12-24 23:40:13 +00:00
|
|
|
\helponly{\image{}{cont.bmp}}
|
2007-03-13 15:08:30 +00:00
|
|
|
|
|
|
|
There clearly must be same number of calls to OpenContainer as to
|
|
|
|
CloseContainer.
|
1999-07-10 21:17:24 +00:00
|
|
|
|
|
|
|
\wxheading{Example}
|
|
|
|
|
1999-08-05 22:05:15 +00:00
|
|
|
This code creates a new paragraph (container at same depth level)
|
|
|
|
with "Hello, world!":
|
1999-07-10 21:17:24 +00:00
|
|
|
|
|
|
|
\begin{verbatim}
|
|
|
|
m_WParser -> CloseContainer();
|
|
|
|
c = m_WParser -> OpenContainer();
|
|
|
|
|
2007-03-13 15:08:30 +00:00
|
|
|
m_WParser -> AddText("Hello, ");
|
|
|
|
m_WParser -> AddText("world!");
|
1999-07-10 21:17:24 +00:00
|
|
|
|
|
|
|
m_WParser -> CloseContainer();
|
|
|
|
m_WParser -> OpenContainer();
|
|
|
|
\end{verbatim}
|
|
|
|
|
|
|
|
and here is image of the situation:
|
1999-12-24 23:40:13 +00:00
|
|
|
\helponly{\image{}{hello.bmp}}
|
1999-07-10 21:17:24 +00:00
|
|
|
|
2007-03-13 15:08:30 +00:00
|
|
|
You can see that there was an opened container before the code was executed.
|
|
|
|
We closed it, created our own container, then closed our container and opened
|
1999-07-10 21:17:24 +00:00
|
|
|
new container. The result was that we had {\it same depth level} after
|
1999-08-05 22:05:15 +00:00
|
|
|
executing. This is general rule that should be followed by tag handlers:
|
1999-07-10 21:17:24 +00:00
|
|
|
leave depth level of containers unmodified (in other words, number of
|
|
|
|
OpenContainer and CloseContainer calls should be same within \helpref{HandleTag}{wxhtmltaghandlerhandletag}'s body).
|
|
|
|
|
2007-03-13 15:08:30 +00:00
|
|
|
Notice that it would be usually better to use
|
|
|
|
\helpref{wxHtmlContainerCell::InsertCell}{wxhtmlcontainercellinsertcell} instead
|
|
|
|
of adding text to the parser directly.
|