]> git.saurik.com Git - wxWidgets.git/blame - interface/wx/font.h
Add wxCALL_FOR_EACH() macro.
[wxWidgets.git] / interface / wx / font.h
CommitLineData
23324ae1
FM
1/////////////////////////////////////////////////////////////////////////////
2// Name: font.h
e54c96f1 3// Purpose: interface of wxFont
23324ae1
FM
4// Author: wxWidgets team
5// RCS-ID: $Id$
526954c5 6// Licence: wxWindows licence
23324ae1
FM
7/////////////////////////////////////////////////////////////////////////////
8
0b70c946
FM
9
10/**
6aea1e4a
FM
11 Standard font families: these are used mainly during wxFont creation to specify
12 the generic properties of the font without hardcoding in the sources a specific
13 face name.
14
15 wxFontFamily thus allows to group the font face names of fonts with similar
16 properties. Most wxWidgets ports use lists of fonts for each font family
17 inspired by the data taken from http://www.codestyle.org/css/font-family.
0b70c946
FM
18*/
19enum wxFontFamily
20{
21 wxFONTFAMILY_DEFAULT = wxDEFAULT, //!< Chooses a default font.
f76c0758 22
0b70c946
FM
23 wxFONTFAMILY_DECORATIVE = wxDECORATIVE, //!< A decorative font.
24 wxFONTFAMILY_ROMAN = wxROMAN, //!< A formal, serif font.
25 wxFONTFAMILY_SCRIPT = wxSCRIPT, //!< A handwriting font.
26 wxFONTFAMILY_SWISS = wxSWISS, //!< A sans-serif font.
f76c0758 27
6aea1e4a
FM
28 /// A fixed pitch font. Note that wxFont currently does not make distinctions
29 /// between @c wxFONTFAMILY_MODERN and @c wxFONTFAMILY_TELETYPE.
30 wxFONTFAMILY_MODERN = wxMODERN,
f76c0758 31
6aea1e4a 32 /// A teletype (i.e. monospaced) font.
f76c0758
VZ
33 /// Monospace fonts have a fixed width like typewriters and often have strong angular
34 /// or block serifs. Monospace font faces are often used code samples and have a simple,
6aea1e4a
FM
35 /// functional font style.
36 /// See also wxFont::IsFixedWidth() for an easy way to test for monospace property.
37 wxFONTFAMILY_TELETYPE = wxTELETYPE,
f76c0758 38
e9321277 39 wxFONTFAMILY_MAX,
59b7da02
VZ
40 /// Invalid font family value, returned by wxFont::GetFamily() when the
41 /// font is invalid for example.
e9321277 42 wxFONTFAMILY_UNKNOWN = wxFONTFAMILY_MAX
0b70c946
FM
43};
44
45/**
46 Font styles.
47*/
48enum wxFontStyle
49{
071de7a0 50 /// The font is drawn without slant.
0b70c946 51 wxFONTSTYLE_NORMAL = wxNORMAL,
071de7a0
FM
52
53 /// The font is slanted in an italic style.
0b70c946 54 wxFONTSTYLE_ITALIC = wxITALIC,
f76c0758
VZ
55
56 /// The font is slanted, but in a roman style.
071de7a0 57 /// Note that under wxMSW this style is the same as @c wxFONTSTYLE_ITALIC.
0b70c946 58 wxFONTSTYLE_SLANT = wxSLANT,
071de7a0 59
0b70c946
FM
60 wxFONTSTYLE_MAX
61};
62
63/**
64 Font weights.
65*/
66enum wxFontWeight
67{
68 wxFONTWEIGHT_NORMAL = wxNORMAL, //!< Normal font.
69 wxFONTWEIGHT_LIGHT = wxLIGHT, //!< Light font.
70 wxFONTWEIGHT_BOLD = wxBOLD, //!< Bold font.
71 wxFONTWEIGHT_MAX
72};
73
19da7aaa
VZ
74/**
75 Symbolic font sizes.
76
77 The elements of this enum correspond to CSS absolute size specifications,
78 see http://www.w3.org/TR/CSS21/fonts.html#font-size-props
79
80 @see wxFont::SetSymbolicSize()
81
82 @since 2.9.2
83 */
84enum wxFontSymbolicSize
85{
86 wxFONTSIZE_XX_SMALL = -3, //!< Extra small.
87 wxFONTSIZE_X_SMALL, //!< Very small.
88 wxFONTSIZE_SMALL, //!< Small.
89 wxFONTSIZE_MEDIUM, //!< Normal.
90 wxFONTSIZE_LARGE, //!< Large.
91 wxFONTSIZE_X_LARGE, //!< Very large.
92 wxFONTSIZE_XX_LARGE //!< Extra large.
93};
94
0b70c946
FM
95/**
96 The font flag bits for the new font ctor accepting one combined flags word.
97*/
98enum wxFontFlag
99{
100 /// no special flags: font with default weight/slant/anti-aliasing
101 wxFONTFLAG_DEFAULT = 0,
102
103 /// slant flags (default: no slant)
104 wxFONTFLAG_ITALIC = 1 << 0,
105 wxFONTFLAG_SLANT = 1 << 1,
106
107 /// weight flags (default: medium)
108 wxFONTFLAG_LIGHT = 1 << 2,
109 wxFONTFLAG_BOLD = 1 << 3,
110
111 /// anti-aliasing flag: force on or off (default: the current system default)
112 wxFONTFLAG_ANTIALIASED = 1 << 4,
113 wxFONTFLAG_NOT_ANTIALIASED = 1 << 5,
114
c7a49742 115 /// Underlined style (not underlined by default).
0b70c946 116 wxFONTFLAG_UNDERLINED = 1 << 6,
c7a49742
VZ
117
118 /// Strike-through style (only supported in wxMSW and wxGTK currently).
0b70c946
FM
119 wxFONTFLAG_STRIKETHROUGH = 1 << 7,
120
121 /// the mask of all currently used flags
122 wxFONTFLAG_MASK = wxFONTFLAG_ITALIC |
123 wxFONTFLAG_SLANT |
124 wxFONTFLAG_LIGHT |
125 wxFONTFLAG_BOLD |
126 wxFONTFLAG_ANTIALIASED |
127 wxFONTFLAG_NOT_ANTIALIASED |
128 wxFONTFLAG_UNDERLINED |
129 wxFONTFLAG_STRIKETHROUGH
130};
131
132
133
134/**
135 Font encodings.
f76c0758 136
7ce58684 137 See wxFont::SetEncoding().
0b70c946
FM
138*/
139enum wxFontEncoding
140{
141 /// Default system encoding.
142 wxFONTENCODING_SYSTEM = -1, // system default
143
144 /// Default application encoding.
145 wxFONTENCODING_DEFAULT, // current default encoding
146
147 // ISO8859 standard defines a number of single-byte charsets
9a6fda22
FM
148 wxFONTENCODING_ISO8859_1, //!< West European (Latin1)
149 wxFONTENCODING_ISO8859_2, //!< Central and East European (Latin2)
150 wxFONTENCODING_ISO8859_3, //!< Esperanto (Latin3)
151 wxFONTENCODING_ISO8859_4, //!< Baltic (old) (Latin4)
152 wxFONTENCODING_ISO8859_5, //!< Cyrillic
153 wxFONTENCODING_ISO8859_6, //!< Arabic
154 wxFONTENCODING_ISO8859_7, //!< Greek
155 wxFONTENCODING_ISO8859_8, //!< Hebrew
156 wxFONTENCODING_ISO8859_9, //!< Turkish (Latin5)
157 wxFONTENCODING_ISO8859_10, //!< Variation of Latin4 (Latin6)
158 wxFONTENCODING_ISO8859_11, //!< Thai
159 wxFONTENCODING_ISO8859_12, //!< doesn't exist currently, but put it
160 //!< here anyhow to make all ISO8859
161 //!< consecutive numbers
162 wxFONTENCODING_ISO8859_13, //!< Baltic (Latin7)
163 wxFONTENCODING_ISO8859_14, //!< Latin8
164 wxFONTENCODING_ISO8859_15, //!< Latin9 (a.k.a. Latin0, includes euro)
0b70c946
FM
165 wxFONTENCODING_ISO8859_MAX,
166
167 // Cyrillic charset soup (see http://czyborra.com/charsets/cyrillic.html)
9a6fda22
FM
168 wxFONTENCODING_KOI8, //!< KOI8 Russian
169 wxFONTENCODING_KOI8_U, //!< KOI8 Ukrainian
170 wxFONTENCODING_ALTERNATIVE, //!< same as MS-DOS CP866
171 wxFONTENCODING_BULGARIAN, //!< used under Linux in Bulgaria
0b70c946
FM
172
173 // what would we do without Microsoft? They have their own encodings
174 // for DOS
9a6fda22
FM
175 wxFONTENCODING_CP437, //!< original MS-DOS codepage
176 wxFONTENCODING_CP850, //!< CP437 merged with Latin1
177 wxFONTENCODING_CP852, //!< CP437 merged with Latin2
178 wxFONTENCODING_CP855, //!< another cyrillic encoding
179 wxFONTENCODING_CP866, //!< and another one
0b70c946 180 // and for Windows
9a6fda22
FM
181 wxFONTENCODING_CP874, //!< WinThai
182 wxFONTENCODING_CP932, //!< Japanese (shift-JIS)
183 wxFONTENCODING_CP936, //!< Chinese simplified (GB)
184 wxFONTENCODING_CP949, //!< Korean (Hangul charset)
185 wxFONTENCODING_CP950, //!< Chinese (traditional - Big5)
186 wxFONTENCODING_CP1250, //!< WinLatin2
187 wxFONTENCODING_CP1251, //!< WinCyrillic
188 wxFONTENCODING_CP1252, //!< WinLatin1
189 wxFONTENCODING_CP1253, //!< WinGreek (8859-7)
190 wxFONTENCODING_CP1254, //!< WinTurkish
191 wxFONTENCODING_CP1255, //!< WinHebrew
192 wxFONTENCODING_CP1256, //!< WinArabic
193 wxFONTENCODING_CP1257, //!< WinBaltic (same as Latin 7)
2253f181
VZ
194 wxFONTENCODING_CP1258, //!< WinVietnamese (since 2.9.4)
195 wxFONTENCODING_CP1361, //!< Johab Korean character set (since 2.9.4)
0b70c946
FM
196 wxFONTENCODING_CP12_MAX,
197
9a6fda22
FM
198 wxFONTENCODING_UTF7, //!< UTF-7 Unicode encoding
199 wxFONTENCODING_UTF8, //!< UTF-8 Unicode encoding
200 wxFONTENCODING_EUC_JP, //!< Extended Unix Codepage for Japanese
201 wxFONTENCODING_UTF16BE, //!< UTF-16 Big Endian Unicode encoding
202 wxFONTENCODING_UTF16LE, //!< UTF-16 Little Endian Unicode encoding
203 wxFONTENCODING_UTF32BE, //!< UTF-32 Big Endian Unicode encoding
0b70c946
FM
204 wxFONTENCODING_UTF32LE, // UTF-32 Little Endian Unicode encoding
205
9a6fda22 206 wxFONTENCODING_MACROMAN, //!< the standard mac encodings
0b70c946
FM
207 wxFONTENCODING_MACJAPANESE,
208 wxFONTENCODING_MACCHINESETRAD,
209 wxFONTENCODING_MACKOREAN,
210 wxFONTENCODING_MACARABIC,
211 wxFONTENCODING_MACHEBREW,
212 wxFONTENCODING_MACGREEK,
213 wxFONTENCODING_MACCYRILLIC,
214 wxFONTENCODING_MACDEVANAGARI,
215 wxFONTENCODING_MACGURMUKHI,
216 wxFONTENCODING_MACGUJARATI,
217 wxFONTENCODING_MACORIYA,
218 wxFONTENCODING_MACBENGALI,
219 wxFONTENCODING_MACTAMIL,
220 wxFONTENCODING_MACTELUGU,
221 wxFONTENCODING_MACKANNADA,
222 wxFONTENCODING_MACMALAJALAM,
223 wxFONTENCODING_MACSINHALESE,
224 wxFONTENCODING_MACBURMESE,
225 wxFONTENCODING_MACKHMER,
226 wxFONTENCODING_MACTHAI,
227 wxFONTENCODING_MACLAOTIAN,
228 wxFONTENCODING_MACGEORGIAN,
229 wxFONTENCODING_MACARMENIAN,
230 wxFONTENCODING_MACCHINESESIMP,
231 wxFONTENCODING_MACTIBETAN,
232 wxFONTENCODING_MACMONGOLIAN,
233 wxFONTENCODING_MACETHIOPIC,
234 wxFONTENCODING_MACCENTRALEUR,
235 wxFONTENCODING_MACVIATNAMESE,
236 wxFONTENCODING_MACARABICEXT,
237 wxFONTENCODING_MACSYMBOL,
238 wxFONTENCODING_MACDINGBATS,
239 wxFONTENCODING_MACTURKISH,
240 wxFONTENCODING_MACCROATIAN,
241 wxFONTENCODING_MACICELANDIC,
242 wxFONTENCODING_MACROMANIAN,
243 wxFONTENCODING_MACCELTIC,
244 wxFONTENCODING_MACGAELIC,
245 wxFONTENCODING_MACKEYBOARD,
246
247 // more CJK encodings (for historical reasons some are already declared
248 // above)
9a6fda22 249 wxFONTENCODING_ISO2022_JP, //!< ISO-2022-JP JIS encoding
0b70c946 250
9a6fda22 251 wxFONTENCODING_MAX, //!< highest enumerated encoding value
0b70c946
FM
252
253 wxFONTENCODING_MACMIN = wxFONTENCODING_MACROMAN ,
254 wxFONTENCODING_MACMAX = wxFONTENCODING_MACKEYBOARD ,
255
256 // aliases for endian-dependent UTF encodings
9a6fda22
FM
257 wxFONTENCODING_UTF16, //!< native UTF-16
258 wxFONTENCODING_UTF32, //!< native UTF-32
259
260 /// Alias for the native Unicode encoding on this platform
261 /// (this is used by wxEncodingConverter and wxUTFFile only for now)
262 wxFONTENCODING_UNICODE,
0b70c946 263
9a6fda22
FM
264 wxFONTENCODING_GB2312 = wxFONTENCODING_CP936, //!< Simplified Chinese
265 wxFONTENCODING_BIG5 = wxFONTENCODING_CP950, //!< Traditional Chinese
3d4e20dd 266 wxFONTENCODING_SHIFT_JIS = wxFONTENCODING_CP932, //!< Shift JIS
2253f181
VZ
267 wxFONTENCODING_EUC_KR = wxFONTENCODING_CP949, //!< Korean
268 wxFONTENCODING_JOHAB = wxFONTENCODING_CP1361, //!< Korean Johab (since 2.9.4)
269 wxFONTENCODING_VIETNAMESE = wxFONTENCODING_CP1258 //!< Vietnamese (since 2.9.4)
0b70c946
FM
270};
271
272
23324ae1
FM
273/**
274 @class wxFont
7c913512 275
0b70c946
FM
276 A font is an object which determines the appearance of text.
277 Fonts are used for drawing text to a device context, and setting the appearance
278 of a window's text.
7c913512 279
0b70c946 280 This class uses @ref overview_refcount "reference counting and copy-on-write"
23324ae1
FM
281 internally so that assignments between two instances of this class are very
282 cheap. You can therefore use actual objects instead of pointers without
283 efficiency problems. If an instance of this class is changed it will create
284 its own data internally so that other instances, which previously shared the
285 data using the reference counting, are not affected.
7c913512 286
23324ae1 287 You can retrieve the current system font settings with wxSystemSettings.
7c913512 288
23324ae1
FM
289 @library{wxcore}
290 @category{gdi}
7c913512 291
23324ae1 292 @stdobjects
65874118 293 ::wxNullFont, ::wxNORMAL_FONT, ::wxSMALL_FONT, ::wxITALIC_FONT, ::wxSWISS_FONT
7c913512 294
0b70c946
FM
295 @see @ref overview_font, wxDC::SetFont, wxDC::DrawText,
296 wxDC::GetTextExtent, wxFontDialog, wxSystemSettings
23324ae1
FM
297*/
298class wxFont : public wxGDIObject
299{
300public:
45a591fa 301 /**
0b70c946 302 Default ctor.
45a591fa
VZ
303 */
304 wxFont();
305
306 /**
0b70c946 307 Copy constructor, uses @ref overview_refcount "reference counting".
45a591fa
VZ
308 */
309 wxFont(const wxFont& font);
310
23324ae1 311 /**
0634700a 312 Creates a font object with the specified attributes and size in points.
3c4f71cc 313
7c913512 314 @param pointSize
b5791cc7 315 Size in points. See SetPointSize() for more info.
45a591fa 316 @param family
6aea1e4a
FM
317 The font family: a generic portable way of referring to fonts without specifying a
318 facename. This parameter must be one of the ::wxFontFamily enumeration values.
319 If the @a faceName argument is provided, then it overrides the font family.
45a591fa 320 @param style
b5791cc7 321 One of @c wxFONTSTYLE_NORMAL, @c wxFONTSTYLE_SLANT and @c wxFONTSTYLE_ITALIC.
45a591fa 322 @param weight
f76c0758 323 Font weight, sometimes also referred to as font boldness.
b5791cc7 324 One of the ::wxFontWeight enumeration values.
45a591fa 325 @param underline
0b70c946
FM
326 The value can be @true or @false.
327 At present this has an effect on Windows and Motif 2.x only.
45a591fa 328 @param faceName
6aea1e4a
FM
329 An optional string specifying the face name to be used.
330 If it is an empty string, a default face name will be chosen based on the family.
45a591fa 331 @param encoding
0b70c946
FM
332 An encoding which may be one of the enumeration values of ::wxFontEncoding.
333 Briefly these can be summed up as:
334 <TABLE>
b5791cc7
FM
335 <TR><TD>@c wxFONTENCODING_SYSTEM</TD><TD>Default system encoding.</TD></TR>
336 <TR><TD>@c wxFONTENCODING_DEFAULT</TD><TD>
8f1337ed 337 Default application encoding: this is the encoding set by calls to
f76c0758
VZ
338 SetDefaultEncoding() and which may be set to, say, KOI8 to create all
339 fonts by default with KOI8 encoding. Initially, the default application
8f1337ed 340 encoding is the same as default system encoding.</TD></TR>
b5791cc7
FM
341 <TR><TD>@c wxFONTENCODING_ISO8859_1...15</TD><TD>ISO8859 encodings.</TD></TR>
342 <TR><TD>@c wxFONTENCODING_KOI8</TD><TD>The standard Russian encoding for Internet.</TD></TR>
343 <TR><TD>@c wxFONTENCODING_CP1250...1252</TD><TD>Windows encodings similar to ISO8859 (but not identical).</TD></TR>
0b70c946 344 </TABLE>
45a591fa 345 If the specified encoding isn't available, no font is created
8f1337ed 346 (see also @ref overview_fontencoding).
45a591fa
VZ
347
348 @remarks If the desired font does not exist, the closest match will be
0b70c946 349 chosen. Under Windows, only scalable TrueType fonts are used.
45a591fa 350 */
882678eb 351 wxFont(int pointSize, wxFontFamily family, wxFontStyle style,
45a591fa 352 wxFontWeight weight,
11e3af6e 353 bool underline = false,
e9c3992c 354 const wxString& faceName = wxEmptyString,
45a591fa 355 wxFontEncoding encoding = wxFONTENCODING_DEFAULT);
0b70c946 356
45a591fa 357 /**
0634700a 358 Creates a font object with the specified attributes and size in pixels.
45a591fa 359
7c913512 360 @param pixelSize
b5791cc7 361 Size in pixels. See SetPixelSize() for more info.
7c913512 362 @param family
6aea1e4a
FM
363 The font family: a generic portable way of referring to fonts without specifying a
364 facename. This parameter must be one of the ::wxFontFamily enumeration values.
365 If the @a faceName argument is provided, then it overrides the font family.
4cc4bfaf 366 @param style
b5791cc7 367 One of @c wxFONTSTYLE_NORMAL, @c wxFONTSTYLE_SLANT and @c wxFONTSTYLE_ITALIC.
7c913512 368 @param weight
0b70c946
FM
369 Font weight, sometimes also referred to as font boldness.
370 One of the ::wxFontWeight enumeration values.
4cc4bfaf 371 @param underline
0b70c946
FM
372 The value can be @true or @false.
373 At present this has an effect on Windows and Motif 2.x only.
4cc4bfaf 374 @param faceName
6aea1e4a
FM
375 An optional string specifying the face name to be used.
376 If it is an empty string, a default face name will be chosen based on the family.
7c913512 377 @param encoding
0b70c946
FM
378 An encoding which may be one of the enumeration values of ::wxFontEncoding.
379 Briefly these can be summed up as:
380 <TABLE>
b5791cc7
FM
381 <TR><TD>@c wxFONTENCODING_SYSTEM</TD><TD>Default system encoding.</TD></TR>
382 <TR><TD>@c wxFONTENCODING_DEFAULT</TD><TD>
8f1337ed 383 Default application encoding: this is the encoding set by calls to
f76c0758
VZ
384 SetDefaultEncoding() and which may be set to, say, KOI8 to create all
385 fonts by default with KOI8 encoding. Initially, the default application
8f1337ed 386 encoding is the same as default system encoding.</TD></TR>
b5791cc7
FM
387 <TR><TD>@c wxFONTENCODING_ISO8859_1...15</TD><TD>ISO8859 encodings.</TD></TR>
388 <TR><TD>@c wxFONTENCODING_KOI8</TD><TD>The standard Russian encoding for Internet.</TD></TR>
389 <TR><TD>@c wxFONTENCODING_CP1250...1252</TD><TD>Windows encodings similar to ISO8859 (but not identical).</TD></TR>
0b70c946 390 </TABLE>
4cc4bfaf 391 If the specified encoding isn't available, no font is created
8f1337ed 392 (see also @ref overview_fontencoding).
3c4f71cc 393
23324ae1 394 @remarks If the desired font does not exist, the closest match will be
0b70c946 395 chosen. Under Windows, only scalable TrueType fonts are used.
23324ae1 396 */
7c913512 397 wxFont(const wxSize& pixelSize, wxFontFamily family,
882678eb 398 wxFontStyle style, wxFontWeight weight,
11e3af6e 399 bool underline = false,
e9c3992c 400 const wxString& faceName = wxEmptyString,
7c913512 401 wxFontEncoding encoding = wxFONTENCODING_DEFAULT);
23324ae1 402
0634700a
VZ
403 /**
404 Creates a font object using font flags.
405
406 This constructor is similar to the constructors above except it
407 specifies the font styles such as underlined, italic, bold, ... in a
408 single @a flags argument instead of using separate arguments for them.
409 This parameter can be a combination of ::wxFontFlag enum elements.
410 The meaning of the remaining arguments is the same as in the other
411 constructors, please see their documentation for details.
412
c7a49742
VZ
413 Notice that this constructor provides the only way of creating fonts
414 with strike-through style.
415
0634700a
VZ
416 @since 2.9.4
417 */
418 wxFont(int pointSize, wxFontFamily family, int flags,
419 const wxString& faceName = wxEmptyString,
420 wxFontEncoding encoding = wxFONTENCODING_DEFAULT);
421
20cc4e19
VZ
422 /**
423 Constructor from font description string.
424
6aea1e4a
FM
425 This constructor uses SetNativeFontInfo() to initialize the font.
426 If @a fontdesc is invalid the font remains uninitialized, i.e. its IsOk() method
20cc4e19
VZ
427 will return @false.
428 */
d775ec48
RD
429 wxFont(const wxString& nativeInfoString);
430
431 /**
432 Construct font from a native font info structure.
433 */
434 wxFont(const wxNativeFontInfo& nativeInfo);
20cc4e19 435
23324ae1
FM
436 /**
437 Destructor.
0b70c946 438
674d80a7 439 See @ref overview_refcount_destruct "reference-counted object destruction"
0b70c946 440 for more info.
3c4f71cc 441
23324ae1 442 @remarks Although all remaining fonts are deleted when the application
4cc4bfaf
FM
443 exits, the application should try to clean up all fonts
444 itself. This is because wxWidgets cannot know if a
445 pointer to the font object is stored in an application
446 data structure, and there is a risk of double deletion.
23324ae1 447 */
adaaa686 448 virtual ~wxFont();
23324ae1 449
f76c0758 450
23324ae1 451 /**
060c4f90 452 @name Getters
23324ae1 453 */
060c4f90 454 //@{
f76c0758 455
7ce58684
FM
456 /**
457 Returns the encoding of this font.
f76c0758 458
7ce58684 459 Note that under wxGTK the returned value is always @c wxFONTENCODING_UTF8.
f76c0758 460
7ce58684
FM
461 @see SetEncoding()
462 */
463 virtual wxFontEncoding GetEncoding() const;
f76c0758 464
23324ae1 465 /**
6aea1e4a
FM
466 Returns the face name associated with the font, or the empty string if
467 there is no face information.
3c4f71cc 468
4cc4bfaf 469 @see SetFaceName()
23324ae1 470 */
adaaa686 471 virtual wxString GetFaceName() const;
23324ae1
FM
472
473 /**
59b7da02
VZ
474 Gets the font family if possible.
475
6aea1e4a
FM
476 As described in ::wxFontFamily docs the returned value acts as a rough,
477 basic classification of the main font properties (look, spacing).
f76c0758 478
6aea1e4a 479 If the current font face name is not recognized by wxFont or by the
59b7da02 480 underlying system, @c wxFONTFAMILY_DEFAULT is returned.
f76c0758 481
59b7da02
VZ
482 Note that currently this function is not very precise and so not
483 particularly useful. Font families mostly make sense only for font
484 creation, see SetFamily().
3c4f71cc 485
4cc4bfaf 486 @see SetFamily()
23324ae1 487 */
26818748 488 virtual wxFontFamily GetFamily() const;
23324ae1
FM
489
490 /**
491 Returns the platform-dependent string completely describing this font.
64932e41
VZ
492
493 Returned string is always non-empty unless the font is invalid (in
494 which case an assert is triggered).
0b70c946 495
23324ae1 496 Note that the returned string is not meant to be shown or edited by the user: a
0b70c946 497 typical use of this function is for serializing in string-form a wxFont object.
3c4f71cc 498
a912ea26 499 @see SetNativeFontInfo(), GetNativeFontInfoUserDesc()
23324ae1 500 */
328f5751 501 wxString GetNativeFontInfoDesc() const;
23324ae1
FM
502
503 /**
0b70c946 504 Returns a user-friendly string for this font object.
64932e41
VZ
505
506 Returned string is always non-empty unless the font is invalid (in
507 which case an assert is triggered).
f76c0758 508
a912ea26
FM
509 The string does not encode all wxFont infos under all platforms;
510 e.g. under wxMSW the font family is not present in the returned string.
0b70c946 511
23324ae1
FM
512 Some examples of the formats of returned strings (which are platform-dependent)
513 are in SetNativeFontInfoUserDesc().
3c4f71cc 514
a912ea26 515 @see SetNativeFontInfoUserDesc(), GetNativeFontInfoDesc()
23324ae1 516 */
adaaa686 517 wxString GetNativeFontInfoUserDesc() const;
23324ae1 518
d775ec48
RD
519 const wxNativeFontInfo *GetNativeFontInfo() const;
520
23324ae1
FM
521 /**
522 Gets the point size.
3c4f71cc 523
4cc4bfaf 524 @see SetPointSize()
23324ae1 525 */
adaaa686 526 virtual int GetPointSize() const;
23324ae1
FM
527
528 /**
b5791cc7 529 Gets the pixel size.
f76c0758 530
b5791cc7
FM
531 Note that under wxMSW if you passed to SetPixelSize() (or to the ctor)
532 a wxSize object with a null width value, you'll get a null width in
533 the returned object.
534
535 @see SetPixelSize()
536 */
537 virtual wxSize GetPixelSize() const;
f76c0758 538
b5791cc7
FM
539 /**
540 Gets the font style. See ::wxFontStyle for a list of valid styles.
3c4f71cc 541
4cc4bfaf 542 @see SetStyle()
23324ae1 543 */
26818748 544 virtual wxFontStyle GetStyle() const;
23324ae1
FM
545
546 /**
547 Returns @true if the font is underlined, @false otherwise.
3c4f71cc 548
4cc4bfaf 549 @see SetUnderlined()
23324ae1 550 */
adaaa686 551 virtual bool GetUnderlined() const;
23324ae1 552
c7a49742
VZ
553 /**
554 Returns @true if the font is stricken-through, @false otherwise.
555
556 @see SetStrikethrough()
557
558 @since 2.9.4
559 */
560 virtual bool GetStrikethrough() const;
561
23324ae1 562 /**
b5791cc7 563 Gets the font weight. See ::wxFontWeight for a list of valid weight identifiers.
3c4f71cc 564
4cc4bfaf 565 @see SetWeight()
23324ae1 566 */
26818748 567 virtual wxFontWeight GetWeight() const;
23324ae1
FM
568
569 /**
570 Returns @true if the font is a fixed width (or monospaced) font,
571 @false if it is a proportional one or font is invalid.
f76c0758 572
6aea1e4a
FM
573 Note that this function under some platforms is different than just testing
574 for the font family being equal to @c wxFONTFAMILY_TELETYPE because native
575 platform-specific functions are used for the check (resulting in a more
576 accurate return value).
23324ae1 577 */
adaaa686 578 virtual bool IsFixedWidth() const;
23324ae1
FM
579
580 /**
581 Returns @true if this object is a valid font, @false otherwise.
582 */
0004982c 583 virtual bool IsOk() const;
f76c0758
VZ
584
585 //@}
586
587
588 /**
589 @name Similar fonts creation
590
6e7d2550
VZ
591 The functions in this section either modify the font in place or create
592 a new font similar to the given one but with its weight, style or size
593 changed.
f76c0758
VZ
594 */
595 //@{
596
597 /**
efb09182 598 Returns a bold version of this font.
6e7d2550
VZ
599
600 @see MakeBold()
601
602 @since 2.9.1
f76c0758 603 */
6e7d2550 604 wxFont Bold() const;
f76c0758
VZ
605
606 /**
efb09182 607 Returns an italic version of this font.
6e7d2550
VZ
608
609 @see MakeItalic()
610
611 @since 2.9.1
f76c0758 612 */
6e7d2550 613 wxFont Italic() const;
f76c0758
VZ
614
615 /**
efb09182 616 Returns a larger version of this font.
f76c0758 617
efb09182
VZ
618 The font size is multiplied by @c 1.2, the factor of @c 1.2 being
619 inspired by the W3C CSS specification.
f76c0758 620
efb09182 621 @see MakeLarger(), Smaller(), Scaled()
6e7d2550
VZ
622
623 @since 2.9.1
624 */
625 wxFont Larger() const;
626
efb09182
VZ
627 /**
628 Returns a smaller version of this font.
629
630 The font size is divided by @c 1.2, the factor of @c 1.2 being
631 inspired by the W3C CSS specification.
632
633 @see MakeSmaller(), Larger(), Scaled()
634
635 @since 2.9.1
636 */
637 wxFont Smaller() const;
638
801423ee
VZ
639 /**
640 Returns underlined version of this font.
641
642 @see MakeUnderlined()
643
644 @since 2.9.2
645 */
646 wxFont Underlined() const;
647
c7a49742
VZ
648 /**
649 Returns stricken-through version of this font.
650
651 Currently stricken-through fonts are only supported in wxMSW and wxGTK.
652
653 @see MakeStrikethrough()
654
655 @since 2.9.4
656 */
657 wxFont Strikethrough() const;
658
6e7d2550
VZ
659 /**
660 Changes this font to be bold.
661
662 @see Bold()
663
664 @since 2.9.1
665 */
666 wxFont& MakeBold();
667
668 /**
669 Changes this font to be italic.
670
671 @see Italic()
672
673 @since 2.9.1
f76c0758 674 */
6e7d2550
VZ
675 wxFont& MakeItalic();
676
677 /**
678 Changes this font to be larger.
679
efb09182
VZ
680 The font size is multiplied by @c 1.2, the factor of @c 1.2 being
681 inspired by the W3C CSS specification.
6e7d2550
VZ
682
683 @see Larger(), MakeSmaller(), Scale()
684
685 @since 2.9.1
686 */
687 wxFont& MakeLarger();
f76c0758
VZ
688
689 /**
efb09182 690 Changes this font to be smaller.
f76c0758 691
efb09182
VZ
692 The font size is divided by @c 1.2, the factor of @c 1.2 being
693 inspired by the W3C CSS specification.
f76c0758 694
efb09182 695 @see Smaller(), MakeLarger(), Scale()
6e7d2550
VZ
696
697 @since 2.9.1
f76c0758 698 */
6e7d2550
VZ
699 wxFont& MakeSmaller();
700
801423ee
VZ
701 /**
702 Changes this font to be underlined.
703
704 @see Underlined()
705
706 @since 2.9.2
707 */
708 wxFont& MakeUnderlined();
709
c7a49742
VZ
710 /**
711 Changes this font to be stricken-through.
712
713 Currently stricken-through fonts are only supported in wxMSW and wxGTK.
714
715 @see Strikethrough()
716
717 @since 2.9.4
718 */
719 wxFont& MakeStrikethrough();
720
6e7d2550
VZ
721 /**
722 Changes the size of this font.
723
724 The font size is multiplied by the given factor (which may be less than
725 1 to create a smaller version of the font).
726
727 @see Scaled(), MakeLarger(), MakeSmaller()
728
729 @since 2.9.1
730 */
731 wxFont& Scale(float x);
f76c0758
VZ
732
733 /**
efb09182 734 Returns a scaled version of this font.
f76c0758
VZ
735
736 The font size is multiplied by the given factor (which may be less than
737 1 to create a smaller version of the font).
6e7d2550
VZ
738
739 @see Scale(), Larger(), Smaller()
740
741 @since 2.9.1
742 */
743 wxFont Scaled(float x) const;
744
23324ae1 745 //@}
f76c0758 746
23324ae1 747 /**
060c4f90 748 @name Setters
f76c0758 749
060c4f90
FM
750 These functions internally recreate the native font object with the new
751 specified property.
23324ae1 752 */
060c4f90
FM
753 //@{
754
7ce58684
FM
755 /**
756 Sets the encoding for this font.
f76c0758 757
7ce58684
FM
758 Note that under wxGTK this function has no effect (because the underlying
759 Pango library always uses @c wxFONTENCODING_UTF8).
f76c0758 760
7ce58684
FM
761 @see GetEncoding()
762 */
763 virtual void SetEncoding(wxFontEncoding encoding);
23324ae1
FM
764
765 /**
766 Sets the facename for the font.
3c4f71cc 767
7c913512 768 @param faceName
4cc4bfaf 769 A valid facename, which should be on the end-user's system.
3c4f71cc 770
23324ae1 771 @remarks To avoid portability problems, don't rely on a specific face,
f7008bad
FM
772 but specify the font family instead (see ::wxFontFamily and SetFamily()).
773
774 @return @true if the given face name exists; if the face name doesn't exist
f76c0758 775 in the user's system then the font is invalidated (so that IsOk() will
f7008bad 776 return @false) and @false is returned.
3c4f71cc 777
4cc4bfaf 778 @see GetFaceName(), SetFamily()
23324ae1 779 */
adaaa686 780 virtual bool SetFaceName(const wxString& faceName);
23324ae1
FM
781
782 /**
783 Sets the font family.
f76c0758 784
060c4f90
FM
785 As described in ::wxFontFamily docs the given @a family value acts as a rough,
786 basic indication of the main font properties (look, spacing).
787
788 Note that changing the font family results in changing the font face name.
3c4f71cc 789
7c913512 790 @param family
0b70c946 791 One of the ::wxFontFamily values.
3c4f71cc 792
4cc4bfaf 793 @see GetFamily(), SetFaceName()
23324ae1 794 */
a44f3b5a 795 virtual void SetFamily(wxFontFamily family);
23324ae1
FM
796
797 /**
0b70c946
FM
798 Creates the font corresponding to the given native font description string
799 which must have been previously returned by GetNativeFontInfoDesc().
800
801 If the string is invalid, font is unchanged.
802 This function is typically used for de-serializing a wxFont object
803 previously saved in a string-form.
804
805 @return @true if the creation was successful.
3c4f71cc 806
4cc4bfaf 807 @see SetNativeFontInfoUserDesc()
23324ae1
FM
808 */
809 bool SetNativeFontInfo(const wxString& info);
810
811 /**
812 Creates the font corresponding to the given native font description string and
0b70c946 813 returns @true if the creation was successful.
3c4f71cc 814
0b70c946
FM
815 Unlike SetNativeFontInfo(), this function accepts strings which are user-friendly.
816 Examples of accepted string formats are:
3c4f71cc 817
0b70c946
FM
818 @beginTable
819 @hdr3col{platform, generic syntax, example}
a349dc10 820 @row3col{wxGTK2, <tt>[underlined] [strikethrough] [FACE-NAME] [bold] [oblique|italic] [POINTSIZE]</tt>, Monospace bold 10}
b5791cc7 821 @row3col{wxMSW, <tt>[light|bold] [italic] [FACE-NAME] [POINTSIZE] [ENCODING]</tt>, Tahoma 10 WINDOWS-1252}
0b70c946 822 @endTable
3c4f71cc 823
0b70c946 824 @todo add an example for wxMac
3c4f71cc 825
23324ae1 826 For more detailed information about the allowed syntaxes you can look at the
0b70c946 827 documentation of the native API used for font-rendering
a349dc10
VZ
828 (e.g. @c pango_font_description_from_string under GTK, although notice
829 that it doesn't support the "underlined" and "strikethrough" attributes
830 and so those are handled by wxWidgets itself).
f76c0758 831
a912ea26
FM
832 Note that unlike SetNativeFontInfo(), this function doesn't always restore all
833 attributes of the wxFont object under all platforms; e.g. on wxMSW the font family
834 is not restored (because GetNativeFontInfoUserDesc doesn't return it on wxMSW).
835 If you want to serialize/deserialize a font in string form, you should use
836 GetNativeFontInfoDesc() and SetNativeFontInfo() instead.
3c4f71cc 837
4cc4bfaf 838 @see SetNativeFontInfo()
23324ae1
FM
839 */
840 bool SetNativeFontInfoUserDesc(const wxString& info);
841
d775ec48
RD
842 void SetNativeFontInfo(const wxNativeFontInfo& info);
843
23324ae1
FM
844 /**
845 Sets the point size.
f76c0758
VZ
846
847 The <em>point size</em> is defined as 1/72 of the anglo-Saxon inch
848 (25.4 mm): it is approximately 0.0139 inch or 352.8 um.
3c4f71cc 849
7c913512 850 @param pointSize
4cc4bfaf 851 Size in points.
3c4f71cc 852
4cc4bfaf 853 @see GetPointSize()
23324ae1 854 */
adaaa686 855 virtual void SetPointSize(int pointSize);
23324ae1 856
b5791cc7
FM
857 /**
858 Sets the pixel size.
f76c0758 859
b5791cc7
FM
860 The height parameter of @a pixelSize must be positive while the width
861 parameter may also be zero (to indicate that you're not interested in the
862 width of the characters: a suitable width will be chosen for best rendering).
f76c0758
VZ
863
864 This feature (specifying the font pixel size) is directly supported only
865 under wxMSW and wxGTK currently; under other platforms a font with the
b5791cc7
FM
866 closest size to the given one is found using binary search (this maybe slower).
867
868 @see GetPixelSize()
869 */
870 virtual void SetPixelSize(const wxSize& pixelSize);
f76c0758 871
23324ae1
FM
872 /**
873 Sets the font style.
3c4f71cc 874
7c913512 875 @param style
0b70c946 876 One of the ::wxFontStyle enumeration values.
3c4f71cc 877
4cc4bfaf 878 @see GetStyle()
23324ae1 879 */
a44f3b5a 880 virtual void SetStyle(wxFontStyle style);
23324ae1 881
19da7aaa
VZ
882 /**
883 Sets the font size using a predefined symbolic size name.
884
885 This function allows to change font size to be (very) large or small
886 compared to the standard font size.
887
888 @see SetSymbolicSizeRelativeTo().
889
890 @since 2.9.2
891 */
892 void SetSymbolicSize(wxFontSymbolicSize size);
893
894 /**
895 Sets the font size compared to the base font size.
896
897 This is the same as SetSymbolicSize() except that it uses the given
898 font size as the normal font size instead of the standard font size.
899
900 @since 2.9.2
901 */
902 void SetSymbolicSizeRelativeTo(wxFontSymbolicSize size, int base);
903
23324ae1
FM
904 /**
905 Sets underlining.
3c4f71cc 906
45a591fa 907 @param underlined
4cc4bfaf 908 @true to underline, @false otherwise.
3c4f71cc 909
4cc4bfaf 910 @see GetUnderlined()
23324ae1 911 */
26818748 912 virtual void SetUnderlined(bool underlined);
23324ae1 913
c7a49742
VZ
914 /**
915 Sets strike-through attribute of the font.
916
917 Currently stricken-through fonts are only supported in wxMSW and wxGTK.
918
919 @param strikethrough
920 @true to add strike-through style, @false to remove it.
921
922 @see GetStrikethrough()
923
924 @since 2.9.4
925 */
926 virtual void SetStrikethrough(bool strikethrough);
927
23324ae1
FM
928 /**
929 Sets the font weight.
3c4f71cc 930
7c913512 931 @param weight
0b70c946 932 One of the ::wxFontWeight values.
3c4f71cc 933
4cc4bfaf 934 @see GetWeight()
23324ae1 935 */
a44f3b5a 936 virtual void SetWeight(wxFontWeight weight);
f76c0758 937
060c4f90
FM
938 //@}
939
23324ae1
FM
940
941 /**
942 Inequality operator.
0b70c946 943
674d80a7 944 See @ref overview_refcount_equality "reference-counted object comparison" for
23324ae1
FM
945 more info.
946 */
fadc2df6 947 bool operator!=(const wxFont& font) const;
23324ae1 948
23324ae1
FM
949 /**
950 Equality operator.
0b70c946 951
674d80a7 952 See @ref overview_refcount_equality "reference-counted object comparison" for
23324ae1
FM
953 more info.
954 */
fadc2df6 955 bool operator==(const wxFont& font) const;
0b70c946
FM
956
957 /**
958 Assignment operator, using @ref overview_refcount "reference counting".
959 */
960 wxFont& operator =(const wxFont& font);
f76c0758
VZ
961
962
060c4f90
FM
963 // statics
964
965 /**
966 Returns the current application's default encoding.
967
968 @see @ref overview_fontencoding, SetDefaultEncoding()
969 */
970 static wxFontEncoding GetDefaultEncoding();
971
972 /**
973 Sets the default font encoding.
974
975 @see @ref overview_fontencoding, GetDefaultEncoding()
976 */
977 static void SetDefaultEncoding(wxFontEncoding encoding);
f76c0758 978
060c4f90
FM
979 //@{
980 /**
981 This function takes the same parameters as the relative
982 @ref wxFont::wxFont "wxFont constructor" and returns a new font
983 object allocated on the heap.
984 */
985 static wxFont* New(int pointSize, wxFontFamily family, wxFontStyle style,
986 wxFontWeight weight,
987 bool underline = false,
988 const wxString& faceName = wxEmptyString,
989 wxFontEncoding encoding = wxFONTENCODING_DEFAULT);
990 static wxFont* New(int pointSize, wxFontFamily family,
991 int flags = wxFONTFLAG_DEFAULT,
992 const wxString& faceName = wxEmptyString,
993 wxFontEncoding encoding = wxFONTENCODING_DEFAULT);
994 static wxFont* New(const wxSize& pixelSize,
995 wxFontFamily family,
996 wxFontStyle style,
997 wxFontWeight weight,
998 bool underline = false,
999 const wxString& faceName = wxEmptyString,
1000 wxFontEncoding encoding = wxFONTENCODING_DEFAULT);
1001 static wxFont* New(const wxSize& pixelSize,
1002 wxFontFamily family,
1003 int flags = wxFONTFLAG_DEFAULT,
1004 const wxString& faceName = wxEmptyString,
1005 wxFontEncoding encoding = wxFONTENCODING_DEFAULT);
d775ec48
RD
1006
1007
1008 static wxFont *New(const wxNativeFontInfo& nativeInfo);
1009 static wxFont *New(const wxString& nativeInfoString);
1010
060c4f90 1011 //@}
23324ae1 1012};
e54c96f1
FM
1013
1014
1015/**
65874118 1016 An empty wxFont.
e54c96f1 1017*/
7fa7088e 1018wxFont wxNullFont;
e54c96f1
FM
1019
1020/**
0b70c946 1021 Equivalent to wxSystemSettings::GetFont(wxSYS_DEFAULT_GUI_FONT).
f76c0758 1022
b5791cc7 1023 @see wxSystemSettings
e54c96f1 1024*/
e2e19a29 1025wxFont* wxNORMAL_FONT;
e54c96f1
FM
1026
1027/**
b5791cc7 1028 A font using the @c wxFONTFAMILY_SWISS family and 2 points smaller than
0b70c946 1029 ::wxNORMAL_FONT.
e54c96f1 1030*/
e2e19a29 1031wxFont* wxSMALL_FONT;
e54c96f1
FM
1032
1033/**
b5791cc7 1034 A font using the @c wxFONTFAMILY_ROMAN family and @c wxFONTSTYLE_ITALIC style and
0b70c946 1035 of the same size of ::wxNORMAL_FONT.
e54c96f1 1036*/
e2e19a29 1037wxFont* wxITALIC_FONT;
e54c96f1
FM
1038
1039/**
0b70c946 1040 A font identic to ::wxNORMAL_FONT except for the family used which is
b5791cc7 1041 @c wxFONTFAMILY_SWISS.
e54c96f1 1042*/
e2e19a29 1043wxFont* wxSWISS_FONT;
7fa7088e
BP
1044
1045
65874118
FM
1046/**
1047 @class wxFontList
65874118 1048
0b70c946
FM
1049 A font list is a list containing all fonts which have been created.
1050 There is only one instance of this class: ::wxTheFontList.
1051
1052 Use this object to search for a previously created font of the desired type
1053 and create it if not already found.
1054
65874118
FM
1055 In some windowing systems, the font may be a scarce resource, so it is best to
1056 reuse old resources if possible. When an application finishes, all fonts will
0b70c946 1057 be deleted and their resources freed, eliminating the possibility of 'memory
65874118
FM
1058 leaks'.
1059
1060 @library{wxcore}
1061 @category{gdi}
1062
1063 @see wxFont
1064*/
1065class wxFontList : public wxList
1066{
1067public:
1068 /**
1069 Constructor. The application should not construct its own font list:
0b70c946 1070 use the object pointer ::wxTheFontList.
65874118
FM
1071 */
1072 wxFontList();
1073
1074 /**
1075 Finds a font of the given specification, or creates one and adds it to the
0b70c946 1076 list. See the @ref wxFont "wxFont constructor" for details of the arguments.
65874118 1077 */
a44f3b5a
FM
1078 wxFont* FindOrCreateFont(int point_size, wxFontFamily family, wxFontStyle style,
1079 wxFontWeight weight, bool underline = false,
1080 const wxString& facename = wxEmptyString,
65874118
FM
1081 wxFontEncoding encoding = wxFONTENCODING_DEFAULT);
1082};
1083
1084
0b70c946
FM
1085/**
1086 The global wxFontList instance.
1087*/
1088wxFontList* wxTheFontList;
1089
7fa7088e
BP
1090
1091// ============================================================================
1092// Global functions/macros
1093// ============================================================================
1094
b21126db 1095/** @addtogroup group_funcmacro_misc */
7fa7088e 1096//@{
e54c96f1
FM
1097
1098/**
7fa7088e
BP
1099 Converts string to a wxFont best represented by the given string. Returns
1100 @true on success.
1101
1102 @see wxToString(const wxFont&)
1103
1104 @header{wx/font.h}
e54c96f1 1105*/
7fa7088e 1106bool wxFromString(const wxString& string, wxFont* font);
e54c96f1
FM
1107
1108/**
7fa7088e
BP
1109 Converts the given wxFont into a string.
1110
1111 @see wxFromString(const wxString&, wxFont*)
1112
1113 @header{wx/font.h}
e54c96f1 1114*/
7fa7088e 1115wxString wxToString(const wxFont& font);
e54c96f1 1116
7fa7088e 1117//@}
e54c96f1 1118