-
Notifications
You must be signed in to change notification settings - Fork 7
Trace bitmaps in scalable fonts
License
hanwen/mftrace
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
\input texinfo @c -*-texinfo-*- @setfilename README.info @settitle mftrace - Scalable Fonts for MetaFont @ignore Copyright (c) 1999--2006 by the authors Permission is granted to copy, distribute and/or modify this document under the terms of the GNU General Public License. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA @end ignore @include version.texi @node Top, , , @top @chapter mftrace - Scalable PostScript Fonts for MetaFont @section Introduction @code{mftrace} is a small Python program that lets you trace a @TeX{} bitmap font into a PFA or PFB font (A PostScript Type1 Scalable Font) or TTF (TrueType) font. It is licensed under the GNU GPL. Scalable fonts offer many advantages over bitmaps, as they allow documents to render correctly at many printer resolutions. Moreover, Ghostscript can generate much better PDF, if given scalable PostScript fonts. Versions prior to 1.0.5 were called `pktrace'. @section Download @itemize @item @uref{http://lilypond.org/download/sources/mftrace/mftrace-@mftversion{}.tar.gz} @item GIT at @uref{https://github.com/hanwen/mftrace} @end itemize @section Required @file{mftrace} is a thin Python wrapper around some other programs that do the real work: a tracing program and t1asm. To run mftrace you need: @itemize @bullet @item A tracing program: autotrace >= 0.30 (see @uref{http://autotrace.sourceforge.net} or potrace (see @uref{http://potrace.sourceforge.net}). Potrace is recommended as it runs quicker than autotrace. @item Python--2.2 or later. See @uref{http://www.python.org/} @item t1utils. See @uref{http://www.lcdf.org/~eddietwo/type/} @item TeX--your tex installation should include @itemize @bullet @item kpsewhich, @item MetaFont @end itemize @end itemize @section Recommended @itemize @bullet @item A recent version (040215 or newer) of @uref{http://fontforge.sourceforge.net,FontForge}. Some of @code{mftrace} functionality requires FontForge to be present on user's system. This includes rounding to integer, simplifying and autohinting font outlines, as well as generating any output formats except PFA, PFB and AFM. You should not request any of these features using @code{mftrace} options if you don't like your font to be run through FontForge (note that in this case you also have to explicitly specify @code{--noround} to disable rounding to integer). @item Alternatively, you need GhostScript with its @file{printafm} utility, available somethere in your PATH. @code{mftrace} uses @file{printafm} to generate AFM files in case there is no need to process the font with FontForge. @end itemize @section Red Hat A RPM may be built by issuing @example rpmbuild -tb mftrace-@var{version}.tar.gz @end example @section Debian GNU/Linux Users of Debian unstable (and Debian 3.0 when it is released) can install all requirements by running (as root): @example apt-get install mftrace @end example If you wish to also install the FontForge package to simplify and autohint the font, then run the command @example apt-get install fontforge @end example @section Install Install the prerequite packages. Then run @example ./configure make install @end example in the mftrace directory. Run as follows: @example mftrace cmr10 @end example @section Invoking mftrace. Command line options: @table @code @item --formats=LIST A comma-separated list of formats to generate. Choices include: AFM, PFA, PFB, TTF and SVG. Default is to generate a PFA file. Note that @file{fontforge} needs to be installed in order to generate any format except PFA or PFB. For generating AFM you need either @file{fontforge} or @file{ghostscript}. @item -e,--encoding=@var{enc} Use encoding file @var{enc}. Encoding files used by @code{mftrace} are basically in the GhostScript/dvips format, but you may use a special @code{.notavail} glyph name in order to tell mftrace not to process a specific glyph. If this option is not specified, mftrace will try to determine the encoding file automatically, from the encoding specified in the TFM file. @item --glyphs=@var{list} Only process glyphs in @var{list}, which is a comma-delimited list of decimal numbers or ranges. @example --glyphs 1-10,50,55,90-100 @end example @item --gffile=@var{name} = Take glyphs from file @var{name}. @item --grid @var{gridsize} Set reciprocal grid size in em units multiplied by ratio magnification/1000. For example @code{--grid 10 --magnification 1000} will round coordinates of control points to 1/10 of em unit. Useful simultaneously with @code{--noround} option. Default @var{gridsize} value is 1, i. e. round to integer. @item -h,--help help on options. @item -k,--keep Retain all temporary files in the directory @file{mftrace.dir/}. This is useful for debugging problems. @item --keep-trying Try to continue if external programs called by mftrace fail. If METAFONT crashes with overflow errors, but nevertheless outputs a GF file, try to process its output as is (useful for some buggy fonts, see below). If potrace/autotrace fails to trace a specific character, first try it with a less smoothed curve, and if that fails, skip the character. By default mftrace outputs @file{trace-bug-FONTNAME-NUMBER.pbm} and stops the process with a request to file a bugreport. @item --magnification The magnification to use for the PFA file. The default is 1000. The larger the more precise the PFA file will be. However, when magnification is too large METAFONT can crash with overflow errors. Sadly, many MF fonts contain resolution checks @example if dots_per_inch * design_size > 1500: ... @end example This check is susceptible to overflow errors. Such code should be reported as a bug, and changed to @example if dots_per_inch > (1500 / design_size): ... @end example @item --noround Don't round coordinates of control points to integer values. Useful simultaneously with @code{--grid} option. Disabled by default. @item -o,--output-base=FILE Output to FILE.pfa or FILE.pfb. @item --simplify Pass the font through FontForge for automatic simplification and hinting. @item --tfmfile=FILE Use @var{file} for the TFM file. This file is needed to determine at what resolution to run MetaFont. @item -V,--verbose Be verbose: print all commands as they are invoked. This is useful for debugging. @item -v,--version Print version number @item --dos-kpath Try to kludge up the paths coming from MikTeX for a cygwin environment. If this doesn't work, specify @code{--tfmfile} and @code{--encoding} manually. @item -w,--warranty show warranty and copyright @item --potrace use Potrace (default). @item --autotrace use AutoTrace. @item -D,--define=@var{symbol}=@var{value} Set the font info @var{symbol} to the given @var{value}. For example @code{-DFamilyName=Foo} sets the font family name to @code{Foo}. Mftrace tries to fill in sensible values for the FontName, FamilyName, FullName and Weight fields. It does so by guessing values for the CM font series. For other fonts, it tries to read an AFM file (which is not likely to exist). Suggestions for a more generic way to handle this are welcome. @end table Mftrace uses kpathsea for finding fonts, so any kpathsea variable can be used to fine-tune which files should be loaded. For example, you can set @code{MFINPUTS} to specify which paths to search for @file{.mf} files. Additional options may be passed to the backend program (potrace or autotrace) with the @code{MFTRACE_BACKEND_OPTIONS} environment variable. @section Discussion Why use @code{mftrace} over @uref{http://textrace.sourceforge.net,textrace}? Textrace and mftrace are functionally similar. However, mftrace is quicker, more cleanly written and can be installed using standard methods. Additionally, textrace requires perl, ghostscript and dvips. How about @uref{http://www.truetex.com,MetaFog}? MetaFog operates directly on the curves that generate the bitmap font, its outlines will probably be smaller and better. However, MetaFog is a proprietary product: its source code is not available, and it will only run on a limited number of platforms. How about @uref{ftp://bop.eps.gda.pl/pub/metatype1/,MetaType1}? MetaType1 is an approach that puts severe constraints on what may be done in a font program. It does not work for fonts containing overlaps and shaped pens. How about @uref{http://fontforge.sourceforge.net/,FontForge} itself? FontForge is an interactive editor, but it can be scripted. Since it supports bitmap tracing and @TeX{} bitmap fonts, it is possible to duplicate the functionality of mftrace. However, out of the box, FontForge does not recognize TeX encodings. @section Bugs and todo @itemize @item Environment variables containing relative directories, such as MFINPUTS or TFMINPUTS, are not handled correctly. @item Discuss fonts & copyright. @item Submit @file{tfm.py} to www.python.org. @file{tfm.py} is a python module to parse Tex Font Metric file. @end itemize Should you encounter any bug or problem, then please send a bugreport to @email{hanwen@@xs4all.nl,Han-Wen Nienhuys}. @section Author @email{hanwen@@xs4all.nl,Han-Wen Nienhuys} @section Credits Gf2pbm, the utility to convert a MetaFont GF file to a PBM file was based on Paul Vojta's Xdvi. The license notice is reproduced below. Thanks to all bughunters and contributors: Andrey V. Panov, Geoffrey Alan Washburn, @uref{http://www.maths.qmul.ac.uk/~jdg/,Julian Gilbey} G@"{u}nther Spahlinger, Richard Mahoney, Stanislav Brabec, and Thomas Bushnell BSG. @quotation Copyright (c) 1990-1999 Paul Vojta Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL PAUL VOJTA BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. @end quotation The rest of the package mftrace script itself is licensed under the @uref{http://www.gnu.org/licenses/gpl.txt,GNU General Public License}. @section See also @itemize @bullet @item @uref{http://partners.adobe.com/asn/developer/pdfs/tn/T1Format.pdf,Type1 font specification} @item @uref{http://partners.adobe.com/asn/developer/pdfs/tn/5015.Type1_Supp.pdf,Supplement to the Type1 specification}. @end itemize @bye
About
Trace bitmaps in scalable fonts
Resources
License
Stars
Watchers
Forks
Packages 0
No packages published