Many computing systems can present information to a user by displaying text on a screen or some other media, such as a printed page. The physical characteristics of the human visual system and the various types and qualities of electronic display or print technology offer unique challenges to a type designer when developing typefaces in which the text can be presented.
In typography, a typeface consists of a coordinated set of character designs. A typeface is usually comprised of an alphabet of letters, numerals, punctuation marks, ideograms, and symbols (collectively referred to as characters or glyphs). Arial, Times New Roman, Verdana, and Georgia are four examples of typefaces. Traditionally, the word “font” denotes a complete typeface in a particular size (usually measured in points), weight (e.g., light, book, bold, black), and orientation (e.g., roman, italic, oblique). For a given typeface, each character typically corresponds to a single glyph, although certain characters of some typefaces may include multiple glyphs.
A typeface can originate as a series of glyphs drawn on paper or created in a computer drawing application. For example, the drawn glyphs may be scanned and digitized to render outline representations of each glyph. Alternatively, a typeface can be converted from typefaces of a different font format (e.g., from raster format to an outline in TrueType format). By at least these methods, the glyphs of a given typeface can be defined by outline definitions in a font file.
Generally, a glyph outline definition specifies a series of points and/or contours. A simple glyph outline may have only one contour whereas a complex glyph may have two or more contours. Furthermore, composite glyphs can be constructed by combining two or more simpler glyphs, and certain control characters with no visual manifestation map to glyphs with no contours.
When a glyph is to be rendered, the glyph outline is read from a font file and font cache scaled to a specified font size (e.g., 12 point) and display resolution (e.g., 72 dpi or dots per inch). The scaled outline is then altered by font hinting instructions to correct any perceived errors introduced by the scaling process, where the interaction of font size and display resolution can result in rounding error and introduce unintended and unwanted distortion to the glyph outline. Exemplary errors may include without limitation drop-outs (i.e., unintended gaps in the glyph), unintended variations in stroke weights or character heights, etc.
In one aspect of font hinting, instructions may access a control value table (CVT) to determine font control values that are to be applied consistently across the typeface. The font control values can specify consistent characteristics of glyphs within the typeface. For example, consistent stroke weights may be specified for vertical strokes of glyphs in the selected typeface. Other exemplary font control values may define the height of a lower case letter above a baseline, the distance a rounded bottom of a letter (e.g., ‘O’) may descend below a baseline, the space between the dot and the top of the vertical stroke of a lower case ‘i’, etc. The font hinting instructions can then alter the scaled font outlines to comply with the font control values, thereby yielding consistent characteristics for glyphs of a given typeface.
However, selecting the font control values representative of a large number of glyphs in a typeface is challenging. For example, the original outlines of different glyphs may exhibit some subtle and some not-so-subtle variations of a given font property (e.g., vertical stroke weights) across the typeface. As such, the measured font property can vary noticeably across a given typeface. Therefore, a typographer may manually and subjectively evaluate a distribution of the font property across multiple glyphs of a typeface to select one or more “acceptable” font control values to represent the entire or some substantial portion of a typeface. Unfortunately, manual determination of font control values is too expensive and time-consuming.
Implementations described and claimed herein allow automation of font control value selection by progressively filtering a distribution of font property values until a threshold number of font control values is identified. Font-hinting instructions may be parameterized using these algorithmically determined font control values, which may be derived from measurements of font properties of glyph outlines across the typeface. In one implementation, a distribution of the measured font properties is progressively filtered to identify a distribution characteristic satisfying a determined criterion, such as a threshold condition. The font property values corresponding to the threshold-satisfying points of the distribution are assigned as font control values.
In some implementations, articles of manufacture are provided as computer program products. One implementation of a computer program product provides a computer program storage medium readable by a computer system and encoding a computer program. Another implementation of a computer program product may be provided in a computer data signal embodied in a carrier wave by a computing system and encoding the computer program. Other implementations are also described and recited herein.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter.
Scalable outline fonts are defined as continuous shapes or outlines described by coordinates, mathematical curves, and/or other parameters. The base outlines are described in a font definition that can be read from memory (e.g., a font file or font cache) when an individual glyph is to be displayed or otherwise output (e.g., printed). Font definitions may be based on a Cartesian grid having x and y axes in font design units (or “font units), although other coordinate frameworks may be employed. Using such font units, a base outline of the glyph in the specified typeface may be described without regard to the displayed glyph size or the resolution of the output device.
When a glyph is to be generated, the base outline is scaled to a specified size and then used to create a discrete raster of dots (e.g., a bitmap of pixels) on a display or hardcopy output device at the specified size. If such a bitmap is made in a simplistic way, such as by simply turning off each pixel or printer cell that has its center lying within the scaled outline, then a number of visually distracting artifacts can arise, such as misalignments of features and breaks in shapes (referred to as “drop-outs”). For example, if the glyph is scaled and rendered at a small size and/or to a low resolution display, the pixels turned on/off to represent the glyph will only grossly approximate the scaled outline because the resulting pixels are too large and discrete in nature to perfectly follow the scaled outline.
As such, additional processing, called “font hinting”, may be employed to optimize the rendering of the glyph for a given size and display resolution. Font hinting code can be included in or associated with the font definition of each individual glyph. Font hinting provides information to the raster image processor (RIP) to enhance the rasterization of fonts. For example, font hinting may be used to alter or distort the scaled outline so as to improve the rendering. Among other uses, font hinting may be used to (1) ensure strokes intended to be equally thick appear equally thick; (2) suppress undesired overshoots (e.g., when a rounded letter, such as “O”, is unintentionally scaled to appear taller than flat letters, such as “M”); (3) line up features on different glyphs that should be at the same height; (4) keep the spaces between stems open (e.g., the spaces between the vertical strokes of an “m” should be visible); (5) force consistent spacing between sets of parallel strokes; and (6) compensate for errors in the rasterization algorithm, such as errors causing drop-outs.
In one implementation, font-hinting instructions can be divided into two categories: (1) per-font, and (2) per-glyph. The per-font instructions alter the outlines of individual glyphs based on font control values associated with multiple characters in the typeface. For example, a vertical stroke weight associated with most or all glyphs in a Courier New typeface is 84 font units. Accordingly, the per-font instructions can alter the vertical stroke weights of individual scaled outlines of such glyphs to satisfy the specified vertical stroke weight for the Courier New typeface. In this manner, glyphs of a common font tend to render with consistent characteristics, so that all such glyphs reflect a similar personality and readability across the typeface. In contrast, the per-glyph instructions are directed to make specific alterations for individual glyphs. For example, per-glyph instructions are likely to ensure that the vertical strokes in a lower case “m” are rendered with uniform, discernable vertical stroke weights and counter stroke weights (e.g., the “spaces” between the vertical strokes of the glyph).
Per-font instructions may be parameterized using per-font control values (called “font control values”) from a control value table (CVT). Individual font control values may be derived from measurements of properties (called “font properties”) of glyph outlines across the typeface. However, as these measurements may vary significantly across the typeface, one or more font control value selections are algorithmically made from a distribution of possible font property measurements and applied across multiple glyphs of the typeface. The algorithmic selection is executed by an auto-hinting module to obtain the font control values for the CVT
When the outlines are scaled (e.g., by a scaling module 110 of a text rendering system), rounding errors influenced by the display resolution may cause the two stroke weights to differ by a noticeable amount (see graphic block 112, in which the vertical right stem 114 is 11 pixels wide and the vertical left stem 116 is 10 pixels wide). Accordingly, a per-font preparation module 118 of the text rendering system extracts font control values from a control value datastore 120 (e.g., a control value table or CVT) with which to parameterize per-font instructions for achieving a more consistent rendering. In the example of
In one implementation for selecting font control values for the CVT, the auto hinting module 100 reads glyph outlines for a given typeface from a font library and generates distributions of specific font properties of each glyph outline (e.g., see distributions 202 and 204 of
If the font property distribution across the typeface indicates a number of local maxima that does not exceed a CVT threshold, the auto hinting module 100 sets font control values in the control value table equal to these maxima. For example, it is possible that a distribution for a given font property is limited to a single value across the typeface. In this case, the control value corresponding to that font property is set to that single value. In most circumstances, however, the font property distribution can include many possible font property values spread across a range. Therefore, the auto hinting module 100 uses filtering techniques to select an appropriate number of font control values based on the font property distribution.
It should be understood that other distribution characteristics may be used to select font control values, including local minima of a font property differential, lowest extremes, highest extremes, or other statistical instruments, such as standard deviation points, medians, averages, etc. for discrete analysis, or calculus for continuous analysis.
In one implementation, in order to select a limited number of font control values, the auto hinting module uses a sequence of filtering operations until an acceptable number of local maxima are achieved (i.e., a CVT threshold). In one implementation, a filter that suppresses high-frequency data is used, and in particular, a Gaussian blur filter is used, although other filters are also contemplated, including a box filter, a sinc filter or other filter to reduce high frequency noise. By applying a Gaussian blur filter having a filter width of 3 font units to the distribution 202, the filtered distribution 206 is achieved. The auto hinting module counts the local maxima of the filter distribution (e.g., by walking along the distribution and counting the detected local maxima therein).
In the example of
Filtered distribution 214 satisfies the CVT threshold condition of two. Accordingly, the x-values of the two local maxima (90 font units and 193 font units) are selected as the corresponding font control values relating to vertical stroke weight for the CVT of the Times New Roman typeface.
In alternative implementations, progressive filtering may involve cascading filters with differing properties, such that distributions at individual stages in the cascade exhibit progressively more pronounced filtering effects.
An identification module in the auto hinter executes a maxima operation 306 that identifies and counts local maxima in the font property distribution. In one implementation, the maxima operation 306 walks along the axis and detects points on the distribution having lower adjacent points on both sides. In alternative implementations, any standard calculus or other mathematical operations for identifying geometrical loci having extreme properties (e.g., maxima, minima, etc.) may be employed.
If the counted number of local maxima in the distribution is not greater than a CVT threshold, the CVT threshold condition is considered satisfied by a decision operation 308 and processing proceeds to a setting operation 312 (e.g., executed by a setting module of the auto hinter) that sets corresponding per-control values to the x coordinates of the local maxima. Otherwise, if the CVT threshold condition is not satisfied, a filtering operation 310 executed by a filtering module of the auto hinter filters the distribution to obtain a filtered distribution and processing returns to the maxima operation 306 to identify and count local maxima in the filtered distribution. At each iteration, the filtering strength is increased, as illustrated in and described with regard to
The exemplary hardware and operating environment of
The system bus 23 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, a switched fabric, point-to-point connections, and a local bus using any of a variety of bus architectures. The system memory may also be referred to as simply the memory, and includes read only memory (ROM) 24 and random access memory (RAM) 25. A basic input/output system (BIOS) 26, containing the basic routines that help to transfer information between elements within the computer 20, such as during start-up, is stored in ROM 24. The computer 20 further includes a hard disk drive 27 for reading from and writing to a hard disk, not shown, a magnetic disk drive 28 for reading from or writing to a removable magnetic disk 29, and an optical disk drive 30 for reading from or writing to a removable optical disk 31 such as a CD ROM or other optical media.
The hard disk drive 27, magnetic disk drive 28, and optical disk drive 30 are connected to the system bus 23 by a hard disk drive interface 32, a magnetic disk drive interface 33, and an optical disk drive interface 34, respectively. The drives and their associated computer-readable media provide nonvolatile storage of computer-readable instructions, data structures, program modules and other data for the computer 20. It should be appreciated by those skilled in the art that any type of computer-readable media which can store data that is accessible by a computer, such as magnetic cassettes, flash memory cards, digital video disks, random access memories (RAMs), read only memories (ROMs), and the like, may be used in the exemplary operating environment.
A number of program modules may be stored on the hard disk, magnetic disk 29, optical disk 31, ROM 24, or RAM 25, including an operating system 35, one or more application programs 36, other program modules 37, and program data 38. A user may enter commands and information into the personal computer 20 through input devices such as a keyboard 40 and pointing device 42. Other input devices (not shown) may include a microphone, joystick, game pad, satellite dish, scanner, or the like. These and other input devices are often connected to the processing unit 21 through a serial port interface 46 that is coupled to the system bus, but may be connected by other interfaces, such as a parallel port, game port, or a universal serial bus (USB). A monitor 47 or other type of display device is also connected to the system bus 23 via an interface, such as a video adapter 48. In addition to the monitor, computers typically include other peripheral output devices (not shown), such as speakers and printers.
The computer 20 may operate in a networked environment using logical connections to one or more remote computers, such as remote computer 49. These logical connections are achieved by a communication device coupled to or a part of the computer 20; the invention is not limited to a particular type of communications device. The remote computer 49 may be another computer, a server, a router, a network PC, a client, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 20, although only a memory storage device 50 has been illustrated in
When used in a LAN-networking environment, the computer 20 is connected to the local network 51 through a network interface or adapter 53, which is one type of communications device. When used in a WAN-networking environment, the computer 20 typically includes a modem 54, a network adapter, a type of communications device, or any other type of communications device for establishing communications over the wide area network 52. The modem 54, which may be internal or external, is connected to the system bus 23 via the serial port interface 46. In a networked environment, program modules depicted relative to the personal computer 20, or portions thereof, may be stored in the remote memory storage device. It is appreciated that the network connections shown are exemplary and other means of and communications devices for establishing a communications link between the computers may be used.
In an exemplary implementation, a scaling module, an auto hinting module, a per-font preparation module, a rendering module, a decision module, and other modules may be embodied by instructions stored in memory 404 and/or storage devices 408 and 410 and processed by the processing unit 402. Font definitions, font-hinting instructions, font property distributions, a CVT, CVT thresholds, rendered bitmaps, and other data may be stored in memory 404 and/or storage devices 408 and 410.
The technology described herein is implemented as logical operations and/or modules in one or more systems. The logical operations may be implemented as a sequence of processor-implemented steps executing in one or more computer systems and as interconnected machine or circuit modules within one or more computer systems. Likewise, the descriptions of various component modules may be provided in terms of operations executed or effected by the modules. The resulting implementation is a matter of choice, dependent on the performance requirements of the underlying system implementing the described technology. Accordingly, the logical operations making up the embodiments of the technology described herein are referred to variously as operations, steps, objects, or modules. Furthermore, it should be understood that logical operations may be performed in any order, unless explicitly claimed otherwise or a specific order is inherently necessitated by the claim language.
The above specification, examples and data provide a complete description of the structure and use of exemplary embodiments of the invention. Although various embodiments of the invention have been described above with a certain degree of particularity, or with reference to one or more individual embodiments, those skilled in the art could make numerous alterations to the disclosed embodiments without departing from the spirit or scope of this invention. In particular, it should be understood that the described technology may be employed independent of a personal computer. Other embodiments are therefore contemplated. It is intended that all matter contained in the above description and shown in the accompanying drawings shall be interpreted as illustrative only of particular embodiments and not limiting. Changes in detail or structure may be made without departing from the basic elements of the invention as defined in the following claims.
Although the subject matter has been described in language specific to structural features and/or methodological arts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts descried above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claimed subject matter.