EP1203345A1 - Verfahren, vorrichtung uns datenstrukturen zur erzielung einer gleichmässigen gunrdlinie in einem system zur textdarstellung - Google Patents

Verfahren, vorrichtung uns datenstrukturen zur erzielung einer gleichmässigen gunrdlinie in einem system zur textdarstellung

Info

Publication number
EP1203345A1
EP1203345A1 EP00926494A EP00926494A EP1203345A1 EP 1203345 A1 EP1203345 A1 EP 1203345A1 EP 00926494 A EP00926494 A EP 00926494A EP 00926494 A EP00926494 A EP 00926494A EP 1203345 A1 EP1203345 A1 EP 1203345A1
Authority
EP
European Patent Office
Prior art keywords
pixel
scan conversion
conversion source
sub
value
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Withdrawn
Application number
EP00926494A
Other languages
English (en)
French (fr)
Other versions
EP1203345A4 (de
Inventor
Charlton E. Lui
Leroy B. Keely, Jr.
Gregory C. Hitchcock
Ryan E. Cukierman
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Microsoft Corp
Original Assignee
Microsoft Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Microsoft Corp filed Critical Microsoft Corp
Publication of EP1203345A1 publication Critical patent/EP1203345A1/de
Publication of EP1203345A4 publication Critical patent/EP1203345A4/de
Withdrawn legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G5/00Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators
    • G09G5/22Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators characterised by the display of characters or indicia using display control signals derived from coded signals representing the characters or indicia, e.g. with a character-code memory
    • G09G5/24Generation of individual character patterns
    • G09G5/28Generation of individual character patterns for enhancement of character form, e.g. smoothing
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G3/00Control arrangements or circuits, of interest only in connection with visual indicators other than cathode-ray tubes
    • G09G3/20Control arrangements or circuits, of interest only in connection with visual indicators other than cathode-ray tubes for presentation of an assembly of a number of characters, e.g. a page, by composing the assembly by combination of individual elements arranged in a matrix no fixed position being assigned to or needed to be assigned to the individual characters or partial characters
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G3/00Control arrangements or circuits, of interest only in connection with visual indicators other than cathode-ray tubes
    • G09G3/20Control arrangements or circuits, of interest only in connection with visual indicators other than cathode-ray tubes for presentation of an assembly of a number of characters, e.g. a page, by composing the assembly by combination of individual elements arranged in a matrix no fixed position being assigned to or needed to be assigned to the individual characters or partial characters
    • G09G3/2003Display of colours
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G2300/00Aspects of the constitution of display devices
    • G09G2300/04Structural and physical details of display devices
    • G09G2300/0439Pixel structures
    • G09G2300/0452Details of colour pixel setup, e.g. pixel composed of a red, a blue and two green components
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G2320/00Control of display operating conditions
    • G09G2320/02Improving the quality of display appearance
    • G09G2320/0242Compensation of deficiencies in the appearance of colours
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G2320/00Control of display operating conditions
    • G09G2320/02Improving the quality of display appearance
    • G09G2320/0271Adjustment of the gradation levels within the range of the gradation scale, e.g. by redistribution or clipping
    • G09G2320/0276Adjustment of the gradation levels within the range of the gradation scale, e.g. by redistribution or clipping for the purpose of adaptation to the characteristics of a display device, i.e. gamma correction
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G2340/00Aspects of display data processing
    • G09G2340/04Changes in size, position or resolution of an image
    • G09G2340/0407Resolution change, inclusive of the use of different resolutions for different screen areas
    • G09G2340/0414Vertical resolution change
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G2340/00Aspects of display data processing
    • G09G2340/04Changes in size, position or resolution of an image
    • G09G2340/0407Resolution change, inclusive of the use of different resolutions for different screen areas
    • G09G2340/0421Horizontal resolution change
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G2340/00Aspects of display data processing
    • G09G2340/04Changes in size, position or resolution of an image
    • G09G2340/0457Improvement of perceived resolution by subpixel rendering
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G3/00Control arrangements or circuits, of interest only in connection with visual indicators other than cathode-ray tubes
    • G09G3/20Control arrangements or circuits, of interest only in connection with visual indicators other than cathode-ray tubes for presentation of an assembly of a number of characters, e.g. a page, by composing the assembly by combination of individual elements arranged in a matrix no fixed position being assigned to or needed to be assigned to the individual characters or partial characters
    • G09G3/2007Display of intermediate tones
    • G09G3/2074Display of intermediate tones using sub-pixels
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G3/00Control arrangements or circuits, of interest only in connection with visual indicators other than cathode-ray tubes
    • G09G3/20Control arrangements or circuits, of interest only in connection with visual indicators other than cathode-ray tubes for presentation of an assembly of a number of characters, e.g. a page, by composing the assembly by combination of individual elements arranged in a matrix no fixed position being assigned to or needed to be assigned to the individual characters or partial characters
    • G09G3/34Control arrangements or circuits, of interest only in connection with visual indicators other than cathode-ray tubes for presentation of an assembly of a number of characters, e.g. a page, by composing the assembly by combination of individual elements arranged in a matrix no fixed position being assigned to or needed to be assigned to the individual characters or partial characters by control of light from an independent source
    • G09G3/36Control arrangements or circuits, of interest only in connection with visual indicators other than cathode-ray tubes for presentation of an assembly of a number of characters, e.g. a page, by composing the assembly by combination of individual elements arranged in a matrix no fixed position being assigned to or needed to be assigned to the individual characters or partial characters by control of light from an independent source using liquid crystals
    • G09G3/3611Control of matrices with row and column drivers
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G5/00Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators
    • G09G5/22Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators characterised by the display of characters or indicia using display control signals derived from coded signals representing the characters or indicia, e.g. with a character-code memory
    • G09G5/24Generation of individual character patterns

Definitions

  • the present invention concerns producing more legible text on video displays, such as flat panel video monitors including liquid crystal display (or LCD) video monitors for example, having horizontal striping.
  • video displays such as flat panel video monitors including liquid crystal display (or LCD) video monitors for example, having horizontal striping.
  • LCD liquid crystal display
  • the present invention may be used in the context of flat panel video monitors, such as LCD video monitors for example.
  • the present invention may be used as a part of processing to produce more legible text on LCD video monitors having horizontal striping.
  • Color display devices have become the principal display devices of choice for most computer users. Color is rendered on a display monitor by operating the display monitor to emit light (such as a combination of red, green, and blue light for example) which results in one or more colors being perceived by the human eye.
  • light such as a combination of red, green, and blue light for example
  • Cathode ray tube (CRT) display devices include a screen having phosphor coatings which may be applied as dots in a sequence.
  • a different phosphor coating is normally associated with the generation of different colors, such as red, green, and blue for example. Consequently, repeated sequences of phosphor dots are defined on the screen of the video monitor.
  • One or more electron guns generate electron beams which are swept, typically left to right and top to bottom, across the screen. When a phosphor dot is irradiated by an electron beam, it will glow thereby rendering its associated color, such as red, green and blue for example.
  • the term "pixel" is commonly used to refer to one spot in a group of spots, such as a rectangular grid of thousands of such spots for example.
  • the spots are selectively activated to form an image on the display device.
  • a single triad of red, green and blue phosphor dots cannot be uniquely selected. Consequently, the smallest possible pixel size will depend on the focus, alignment and bandwidth of the electron guns used to excite the phosphor dots.
  • the light emitted from one or more triads of red, green and blue phosphor dots in various arrangements known for CRT displays, tend to blend together giving, at a distance, the appearance of a single colored light source.
  • the intensity of the light emitted from the additive primary colors (such as red, green and blue for example) can be varied to achieve the appearance of almost any desired color pixel. Adding no color, that is, emitting no light, produces a black pixel. Adding 100 percent of all three (3) colors produces a white pixel. Having introduced color CRT video monitors, color LCD video monitors are now introduced in ⁇ 1.2.2 below.
  • Portable computing devices also referred to generally as computing appliances or untethered computing appliances
  • LCDs liquid crystal displays
  • flat panel displays tend to be smaller and lighter than CRT displays.
  • flat panel displays are well suited for battery powered applications since they typically consume less power than comparably sized CRT displays.
  • Color LCD displays are examples of display devices which distinctly address pixel elements to represent each pixel of an image being displayed.
  • each pixel element of a color LCD display includes three (3) non-square elements (also referred to as “sub-pixel elements” or “sub-pixel components”). More specifically, each pixel element may include adjacent red, green and blue (RGB) sub-pixel elements. Thus, a set of RGB sub-pixel elements together define a single pixel element.
  • Some LCD displays may have non-square pixels and/or pixels which are defined by more than three (3) sub-pixel elements.
  • Known LCD displays generally include a series of RGB sub-pixel elements which are commonly arranged to form stripes along the display. The RGB stripes normally run the entire length of the display in one direction.
  • RGB striping The resulting RGB stripes are sometimes referred to as "RGB striping".
  • Many LCD monitors, used for computer applications, are wider than they are tall, and tend to have RGB vertical stripes.
  • many LCD monitors used in untethered or handheld computing appliances are taller than they are wide, and tend to have RGB horizontal stripes.
  • the present invention may be used when rendering text on monitors, such as LCD RGB monitors for example, which have horizontal striping.
  • Figure 1 illustrates a known LCD screen 100 comprising pixels arranged in a plurality of rows (R1-R8) and columns (C1-C6). That is, a pixel is defined at each row-column intersection.
  • Each pixel m cludes a red sub-pixel element, depicted with hatching, a green sub-pixel element, depicted with cross hatching, and a blue sub- pixel element, depicted with no hatching.
  • Figure 2 illustrates the upper portion of the known display 100 in greater detail.
  • each pixel element e.g., the (RI, C6) pixel element, comprises three distinct sub-pixel elements or sub-pixel components, a red sub-pixel element 210, a green sub-pixel element 220 and a blue sub-pixel element 230.
  • Each known sub-pixel element 210, 220, 230 is 1/3, or approximately 1/3, the height of a pixel while being equal, or approximately equal, in width to the width of a pixel.
  • the three 1/3 height, full width, sub-pixel elements 210, 220, 230 define a single pixel element.
  • RGB pixel subcomponents 210, 220, 230 define horizontal color stripes on the display 100. Accordingly, the arrangement of 1/3 height color sub-pixel elements 210, 220, 230, in the known manner illustrated in Figures 1 and 2, exhibit what is sometimes called "horizontal striping".
  • the RGB sub-pixel elements are generally addressed and used as a group to generate a single colored pixel corresponding to a single sample of the image to be represented. More specifically, in known systems, luminous intensity values for all of the sub-pixel elements of a pixel element are generated from a single sample of the image to be represented. For example, referring to Figure 3, an image section 300 is segmented into twelve (12) squares by the grid 310. Each square of the grid 310 defined by the segmented image section 300 represents an area of the image section 300 which is to be represented by a single pixel element. In Figure 3, a hatched circle 320 is used to represent a single image sample from which luminous intensity values associated with the red, green, and blue sub-pixel elements 330, 332, and 334 of the associated pixel are generated.
  • LCD displays are often used for rendering textual information.
  • a personal information manager may be used to render contact information, such as a person's address, telephone number, fax number, and e-mail address for example, on an untethered computing device.
  • Characters may include symbols, such as the "Parties MT”, “Webdings", and “Wingdings” symbol groups found on the WordTM word processor from Microsoft Corporation of Redmond, Washington for example.
  • a "typeface” is a specific named design of a set of printed characters (e.g., Helvetica Bold Oblique), that has a specified obliqueness (i.e., degree of slant) and stoke weight (i.e., line thickness).
  • a typeface is not the same as a font, which is a specific size of a specific typeface (such as 12-point Helvetica Bold Oblique). However, since some fonts are "scalable", the terms “font” and “typeface” may sometimes be used interchangeably.
  • a “typeface family” is a group of related typefaces. For example, the Helvetica family may include Helvetica, Helvetica Bold, Helvetica Oblique and Helvetica Bold Oblique.
  • font outline technology such as scalable fonts for example, to facilitate the rendering and display of text.
  • TrueTypeTM fonts from Microsoft Corporation of Redmond, Washington are an example of such technology.
  • various font sets such as "Times New Roman,” “Onyx,” “Courier New,” etc. for example, may be provided.
  • the font set normally includes a high resolution outline representation, such as a series of contours for example, for each character which may be displayed using the provided font set.
  • the contours may be straight lines or curves for example.
  • Curves may be defined by a series of points that describe second order Bezier-splines for example.
  • the points defining a curve are typically numbered in consecutive order The ordering of the points may be important.
  • the character outline may be "filled" to the right of curves when the curves are followed in the direction of increasing point numbers.
  • the high resolution character outline representation may be defined by a set of points and mathematical formulas.
  • a "font unit” may be defined as the smallest measurable unit in an "em” square, which is an imaginary square that is used to size and align glyphs (a glyph can be thought of as a character).
  • Figure 9 illustrates an "em" square 910 around a character outline 920 of the letter Q. Historically, an "em” was approximately equal to the width of a capital M. Further, historically, glyphs could not extend beyond the em square. More generally, however, the dimensions of an "em” square are those of the full body height 940 of a font plus some extra spacing. This extra spacing was provided to prevent lines of text from colliding when typeset without extra leading was used.
  • portions of glyphs can extend outside of the em square.
  • the portion of the character outline 920 above the baseline 930 is referred to as the "ascent" 942 of the glyph.
  • the portion of the character outline 920 below the baseline 930 is referred to as the "decent" 944 of the glyph. Note that in some languages, such as Japanese for example, the characters sit on the baseline, with no portion of the character extending below the baseline.
  • the stored outline character representation normally does not represent space beyond the maximum horizontal and vertical boundaries of the character (also referred to as “white space” or “side bearings”). Therefore, the stored character outline portion of a character font is often referred to as a black body (or BB).
  • a font generator is a program for transforming character outlines into bitmaps of the style and size required by an application. Font generators (also referred to as “rasterizers”) typically operate by scaling a character outline to a requested size and can often expand or compress the characters that they generate.
  • a character font In addition to stored black body character outline information, a character font normally includes black body size, black body positioning, and overall character width information. Black body size information is sometimes expressed in terms of the dimensions of a bounding box used to define the vertical and horizontal borders of the black body.
  • Box 408 is a bounding box which defines the size of the black body 407 of the character (A).
  • the total width of the character (A), including white space to be associated with the character (A), is denoted by an advance width (or AW) value 402.
  • the advance width typically starts to a point left of the bounding box 408.
  • This point 404 is referred to as the left side bearing point (or LSBP).
  • the left side bearing point 404 defines the horizontal starting point for positioning the character (A) relative to a current display position.
  • the horizontal distance 410 between the left end of the bounding box 408 and the left side bearing point 404 is referred to as the left side bearing (or LSB).
  • the left side bearing 410 indicates the amount of white space to be placed between the left end of the bounding box 408 of a current character (A) and the right side bearing point of the preceding character (not shown).
  • the point 406 to the right of the bounding box 408 at the end of the advance width 402 is referred to as the right side bearing point (or RSBP).
  • the right side bearing point 406 defines the end of the current character (A) and the point at which the left side bearing point 404' of the next character (I) should be positioned.
  • the horizontal distance 412 between the right end of the bounding box 408 and the right side bearing point 406 is referred to as the right side bearing (or RSB).
  • the right side bearing 412 indicates the amount of white space to be placed between the right end of the bounding box 408 of a current character (A) and the left side bearing point 404' of the next character (I).
  • the left and right side bearings may have zero (0) or negative values.
  • metrics analogous to advance width, left side bearing and right side bearing ⁇ namely, advance height (AH), top side bearing (TSB) and bottom side bearing (BSB) -- may be used.
  • a scalable font file normally mcludes black body size, black body positioning, and overall character width information for each supported character.
  • the black body size information may include horizontal and vertical size information expressed in the form of bounding box 408 dimensions.
  • the black body positioning information may be expressed as a left side bearing value 410.
  • Overall character width information may be expressed as an advance width 402. ⁇ 1.2.2.1.2 RENDERING TEXT TO PIXEL PRECISION Recall that font generators convert a black body character outline into a bitmap. This conversion may consider the point size of the font to be rendered, and the resolution (e.g., dots per inch, pixels per inch, etc.) of the device (e.g., a video display, a printer, etc.) which will ultimately render the text.
  • the resolution e.g., dots per inch, pixels per inch, etc.
  • Rounding size and positioning values of character fonts to pixel precision introduces changes, or e ⁇ ors, into displayed images.
  • Each of these e ⁇ ors may be up to 1/2 a pixel in size (assuming that values less than 1/2 a pixel are rounded down and values greater than or equal to 1/2 a pixel are rounded up).
  • the overall width of a character may be less precise than desired since the character's AW is (may be) rounded.
  • the positioning of a character's black body within the total horizontal space allocated to that character may be sub-optimal since the left side bearing is (may be) rounded.
  • the changes introduced by rounding using pixel precision can be significant. ⁇ 1.2.3 UNMET NEEDS
  • the present invention increases the resolution of text rendered on a display device having sub-pixel elements, such as an RGB LCD for example, and in particular, on a display device having horizontal striping.
  • the present invention may do so by (i) overscaling (or oversampling) character outline information in the vertical (or Y) direction, and (ii) filtering (e.g., averaging) displaced (either overlapping, immediately adjacent, or spaced) scan conversion source samples from the overscaled (or oversampled) character outline information.
  • the present invention may also appropriately adjust metrics associated with the character outline information (such as left side bearing, advance width, vertical character size, ascent, descent, etc.).
  • the present invention may also constrain the vertical (or Y) position of the baseline of adjacent characters by forcing the first pixel above the baseline to be composed of a full number N of scan conversion source samples, where N corresponds to an overscaling (or oversampling) factor. This prevents "jumping" or
  • the present invention may also convert groups of scan conversion source samples into packed pixel index values.
  • the present invention may also selectively filter color values when the differences in the intensity of adjacent sub-pixel elements would otherwise be irritating to view.
  • the present invention may correct the gamma of the pixel values (or to achieve an effect similar to gamma correction) so that the gamma of the display device is considered and so that intensity values of sub-pixel elements fall within a range of intensities in which gamma correction is more useful.
  • Figure 1 illustrates a known arrangement of sub-pixel elements of an LCD display having horizontal striping.
  • Figure 2 illustrates a portion of Figure 1 in greater detail.
  • Figure 3 illustrates a known image sampling operation.
  • Figure 4 illustrates known ways of representing character information.
  • Figure 5A is a block diagram of a computer system which may be used to implement at least certain aspects of the present invention.
  • Figure 5B is a high level block diagram of a machine which may be used to implement at least certain aspects of the present invention.
  • Figure 6 illustrates an image sampling technique with which the present invention may be used.
  • Figure 7 is a diagram of high level processes of an environment in which at least certain aspects of the present invention may operate.
  • Figure 8 is a diagram of graphics display interface processes of an environment in which at least certain aspects of the present invention may operate.
  • Figure 9 illustrates certain typographic terms which are used when describing certain aspects of the present invention.
  • Figure 10 is a high level flow diagram of a first method for effecting an overscaling or oversampling process.
  • Figure 11 is an example which illustrates the operation of the method depicted in Figure 10.
  • Figure 12 is a high level flow diagram of a second method for effecting an overscaling or oversampling process.
  • Figure 13 is an example which illustrates the operation of the method depicted in Figure 12.
  • Figure 14 is a high level flow diagram of a method for effecting a hinting process.
  • Figures 15A and 15B are examples which illustrate the operation of the hinting method of Figure 14.
  • Figure 16 is a high level flow diagram of a first method for effecting a scan conversion process.
  • Figure 17 is a high level flow diagram of a second method for effecting a scan conversion process.
  • Figures 18A and 18B illustrate the usefulness of zero padding steps in the scan conversion methods of Figures 16 and 17.
  • Figure 19 is an example which illustrates an exemplary scan conversion process.
  • Figures 20A and 20B illustrate the storage and retrieval of scan conversion source samples (or more generally, information).
  • Figure 21 is an exemplary data structure which may be used to store glyph information in a glyph cache.
  • Figure 22 is a high level flow diagram of an exemplary method for effecting a display driver management process.
  • Figure 23 is a high level flow diagram of an exemplary method for effecting a color compensation (or color filtering) process.
  • Figure 24 is a high level flow diagram of an exemplary method for effecting a gamma correction method.
  • the present invention concerns novel methods, apparatus and data structures used to increase the resolution of fonts to be rendered on displays, such as RGB LCD displays for example, having horizontal striping.
  • displays such as RGB LCD displays for example, having horizontal striping.
  • the present invention functions to increase the resolution of text rendered on a display device having sub-pixel elements, such as an RGB LCD for example, and in particular, on a display device having horizontal striping.
  • the present invention may do so by (i) overscaling (or oversampling) character outline information in the vertical (or Y) direction, and (ii) filtering (e.g., averaging) displaced (either overlapping, immediately adjacent, or spaced) scan conversion source samples from the overscaled (or oversampled) character outline information.
  • the present invention may also function to appropriately adjust metrics associated with the character outline information (such as left side bearing, advance width, vertical character size, ascent, descent, etc.).
  • the present invention may also function to constrain the vertical (or Y) position of the baseline of adjacent characters by forcing the first pixel above the baseline to be composed of a full number N of scan conversion source samples, where N corresponds to an overscaling (or oversampling) factor.
  • the present invention may also function to convert groups of scan conversion source samples into packed pixel index values.
  • the scan conversion process is described as operating on “scan conversion source samples"
  • the scan conversion process, as well as the overscaling (or oversampling) and hinting processes may be analog operations operating on analog information rather than discrete samples.
  • the present invention may also function to selectively filter color values when the differences in the intensity of adjacent sub-pixel elements would otherwise be irritating to view.
  • the present invention may function to correct the gamma of the pixel values so that the gamma of the display device is considered and so that intensity values of sub-pixel elements fall within a range of intensities in which gamma correction is more useful.
  • FIG. 5A and the following discussion provide a brief, general description of an exemplary apparatus in which at least some aspects of the present invention may be implemented.
  • Various methods of the present invention will be described in the general context of computer-executable instructions, such as program modules and/or routines for example, being executed by a computing device such as a personal computer.
  • Other aspects of the invention will be described in terms of physical hardware such as display device components and display screens for example.
  • Program modules may include routines, programs, objects, components, data structures (e.g., look-up tables, etc.) that perform task(s) or implement particular abstract data types.
  • Program modules may be practiced with other configurations, including hand held devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, network computers, minicomputers, set top boxes, mainframe computers, displays used in, e.g., automotive, aeronautical, industrial applications, and the like.
  • At least some aspects of the present invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices linked through a communications network.
  • program modules may be located in local and/or remote memory storage devices.
  • FIG. 5A is a block diagram of an exemplary apparatus 500 which may be used to implement at least some aspects of the present invention.
  • a personal computer 520 may include a processing unit 521, a system memory 522, and a system bus 523 that couples various system components including the system memory 522 to the processing unit 521.
  • the system bus 523 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures.
  • the system 522 memory may include read only memory (ROM) 524 and/or random access memory (RAM) 525.
  • ROM read only memory
  • RAM random access memory
  • a basic input/output system 526 (BIOS) including basic routines that help to transfer information between elements within the personal computer 520, such as during startup, may be stored in ROM 524.
  • the personal computer 520 may also include a hard disk drive 527 for reading from and writing to a hard disk, (not shown), a magnetic disk drive 528 for reading from or writing to a (e.g., removable) magnetic disk 529, and an optical disk drive 530 for reading from or writing to a removable (magneto) optical disk 531 such as a compact disk or other (magneto) optical media.
  • the hard disk drive 527, magnetic disk drive 528, and (magneto) optical disk drive 530 may be coupled with the system bus 523 by a hard disk drive interface 532, a magnetic disk drive interface 533, and a (magneto) optical drive interface 534, respectively.
  • the drives and their associated storage media provide nonvolatile storage of machine readable instructions, data structures, program modules and other data for the personal computer 520.
  • the exemplary environment described herein employs a hard disk, a removable magnetic disk 529 and a removable optical disk 531 , those skilled in the art will appreciate that other types of storage media, such as magnetic cassettes, flash memory cards, digital video disks, Bernoulli cartridges, random access memories (RAMs), read only memories (ROMs), and the like, may be used instead of, or in addition to, the storage devices introduced above.
  • a number of program modules may be stored on the hard disk 523, magnetic disk 529, (magneto) optical disk 531 , ROM 524 or RAM 525, such as an operating system 535, one or more application programs 536, other program modules 537, display driver 732 (described in ⁇ 4.2.2.2 below), and/or program data 538 for example.
  • the RAM 525 can also be used for storing data used in rendering images for display as will be discussed below.
  • a user may enter commands and information into the personal computer 520 through input devices, such as a keyboard 540 and pointing device 542 for example.
  • Other input devices such as a microphone, joystick, game pad, satellite dish, scanner, or the like may also be included.
  • These and other input devices are often connected to the processing unit 521 through a serial port interface 546 coupled to the system bus. However, input devices may be connected by other interfaces, such as a parallel port, a game port or a universal serial bus (USB).
  • a monitor 547 or other type of display device may also be connected to the system bus 523 via an interface, such as a display adapter 548, for example.
  • the personal computer 520 may include other peripheral output devices (not shown), such as speakers and printers for example.
  • the personal computer 520 may operate in a networked environment which defines logical connections to one or more remote computers, such as a remote computer 549.
  • the remote computer 549 may be another personal computer, a server, a router, a network PC, a peer device or other common network node, and may include many or all of the elements described above relative to the personal computer 520.
  • the logical connections depicted in Figure 5A include a local area network (LAN) 551 and a wide area network (WAN) 552 (such as an intranet and the Internet for example).
  • LAN local area network
  • WAN wide area network
  • the personal computer 520 may be connected to the LAN 551 through a network interface adapter card (or "NIC") 553.
  • NIC network interface adapter card
  • the personal computer 520 When used in a WAN, such as the Internet, the personal computer 520 may include a modem 554 or other means for establishing communications over the wide area network 552.
  • the modem 554 which may be internal or external, may be connected to the system bus 523 via the serial port interface 546.
  • the program modules depicted relative to the personal computer 520 may be stored in the remote memory storage device.
  • the network connections shown are exemplary and other means of establishing' a communications link between the computers may be used.
  • FIG. 5B is a more general machine 500' which may effect at least some aspects of the present invention.
  • the machine 500' basically includes a processor(s) 502, an input/output interface unit(s) 504, a storage device(s) 506, and a system bus or network 508 for facilitating data and control communications among the coupled elements.
  • the processor(s) 502 may execute machine-executable instructions to effect one or more aspects of the present invention. At least a portion of the machine executable instructions and data structures may be stored (temporarily or more permanently) on the storage devices 506 and/or may be received from an external source via an input interface unit 504.
  • ⁇ 4.2.2 an overview of the text enhancement system is now presented in ⁇ 4.2.2 below.
  • the resolution of the em square when used to define a character outline, before that character can be displayed, it must be scaled to reflect the size, transformation and the characteristics of the output device on which it is to be rendered.
  • the scaled outline describes the character outline in units that reflect the absolute unit of measurement used to measure pixels of the output device, rather than the relative system of measurement of font units per em.
  • the resolution of the output device may be specified by the number of dots or pixels per inch (dpi).
  • a VGA video monitor may be treated as a 96 dpi device
  • a laser printer may be treated as a 300 dpi device
  • an EGA video monitor may be treated as a 96 dpi device in the horizontal (X) direction, but a 72 dpi device in the vertical (Y) direction.
  • the image is overscaled or oversampled, and in particular, may be overscaled or oversampled in the vertical (or Y) direction.
  • the RGB sub-pixel elements of a pixel are treated as independent luminous intensity elements into which a different portion of the overscaled or oversampled image can be mapped. This overscaling or oversampling operation is described in more detail in ⁇ 4.2.2.1.1.1 below.
  • Figure 7 is a high level diagram of processes which may be performed by the text enhancement system.
  • an application process 710 such as a word processor or contact manager for example, may request that text be displayed and may specify a point size for the text.
  • the application process 710 may also request a font name, background and foreground colors and a screen location at which the text is to be rendered.
  • the text and, if applicable, the point size are provided to a graphics display interface (or GDI) process (or more generally, a graphics display interface) 722.
  • GDI graphics display interface
  • the GDI process 722 uses display information 724 (which may include such display resolution information as pixels per inch on the display) and character information 728 (which may be a character outline information which may be represented as points defining a sequence of contours such as lines and curves, advance width information and left side bearing information) to generate glyphs (or to access cached glyphs which have already been generated).
  • Glyphs may include a bitmap of a scaled character outline (or a bounding box 408 containing black body 407 information), advance width 402 information, and left side bearing 410 information. Each of the bits of the bitmap may have associated red, green and blue luminous intensity values.
  • the graphics display interface process 722 is described in more detail in ⁇ 4.2.2.1 below.
  • the graphics display interface process 722, the display information 724, and the glyph cache 726 may be a part of, and effected by, an operating system 535', such as the Windows CE or Windows NT operating systems (from Microsoft Corporation of Redmond, Washington) for example.
  • Glyphs either from the glyph cache 726 or from the graphics display interface process 722, are then provided to a display driver management process (or more generally, a display driver manager) 735.
  • the display driver management process 735 may be a part of a display (or video) driver 732.
  • a display driver 732 may be software which permits a computer operating system to communicate with a particular video display.
  • the display driver management process 735 may invoke a color compensation (or color filtering) process 736, a gamma correction process 737 and a color palette selection process 738.
  • These processes 735, 736, 737, and 738 serve to convert the character glyph information into the actual RGB pixel sub-component luminous intensity values.
  • One or more of the processes 736, 737, and 738 may be effected by a set of pre-computed look-up tables which may be used to perform a plurality of image processing operations.
  • the process 735 receives, as input, glyphs and display information 724'.
  • the display information 724' may include, for example, foreground/background color information, a gamma value of the display device 547, color palette information and pixel value format information.
  • the display information 724' may be used to select one of the look-up tables included in the set of look-up tables to be used.
  • the processed pixel values may then be forwarded as video frame part(s) along with screen (and perhaps window) positioning information (e.g., from the application process 710 and/or operating system 535'), to a display (video) adapter 548'.
  • a display adapter 548' may include electronic components that generate a video signal sent to the display 547.
  • a frame buffer process 740 may be used to store the received video frame part(s) in a screen frame buffer 745 of the display adapter 548. Using the screen frame buffer 745 allows a single image of, e.g., a text string, to be generated from glyphs representing several different characters.
  • the video frame(s) from the screen frame buffer 745 is then provided to a display adaptation process 750 which adapts the video for a particular display device.
  • the display adaptation process 750 may also be effected by the display adapter 548'.
  • the adapted video is presented to the display device 547, such as an LCD display for example, for rendering.
  • Figure 8 illustrates processes that may be performed by a graphics display interface (or GDI) process 722, as well as data that may be used by the GDI process 722.
  • the GDI process 722 may include a glyph cache management process (or more generally, a glyph cache manager) 802 which accepts text, or more specifically, requests to display text, 820. The request may include the point size of the text.
  • the glyph cache management process 802 forwards this request to the glyph cache 726. If the glyph cache 726 includes the glyph corresponding to the requested text character, it provides it for downstream processing.
  • a type rasterization process 804 may be effected by hardware and/or software and converts a character outline (which may, recall include points which define contours such as lines and curves based on mathematical formulas) into a raster (that is, a bitmapped) image. Each pixel of the bitmap image may have a color value and a brightness for example.
  • a type rasterization process is described in ⁇ 4.2.2.1.1 below. ⁇ 4.2.2.1.1 RASTERIZER
  • the type rasterization process 804 basically transforms character outlines into bitmapped images.
  • the scale of the bitmap may be based on the point size of the font and the resolution (e.g., pixels per inch) of the display device 547.
  • the text, font, and point size information may be obtained from the application 710, while the resolution of the display device 547 may be obtained from a system configuration or display driver file or from monitor settings stored in memory 522 by the operating system 535.
  • the display information 724 may also include foreground/background color information, gamma values, color palette information and/or display adapter/display device pixel value format information. To reiterate, this information may be provided from the graphics display interface 722 in response to a request from the application process 710.
  • the background color information is what is being rendered on the display (such as a bitmap image or other text for example) and is provided from the display device 547 or the video frame buffer 745.
  • the rasterization process may include two (2) or three (3) sub-steps or sub-processes.
  • the character outline is overscaled (or oversampled) using an overscaling/oversampling process 806. This process is described in ⁇ 4.2.2.1.1.1 below.
  • the overscaled/oversampled image generated by the overscaling/oversampling process 806 may be placed on a grid and have portions extended or shrunk using a hinting process 808. This process is described in ⁇
  • displaced (e.g., immediately adjacent, overlapping, or spaced) samples of scan conversion source samples of the overscaled/oversampled (and optionally hinted) image are combined (e.g., filtered, averaged, etc.) by a scan conversion process 812 to generate values corresponding to the sub-pixel elements 210, 220, 230 of the display 547.
  • the scan conversion process 812 is described in ⁇
  • the resolution of an output device may be specified by the number of dots or pixels per inch (dpi).
  • the image is overscaled or oversampled, and in particular, may be overscaled or oversampled in the vertical (or Y) direction.
  • the RGB pixel sub- components of a pixel are treated as independent luminous intensity elements into which a different portion of the overscaled or oversampled image can be mapped.
  • the overscaling or oversampling factor may be zero (0) in he X direction and three (3) in the Y direction.
  • Such overscaling or oversampling factors would scale the character outline from font units to sub-pixel elements (Recall 210, 220, 230 of Figure 2.)
  • the overscaling or oversampling factor is nine (9) in the Y direction
  • three (3) scan conversion source samples may be used (e.g., via an averaging operation) to define the intensity of a red sub-pixel element of a pixel
  • another three (3) scan conversion source samples may be used to define the intensity of a green sub-pixel element of the pixel
  • the final three (3) scan conversion source samples may be used to define the intensity of a blue sub-pixel element of the pixel.
  • Alternative sampling and filtering techniques are possible.
  • the samples may be weighted such that more scan conversion source samples are used to define the green sub-pixel element and less scan conversion source samples are used to define the blue sub-pixel element.
  • the red sub-pixel element is allocated a weight of five (5) and is derived from five (5) scan conversion source samples
  • the green sub-pixel element is allocated a weight of nine (9) and is derived from nine (9) scan conversion source samples
  • the blue sub-pixel element is allocated a weight of two (2) and is derived from two (2) scan conversion source samples
  • overscaling or oversampling
  • the samples may include some overlapping scan conversion source samples such that some scan conversion source sample(s) may be used to determine more than one sub-pixel element. Alternatively, some scan conversion source sample(s) may be ignored. Similarly, alternative filtering techniques to averaging may be used.
  • Figure 6 illustrates an exemplary scan conversion operation implemented in accordance with an exemplary text enhancement system.
  • different image samples 630, 632, 634 of the image 610 segmented by the grid 620 are used to generate the red, green and blue intensity values associated with corresponding portions 640, 642, 644 of the bitmap image 650 being generated.
  • image samples for red and blue are displaced -1/3 and +1/3 of a pixel width in distance from the green sample, respectively.
  • the rasterized character i.e., the bitmap produced by the rasterization process is overscaled and/or oversampled, typically in the direction perpendicular to the striping of the display device.
  • Oversampling can be thought of as compressing the grid of samples while maintaining the image on which the grid is laid.
  • overscaling can be thought of as maintaining the grid of samples while stretching the image on which the grid is laid.
  • the overscaling (or oversampling) process 806 may perform a non- square scaling (or sampling) based on the direction and/or number of sub-pixel elements included in each pixel element.
  • the high resolution character information 728 may be overscaled (or oversampled) in the direction perpendicular to the striping at a greater rate than in the direction of the striping.
  • this information may include contours defined by a sequence of points which define lines and curves.
  • scaling is performed in the horizontal (or X) direction at a rate that is greater than that performed in the vertical direction.
  • horizontally striped displays of the type illustrated in Figure 1 are used as the device upon, which data is to be displayed, scaling is performed in the vertical (or Y) direction at a rate that is greater than that performed in the horizontal direction.
  • the overscaling (or oversampling) of characters or images is, but need not be, performed in a direction perpendicular to the striping at a rate which allows further dividing of the red, green and blue stripes to thereby support a subsequent scan conversion operation.
  • a first overscaling (or oversampling) technique will now be described with reference to Figures 10 and 1 1 , while a second overscaling (or oversampling) technique will be described with reference to Figures 12 and 13.
  • Figure 10 is a high level flow diagram of a first method 806' for effecting the overscaling (or oversampling) process 806.
  • Figure 11 illustrates an example of the operation of the method 806' of Figure 10.
  • the font vector graphics e.g., the character outline
  • point size e.g., the point size
  • display resolution e.g., the display resolution
  • Font metrics such as the left side bearing (Recall 410), advance width (Recall 402), ascent (Recall 942) and descent (Recall 944) may also be accepted.
  • This information is denoted 11 12 and 1114 in Figure 11.
  • the overscale factor or oversample rate (Recall N of Equation 2) is accepted.
  • the font vector graphics e.g., the character outline
  • the X coordinate values of the character outline in units of font units
  • the advance width and left side bearing also in units of font units
  • the Y coordinate values of the character outline (in units of font units), as well as ascent, descent, and other vertical font feature values (also in units of font units) are overscaled as shown in 1 130 (Recall Equation 2.) and rounded to the nearest integer scan conversion source sample value.
  • the resulting data 1 140 is the character outline in units of pixels in the X direction and units of scan conversion source samples in the Y direction.
  • the method 806' is then left via RETURN node 1040.
  • Figure 12 is a high level flow diagram of a second method 806' ' for effecting the overscaling (or oversampling) process 806.
  • Figure 13 illustrates an example of the operation of the method 806' ' of Figure 12.
  • the font vector graphics e.g., the character outline
  • point size e.g., the point size
  • display resolution e.g., the font vector graphics
  • Font metrics such as the left side bearing and advance width may also be accepted.
  • the overscale factor or oversample rate (Recall N of equation 2.) is accepted.
  • decision step 1230 it is determined whether the sub-pixel elements of the display are arranged in the order R-G-B or B-G-R for example.
  • the font vector graphics (e.g., the character outline) 1310 is rotated by 90 degrees, counterclockwise. Referring to Figure 13, this transformation may be effected by changing the original X coordinate values to new Y coordinate values and by inverting the original Y coordinate values to generate new X coordinate values as denoted by 1312. Processing then continues to step 1260.
  • the font vector graphics (e.g., the character outline 1310 is rotated by 90 degrees clockwise. This transformation may be effected by changing the original X coordinates to new Y coordinates and by changing the original Y coordinates to X coordinates.
  • the rotated font vector graphics (e.g., the character outline) 1110 is rasterized based on the point size, display resolution and the overscale factor (or oversample rate). As shown in the example of Figure 13, the new Y coordinate values of the character outline (in units of font units), as well as the advance width and left side bearing (also in units of font units) are scaled as shown in 1330 (Recall equation 1.). These values may then be rounded to the nearest integer pixel value.
  • the new X coordinate values of the character outline (in units of font units), as well as ascent and descent values (also in units of font units) are overscaled (or oversampled) as shown in 1320 (Recall equation 2.) and rounded to the nearest integer scan conversion source sample value.
  • the resulting data 1340 is the character outline in units of pixels in the new Y direction and units of scan conversion source samples in the new X direction.
  • the method 806' ' is left via RETURN node 1270.
  • the second method 806 provides certain data access advantages in certain embodiments, when accessing the data 1340 during a scan conversion process 812. These advantages are described in ⁇ 4.2.2.1.1.3 below with reference to Figures 20A and 20B. Referring back to Figure 8, once the overscaling (or oversampling) process
  • hinting also referred to as "instructing a glyph”
  • ⁇ 4.2.2.1.1.2 HINTING The purpose of hinting (also referred to as "instructing a glyph") is to ensure that critical characteristics of the original font design are preserved when the glyph is rendered at different sizes and on different devices. Consistent stem weights, consistent "color” (that is, in this context, the balance of black and white on a page or screen), even spacing and avoiding pixel dropout are common goals of hinting.
  • uninstructed, or unhinted, fonts would generally produce good quality results at sufficiently high resolutions and point sizes. However, for many fonts, legibility may become compromised at smaller point sizes on lower resolution displays.
  • hinting may involve "grid placement” and "grid fitting".
  • Grid placement is used to align a scaled (or overscaled) character within a grid, that is used by a subsequent scan conversion operation, in a manner intended to optimize the accurate display of the character using the available sub-pixel- elements.
  • Grid fitting involves distorting character outlines so that the character better conforms to the shape of the grid.
  • Grid fitting ensures that certain features of the glyphs are regularized. Since the outlines are only distorted at a specified number of smaller sizes, the contours of the fonts at high resolutions remain unchanged and undistorted.
  • sub-pixel element boundaries may be treated as boundaries along which characters can, and should, be aligned or boundaries to which the outline of a character should be adjusted.
  • hinting involves aliasing the left edge of a character stem with a left pixel or sub-pixel element boundary and aligning the bottom of the character's base along a pixel component or sub-pixel element boundary.
  • Figure 14 is a high level flow diagram of an exemplary method 808' for effecting at least a part of a hinting process 808.
  • Figures 15A and 15B illustrate the operation of the method 808' of Figure 14.
  • the overscaled or oversampled character bitmap is accepted.
  • the bottom of the character feature is on a scan conversion source sample that will be scan converted to a green sub-pixel element, it should be shifted (or distorted) to scan conversion source samples to be scan converted to a blue or a red sub-pixel element, or to a scan conversion source sample adjacent to a scan conversion source sample to be scan converted to a blue or a red sub-pixel element.
  • decision step 1420 if the bottom of the character feature is not on a scan conversion source sample to be scan converted to a green sub-pixel element, the method 808' is left via RETURN node 1460.
  • decision step 1430 it is determined whether or not the bottom of the character feature is closer to a scan conversion source sample to be scan converted to a red sub-pixel element or a scan conversion source sample to be scan converted to a blue sub-pixel element.
  • the character feature outline is shifted (or compressed) up so that its bottom is on a scan conversion source sample to be scan converted to a red sub-pixel element as shown in step 1440.
  • the character feature outline is shifted (or stretched) down so that its bottom is on (or immediately adjacent to) a scan conversion source sample to be scan converted to a blue sub-pixel element as shown in step 1450.
  • the method 808' is left via RETURN node 808'.
  • Figures 15A and 15B illustrate the operation of the method 808' of Figure 14 on character outlines in an overscaled or oversampled character outline which is to be subject to a weighted scan conversion in which five (5) scan conversion source samples will be used to derive a red sub-pixel element, nine (9) scan conversion source samples will be used to derive a green sub- pixel element, and two (2) scan conversion source samples will be used to derive a blue sub-pixel element.
  • the bottom 1512 of the overscaled or oversampled character feature outline 1510 is at a scan conversion source sample to be scan converted to a green sub-pixel element but is close to the scan conversion source samples to be scan converted to a blue sub-pixel element.
  • the overscaled or oversampled character feature outline is shifted (or stretched) downward such that the bottom 1512' of the resulting overscaled or oversampled character feature outline 1510' is on the scan conversion source sample which is immediately adjacent to a scan conversion source sample to be scan converted to a blue sub-pixel element.
  • the bottom 1522 of the overscaled or oversampled character feature outline 1520 is at a scan conversion source sample to be scan converted to a green sub-pixel element but is close to the scan conversion source samples to be scan converted to a red sub-pixel element. Accordingly, the overscaled or oversampled character feature outline is shifted (or compressed) upward such that the bottom 1522' of the resulting overscaled or oversampled character feature outline 1520' is on the scan conversion source sample to be scan converted to a red sub-pixel element.
  • hinting instructions may also be carried out on the overscaled or oversampled character outline. Note however, that the additional vertical resolution afforded by considering sub-pixel elements may make performing certain hinting instructions unnecessary.
  • a scan conversion process 812 is performed.
  • the scan conversion process is described in ⁇ 4.2.2.1.1.3 below. ⁇ 4.2.2.1.1.3 SCAN CONVERSION
  • the scan conversion process 812 converts the overscaled (or oversampled) geometry representing a character into a bitmap image.
  • Conventional scan conversion operations treat pixels as individual units into which a corresponding portion of the scaled image can be mapped. Accordingly, in conventional scan conversion operations, the same portion of an image is used to determine the luminous intensity values to be used with each of the red, green and blue sub-pixel elements of a pixel element into which a portion of the scaled image is mapped.
  • Figure 3 illustrates an example of a known scan conversion process which involves sampling an image to be represented as a bitmap and generating luminous intensity values from the sampled values.
  • the red, green and blue sub-pixel elements of a pixel are treated as independent luminous intensity elements. Accordingly, each sub-pixel element is treated as a separate luminous intensity component into which a different portion of the overscaled (or oversampled) image can be mapped.
  • a higher degree of resolution than with the known scan conversion techniques is provided.
  • different portions of the overscaled (or oversampled) image are used to independently determine the luminous intensity values to be used with each sub-pixel element.
  • the scan conversion process can be thought of as filtering (e.g., averaging) displaced samples. The displaced samples may be overlapping, one immediately adjacent to the next, and/or one spaced from the next.
  • Figure 6 illustrates an exemplary scan conversion process 812 which may be used in the text enhancement system.
  • different image samples 630, 632, 634 of the image 610 segmented by the grid 620 are used to generate the red, green and blue intensity values associated with corresponding portions 640, 642, 644 of the bitmap image 650 being generated.
  • image samples for red and blue are displaced -1/3 and +1/3 of a pixel height in distance from the green sample, respectively.
  • the scan conversion processes 812 generates red, green and blue (R, G, B) luminance intensity values for each pixel sub-component. These values may be expressed in the form of separate, red, green and blue luminance intensity levels.
  • Figure 16 is a high level flow diagram of an exemplary method 812' for effecting the scan conversion process 812.
  • the hinted and overscaled (or oversampled) character outline bitmap is accepted.
  • the overscaled (or oversampled) glyph metrics are also accepted.
  • expected size glyph metrics are determined from the overscaled (or oversampled) glyph metrics.
  • the ascent and descent may be determined as follows: ascent ⁇ ceiling (overscaled ascent / N) (3) body height ⁇ ceiling (overscaled ascent / N) + I ceiling (overscaled descent / N)
  • This step is used to ensure that there will be a complete pixel for scan conversion source samples of the overscaled (or oversampled) character outline bitmap.
  • step 1640 remainder scan conversion source samples in the ascent and descent of the character outline are zero padded. More specifically, if the number of scan conversion source samples in the ascent is not evenly divisible by the overscaling (or oversampling) factor N, then additional scan conversion source samples, with a value of zero (0), are added to the ascent of the character outline until the number of scan conversion source samples in the ascent is evenly divisible by the overscaling (or oversampling) factor N.
  • Such functionally equivalent techniques may include, for example, having the scan conversion process access integer multiples of the overscaling factor (or oversampling rate) of scan conversion source samples above the baseline and ignoring (using masking operations for example) scan conversion source samples above the ascent of the character outline.
  • the sub-pixel element values are determined based on scan conversion source samples As discussed above, this determination may be made by filtering displaced samples.
  • Figure 19 illustrates an example of a weighted scan conversion process. This exemplary scan conversion process is termed "weighted" since the intensity value of the red sub-pixel element is based on a sample of five (5) scan conversion source samples the intensity value of the green sub-pixel element is based on a sample of nine (9) scan conversion source samples, and the intensity value of the blue sub-pixel element is based on a sample of two (2) scan conversion source samples. This weighting may be used since the human eye perceives light intensity from different color light sources at different rates.
  • Green contributes approximately 60%, red approximately 30% and blue approximately 10% to the perceived luminance of a white pixel which results from having the red, green and blue sub-pixel elements set to their maximum luminous intensity output.
  • more levels may be allocated to green than to blue or red.
  • more intensity levels may be allocated to red then to blue.
  • equal numbers of intensity levels are assigned to red, green, and blue sub-pixel elements.
  • the overscaling (or oversampling) factor in this example was sixteen (16).
  • the dashed line 1910 depicts a part of an overscaled (or oversampled) character outline.
  • Reference number 1912 denotes an area within the character outline 1910
  • reference number 1914 denotes an area outside of the character outline 1910.
  • Figure 19 illustrates scan conversion source samples corresponding to two (2) pixels, having six (6) sub-pixel elements, of the display on which the character 1910 is to be rendered.
  • the filtering operation simply adds the number of samples in which the center 1922 of the scan conversion source sample 1920 lies within or on the overscaled (or oversampled) character outline 1910.
  • the number of scan conversion source samples which are at least 50% within the character outline 1910 may be used.
  • the topmost source sub-pixel has been zero padded so that the ascent of the character outline 1910 is evenly divisible by sixteen (16).
  • the red value 1932a is three (3)
  • the green value 1934a is eight (8)
  • the blue value 1936a is zero (0).
  • the red value 1932b is zero (0)
  • the green value 1934b is zero (0)
  • the blue value 1936b is two (2).
  • the sub-pixel element values are "packed".
  • the sub-pixel element values are packed into a single eight (8) bit value in accordance with the following expression: Packed Pixel Value ⁇ 3 x ( 10 x red + green) + blue (5)
  • the packed pixel value will have a value between zero (0) (i.e., when the red, green and blue values are all zero (0)) and 179 (i.e., when the red value is five (5), the green value is nine (9) and the blue value is two (2)).
  • step 1670 the character bitmap and glyph metrics are stored in the glyph cache 726.
  • An exemplary data structure of the data stored in the glyph cache 726 is described in ⁇ 4.2.2.1.1.4 below.
  • the method 812' is then left via RETURN node 1680.
  • Figure 17 is a high level flow diagram of an alternative method 812' ' for effecting scan conversion process 812.
  • the method 812' ' of Figure 17 may be used when the overscaling (or oversampling) method 806' ' of Figure 12 is used.
  • steps 1240 and 1250 of is Figure 12, as well as glyph 1314 of Figure 13, that the character outline 1310 was rotated by 90 degrees.
  • the scan converted glyph is rotated back as shown in step 1770.
  • the Y coordinates are mapped to final X coordinates
  • negative X coordinates are mapped to positive final Y coordinates
  • positive X coordinates are mapped to negative final Y coordinates.
  • Such coordinate mapping may be automatically effected by the manner in which scan conversion source samples are accessed (as will become apparent in the description of Figure 20B below). Otherwise, the method 812' ' of Figure 17 is similar to that of Figure 16.
  • the overscaling (or oversampling) method 8061 1 of Figure 12 stores scan conversion source sample information in a way that may be easier to access by a scan conversion process 812, such as the scan conversion method 812' ' of Figure 17 than when overscaling (or oversampling) method 806' of Figure 10 stores scan conversion source sample information.
  • Figures 20A and 20B illustrate this difference in the ease of accessing scan conversion source sample information by the scan conversion process 812.
  • scan conversion source sample information from the overscaled (or oversampled) character outline 1140 may broken into a number of bytes, from left to right and top to bottom and stored as a series of bytes denoted by reference number 2010.
  • scan conversion source sample information from the rotated and overscaled (or oversampled) character outline 1340 may be broken into a number of bytes from left to right and top to bottom and stored as a series of bytes denoted by reference number 2010'.
  • the scan conversion since the scan conversion is accessing a number (e.g., 16) of consecutive bits in the x direction (which was originally the Y direction), it can merely access two (2) consecutive bytes (such as 2000 ⁇ , i' and 2000 ⁇ , 2 - for example. If there are scan conversion source samples corresponding to a space between the two of the body 940 of the character outline and the em box 910 (Recall Figure 9.), an access method which accounts for such offsets may be used. Recall that in step 1640 of Figure 16 and step 1740 of Figure 17 that remainder scan conversion source samples in the ascent and descent of the character outline are zero padded.
  • Figures 18A and 18B serve to illustrate how these steps prevent the baseline from "jumping” or “bouncing”.
  • source sample 1850a is the highest sub-pixel source sample of the overscaled (or oversampled) character outline.
  • Reference number 1810b denotes the first 16 (where the overscaling or oversampling factor is 16) scan conversion source samples above the baseline 1820 while reference number 1810a denotes the last 16 scan conversion source samples above the baseline 1820. Without zero padding, the first set of samples will take scan conversion source samples from the set 1810a and one ( 1 ) scan conversion source sample from the next set (not shown).
  • this offset will propagate down such that a set of samples will take scan conversion source samples from the set 1810 above the baseline 1820 and one (1) scan conversion source sample from the first set below the baseline 1820. Effectively, the consequence of not zero padding the top set 1810a of scan conversion source samples Is that the baseline 1820 will move down one scan conversion source sample. Zero padding the top set 1810a of the scan conversion source samples maintains the position of the baseline 1820.
  • scan conversion source sample 1850c is the highest scan conversion source sample of the overscaled (or oversampled) character outline.
  • Reference number 1810d denotes the first 16 (where the overscaling or oversampling factor is 16) scan conversion source samples above the baseline 1820 while reference number 1810c denotes the last 16 scan conversion source samples above the baseline 1820. Without zero padding, the first set of samples will take one (1) scan conversion source sample from the set 1810c and 15 scan conversion source samples from the next set (not shown).
  • this offset will propagate down such that a set of samples will take one (1) scan conversion source sample from the set 1810d above the baseline 1820 and 15 scan conversion source samples from the first set below the baseline 1820.
  • the consequence of not zero padding the top set 1810c of scan conversion source sample is that the baseline 1820 will move down scan conversion source samples.
  • Zero padding the top set 1810c of the scan conversion source samples maintains the position of the baseline 1820.
  • R, G and B luminance intensity values are specified, stored and processed as three (3) discrete quantities, each having a number of bits corresponding to the number used to specify sub-pixel element luminance Intensity values to the display adapter 548 and/or display device 547.
  • R, G and B luminance intensity values are specified, stored and processed as three (3) discrete quantities, each having a number of bits corresponding to the number used to specify sub-pixel element luminance Intensity values to the display adapter 548 and/or display device 547.
  • many systems use 8-bit quantities, each representing an R, G or B luminance intensity value.
  • the processing of R, G and B luminous intensity values requires the storage, processing and transfer of 24 bits per pixel.
  • R, G, B luminance intensity value may be converted, e.g., compressed, into a single number.
  • this number is referred as a "packed pixel value" because it represents the packing of the R, G and B luminous intensity values associated, with a pixel, into a single value.
  • the range of numbers e.g., range of packed pixel values, used to represent pixel R, G and B luminous intensity levels, is selected to be large enough so that each possible R, G, B luminous intensity level combination can be uniquely identified.
  • the total number of packed pixel values, used to represent R, G and B luminous intensity level combinations should be at least as large as the product of the total number of supported red intensity levels, the total number of supported green intensity levels, and the total number of supported blue intensity levels. Since it is often convenient to work with bytes, i.e., 8-bit quantities, in terms of memory access, processing, and data transfer operations, the product should be able to be specified as an 8-bit quantity or a multiple thereof.
  • the scan conversion process 812 may convert separate R, G and B luminous intensity values associated with a pixel into a packed pixel value.
  • glyphs are represented, and stored using packed pixel values as opposed to, e.g., separate 8-bit R, G and B luminous intensity values.
  • the packed pixel value representations may be converted into separate R, G, and B luminance values of the form used by the display device 547 before the luminous intensity values are supplied to the display adapter 548.
  • Converting separate R, G and B luminous intensity levels into packed pixel values may be performed as part of, or as a post process to, the scan conversion process 812. (Recall steps 1660 and 1760 of Figures 16 and 17, respectively, described above.)
  • a shift operation or arithmetic equation may be used to convert between separate R, G and B luminance intensity levels associated with a pixel and a packed pixel value.
  • Such an operation can produce a total of M (0 through M-l) distinct packed pixel value entries, Where M is the total number of possible R, G and B luminous intensity level combinations that may be assigned to a pixel element.
  • a corresponding R, G and B luminous intensity level combination is associated with each packed pixel value.
  • the R luminous intensity values vary from 0 to RP-1 where RP is the maximum possible number of red luminous intensity levels.
  • the G luminous intensity values vary from 0 to GP-1 where GP is the maximum possible number of green luminous intensity levels.
  • the B luminous intensity values vary from 0 to BP-1 where BP is the maximum possible number of blue luminous intensity levels.
  • packed pixel values may be converted into separate R, G, B luminous intensity values using a look-up table by using the packed pixel value as an index into the look-up table and outputting the individual R, G and B luminous intensity level entries associated with the packed pixel value.
  • the number of supported R, G, and B luminous intensity levels is usually a function of the number of scan conversion source samples used to determine the R, G and B luminous intensity levels during the scan conversion process 812.
  • each of the packed pixel values 0-179 can be represented using an 8-bit quantity. This significantly lowers storage requirements as compared to embodiments where separate 8-bit values are used for a total of 24 bits per R, G, B combination.
  • Figure 21 illustrates an example of information which may be stored in the glyph cache 726' by the scan conversion process 812.
  • the glyph cache 726' may include a number of glyph files 21 10a.
  • Each of the glyph files 21 10a may include a number of glyph metrics 2112a (such as left side bearing, advance width, ascent, descent, etc. for example) and a number of pixel records 2120.
  • Each of the pixel records 2120 may include display screen pixel coordinates 2122 and a packed pixel value 2124.
  • the display driver 732 may include software instructions which permit the computer system to communicate information to the video display 547, or video adapter 740, in a way which can be interpreted by the video display 547. Although the display driver 732 is shown outside of the operating system block 535', the display driver 732 may be considered as a part of the operating system 535'. As shown in Figure 7, the display driver 732 may include a display driver management process 735 which can accept display information 724' and which manages a color compensation (or color filtering) process 736, a gamma correction process 737, and a color palette selection process 738. The display information 724' may include the gamma of the display device 547 and the color palette of the display device 547.
  • Figure 22 is a high level flow diagram of a method 735' which may be used to effect the display driver management process 735.
  • the display driver management method accepts 735' glyph(s) from the glyph cache 726 and display information from the display device 547 (or display information about the display device 547 from a system configuration file) as shown in steps 2210 and 2220. Then, the method 735' may invoke a color filtering process 736, described in more detail below in ⁇ 4.2.2.2.1, in step 2230. The method 735' may also invoke a gamma correction process 737, described in more detail in ⁇ 4.2.2.2.2, in step 2240.
  • the method 735' may invoke a color palette selection process 738, described in more detail below in ⁇ 4.2.2.2.3, in step 2250.
  • the method 735' is left via RETURN node 2260.
  • FILTERING COLOR COMPENSATION
  • the overscaling (or oversampling) and scan conversion processes effectively increase the resolution of the display device in the vertical direction by separately considering the red 210, green 220, and blue 230 sub-pixel elements, if the intensity values of adjacent sub-pixels differ by too much, the resulting display may be visually annoying to a user.
  • the color compensation (color filtering) process 736 is used to decrease intensity differences between certain adjacent sub-pixel elements if the intensity differences are too large.
  • FIG 23 is a flow diagram of an exemplary method 736' which may be used to effect the color filtering process 736.
  • filter parameters are accepted.
  • two (2) filters namely a red filter and a blue filter are provided.
  • the red filter uses a threshold, a red factor, and a green factor.
  • the blue filter uses a threshold, a green factor, a blue factor, and a red factor.
  • the loop defined by steps 2320 and 2380 is run for each packed pixel value of a glyph being processed.
  • normalized red, green and blue intensity values are determined from the packed pixel value as shown in step
  • the color space 0 through 255 may be divided into equal segments based on weighted colors. Thus, for example, if there are five (5) red colors, the color space is divided into five (5) segments, each spaced 255/5 apart.
  • normalized colors can be determined using the following expression:
  • step 2340 it is determined whether the absolute value (i.e., the magnitude) of the difference between the red and green intensities is greater than the red filter threshold value. If so, as shown in step 2350, the red and green intensities are adjusted to decrease the magnitude of the difference. For example, part of this step may be carried out in accordance with the following expressions: if (R - G) > Red Filter Threshold, then
  • the green intensity (as modified in step 2350, if so modified), the blue intensity, and/or the red intensity (as modified in step 2350, if so modified) are modified to decrease the absolute value (i.e., the magnitude) of the difference.
  • Figure 24 is a high level flow diagram of an exemplary gamma correction method 2240' which may be used to effect the gamma correction process 2240.
  • This method 2240' may optionally normalize intensity values to a range in which gamma correction is most effective.
  • upper and lower "useful" intensity values are accepted. These bounds reflect the range of intensities in which gamma correction is most effective. If the range of intensities is from 0 to 255, the lower bound may be 30 and the upper bound may be 250 for example.
  • the intensity value(s) are accepted.
  • the intensity values are normalized t9 the "useful" range of intensities.
  • the normalization may be performed simply by clamping such that intensities below the lower bound are set to the lower bound and intensities above the upper bound are set to the upper bound.
  • the normalization may be performed by shifting and clamping the intensities
  • the intensities are scaled and rounded to fall within the "useful" range of intensities.
  • step 2440 the gamma of the device 547 is accepted and, in step 2450, the (normalized) intensity values are adjusted based on the gamma of the device 547.
  • the method 2240' is then left via RETURN node 2460. ⁇ 4.2.2.2.3 COLOR PALETTE SELECTION
  • Display devices typically have a palette of available colors.
  • the color as defined by the color filtered and gamma corrected red-green-blue intensity value triplet, is mapped to a closest available color of the display device 547.
  • the display information 724' may be used to select one of the look-up tables included in the set of look up tables to be used.
  • the look-up tables in the set of look-up tables are used for converting packed pixel values, used to represent the glyph, into processed pixel values.
  • the processed pixel values are of a form, such as 8-bit R, G and B luminous intensity values for example, which are used by the display adapter 548' and/or display device 547.
  • Each look-up table includes one entry for each potential packed pixel value and a corresponding output value.
  • a look-up table would include 180 packed pixel values and 18D co ⁇ esponding processed (e.g., output) pixel values.
  • Each output pixel value may be a pre-computed value that is generated by performing the implemented display driver processing operations using the packed pixel value, to which the output pixel value corresponds, as input.
  • a set of processed pixel values including R, G and B luminous intensity values, in the form utilized by the attached display adapter or display device is obtained.
  • the processed pixel values included in the look-up table may be pre- computed, that is, computed before use in the display driver 732. By pre-computing the processed pixel values, the need to perform gamma correction, color compensation and/or palette selection operations in real time during image rendering is avoided.
  • Gamma correction, color compensation and/or palette selection operations may be performed using the packed pixel values as input to generate processed pixel values in a format suitable for use by the display adapter 548' and/or display 547.
  • a conventional display adapter 548' may be operated in a conventional manner to buffer video grams and to adapt the video frames for output to the display device 547.
  • the present invention disclosed techniques for increasing the resolution of text rendered on a display device having sub-pixel elements, such as an RGB LCD for example, and in particular, on a display device having horizontal striping.
  • the present invention disclosed techniques for appropriately adjusting metrics associated with the character outline information (such as left side bearing, advance width, vertical character sizel etc.).
  • the present invention also disclosed techniques for preventing "jumping" or "bouncing" baselines.
  • the present invention also disclosed techniques for compressing red, green and blue luminous intensity values.
  • the present invention also disclosed techniques for selectively filtering color values when the differences in the intensity of adjacent sub-pixel elements would otherwise be irritating to view.
  • the present invention disclosed techniques for correcting the gamma of the pixel values so that the gamma of the display device is considered and so that intensity values of sub-pixel elements fall within a range of intensities in which gamma correction is more useful.

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Control Of Indicators Other Than Cathode Ray Tubes (AREA)
  • Controls And Circuits For Display Device (AREA)
  • Image Generation (AREA)
EP00926494A 1999-04-29 2000-04-28 Verfahren, vorrichtung uns datenstrukturen um eine gleichmässige grundlinie in einem system zur textdarstellung zu erzielen Withdrawn EP1203345A4 (de)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US301905 1981-09-14
US30190599A 1999-04-29 1999-04-29
PCT/US2000/011741 WO2000067196A1 (en) 1999-04-29 2000-04-28 Method, apparatus and data structures for maintaining a consistent baseline position in a system for rendering text

Publications (2)

Publication Number Publication Date
EP1203345A1 true EP1203345A1 (de) 2002-05-08
EP1203345A4 EP1203345A4 (de) 2004-04-14

Family

ID=23165397

Family Applications (1)

Application Number Title Priority Date Filing Date
EP00926494A Withdrawn EP1203345A4 (de) 1999-04-29 2000-04-28 Verfahren, vorrichtung uns datenstrukturen um eine gleichmässige grundlinie in einem system zur textdarstellung zu erzielen

Country Status (4)

Country Link
EP (1) EP1203345A4 (de)
JP (1) JP2002543473A (de)
AU (1) AU4501700A (de)
WO (1) WO2000067196A1 (de)

Families Citing this family (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1210708B1 (de) * 1999-07-30 2012-07-18 Microsoft Corporation Schriftzeichenwiedergabe mit subpixelpräzision und an pixelpräzisionszeichen angepasste zeichenbreite
US8022969B2 (en) * 2001-05-09 2011-09-20 Samsung Electronics Co., Ltd. Rotatable display with sub-pixel rendering
ATE459908T1 (de) 2001-05-02 2010-03-15 Bitstream Inc Verfahren, systeme und programmierung zur herstellung und anzeige von subpixeloptimierten font-bitmaps unter verwendung eines nichtlinearen farbausgleichs
US7219309B2 (en) 2001-05-02 2007-05-15 Bitstream Inc. Innovations for the display of web pages
US7123277B2 (en) * 2001-05-09 2006-10-17 Clairvoyante, Inc. Conversion of a sub-pixel format data to another sub-pixel data format
US7221381B2 (en) * 2001-05-09 2007-05-22 Clairvoyante, Inc Methods and systems for sub-pixel rendering with gamma adjustment
US7184066B2 (en) 2001-05-09 2007-02-27 Clairvoyante, Inc Methods and systems for sub-pixel rendering with adaptive filtering
JP2003302962A (ja) * 2002-04-08 2003-10-24 Sharp Corp 表示装置、文字・図形表示方法、文字・図形表示プログラムおよび可読記録媒体
JP2008064771A (ja) 2004-12-27 2008-03-21 Sharp Corp 表示パネルの駆動装置、それを備えた表示装置及び表示パネルの駆動方法、並びにプログラム、記録媒体
JP5424534B2 (ja) 2007-01-31 2014-02-26 日立コンシューマエレクトロニクス株式会社 画像処理装置および画像表示装置
KR101332495B1 (ko) * 2010-05-20 2013-11-26 엘지디스플레이 주식회사 영상처리방법 및 이를 이용한 표시장치
GB2552338B (en) 2016-07-19 2020-06-24 Ge Aviat Systems Ltd Display of intensity profile discs
KR102185668B1 (ko) * 2019-01-30 2020-12-02 스노우 주식회사 이미지 파일의 픽셀 변환을 통한 압축율 향상 방법 및 시스템

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0346621A2 (de) * 1988-06-13 1989-12-20 International Business Machines Corporation Verfahren und Vorrichtung zur Wiedergabe eines mehrfarbigen Bildes
EP0693740A1 (de) * 1994-07-19 1996-01-24 Microsoft Corporation Verfahren zur Schriftdarstellung mit Anwendung der Grauwertverarbeitung von gitterangepassten Schrifttypen

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5543819A (en) * 1988-07-21 1996-08-06 Proxima Corporation High resolution display system and method of using same
US5159668A (en) * 1989-05-08 1992-10-27 Apple Computer, Inc. Method and apparatus for manipulating outlines in improving digital typeface on raster output devices

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0346621A2 (de) * 1988-06-13 1989-12-20 International Business Machines Corporation Verfahren und Vorrichtung zur Wiedergabe eines mehrfarbigen Bildes
EP0693740A1 (de) * 1994-07-19 1996-01-24 Microsoft Corporation Verfahren zur Schriftdarstellung mit Anwendung der Grauwertverarbeitung von gitterangepassten Schrifttypen

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
See also references of WO0067196A1 *

Also Published As

Publication number Publication date
AU4501700A (en) 2000-11-17
WO2000067196A1 (en) 2000-11-09
EP1203345A4 (de) 2004-04-14
WO2000067196B1 (en) 2000-12-21
JP2002543473A (ja) 2002-12-17

Similar Documents

Publication Publication Date Title
US6339426B1 (en) Methods, apparatus and data structures for overscaling or oversampling character feature information in a system for rendering text on horizontally striped displays
US6393145B2 (en) Methods apparatus and data structures for enhancing the resolution of images to be rendered on patterned display devices
US6282327B1 (en) Maintaining advance widths of existing characters that have been resolution enhanced
JP4633263B2 (ja) 表示文字の位置付け方法および装置
US6342890B1 (en) Methods, apparatus, and data structures for accessing sub-pixel data having left side bearing information
EP2579246B1 (de) Abbilden von Mustern von Vordergrund-/Hintergrundfarbbilddaten auf Pixelunterkomponenten
US6396505B1 (en) Methods and apparatus for detecting and reducing color errors in images
US6360023B1 (en) Adjusting character dimensions to compensate for low contrast character features
EP1125270B1 (de) Verfahren zur Anzeige von Bildern wie Text mit verbesserter Auflösung
US6356278B1 (en) Methods and systems for asymmeteric supersampling rasterization of image data
US6342896B1 (en) Methods and apparatus for efficiently implementing and modifying foreground and background color selections
WO2000067196A1 (en) Method, apparatus and data structures for maintaining a consistent baseline position in a system for rendering text
EP1155396A1 (de) Zuordnung von bilddatenproben zu bildpunkt- teilkomponenten auf einer, in streifen aufgeteilten anzeigevorrichtung
WO2000067247A1 (en) Methods, apparatus and data structures for determining glyph metrics for rendering text on horizontally striped displays
WO2002001546A1 (en) Data structures for overscaling or oversampling character in a system for rendering text on horizontally striped displays
EP1226508B1 (de) Einstellung von zeichendimensionen um niedrige kontrastmerkmale der zeichen auszugleichen

Legal Events

Date Code Title Description
PUAI Public reference made under article 153(3) epc to a published international application that has entered the european phase

Free format text: ORIGINAL CODE: 0009012

17P Request for examination filed

Effective date: 20011128

AK Designated contracting states

Kind code of ref document: A1

Designated state(s): AT BE CH CY DE DK ES FI FR GB GR IE IT LI LU MC NL PT SE

RIC1 Information provided on ipc code assigned before grant

Free format text: 7G 09G 3/36 A

RIN1 Information on inventor provided before grant (corrected)

Inventor name: CUKIERMAN, RYAN E.

Inventor name: HITCHCOCK, GREGORY C.

Inventor name: KEELY, LEROY B., JR.

Inventor name: LUI, CHARLTON E.

A4 Supplementary search report drawn up and despatched

Effective date: 20040227

RIC1 Information provided on ipc code assigned before grant

Ipc: 7G 09G 5/28 A

17Q First examination report despatched

Effective date: 20040419

RTI1 Title (correction)

Free format text: METHOD AND DATA STRUCTURES FOR MAINTAINING A CONSISTENT BASELINE POSITION IN A SYSTEM FOR RENDERING TEXT

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: THE APPLICATION IS DEEMED TO BE WITHDRAWN

18D Application deemed to be withdrawn

Effective date: 20051108

RIN1 Information on inventor provided before grant (corrected)

Inventor name: CUKIERMAN, RYAN E.

Inventor name: HITCHCOCK, GREGORY C.

Inventor name: KEELY, LEROY B., JR.

Inventor name: LUI, CHARLTON E.