[cbdt] Refactor get_strike()
This commit is contained in:
parent
6983cca9c8
commit
e2ba96da4c
|
@ -343,26 +343,21 @@ struct CBLC
|
||||||
}
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
const IndexSubtableRecord *find_table (hb_codepoint_t glyph,
|
const BitmapSizeTable &get_strike (hb_font_t *font,
|
||||||
unsigned int *x_ppem, unsigned int *y_ppem,
|
unsigned int *x_ppem, unsigned int *y_ppem) const
|
||||||
const void **base) const
|
|
||||||
{
|
{
|
||||||
/* TODO: Make it possible to select strike. */
|
/* TODO: Make it possible to select strike. */
|
||||||
|
|
||||||
unsigned int count = sizeTables.len;
|
unsigned int count = sizeTables.len;
|
||||||
for (uint32_t i = 0; i < count; ++i)
|
for (uint32_t i = 0; i < count; ++i)
|
||||||
{
|
{
|
||||||
unsigned int startGlyphIndex = sizeTables.arrayZ[i].startGlyphIndex;
|
*x_ppem = sizeTables[i].ppemX;
|
||||||
unsigned int endGlyphIndex = sizeTables.arrayZ[i].endGlyphIndex;
|
*y_ppem = sizeTables[i].ppemY;
|
||||||
if (startGlyphIndex <= glyph && glyph <= endGlyphIndex)
|
return sizeTables[i];
|
||||||
{
|
|
||||||
*x_ppem = sizeTables[i].ppemX;
|
|
||||||
*y_ppem = sizeTables[i].ppemY;
|
|
||||||
return sizeTables[i].find_table (glyph, this, base);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return nullptr;
|
*x_ppem = *y_ppem = 0;
|
||||||
|
return Null(BitmapSizeTable);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
@ -405,13 +400,13 @@ struct CBDT
|
||||||
inline bool get_extents (hb_font_t *font, hb_codepoint_t glyph,
|
inline bool get_extents (hb_font_t *font, hb_codepoint_t glyph,
|
||||||
hb_glyph_extents_t *extents) const
|
hb_glyph_extents_t *extents) const
|
||||||
{
|
{
|
||||||
unsigned int x_ppem = font->x_ppem, y_ppem = font->y_ppem;
|
|
||||||
|
|
||||||
if (!cblc)
|
if (!cblc)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
unsigned int x_ppem, y_ppem;
|
||||||
const void *base;
|
const void *base;
|
||||||
const IndexSubtableRecord *subtable_record = this->cblc->find_table (glyph, &x_ppem, &y_ppem, &base);
|
const BitmapSizeTable &strike = this->cblc->get_strike (font, &x_ppem, &y_ppem);
|
||||||
|
const IndexSubtableRecord *subtable_record = strike.find_table (glyph, cblc, &base);
|
||||||
if (!subtable_record || !x_ppem || !y_ppem)
|
if (!subtable_record || !x_ppem || !y_ppem)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
@ -454,23 +449,21 @@ struct CBDT
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline hb_blob_t* reference_png (hb_codepoint_t glyph_id,
|
inline hb_blob_t* reference_png (hb_font_t *font,
|
||||||
unsigned int x_ppem,
|
hb_codepoint_t glyph) const
|
||||||
unsigned int y_ppem) const
|
|
||||||
{
|
{
|
||||||
if (!cblc)
|
if (!cblc)
|
||||||
return hb_blob_get_empty ();
|
return hb_blob_get_empty ();
|
||||||
|
|
||||||
if (x_ppem == 0) x_ppem = upem;
|
unsigned int x_ppem, y_ppem;
|
||||||
if (y_ppem == 0) y_ppem = upem;
|
|
||||||
|
|
||||||
const void *base;
|
const void *base;
|
||||||
const IndexSubtableRecord *subtable_record = this->cblc->find_table (glyph_id, &x_ppem, &y_ppem, &base);
|
const BitmapSizeTable &strike = this->cblc->get_strike (font, &x_ppem, &y_ppem);
|
||||||
|
const IndexSubtableRecord *subtable_record = strike.find_table (glyph, cblc, &base);
|
||||||
if (!subtable_record || !x_ppem || !y_ppem)
|
if (!subtable_record || !x_ppem || !y_ppem)
|
||||||
return hb_blob_get_empty ();
|
return hb_blob_get_empty ();
|
||||||
|
|
||||||
unsigned int image_offset = 0, image_length = 0, image_format = 0;
|
unsigned int image_offset = 0, image_length = 0, image_format = 0;
|
||||||
if (!subtable_record->get_image_data (glyph_id, base, &image_offset, &image_length, &image_format))
|
if (!subtable_record->get_image_data (glyph, base, &image_offset, &image_length, &image_format))
|
||||||
return hb_blob_get_empty ();
|
return hb_blob_get_empty ();
|
||||||
|
|
||||||
switch (image_format)
|
switch (image_format)
|
||||||
|
|
|
@ -321,7 +321,7 @@ hb_ot_color_glyph_reference_png (hb_font_t *font, hb_codepoint_t glyph)
|
||||||
blob = _get_sbix (font->face).reference_png (font, glyph, nullptr, nullptr, nullptr);
|
blob = _get_sbix (font->face).reference_png (font, glyph, nullptr, nullptr, nullptr);
|
||||||
|
|
||||||
if (!blob->length && _get_cbdt (font->face).has_data ())
|
if (!blob->length && _get_cbdt (font->face).has_data ())
|
||||||
blob = _get_cbdt (font->face).reference_png (glyph, font->x_ppem, font->y_ppem);
|
blob = _get_cbdt (font->face).reference_png (font, glyph);
|
||||||
|
|
||||||
return blob;
|
return blob;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue