1 ///////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     font-related helper functions 
   4 // Author:      Vadim Zeitlin 
   8 // Copyright:   (c) wxWidgets team 
   9 // Licence:     wxWindows licence 
  10 ///////////////////////////////////////////////////////////////////////////// 
  12 // General note: this header is private to wxWidgets and is not supposed to be 
  13 // included by user code. The functions declared here are implemented in 
  14 // msw/fontutil.cpp for Windows, unix/fontutil.cpp for GTK/Motif &c. 
  16 #ifndef _WX_FONTUTIL_H_ 
  17 #define _WX_FONTUTIL_H_ 
  19 // ---------------------------------------------------------------------------- 
  21 // ---------------------------------------------------------------------------- 
  23 #include "wx/font.h"        // for wxFont and wxFontEncoding 
  25 #if defined(__WXMSW__) 
  26     #include "wx/msw/wrapwin.h" 
  29 class WXDLLIMPEXP_FWD_BASE wxArrayString
; 
  30 struct WXDLLIMPEXP_FWD_CORE wxNativeEncodingInfo
; 
  32 #if defined(_WX_X_FONTLIKE) 
  34 // the symbolic names for the XLFD fields (with examples for their value) 
  36 // NB: we suppose that the font always starts with the empty token (font name 
  37 //     registry field) as we never use nor generate it anyhow 
  40     wxXLFD_FOUNDRY
,     // adobe 
  41     wxXLFD_FAMILY
,      // courier, times, ... 
  42     wxXLFD_WEIGHT
,      // black, bold, demibold, medium, regular, light 
  43     wxXLFD_SLANT
,       // r/i/o (roman/italique/oblique) 
  44     wxXLFD_SETWIDTH
,    // condensed, expanded, ... 
  45     wxXLFD_ADDSTYLE
,    // whatever - usually nothing 
  46     wxXLFD_PIXELSIZE
,   // size in pixels 
  47     wxXLFD_POINTSIZE
,   // size in points 
  48     wxXLFD_RESX
,        // 72, 75, 100, ... 
  50     wxXLFD_SPACING
,     // m/p/c (monospaced/proportional/character cell) 
  51     wxXLFD_AVGWIDTH
,    // average width in 1/10 pixels 
  52     wxXLFD_REGISTRY
,    // iso8859, rawin, koi8, ... 
  53     wxXLFD_ENCODING
,    // 1, r, r, ... 
  57 #endif // _WX_X_FONTLIKE 
  59 // ---------------------------------------------------------------------------- 
  61 // ---------------------------------------------------------------------------- 
  63 // wxNativeFontInfo is platform-specific font representation: this struct 
  64 // should be considered as opaque font description only used by the native 
  65 // functions, the user code can only get the objects of this type from 
  66 // somewhere and pass it somewhere else (possibly save them somewhere using 
  67 // ToString() and restore them using FromString()) 
  68 class WXDLLEXPORT wxNativeFontInfo
 
  72     PangoFontDescription 
*description
; 
  73 #elif defined(_WX_X_FONTLIKE) 
  74     // the members can't be accessed directly as we only parse the 
  75     // xFontName on demand 
  77     // the components of the XLFD 
  78     wxString     fontElements
[wxXLFD_MAX
]; 
  83     // true until SetXFontName() is called 
  86     // return true if we have already initialized fontElements 
  87     inline bool HasElements() const; 
  90     // init the elements from an XLFD, return true if ok 
  91     bool FromXFontName(const wxString
& xFontName
); 
  93     // return false if we were never initialized with a valid XLFD 
  94     bool IsDefault() const { return m_isDefault
; } 
  96     // return the XLFD (using the fontElements if necessary) 
  97     wxString 
GetXFontName() const; 
  99     // get the given XFLD component 
 100     wxString 
GetXFontComponent(wxXLFDField field
) const; 
 102     // change the font component 
 103     void SetXFontComponent(wxXLFDField field
, const wxString
& value
); 
 106     void SetXFontName(const wxString
& xFontName
); 
 107 #elif defined(__WXMSW__) 
 109 #elif defined(__WXPM__) 
 110     // OS/2 native structures that define a font 
 114 #else // other platforms 
 116     //  This is a generic implementation that should work on all ports 
 117     //  without specific support by the port. 
 119     #define wxNO_NATIVE_FONTINFO 
 127     wxFontEncoding encoding
; 
 130     // default ctor (default copy ctor is ok) 
 131     wxNativeFontInfo() { Init(); } 
 135     void Init(const wxNativeFontInfo
& info
); 
 139     wxNativeFontInfo(const wxNativeFontInfo
& info
) { Init(info
); } 
 140     ~wxNativeFontInfo() { Free(); } 
 142     wxNativeFontInfo
& operator=(const wxNativeFontInfo
& info
) 
 148 #endif // wxUSE_PANGO 
 150     // reset to the default state 
 153     // init with the parameters of the given font 
 154     void InitFromFont(const wxFont
& font
) 
 156         // translate all font parameters 
 157         SetStyle((wxFontStyle
)font
.GetStyle()); 
 158         SetWeight((wxFontWeight
)font
.GetWeight()); 
 159         SetUnderlined(font
.GetUnderlined()); 
 160 #if defined(__WXMSW__) 
 161         if ( font
.IsUsingSizeInPixels() ) 
 162             SetPixelSize(font
.GetPixelSize()); 
 164             SetPointSize(font
.GetPointSize()); 
 166         SetPointSize(font
.GetPointSize()); 
 169         // set the family/facename 
 170         SetFamily((wxFontFamily
)font
.GetFamily()); 
 171         const wxString
& facename 
= font
.GetFaceName(); 
 172         if ( !facename
.empty() ) 
 174             SetFaceName(facename
); 
 177         // deal with encoding now (it may override the font family and facename 
 178         // so do it after setting them) 
 179         SetEncoding(font
.GetEncoding()); 
 182     // accessors and modifiers for the font elements 
 183     int GetPointSize() const; 
 184     wxSize 
GetPixelSize() const; 
 185     wxFontStyle 
GetStyle() const; 
 186     wxFontWeight 
GetWeight() const; 
 187     bool GetUnderlined() const; 
 188     wxString 
GetFaceName() const; 
 189     wxFontFamily 
GetFamily() const; 
 190     wxFontEncoding 
GetEncoding() const; 
 192     void SetPointSize(int pointsize
); 
 193     void SetPixelSize(const wxSize
& pixelSize
); 
 194     void SetStyle(wxFontStyle style
); 
 195     void SetWeight(wxFontWeight weight
); 
 196     void SetUnderlined(bool underlined
); 
 197     bool SetFaceName(const wxString
& facename
); 
 198     void SetFamily(wxFontFamily family
); 
 199     void SetEncoding(wxFontEncoding encoding
); 
 201     // sets the first facename in the given array which is found 
 202     // to be valid. If no valid facename is given, sets the 
 203     // first valid facename returned by wxFontEnumerator::GetFacenames(). 
 204     // Does not return a bool since it cannot fail. 
 205     void SetFaceName(const wxArrayString 
&facenames
); 
 208     // it is important to be able to serialize wxNativeFontInfo objects to be 
 209     // able to store them (in config file, for example) 
 210     bool FromString(const wxString
& s
); 
 211     wxString 
ToString() const; 
 213     // we also want to present the native font descriptions to the user in some 
 214     // human-readable form (it is not platform independent neither, but can 
 215     // hopefully be understood by the user) 
 216     bool FromUserString(const wxString
& s
); 
 217     wxString 
ToUserString() const; 
 220 // ---------------------------------------------------------------------------- 
 221 // font-related functions (common) 
 222 // ---------------------------------------------------------------------------- 
 224 // translate a wxFontEncoding into native encoding parameter (defined above), 
 225 // returning true if an (exact) macth could be found, false otherwise (without 
 226 // attempting any substitutions) 
 227 WXDLLIMPEXP_CORE 
bool wxGetNativeFontEncoding(wxFontEncoding encoding
, 
 228                                               wxNativeEncodingInfo 
*info
); 
 230 // test for the existence of the font described by this facename/encoding, 
 231 // return true if such font(s) exist, false otherwise 
 232 WXDLLIMPEXP_CORE 
bool wxTestFontEncoding(const wxNativeEncodingInfo
& info
); 
 234 // ---------------------------------------------------------------------------- 
 235 // font-related functions (X and GTK) 
 236 // ---------------------------------------------------------------------------- 
 238 #ifdef _WX_X_FONTLIKE 
 239     #include "wx/unix/fontutil.h" 
 242 #endif // _WX_FONTUTIL_H_