提交 ae2f49e8 编写于 作者: P prr

8225286: Better rendering of native glyphs

Reviewed-by: serb, psadhukhan, mschoene, rhalade
上级 d5a0e4cf
...@@ -770,6 +770,13 @@ static void CopyFTSubpixelVToSubpixel(const void* srcImage, int srcRowBytes, ...@@ -770,6 +770,13 @@ static void CopyFTSubpixelVToSubpixel(const void* srcImage, int srcRowBytes,
} }
/* JDK does not use glyph images for fonts with a
* pixel size > 100 (see THRESHOLD in OutlineTextRenderer.java)
* so if the glyph bitmap image dimension is > 1024 pixels,
* something is up.
*/
#define MAX_GLYPH_DIM 1024
/* /*
* Class: sun_font_FreetypeFontScaler * Class: sun_font_FreetypeFontScaler
* Method: getGlyphImageNative * Method: getGlyphImageNative
...@@ -846,6 +853,15 @@ Java_sun_font_FreetypeFontScaler_getGlyphImageNative( ...@@ -846,6 +853,15 @@ Java_sun_font_FreetypeFontScaler_getGlyphImageNative(
/* generate bitmap if it is not done yet /* generate bitmap if it is not done yet
e.g. if algorithmic styling is performed and style was added to outline */ e.g. if algorithmic styling is performed and style was added to outline */
if (ftglyph->format == FT_GLYPH_FORMAT_OUTLINE) { if (ftglyph->format == FT_GLYPH_FORMAT_OUTLINE) {
FT_BBox bbox;
int w, h;
FT_Outline_Get_CBox(&(ftglyph->outline), &bbox);
w = (int)((bbox.xMax>>6)-(bbox.xMin>>6));
h = (int)((bbox.yMax>>6)-(bbox.yMin>>6));
if (w > MAX_GLYPH_DIM || h > MAX_GLYPH_DIM) {
glyphInfo = getNullGlyphImage();
return ptr_to_jlong(glyphInfo);
}
error = FT_Render_Glyph(ftglyph, FT_LOAD_TARGET_MODE(target)); error = FT_Render_Glyph(ftglyph, FT_LOAD_TARGET_MODE(target));
if (error != 0) { if (error != 0) {
return ptr_to_jlong(getNullGlyphImage()); return ptr_to_jlong(getNullGlyphImage());
...@@ -854,6 +870,11 @@ Java_sun_font_FreetypeFontScaler_getGlyphImageNative( ...@@ -854,6 +870,11 @@ Java_sun_font_FreetypeFontScaler_getGlyphImageNative(
width = (UInt16) ftglyph->bitmap.width; width = (UInt16) ftglyph->bitmap.width;
height = (UInt16) ftglyph->bitmap.rows; height = (UInt16) ftglyph->bitmap.rows;
if (width > MAX_GLYPH_DIM || height > MAX_GLYPH_DIM) {
glyphInfo = getNullGlyphImage();
return ptr_to_jlong(glyphInfo);
}
imageSize = width*height; imageSize = width*height;
glyphInfo = (GlyphInfo*) malloc(sizeof(GlyphInfo) + imageSize); glyphInfo = (GlyphInfo*) malloc(sizeof(GlyphInfo) + imageSize);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册