提交 e2ba96da 编写于 作者: B Behdad Esfahbod

[cbdt] Refactor get_strike()

上级 6983cca9
...@@ -343,26 +343,21 @@ struct CBLC ...@@ -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;
unsigned int endGlyphIndex = sizeTables.arrayZ[i].endGlyphIndex;
if (startGlyphIndex <= glyph && glyph <= endGlyphIndex)
{ {
*x_ppem = sizeTables[i].ppemX; *x_ppem = sizeTables[i].ppemX;
*y_ppem = sizeTables[i].ppemY; *y_ppem = sizeTables[i].ppemY;
return sizeTables[i].find_table (glyph, this, base); return sizeTables[i];
}
} }
return nullptr; *x_ppem = *y_ppem = 0;
return Null(BitmapSizeTable);
} }
protected: protected:
...@@ -405,13 +400,13 @@ struct CBDT ...@@ -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 ...@@ -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) ...@@ -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;
} }
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册