This invention generally relates to systems, methods, and computer-readable media associated with fonts and representations of fonts. Example aspects of this invention relate to designing, storing, compiling, and rendering high-quality, compact fonts that are useful over a wide variety of text sizes and on devices of varying system size and/or resolution.
Improvements in computer related technologies have spawned a wide variety of computer-containing devices that access, store, and display information to their users. Such devices include, for example, laptops and other personal computers (including pen-based computing systems and hand-held computing systems); personal digital assistants; pocket personal computers; mobile and cellular telephones, pagers, and other communication devices; watches; appliances; and many other devices or systems that include monitors or other display devices that present printed and/or graphical information to users. In recent years, such devices have become smaller, lighter, faster, more powerful, and more reliable than ever.
While often taken for granted by the device users, printed or graphical information does not magically appear on display devices, and it does not magically render from printers or other devices associated with computer systems. Rather, the content and appearance of printed and graphical information are carefully controlled by the computer system, display device, and/or printer to assure that it renders in a proper and aesthetically pleasing manner. Displayed and printed information must appear in typefaces and font designs that are easy to read irrespective of the desired text size and/or the resolution of the rendering system.
Fonts based on Latin scripts and other character-based fonts generally have a relatively limited number of characters (e.g., the American-English alphabet has fifty-two letters (capital and small letters), ten numerals, punctuation, and up to approximately a few hundred other commonly used characters or symbols). Accordingly, the characters or “glyphs” associated with Latin-based fonts or other character-based fonts generally may be provided as stored outline descriptions and/or stored bitmap descriptions of the various characters at different desired text sizes, for each desired font on a system. Because of the relatively small number of characters or glyphs present in many Latin-based fonts or other character-based fonts, the memory footprint of the font (that is, the amount of computer system memory required to store the font) is not excessively large, even when stored bitmap descriptions are provided for each character at each desired text size.
Various fonts for Asian scripts and/or other ideographic, pictographic, and complex scripts, on the other hand, may contain more than 60,000 independent characters or glyphs, and many currently used Asian scripts (or other ideographic-based scripts, pictographic-based scripts, and complex scripts) contain at least tens of thousands of glyphs. Providing outline descriptions for each glyph and/or providing individual bitmap descriptions for this large number of glyphs at every desired text size on a computer system requires many megabytes of data and a large amount of file storage space. This large memory footprint can be too large for the storing, retrieving, and processing constraints of many computing devices, such as small, mobile, or hand held devices or other devices that have limited data storage space, limited memory, and/or limited processing capacity. This problem is further exacerbated in devices that enable user selection and/or dynamic download of a variety of different fonts and/or text display sizes.
In an effort to reduce the overall size of ideographic-based fonts, some font designers and producers have sought to create smaller versions of the fonts. For example, smaller versions of a font may be created by removing glyphs, features, or bitmaps from the font. This approach, however, also reduces the functionality of the font.
In another effort to reduce the overall size of ideographic-based fonts, some font designers and producers have used an approach called “glyph compositing.” Instead of storing full-form outline and/or bitmap descriptions of entire glyphs for every character, one static “generic” copy of each commonly occurring glyph part or glyph fragment is stored (along with a lesser number of full-form entire glyph descriptions). In this way, the glyph parts and fragments can be shared and reused for the reconstruction of many glyphs. Although this approach reduces the overall size of the font, the font size often is still too large for devices with small amounts of available memory. Further, in this approach, many details of the natural glyph shapes are lost, and the overall quality of the reconstructed or reassembled glyph images often is reduced.
Accordingly, there is a need in the art for systems and methods that will allow fonts, including fonts with large character sets and glyph sets, to remain intact and that will enable devices to support full character complements and families of fonts and produce high quality rendered output at a variety of device resolutions and text display sizes, without overburdening the memory and processing capabilities of the computing system or device. It further would be advantageous to provide a font representation that produces high quality output on small mobile devices and/or other devices having limited or reduced memory and/or processing capabilities.
Aspects of the present invention include numerous approaches that help to improve legibility and aesthetic appearance of a font representation and/or decrease storage size required for a font representation.
Numerous aspects of this invention are applicable to font representations of various scripts (including Latin and East Asian scripts) and are independent of any particular font format or script type. Some aspects can be especially beneficial if applied to structured ideographic fonts. Some aspects help contribute to the quality of font representations that are to be rendered at small text sizes or/and low display resolutions. Additional aspects of the invention relate to reusability of font objects and extensions of the TrueType technology.
Different aspects of the invention address multiple issues in such primary areas as geometrical descriptions of font elements and instructing font elements (e.g., specification of possible modifications of the appearance of a font element under different conditions). Both areas are considered in close connection to use of a component-wise structure of a font representation. While numerous aspects of the invention may be applied independently of a particular structure of a font representation, some other aspects provide methods that can be differentially applied to different font elements (such as glyphs, radicals, and strokes) based on characteristics specific to a particular type of font element. Because one of the ultimate purposes of a font representation is to provide high quality rendering results, aspects of this invention analyze in detail how different elements of a font representation can be “tuned,” depending, for example, on actual characteristics of the rendered image to be produced (such as pixels regions available for rendering a glyph, glyph parts, and/or glyph components), hardware specifications, run-time parameters, etc.
Aspects of the invention also aim to propose additional opportunities for high quality designs of font representations and do not imply any necessary limitations. For example, font representations in accordance with at least some examples of the invention can support any desired level of tradeoff between diversity of the font design and compactness (which typically leads to some uniformity of the design). Many aspects of the present invention can be easily supported by existing font technology (including existing font formats, existing rendering engines (such as TrueType), etc.). However, some can benefit (for example, contribute to compactness of a font representation) if supported by special features of a font format and rendering engine. Therefore, some possible extension of currently existing font technology is possible in accordance with at least some aspects of this invention.
According to at least some aspects of the present invention, multiple geometrical descriptions of the same font elements, including, for example, a combination of trajectory-based geometrical descriptions, outline-based geometrical descriptions, and optionally bitmap-based descriptions and/or augmented trajectory-based descriptions, may be combined. These different descriptions may be designed independently and may be used under different conditions (for example, based on run time parameters, such as available space or ppem for the rendering, system resolution, font size, etc.), so that for every combination of possible rendering conditions, a rendered image of a font element will have an optimal appearance. A single rendering engine may be used to render these font objects from the various different descriptions. This approach allows the font to “cover” complete glyph sets and complete ranges of ppems with a relatively simple design and without significant memory space expenses. The approach has a potential to significantly reduce the need for bitmap descriptions of font elements without compromising rendered quality. This results in a decrease of required storage size (as compared to corresponding font representations containing a significant number of bitmap-based descriptions). It also contributes to sub-setting of a font for conditions known a priory. Additional aspects of the invention provide approaches for handling enhancing features of font elements or font objects (such as serifs, special stroke ending features, and the like), which also contribute to the overall quality of a font representation.
Still other aspects of the invention relate to instructing elements of a font representation. In particular, for componentized font representations, aspects of the invention propose such rules and means of control that can increase reusability of the font components, which also contributes to compactness of a font representation and provides a possibility to design every one of the font components more carefully, which naturally leads to a better quality. According to some aspects of the present invention, instructing code associated with a font component may be sensitive both to the context of a component in a specific glyph (e.g., on information that may vary from glyph to glyph) and to run-time information (e.g., on information that may vary from one run-time request of a specific glyph to another request), and the code should not impose any specific limitations on possible modifications of a component's data. The use of componentized font representations and instructing code supports pixel-hinting and its applications to elements of font representations at any level of a hierarchy, as well as to parameters of the conditional rules associated with the elements.
In accordance with at least some examples of the present invention, instructing code may be associated with reusable radical components to make any rendering of the component sensitive to an arrangement of the radical components or guiding frames associated with radical components in a particular glyph. In accordance with still other example aspects of the present invention, rules associated with reusable radical components may be provided that will be responsible for generation of a simplified form of a radical (e.g., by eliminating one or more strokes in the radical) whenever there is not enough pixel space available for legible or complete rendering of a full representation of the radical as a component of a font object (e.g., may use guiding frame data for the radical and/or pixel availability information).
Additional aspects included in at least some examples of font representations according to this invention may include:
As one more specific example, additional aspects of this invention may include methods for rendering a desired font object that include: receiving input data indicating a desired font object to be rendered; obtaining data for rendering the desired font object from a font object data set, wherein the font object data set includes data corresponding to a description of the desired font object and data corresponding to at least one augmenting trajectory description corresponding to an enhancing feature for at least one portion of the desired font object; and rendering the desired font object using the obtained data. Use of the augmenting data may be optional, so methods according to this aspect of the invention additionally may include determining whether to use the augmenting trajectory description during the rendering. This determination may include evaluation of one or more “run time parameters,” such as data relating to an amount of space available for rendering the desired font object; data relating to a guiding frame size for the desired font object when rendered; data relating to a text size for rendering the desired font object; data relating to a resolution associated with the rendering of the desired font object; and data relating to ppem associated with the rendering of the desired font object. Additionally, if desired, the size, shape, location, or other characteristics of the enhancing feature may be modified, e.g., based on input data during the rendering.
In at least some examples, the augmenting trajectory data used for rendering the desired font object may, at least in part, define a region that encloses one or more pixels. In such situations, during the rendering step, all of the pixels located fully within this enclosed region may be activated in the same manner as the other pixels activated in rendering the desired font object (e.g., so that the enclosed area will not enclose unactivated pixels).
Additional aspects of the invention may relate to methods for rendering a desired font object that include: receiving input data indicating a desired font object to be rendered; selecting a data set for providing data for rendering at least a first portion of the desired font object, wherein the data set is selected from the group consisting of: (i) a first data set that includes data relating to at least the first portion of the desired font object in a first format, and (ii) a second data set that includes data relating to at least the first portion of the desired font object in a second format, wherein the data set is selected, at least in part, based on a pixel region available for rendering at least the first portion of the desired font object; and rendering at least the first portion of the desired font object using the selected data set. Again, the selected data set(s) may include one or more augmenting data descriptions corresponding to one or more enhancing features for the desired font object, as generally described above. When the desired font object includes at least a second portion, the second portion also may include an augmenting data description corresponding to an enhancing feature, and the selecting may include determining whether to use the second augmenting data description during the rendering, optionally, based at least in part on the pixel region available for rendering the second portion.
Another example aspect of the invention relates to methods for rendering a desired font object that include: receiving input data indicating a desired font object to be rendered; obtaining data for rendering the desired font object from a font object data set, wherein the font object data set includes data corresponding to at least a first augmenting data description corresponding to a first enhancing feature for the desired font object; determining whether to use the first augmenting data description based, at least in part, on a pixel region available for rendering at least a first portion of the desired font object including the first enhancing feature; and rendering the desired font object, wherein the desired font object is rendered using the first augmenting data description when the determining step determines that the pixel region available for rendering the first portion of the desired font object is large enough to display the first enhancing feature and wherein the desired font object is rendered without using the first augmenting data description when the determining step determines that the pixel region available for rendering the first portion of the desired font object is not large enough to display the first enhancing feature. Of course, these same procedures may be used, if desired, for determining whether to render a second or additional enhancing features for the desired font object.
Still an additional aspect of the invention relates to methods for rendering a desired font object that include: receiving a first data set for rendering at least a first portion of the desired font object wherein the first data set includes data relating to a guiding frame associated with at least the first portion of the desired font object; receiving a second data set for rendering at least a second portion of the desired font object; and rendering the desired font object using at least the first data set and the second data set, wherein the data relating to the guiding frame is used in determining at least one of a position, size, or shape of at least some part of the second portion of the desired font object during the rendering. An additional or alternative aspect of the invention relates to methods for rendering a desired font object, that include: receiving a first data set for rendering at least a first portion of the desired font object wherein the first data set includes data relating to a guiding frame associated with at least the first portion of the desired font object; and rendering the desired font object using at least the first data set, wherein the data relating to the guiding frame is used in determining at least one of a position, size, or shape of at least some part of the first portion of the desired font object during the rendering.
Additional aspects of the invention relate to hinting when rendering font objects. One example of this aspect relates to methods for rendering a desired font object that include: receiving a first data set for rendering at least a first portion of the desired font object wherein the first data set includes data relating to a guiding frame associated with at least the first portion of the desired font object; receiving a second data set for rendering at least a second portion of the desired font object; and rendering the desired font object using at least the first data set and the second data set, wherein the data relating to the guiding frame is used in hinting at least some part of the second portion of the desired font object during the rendering. Another example of this aspect of the invention relates to methods for rendering a desired font object that include: receiving a first data set for rendering at least a first portion of the desired font object wherein the first data set includes data relating to a guiding frame associated with at least the first portion of the desired font object; and rendering the desired font object using at least the first data set, wherein the rendering includes hinting of the guiding frame to, at least in part, control a position or size of at least a part of the first portion of the desired font object.
An additional example aspect of the invention relates to methods for rendering a desired font object that include: receiving input data indicating a desired font object to be rendered, wherein the desired font object includes plural portions; determining an amount of pixel space available for rendering the desired font object; and rendering a complete version of the desired font object when the amount of pixel space available is sufficient to render the complete version of the desired font object and rendering a modified version of the desired font object when the amount of pixel space available is insufficient to render the complete version of the desired font object, wherein the modified version of the desired font object has eliminated at least one portion as compared to the complete version of the desired font object. Still another example aspect of the invention relates to methods for rendering a desired font object, that include: receiving input data indicating a desired font object to be rendered, wherein the desired font object includes at least a first portion and a second portion; determining an amount of pixel space available for rendering the desired font object; and rendering a complete version of the desired font object, including the first portion and the second portion, when the amount of pixel space available is sufficient to render the complete version of the desired font object and rendering a modified version of the desired font object when the amount of pixel space available is insufficient to render the complete version of the desired font object, wherein the modified version of the desired font object has substituted a third portion for at least one of the first portion or the second portion as compared to the complete version of the desired font object.
Aspects of the invention also relate to systems, rendering engines, and computer-readable media including computer-executable instructions stored thereon for performing various methods, including the methods described above.
Another specific example aspect of the invention relates to computer-readable media including data stored thereon for rendering font objects, wherein the data includes, for example: a first data set including mathematical representations of plural font objects in a conventional TrueType font format (e.g., in an outline format); and a second data set including mathematical representations of plural font objects in a trajectory format, wherein the mathematical representations in the second data set are TrueType compatible representations. The data sets may be stored on the media in one or more tables without departing from the invention.
Rendering systems in accordance with examples of this invention may include, for example: means for receiving input indicating a desired font object to be rendered; and a rendering engine for providing data for rendering the desired font object, wherein the rendering engine has access to computer-readable media including at least a first data set stored thereon for rendering plural font objects including the desired font object, wherein the first data set includes mathematical representations of plural font objects including the desired font object in a trajectory format, wherein the mathematical representations in the first data set are TrueType compatible representations. Another example rendering system according to the invention may include: means for receiving input indicating a desired font object to be rendered; and a TrueType rendering engine for providing data for rendering the desired font object, wherein the TrueType rendering engine includes access to data for at least one hinting procedure associated with the desired font object as part of the rendering, wherein the hinting procedure includes at least one member selected from the group consisting of: hinting at least some portion of the desired font object based on a guiding frame associated with a different portion of the desired font object; hinting a guiding frame associated with a first portion of the desired font object to, at least in part, control a position or size of at least a part of the first portion of the desired font object; hinting to eliminate at least one portion of the desired font object based on a size of a guiding frame associated with at least a first portion of the desired font object; and hinting to substitute at least one stroke in the desired font object with a different stroke based on a size of a guiding frame associated with at least a first portion of the desired font object.
The above and other objects, features, and advantages of the present invention will be more readily apparent and more fully understood from the following detailed description, taken in conjunction with the appended drawings, in which:
I. Terms
The following terms are used herein, and unless otherwise noted or clear from the context, these terms have the meanings provided below.
“Hierarchical Representation” or “Structured Representation”—A “hierarchical” or “structured” representation of a glyph or font, as used herein, means that glyph data corresponding to at least some glyphs in a font is composed from data corresponding to one or more separate radicals (and these individual radicals may be repeated in a single glyph and/or in several glyphs in the font), and further that at least some radicals in the glyphs may be composed from data corresponding to one or more separate strokes (and these individual strokes may be repeated within a single radical, in numerous glyphs, and/or in other radicals in the font). In some instances or examples, individual strokes also may be composed from data corresponding to one or more “stroke portions,” which may include data corresponding to various stroke enhancing features (such as end features, serifs, or the like) that are individual or common to plural strokes, radicals, and/or glyphs in the font. In addition, and alternatively, some glyphs may be directly composed from one or more stroke components and/or one or more stroke enhancing features without any specified radical component. There is no limitation imposed to the possible kinds hierarchies supported by fonts in accordance with examples of the invention and/or to the number of levels in any particular hierarchical structure.
“Simple Glyph” or “Simple Glyph Representation” or “Non-Hierarchical Glyph” or “Non-Hierarchical Glyph Representation”—These terms all are used interchangeably to refer to a glyph or glyph representation that has a single level of description and no additional component parts.
“Glyph”—The term “glyph” refers to a shape that is defined in a font to represent a character or another graphic element on screen, on paper, on any display device, on any display medium, and/or output in any other manner. As used herein, glyphs include, but are not necessarily limited to representations of: letters, characters, symbols, shapes, graphics, icons, ideographic characters, pictographic characters, and the like. Glyphs may be composed of one or more independent instances of radicals and/or strokes and/or stroke portions. A glyph may contain multiple instances of the same radical and/or multiple instances of the same stroke and/or multiple instances of the same stroke portion. The term “glyph” also may refer to the physical displayed image of a character or other graphic element.
“Radical”—The term “radical” refers to a conceptual building block of a glyph, or to a sub-symbol included as part of at least some glyphs. A radical typically comprises a set of one or more associated (or grouped) strokes that may appear separately, connected, or overlapping within a glyph when rendered. Although there is similarity, the term “radical,” as used herein, is broader and more general than the rather restricted term “radical” used in formal linguistics and used in describing certain parts of East Asian writing systems (such as Chinese, Japanese, and Korean). In this specification, the term “radical” may apply to glyph components that are artificially, but purposefully constructed, e.g., to improve system performance, reduce overall font size or the like, and such “radicals” may have no analog in formal linguistics or written ideographic, pictographic, or complex scripts.
“Stroke”—A building block of or a sub-symbol included as part of at least one radical and/or glyph. A stroke is typically a continuous uninterrupted single marking segment akin to a segment produced by one brush or pen movement in handwritten text. A stroke also may be akin to a portion of one brush or pen movement in handwritten text. Also, as used herein, a stroke may be any artificial, but purposefully made element of a glyph object whether or not it corresponds to any analog of written text.
“Display device”—Any device on which, or through which, information (including printed, visual, and/or graphical information) is presented to a user. Such devices may include, but are not necessarily limited to: computer screens or monitors (including, but not limited to monitors associated with laptops, desktops, pen-based computing systems, handheld computing systems, and the like); LCD, LED, plasma, or other display surfaces (including, but not limited to display screens or surfaces associated with computers, televisions, telephones, pagers, other communication devices, watches, personal digital assistants, appliances, and the like); a projector for projecting an image including virtual images and including rendered information onto a surface, screen or wall; and the like.
“Render” or “Rendered” or “Rendering”—The process of determining how information (including text, graphics, and/or electronic ink) is to be displayed, whether on a surface, on a screen, printed, displayed using a projector, or output in some other manner. With respect to fonts, the term “rendering” may include the process of converting run-time contextual information and data (such as, requested character/glyph identifiers, device resolution, requested text display size, and the like) and stored font data and information (e.g., outlines, bitmaps, trajectories, and the like) into final display-ready images (also called “rendered images”), e.g., through the transformational steps of scaling, grid fitting, pixel-hinting, scan conversion, and the like. “Rendering” is not limited to black-and-white displays. Rather, information may be rendered in color, in grayscale, and/or in any appropriate format or method without departing from the invention.
“Rendering Engine”—The software and programs involved in the process of rendering font data and/or other information.
“Rendering Device”—Any device that provides, produces, or makes available rendered information in its final presentation form, including printed and/or graphical information. In addition to “display devices” as described above, rendering devices include printers (e.g., dot matrix printers, ink jet printers, laser jet printers, copiers, and the like); typewriters; and the like.
“Computer-Readable Medium”—The term “computer-readable medium” refers to any available media that can be accessed by a user on or through a computer system. By way of example, and not limitation, “computer-readable media” may include computer storage media and communication media. “Computer storage media” includes volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information, such as computer-readable instructions, data structures, program modules, or other data. “Computer storage media” includes, but is not limited to: RAM, ROM, EEPROM, flash memory or other memory technology; CD-ROM, digital versatile disks (DVD) or other optical storage devices; magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices; or any other medium that can be used to store the desired information and that can be accessed by a computer. “Communication media” typically embodies computer-readable instructions, data structures, program modules or other data in a modulated data signal, such as a carrier wave or other transport mechanism, and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media, such as a wired network or direct-wired connection, and wireless media, such as acoustic, RF, infrared and other wireless media. Combinations of any of the above should also be included within the scope of “computer-readable media.”
“Function,” “Program,” “Routine,” or “Rule”—These terms are used interchangeably in this specification and refer to computer code and/or computer-executable instructions.
“Pixel”—The term “pixel” refers to the smallest, elemental, individually-addressable unit of a display or the smallest discrete element of a stored bitmap.
“Pixel Grid”—The entire two-dimensional, rectangular coordinate system that is available in device space for a particular display medium.
“Rendering Pixel Space”—A specific, limited-size, two-dimensional, rectangular array of pixels to which a desired glyph, radical, stroke, and/or other image will be rendered.
“Pixel Region”—A specific, limited-size, two-dimensional set of pixels available for rendering a specific glyph, or a component or sub-component of a glyph.
“Device Resolution”—The number of pixels (or discrete “dots”) available per inch on a display device. Usually, device resolution is expressed in units of “dpi” (dots per inch) or “ppi” (pixels per inch).
“PPEM” or “ppem”—The term “PPEM” (“Pixels Per EM”) or “ppem” is a typographic term and a numeric value (or pair of numeric values) referring to the number of pixels used for defining a particular bitmap or a particular set of bitmaps that all have the same bitmap size. This term also is used in some instances to refer to the number of pixels available for a rendered image.
“Component”—The term “component” refers to one part that can be arranged or combined with other parts to form a whole. When used in the context of a glyph, the term may refer to a radical, a stroke, a stroke portion, an enhancing feature, and the like that may be used, optionally in combination, to make up the entire glyph.
“Point Size”—A typographic term referring to a physical measure of vertical height for text or graphics. There are 72 points in 1 inch.
“Desired Glyph”—The terms “desired glyph” and “requested glyph” are synonymous. The desired glyph is the one intended to be displayed.
“Memory Footprint”—The term “memory footprint” refers to the amount of computer system memory required to store a font, or a set of fonts.
II. Background and General Information Relating to the Invention
A. Information Relating to Certain Fonts for Use on Electronic Devices
As those skilled in the art understand, things that exist in the everyday world and computer-based constructs representing these things can be confused with one another, particularly when both are referred to using the same name or term. To reduce possible confusion, the term “entity” is used in this specification to refer to things (e.g., people, books, plants, ideas, computers, businesses, written characters, etc.) that exist in the real world, and the term “object” has been chosen to refer to computer-based constructs that model or represent various real world entities. A glyph written on paper is an example of a glyph “entity” while a computer-based stored representation of a glyph is an example of a glyph “object.”
Ideographic written scripts have a large number of characters with repeating basic design elements. In the written scripts of East Asia, many characters, pictographs, ideographs, and the like are constructed from a basic set of strokes. The written characters (or glyphs) also are conceived and constructed from meaningful combinations of a basic set of linguistic and graphical parts called “radicals.” Rules for writing the scripts, and linguistic rules for placement of constituent parts within the written character forms (ideographic space) also exist. Although the basic strokes and basic radical shapes are repeated and reused, there may be slight and subtle variations in these elements that occur naturally and intentionally. Some of the variations reflect a natural influence of each part on the other constituent parts (such as relative positioning, size, length, width, and orientation, etc.) as they seemingly “compete” for space within the bounds of the character or ideographic space. Variations of stroke and radical shapes also may occur in different writing styles, as a result of cultural preference for internal “balance” and “harmony” in the character forms, and as a result of different cultural preferences for different aesthetic graphical shapes. Historically, in order to retain all of these subtleties and variations, East Asian fonts have been designed and constructed to contain at least one set of stored geometrical data for each character or glyph that has any difference in shape or form, resulting in large font sizes (e.g., fonts having a large memory footprint when stored electronically).
In many East Asian fonts, it is possible to identify a natural hierarchy of reusable glyph components. For example, many East Asian glyph objects can be constructed from a collection of reusable components, including, for example: commonly occurring radical objects, commonly occurring stroke objects, and commonly occurring enhancing feature objects (such as stroke endings, serifs, and the like). This natural hierarchy, and the reusability of glyph components, can be reflected in the organization and structure of stored glyph representations. In order for the glyph components to be reusable in a general sense and yet retain fidelity to the original design details, additional “guiding” information, composition information, and “reconstruction” rules must be stored in the font or preserved in some other way.
Not only is a natural hierarchy of glyph components observable in many written scripts and fonts, but natural variations and modifications to the shape of glyph components (relative to each other) can be seen. For example, as a basic recurring stroke or radical is written or rendered, it may be stretched or compressed, expanded or contracted, thinned or broadened, or otherwise modified to fit the allocated or remaining area in the ideographic space for the glyph. Indeed, some parts of a stroke or radical may appear to be “deformed” to accommodate the graphical shape of some other part(s). A high quality font design will retain these natural modifications and variations. Systems and methods for designing, producing, compiling, and rendering compact fonts are needed that can retain and reflect the original design intent in the displayed glyph images.
Some typeface designs are more regular and “structured,” while others appear to be less regular and more “free-form.” In general, typefaces that are more regular and structured can be rendered with higher quality and greater fidelity to the original typeface design on devices with lower resolution than can typefaces that are less regular and more free-form. The more regular and structured a typeface is, the more likely it is to have repeating patterns and repeating shapes, and the more likely it can be designed from re-useable and modifiable components in a compact font form, such as re-usable and modifiable components in a hierarchical structure.
In contrast, glyphs 400E, 400F, 400G, and 400H, and their component radicals, strokes, and enhancing features, are very regular and consistent. For example, radicals 401e and 401f have the same overall shape, and the corresponding component strokes and enhancing features are identical. In the same way, radical component 402e has the same shape and form as radical component 403e, and these components have the same shape as radical components 402f and 403f in glyph 400F. Also, stroke components 401g and 401h are identical in shape, and stroke components 402g and 402h are identical in shape. Other repeating radical, stroke, and enhancing features can be seen by comparing
Fundamentally, a font is a specific set of characters/glyphs that have a typeface design in common. The font designer and producer must consider the font format, how the font elements and components will be modeled, and how the font format and rendering technology can support the envisioned design.
The design of an original typeface generally begins in the mind of a typeface designer as a visual concept of a cohesive graphic style incorporating repeated patterns and shapes, and various associations among the shapes which are bound to character forms (glyphs) and various design elements of glyphs. When these natural visual concepts and entities are expressed in physical form as drawings of characters, glyphs, and glyph components and the like on paper (or any drawing surface), they form the natural design expressions of the typeface.
Designing a font (or font representation), in at least some instances, starts with deciding on the set of characters, deciding on the typeface, and deciding on a font format. Designing a font representation also involves the identification of consistent font-wide characteristics as well as relationships and dependencies (e.g., that may constitute natural hierarchies and relationships) between various glyphs and glyph components, and then designing the font representations, data structures, and the like that model these characteristics, relationships, and dependencies.
Storing a font (or a font representation) involves capturing the natural designs (the design entities) and converting/transforming them into computer-based representations (objects) and the like in the chosen font format. Storing a font representation also may involve capturing and converting/transforming the font-wide design characteristics, as well as the design relationships and dependencies between and among various glyphs and glyph components, into computer-based relationship representations (such as a hierarchy of related components), stored rules, stored parametric values, stored controls, stored programs and functions, and the like.
Each design entity may have multiple corresponding computer-based descriptions in a final font implementation. For example, a glyph may have an outline description and one or more bitmap descriptions in a font. Design entities also may have one or more design representations that are used during the design process, but any such design representations may be entirely independent of the final font representations or descriptions. For example, a stroke entity can be designed with a design representation using a sweeping trajectory with a variable brush, and then the silhouette of the resulting stroke shape can be stored in outline form as the stored object description in the font. Since possible design representations are not part of the final font representation and descriptions, they are not described in any greater detail here. The computer-based representations and descriptions may be stored in a known font format, such as TrueType/OpenType, PostScript, or the like.
Compiling involves traversing, accessing, and evaluating the stored representations and descriptions of glyphs and glyph components in various contexts (such as, different device resolutions and different desired text sizes) to provide the information necessary for the rendering engine of the system to generate high-fidelity displayed manifestations (renditions) of requested characters/glyphs in bitmap image form.
As noted above, rendering is the process of determining how information (including text, graphics, and/or electronic ink) is to be displayed, whether on a surface, on a screen, printed, displayed using a projector, or output in some other manner. “Rendering” may include the process of determining the location, size, and pixel density (number of pixels) of a target rendering pixel space available on the display device/media for the desired glyph, and converting/transforming the compiled glyph data (compiled from the stored representations and descriptions such as outlines, bitmaps, etc.) into a final display-ready bitmap image.
Rendering typically may involve the transformational steps of: scaling outline descriptions, trajectory descriptions, or bitmap descriptions of the object to be rendered; interpreting hinting instructions and glyph program instructions and the like; and grid fitting and scan conversion of the resulting compiled glyph data to a bitmap image. Much of this work may be accomplished by a rasterizer (such as a conventional TrueType Rasterizer). The rendering process typically attempts to map (scale) the resolution of the stored font data to the resolution of the display device and determines the size and number of available pixels on the display device for the desired character/glyph. A target bitmap image is created to match this rendering pixel space. In the final steps, the compiled glyph image may be “superimposed” on the target bitmap image in such a way that the bitmap image pixels that coincide with the compiled glyph shape are turned “ON,” and the bitmap image pixels that are not part of the glyph shape are turned “OFF.” Finally, the rendered target bitmap image is output to the display device or display medium to fill the rendering pixel space.
In order for the stored font data (in any particular font format) to be rendered successfully, a rendering engine (e.g., a suite of programs) must exist that includes a rasterizer capable of correctly processing the compiled data, including stored font data. The rendering engine and rasterizer must understand how the font data is organized and stored, and how it is to be transformed and translated. At any one of the processing and transformational steps noted above, loss of quality and loss of fidelity to the original typeface design can occur.
TrueType is both a font format and a font-rendering technology that is known in the art. The TrueType font format was first envisioned by Apple Computer and then jointly developed by Apple Computer and Microsoft Corporation in the late 1980s. Since then, Microsoft Corporation has taken a leadership role in further advancing TrueType as an industry standard and promoting its use. The TrueType Rasterizer is part of the TrueType font rendering technology. TrueType fonts contain scaleable TrueType font data.
OpenType is an extension of the TrueType font format, adding support for some types of PostScript font data (for example PostScript font data in Adobe CFF (Compact Font Format)). The OpenType format also provides for advanced OpenType layout information to support high-end typography and advanced text-processing. The OpenType font format was jointly developed by Adobe and Microsoft Corporation and is known to those skilled in this art.
The TrueType specification includes not only data format specifications, but also a definition of a general programming language instruction set. The TrueType rasterizer is capable of interpreting these instructions and, among other things, is capable of modifying the stored font data under a variety of run-time conditions. This is referred to as “instructing the glyph data” or “hinting,” and it provides the capability to achieve improved rendered image quality over a range of device resolutions. This same instruction set can be used conditionally to make other adjustments (such as precise positioning) to various components of the font's stored glyph data.
In addition to the stored font data, run-time data also may be used during the compiling and rendering processes. For example, the resolution of the display device, the desired text size, and the identifiers for the desired characters/glyphs are all run-time pieces of data that are not stored in the font. In addition, the final output may be rendered in color, gray-scale, or using sub-pixel positioning (as used in ClearType® rendering for example), all of which require additional data at run-time (“ClearType®” is a registered trademark of Microsoft Corporation for computer software used in displaying fonts on computers or other display devices). Still other forms of run-time information may be accessed and used during compiling, rendering, and rasterization. For example, previously compiled cached data sets, language-specific and script-specific rules for text shaping and layout, and the like may be used.
All physical display devices have a finite display size and a finite resolution that may be expressed in physical device units (e.g., dots per inch or “dpi”). Glyph outline data, however, typically is designed and stored in the font in a different (usually higher) resolution that often is expressed in font units (also called “design units”). The design units and the device units are both discrete integral values.
When glyph data is rendered to a physical display device, the text display size and the display resolution together determine the number of display pixels (in the horizontal and vertical directions) that will be available in the rendering pixel grid for the displayed glyph. As the font data is scaled and mapped to the target bitmap image, numeric rounding may occur up to some integral fractions of a pixel and produce different displayed images on devices with different resolutions.
1. Definition of “Bitmap-Based Descriptions”
Bitmap-based glyph descriptions (also known as “embedded bitmaps” or “stored bitmaps”) provide one way of representing a font object's geometrical data. Fundamentally, each glyph object is described by a stored matrix of discrete pixel values where each value is either set to ON or OFF. “ON” values may be single-bit values or multiple-bit values. The pattern of ON pixels in the matrix form the “printing” or “marking” shape of the character or glyph. Generally, in many conventional fonts, a separate stored bitmap matrix is required for each character at each supported text display size.
One benefit of bitmap-based descriptions is that they can provide high quality, ready-to-display glyph images, if they are well-crafted, hand-designed, and hand-tuned. However, bitmap-based descriptions typically require very large amounts of file or memory space, and each additional supported text size only adds to the amount of space needed. The large file size is one factor that limits the practicality of producing and using bitmap-based descriptions extensively, particularly for fonts that contain several thousand individual glyphs or font objects. High quality, well-crafted, and hand-tuned bitmap-based descriptions also are very expensive (almost prohibitively expensive) to design and produce, particularly for ideographic character sets and fonts including a very large number of glyphs or characters. Programmatically-generated bitmaps are generally of poor quality. Primarily for these reasons, bitmap-based descriptions typically are provided only for small ppem sizes and for a limited number of characters or glyphs. Scaling existing bitmap data (to match intermediate or large text sizes and sizes not directly supported in a font) almost always results in poor quality, irregular-looking glyph images.
2. Definition of “Outline-Based Descriptions”
Outline-based descriptions are another way to represent the geometrical data of glyphs or glyph components. An outline-based description is defined by a series of contours, where every contour is represented by a closed sequence of line segments, arcs, and/or curves. Outer contours bound a glyph's shape from outside while inner contours bound the glyph's shape from inside.
Certain problems can occur, however, when processing outline font data. As mentioned above, in mapping from the design units of the stored outline data to the device units corresponding to the resolution of a specific display device, rounding can occur. In such instances, particularly at low device resolutions and/or when few pixels are available for the rendered glyph, parts of the rendered glyph outline (such as strokes or stems) may appear too narrow or too wide, or may even completely disappear. Nearby parts of the original glyph shape may appear to run into each other, thus eliminating the space between the adjacent parts. Some fine details and features may be missing entirely from the rendered and displayed image. When a font is being designed, additional information (often in the form of hinting instructions) can be added to the stored font data to assist the rendering process so that more consistent results and higher quality output can be obtained for a range of devices with different resolutions.
Pixel-hinting is one kind of hinting instruction that can be applied to outline data in a font (or font representation).
Additional problems may occur when rendering unhinted outline data (including mapping between design coordinate space and device coordinate space) especially at low resolutions and in cases where the glyph shapes are complex. Inconsistent results, irregularities, inconsistent rendering for repeated component shapes, and poor overall quality may result. Indeed, some rendered images may be unrecognizable.
As mentioned previously, the currently specified text display size and the display resolution determine how many pixels (in the horizontal and vertical directions) will be available for rendering a desired glyph as a whole character shape. This also is the amount of available pixels for rendering a non-hierarchical glyph object. Then, in a hierarchical glyph representation, the amount of display pixels available for any one component of the whole glyph is determined by the amount of space that component occupies in the original glyph design. Further, the amount of space available for any sub-component is determined by the amount of space the sub-component occupies in the component design. For complex characters and ideographs, the amount of rendering space available (the number of available pixels) for individual components may be severely limited, even at relatively high device resolutions and large desired text sizes. This can lead to a number of problems as illustrated, for example, by the inconsistencies in
3. Definition of “Trajectory-Based Descriptions”
Trajectory-based descriptions provide another way (an alternative to outlines) to represent a font object's geometrical data. A trajectory-based description may be thought of as being defined by a brush moving along a sweeping trajectory. As illustrated in
The brush and sweeping trajectory are independent components of a trajectory-based description of a glyph component. That is, they can be modified independently. For example, the same trajectory can be swept by different brushes. While a variable brush (i.e. a brush that changes its shape while moving along a trajectory path) can be applied in order to describe an object's geometry, typically the examples of trajectory-based font representations that follow will use constant (invariant) brushes. The present invention, however, should not be construed as limited to use with constant brush shapes.
At design time, application of variable brushes can be used to advantage in the design process and the design of design entities. However, in at least some examples of the invention, a final design-time geometrical shape for a design entity generated in this way may be converted into another representation or description (such as an outline) before it is stored as an object description in a font or font representation.
a. Rendering Trajectory-Based Descriptions
In general during rendering of a font object, pixels that have centers belonging to (that is coinciding with) or within the region bounded by a silhouette are turned ON and form the resulting rendered image of the object. As in the case of outline-based descriptions, a trajectory-based description typically is designed in design space coordinates, and rendering involves mapping of the geometrical data into device space coordinates, accompanied by possible mathematical rounding and/or execution of some instructing code.
Note that during the rendering process, a trajectory-based description (using a constant, invariant brush in this example) maintains stroke width in a much better manner than an outline-based description. For example, all horizontal and vertical strokes in the rendered images 1102, 1104, and 1106 have consistent widths. This characteristic of trajectory-based descriptions is extremely attractive when a small number of display pixels are available for the rendered image.
However, consistent-width strokes generated with trajectories and a constant brush result in somewhat lower quality rendered images at high ppems (as compared to outline-based renderings) because they are unable to adequately show detailed shapes for variable width strokes and/or for various enhancing features (such as endings or corners). Also, for a more sophisticated set of curves (e.g., glyph 1110), a sweeping trajectory description produces lower quality rendered images of the enhancing features, and it produces a rather uniform appearance for the strokes (as compared to a rendered image 1130, which is based on an outline description of the geometrical data).
In general, currently existing trajectory-based font representations do not provide high quality rendering results. As shown in
Today, most available rendering systems apply uniform scaling to glyph outline data in order to change the size or extent of a whole glyph, or to change the size of glyph components in hierarchically structured glyph representations. Uniform scaling of this type also typically is applied to stored bitmap data. Uniform scaling is the only shape modification technique in wide use today. At rendering time, uniform scaling of glyph outline data can result in poor quality and incorrect results. Uniform scaling of outlines and stored bitmaps in conventional use today applies to all parts of the graphical information without consideration for proper handling of stroke widths, stroke endings, or enhancing features. Generally, stroke widths, stroke endings, and enhancing features should not change size uniformly to the same extent as the overall glyph changes size. In most cases, only the stroke extent (and not width, endings, or enhancing features) should scale.
B. Features of Fonts for Use on Electronic Devices
In order to be displayed on a “computer-related device,” any font should have a computer-readable representation (i.e., the stored, object data and other information associated with a font), and the font representation should be supported by a rendering engine.
1. Relationship Between Elements of “Natural” Fonts and Elements of a Font Representation
An “object” or a “font object” may be considered as any independent or self-containing structural element of a font representation, and such objects often correspond to entities in a “natural” font. “Glyph objects,” “radical objects,” and “stroke objects” (or their shorthand terms “glyphs,” “radicals,” and “strokes”) are examples of objects or elements in a font representation that correspond to glyph, radical, and stroke entities of a typeface. Enhancing features of a stroke (such as ending features, serifs, and the like) also may be considered to be font objects.
Although the objects used in a font representation may correspond to typeface entities, “entities,” as described above, are not limited by any standard/linguistic classification of the entities. Font objects (such as glyph objects, radical objects, stroke objects, and the like, as well as their corresponding entities) are not uniquely identified; they can be identified differently according to design convenience. For example, as shown in
2. Data Associated with Font Objects
Font objects may be described, at least in part, by data associated in some manner with the objects. Two major types of data are described in more detail below, namely: rules and attributes.
Rules are sequences of computer-executable instructions. Usually a rule is responsible for performance of a definite “complete task.” Sometimes in this specification the term “routine” refers to a complete rule or to a sequence of instructions that form a part of a rule and perform a “sub-task.”
More than one rule can be associated with an object. Rules can be conditional (rules that require some input data) or unconditional (rules that require no input data).
Rules may have the following structure: “parameters” (if any) (e.g., input values required in order to execute the rule); and “body” (e.g., a sequence of computer-executable instructions implemented/stored, for example, in any computer-readable media). The term “parametric values” also may be used to refer to particular input values provided to a rule.
From an implementation point of view, rules may be associated with objects in different ways. A rule associated with an object is not necessarily stored in a font representation together with other data associated with the object (although it may be). For example, a rule providing common functionality for several objects can be stored in a “general, global” part of a font representation, or it may be directly supported by a rendering engine. Most of the subjects discussed below are completely independent of a particular implementation; any way of “association” described below should not be construed to imply limitations to the present invention or associations relating to it.
The rest of the data associated with an object (i.e., anything besides rules) will be referred as “attributes”.
As a more specific example, the glyph object represented at
3. Font Objects and Instances of Objects
A font object may be defined by information associated with an object in a font. An object may or may not have any “final” visual image. That is, some objects do not produce any display image.
An instance of an object may be defined by a font object together with a complete set of parametric values for all conditional rules associated with the object that should be executed under given conditions. An instance (instantiation) of an object typically produces, or contributes to, a visual display image or representation.
4. General Types of Font Representations and Levels of Generalization
Font representation approaches can be classified in various ways. Examples of variations in font representations that may be used in accordance with examples of this invention include:
The types of font representations listed above are independent. A particular font representation can be characterized by one type, as well as by any combination of several types.
A particular implementation type of a font representation approach may require, for example, completion of the following specification and development tasks:
Aspects of the present invention apply to different classes of the representations and different levels of generalization. For example, some aspects of this invention are not related to or do not require the presence of a hierarchical structure, but they remain applicable to the description of any font.
5. Hierarchical or Componentized Representations of a Font
A “component” or a “glyph component” corresponds to a reusable font object that typically participates in the representation of more than one glyph. Glyph components may include radicals, strokes, stroke endings, enhancing elements, or the like.
Componentized (or hierarchical) font representations typically correspond to “naturally structured,” “regular” typefaces. Although almost any font can be designed to contain some componentized font representations “structured ideographic” fonts provide an opportunity to describe a majority of glyphs in a hierarchical manner based on a relatively limited number of basic components.
In various examples illustrating aspects of the present invention related to hierarchical font representations, a hierarchical structure similar to that described below may be used. As shown in
Data associated with a composite object and related to its composite structure and to the compilation process may include, for example: attributes and rules. These data types are described in more detail below.
Clearly, the presence or absence of a hierarchical structure does not influence the presence or absence of other kinds of attributes and/or rules. An object may contain various other kinds of data as well. For example, the hierarchical structure may include attributes and rules related to the geometrical description of the object.
A hierarchical font representation, in at least some examples, may provide various improvements and advantages, including improvements and advantages related to font storage size and quality of the rendering results, such as:
6. Modifiable or Parameterized Font Objects
A modifiable font object is an object constructed such that instantiation of the object (at least under certain circumstances) will involve specification of conditional information. Reference will be made to modifications related to the geometrical appearance of an object. The modification may be performed by altering the geometry directly associated with the object, or modifications may be performed during a compilation process of a composite object.
It may be beneficial, in at least some examples, to use modifiable font objects. For example, the use of modifiable objects may:
a. Examples of Modifiable Font Objects
Stroke end features or enhancing features also may be modifiable in accordance with at least some examples of this invention. In the example shown in
7. Sources of Input Information for Conditional Rules
Various different sources of input information may be used to provide input/parametric values used by the conditional rules. Examples of these sources of information are described in more detail below.
Run-time information may be one source of information used by conditional rules. An example of this type of information may include the ppem of the rendering system and the like.
“Component context” (relevant for objects that can participate as components in composite objects): This is information accessible (known) at the level of a higher-level object in a hierarchical representation that contains (an instance of) the current object as one of its components and is related to the current object. For example, as shown in
“Full context”: This is a complete set of condition-dependent information (e.g., run-time input and “component context”) used to instantiate an object under given conditions.
8. Pixel-Hinting and Shape-Hinting as Conditional Routines Responsible for Geometrical Modifications
There are at least two major types of conditional routines often applied to geometrical data associated with an object or related to computation of the geometrical data provided as an input to the rules associated with an object's components. One is “shape-hinting” and the other is “pixel-hinting.” If the primary purpose of a routine is to generate (or contribute to generation) of an instance that has a specific “new” shape, the routine is classified as “shape-hinting.” For example,
For a given ppem, the routine may slightly reposition horizontal strokes such that every one of them will contain a row of pixel's centers and will be visible in the resulting rendered image. This routine involves local modifications of the outline. In particular, the final horizontal strokes may not be spaced evenly after application of the routine. However, as shown in
An object is “shape-modifiable” if at least some of the conditional rules associated with the object perform shape-hinting (at least under some conditions).
9. Hierarchical Font Representation Using Shape-Modifiable Components
Different aspects of the present invention can be applied to font representations that have hierarchical structure objects and/or shape-modifiable font objects.
Aspects of the invention relating to designing a font may include (in addition to identification of the general implementation type for the font representation, the choice of mathematical representation(s) for geometry, the choice of instruction language, the choice of a storage format, and choice/implementation of the rendering engine):
Storing a particular font representation typically involves preserving information specific for the font representation in a format corresponding to the general implementation type of the font representation. Not all information related to a particular font representation should necessarily explicitly be saved in “computer-readable media” associated with the font representation. For example, some default rules (applicable to all fonts or a category of similar fonts) can be supported by a rendering engine and need not be stored along with the font). Information associated with a font representation may include (but is not limited to) the following data.
(1) Attributes associated with specific objects, including attributes related to:
(2) Rules associated with specific objects, including rules related to:
(3) Global attributes and rules, including: values, settings, and rules applicable to any large group (or groups) of the font objects.
Compiling, in at least some examples of systems and methods of the invention, may include: starting from the top-most level in the hierarchy (for every glyph object), providing parametric values for the rules associated with the components and instantiation of the components in the hierarchical manner. Compiling will be described in more detail below, e.g., in conjunction with
10. Examples of Sets of Objects Participating in a Hierarchical Font Representation
11. Examples of Data Associated with Font Objects and the Process of Hierarchical Compiling
In
A glyph object may have information or data associated with it regarding its componentized structure (e.g., an attribute including a list of IDs of the radical objects corresponding to radical components of the glyph) and information or data regarding positioning and size for every one of its radical components (e.g., an attribute including information regarding the vertical and horizontal extents of the radical components).
A radical object also may have information or data associated with it, e.g., information regarding its componentized structure (e.g., an attribute including a list of IDs of the stroke objects corresponding to the stroke components of the radical). A radical object also may have one or more associated conditional rules (e.g., conditional rules responsible for computation of the parametric values used for instantiation of the stroke components of the radical based on information regarding position and size (e.g., horizontal and vertical extents) of the radical obtained from the glyph object (e.g., also called “RadRule0” in this specification)).
A stroke object also may have information or data associated with it, e.g., an attribute including information related to the geometrical description of the stroke, such as the stroke's outline data in design units, a list of IDs of the stroke portion objects making up the stroke object, etc. Stroke objects also may include one or more associated conditional rules, e.g., conditional rules responsible for modification of the geometrical data according to provided parametric values, such as the parametric values associated with locations of the key stroke elements (e.g., also called “StrRule0” in this specification).
During compilation of a glyph, for every radical component of the glyph, information regarding its position and size (e.g., its horizontal and vertical extents) is provided as parametric value(s) to a conditional rule associated with the corresponding radical object, and the rule is invoked. For example, during compilation of glyph 2000 in
During execution of RadRule0, parametric values used for instantiation of the stroke components of the radical will be computed, and the associated stroke conditional rules will be invoked. For example, stroke rule StrRule0 associated with stroke object 2006 may require the locations of the stroke's endpoints as input parametric values. During execution of the rule RadRule0, the values for the locations of the endpoints of stroke object 2006 are computed four times (once for each occurrence of the stroke object 2006 in radical 2004), and the rule StrRule0 is invoked separately for every one of the components. For example, for the topmost horizontal stroke 2024, the location of the endpoints 2038 and 2040 may be computed by offsetting some constant distances in the vertical and horizontal directions from the sides of the radical's “guiding frame” 2030. The locations of the endpoints for other instances of the horizontal strokes 2006 can be computed by execution of some corresponding appropriate code or rule.
During execution of StrRule0, outline data associated with the stroke object 2006 may be modified, if necessary, so that the stroke will be located at the required position and have the required length. In this manner, the stroke object 2006 is instantiated.
For every stroke component of the radical 2004, resulting geometrical data corresponding to the stroke instance is returned back to the radical. For example, for the topmost horizontal stroke 2024, resulting geometrical data 2042 is returned to the radical. In this manner, the radical is instantiated.
For every radical component of the glyph 2000, the resulting geometrical data corresponding to the radical instance is returned back to the glyph. For example, for the radical 2020, the resulting geometrical data 2032 is returned to the glyph, and all components of the glyph are instantiated. In this manner, the resulting geometrical data for the glyph is completely defined and ready for processing by a rendering engine in order to create a final bitmap image that is ready for display.
The above is a general description of a font representation and compilation process. In this example, conditional rules associated with the objects (e.g., RadRule0 and StrRule0) require only “component context” type information as their input. Those skilled in the art will appreciate, however, that the present invention is not so limited to the examples recited herein. Any conditional rule associated with any font object can require an input related to the run-time information. For example, a conditional rule associated with a stroke can “snap” positions of the key elements to the pixel grid or can modify a stroke width depending on the ppem in order to provide a better rendered image.
III. Geometrical Descriptions of Objects
In order to render font objects, the various objects (e.g., glyphs, radicals, strokes, enhancing features, etc.) must have geometrical data associated with them in some manner so that the rendering engine can be instructed to create the font object on the electronic display device or printer. The following describes examples of geometrical descriptions of various font objects useful in accordance with at least some examples of this invention.
A. Additional Terms
“Primary geometrical data,” as used in this specification, is part of the geometrical data associated with an object. It explicitly participates (or may participate under certain conditions) in input provided to a rendering engine in order to create the resulting bitmap image. For example, outline or bitmap data associated with a glyph in a TrueType font representation are examples of primary geometrical data. For a hierarchical font representation, primary geometrical data typically is associated with the lowest-level objects only (e.g., the strokes or stroke portions).
Different types of primary geometrical data relate to the different ways the data is treated by the rendering engine while creating the rendered image. Some types of primary geometrical data useful in at least some examples of the invention include: outline-based geometrical descriptions; swept trajectory-based geometrical descriptions; and bitmap-based geometrical descriptions.
“Auxiliary geometrical data” is geometrical data associated with an object such that it is not “primary” data. “Auxiliary geometrical data” can be used for simplification of control. For example, the locations of the elements of a modifiable stroke or radical object are examples of auxiliary geometrical data. For a hierarchical font representation, “auxiliary geometrical data” may be associated with objects at any level of the hierarchy.
“Resulting geometrical data” is geometrical data that describes the appearance of an object's instance and directly provides an input to the rendering engine in order to create the resulting bitmap image. Any instance of any object usually has resulting geometrical data. This includes objects that have associated primary geometrical data and those that do not.
“Mathematical representation” is a particular mathematical representation of geometrical data (for example, piecewise linear curves, second or third order Bezier curves, or BSpline curves). Many aspects of the present invention are independent of any particular choice of the mathematical representation. However, a choice of a particular mathematical representation may influence the design possibilities, as well as design and rendering complexity.
“Geometrical description” of an object is the minimal complete set of the primary geometrical data associated with an object that is sufficient to provide complete information for generation of a rendered image of the object under specific conditions. The type of the geometrical description is the same as the type of the primary data included in the description. More than one geometrical description can be associated with an object. For example, in a TrueType font representation, if a glyph has associated outline data (in design space) and five bitmaps for rendering at 12 to 16 ppem inclusive, the glyph then is considered to have six geometrical descriptions: one outline-based and five bitmap-based. Even if the outline is instructed to collapse to a single point at 20 ppem and preserve its original shape at all the other ppems, the glyph has one outline description.
B. Mathematical Representations of Curves Used in TrueType
According to a convention, curves that form a glyph's outline(s) in TrueType fonts have a mathematical representation as described in more detail below. A curve may be represented by a series of on-curve and off-curve control points (as illustrated in
C. General Remarks Regarding Geometrical Descriptions
Clearly, the type of a geometrical description and/or the presence of multiple geometrical descriptions associated with an object are independent of whether or not the font is a representation that has a hierarchical or a flat structure. For a hierarchical font representation, geometrical descriptions typically are associated with the entities at the lowest level of the hierarchy, although other associations are possible without departing from the invention.
As described below, at least one aspect of the present invention relates to the association of multiple geometrical descriptions with a font object, and the conditional choice of one of these descriptions at the time of instantiation. In this case, for a composite object, different components of a single object can be instantiated using different geometrical descriptions.
In the examples that follow, much of the description relates and corresponds to a hierarchical font representation (in many instances with geometrical descriptions associated with objects at the lowest level of the hierarchy). However, the presence of a hierarchical structure is not a requirement of the present invention and it should not be considered as a limitation for applicability of the approach related to the geometrical descriptions.
Outline-based geometrical descriptions and sweeping trajectory-based geometrical descriptions of font objects can be associated with both modifiable and static objects. Bitmap-based geometrical descriptions can be “naturally” associated with static objects only. Although it is possible to scale static bitmap descriptions to other sizes, the rendered results are almost always of poor quality. For this reason, where possible, aspects of the present invention will avoid the use of scaled (dynamic) bitmap descriptions for modifiable objects.
D. Multiple Geometrical Descriptions Associated with the Same Font Object and Contextual Choice of a Description
The following describes example systems and methods according to the invention that combine outline-based geometrical descriptions and trajectory-based geometrical descriptions for the same font objects. This approach can be applied to any font representation, for example, starting from flat representations with static font objects and including hierarchical representations with modifiable font objects. Some aspects of the invention, e.g., for use with hierarchical font representations and/or modifiable font objects, are described in more detail below. The approach can be applied independently of a particular mathematical representation of the geometrical data. Some specific aspects related to a TrueType-compatible representation are also described below.
One purpose of a geometrical description (and of the rules related to the geometrical description) of an object is to produce legible rendering results with the highest possible quality for all ppem, under a variety of rendering conditions, and for all appearances of the object. Another objective is keeping the overall required storage space small for the collection of all geometrical descriptions (and related rules) associated with all the font objects. Existing “structured ideographic” fonts are characterized by both low-quality rendered output and extremely large storage space requirements. Various aspects of the present invention will address these quality and/or storage space issues.
Independent of the underlying geometrical description, the resulting rendered images considered as having “good quality” may have different characteristics for different ppems or under different rendering conditions.
Three major classes of ppems are distinguished with respect to different characteristics of the rendered images. Ppem boundaries between the classes are approximate and can vary depending on a specific typeface design. However, the ppem values can be classified generally as follows:
Characteristics of high quality rendered images clearly depend on the number of pixels available for the rendering, and these characteristics may change dramatically from low to high ppems. The various characteristics listed below are common characteristics typically shared by a majority of glyphs. However, exceptions are possible depending, for example, on a specific typeface design. In general, the strokes (or “stroke-curves,” i.e., the strokes that form a font object's shape) of a glyph may render with different degrees of detail depending on the pixel region available for the rendering and on the configuration of the region available for the rendering. These aspects of the invention may be used in any desired font representation, including, for example, ideographic fonts, hierarchical font representations, character-based font representations, and the like. The following characteristics may be taken into account by code associated with systems and methods according to the invention when rendering at various ppem classes in accordance with examples of the invention:
In order to provide legible, high quality rendering results, a geometrical description used in at least some examples of the invention will support the characteristics of the rendered image for those ppems where the description is used. However, no single type of the geometrical description will provide the best possibilities and output at all ppems. Different types of geometrical descriptions tend to produce better quality and more legible font objects at some classes of ppems and less at others, as will be described and shown in more detail below.
Bitmap-based geometrical descriptions typically are able to provide good rendering results, but they generally are not practical or actually useful above 20-22 ppems, because the descriptions are extremely expensive from a production point of view and require extremely large amounts of storage space.
Outline-based geometrical descriptions are able to provide good rendering results for high ppem. However, for low and middle ppems, outline-based descriptions typically require extensive pixel-hinting, for example, in order to maintain stroke widths and minimal separation distances. Hinting is extremely expensive from a design (and production) point of view, and it requires extra storage/memory space. In addition, for low and middle ppems (depending on a glyph's complexity), an outline-based description usually contains more information that can be reasonably displayed in a rendered image. Therefore, this extra information is not useful, but it takes up storage/memory space.
Simple trajectory-based geometrical descriptions provide a natural way to describe “stroke-curves” at low/middle ppems. However, these descriptions rarely produce high quality font objects at high ppems. For high ppems, application of a trajectory swept by a constant brush result in a “stick-like” stroke-curve appearance, even if the trajectory is swept by a brush more than one pixel wide. Generally, application of sweeping trajectories, swept by a variable width brush, while possible, may cause run-time performance issues, particularly for electronic devices having reduced or limited processing capacity.
Because a single font representation often is intended to be used under different run-time conditions, it advantageously will be able to provide legible, high quality rendering results over a wide range of ppems, from low to high. However, for most glyphs or font objects, there is no single geometrical description that is optimal for use at all possible ppems. In existing, currently available fonts, the following combinations of the geometrical descriptions typically are used:
A problem common for both types of fonts is that both outline-based and trajectory-based geometrical descriptions are designed for high ppems and fail to produce rendered images of a high quality for low/middle ppems.
E. More Specific Examples
In accordance with at least one aspect of the present invention, a combination of trajectory-based and outline-based geometrical descriptions associated with the same font objects may be stored and used in the font, and at run-time, a choice of the “most appropriate” description for use may be determined, e.g., based on various run-time conditions, as will be described in more detail below.
In at least some examples of the invention, the ppem associated with the rendering at run-time will be considered as one parameter that may influence the choice of the description to be used in the rendering. A single trajectory-based description and a single outline-based description, optionally independently designed descriptions, will be associated with an object and stored as part of the font. Application of even a simplified approach according to the invention where ppem is the only run-time parameter considered will, in at least some instances, provide rendering results of high quality (or at least improved quality) at low and high ppem.
A more robust rendering scheme, which eliminates the limitations listed above and utilizes additional run-time parameters, may provide rendering results of high quality for a wide range of ppem (including middle ppem). Such a scheme is described in more detail below:
Having both trajectory-based descriptions and outline-based descriptions associated with the same font object and using contextual choice of an appropriate description (e.g., based on run-time parameters such as ppem) allows maximal or at least improved “automatic” support of high-quality rendering results directly based on the properties of the description. For example, for low/middle ppem, a trajectory-based description:
According to at least one aspect of the present invention, the various geometrical descriptions of a given font object may be designed independently with respect to one another. In this manner, every one of the geometrical descriptions may be designed so that it will provide the best possible rendering results for at least some range of ppems (or other run-time parameters), and that specially designed description then will be used under those conditions (e.g., code associated with the font will look at the relevant run-time parameters and determine which description should be used). High-quality design of a particular description becomes easier, and the rendered images have a more stable appearance because one description is not attempting to provide a universal solution at all ppem levels. Rather, each description is used only under a certain limited set of conditions. For example, knowledge of a maximum ppem at which a trajectory-based description will be used allows limiting a range of the scaling ratios between the design units and the device units. This information can be used explicitly while designing a trajectory in the design units. For example, a part of a trajectory representing an ending or a curvature of a trajectory at a corner can be designed in design units so that it will provide the desired rendering result for a whole range of ppems without additional adjustments (e.g., hinting) for a particular ppem.
Any rules associated with an object and related to the geometrical description(s) can be designed independently for the different descriptions, optionally and advantageously taking into consideration the conditions under which that description will be used.
However, in at least some instances, different geometrical descriptions, or the rules related to the descriptions, can share (or may require as input) common elements of data. For example, rules responsible for modification and/or positioning of a stroke object may require at least some of the same input (such as locations for the stroke's key elements), and this input may be used, in at least some instances, for both trajectory-based descriptions and outline-based descriptions of the stroke object.
The combination of trajectory-based descriptions and outline-based descriptions associated with the same objects in a font representation, as available in at least some examples of the invention, requires implementation of a rendering engine that is able to support both descriptions (and optionally any other description in the font). In particular, the rendering engine, in at least some examples of the invention, should support access functionality (that is, it should be able to access the data related to any one of the geometrical descriptions of any objects), should support rendering functionality (that is, it should be able to produce a bitmap image based on any type of the geometrical description), and should provide the ability to choose one of the descriptions based on run-time parameters or conditions.
The combination of trajectory-based geometrical descriptions and outline-based geometrical descriptions in accordance with aspects of the present invention increases the amount of information associated with an object and requires more storage space as compared to an outline-based description alone, but such a combination appears to be much more compact than any combination of descriptions that includes a significant number of bitmap-based descriptions. Typically, a trajectory-based description of an object requires approximately less than half as much data (or memory space) as compared to an outline-based description. For a hierarchical font representation, the overall storage size associated with the font does not increase significantly when the combination of trajectory-based and outline-based geometrical descriptions is used (as compared to outline-based descriptions alone) because the geometrical descriptions typically are associated with a rather limited number of components at the lowest level of the hierarchy.
As noted above, trajectory-based descriptions can provide high-quality rendering results at low/middle ppem, particularly when the trajectory-based descriptions are specifically and independently designed for use at low/middle ppem. This makes it possible to reduce significantly the number of bitmap-based descriptions present in a font representation (or even completely avoid bitmap-based descriptions, in at least some instances). Eliminating or reducing the number of complete bitmap-based descriptions significantly decreases the required storage size of the font representation without compromising the rendered font quality.
If certain limitations regarding the scope of a font's usage are known a priory (for example, if the font is supposed to be rendered at low ppems only or at high ppems only), having multiple geometrical descriptions provides a possibility to exclude some redundant information from the font representation (or to design a font representation containing only one type of the geometrical description) and may make the font representation even more compact.
The use of a combination of trajectory-based and outline-based descriptions for providing a font in accordance with aspects of this invention does not prevent inclusion and use of bitmap-based descriptions in the font. Although properly designed trajectory-based descriptions can reduce the number of bitmaps associated with a glyph (or even make use of bitmaps completely unnecessary), bitmaps still can be used, if desired, e.g., based on a font designer's preferences, particularly at low ppems and/or for glyphs of high complexity.
F. Representation of Stroke-Enhancing Features by Swept Trajectories (“Augmented Trajectories”)
Additional aspects of the present invention relate to representation of enhancing features of a stroke or other font object using swept trajectories. The use of such swept trajectories can be useful to provide some stroke enhancing detail (such as end features, serifs, and the like), under at least some rendering conditions, at middle ppems and higher. This approach can be applicable to any font representation that supports trajectory-based descriptions (independent of the presence/absence of a hierarchical structure, independent of the modifiability of the objects, and independent of a particular mathematical representation of trajectories).
At the middle ppems, while the middle or main parts of the “stroke-curves” still typically appear in a rendered image as single pixel mono-width curves, some enhancing features may become visible, usually as one or two turned ON pixels. Although the enhancing features still do not have enough pixel space available to them to be rendered with great detail, the quality of the rendered images can significantly benefit when those features are displayed (even if the display is limited to one or two turned ON pixels).
As at low ppems, a trajectory-based description still is able to support rendered images that may be modified to include enhancing features. The geometry of the enhancing features can be described by a trajectory swept by a one-pixel brush (e.g., like the remainder of the trajectory, at least in some examples). A trajectory-based description that supports visibility of the enhancing features may be referred to in this specification as an “augmented trajectory,” as opposed to a “simple trajectory” (which refers to a trajectory-based description that does not support visibility or display of any enhancing features).
1. Relationship Between “Simple” and “Augmented” Trajectories
Theoretically, an object in a font representation may have two (or even more) independent trajectory-based descriptions. For example, a “simple trajectory” description can be used at low ppems and an “augmented trajectory” description can be used at middle ppems. As a practical matter, however, these descriptions may share a lot of common data. Therefore, rather than having completely separate simple and augmented trajectory descriptions, in at least some examples of the invention, a trajectory-based description of an object can be designed from the very beginning to support the enhancing features. In this case, a modification rule associated with the object can completely or partially disable the enhancing features (for example, by modification of a trajectory, e.g., by “collapsing” the parts of a trajectory responsible for visualization of the enhancing features) when there is not enough “pixel space” available to render a detailed image or when a uniform design should be applied to a set of objects. In this case, a “simple trajectory” description becomes a derivative form of the “augmented trajectory” description, which makes the font more compact. However, no specific relation between “simple” and “augmented” trajectories should be considered as a limitation to the present invention. “Simple” and “augmented” trajectories also can be designed independently, particularly if it makes it easier to create a high-quality (mathematically “stable”) description applicable for smaller ranges of ppems (and therefore for smaller ranges of scaling factors between design space and device space).
2. Augmented Trajectories and the Font Structure
The possibility of representing at least some enhancing features of a stroke using a trajectory-based description is independent of the presence of a hierarchical structure. As with any other geometrical description, trajectory-based descriptions of the enhancing features can be associated with any appropriate font object (e.g., depending on a particular structure of a font) without departing from the invention. For example, as shown in
As another example, the “enhancing features” may be stored as separate “stroke portions” that can be included and called when the stroke is rendered under certain conditions (e.g., middle ppems) and that can be ignored or not called under other conditions (e.g., low ppems). An example was described above in conjunction with
An enhancing feature also may be associated with or attached to a font object in any desired manner without departing from the invention. For example, this association or attachment may be accomplished if either data describing the enhancing feature is directly associated with the object or if it is associated with one of the (immediate or not immediate) components of the object (for composite objects).
3. Modifiable Augmented Trajectories
4. Augmented Trajectories Implementing a “Fill-In” Routine
As illustrated in
Other possibilities for supporting routines can exist, and the present invention is not limited by the example of a “fill-in” routine presented above.
G. Use of Multiple Geometrical Descriptions Associated with a Font Object and Contextual Choice of a Design
As noted above, parameters or factors other than ppem may be relied upon to influence choice of a geometrical description for a particular font object rendering. Additionally, aspects of this invention may be extended for use at middle ppems and to modifiable objects. Finally, selection and use of different geometrical descriptions for different parts or components of an object may be described based on various “local” characteristics associated with the rendering. These aspects of the invention will be described in more detail below.
1. Extension to Middle PPEMs and Modifiable Objects
As demonstrated above, one of the possibilities for extending aspects of the present invention to the middle ppems is to associate “augmented trajectory” descriptions with the font objects. In this case, a general scheme (for design and choice of the geometrical descriptions) may include the following:
2. Additional Factors Potentially Influencing Geometrical Description Choice
As described above, ppem (e.g., the number of pixels available for rendering of an entire glyph) typically has an important influence on the characteristics of a high-quality rendered image, and therefore, it may have an important influence on the choice of a specific geometrical description. Ppem, however, need not be the only factor taken into consideration when choosing a description. For example, even at the same ppem, it may be beneficial to have rendered images with different characteristics or rendered from different types of geometrical descriptions for different glyphs and/or for different portions within a single glyph. For example,
What actually defines the “most appropriate” description for use in rendering all or a part/component of a glyph (for a given ppem) is the pixel region (e.g., the number and configuration of the pixels) available for rendering this specific glyph and/or part/component thereof. For example, (e.g., in a hierarchical font representation with modifiable objects) the same radical (or stroke) object, at the same ppem, may have different pixel regions available for its rendering when it appears in different glyphs (as an instance), depending on its component context. In such cases, run-time information (e.g., ppem) together with the component context of an object may be used as input information (e.g., in code associated with the font, glyph, radical, stroke, etc.) to influence the choice of the most appropriate description of the object for use in the rendering.
H. Additional Examples and Features of the Invention
Approaches in accordance with at least some examples of the invention may accommodate and include two further ideas that extend from the discussion above (e.g., in code associated with the font, glyph, radical, stroke, stroke portion, etc.):
Practically, these potential extensions mean that enable rules associated with objects and responsible for choice of the geometrical representation may be used to make a decision as to which geometrical representation to use for a specific rendering based on any appropriate factors, such as based on run-time input and component context.
In many cases, generalized information regarding a glyph's structure (rather than complete geometrical information) may provide fairly good input to and information relating to a decision-making rule. The ability to use generalized information allows making the rules to be more efficient and increases the scope of their applicability. More information regarding the possibility of using general glyph structural information as a means of control is described below.
An extended scheme of design and choice of the (primary) geometrical information useful in systems and methods according to examples of the invention may be described as follows:
1. Multiple Geometrical Descriptions Associated with Objects and Conditional Choice of a Description
In the same manner as the example described in
At design time, attributes for the stroke objects may be defined, e.g., “simple trajectory” geometrical descriptions (shown as thin solid lines 2808, 2810, and 2812), “augmented trajectory” geometrical descriptions (shown as thicker dashed lines 2814, 2816, and 2818), and outline geometrical descriptions (2820, 2822, and 2824) are defined (optionally independent of one another) for every one of the stroke objects in the radical object 2800, and a conditional modification rule (e.g., StrRule0) responsible for modification of the geometrical data is defined for every one of the geometrical descriptions, e.g., based on input data relating to the location of key elements or points of the stroke elements.
In this specific example, the radical objects are assumed to be responsible for the choice of the geometrical descriptions of their stroke components, and a conditional rule e.g., RadRule1, responsible for the choice of a specific description is associated with the radical object. The radical rule RadRule1 makes a decision as to which geometrical description to use for each stroke (e.g., individually or as a group), e.g., based both on run-time information and on specific characteristics of the radical as a component of a particular glyph (component context). For example, RadRule1 associated with radical 2800 can make a decision based on the rectangular pixel region allocated for the radical at the current ppem in the current glyph. (The dimensions of the available region can be computed based on run-time information regarding ppem for the rendering and component information regarding the location and horizontal and vertical extents of the radical in design units). For example, one version of an appropriate rule can decide that all strokes should be instantiated using their outline descriptions for a ppem higher than 30, “augmented trajectory” descriptions for a ppem lower than 30 and if the pixel region allocated for the radical is at least 5 pixels wide and at least 9 pixel high, and “simple trajectory” descriptions otherwise. The radical 2800 also may have attributes and rules associated with it, including but not limited to those described above in conjunction with
At run-time, during compilation of the radical, rules (e.g., RadRule0 and RadRule1) provide information regarding the chosen geometrical description and regarding the required geometrical modifications (2830) for every one of the radical's strokes. Data of the chosen geometrical description of a stroke is accessed and the modification rule (e.g., StrRule0) is applied. A stroke is instantiated and its resulting geometrical data (2832) is returned to the radical (2800).
2. The Resulting Rendered Image
For the example illustrated in
I. A Mathematical Representation of Trajectory-Based Geometrical Descriptions in TrueType-Compatible Format
As is generally known in the art, the TrueType/OpenType Specification defines an overall font file format and a number of different types of internal data tables. Each different table is designed to contain a different kind of information (for example: identification, indexing and access mechanisms, geometrical data, control instructions, rendering instructions, etc.).
The TrueType/OpenType Specification defines a number of required mandatory tables and a number of standard “optional” tables. In addition, this Specification is quite flexible, as it permits new tables to be added (without departing from the Specification) so that new features, capabilities, and extensions can be realized. A number of font vendors, equipment manufacturers, and software companies have defined their own TrueType-compatible data tables and data formats to support special, advanced and unique capabilities of their products.
Rendering engines typically and conventionally access the TrueType font tables and data for which they are enabled (including all the mandatory and required tables), and they generally ignore the tables and data they do not recognize.
Additionally, the TrueType Instruction Set (and the TrueType Instruction Language capability) can be extended. Each instruction type has a unique “instruction code” (or “operation code”) that is recognized and interpreted by the TrueType rendering engine. The TrueType rendering engine can be extended with the ability to recognize new codes and perform the associated mathematical operations and rendering operations.
Conventional font representations and rendering engines may be modified to use trajectory-based descriptions that are based on TrueType compatible mathematical representations. Trajectory-based font object representations may be added to a TrueType font in a number of ways. For example, one way is to add a new font table (for example, a new table called “traj”) containing the trajectory data representation for each of the font objects that has a trajectory representation. Access to the individual font object trajectory data could be provided by the same indexing mechanism that is used for the “glyf” data table (for example, via offsets provided in the “cmap” subtables).
A second way to add trajectory-based font object representations to a TrueType font is to extend the “glyf” table itself to include not only the outline representations for font objects, but also to include the trajectory representations for font objects. This approach avoids the need to define a new table.
In either of the above examples (creation of a new table for trajectory representations or extension of an existing table (such as the “glyf” table) to include trajectory representations), the TrueType rendering engine may be modified and extended to be “aware” of the possibility that trajectory data could be present in the font, and the rendering engine may be modified and extended to access the trajectory representation (from the font table in which it is stored) rather than the outline representation or the bitmap representation under certain circumstances. Several different examples of these circumstances are identified and described in various aspects of the present invention.
As a more specific example, the rendering engine may be modified and extended with the capability (e.g., via code and functions) to interpret the stored trajectory representation (in the current display, system, and rendering context) and produce a trajectory-based rendered image of the font object.
Those skilled in this art know and will recognize that in the process of interpreting a trajectory representation, the rendering engine can mathematically “sweep” a selected geometrical pattern (for example a “brush” style pattern as described above) along a mathematical curve described by the trajectory data. This “sweep” operation fills (or turns “ON”) the pixels of the rendered image that coincide with the path of the geometrical “brush” shape.
A mathematical representation of a geometrical description is “TrueType-compatible” if it describes curves using the same representation as curves of TrueType outlines. Such representations compatible with TrueType are conventional and known to those skilled in the art. TrueType is an open format, so that tables/data can be added, as generally described above. However, the font format/data itself will not be rendered without a rasterization engine that is able to read the data, interpret and execute the commands (e.g., rules) if the data contain any, and interpret the data itself, transforming it into resulting images by a set of rasterization routines. Therefore, to be used by standard applications, a modification of the TrueType format should be supported by modification of the standard rasterizer (e.g., a rasterizer used for standard Microsoft application programs).
For supporting trajectory data, the following (or similar) changes could be made:
In this manner, support for trajectory data with any mathematical representation can be added to the TrueType font format and rasterizer. However, adding support for trajectories with TrueType-compatible mathematical representations has advantages for the TrueType technology. As mentioned above, when the trajectory data uses TrueType-compatible mathematical representations, many agreed upon conventions regarding file format and existing functionality of a standard rasterizer (e.g., a Microsoft rasterizer) can be reused, therefore providing a quick and safe start for implementation of support of trajectory data. As more detailed examples, some of the reusable elements described above can be utilized as described below:
A. Identification and Parameterization of Modifiable Components and their Influence on Font Quality
As described above, representation of a font in a hierarchical manner using shape-modifiable components naturally fits “structured ideographic” fonts. However, a high quality font is not automatically achieved simply by imposing some hierarchical structure or by specification of some modifications associated with the font objects. Specification of appropriate modification rules associated with font objects may be important both for compactness of the representation and for high-quality of the rendering results. The better a modification rule reflects “natural” behavior of a font entity, the more reusable the font object, which results in fewer components (e.g., fewer objects at hierarchical levels other than at the highest level) and makes the font representation more compact and easier to manage. Additional issues that may be taken into consideration while providing a compact font representation include the ability to specify rules in a uniform manner (so that a uniform font format can be applied and less format-related information needs to be stored) and the ability to specify rules so that they require as few input parameters as possible (in at least some instances, this is important for the rules associated with the radicals as objects that usually require storing parameters in the data associated with the glyph objects). The quality of the rendering results also may directly depend on the modification rules associated with the font objects because the rules actually are responsible for providing the resulting geometrical data during the process of instantiation, i.e., geometrical data that is used as input for a rendering routine that creates a bitmap image when the font object is rendered. Some techniques and methods applicable to specification of the modification rules associated with specific classes of objects are described below.
In most of the examples provided below, a hierarchical font representation with shape-modifiable components and (at least) three levels of hierarchy (e.g., levels of glyph, radical, and stroke objects) are described. Although these examples contribute to simplifying the discussion below, it should be understood by those skilled in the art that these examples do not represent any required limitations on the present invention. Although the following describes approaches and techniques related to specification of modification rules associated with the objects and managing the overall control, the present invention is not so limited to any restrictions regarding a specific structure of the modification rules, order of their invocation, etc. Support by any appropriate kind and number of rules and/or their combinations associated with the objects in any appropriate way (explicitly or implicitly) should not present a limitation for the techniques and the approaches described below. Particular implementation examples are shown below for purely illustrative purposes.
B. Pixel-Hinting and Hierarchical Font Representations with Shape-Modifiable Components
Pixel-hinting may be incorporated into a hierarchical font representation without departing from the invention, into both hierarchical font representations with or without shape-modifiable components.
1. Pixel-Hinting Applicable to Hierarchical Font Representations—Technique 1
Pixel-hinting can be supported by rules or routines associated with an object and responsible for modification of the geometrical data of the object. Typically, the rules are associated with the objects that have geometrical descriptions, e.g., with objects at the lowest level of the hierarchy. For shape-modifiable objects, shape and pixel-hinting can be combined in the same rules, if desired.
The following explanation extends an earlier example provided in conjunction with
2. Pixel-Hinting Applicable to Hierarchical Font Representations—Technique 2
Pixel-hinting also can be supported by a rule associated with a composite object and responsible for computation of the parametric values provided to the (shape-modification) rules associated with the components. Those values can be directly adjusted according to run-time information. Application of this technique makes sense when a decision regarding possible improvement of the rendered image quality can be performed based on the common context of the components; a component alone does not have enough information in order to make a decision. For example, any decision that affects relative positioning of the components (including maintaining a specific distance between the components) can be naturally made at the higher hierarchical level object that contains the components. The following example demonstrates this technique applied during compilation of a radical from the stroke components. Another example of this technique is described below and relates to pixel-hinting of the “guiding frames” when a glyph is compiled from its radical components.
In this example, for the two pairs of the vertical extents (3012 and 3014 and 3018 and 3020), the vertical locations of the horizontal strokes will be computed, and the rendered results will look like instances 3010 and 3016, respectively. (In this specific case, the rendering results will remain the same independent of whether or not the rules associated with the strokes (e.g., StrRule0) will perform rounding of the endpoints' locations). As is easy to see, those rendered images, which occupy the same total number of pixels in the vertical direction, appear inconsistent in that they differ by the positions of the upper middle horizontal stroke. In some examples or some designs, it might be desirable to achieve more consistent results. However, the consistency depends on the relative positions of the strokes with respect to one another rather than on the appearance of a specific stroke. This means, for example, that a rule associated with the radical (e.g., RadRule0) is the one that should control the inter-stroke distances. This control can be performed, for example, by direct computation of the rounded (pixel-hinted) locations of the endpoints before providing them as the parametric values to the stroke rules. For example, as illustrated in
3. Advantages of Pixel-Hinting in Combination with Componentized Font Representations
Pixel-hinting of the limited (relatively small) number of components allows significant improvement in the rendering results for the entire glyph set. Having a limited number of components also allows maintenance of consistency of the rules associated with pixel-hinting different components.
Pixel-hinting of shape-modifiable objects may be used, in at least some instances, to provide proper rendering results for different ppem and for all allowed shape-modifications of an object. This may increase the complexity of the pixel-hinting process (for each single shape-modifiable object).
C. Guiding Frames and Their Use to Control Radicals or Other Font Objects
The notion of “guiding frames” is described below. This description shows how a guiding frame-based control can contribute to description of radical behavior in a natural manner, to reusability of radical objects, to uniformity of radical control, and to improvement of the quality of the resulting rendered images. The techniques described below are applicable to fonts that, from a design point of view (not necessarily explicitly supported by the structure of the font representation), contain shape-modifiable radicals as reusable font components. Improved font compaction and performance results may be achieved, in at least some examples, if radical objects (as font components and specific means of control) will be explicitly supported by the format of the font representation and by the rendering engine. However, from a design (and resulting quality) point of view, the guiding frame-based control is independent of the actual font representation and can be supported by a non-explicit componentization into the radical objects, even by existing TrueType font representations using the TrueType hinting language. The guiding frame-based control is independent of the type(s) of the geometrical description(s) (e.g., trajectory-based or outline-based) used in a font representation.
While studying the “natural” behavior (modifications) of radical entities as components of different glyphs, it can be observed that many radicals feature an overall rectangular “aesthetical appearance.” For example,
The term “guiding frame” is used in this specification to refer to a conceptual enclosing (or substantially enclosing) region that defines an appearance of a radical and serves as a reference for the radical's geometry. With respect to a font representation, a “guiding frame” is an auxiliary geometrical object that can be used to simplify the design. Neither the guiding frame(s) nor the number of guiding frames is uniquely defined for a radical; their choice depends on a font designer's preferences and typically will be consistent for different radicals and agree with the modification rules associated with the radicals. Although a guiding frame typically will adequately represent the vertical and horizontal dimensions of a radical, the decision as to whether it will completely contain all the features, including the enhancing features, of a radical can be made by an individual designer. For example,
Radicals that participate in the glyphs shown in
In some instances, more than one guiding frame may be required in order to describe a modification behavior of a radical. In many cases, external guiding frames of the internal radicals will provide enough information for the (external) radical to configure itself. For example, as shown in
1. Extending Guiding Frames to Control Radical Components
Although a guiding frame-based control as described above may be especially applicable to radical objects (due to the “natural” behavior of radical entities), the same techniques can be applied to controlling the behavior of a radical's components (e.g., strokes and sub-strokes), if appropriate, without departing from the present invention.
a. External Guiding Frames and Bounding Boxes
Although one purpose of the “external” guiding frames is to provide information (e.g., for the radical itself and/or for other radical components of a glyph) regarding the external dimensions of the radical, the present invention is not limited by any requirement that the external guiding frame will necessarily coincide with a bounding box of a radical in precise mathematical meaning. Use of a true mathematical “bounding box” implies that all the geometry of the radical should belong on or within the interior of the bounding box. Bounding boxes in a precise mathematical meaning can be used as a particular kind of guiding frame; however, the term “guiding frame” is intended to accommodate a wider concept. In addition, the term “external guiding frame” is used instead of the term “bounding box” in order to avoid imprecision that can be caused by rounding (or hinting) during mapping of the geometry to the device space even in cases when an external guiding frame actually has the same dimensions and extent as a bounding box in the design space.
b. Additional Aspects of Control Using Guiding Frames
While designing and representing a font, the guiding frames of the radicals may be defined and used as a reference in order to define contextual behavior of a radical component. For example, a radical object's behavior in a font may be described independent of the details of a specific glyph context and still adequately enough in order to reflect the “natural” behavior of the corresponding radical entity. Radicals also may be made or designed independent (e.g., of the detailed characteristics of other radicals in a particular glyph) and in a reusable manner (e.g., to increase the number of glyphs where a radical object will properly reflect behavior of the radical entity).
“Guiding frames” help to describe the general modification behavior of a radical in a font using a minimal amount of information.
For example, guiding frame-based control enables a designer to make the modification rules associated with radicals more general (e.g., requiring less specific input with respect to a case when a rule would require complete information regarding a specific glyph). The use of guiding frame-based controls and rules increases the reusability of a radical and simplifies (e.g., makes more abstract) the information required for the rules associated with the radicals. Guiding frames also can reduce the number of the necessary radical objects (e.g., to help achieve font compactness), can help simplify specification of the modification rules, and can still allow configuring of a radical based on contextual information (e.g., to helping to achieve higher quality). Use of a limited number of radicals also provides a possibility to design the modification behavior of any specific radical more carefully, including the design of modifications such that the design will properly reflect the “natural” behavior of a radical (e.g., to provide quality modifications, as opposed to uniform scaling of a radical, for example) and pixel-hinting for low and middle ppem.
Guiding frame-based control also promotes memory space saving and font compactness by requiring a lower number of parameterization values for the rules associated with a radical (because the parametric values for the rules associated with the radical typically are provided separately for every glyph, the number of parameters required for a specific radical may significantly influence the required storage size). Guiding frame-based control also allows systems and methods in accordance with examples of the invention to encapsulate information and improve performance (e.g., less time necessary for obtaining and/or processing the input information by the radical rules as compared to the situation when a radical must receive complete information regarding a glyph).
For at least some guiding frame-based controls, however, proper representation of some glyphs may require passing more complete information to the rules associated with radicals than that provided by simple guiding frames. Such situations can be handled by rules associated with those glyphs without departing from the present invention (e.g., “exception” rules). In those cases, execution of a “default” rule (e.g., a rule that requires guiding frame(s) information as an input) associated with a radical might provide a basis for additional modifications necessary in order to configure properly an instance of a radical in a specific glyph.
c. Guiding Frames to Control Interactions Between Glyphs and Radicals
d. Pixel-Hinting Using Guiding Frames
As one example of a possible implementation of radical rules, geometrical data of a radical component may be generated under a rule associated with the radical requiring that the radical receive information regarding the guiding frames and apply all the required geometrical modifications in design units. The final geometrical data in the design units later may be mapped into the device space in order to provide an input for a rasterization routine of the rendering engine. However, especially at low and middle ppem, “automatic” mapping and rounding of the guiding frames and/or of the depending geometrical data to the pixel grid may not provide a good rendering result. Such undesirable effects as overlapping of the radicals and/or lack of inter-radical space may easily take place. For glyphs (especially for relatively dense glyphs), it may be beneficial to adjust the guiding frames of radicals in the glyphs by a rule associated with the glyph object (e.g., a conditional rule (GlyphRule0), which may receive run-time information, such as the rendering ppem before providing the information to the rules associated with the radical components (e.g., to apply a pixel-hinting technique). Pixel-hinting of the guiding frames allows for making a (human) decision (at design time) regarding adjustments of the guiding frames based on the complete information accessible at the level of a glyph, such that it will help improve the overall balance of the resulting rendered image and maintain minimal (and consistent) distances between the radicals in the glyph. In many cases, this simple technique will not require a significant increase in the storage space (e.g., instead of the rules, a glyph can store information sufficient for the adjustments in a definite format (for example, by how many pixels should a guiding frame's position and/or dimensions be modified for a specific ppem) while the adjustments themselves can be supported by a rendering engine) and will allow a significant improvement in the quality of the resulting images. In addition to the benefits listed above, rounding of the guiding frames to the pixel grid before configuring a radical's geometry may provide a way of improving regularity of the rendered patterns corresponding to the enhancing features that are rigidly-attached (e.g., maintained at a constant distance) to one or more sides of the guiding frames. For font representations that feature multiple geometrical descriptions associated with the objects, pixel-hinting and/or rounding of the guiding frames to the pixel grid before passing the parametric values to the rules associated with the radicals provide those rules with more exact information regarding the actual pixel region available for rendering of a radical and contribute to a better choice of an appropriate level of detail to be displayed and of the geometrical description that should be used for the specific rendering.
D. Modification Rules Using Guiding Frames as a Reference
This example implementation relates to modification rules associated with a radical object and the use of guiding frames as a reference. The rules receive information regarding the arrangement of the guiding frames as their input and provide a possibility to specify a modification in the most general manner so that it will reflect the “natural” behavior of the radical entity (for example, different types of modifications can be applied to different parts or components of a radical, as opposed to the commonly-applied uniform scaling of the radical's overall geometry).
In what follows, the term “guiding points” will refer to points (e.g., actual, conceptual, or auxiliary points) that define locations of key elements of an object. For example, the “guiding points” can be associated with endings, corners, and sharp turns of a stroke. As another example, radical 3500 shown in
In accordance with some examples of the invention, key elements of a radical (e.g., guiding points of a radical) may be positioned based on information regarding the guiding frame(s) of the radical. For example, every guiding point may be attached to the guiding frame independently, according to a rule that is most appropriate for the specific guiding point. As a more specific example, the simplest common types of attachments include: (a) positioning a guiding point at a constant distance from a specific side of the guiding frame, and (b) keeping a definite (specified) ratio between distances from a guiding point to the opposite sides of a guiding frame. As illustrated in
However, simple rules such as those described above are not always sufficient to properly or completely reflect a “natural” appearance of a radical entity in different glyphs. For example, as shown in
A rule for positioning the guiding points of a radical or other font object also may use information regarding more than one guiding frame. For example, in the radical shown in
Rules responsible for positioning guiding points also can incorporate pixel-hinting routines.
In at least some examples, a radical will have associated geometrical description(s), and in such cases, rules associated with the radical may be responsible for modification/positioning of the geometrical data depending on positions of the guiding points. If a radical further is decomposed into modifiable stroke components, then a rule associated with the radical may be used to compute positions of the guiding points (based on the guiding frame(s) information) and pass them as input to the rules associated with the stroke components, which then may be responsible for modification/positioning of the geometrical data. These examples should not be construed as imposing any limitations on the applicability of the present invention.
E. Enabling/Disabling Enhancing Features
In accordance with at least some aspects of this invention, enhancing features of objects (e.g., reusable font objects, such as ending features, serifs, and the like) may be selectively enabled or disabled, e.g., based on information regarding the pixel region available for rendering the object and/or the pixel region configuration.
Various examples and features of the invention can be applied to any font that contains reusable objects and supports visualization of the enhancing features. Examples of aspects of the invention are independent of a particular hierarchical structure. For example, radicals can have associated geometrical data or radicals can be componentized into strokes that contain the geometrical data. Enhancing features can exist as independent font objects or their visualization can be supported by geometrical data associated with stroke or radical objects. (Depending on a particular hierarchical structure, the inclusion of enhancing features may be supported in any desired manner, such as through shape-modification, by compilation rules, etc.). The approachability to enable/disable enhancing features is independent of the type of geometrical description (e.g., trajectory-based or outline-based) and is independent of the presence of multiple geometrical descriptions associated with the same object. However, for font representations that contain both trajectory-based geometrical descriptions (e.g., for low and middle ppems) and outline-based geometrical descriptions (e.g., for high ppem), the selective enablement/disablement is mainly applicable at ppems where the trajectory-based description is used (at high ppems where outline-based descriptions are used, the outline data typically will already have the enhancing features incorporated into the outline description of the font object).
Complete or partial disabling/enabling of the enhancing features may improve the quality of the rendering results especially at low and middle ppem, while still producing rendering images with appropriate level of details over a wide range of ppem.
As described above, it may be beneficial to display the same reusable font object with different levels of detail depending on the pixel region available for rendering the object. For example, the same radical in the same glyph may be displayed with enabled and/or disabled enhancing features depending on the ppem, and/or different instances of the same radical may be displayed with different levels of detail when they appear as components of different glyphs at the same ppem. Different enhancing features of the same object may be selectively enabled and/or disabled completely independently, or this action may follow some other universal rules designed for the font. For example, for a radical object, a rule may disable all enhancing features of one instance of a radical such that eliminating their visualization will result in increasing the vertical extent for other instances of the radical in the same glyph, and thereby facilitate enablement of all the enhancing features of the other instances of the radical.
Different kinds of enabling/disabling of enhancing features for the upper and lower instances of a radical may be supported by the same rule associated with the radical executed under different conditions (e.g., where different pixel regions are available). For even higher ppem (e.g., as in
F. Stroke Reduction
In at least some examples of the invention, font quality may be improved by reducing the number of or eliminating certain strokes from a rendered object, based, for example, on the pixel region available for the rendering and/or the available pixel region configuration. This approach may be applied to any desired font representation, for example, to “structured ideographic” fonts and other fonts that contain radical objects as reusable components. Applicability of this approach is independent of any particular hierarchical structure of a representation and of the type of geometrical description(s) used for the modifiable objects. Applicability of the approach also is independent of whether or not componentization (into radical components) is explicitly supported by the format of the font representation.
A radical component of a glyph does not always have enough pixel space available to provide a legible rendered image.
In this situation, in accordance with at least some examples of the invention, a “simplified” form (or several forms) of a radical can be specified as a “substitute” by the font designer in order to produce repeatable, legible rendered images. Simplification of a radical's shape typically involves stroke reduction (i.e., removal of one or more strokes from the rendered image) and/or (optionally) repositioning of the remaining strokes. Stroke reduction is not generally an arbitrary matter. Proper stroke reduction for many East Asian character/glyphs have been defined by several governmental standards bodies in East Asian countries, and standards have been established that define not only which strokes can (and should) be removed (or reshaped), but also the proper order of stroke removal (e.g., as fewer and fewer pixels are available at diminishing text sizes and lowered resolutions). The term “stroke reduction” is used generally in this specification for all or part of a process of simplification of a radical's shape that may involve removal of one or more strokes and/or may involve another “global” modification to the radical's shape. (In existing font technologies, stroke reduction is supported by manual design of static bitmaps for every glyph (i.e. separately for every appearance of a radical in every glyph) and for every ppem, or by storing “glyph alternatives” for each and every different case and having explicit knowledge of these “glyph alternatives” reside in the rendering software).
In accordance with at least one aspect of the present invention, simplification of a radical's shape (e.g., “stroke reduction”) may be performed by (reusable) rules associated with (reusable) radical objects. This allows significant quality improvement in the resulting rendered images (when compared to rendering the complete versions of the radicals), significant reduction in the required design effort (when compared to using pre-stored bitmaps), and increased consistency of the rendered images.
For example, radical 3720 (shown in
Although the above proposed approach for stroke reduction may be naturally applied to font representations that describe radicals as composite objects, the applicability of this approach actually is independent of whether the radicals are represented as composites or simple objects. For example, for font representations that contain radicals as the lowest-level components with associated primary geometrical data, stroke reduction can be supported by rules responsible for modification of the geometrical data of the radicals rather than by rules responsible for compilation. That is, the geometrical data associated with a radical can be “artificially” deformed to eliminate a stroke.
The appearance of stroke reduction also can be accomplished in other ways. For example, in some cases, stroke reduction can be accomplished by application of a shape modification rule associated with stroke components of a radical such that one or more strokes are positioned to the same location under certain contextual conditions.
G. Stroke Substitution
In accordance with at least some examples of this invention, one stroke or stroke ending may be substituted for another stroke or stroke ending in a rendered glyph or radical (or other font object), for example, depending on glyph specific information relating to the font object (e.g., based on contextual positional information relating to a radical in a glyph). This approach can be applied to any font representation without departing from the invention (e.g., “structured ideographic” fonts and fonts that contain radical objects as reusable components). Applicability of this approach is independent of the particular hierarchical structure of a font object representation and/or of the type of geometrical description(s) used for the modifiable objects (e.g., trajectories, outlines, etc.) Applicability of the stroke substitution approach in accordance with examples of the invention also is independent of whether or not componentization into the radical components is explicitly supported by the format of the font representation.
Some radical objects may appear consistently different as components of different glyphs. For example, certain strokes of a radical may have different shapes depending on the location of the radical within a glyph. As illustrated in
Stroke substitution in accordance with examples of the invention may be performed by a conditional rule associated with a radical object. For example,
Similar to the case of stroke reduction, stroke substitution in accordance with examples of the invention may be applied in the most natural way to composite radical objects composed from stroke components. It also may be applied to the simple radical objects by deformation of the geometrical data associated with the radicals. In this case the stroke substitution will be supported by a modification rule rather than by a compilation rule.
Support for the stroke-substitution functionality may be considered less significant or critical than support for the stroke reduction functionality, because the radical still will consistently appear in any specific glyph, independent of the run-time information. Also, instead of support of the stroke-substitution functionality, a font representation may contain two (slightly) different radical objects so that any specific glyph can reference either one of the radicals as its component. This approach increases somewhat the number of font objects and results in repeatability of some parts of the rules associated with different font objects, but it may decrease the complexity of the design and compilation for glyph and radical objects that otherwise would involve application of stroke substitution rules.
H. Implementation Rules Based on TrueType Hinting Language
If geometrical data associated with font objects has a TrueType-compatible mathematical representation, then rules associated with the objects can be naturally supported by the TrueType hinting language. Such implementation allows reuse of significant elements of currently existing TrueType font format and the TrueType rendering engine. If a font representation makes use of some of the proposed approaches, then a TrueType hinting language (TrueType instruction set) can be extended to provide direct support for some basic operations. Such extension will allow improved run-time performance, help reduce font size, and help reduce the design complexity of a font representation. Extension of the TrueType instruction set typically should be accompanied by a corresponding extension of the rendering engine functionality. For example, some basic operations that may be added to the TrueType instruction set can be related to: managing multiple (trajectory and/or outline-based) geometrical descriptions associated with an object (including support for choice of and access to the geometrical data); guiding frame-based control (including, for example, support for pixel-hinting of the bounding boxes and guiding frames standard methods of attachment of the guiding points and/or primary geometrical data to a bounding box and/or guiding frame; standard methods of attachment of the geometrical data to the guiding points); stroke reduction/stroke substitution; and complete or partial enabling/disabling of the enhancing features of a font object.
The following provides more specific examples of how the TrueType hinting language may be extended to support the various hinting approaches described in the application.
More specifically, the TrueType instruction language (including hinting instructions) can be extended with new instruction codes (or operation codes) to support various hinting approaches, including those described above. The new codes can specify additional mathematical operations that can be applied to the stored font object representations and the intermediate stages of the rendered image.
Similarly, the rendering engine also may be modified and extended with the capability (e.g., via code and functions) to recognize the additional operation codes and to perform the specified mathematical operations.
A more specific example is a new “stroke-reduction” hint instruction that can be applied to one or more horizontal strokes of specific font object representations to guide (or “instruct”) the rendering engine as to which strokes can be removed (or ignored) in a context where not enough pixels are available in the vertical direction to distinctly render every horizontal stroke of the font object. The rendering engine capabilities would be extended to look for and recognize a new “stroke-reduction” instruction code (e.g., under conditions of “low available pixels”), and it would then “assemble” the appropriate rendered image from the remaining component parts.
V. Example Data Structures
As described above, at least some examples of the present invention provide geometrical data for rendering font objects from plural independently designed font object data sets, such that different font object data sets may be used for compiling and rendering a font object, depending on various run-time conditions such as: desired text size, rendering device size, rendering device resolution, individual glyph density or complexity, available ppem for the font object, available pixel region configuration for the font object, contextual information, and the like. In at least some examples of the invention, a font representation will include at least trajectory-based geometrical data and outline-based geometrical data for the same font objects. These geometrical data sets may be independently designed, specially targeted for predetermined run-time conditions.
In font object data set No. 4 of this example, various enhancing features (such as stroke end features, serifs, or other augmenting data) are stored (e.g., as trajectory data) for use with at least the trajectory-based geometrical data present in font object data set No. 2. Alternatively, the trajectory data corresponding to the enhancing features may be stored as part of font object data set No. 2 (or No. 3), without departing from the invention (to illustrate this potential alternative arrangement, font object data set No. 4 and the enhancing feature data set of font object data set No. 2 are illustrated in broken lines). As another alternative, font object data set No. 4 also could be used to provide data for augmenting or enhancing features for use with font object data set No. 3 without departing from the invention. As still another example, if desired, font object data set No. 2 could include simple trajectory geometrical data for various font objects (e.g., for use between 12 and 16 ppem) and font object data set No. 4 could include augmented trajectory geometrical data for the various font objects, e.g., for use between 16 and 24 ppem, without departing from the invention.
As described above in conjunction with
If desired, the conditions under which any font object will be used may be separately stored or embodied in code associated with the font object at any location in the data structures 4000 or 4100 without departing from the invention. For example, code or data may be included or associated with the geometrical data relating to an individual font object, at any level of a hierarchical structure including the font object (if any), and/or at any other suitable or desired location.
Of course, other variations on the data structures for font representations are possible without departing from the invention. For example, a font representation need not include all of the font object data sets illustrated in
VI. Example Hardware
As noted above, the various fonts and methods according to the invention, including those described above, can be used with any computer system and/or rendering device without departing from the invention.
A basic input/output system 4260 (BIOS) containing the basic routines that help to transfer information between elements within the computer 4200, such as during start-up, is stored in the ROM 4240. The computer 4200 also includes a hard disk drive 4270 for reading from and/or writing to a hard disk (not shown), a magnetic disk drive 4280 for reading from and/or writing to a removable magnetic disk 4290, and an optical disk drive 4291 for reading from and/or writing to a removable optical disk 4292, such as a CD ROM or other optical media. The hard disk drive 4270, magnetic disk drive 4280, and optical disk drive 4291 are connected to the system bus 4230 by a hard disk drive interface 4292, a magnetic disk drive interface 4293, and an optical disk drive interface 4294, 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 personal computer 4200. It will be appreciated by those skilled in the art that other types of computer-readable media that can store data that is accessible by a computer, such as magnetic cassettes, flash memory cards, punch cards, digital video disks, Bernoulli cartridges, random access memories (RAMs), read only memories (ROMs), and the like, also may be used in the example operating environment without departing from the invention.
A number of program modules can be stored on the hard disk drive 4270, magnetic disk 4290, optical disk 4292, ROM 4240, or RAM 4250, including an operating system 4295, one or more application programs 4296, other program modules 4297, and program data 4298. A user can enter commands and information into the computer 4200 through input devices, such as a keyboard 4201 and a pointing device 4202. Other input devices (not shown) may include a microphone, joystick, game pad, satellite dish, scanner, or the like. These and other input devices often are connected to the processing unit 4210 through a serial port interface 4206 that is coupled to the system bus 4230, but they may be connected by other interfaces, such as a parallel port, game port, a universal serial bus (USB), or the like. Further still, these devices may be coupled directly to the system bus 4230 via an appropriate interface (not shown). A monitor 4207 or other type of display device also is connected to the system bus 4230 via an interface, such as a video adapter 4208. In addition to the monitor 4207, personal computers typically include other peripheral output devices (not shown), such as speakers and printers. In one example, a pen digitizer 4265 and accompanying pen or stylus 4266 are provided in order to digitally capture freehand electronic ink input. Although a direct connection between the pen digitizer 4265 and the serial port interface 4206 is shown, in practice, the pen digitizer 4265 may be coupled to the processing unit 4210 directly, to a parallel port, to another interface, and to the system bus 2130, as known in the art. Furthermore, although the digitizer 4265 is shown apart from the monitor 4207, the usable input area of the digitizer 4265 may be co-extensive with the display area of the monitor 4207. Further still, the digitizer 4265 may be integrated in the monitor 4207, or may exist as a separate device overlaying or otherwise appended to the monitor 4207.
The computer 4200 can operate in a networked environment using logical connections to one or more remote computers, such as remote computer 4209. The remote computer 4209 can be a server, a router, a network PC, a peer device, or other common network node, and it typically includes many or all of the elements described above relative to the computer 4200, although only a memory storage device 4211 has been illustrated in
When used in a LAN networking environment, the computer 4200 may be connected to the local network 4212 through a network interface or adapter 4214. When used in a WAN networking environment, the personal computer 2100 typically includes a modem 4215 or other means for establishing communications over the wide area network 4213, such as the Internet. The modem 4215, which may be internal or external to the computer 4200, may be connected to the system bus 4230 via the serial port interface 4206. In a networked environment, program modules depicted relative to the personal computer 4200, or portions thereof, may be stored in the remote memory storage device 4211.
It will be appreciated that the network connections shown are illustrative and other techniques for establishing a communications link between the computers can be used. The existence of any of various well-known protocols such as TCP/IP, UDP, Ethernet, FTP, HTTP, and the like is presumed, and the system can be operated in a client-server configuration to permit a user to retrieve web pages from a web-based server. Any of various conventional web browsers can be used to display and manipulate data on web pages.
The stylus 4304 may be equipped with one or more buttons or other features to augment its capabilities. In one example, the stylus 4304 could be implemented as a “pencil” or “pen,” in which one end constitutes a writing portion and the other end constitutes an “eraser” end that, when moved across the display, indicates portions of the display to be erased. Other types of input devices, such as a mouse, a trackball, or the like could be used. Additionally, a user's own finger could be the stylus 4304 and used for selecting or indicating portions of the displayed image on a touch-sensitive or proximity-sensitive display. Consequently, the term “user input device,” as used herein, is intended to have a broad definition and encompasses many variations on well-known input devices, such as stylus 4304. Region 4305 shows a feedback region or contact region permitting the user to determine where the stylus 4304 has contacted the display surface 4302.
Of course, the invention can be used to render fonts on any other suitable type of device without departing from the invention. For example, the invention could be used to render or display information on pocket personal computers, mobile or cellular telephones, pagers, other communication devices, watches, appliances, printers, and/or any devices that have a display screen and/or that render printed information.
VII. Conclusion
Various examples of the present invention have been described above, and it will be understood by those of ordinary skill that the present invention includes within its scope all combinations and subcombinations of these examples. Additionally, those skilled in the art will recognize that the above examples simply exemplify various aspects of the invention. Various changes and modifications may be made without departing from the spirit and scope of the invention, as defined in the appended claims.