1 /***************************************************************************/
   2 /*                                                                         */
   3 /*  psblues.h                                                              */
   4 /*                                                                         */
   5 /*    Adobe's code for handling Blue Zones (specification).                */
   6 /*                                                                         */
   7 /*  Copyright 2009-2013 Adobe Systems Incorporated.                        */
   8 /*                                                                         */
   9 /*  This software, and all works of authorship, whether in source or       */
  10 /*  object code form as indicated by the copyright notice(s) included      */
  11 /*  herein (collectively, the "Work") is made available, and may only be   */
  12 /*  used, modified, and distributed under the FreeType Project License,    */
  13 /*  LICENSE.TXT.  Additionally, subject to the terms and conditions of the */
  14 /*  FreeType Project License, each contributor to the Work hereby grants   */
  15 /*  to any individual or legal entity exercising permissions granted by    */
  16 /*  the FreeType Project License and this section (hereafter, "You" or     */
  17 /*  "Your") a perpetual, worldwide, non-exclusive, no-charge,              */
  18 /*  royalty-free, irrevocable (except as stated in this section) patent    */
  19 /*  license to make, have made, use, offer to sell, sell, import, and      */
  20 /*  otherwise transfer the Work, where such license applies only to those  */
  21 /*  patent claims licensable by such contributor that are necessarily      */
  22 /*  infringed by their contribution(s) alone or by combination of their    */
  23 /*  contribution(s) with the Work to which such contribution(s) was        */
  24 /*  submitted.  If You institute patent litigation against any entity      */
  25 /*  (including a cross-claim or counterclaim in a lawsuit) alleging that   */
  26 /*  the Work or a contribution incorporated within the Work constitutes    */
  27 /*  direct or contributory patent infringement, then any patent licenses   */
  28 /*  granted to You under this License for that Work shall terminate as of  */
  29 /*  the date such litigation is filed.                                     */
  30 /*                                                                         */
  31 /*  By using, modifying, or distributing the Work you indicate that you    */
  32 /*  have read and understood the terms and conditions of the               */
  33 /*  FreeType Project License as well as those provided in this section,    */
  34 /*  and you accept them fully.                                             */
  35 /*                                                                         */
  36 /***************************************************************************/
  37 
  38 
  39   /*
  40    * A `CF2_Blues' object stores the blue zones (horizontal alignment
  41    * zones) of a font.  These are specified in the CFF private dictionary
  42    * by `BlueValues', `OtherBlues', `FamilyBlues', and `FamilyOtherBlues'.
  43    * Each zone is defined by a top and bottom edge in character space.
  44    * Further, each zone is either a top zone or a bottom zone, as recorded
  45    * by `bottomZone'.
  46    *
  47    * The maximum number of `BlueValues' and `FamilyBlues' is 7 each.
  48    * However, these are combined to produce a total of 7 zones.
  49    * Similarly, the maximum number of `OtherBlues' and `FamilyOtherBlues'
  50    * is 5 and these are combined to produce an additional 5 zones.
  51    *
  52    * Blue zones are used to `capture' hints and force them to a common
  53    * alignment point.  This alignment is recorded in device space in
  54    * `dsFlatEdge'.  Except for this value, a `CF2_Blues' object could be
  55    * constructed independently of scaling.  Construction may occur once
  56    * the matrix is known.  Other features implemented in the Capture
  57    * method are overshoot suppression, overshoot enforcement, and Blue
  58    * Boost.
  59    *
  60    * Capture is determined by `BlueValues' and `OtherBlues', but the
  61    * alignment point may be adjusted to the scaled flat edge of
  62    * `FamilyBlues' or `FamilyOtherBlues'.  No alignment is done to the
  63    * curved edge of a zone.
  64    *
  65    */
  66 
  67 
  68 #ifndef PSBLUES_H_
  69 #define PSBLUES_H_
  70 
  71 
  72 #include "psglue.h"
  73 
  74 
  75 FT_BEGIN_HEADER
  76 
  77 
  78   /*
  79    * `CF2_Hint' is shared by `cf2hints.h' and
  80    * `cf2blues.h', but `cf2blues.h' depends on
  81    * `cf2hints.h', so define it here.  Note: The typedef is in
  82    * `cf2glue.h'.
  83    *
  84    */
  85   enum
  86   {
  87     CF2_GhostBottom = 0x1,  /* a single bottom edge           */
  88     CF2_GhostTop    = 0x2,  /* a single top edge              */
  89     CF2_PairBottom  = 0x4,  /* the bottom edge of a stem hint */
  90     CF2_PairTop     = 0x8,  /* the top edge of a stem hint    */
  91     CF2_Locked      = 0x10, /* this edge has been aligned     */
  92                             /* by a blue zone                 */
  93     CF2_Synthetic   = 0x20  /* this edge was synthesized      */
  94   };
  95 
  96 
  97   /*
  98    * Default value for OS/2 typoAscender/Descender when their difference
  99    * is not equal to `unitsPerEm'.  The default is based on -250 and 1100
 100    * in `CF2_Blues', assuming 1000 units per em here.
 101    *
 102    */
 103   enum
 104   {
 105     CF2_ICF_Top    = cf2_intToFixed(  880 ),
 106     CF2_ICF_Bottom = cf2_intToFixed( -120 )
 107   };
 108 
 109 
 110   /*
 111    * Constant used for hint adjustment and for synthetic em box hint
 112    * placement.
 113    */
 114 #define CF2_MIN_COUNTER  cf2_doubleToFixed( 0.5 )
 115 
 116 
 117   /* shared typedef is in cf2glue.h */
 118   struct  CF2_HintRec_
 119   {
 120     CF2_UInt  flags;  /* attributes of the edge            */
 121     size_t    index;  /* index in original stem hint array */
 122                       /* (if not synthetic)                */
 123     CF2_Fixed  csCoord;
 124     CF2_Fixed  dsCoord;
 125     CF2_Fixed  scale;
 126   };
 127 
 128 
 129   typedef struct  CF2_BlueRec_
 130   {
 131     CF2_Fixed  csBottomEdge;
 132     CF2_Fixed  csTopEdge;
 133     CF2_Fixed  csFlatEdge; /* may be from either local or Family zones */
 134     CF2_Fixed  dsFlatEdge; /* top edge of bottom zone or bottom edge   */
 135                            /* of top zone (rounded)                    */
 136     FT_Bool  bottomZone;
 137 
 138   } CF2_BlueRec;
 139 
 140 
 141   /* max total blue zones is 12 */
 142   enum
 143   {
 144     CF2_MAX_BLUES      = 7,
 145     CF2_MAX_OTHERBLUES = 5
 146   };
 147 
 148 
 149   typedef struct  CF2_BluesRec_
 150   {
 151     CF2_Fixed  scale;
 152     CF2_UInt   count;
 153     FT_Bool    suppressOvershoot;
 154     FT_Bool    doEmBoxHints;
 155 
 156     CF2_Fixed  blueScale;
 157     CF2_Fixed  blueShift;
 158     CF2_Fixed  blueFuzz;
 159 
 160     CF2_Fixed  boost;
 161 
 162     CF2_HintRec  emBoxTopEdge;
 163     CF2_HintRec  emBoxBottomEdge;
 164 
 165     CF2_BlueRec  zone[CF2_MAX_BLUES + CF2_MAX_OTHERBLUES];
 166 
 167   } CF2_BluesRec, *CF2_Blues;
 168 
 169 
 170   FT_LOCAL( void )
 171   cf2_blues_init( CF2_Blues  blues,
 172                   CF2_Font   font );
 173   FT_LOCAL( FT_Bool )
 174   cf2_blues_capture( const CF2_Blues  blues,
 175                      CF2_Hint         bottomHintEdge,
 176                      CF2_Hint         topHintEdge );
 177 
 178 
 179 FT_END_HEADER
 180 
 181 
 182 #endif /* PSBLUES_H_ */
 183 
 184 
 185 /* END */