]> git.saurik.com Git - wxWidgets.git/blame - interface/wx/html/winpars.h
avoid GTK+ prefixes for our tree entry code, it is not part of GTK+
[wxWidgets.git] / interface / wx / html / winpars.h
CommitLineData
23324ae1
FM
1/////////////////////////////////////////////////////////////////////////////
2// Name: html/winpars.h
e54c96f1 3// Purpose: interface of wxHtmlTagsModule
23324ae1
FM
4// Author: wxWidgets team
5// RCS-ID: $Id$
526954c5 6// Licence: wxWindows licence
23324ae1
FM
7/////////////////////////////////////////////////////////////////////////////
8
9/**
10 @class wxHtmlTagsModule
7c913512 11
23324ae1
FM
12 This class provides easy way of filling wxHtmlWinParser's table of
13 tag handlers. It is used almost exclusively together with the set of
5bddd46d 14 @ref overview_html_handlers "TAGS_MODULE_* macros"
7c913512 15
23324ae1 16 @library{wxhtml}
5bddd46d 17 @category{html}
7c913512 18
5bddd46d 19 @see @ref overview_html_handlers, wxHtmlTagHandler, wxHtmlWinTagHandler
23324ae1
FM
20*/
21class wxHtmlTagsModule : public wxModule
22{
23public:
24 /**
25 You must override this method. In most common case its body consists
26 only of lines of the following type:
5bddd46d
FM
27 @code
28 parser -> AddTagHandler(new MyHandler);
29 @endcode
30
31 It's recommended to use the @b TAGS_MODULE_* macros.
32
7c913512 33 @param parser
4cc4bfaf 34 Pointer to the parser that requested tables filling.
23324ae1 35 */
5bddd46d 36 virtual void FillHandlersTable(wxHtmlWinParser* parser);
23324ae1
FM
37};
38
39
e54c96f1 40
23324ae1
FM
41/**
42 @class wxHtmlWinTagHandler
7c913512 43
5bddd46d
FM
44 This is basically wxHtmlTagHandler except that it is extended with protected
45 member m_WParser pointing to the wxHtmlWinParser object (value of this member
46 is identical to wxHtmlParser's m_Parser).
7c913512 47
23324ae1
FM
48 @library{wxhtml}
49 @category{html}
50*/
51class wxHtmlWinTagHandler : public wxHtmlTagHandler
52{
047ea2e2 53public:
c0d87687
RD
54 /**
55 Constructor.
56 */
57 wxHtmlWinTagHandler();
3f7564f2 58
047ea2e2
RD
59 /**
60 Assigns @a parser to this handler. Each @b instance of handler
61 is guaranteed to be called only from the one parser.
62 */
63 virtual void SetParser(wxHtmlWinParser* parser);
64
5bddd46d 65protected:
23324ae1 66 /**
5bddd46d
FM
67 Value of this attribute is identical to value of m_Parser.
68 The only difference is that m_WParser points to wxHtmlWinParser object
69 while m_Parser points to wxHtmlParser object. (The same object, but overcast.)
23324ae1 70 */
5bddd46d 71 wxHtmlWinParser* m_WParser;
23324ae1
FM
72};
73
74
e54c96f1 75
23324ae1
FM
76/**
77 @class wxHtmlWinParser
7c913512 78
5bddd46d
FM
79 This class is derived from wxHtmlParser and its main goal is to parse HTML
80 input so that it can be displayed in wxHtmlWindow.
81 It uses a special wxHtmlWinTagHandler.
82
83 @note The product of parsing is a wxHtmlCell (resp. wxHtmlContainer) object.
7c913512 84
23324ae1
FM
85 @library{wxhtml}
86 @category{html}
7c913512 87
5bddd46d 88 @see @ref overview_html_handlers
23324ae1
FM
89*/
90class wxHtmlWinParser : public wxHtmlParser
91{
92public:
23324ae1 93 /**
5bddd46d
FM
94 Constructor.
95
50ec54b6 96 Don't use the default one, use the constructor with @a wndIface parameter
5bddd46d
FM
97 (@a wndIface is a pointer to interface object for the associated wxHtmlWindow
98 or other HTML rendering window such as wxHtmlListBox).
23324ae1 99 */
50ec54b6 100 wxHtmlWinParser(wxHtmlWindowInterface* wndIface = NULL);
23324ae1
FM
101
102 /**
e54c96f1 103 Adds module() to the list of wxHtmlWinParser tag handler.
23324ae1 104 */
382f12e4 105 static void AddModule(wxHtmlTagsModule* module);
23324ae1
FM
106
107 /**
108 Closes the container, sets actual container to the parent one
5bddd46d 109 and returns pointer to it (see @ref overview_html_cells).
23324ae1
FM
110 */
111 wxHtmlContainerCell* CloseContainer();
112
113 /**
5bddd46d
FM
114 Creates font based on current setting (see SetFontSize(), SetFontBold(),
115 SetFontItalic(), SetFontFixed(), wxHtmlWinParser::SetFontUnderlined)
23324ae1 116 and returns pointer to it.
5bddd46d 117
23324ae1
FM
118 If the font was already created only a pointer is returned.
119 */
120 virtual wxFont* CreateCurrentFont();
121
122 /**
123 Returns actual text colour.
124 */
95b4a59e 125 const wxColour& GetActualColor() const;
23324ae1
FM
126
127 /**
128 Returns default horizontal alignment.
129 */
328f5751 130 int GetAlign() const;
23324ae1
FM
131
132 /**
5bddd46d
FM
133 Returns (average) char height in standard font.
134 It is used as DC-independent metrics.
135
cdbcf4c2 136 @note This function doesn't return the @e actual height. If you want to
5bddd46d 137 know the height of the current font, call @c GetDC->GetCharHeight().
23324ae1 138 */
328f5751 139 int GetCharHeight() const;
23324ae1
FM
140
141 /**
5bddd46d
FM
142 Returns average char width in standard font.
143 It is used as DC-independent metrics.
144
cdbcf4c2 145 @note This function doesn't return the @e actual width. If you want to
5bddd46d 146 know the height of the current font, call @c GetDC->GetCharWidth().
23324ae1 147 */
328f5751 148 int GetCharWidth() const;
23324ae1
FM
149
150 /**
5bddd46d 151 Returns pointer to the currently opened container (see @ref overview_html_cells).
23324ae1 152 Common use:
5bddd46d
FM
153 @code
154 m_WParser -> GetContainer() -> InsertCell(new ...);
155 @endcode
23324ae1 156 */
328f5751 157 wxHtmlContainerCell* GetContainer() const;
23324ae1
FM
158
159 /**
160 Returns pointer to the DC used during parsing.
161 */
4cc4bfaf 162 wxDC* GetDC();
23324ae1
FM
163
164 /**
5bddd46d
FM
165 Returns wxEncodingConverter class used to do conversion between the
166 @ref GetInputEncoding() "input encoding" and the
167 @ref GetOutputEncoding() "output encoding".
23324ae1 168 */
328f5751 169 wxEncodingConverter* GetEncodingConverter() const;
23324ae1
FM
170
171 /**
172 Returns @true if actual font is bold, @false otherwise.
173 */
328f5751 174 int GetFontBold() const;
23324ae1
FM
175
176 /**
177 Returns actual font face name.
178 */
328f5751 179 wxString GetFontFace() const;
23324ae1
FM
180
181 /**
182 Returns @true if actual font is fixed face, @false otherwise.
183 */
328f5751 184 int GetFontFixed() const;
23324ae1
FM
185
186 /**
187 Returns @true if actual font is italic, @false otherwise.
188 */
328f5751 189 int GetFontItalic() const;
23324ae1
FM
190
191 /**
192 Returns actual font size (HTML size varies from -2 to +4)
193 */
328f5751 194 int GetFontSize() const;
23324ae1
FM
195
196 /**
197 Returns @true if actual font is underlined, @false otherwise.
198 */
328f5751 199 int GetFontUnderlined() const;
23324ae1
FM
200
201 /**
202 Returns input encoding.
203 */
328f5751 204 wxFontEncoding GetInputEncoding() const;
23324ae1
FM
205
206 /**
5bddd46d
FM
207 Returns actual hypertext link.
208 (This value has a non-empty @ref wxHtmlLinkInfo::GetHref Href string
209 if the parser is between \<A\> and \</A\> tags, wxEmptyString otherwise.)
23324ae1 210 */
95b4a59e 211 const wxHtmlLinkInfo& GetLink() const;
23324ae1
FM
212
213 /**
214 Returns the colour of hypertext link text.
215 */
95b4a59e 216 const wxColour& GetLinkColor() const;
23324ae1
FM
217
218 /**
219 Returns output encoding, i.e. closest match to document's input encoding
220 that is supported by operating system.
221 */
328f5751 222 wxFontEncoding GetOutputEncoding() const;
23324ae1
FM
223
224 /**
5bddd46d
FM
225 Returns associated window (wxHtmlWindow). This may be @NULL!
226 (You should always test if it is non-@NULL.
227 For example @c TITLE handler sets window title only if some window is
228 associated, otherwise it does nothing.
90f011dc
RD
229 */
230 wxHtmlWindowInterface* GetWindowInterface();
23324ae1
FM
231
232 /**
5bddd46d 233 Opens new container and returns pointer to it (see @ref overview_html_cells).
23324ae1
FM
234 */
235 wxHtmlContainerCell* OpenContainer();
236
237 /**
238 Sets actual text colour. Note: this DOESN'T change the colour!
239 You must create wxHtmlColourCell yourself.
240 */
241 void SetActualColor(const wxColour& clr);
242
243 /**
5bddd46d 244 Sets default horizontal alignment (see wxHtmlContainerCell::SetAlignHor).
23324ae1
FM
245 Alignment of newly opened container is set to this value.
246 */
247 void SetAlign(int a);
248
249 /**
5bddd46d
FM
250 Allows you to directly set opened container.
251 This is not recommended - you should use OpenContainer() wherever possible.
23324ae1 252 */
4cc4bfaf 253 wxHtmlContainerCell* SetContainer(wxHtmlContainerCell* c);
23324ae1
FM
254
255 /**
256 Sets the DC. This must be called before wxHtmlParser::Parse!
5bddd46d 257
4cc4bfaf 258 @a pixel_scale can be used when rendering to high-resolution
7c913512 259 DCs (e.g. printer) to adjust size of pixel metrics. (Many dimensions in
23324ae1
FM
260 HTML are given in pixels -- e.g. image sizes. 300x300 image would be only one
261 inch wide on typical printer. With pixel_scale = 3.0 it would be 3 inches.)
262 */
95b4a59e 263 virtual void SetDC(wxDC* dc, double pixel_scale = 1.0e+0);
23324ae1
FM
264
265 /**
4cc4bfaf 266 Sets bold flag of actualfont. @a x is either @true of @false.
23324ae1
FM
267 */
268 void SetFontBold(int x);
269
270 /**
5bddd46d 271 Sets current font face to @a face. This affects either fixed size
7c913512 272 font or proportional, depending on context (whether the parser is
5bddd46d 273 inside @c \<TT\> tag or not).
23324ae1
FM
274 */
275 void SetFontFace(const wxString& face);
276
277 /**
4cc4bfaf 278 Sets fixed face flag of actualfont. @a x is either @true of @false.
23324ae1
FM
279 */
280 void SetFontFixed(int x);
281
282 /**
4cc4bfaf 283 Sets italic flag of actualfont. @a x is either @true of @false.
23324ae1
FM
284 */
285 void SetFontItalic(int x);
286
287 /**
5bddd46d 288 Sets actual font size (HTML size varies from 1 to 7).
23324ae1
FM
289 */
290 void SetFontSize(int s);
291
292 /**
4cc4bfaf 293 Sets underlined flag of actualfont. @a x is either @true of @false.
23324ae1
FM
294 */
295 void SetFontUnderlined(int x);
296
297 /**
5bddd46d 298 Sets fonts. See wxHtmlWindow::SetFonts for detailed description.
23324ae1 299 */
95b4a59e
FM
300 void SetFonts(const wxString& normal_face, const wxString& fixed_face,
301 const int* sizes = 0);
23324ae1
FM
302
303 /**
304 Sets input encoding. The parser uses this information to build conversion
5bddd46d 305 tables from document's encoding to some encoding supported by operating system.
23324ae1
FM
306 */
307 void SetInputEncoding(wxFontEncoding enc);
308
309 /**
5bddd46d
FM
310 Sets actual hypertext link.
311 Empty link is represented by wxHtmlLinkInfo with @e Href equal
23324ae1
FM
312 to wxEmptyString.
313 */
314 void SetLink(const wxHtmlLinkInfo& link);
315
316 /**
317 Sets colour of hypertext link.
318 */
319 void SetLinkColor(const wxColour& clr);
320};
e54c96f1 321