fix postscript hinter's handling of small and ghost stems

david-pic-changes
David Turner 18 years ago
parent b68e025c1b
commit 601aefe4ec
  1. 5
      ChangeLog
  2. 55
      src/pshinter/pshalgo.c

@ -1,3 +1,8 @@
2007-02-21 David Turner <david@freetype.org>
* src/pshinter/pshalgo.c: fixed a bug in the hinting of small
and ghost stems in the Postscript interpreter
2007-02-20 suzuki toshiya <mpsuzuki@hiroshima-u.ac.jp>
* src/base/ftmac.c (FT_GetFileRef_From_Mac_ATS_Name): Fix memory

@ -543,13 +543,54 @@
/* the stem is less than one pixel; we will center it
* around the nearest pixel center
*/
#if 1
pos = FT_PIX_FLOOR( pos + ( len >> 1 ) );
#else
/* this seems to be a bug! */
pos = pos + FT_PIX_FLOOR( len >> 1 );
#endif
len = 64;
if (len >= 32)
{
/* this is a special case where we also widen the stem
* and align it to the pixel grid.
*
* stem_center = pos + (len/2)
* nearest_pixel_center = FT_ROUND(stem_center-32)+32
* new_pos = nearest_pixel_center-32
* = FT_ROUND(stem_center-32)
* = FT_FLOOR(stem_center-32+32)
* = FT_FLOOR(stem_center)
* new_len = 64
*/
pos = FT_PIX_FLOOR( pos + (len >> 1) );
len = 64;
}
else if (len > 0)
{
/* this is a very small stem, we simply align it to the
* pixel grid, trying to find the minimal displacement
*
* left = pos
* right = pos + len
* left_nearest_edge = ROUND(pos)
* right_nearest_edge = ROUND(right)
*
* if ( ABS(left_nearest_edge - left) <= ABS(right_nearest_edge - right)
* new_pos = left
* else
* new_pos = right
*/
FT_Pos left_nearest = FT_PIX_ROUND(pos);
FT_Pos right_nearest = FT_PIX_ROUND(pos+len);
FT_Pos left_disp = left_nearest - pos;
FT_Pos right_disp = right_nearest - (pos+len);
if (left_disp < 0) left_disp = -left_disp;
if (right_disp < 0) right_disp = -right_disp;
if (left_disp <= right_disp)
pos = left_nearest;
else
pos = right_nearest;
}
else
{
/* this is a ghost stem, we're going to simply round it */
pos = FT_PIX_ROUND( pos );
}
}
else
{

Loading…
Cancel
Save