[type1,cid,type42] Minor improvements.
* src/type1/t1load.c (t1_parse_font_matrix): Scale units per EM only when necessary. Refresh comments. * src/cid/cidload.c (cid_parse_font_matrix): Ditto. * src/type42/t42parse.c (t42_parse_font_matrix): Refresh comments.
This commit is contained in:
parent
bd75a517dc
commit
a37da21a49
|
@ -1,3 +1,12 @@
|
||||||
|
2015-08-10 Alexei Podtelezhnikov <apodtele@gmail.com>
|
||||||
|
|
||||||
|
[type1,cid,type42] Minor improvements.
|
||||||
|
|
||||||
|
* src/type1/t1load.c (t1_parse_font_matrix): Scale units per EM only
|
||||||
|
when necessary. Refresh comments.
|
||||||
|
* src/cid/cidload.c (cid_parse_font_matrix): Ditto.
|
||||||
|
* src/type42/t42parse.c (t42_parse_font_matrix): Refresh comments.
|
||||||
|
|
||||||
2015-08-08 Werner Lemberg <wl@gnu.org>
|
2015-08-08 Werner Lemberg <wl@gnu.org>
|
||||||
|
|
||||||
[type42] Fix glyph access.
|
[type42] Fix glyph access.
|
||||||
|
|
|
@ -167,6 +167,7 @@
|
||||||
matrix = &dict->font_matrix;
|
matrix = &dict->font_matrix;
|
||||||
offset = &dict->font_offset;
|
offset = &dict->font_offset;
|
||||||
|
|
||||||
|
/* input is scaled by 1000 to accomodate default FontMatrix */
|
||||||
result = cid_parser_to_fixed_array( parser, 6, temp, 3 );
|
result = cid_parser_to_fixed_array( parser, 6, temp, 3 );
|
||||||
|
|
||||||
if ( result < 6 )
|
if ( result < 6 )
|
||||||
|
@ -180,15 +181,12 @@
|
||||||
return FT_THROW( Invalid_File_Format );
|
return FT_THROW( Invalid_File_Format );
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Set Units per EM based on FontMatrix values. We set the value to */
|
/* atypical case */
|
||||||
/* 1000 / temp_scale, because temp_scale was already multiplied by */
|
|
||||||
/* 1000 (in t1_tofixed, from psobjs.c). */
|
|
||||||
|
|
||||||
root->units_per_EM = (FT_UShort)FT_DivFix( 1000, temp_scale );
|
|
||||||
|
|
||||||
/* we need to scale the values by 1.0/temp[3] */
|
|
||||||
if ( temp_scale != 0x10000L )
|
if ( temp_scale != 0x10000L )
|
||||||
{
|
{
|
||||||
|
/* set units per EM based on FontMatrix values */
|
||||||
|
root->units_per_EM = (FT_UShort)FT_DivFix( 1000, temp_scale );
|
||||||
|
|
||||||
temp[0] = FT_DivFix( temp[0], temp_scale );
|
temp[0] = FT_DivFix( temp[0], temp_scale );
|
||||||
temp[1] = FT_DivFix( temp[1], temp_scale );
|
temp[1] = FT_DivFix( temp[1], temp_scale );
|
||||||
temp[2] = FT_DivFix( temp[2], temp_scale );
|
temp[2] = FT_DivFix( temp[2], temp_scale );
|
||||||
|
|
|
@ -1107,6 +1107,7 @@
|
||||||
FT_Int result;
|
FT_Int result;
|
||||||
|
|
||||||
|
|
||||||
|
/* input is scaled by 1000 to accomodate default FontMatrix */
|
||||||
result = T1_ToFixedArray( parser, 6, temp, 3 );
|
result = T1_ToFixedArray( parser, 6, temp, 3 );
|
||||||
|
|
||||||
if ( result < 6 )
|
if ( result < 6 )
|
||||||
|
@ -1124,15 +1125,12 @@
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Set Units per EM based on FontMatrix values. We set the value to */
|
/* atypical case */
|
||||||
/* 1000 / temp_scale, because temp_scale was already multiplied by */
|
|
||||||
/* 1000 (in t1_tofixed, from psobjs.c). */
|
|
||||||
|
|
||||||
root->units_per_EM = (FT_UShort)FT_DivFix( 1000, temp_scale );
|
|
||||||
|
|
||||||
/* we need to scale the values by 1.0/temp_scale */
|
|
||||||
if ( temp_scale != 0x10000L )
|
if ( temp_scale != 0x10000L )
|
||||||
{
|
{
|
||||||
|
/* set units per EM based on FontMatrix values */
|
||||||
|
root->units_per_EM = (FT_UShort)FT_DivFix( 1000, temp_scale );
|
||||||
|
|
||||||
temp[0] = FT_DivFix( temp[0], temp_scale );
|
temp[0] = FT_DivFix( temp[0], temp_scale );
|
||||||
temp[1] = FT_DivFix( temp[1], temp_scale );
|
temp[1] = FT_DivFix( temp[1], temp_scale );
|
||||||
temp[2] = FT_DivFix( temp[2], temp_scale );
|
temp[2] = FT_DivFix( temp[2], temp_scale );
|
||||||
|
|
|
@ -268,7 +268,7 @@
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* we need to scale the values by 1.0/temp_scale */
|
/* atypical case */
|
||||||
if ( temp_scale != 0x10000L )
|
if ( temp_scale != 0x10000L )
|
||||||
{
|
{
|
||||||
temp[0] = FT_DivFix( temp[0], temp_scale );
|
temp[0] = FT_DivFix( temp[0], temp_scale );
|
||||||
|
|
Loading…
Reference in New Issue