I got original ttf2fft source from [[ming:http://ming.sourceforge.net/]] web site. this original ttf2fft version is 1.0. The original ttf2fft require under Freetype 2.0.9. so I wrote this path to compile with Freetype2.2.1.
But I don't test kerning table conversion. Please use this path at your own risk.~
I got original ttf2fft source from [[ming:http://ming.sourceforge.net/]] web site. this original ttf2fft version is 1.0. The original ttf2fft require under Freetype 2.0.9. so I wrote this patch to compile with Freetype2.2.1.
But I don't test kerning table conversion. Please use this patch at your own risk.~
~
**Windows Binary [#e6eeff5c]
http://reddog.s35.xrea.com/software/ttf2fft.zip
**Comment [#dc4803c0]
#comment
**Patch [#xe24500b]
diff -uNr ttf2fft_old/ttf2fft.cxx ttf2fft/ttf2fft.cxx
--- ttf2fft_old/ttf2fft.cxx Sun Jan 11 03:49:11 2004
+++ ttf2fft/ttf2fft.cxx Wed Feb 28 20:54:12 2007
@@ -57,7 +57,7 @@
#include FT_CACHE_CHARMAP_H
#include <freetype/ftoutln.h>
#include <freetype/ftbbox.h>
-#include <freetype/internal/tttypes.h>
+//#include <freetype/internal/tttypes.h>
#include <freetype/ttnameid.h>
#include <stdio.h>
@@ -477,21 +477,21 @@
static double ratio_EM;
-int Outline_MoveTo_Func( FT_Vector * to, void * user ) {
+int Outline_MoveTo_Func(const FT_Vector * to, void * user ) {
Shape* shape = (Shape*) user;
//printf(" moveTo(%d, %d)\n", to->x, to->y);
shape->movePenTo((int)(to->x*ratio_EM), -(int)(to->y*ratio_EM));
return 0;
}
-static int Outline_LineTo_Func( FT_Vector * to, void * user ) {
+static int Outline_LineTo_Func(const FT_Vector * to, void * user ) {
Shape* shape = (Shape*) user;
//printf(" lineTo(%d, %d)\n", to->x, to->y);
shape->drawLineTo((int)(to->x*ratio_EM), -(int)(to->y*ratio_EM));
return 0;
}
-static int Outline_ConicTo_Func( FT_Vector* ctrl, FT_Vector * to, void * user ) {
+static int Outline_ConicTo_Func(const FT_Vector* ctrl,const FT_Vector * to, void * user ) {
Shape* shape = (Shape*) user;
//printf(" conicTo(%d, %d, %d, %d)\n",ctrl->x, ctrl->y, to->x, to->y);
shape->drawCurveTo((int)(ctrl->x*ratio_EM), -(int)(ctrl->y*ratio_EM),
@@ -499,7 +499,7 @@
return 0;
}
-static int Outline_CubicTo_Func( FT_Vector* ctrl1, FT_Vector* ctrl2, FT_Vector * to, void * user ) {
+static int Outline_CubicTo_Func(const FT_Vector* ctrl1,const FT_Vector* ctrl2,const FT_Vector * to, void * user ) {
Shape* shape = (Shape*) user;
//printf(" CUBICTo(%d, %d, %d, %d)\n",ctrl1->x, ctrl1->y, to->x, to->y);
return 1;
@@ -721,45 +721,42 @@
// probably we need to restrict writing only to codes from codetable
if( FT_HAS_KERNING(face) && FT_IS_SFNT(face) ) {
- printf(" writing kerning table\n");
- TT_Face ttface = (TT_Face) face;
- int nKern = ttface->num_kern_pairs;
-
- int* kern_table = new int[nKern*3];
+ Vector<int> ktable;
- int sz = 0;
- for( int i=0; i<nKern; i++ ) {
- TT_Kern0_Pair pair = ttface->kern_pairs + i;
- int left_idx = pair->left;
- int right_idx = pair->right;
- int value = (int) (pair->value*ratio_EM);
- if( value == 0 ) continue;
- //printf( "left: %d, right: %d, value: %d\n", left_idx, right_idx, value);
-
- int left_code = -1;
- for( int k=0; k<indexes.size(); k++ ) {
- if( indexes.elementAt(k) == left_idx ) {
- left_code = codetable.elementAt(k);
- break;
- }
- }
- if( left_code < 0 ) continue;
-
- int right_code = -1;
- for( int k=0; k<indexes.size(); k++ ) {
- if( indexes.elementAt(k) == right_idx ) {
- right_code = codetable.elementAt(k);
- break;
- }
- }
- if( right_code < 0 ) continue;
-
- kern_table[sz++] = left_code;
- kern_table[sz++] = right_code;
- kern_table[sz++] = value;
- }
-
- nKern = sz/3;
+ printf(" writing kerning table\n");
+ for( int n=0; n<indexes.size(); n++ ) {
+ int left = indexes.elementAt(n);
+ int right;
+ FT_Vector delta;
+
+ if (left < 0) continue;
+
+ for( int m=0; m<indexes.size(); m++ ) {
+ right = indexes.elementAt(m);
+
+ if (right < 0) continue;
+
+ if (FT_Get_Kerning(face, left, right, 0, &delta) == 0) {
+ if (delta.x != 0) break;
+ } else {
+ break;
+ }
+ }
+ if (delta.x == 0 || !error) continue;
+
+ ktable.addElement(left);
+ ktable.addElement(right);
+ ktable.addElement((int)(delta.x * ratio_EM));
+ }
+
+ int sz = ktable.size();
+ int nKern = sz/3;
+ int* kern_table = new int[sz];
+ for (int j=0; j<ktable.size();) {
+ kern_table[j] = ktable.elementAt(j); j++;
+ kern_table[j] = ktable.elementAt(j); j++;
+ kern_table[j] = ktable.elementAt(j); j++;
+ }
fob->writeWord( nKern );
for( int j=0; j<nKern; j++ ) {
HTML convert time: 0.002 sec.