1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: SWIG interface file for wxFont and related classes
9 // Copyright: (c) 2002 by Total Control Software
10 // Licence: wxWindows license
11 /////////////////////////////////////////////////////////////////////////////
16 //---------------------------------------------------------------------------
19 #include <wx/fontutil.h>
20 #include <wx/fontmap.h>
21 #include <wx/fontenum.h>
24 //---------------------------------------------------------------------------
30 wxFONTFAMILY_DEFAULT = wxDEFAULT,
31 wxFONTFAMILY_DECORATIVE = wxDECORATIVE,
32 wxFONTFAMILY_ROMAN = wxROMAN,
33 wxFONTFAMILY_SCRIPT = wxSCRIPT,
34 wxFONTFAMILY_SWISS = wxSWISS,
35 wxFONTFAMILY_MODERN = wxMODERN,
36 wxFONTFAMILY_TELETYPE = wxTELETYPE,
38 wxFONTFAMILY_UNKNOWN = wxFONTFAMILY_MAX
44 wxFONTSTYLE_NORMAL = wxNORMAL,
45 wxFONTSTYLE_ITALIC = wxITALIC,
46 wxFONTSTYLE_SLANT = wxSLANT,
53 wxFONTWEIGHT_NORMAL = wxNORMAL,
54 wxFONTWEIGHT_LIGHT = wxLIGHT,
55 wxFONTWEIGHT_BOLD = wxBOLD,
60 // the font flag bits for the new font ctor accepting one combined flags word
63 // no special flags: font with default weight/slant/anti-aliasing
64 wxFONTFLAG_DEFAULT = 0,
66 // slant flags (default: no slant)
67 wxFONTFLAG_ITALIC = 1 << 0,
68 wxFONTFLAG_SLANT = 1 << 1,
70 // weight flags (default: medium)
71 wxFONTFLAG_LIGHT = 1 << 2,
72 wxFONTFLAG_BOLD = 1 << 3,
74 // anti-aliasing flag: force on or off (default: the current system default)
75 wxFONTFLAG_ANTIALIASED = 1 << 4,
76 wxFONTFLAG_NOT_ANTIALIASED = 1 << 5,
78 // underlined/strikethrough flags (default: no lines)
79 wxFONTFLAG_UNDERLINED = 1 << 6,
80 wxFONTFLAG_STRIKETHROUGH = 1 << 7,
82 // the mask of all currently used flags
83 wxFONTFLAG_MASK = wxFONTFLAG_ITALIC |
87 wxFONTFLAG_ANTIALIASED |
88 wxFONTFLAG_NOT_ANTIALIASED |
89 wxFONTFLAG_UNDERLINED |
90 wxFONTFLAG_STRIKETHROUGH
97 wxFONTENCODING_SYSTEM = -1, // system default
98 wxFONTENCODING_DEFAULT, // current default encoding
100 // ISO8859 standard defines a number of single-byte charsets
101 wxFONTENCODING_ISO8859_1, // West European (Latin1)
102 wxFONTENCODING_ISO8859_2, // Central and East European (Latin2)
103 wxFONTENCODING_ISO8859_3, // Esperanto (Latin3)
104 wxFONTENCODING_ISO8859_4, // Baltic (old) (Latin4)
105 wxFONTENCODING_ISO8859_5, // Cyrillic
106 wxFONTENCODING_ISO8859_6, // Arabic
107 wxFONTENCODING_ISO8859_7, // Greek
108 wxFONTENCODING_ISO8859_8, // Hebrew
109 wxFONTENCODING_ISO8859_9, // Turkish (Latin5)
110 wxFONTENCODING_ISO8859_10, // Variation of Latin4 (Latin6)
111 wxFONTENCODING_ISO8859_11, // Thai
112 wxFONTENCODING_ISO8859_12, // doesn't exist currently, but put it
113 // here anyhow to make all ISO8859
114 // consecutive numbers
115 wxFONTENCODING_ISO8859_13, // Baltic (Latin7)
116 wxFONTENCODING_ISO8859_14, // Latin8
117 wxFONTENCODING_ISO8859_15, // Latin9 (a.k.a. Latin0, includes euro)
118 wxFONTENCODING_ISO8859_MAX,
120 // Cyrillic charset soup (see http://czyborra.com/charsets/cyrillic.html)
121 wxFONTENCODING_KOI8, // we don't support any of KOI8 variants
122 wxFONTENCODING_ALTERNATIVE, // same as MS-DOS CP866
123 wxFONTENCODING_BULGARIAN, // used under Linux in Bulgaria
125 // what would we do without Microsoft? They have their own encodings
127 wxFONTENCODING_CP437, // original MS-DOS codepage
128 wxFONTENCODING_CP850, // CP437 merged with Latin1
129 wxFONTENCODING_CP852, // CP437 merged with Latin2
130 wxFONTENCODING_CP855, // another cyrillic encoding
131 wxFONTENCODING_CP866, // and another one
133 wxFONTENCODING_CP874, // WinThai
134 wxFONTENCODING_CP932, // Japanese (shift-JIS)
135 wxFONTENCODING_CP936, // Chinese simplified (GB)
136 wxFONTENCODING_CP949, // Korean (Hangul charset)
137 wxFONTENCODING_CP950, // Chinese (traditional - Big5)
138 wxFONTENCODING_CP1250, // WinLatin2
139 wxFONTENCODING_CP1251, // WinCyrillic
140 wxFONTENCODING_CP1252, // WinLatin1
141 wxFONTENCODING_CP1253, // WinGreek (8859-7)
142 wxFONTENCODING_CP1254, // WinTurkish
143 wxFONTENCODING_CP1255, // WinHebrew
144 wxFONTENCODING_CP1256, // WinArabic
145 wxFONTENCODING_CP1257, // WinBaltic (same as Latin 7)
146 wxFONTENCODING_CP12_MAX,
148 wxFONTENCODING_UTF7, // UTF-7 Unicode encoding
149 wxFONTENCODING_UTF8, // UTF-8 Unicode encoding
150 wxFONTENCODING_EUC_JP, // Extended Unix Codepage for Japanese
151 wxFONTENCODING_UTF16BE, // UTF-16 Big Endian Unicode encoding
152 wxFONTENCODING_UTF16LE, // UTF-16 Little Endian Unicode encoding
153 wxFONTENCODING_UTF32BE, // UTF-32 Big Endian Unicode encoding
154 wxFONTENCODING_UTF32LE, // UTF-32 Little Endian Unicode encoding
156 wxFONTENCODING_MACROMAN, // the standard mac encodings
157 wxFONTENCODING_MACJAPANESE,
158 wxFONTENCODING_MACCHINESETRAD,
159 wxFONTENCODING_MACKOREAN,
160 wxFONTENCODING_MACARABIC,
161 wxFONTENCODING_MACHEBREW,
162 wxFONTENCODING_MACGREEK,
163 wxFONTENCODING_MACCYRILLIC,
164 wxFONTENCODING_MACDEVANAGARI,
165 wxFONTENCODING_MACGURMUKHI,
166 wxFONTENCODING_MACGUJARATI,
167 wxFONTENCODING_MACORIYA,
168 wxFONTENCODING_MACBENGALI,
169 wxFONTENCODING_MACTAMIL,
170 wxFONTENCODING_MACTELUGU,
171 wxFONTENCODING_MACKANNADA,
172 wxFONTENCODING_MACMALAJALAM,
173 wxFONTENCODING_MACSINHALESE,
174 wxFONTENCODING_MACBURMESE,
175 wxFONTENCODING_MACKHMER,
176 wxFONTENCODING_MACTHAI,
177 wxFONTENCODING_MACLAOTIAN,
178 wxFONTENCODING_MACGEORGIAN,
179 wxFONTENCODING_MACARMENIAN,
180 wxFONTENCODING_MACCHINESESIMP,
181 wxFONTENCODING_MACTIBETAN,
182 wxFONTENCODING_MACMONGOLIAN,
183 wxFONTENCODING_MACETHIOPIC,
184 wxFONTENCODING_MACCENTRALEUR,
185 wxFONTENCODING_MACVIATNAMESE,
186 wxFONTENCODING_MACARABICEXT,
187 wxFONTENCODING_MACSYMBOL,
188 wxFONTENCODING_MACDINGBATS,
189 wxFONTENCODING_MACTURKISH,
190 wxFONTENCODING_MACCROATIAN,
191 wxFONTENCODING_MACICELANDIC,
192 wxFONTENCODING_MACROMANIAN,
193 wxFONTENCODING_MACCELTIC,
194 wxFONTENCODING_MACGAELIC,
195 wxFONTENCODING_MACKEYBOARD,
197 wxFONTENCODING_MACMIN = wxFONTENCODING_MACROMAN ,
198 wxFONTENCODING_MACMAX = wxFONTENCODING_MACKEYBOARD ,
200 wxFONTENCODING_MAX, // highest enumerated encoding value
203 // aliases for endian-dependent UTF encodings
204 wxFONTENCODING_UTF16, // native UTF-16
205 wxFONTENCODING_UTF32, // native UTF-32
207 // alias for the native Unicode encoding on this platform
208 // (this is used by wxEncodingConverter and wxUTFFile only for now)
209 wxFONTENCODING_UNICODE = wxFONTENCODING_UTF16,
211 // alternative names for Far Eastern encodings
213 wxFONTENCODING_GB2312 = wxFONTENCODING_CP936, // Simplified Chinese
214 wxFONTENCODING_BIG5 = wxFONTENCODING_CP950, // Traditional Chinese
216 // Japanese (see http://zsigri.tripod.com/fontboard/cjk/jis.html)
217 wxFONTENCODING_SHIFT_JIS = wxFONTENCODING_CP932 // Shift JIS
220 //---------------------------------------------------------------------------
223 // wxNativeFontInfo is platform-specific font representation: this struct
224 // should be considered as opaque font description only used by the native
225 // functions, the user code can only get the objects of this type from
226 // somewhere and pass it somewhere else (possibly save them somewhere using
227 // ToString() and restore them using FromString())
228 struct wxNativeFontInfo
234 // reset to the default state
237 // init with the parameters of the given font
238 void InitFromFont(const wxFont& font);
240 // accessors and modifiers for the font elements
241 int GetPointSize() const;
242 wxFontStyle GetStyle() const;
243 wxFontWeight GetWeight() const;
244 bool GetUnderlined() const;
245 wxString GetFaceName() const;
246 wxFontFamily GetFamily() const;
247 wxFontEncoding GetEncoding() const;
249 void SetPointSize(int pointsize);
250 void SetStyle(wxFontStyle style);
251 void SetWeight(wxFontWeight weight);
252 void SetUnderlined(bool underlined);
253 void SetFaceName(wxString facename);
254 void SetFamily(wxFontFamily family);
255 void SetEncoding(wxFontEncoding encoding);
257 // it is important to be able to serialize wxNativeFontInfo objects to be
258 // able to store them (in config file, for example)
259 bool FromString(const wxString& s);
260 wxString ToString() const;
264 return self->ToString();
268 // we also want to present the native font descriptions to the user in some
269 // human-readable form (it is not platform independent neither, but can
270 // hopefully be understood by the user)
271 bool FromUserString(const wxString& s);
272 wxString ToUserString() const;
278 struct wxNativeEncodingInfo
280 wxString facename; // may be empty meaning "any"
281 wxFontEncoding encoding; // so that we know what this struct represents
283 wxNativeEncodingInfo();
284 ~wxNativeEncodingInfo();
286 // this struct is saved in config by wxFontMapper, so it should know to
287 // serialise itself (implemented in platform-specific code)
288 bool FromString(const wxString& s);
289 wxString ToString() const;
294 // translate a wxFontEncoding into native encoding parameter (defined above),
295 // returning a wxNativeEncodingInfo if an (exact) match could be found, NULL
298 wxNativeEncodingInfo* wxGetNativeFontEncoding(wxFontEncoding encoding) {
299 static wxNativeEncodingInfo info;
300 if ( wxGetNativeFontEncoding(encoding, &info) )
307 // test for the existence of the font described by this facename/encoding,
308 // return True if such font(s) exist, False otherwise
309 bool wxTestFontEncoding(const wxNativeEncodingInfo& info);
314 wxNativeEncodingInfo* wxGetNativeFontEncoding(wxFontEncoding encoding)
315 { wxPyRaiseNotImplemented(); return NULL; }
317 bool wxTestFontEncoding(const wxNativeEncodingInfo& info)
318 { wxPyRaiseNotImplemented(); return False; }
322 //---------------------------------------------------------------------------
325 // wxFontMapper manages user-definable correspondence between logical font
326 // names and the fonts present on the machine.
328 // The default implementations of all functions will ask the user if they are
329 // not capable of finding the answer themselves and store the answer in a
330 // config file (configurable via SetConfigXXX functions). This behaviour may
331 // be disabled by giving the value of False to "interactive" parameter.
332 // However, the functions will always consult the config file to allow the
333 // user-defined values override the default logic and there is no way to
334 // disable this - which shouldn't be ever needed because if "interactive" was
335 // never True, the config file is never created anyhow.
337 // This is a singleton class, font mapper objects can only be accessed using
338 // wxFontMapper::Get().
346 // return instance of the wxFontMapper singleton
347 static wxFontMapper *Get();
348 // set the sigleton to 'mapper' instance and return previous one
349 static wxFontMapper *Set(wxFontMapper *mapper);
352 // returns the encoding for the given charset (in the form of RFC 2046) or
353 // wxFONTENCODING_SYSTEM if couldn't decode it
355 // interactive parameter is ignored in the base class, we behave as if it
357 virtual wxFontEncoding CharsetToEncoding(const wxString& charset,
358 bool interactive = True);
361 // get the number of font encodings we know about
362 static size_t GetSupportedEncodingsCount();
364 // get the n-th supported encoding
365 static wxFontEncoding GetEncoding(size_t n);
367 // return internal string identifier for the encoding (see also
368 // GetEncodingDescription())
369 static wxString GetEncodingName(wxFontEncoding encoding);
371 // return user-readable string describing the given encoding
373 // NB: hard-coded now, but might change later (read it from config?)
374 static wxString GetEncodingDescription(wxFontEncoding encoding);
377 // set the config object to use (may be NULL to use default)
378 void SetConfig(wxConfigBase *config);
380 // set the root config path to use (should be an absolute path)
381 void SetConfigPath(const wxString& prefix);
383 // return default config path
384 static const wxString GetDefaultConfigPath();
388 // Find an alternative for the given encoding (which is supposed to not be
389 // available on this system). If successful, returns the encoding otherwise
392 PyObject* GetAltForEncoding(wxFontEncoding encoding,
393 const wxString& facename = wxPyEmptyString,
394 bool interactive = True) {
395 wxFontEncoding alt_enc;
396 if (self->GetAltForEncoding(encoding, &alt_enc, facename, interactive))
397 return PyInt_FromLong(alt_enc);
406 // checks whether given encoding is available in given face or not.
407 // If no facename is given,
408 bool IsEncodingAvailable(wxFontEncoding encoding,
409 const wxString& facename = wxPyEmptyString);
411 // the parent window for modal dialogs
412 void SetDialogParent(wxWindow *parent);
414 // the title for the dialogs (note that default is quite reasonable)
415 void SetDialogTitle(const wxString& title);
421 //---------------------------------------------------------------------------
425 class wxFont : public wxGDIObject {
427 wxFont( int pointSize, int family, int style, int weight,
428 bool underline=False, const wxString& face = wxPyEmptyString,
429 wxFontEncoding encoding=wxFONTENCODING_DEFAULT);
432 %name(FontFromNativeInfo) wxFont(const wxNativeFontInfo& info);
434 %name(FontFromNativeInfoString) wxFont(const wxString& info) {
435 wxNativeFontInfo nfi;
436 nfi.FromString(info);
437 return new wxFont(nfi);
440 %name(Font2) wxFont(int pointSize,
442 int flags = wxFONTFLAG_DEFAULT,
443 const wxString& face = wxPyEmptyString,
444 wxFontEncoding encoding = wxFONTENCODING_DEFAULT) {
445 return wxFont::New(pointSize, family, flags, face, encoding);
450 // was the font successfully created?
452 %pythoncode { def __nonzero__(self): return self.Ok() }
456 bool __eq__(const wxFont* other) { return other ? (*self == *other) : False; }
457 bool __ne__(const wxFont* other) { return other ? (*self != *other) : True; }
460 // accessors: get the font characteristics
461 virtual int GetPointSize() const;
462 virtual int GetFamily() const;
463 virtual int GetStyle() const;
464 virtual int GetWeight() const;
465 virtual bool GetUnderlined() const;
466 virtual wxString GetFaceName() const;
467 virtual wxFontEncoding GetEncoding() const;
468 virtual const wxNativeFontInfo *GetNativeFontInfo() const;
470 virtual bool IsFixedWidth() const;
472 wxString GetNativeFontInfoDesc() const;
473 wxString GetNativeFontInfoUserDesc() const;
475 // change the font characteristics
476 virtual void SetPointSize( int pointSize );
477 virtual void SetFamily( int family );
478 virtual void SetStyle( int style );
479 virtual void SetWeight( int weight );
480 virtual void SetFaceName( const wxString& faceName );
481 virtual void SetUnderlined( bool underlined );
482 virtual void SetEncoding(wxFontEncoding encoding);
483 void SetNativeFontInfo(const wxNativeFontInfo& info);
484 %name(SetNativeFontInfoFromString) void SetNativeFontInfo(const wxString& info);
485 void SetNativeFontInfoUserDesc(const wxString& info);
487 // translate the fonts into human-readable string (i.e. GetStyleString()
488 // will return "wxITALIC" for an italic font, ...)
489 wxString GetFamilyString() const;
490 wxString GetStyleString() const;
491 wxString GetWeightString() const;
493 // Unofficial API, don't use
494 virtual void SetNoAntiAliasing( bool no = True );
495 virtual bool GetNoAntiAliasing();
497 // the default encoding is used for creating all fonts with default
498 // encoding parameter
499 static wxFontEncoding GetDefaultEncoding() { return ms_encodingDefault; }
500 static void SetDefaultEncoding(wxFontEncoding encoding);
505 //---------------------------------------------------------------------------
510 class wxPyFontEnumerator : public wxFontEnumerator {
512 wxPyFontEnumerator() {}
513 ~wxPyFontEnumerator() {}
515 DEC_PYCALLBACK_BOOL_STRING(OnFacename);
516 DEC_PYCALLBACK_BOOL_STRINGSTRING(OnFontEncoding);
521 IMP_PYCALLBACK_BOOL_STRING(wxPyFontEnumerator, wxFontEnumerator, OnFacename);
522 IMP_PYCALLBACK_BOOL_STRINGSTRING(wxPyFontEnumerator, wxFontEnumerator, OnFontEncoding);
526 %name(FontEnumerator) class wxPyFontEnumerator {
528 %pythonAppend wxPyFontEnumerator "self._setCallbackInfo(self, FontEnumerator, 0)"
530 wxPyFontEnumerator();
531 ~wxPyFontEnumerator();
532 void _setCallbackInfo(PyObject* self, PyObject* _class, bool incref);
534 bool EnumerateFacenames(
535 wxFontEncoding encoding = wxFONTENCODING_SYSTEM, // all
536 bool fixedWidthOnly = False);
538 bool EnumerateEncodings(const wxString& facename = wxPyEmptyString);
540 //wxArrayString* GetEncodings();
541 //wxArrayString* GetFacenames();
543 PyObject* GetEncodings() {
544 wxArrayString* arr = self->GetEncodings();
545 return wxArrayString2PyList_helper(*arr);
548 PyObject* GetFacenames() {
549 wxArrayString* arr = self->GetFacenames();
550 return wxArrayString2PyList_helper(*arr);
558 wxPyPtrTypeMap_Add("wxFontEnumerator", "wxPyFontEnumerator");
561 //---------------------------------------------------------------------------