summaryrefslogtreecommitdiff
path: root/src/pshinter/pshalgo2.h
blob: 575712cc37761c016a70306bd39bffec7bb7941c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
/***************************************************************************/
/*                                                                         */
/*  pshalgo2.h                                                             */
/*                                                                         */
/*    First (basic) Postscript hinting routines                            */
/*                                                                         */
/*  Copyright 2001 by                                                      */
/*  David Turner, Robert Wilhelm, and Werner Lemberg.                      */
/*                                                                         */
/*  This file is part of the FreeType project, and may only be used,       */
/*  modified, and distributed under the terms of the FreeType project      */
/*  license, LICENSE.TXT.  By continuing to use, modify, or distribute     */
/*  this file you indicate that you have read the license and              */
/*  understand and accept it fully.                                        */
/*                                                                         */
/***************************************************************************/

#ifndef __PS_HINTER_ALGO2_H__
#define __PS_HINTER_ALGO2_H__

#include "pshrec.h"
#include "pshglob.h"
#include FT_TRIGONOMETRY_H

FT_BEGIN_HEADER

  typedef struct PSH2_HintRec_*   PSH2_Hint;

  typedef enum
  {
    PSH2_HINT_GHOST  = PS_HINT_FLAG_GHOST,
    PSH2_HINT_BOTTOM = PS_HINT_FLAG_BOTTOM,
    PSH2_HINT_ACTIVE = 4,
    PSH2_HINT_FITTED = 8  
  } PSH2_Hint_Flags;

#define  psh2_hint_is_active(x)  (((x)->flags  & PSH2_HINT_ACTIVE) != 0)
#define  psh2_hint_is_ghost(x)   (((x)->flags  & PSH2_HINT_GHOST)  != 0)  
#define  psh2_hint_is_fitted(x)  (((x)->flags  & PSH2_HINT_FITTED) != 0)

#define  psh2_hint_activate(x)     (x)->flags |=  PSH2_HINT_ACTIVE
#define  psh2_hint_deactivate(x)   (x)->flags &= ~PSH2_HINT_ACTIVE
#define  psh2_hint_set_fitted(x)   (x)->flags |=  PSH2_HINT_FITTED

  typedef struct PSH2_HintRec_
  {
    FT_Int     org_pos;
    FT_Int     org_len;
    FT_Pos     cur_pos;
    FT_Pos     cur_len;
    FT_UInt    flags;
    PSH2_Hint  parent;
    FT_Int     order;
  
  } PSH2_HintRec;


 /* this is an interpolation zone used for strong points   */
 /* weak points are interpolated according to their strong */
 /* neighbours..                                           */
  typedef struct PSH2_ZoneRec_
  {
    FT_Fixed  scale;
    FT_Fixed  delta;
    FT_Pos    min;
    FT_Pos    max;
    
  } PSH2_ZoneRec, *PSH2_Zone;


  typedef struct PSH2_Hint_TableRec_
  {
    FT_UInt        max_hints;
    FT_UInt        num_hints;
    PSH2_Hint      hints;
    PSH2_Hint*     sort;
    PSH2_Hint*     sort_global;
    FT_UInt        num_zones;
    PSH2_Zone      zones;
    PSH2_Zone      zone;
    PS_Mask_Table  hint_masks;
    PS_Mask_Table  counter_masks;
    
  } PSH2_Hint_TableRec, *PSH2_Hint_Table;

  typedef struct PSH2_PointRec_*    PSH2_Point;
  typedef struct PSH2_ContourRec_*  PSH2_Contour;
  
  enum
  {
    PSH2_DIR_NONE   =  4,
    PSH2_DIR_UP     =  1,
    PSH2_DIR_DOWN   = -1,
    PSH2_DIR_LEFT   = -2,
    PSH2_DIR_RIGHT  =  2
  };
  
  enum
  {
    PSH2_POINT_OFF    = 1,   /* point is off the curve  */
    PSH2_POINT_STRONG = 2,   /* point is strong         */
    PSH2_POINT_SMOOTH = 4,   /* point is smooth         */
    PSH2_POINT_FITTED = 8    /* point is already fitted */
  };


  typedef struct PSH2_PointRec_
  {
    PSH2_Point    prev;
    PSH2_Point    next;
    PSH2_Contour  contour;
    FT_UInt       flags;
    FT_Char       dir_in;
    FT_Char       dir_out;
    FT_Angle      angle_in;
    FT_Angle      angle_out;
    PSH2_Hint     hint;
    FT_Pos        org_u;
    FT_Pos        cur_u;
#ifdef DEBUG_HINTER
    FT_Pos        org_x;
    FT_Pos        cur_x;
    FT_Pos        org_y;
    FT_Pos        cur_y;
    FT_UInt       flags_x;
    FT_UInt       flags_y;
#endif    
    
  } PSH2_PointRec;

#define  psh2_point_is_strong(p)   ((p)->flags & PSH2_POINT_STRONG)
#define  psh2_point_is_fitted(p)   ((p)->flags & PSH2_POINT_FITTED)
#define  psh2_point_is_smooth(p)   ((p)->flags & PSH2_POINT_SMOOTH)

#define  psh2_point_set_strong(p)  (p)->flags |= PSH2_POINT_STRONG
#define  psh2_point_set_fitted(p)  (p)->flags |= PSH2_POINT_FITTED
#define  psh2_point_set_smooth(p)  (p)->flags |= PSH2_POINT_SMOOTH

  typedef struct PSH2_ContourRec_
  {
    PSH2_Point  start;
    FT_UInt     count;
   
  } PSH2_ContourRec;

  

  typedef struct PSH2_GlyphRec_
  {
    FT_UInt             num_points;
    FT_UInt             num_contours;
    
    PSH2_Point          points;
    PSH2_Contour        contours;
               
    FT_Memory           memory;
    FT_Outline*         outline;
    PSH_Globals         globals;
    PSH2_Hint_TableRec  hint_tables[2];
    
    FT_Bool             vertical;
    FT_Int              major_dir;
    FT_Int              minor_dir;
    
  } PSH2_GlyphRec, *PSH2_Glyph;


#ifdef DEBUG_HINTER  
  extern  PSH2_Hint_Table  ps2_debug_hint_table;

  typedef void  (*PSH2_HintFunc)( PSH2_Hint  hint, FT_Bool vertical );
  extern  PSH2_HintFunc    ps2_debug_hint_func;
  
  extern  PSH2_Glyph       ps2_debug_glyph;
#endif


  extern FT_Error
  ps2_hints_apply( PS_Hints      ps_hints,
                   FT_Outline*   outline,
                   PSH_Globals   globals );

FT_END_HEADER

#endif /* __PS_HINTS_ALGO_2_H__ */