#include <gdi.h>
class CFontCache : public CBase |
Public Attributes | |
---|---|
TInt | iNumHits |
TInt | iNumMisses |
Public Member Functions | |
---|---|
CFontCache() | |
CFontCache(TInt) | |
~CFontCache() | |
IMPORT_C CFont * | AddEntryL(CFont *, const TFontSpec &) |
IMPORT_C CFont * | RemoveFirstEntry() |
IMPORT_C CFont * | Search(const TFontSpec &) |
Font cache.
When a CFont* needs to be found for a particular TFontSpec, the cache can be searched to see if the TFontSpec is already in the cache. If the TFontSpec is in the cache, its corresponding CFont* can be returned. Otherwise GetNearestFontInTwips() must be used to search all of the available fonts for the nearest CFont- a procedure which takes much longer than a simple cache search.
The current font cache should be destroyed and a new cache created whenever the zoom factor or device map changes, as these changes break the relation between CFont and TFontSpec.
TInt | iNumHits |
The number of cache hits since the font cache was created i.e. successful results from CFontCache::Search().
TInt | iNumMisses |
The number of cache misses since the font cache was created i.e. unsuccessful results from CFontCache::Search().
IMPORT_C | CFontCache | ( | ) |
Default constructor.
This constructs a CFontCache of size KMaxFontCacheEntries.
IMPORT_C | CFontCache | ( | TInt | aMaxEntries | ) |
Constructor specifying the number of cache entries.
Parameter | Description |
---|---|
aMaxEntries | Number of entries for this cache. You must ensure this is less than or equal to KMaxFontCacheEntries. |
IMPORT_C | ~CFontCache | ( | ) |
Destructor.
This destroys the cashe and releases its allocated memory.
Adds a font entry to the cache.
The font, and the font specification required to extract it from the cache, are both specified. If the cache is already full, the font replaces the oldest entry already in the cache, which is returned.
Parameter | Description |
---|---|
aFont | The font to be stored in the cache. |
aFontSpec | The font's corresponding font specification. |
Returns: If the cache isn't full, NULL is returned. If the cache is full, the displaced cache entry is returned.
IMPORT_C CFont * | RemoveFirstEntry | ( | ) |
Removes the first entry from the font cache and returns it.
Returns: The entry removed from the font cache. If the cache is empty, NULL is returned.
Searches the cache for a specified font.
The CFont returned is that which corresponds to the font specification aFontSpec.
Parameter | Description |
---|---|
aFontSpec | The specification of the font to be searched for. |
Returns: If an entry for the font specification is found in the cache, the pointer to the font corresponding to the font specification is returned. Otherwise NULL is returned.