shithub: freetype+ttf2subf

Download patch

ref: e6472c1251b6abdc884e63c752b862248eff8904
parent: 24fd93d6ec77155f5c2d604be2f7a1760d575919
author: David Turner <[email protected]>
date: Mon Apr 2 09:13:54 EDT 2007

detect "extra-light" fonts in the auto-hinter in order to avoid producing weird results with them

git/fs: mount .git/fs: mount/attach disallowed
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2007-04-02  David Turner  <[email protected]>
+
+	* src/autofit/aflatin.h, src/autofit/aflatin.c: add special code to
+	detect "extra-light" fonts and do not snap their stem widths too much
+	to avoid bizarre hinting effects.
+
 2007-03-28  David Turner  <[email protected]>
 
 	* src/base/ftbitmap.c (ft_bitmap_assure_buffer): Fix zero-ing of the
--- a/src/autofit/aflatin.c
+++ b/src/autofit/aflatin.c
@@ -133,6 +133,8 @@
 
         /* let's try 20% of the smallest width */
         axis->edge_distance_threshold = stdw / 5;
+        axis->standard_width          = stdw;
+        axis->extra_light             = 0;
       }
     }
 
@@ -523,6 +525,11 @@
       width->fit = width->cur;
     }
 
+   /* an extra-light axis corresponds to a standard width that is smaller
+    * than 0.75 pixels
+   */
+    axis->extra_light = (FT_MulFix(axis->standard_width, scale) < 32+8);
+
     if ( dim == AF_DIMENSION_VERT )
     {
       /* scale the blue zones */
@@ -1531,7 +1538,8 @@
     FT_Int           vertical = ( dim == AF_DIMENSION_VERT );
 
 
-    if ( !AF_LATIN_HINTS_DO_STEM_ADJUST( hints ) )
+    if ( !AF_LATIN_HINTS_DO_STEM_ADJUST( hints ) ||
+          axis->extra_light )
       return width;
 
     if ( dist < 0 )
--- a/src/autofit/aflatin.h
+++ b/src/autofit/aflatin.h
@@ -102,6 +102,8 @@
     FT_UInt          width_count;
     AF_WidthRec      widths[AF_LATIN_MAX_WIDTHS];
     FT_Pos           edge_distance_threshold;
+    FT_Pos           standard_width;
+    FT_Bool          extra_light;
 
     /* ignored for horizontal metrics */
     FT_Bool          control_overshoot;