Pango Reference Manual |
---|
Coverage Maps — Unicode character range coverage storage
enum PangoCoverageLevel; #define PANGO_TYPE_COVERAGE_LEVEL struct PangoCoverage; PangoCoverage* pango_coverage_new (void); PangoCoverage* pango_coverage_ref (PangoCoverage *coverage); void pango_coverage_unref (PangoCoverage *coverage); PangoCoverage* pango_coverage_copy (PangoCoverage *coverage); PangoCoverageLevel pango_coverage_get (PangoCoverage *coverage, int index_); void pango_coverage_max (PangoCoverage *coverage, PangoCoverage *other); void pango_coverage_set (PangoCoverage *coverage, int index_, PangoCoverageLevel level); void pango_coverage_to_bytes (PangoCoverage *coverage, guchar **bytes, int *n_bytes); PangoCoverage* pango_coverage_from_bytes (guchar *bytes, int n_bytes);
It is often necessary in Pango to determine if a particular font can represent a particular character, and also how well it can represent that character. The PangoCoverage is a data structure that is used to represent that information.
typedef enum { PANGO_COVERAGE_NONE, PANGO_COVERAGE_FALLBACK, PANGO_COVERAGE_APPROXIMATE, PANGO_COVERAGE_EXACT } PangoCoverageLevel;
Used to indicate how well a font can represent a particular ISO 10646 character point for a particular script.
PANGO_COVERAGE_NONE | The character is not representable with the font. |
PANGO_COVERAGE_FALLBACK | The character is represented in a way that may be comprehensible but is not the correct graphical form. For instance, a Hangul character represented as a a sequence of Jamos, or a Latin transliteration of a Cyrillic word. |
PANGO_COVERAGE_APPROXIMATE | The character is represented as basically the correct graphical form, but with a stylistic variant inappropriate for the current script. |
PANGO_COVERAGE_EXACT | The character is represented as the correct graphical form. |
#define PANGO_TYPE_COVERAGE_LEVEL (pango_coverage_level_get_type())
The GObject type for PangoCoverageLevel.
struct PangoCoverage;
The PangoCoverage structure represents a map from ISO-10646 character point to PangoCoverageLevel. It is an opaque structure with no public fields.
PangoCoverage* pango_coverage_new (void);
Create a new PangoCoverage
Returns : | a new PangoCoverage object, initialized to PANGO_COVERAGE_NONE with a reference count of 0. |
PangoCoverage* pango_coverage_ref (PangoCoverage *coverage);
Increase the reference count on the PangoCoverage by one
coverage : | a PangoCoverage |
Returns : | coverage |
void pango_coverage_unref (PangoCoverage *coverage);
Increase the reference count on the PangoCoverage by one. if the result is zero, free the coverage and all associated memory.
coverage : | a PangoCoverage |
PangoCoverage* pango_coverage_copy (PangoCoverage *coverage);
Copy an existing PangoCoverage. (This function may now be unecessary since we refcount the structure. Mail otaylorredhat.com if you use it.)
coverage : | a PangoCoverage |
Returns : | a copy of coverage with a reference count of 1 |
PangoCoverageLevel pango_coverage_get (PangoCoverage *coverage, int index_);
Determine whether a particular index is covered by coverage
coverage : | a PangoCoverage |
index_ : | the index to check |
Returns : |
void pango_coverage_max (PangoCoverage *coverage, PangoCoverage *other);
Set the coverage for each index in coverage to be the max (better) value of the current coverage for the index and the coverage for the corresponding index in other.
coverage : | a PangoCoverage |
other : | another PangoCoverage |
void pango_coverage_set (PangoCoverage *coverage, int index_, PangoCoverageLevel level);
Modify a particular index within coverage
coverage : | a PangoCoverage |
index_ : | the index to modify |
level : | the new level for index_ |
void pango_coverage_to_bytes (PangoCoverage *coverage, guchar **bytes, int *n_bytes);
Convert a PangoCoverage structure into a flat binary format
coverage : | a PangoCoverage |
bytes : | location to store result (must be freed with g_free()) |
n_bytes : | location to store size of result |
PangoCoverage* pango_coverage_from_bytes (guchar *bytes, int n_bytes);
Convert data generated from pango_converage_to_bytes() back to a PangoCoverage
bytes : | binary data representing a PangoCoverage |
n_bytes : | the size of bytes in bytes |
Returns : | a newly allocated PangoCoverage, or NULL if the data was invalid. |
<< OpenType Font Handling | Engines >> |