This is necessary to recognize new fonts, for example those added using AddPrivateFont(), as being valid: otherwise they were not found in the cache and couldn't be used in wxGTK.
		
			
				
	
	
		
			103 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Objective-C
		
	
	
	
	
	
			
		
		
	
	
			103 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Objective-C
		
	
	
	
	
	
| /////////////////////////////////////////////////////////////////////////////
 | |
| // Name:        fontenum.h
 | |
| // Purpose:     interface of wxFontEnumerator
 | |
| // Author:      wxWidgets team
 | |
| // Licence:     wxWindows licence
 | |
| /////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| /**
 | |
|     @class wxFontEnumerator
 | |
| 
 | |
|     wxFontEnumerator enumerates either all available fonts on the system or only
 | |
|     the ones with given attributes - either only fixed-width (suited for use in
 | |
|     programs such as terminal emulators and the like) or the fonts available in
 | |
|     the given encoding).
 | |
| 
 | |
|     To do this, you just have to call one of EnumerateXXX() functions - either
 | |
|     wxFontEnumerator::EnumerateFacenames() or wxFontEnumerator::EnumerateEncodings()
 | |
|     and the corresponding callback (wxFontEnumerator::OnFacename() or
 | |
|     wxFontEnumerator::OnFontEncoding()) will be called repeatedly until either
 | |
|     all fonts satisfying the specified criteria are exhausted or the callback
 | |
|     returns @false.
 | |
| 
 | |
|     @section fontenum_virtual Virtual functions to override
 | |
| 
 | |
|     Either OnFacename or OnFontEncoding should be overridden depending on
 | |
|     whether you plan to call EnumerateFacenames or EnumerateEncodings.
 | |
|     Of course, if you call both of them, you should override both functions.
 | |
| 
 | |
|     @library{wxcore}
 | |
|     @category{gdi}
 | |
| 
 | |
|     @see @ref overview_fontencoding, @ref page_samples_font, wxFont, wxFontMapper
 | |
| */
 | |
| class wxFontEnumerator
 | |
| {
 | |
| public:
 | |
|     wxFontEnumerator();
 | |
|     virtual ~wxFontEnumerator();
 | |
| 
 | |
|     /**
 | |
|         Call OnFontEncoding() for each encoding supported by the given font -
 | |
|         or for each encoding supported by at least some font if @a font is not specified.
 | |
|     */
 | |
|     virtual bool EnumerateEncodings(const wxString& font = wxEmptyString);
 | |
| 
 | |
|     /**
 | |
|         Call OnFacename() for each font which supports given encoding (only if
 | |
|         it is not @c wxFONTENCODING_SYSTEM) and is of fixed width
 | |
|         (if @a fixedWidthOnly is @true).
 | |
| 
 | |
|         Calling this function with default arguments will result in enumerating all
 | |
|         fonts available on the system.
 | |
|     */
 | |
|     virtual bool EnumerateFacenames(wxFontEncoding encoding = wxFONTENCODING_SYSTEM,
 | |
|                                     bool fixedWidthOnly = false);
 | |
| 
 | |
|     /**
 | |
|         Return array of strings containing all encodings found by
 | |
|         EnumerateEncodings().
 | |
|     */
 | |
|     static wxArrayString GetEncodings(const wxString& facename = wxEmptyString);
 | |
| 
 | |
|     /**
 | |
|         Return array of strings containing all facenames found by
 | |
|         EnumerateFacenames().
 | |
|     */
 | |
|     static wxArrayString GetFacenames(wxFontEncoding encoding = wxFONTENCODING_SYSTEM,
 | |
|                                       bool fixedWidthOnly = false);
 | |
| 
 | |
|     /**
 | |
|         Returns @true if the given string is valid face name, i.e. it's the face name
 | |
|         of an installed font and it can safely be used with wxFont::SetFaceName.
 | |
|     */
 | |
|     static bool IsValidFacename(const wxString& facename);
 | |
| 
 | |
|     /**
 | |
|         Invalidate cache used by some of the methods of this class internally.
 | |
| 
 | |
|         This method should be called if the list of the fonts available on the
 | |
|         system changes, for whatever reason. In particular, it is called
 | |
|         automatically by wxFont::AddPrivateFont().
 | |
| 
 | |
|         @since 3.1.1
 | |
|      */
 | |
|     static void InvalidateCache();
 | |
| 
 | |
|     /**
 | |
|         Called by EnumerateFacenames() for each match.
 | |
| 
 | |
|         Return @true to continue enumeration or @false to stop it.
 | |
|     */
 | |
|     virtual bool OnFacename(const wxString& font);
 | |
| 
 | |
|     /**
 | |
|         Called by EnumerateEncodings() for each match.
 | |
| 
 | |
|         Return @true to continue enumeration or @false to stop it.
 | |
|     */
 | |
|     virtual bool OnFontEncoding(const wxString& font,
 | |
|                                 const wxString& encoding);
 | |
| };
 | |
| 
 |