2000-07-26 16:11:15 +02:00
|
|
|
#!/usr/bin/env python
|
|
|
|
#
|
|
|
|
|
|
|
|
#
|
|
|
|
# autohint math table builder
|
|
|
|
#
|
|
|
|
|
|
|
|
|
|
|
|
# Copyright 1996-2000 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.
|
|
|
|
|
|
|
|
|
2000-07-19 22:02:14 +02:00
|
|
|
import math
|
|
|
|
|
|
|
|
ag_pi = 256
|
|
|
|
|
|
|
|
def print_arctan( atan_bits ):
|
|
|
|
atan_base = 1 << atan_bits
|
2000-10-31 21:42:18 +01:00
|
|
|
|
2000-07-26 16:11:15 +02:00
|
|
|
print " static AH_Angle ag_arctan[1L << AG_ATAN_BITS] ="
|
|
|
|
print " {"
|
2000-10-31 21:42:18 +01:00
|
|
|
|
2000-07-19 22:02:14 +02:00
|
|
|
count = 0
|
2000-07-26 16:11:15 +02:00
|
|
|
line = " "
|
2000-10-31 21:42:18 +01:00
|
|
|
|
2000-07-26 16:11:15 +02:00
|
|
|
for n in range( atan_base ):
|
2000-07-19 22:02:14 +02:00
|
|
|
comma = ","
|
2000-07-26 16:11:15 +02:00
|
|
|
if ( n == atan_base - 1 ):
|
2000-07-19 22:02:14 +02:00
|
|
|
comma = ""
|
2000-10-31 21:42:18 +01:00
|
|
|
|
2000-07-26 16:11:15 +02:00
|
|
|
angle = math.atan( n * 1.0 / atan_base ) / math.pi * ag_pi
|
|
|
|
line = line + " " + repr( int( angle + 0.5 ) ) + comma
|
|
|
|
count = count + 1;
|
|
|
|
if ( count == 8 ):
|
2000-07-19 22:02:14 +02:00
|
|
|
count = 0
|
|
|
|
print line
|
2000-07-26 16:11:15 +02:00
|
|
|
line = " "
|
2000-10-31 21:42:18 +01:00
|
|
|
|
2000-07-26 16:11:15 +02:00
|
|
|
if ( count > 0 ):
|
2000-07-19 22:02:14 +02:00
|
|
|
print line
|
2000-07-26 16:11:15 +02:00
|
|
|
print " };"
|
2000-07-19 22:02:14 +02:00
|
|
|
|
|
|
|
|
2000-07-26 16:11:15 +02:00
|
|
|
# This routine is not used currently.
|
|
|
|
#
|
2000-07-19 22:02:14 +02:00
|
|
|
def print_sines():
|
2000-07-26 16:11:15 +02:00
|
|
|
print " static FT_Fixed ah_sines[AG_HALF_PI + 1] ="
|
|
|
|
print " {"
|
|
|
|
|
2000-07-19 22:02:14 +02:00
|
|
|
count = 0
|
2000-07-26 16:11:15 +02:00
|
|
|
line = " "
|
2000-10-31 21:42:18 +01:00
|
|
|
|
2000-07-26 16:11:15 +02:00
|
|
|
for n in range( ag_pi / 2 ):
|
|
|
|
sinus = math.sin( n * math.pi / ag_pi )
|
|
|
|
line = line + " " + repr( int( 65536.0 * sinus ) ) + ","
|
|
|
|
count = count + 1
|
|
|
|
if ( count == 8 ):
|
2000-07-19 22:02:14 +02:00
|
|
|
count = 0
|
|
|
|
print line
|
2000-07-26 16:11:15 +02:00
|
|
|
line = " "
|
2000-10-31 21:42:18 +01:00
|
|
|
|
2000-07-26 16:11:15 +02:00
|
|
|
if ( count > 0 ):
|
2000-07-19 22:02:14 +02:00
|
|
|
print line
|
2000-07-26 16:11:15 +02:00
|
|
|
print " 65536"
|
|
|
|
print " };"
|
2000-07-19 22:02:14 +02:00
|
|
|
|
2000-07-26 16:11:15 +02:00
|
|
|
|
|
|
|
print_arctan( 8 )
|
2000-07-19 22:02:14 +02:00
|
|
|
print
|
|
|
|
|
2000-07-26 16:11:15 +02:00
|
|
|
|
|
|
|
# END
|