US20160110905A1 - Systems and Methods For Rendering Graphical Content and Glyphs - Google Patents

Systems and Methods For Rendering Graphical Content and Glyphs Download PDF

Info

Publication number
US20160110905A1
US20160110905A1 US14/976,010 US201514976010A US2016110905A1 US 20160110905 A1 US20160110905 A1 US 20160110905A1 US 201514976010 A US201514976010 A US 201514976010A US 2016110905 A1 US2016110905 A1 US 2016110905A1
Authority
US
United States
Prior art keywords
glyphs
page
image
processor
property
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.)
Abandoned
Application number
US14/976,010
Inventor
Raymond C. Kurzweil
Paul Albrecht
Peter Chapman
Jeff Brewer
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.)
EM ACQUISITION CORP Inc
K NFB READING Tech Inc
Original Assignee
EM ACQUISITION CORP Inc
K NFB READING Tech Inc
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 EM ACQUISITION CORP Inc, K NFB READING Tech Inc filed Critical EM ACQUISITION CORP Inc
Priority to US14/976,010 priority Critical patent/US20160110905A1/en
Publication of US20160110905A1 publication Critical patent/US20160110905A1/en
Assigned to K-NFB READING TECHNOLOGY, INC. reassignment K-NFB READING TECHNOLOGY, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: BREWER, JEFF, CHAPMAN, PETER, KURZWEIL, RAYMOND C., ALBRECHT, PAUL
Assigned to EM ACQUISITION CORP., INC. reassignment EM ACQUISITION CORP., INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: DIMENSIONAL STACK ASSETS, LLC
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T11/002D [Two Dimensional] image generation
    • G06T11/60Editing figures and text; Combining figures or text

Definitions

  • Webpages and documents often include both glyph-based (e.g., textual) and graphical components that are combined when rendered on a viewable display.
  • glyph-based e.g., textual
  • graphical components that are combined when rendered on a viewable display.
  • the amount of time it takes for the webpage or display to load, e.g., to be viewable on the screen, can depend on the format and size of the contents of the document or page.
  • This invention relates generally to techniques for rendering pages with both graphical and glyph-based (e.g., text-based, character-based, or symbol-based) content.
  • the techniques can improve performance of rendered pages by converting graphical content to an image while preserving the glyph-based content.
  • the techniques described herein locate and hide all the glyph-based content (e.g., hide all of the glyphs such as letters, numbers, and characters) and produce an image from remaining components of the page including all of the graphical content for the page.
  • the image provides a background onto which the glyphs can be overlaid because the glyphs are not included in the image. Because the glyphs are overlaid (e.g., presented in a higher level layer of the page), any glyphs that were originally not visible on the rendered page are excluded from the subset of overlaid glyphs.
  • the techniques determine which of the glyphs included in the original page were visible (e.g., not obscured by other content such as graphics) and removes all glyphs or characters that are not visible (e.g., that were hidden by other images or graphics). Only those glyphs that are visible are rendered on the page with the background image.
  • the font color of all glyphs is changed to a first color
  • an image of the page is generated (e.g., a bitmap image).
  • the font color of all glyphs is changed to a second color and a second image of the page (e.g., a second bitmap image) is generated.
  • a computer-implemented method includes determining portions of a page that include glyphs, generating by a computer an image that includes non-glyph portions of the page by converting graphical content associated with the page into an image, classifying by the computer the glyphs into visible glyphs and non-visible glyphs, removing by the computer the non-visible glyphs, and overlaying by the computer the visible glyphs on the image of the non-glyph portions of the page when rendering the page.
  • a system includes one or more processors configured to determine portions of a page that include glyphs, generate an image that includes non-glyph portions of the page by converting graphical content associated with the page into an image, classify the glyphs into visible glyphs and non-visible glyphs, remove the non-visible glyphs and overlay the visible glyphs on the image of the non-glyph portions of the page when rendering the page.
  • a computer program product tangibly embodied in a computer readable device includes instructions to cause a processor to determine portions of a page that include glyphs, generate an image that includes non-glyph portions of the page by converting graphical content associated with the page into an image, classify the glyphs into visible glyphs and non-visible glyphs, remove the non-visible glyphs and overlay the visible glyphs on the image of the non-glyph portions of the page when rendering the page.
  • a method includes determining portions of a page that include glyphs. The method also includes classifying the glyphs into visible glyphs and non-visible glyphs by changing a property associated with at least one of the glyphs to a first value, generating a first image of the page based on the first value of the property, changing the property of at least one of the all glyphs to a second, different value, generating a second image of the page based on the second value of the property, and comparing the first and second images to detect differences in the property of the glyphs between the first and the second images.
  • Embodiments can include one or more of the following.
  • the image can be a bitmap.
  • Classifying the glyphs can include determining if a glyph is hidden by an image or graphic. Classifying the glyphs can include changing a property associated with all glyphs to a first value, generating a first image of the page based on the first value of the property, changing the property of all glyphs to a second, different value, generating a second image of the page based on the second value of the property, and comparing the first and second images to detect differences in the property of the glyphs between the first and the second images.
  • Classifying the glyphs can include changing the color of all glyphs to a first color, generating a first image of the page, changing the color of all glyphs to a second color, generating a second image of the page, and comparing the first and second images to detect differences in the colors of the glyphs between the first and the second images. Comparing the first and second images can include determining portions where the first and second images differ. The method can also include using speech-to-text processing to generate an audio output of the visible glyphs.
  • FIG. 1 is a block diagram of a system.
  • FIG. 2 is a flowchart of generating a viewable display.
  • FIGS. 3A-3D show exemplary portions of a document or page.
  • FIG. 4 is a flowchart of a process for determining glyphs that are viewable on a rendered document or page.
  • FIGS. 5A-5E show exemplary portions of a document or page.
  • the system 10 improves performance of rendered pages, e.g., the speed at which the page loads, by converting graphical content to an image while preserving glyph-based content such as letters, numbers, or other characters that exist in the image.
  • the system 10 includes a computer system 12 .
  • the computer system 12 is generally a personal computer or can alternatively be another type of computing device (e.g., a server, a cellular phone that includes a processor, a handheld computer, a camera, an electronic book reader, etc.) and typically includes a processor 14 .
  • the processor 14 can be a Pentium based system from Intel Corporation, Santa Clara, Calif., although other processors could alternatively be used.
  • the computer system 12 includes main memory, 16 cache memory and bus interface circuits (not shown).
  • the computer system 12 includes a mass storage element 18 , here typically the hard drive associated with personal computer systems.
  • the system 10 can also include a standard PC type keyboard (not shown), a standard monitor 20 as well as speakers (not shown), a sound card (not shown), a pointing device such as a mouse (not shown) all coupled to various ports of the computer system 12 via appropriate interfaces and software drivers (not shown) and a system bus 19 .
  • the computer system 12 here operates under a Windows Microsoft Corporation operating system although other systems could alternatively be used.
  • page conversion software 30 Resident on the mass storage element 16 is page conversion software 30 (described in FIG. 2 ) that generates pages with both graphical and glyph-based (e.g., textual) content in a format that improves rendering of the pages.
  • pages such as XAML pages or PDF based pages include a large amount of content that can take a long time to render.
  • the page conversion software 30 generates an image that includes all of the graphical content (e.g., as opposed to multiple separate images) in a file type that can be easily and quickly rendered such as a bitmap or tiff image.
  • the conversion software 30 overlays any previously visible text (and excludes previously non-visible text, if any) onto the image of the graphical content.
  • Other content on the original page such as videos, can be preserved in the content's original format.
  • the page conversion software 30 receives 32 a document or webpage that includes both graphical and glyph-based (e.g., textual) portions.
  • the document or page can be in various formats such as XML or other programming languages.
  • the graphical and glyph-based portions can be included in multiple different layers that are combined to render the complete document or page.
  • the page conversion software 30 identifies 34 glyph-based portions of the document of webpage.
  • a glyph is a term used to define an element of writing such as text, e.g., individual marks or markings on a written document that contributes to the meaning of what is written on the document.
  • images and graphical content are not used to form text.
  • the system identifies all of the glyphs included in each of the layer(s) that are combined to render the page.
  • the glyphs include any letters, numbers, or symbols included in a written language (e.g., English letters and numbers, Chinese characters, etc).
  • the system also identifies 36 all image based portions of the document. That is, portions of the document that include pixels that are not used to form glyphs can be identified as graphical content. In identifying the graphical portions, the system excludes executable files such as videos and/or sound files.
  • the page conversion software 30 identifies 38 glyphs that are included in the document or page that are not viewable when the document is rendered. Identifying the glyphs that are included in the document or page that are not viewable can also be beneficial in applications in which text-to-speech processes are used to read out loud the text displayed on a page or document to ensure that only the text that is visible is read out loud during the text-to-speech process. In some additional examples, identifying the glyphs that are included in the document or page that are not viewable can also be beneficial in applications in which a word search of a document is performed to ensure that only the text that is visible is included in the search.
  • Various techniques that are executed on a processor in a computer system can be used to identify the portions of glyph-based content that are/are not viewable in the rendered image.
  • One technique uses hit testing to determine whether the pixel associated with the glyph is the first pixel encountered from front to back in the layers of the image. If another pixel is “hit” prior to reaching the glyph pixel, then the system determines that the glyph pixel is not viewable in the final document or page.
  • a comparison of two rendered pages can be used to determine what glyphs are rendered in the document or page. For example, the page conversion software 30 generates two different renderings of the page or document with the font color of all glyphs is changed between the two renderings such that the font color is different between the two pages.
  • the page conversion software 30 determines what glyphs are viewable by classifying areas where a color change is observed as including visible glyphs. In some examples, a portion of less than the entire page can be converted into an image and analyzed to see where the color change is observed. For example, a character-by-character or pixel-by-pixel comparison could be implemented.
  • the page conversion software 30 reduces the total size of the graphical content by removing 40 all glyphs and generating a bitmap (or other image file) of the remaining content. Generating a single image of the remaining content (e.g., the graphical or non-glyph content), reduces the total size of the file used to render the graphical content and can enable the page to be rendered quicker than having the page rendered directly from the XML form.
  • generating the bitmap or other image file can include changing the format of the image from a higher resolution image to a lower resolution image.
  • the page conversion software 30 places 42 all glyphs that are viewable in a layer that is overlaid on top of the bitmap when rendered. As such, the layers of the page or document are reduced to a single bitmap or other image file that includes all of the graphical content and a layer that includes all of the glyphs that is overlaid onto the graphical content layer.
  • an additional layer can include executable files such as videos.
  • the glyphs are associated with positional and size information that associates the glyph elements to respective locations in the image representation of the document as displayed on the display device.
  • Information related to formatting such as font style, font color, background color, font size, and so forth for each of the glyphs can also be stored such that the glyphs are rendered in the same format as in the original page or document.
  • FIG. 3A shows an exemplary rendered document or page 50 .
  • the rendered document or page 50 includes visible non-glyph based portions and glyph-based portions.
  • the non-glyph based items include a graphic of a cow 54 and a page border 52 .
  • the glyph based portions include both visible and non-visible portions.
  • the visible glyph-based portions are the words “The cow lived on the farm.” While the rendering of the document or page includes only one portion of visible text—“The cow lived on the farm”—other glyphs are included in the document that are not visible because the glyphs are obscured by the graphical content (e.g., glyphs 58 and 60 as shown in FIG. 3C ).
  • the page conversion software 30 identifies the glyph-based portions of the document of webpage.
  • the identified glyph-based portions include both the visible and the non-visible glyphs.
  • the identified glyphs include both the glyphs that are displayed in the rendered document (e.g., glyphs 56 ) and the glyphs that are not visible in the rendered document (e.g., glyphs 58 and 60 ).
  • the glyphs 58 and 60 are obscured by the graphic of the cow 54 and the page border 52 , respectively.
  • the system also identifies all image based portions of the document.
  • the graphical portions of the document or page include the graphic of the cow 54 and the page border 52 .
  • the page conversion software 30 generates a bitmap (or other image file) of the remaining graphical portions (e.g., the portions shown in FIG. 3B ) by removing all glyph based portions and generating a single image of the remaining content.
  • the page conversion software 30 determines which of the glyphs are visible (e.g., the glyphs shown in FIG. 3D ) and stores the glyphs that are viewable in a layer to be displayed on top of the bitmap. As such, the layers of the page or document are reduced to a single bitmap or other image file that includes all of the graphical content (e.g., as shown in FIG. 3B ) and a layer that includes all of the glyphs that is overlaid onto the graphical content layer (e.g., as shown in FIG. 3D ).
  • FIG. 4 shows a process 70 for determining which portion of the glyphs included in a page or document are visible in the rendered document using a color property of the glyphs.
  • the process includes determining the portions of the document or page that include glyphs by locating each of the glyphs included in the various layers of the page that are combined to generate the rendered document or page.
  • the page conversion software 30 changes 74 all of the glyphs to a first color.
  • the page conversion software 30 generates 75 a rendering of the complete page or document (e.g., the glyphs plus any other content).
  • the rendered image is stored 76 in a memory associated with the computer system as first glyph color rendering.
  • the page conversion software 30 changes 78 all of the glyphs to a second color that is different from the first color, renders 79 the complete page or document (e.g., the glyphs plus any other content) and stores 80 the rendered page as a second glyph color rendering. For example, if the first color is red and the second color is black, regardless of the original font colors of the glyphs in the page or document, the first color rendering will include all glyphs in red font and the second color rendering will include all glyphs in black font.
  • the page conversion software 30 compares 82 the first and second color renderings to determine which portions (e.g., which pixels) have changed color.
  • the page conversion software 30 After identifying the visible glyphs, the page conversion software 30 generates a clipping mask to select the portions where the color has changed (e.g., the visible glyphs). By selecting only the portions where there was a visible color change, any obscured glyphs or otherwise non-visible glyphs will not be included in the clipping mask.
  • FIGS. 5A-5E shows an example of the glyphs and the rendered documents using the above described page conversion software 30 to identify the visible glyphs.
  • the glyphs both the visible 56 , and non-visible portions 58 and 60
  • a first color here the color is black.
  • FIG. 5B in a rendered image, only the portion 56 is visible and displayed in black font because portions 58 and 60 are obscured by the images of the cow and page border, respectively.
  • the glyphs both the visible 56 and non-visible portions 58 and 60
  • the glyphs are changed to a second color (here the color is grey).
  • FIG. 5D in a rendered image using the font of the second color, only the portion 56 is visible and displayed in grey font.
  • the rendered images e.g., the images shown in FIG. 5B and 5D
  • the color of the pixels in the two images changes only where the glyphs are visible.
  • text-to-speech processes are used to read out loud the text displayed on a page or document.
  • Optical character recognition is performed on the text that is clipped for display after the non-visible text is removed.
  • non-visible glyphs from the original document are not read out loud during the text-to-speech process.
  • searching software or algorithms are used to perform a word search on the text displayed on a page or document.
  • Optical character recognition is performed on the text that is clipped for display after the non-visible text is removed. Thus, only the text that is visible and should be included in the search. Thus, non-visible glyphs from the original document are not included in the search results.
  • glyphs can be partially obscured by transparent or semi-transparent overlying images.
  • glyphs that are viewable are placed in a layer that is overlaid on top of the bitmap when rendered.
  • These glyphs would include glyphs that are partially obscured by transparent or semi-transparent overlying images assuming that the glyphs are still visible in the original document.
  • the layers of the page or document are reduced to a single bitmap or other image file that includes all of the graphical content and a layer that includes all of the glyphs that is overlaid onto the graphical content layer.
  • the formatting of the font is altered to have the same appearance as in the original document.
  • the font can be partially blurred or the color of the font can be adjusted to create the illusion that the image overlays the font.
  • the systems and methods described herein can be implemented in digital electronic circuitry, or in computer hardware, firmware, software, web-enabled applications, or in combinations thereof.
  • Data structures used to represent information can be stored in memory and in persistence storage.
  • Apparatus of the invention can be implemented in a computer program product tangibly embodied in a machine-readable storage device for execution by a programmable processor and method actions can be performed by a programmable processor executing a program of instructions to perform functions of the invention by operating on input data and generating output.
  • the invention can be implemented advantageously in one or more computer programs that are executable on a programmable system including at least one programmable processor coupled to receive data and instructions from, and to transmit data and instructions to, a data storage system, at least one input device, and at least one output device.
  • Each computer program can be implemented in a high-level procedural or object oriented programming language, or in assembly or machine language if desired, and in any case, the language can be a compiled or interpreted language.
  • Suitable processors include, by way of example, both general and special purpose microprocessors. Generally, a processor will receive instructions and data from a read-only memory and/or a random access memory.
  • a computer will include one or more mass storage devices for storing data files, such devices include magnetic disks, such as internal hard disks and removable disks magneto-optical disks and optical disks.
  • Storage devices suitable for tangibly embodying computer program instructions and data include all forms of memory, non-volatile and volatile and including, by way of example, semiconductor memory devices, such as EPROM, EEPROM, and flash memory devices; magnetic disks such as, internal hard disks and removable disks; magneto-optical disks; and CD_ROM disks. Any of the foregoing can be supplemented by, or incorporated in, ASICs (application-specific integrated circuits).
  • ASICs application-specific integrated circuits
  • the system in order to identify the glyphs, can recolor all images to a single color (white or black) without changing transparencies of the elements and compare the recolored image to the original image.
  • the system in order to identify the glyphs, can use multiple colors (or hues) in a single rendering pass to identify which glyphs are missing and which are visible. In such examples, the change in the hue of the glyphs will cause each glyph to differ from the original image such that the glyphs can be identified by a comparison of the rendering with the original image.

Landscapes

  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • User Interface Of Digital Computer (AREA)

Abstract

Disclosed are techniques and systems for rendering pages or documents with both graphical and textual content.

Description

  • This application claims priority from and incorporates herein by reference in its entirety U.S. Provisional Application No. 61/379,097, filed Sep. 1, 2010, and titled: “SYSTEMS AND METHODS FOR RENDERING GRAPHICAL CONTENT AND GLYPHS.”
  • BACKGROUND
  • Webpages and documents often include both glyph-based (e.g., textual) and graphical components that are combined when rendered on a viewable display. The amount of time it takes for the webpage or display to load, e.g., to be viewable on the screen, can depend on the format and size of the contents of the document or page.
  • SUMMARY
  • This invention relates generally to techniques for rendering pages with both graphical and glyph-based (e.g., text-based, character-based, or symbol-based) content. The techniques can improve performance of rendered pages by converting graphical content to an image while preserving the glyph-based content.
  • To convert graphical content to an image while preserving the glyph-based content, the techniques described herein locate and hide all the glyph-based content (e.g., hide all of the glyphs such as letters, numbers, and characters) and produce an image from remaining components of the page including all of the graphical content for the page. The image provides a background onto which the glyphs can be overlaid because the glyphs are not included in the image. Because the glyphs are overlaid (e.g., presented in a higher level layer of the page), any glyphs that were originally not visible on the rendered page are excluded from the subset of overlaid glyphs. The techniques determine which of the glyphs included in the original page were visible (e.g., not obscured by other content such as graphics) and removes all glyphs or characters that are not visible (e.g., that were hidden by other images or graphics). Only those glyphs that are visible are rendered on the page with the background image.
  • Various approaches can be used to determine which glyphs are visible on the originally rendered page. In one exemplary approach, the font color of all glyphs is changed to a first color, an image of the page is generated (e.g., a bitmap image). The font color of all glyphs is changed to a second color and a second image of the page (e.g., a second bitmap image) is generated. By comparing the images to see where they differ, any areas where the color of the pixels has changed corresponds to visible glyphs while glyphs or glyph characters where the color has not changed are not visible and are removed or hidden.
  • In some aspects, a computer-implemented method includes determining portions of a page that include glyphs, generating by a computer an image that includes non-glyph portions of the page by converting graphical content associated with the page into an image, classifying by the computer the glyphs into visible glyphs and non-visible glyphs, removing by the computer the non-visible glyphs, and overlaying by the computer the visible glyphs on the image of the non-glyph portions of the page when rendering the page.
  • In other aspects, a system includes one or more processors configured to determine portions of a page that include glyphs, generate an image that includes non-glyph portions of the page by converting graphical content associated with the page into an image, classify the glyphs into visible glyphs and non-visible glyphs, remove the non-visible glyphs and overlay the visible glyphs on the image of the non-glyph portions of the page when rendering the page.
  • In still other aspects, a computer program product tangibly embodied in a computer readable device includes instructions to cause a processor to determine portions of a page that include glyphs, generate an image that includes non-glyph portions of the page by converting graphical content associated with the page into an image, classify the glyphs into visible glyphs and non-visible glyphs, remove the non-visible glyphs and overlay the visible glyphs on the image of the non-glyph portions of the page when rendering the page.
  • In still other aspects, a method includes determining portions of a page that include glyphs. The method also includes classifying the glyphs into visible glyphs and non-visible glyphs by changing a property associated with at least one of the glyphs to a first value, generating a first image of the page based on the first value of the property, changing the property of at least one of the all glyphs to a second, different value, generating a second image of the page based on the second value of the property, and comparing the first and second images to detect differences in the property of the glyphs between the first and the second images.
  • Embodiments can include one or more of the following.
  • The image can be a bitmap. Classifying the glyphs can include determining if a glyph is hidden by an image or graphic. Classifying the glyphs can include changing a property associated with all glyphs to a first value, generating a first image of the page based on the first value of the property, changing the property of all glyphs to a second, different value, generating a second image of the page based on the second value of the property, and comparing the first and second images to detect differences in the property of the glyphs between the first and the second images. Classifying the glyphs can include changing the color of all glyphs to a first color, generating a first image of the page, changing the color of all glyphs to a second color, generating a second image of the page, and comparing the first and second images to detect differences in the colors of the glyphs between the first and the second images. Comparing the first and second images can include determining portions where the first and second images differ. The method can also include using speech-to-text processing to generate an audio output of the visible glyphs.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 is a block diagram of a system.
  • FIG. 2 is a flowchart of generating a viewable display.
  • FIGS. 3A-3D show exemplary portions of a document or page.
  • FIG. 4 is a flowchart of a process for determining glyphs that are viewable on a rendered document or page.
  • FIGS. 5A-5E show exemplary portions of a document or page.
  • DETAILED DESCRIPTION
  • Referring now to FIG. 1, a system 10 for generating and rendering pages with both graphical and glyph-based content is shown. The system improves performance of rendered pages, e.g., the speed at which the page loads, by converting graphical content to an image while preserving glyph-based content such as letters, numbers, or other characters that exist in the image. The system 10 includes a computer system 12. The computer system 12 is generally a personal computer or can alternatively be another type of computing device (e.g., a server, a cellular phone that includes a processor, a handheld computer, a camera, an electronic book reader, etc.) and typically includes a processor 14. In some examples, the processor 14 can be a Pentium based system from Intel Corporation, Santa Clara, Calif., although other processors could alternatively be used. In addition, to the processor 14, the computer system 12 includes main memory, 16 cache memory and bus interface circuits (not shown). The computer system 12 includes a mass storage element 18, here typically the hard drive associated with personal computer systems.
  • The system 10 can also include a standard PC type keyboard (not shown), a standard monitor 20 as well as speakers (not shown), a sound card (not shown), a pointing device such as a mouse (not shown) all coupled to various ports of the computer system 12 via appropriate interfaces and software drivers (not shown) and a system bus 19. The computer system 12 here operates under a Windows Microsoft Corporation operating system although other systems could alternatively be used.
  • Resident on the mass storage element 16 is page conversion software 30 (described in FIG. 2) that generates pages with both graphical and glyph-based (e.g., textual) content in a format that improves rendering of the pages. For example, pages such as XAML pages or PDF based pages include a large amount of content that can take a long time to render. The page conversion software 30 generates an image that includes all of the graphical content (e.g., as opposed to multiple separate images) in a file type that can be easily and quickly rendered such as a bitmap or tiff image. The conversion software 30 overlays any previously visible text (and excludes previously non-visible text, if any) onto the image of the graphical content. Other content on the original page, such as videos, can be preserved in the content's original format.
  • Referring now to FIG. 2 details of the page conversion software 30 for converting a webpage or other document into a format that can be more quickly rendered is shown. The page conversion software 30 receives 32 a document or webpage that includes both graphical and glyph-based (e.g., textual) portions. The document or page can be in various formats such as XML or other programming languages. The graphical and glyph-based portions can be included in multiple different layers that are combined to render the complete document or page. The page conversion software 30 identifies 34 glyph-based portions of the document of webpage.
  • As used herein a glyph is a term used to define an element of writing such as text, e.g., individual marks or markings on a written document that contributes to the meaning of what is written on the document. Excluded from the definition of a glyph are images and graphical content (non-limiting examples of which include graphs, pictures, charts, etc.) that are not used to form text. For example, the system identifies all of the glyphs included in each of the layer(s) that are combined to render the page. The glyphs include any letters, numbers, or symbols included in a written language (e.g., English letters and numbers, Chinese characters, etc). The system also identifies 36 all image based portions of the document. That is, portions of the document that include pixels that are not used to form glyphs can be identified as graphical content. In identifying the graphical portions, the system excludes executable files such as videos and/or sound files.
  • Due to stacking of multiple layers that are combined when rendering a complete page or document, it is possible that some glyphs included in the layers are not displayed in the rendered document or page. In order to insure that an image that is generated is consistent with the image of the originally viewable document or page, the page conversion software 30 identifies 38 glyphs that are included in the document or page that are not viewable when the document is rendered. Identifying the glyphs that are included in the document or page that are not viewable can also be beneficial in applications in which text-to-speech processes are used to read out loud the text displayed on a page or document to ensure that only the text that is visible is read out loud during the text-to-speech process. In some additional examples, identifying the glyphs that are included in the document or page that are not viewable can also be beneficial in applications in which a word search of a document is performed to ensure that only the text that is visible is included in the search.
  • Various techniques that are executed on a processor in a computer system can be used to identify the portions of glyph-based content that are/are not viewable in the rendered image. One technique uses hit testing to determine whether the pixel associated with the glyph is the first pixel encountered from front to back in the layers of the image. If another pixel is “hit” prior to reaching the glyph pixel, then the system determines that the glyph pixel is not viewable in the final document or page. In another technique, a comparison of two rendered pages can be used to determine what glyphs are rendered in the document or page. For example, the page conversion software 30 generates two different renderings of the page or document with the font color of all glyphs is changed between the two renderings such that the font color is different between the two pages. By comparing the rendered images to see where the two images differ, the page conversion software 30 determines what glyphs are viewable by classifying areas where a color change is observed as including visible glyphs. In some examples, a portion of less than the entire page can be converted into an image and analyzed to see where the color change is observed. For example, a character-by-character or pixel-by-pixel comparison could be implemented.
  • In order to generate a document of page that can be quickly rendered, the page conversion software 30 reduces the total size of the graphical content by removing 40 all glyphs and generating a bitmap (or other image file) of the remaining content. Generating a single image of the remaining content (e.g., the graphical or non-glyph content), reduces the total size of the file used to render the graphical content and can enable the page to be rendered quicker than having the page rendered directly from the XML form. In some examples, generating the bitmap or other image file can include changing the format of the image from a higher resolution image to a lower resolution image. In order to display the glyphs in addition to the graphical content, the page conversion software 30 places 42 all glyphs that are viewable in a layer that is overlaid on top of the bitmap when rendered. As such, the layers of the page or document are reduced to a single bitmap or other image file that includes all of the graphical content and a layer that includes all of the glyphs that is overlaid onto the graphical content layer. In some examples, an additional layer can include executable files such as videos.
  • In order to correctly align the glyphs with the image or bitmap of the graphical components, the glyphs are associated with positional and size information that associates the glyph elements to respective locations in the image representation of the document as displayed on the display device. Information related to formatting such as font style, font color, background color, font size, and so forth for each of the glyphs can also be stored such that the glyphs are rendered in the same format as in the original page or document.
  • FIG. 3A shows an exemplary rendered document or page 50. The rendered document or page 50 includes visible non-glyph based portions and glyph-based portions. In this exemplary page, the non-glyph based items include a graphic of a cow 54 and a page border 52. The glyph based portions include both visible and non-visible portions. The visible glyph-based portions are the words “The cow lived on the farm.” While the rendering of the document or page includes only one portion of visible text—“The cow lived on the farm”—other glyphs are included in the document that are not visible because the glyphs are obscured by the graphical content (e.g., glyphs 58 and 60 as shown in FIG. 3C).
  • The page conversion software 30 identifies the glyph-based portions of the document of webpage. The identified glyph-based portions include both the visible and the non-visible glyphs. As shown in FIG. 3C, the identified glyphs include both the glyphs that are displayed in the rendered document (e.g., glyphs 56) and the glyphs that are not visible in the rendered document (e.g., glyphs 58 and 60). In this example, the glyphs 58 and 60 are obscured by the graphic of the cow 54 and the page border 52, respectively. The system also identifies all image based portions of the document.
  • As shown in FIG. 3B, the graphical portions of the document or page include the graphic of the cow 54 and the page border 52. The page conversion software 30 generates a bitmap (or other image file) of the remaining graphical portions (e.g., the portions shown in FIG. 3B) by removing all glyph based portions and generating a single image of the remaining content.
  • The page conversion software 30 determines which of the glyphs are visible (e.g., the glyphs shown in FIG. 3D) and stores the glyphs that are viewable in a layer to be displayed on top of the bitmap. As such, the layers of the page or document are reduced to a single bitmap or other image file that includes all of the graphical content (e.g., as shown in FIG. 3B) and a layer that includes all of the glyphs that is overlaid onto the graphical content layer (e.g., as shown in FIG. 3D).
  • FIG. 4 shows a process 70 for determining which portion of the glyphs included in a page or document are visible in the rendered document using a color property of the glyphs. The process includes determining the portions of the document or page that include glyphs by locating each of the glyphs included in the various layers of the page that are combined to generate the rendered document or page. The page conversion software 30 changes 74 all of the glyphs to a first color. The page conversion software 30 generates 75 a rendering of the complete page or document (e.g., the glyphs plus any other content). The rendered image is stored 76 in a memory associated with the computer system as first glyph color rendering. The page conversion software 30 changes 78 all of the glyphs to a second color that is different from the first color, renders 79 the complete page or document (e.g., the glyphs plus any other content) and stores 80 the rendered page as a second glyph color rendering. For example, if the first color is red and the second color is black, regardless of the original font colors of the glyphs in the page or document, the first color rendering will include all glyphs in red font and the second color rendering will include all glyphs in black font. The page conversion software 30 compares 82 the first and second color renderings to determine which portions (e.g., which pixels) have changed color. As some portions of the glyphs may be obscured in the rendered document by graphics or io other content, while all of the glyphs (including the obscured glyphs) will have changed colors between the two renderings, only the portions of the glyphs that are visible will be seen as a changed color in the rendered pages. The glyphs that are hidden will have no visual effect due to the stacking order of the multiple layers and, thus, will not be seen a portion where a color change has occurred because the color of that portion will remain as the color of the higher level layer. After identifying the visible glyphs, the page conversion software 30 generates a clipping mask to select the portions where the color has changed (e.g., the visible glyphs). By selecting only the portions where there was a visible color change, any obscured glyphs or otherwise non-visible glyphs will not be included in the clipping mask.
  • FIGS. 5A-5E shows an example of the glyphs and the rendered documents using the above described page conversion software 30 to identify the visible glyphs. As shown in FIG. 5A, the glyphs (both the visible 56, and non-visible portions 58 and 60) are changed to a first color (here the color is black). As shown in
  • FIG. 5B, in a rendered image, only the portion 56 is visible and displayed in black font because portions 58 and 60 are obscured by the images of the cow and page border, respectively. As shown in FIG. 5C, the glyphs (both the visible 56 and non-visible portions 58 and 60) are changed to a second color (here the color is grey). As shown in FIG. 5D, in a rendered image using the font of the second color, only the portion 56 is visible and displayed in grey font. When the rendered images (e.g., the images shown in FIG. 5B and 5D) are compared, the color of the pixels in the two images changes only where the glyphs are visible. While the glyphs 58 and 60 changed colors between the rendered images, this color change is not evident in the displayed image because the glyphs are obscured by the image of the cow 54 and the border 52. As such, when selecting glyphs to overlay onto an image that includes all of the graphical elements, only the glyphs in portions where the color change was observed will be selected (e.g., as shown in FIG. 5E).
  • In some embodiments, text-to-speech processes are used to read out loud the text displayed on a page or document. Optical character recognition is performed on the text that is clipped for display after the non-visible text is removed. Thus, only the text that is visible and should be spoken is included. Thus, non-visible glyphs from the original document are not read out loud during the text-to-speech process.
  • In some embodiments, searching software or algorithms are used to perform a word search on the text displayed on a page or document. Optical character recognition is performed on the text that is clipped for display after the non-visible text is removed. Thus, only the text that is visible and should be included in the search. Thus, non-visible glyphs from the original document are not included in the search results.
  • In some embodiments, glyphs can be partially obscured by transparent or semi-transparent overlying images. As noted above, in generating a page that is more quickly viewable, glyphs that are viewable are placed in a layer that is overlaid on top of the bitmap when rendered. These glyphs would include glyphs that are partially obscured by transparent or semi-transparent overlying images assuming that the glyphs are still visible in the original document. As such, the layers of the page or document are reduced to a single bitmap or other image file that includes all of the graphical content and a layer that includes all of the glyphs that is overlaid onto the graphical content layer. Because the glyphs are overlaid in a layer above the images, the formatting of the font is altered to have the same appearance as in the original document. For example, the font can be partially blurred or the color of the font can be adjusted to create the illusion that the image overlays the font.
  • The systems and methods described herein can be implemented in digital electronic circuitry, or in computer hardware, firmware, software, web-enabled applications, or in combinations thereof. Data structures used to represent information can be stored in memory and in persistence storage. Apparatus of the invention can be implemented in a computer program product tangibly embodied in a machine-readable storage device for execution by a programmable processor and method actions can be performed by a programmable processor executing a program of instructions to perform functions of the invention by operating on input data and generating output. The invention can be implemented advantageously in one or more computer programs that are executable on a programmable system including at least one programmable processor coupled to receive data and instructions from, and to transmit data and instructions to, a data storage system, at least one input device, and at least one output device. Each computer program can be implemented in a high-level procedural or object oriented programming language, or in assembly or machine language if desired, and in any case, the language can be a compiled or interpreted language. Suitable processors include, by way of example, both general and special purpose microprocessors. Generally, a processor will receive instructions and data from a read-only memory and/or a random access memory. Generally, a computer will include one or more mass storage devices for storing data files, such devices include magnetic disks, such as internal hard disks and removable disks magneto-optical disks and optical disks. Storage devices suitable for tangibly embodying computer program instructions and data include all forms of memory, non-volatile and volatile and including, by way of example, semiconductor memory devices, such as EPROM, EEPROM, and flash memory devices; magnetic disks such as, internal hard disks and removable disks; magneto-optical disks; and CD_ROM disks. Any of the foregoing can be supplemented by, or incorporated in, ASICs (application-specific integrated circuits).
  • Other implementations are within the scope of the following claims: For example, other properties of the text could be used. For example, an image with the text in the original color could be compared to an image of the page with all text removed. Additionally, other properties could include font style or type or type face or color could changed between renderings, albeit using such properties could require modifications to the software used to identify the glyphs as the pixels forming the glyphs could change. For example, rather than using a pixel by pixel comparison, the general areas in which changes are identified could be identified as including text and a character recognition program could locate the characters within those regions. In some additional examples, in order to identify the glyphs, the system can recolor all images to a single color (white or black) without changing transparencies of the elements and compare the recolored image to the original image. In some additional examples, in order to identify the glyphs, the system can use multiple colors (or hues) in a single rendering pass to identify which glyphs are missing and which are visible. In such examples, the change in the hue of the glyphs will cause each glyph to differ from the original image such that the glyphs can be identified by a comparison of the rendering with the original image.

Claims (24)

1. A method comprises
determining by a processor device portions of a page that include glyphs;
generating by the processor device an image that includes non-glyph portions of the page by converting graphical content associated with the page into an image;
classifying by the processor device the glyphs into visible glyphs and non-visible glyphs;
removing by the processor device the non-visible glyphs; and
causing by the processor device a display device coupled to the processor device to render the visible glyphs on the image of the non-glyph portions of the page.
2. The method of claim 1, further comprising:
overlaying by the processor device the visible glyphs on the image of the non-glyph portions of the page when rendering the page.
3. The method of claim 1, wherein generating the image comprises generating by the processor device a bitmap image of the non-glyph portions of the page.
4. The method of claim 1, wherein classifying the glyphs comprises determining by the processor whether a glyph is hidden by an image or graphic.
5. The method of claim 1, wherein classifying the glyphs comprises:
changing by the processor a property associated with at least one of the glyphs to a first value;
generating by the processor a first image of the page based on the first value of the property;
changing by the processor the property of at least one of the glyphs to a second, different value;
generating by the processor a second image of the page based on the second value of the property; and
comparing by the processor the first and second images to detect differences in the property of the glyphs between the first and the second images.
6. The method of claim 1, wherein classifying the glyphs comprises:
changing by the processor a property associated with all of the glyphs to a first value;
generating by the processor a first image of the page based on the first value of the property;
changing by the processor the property of all glyphs to a second, different value;
generating by the processor a second image of the page based on the second value of the property; and
comparing by the processor the first and second images to detect differences in the property of the glyphs between the first and the second images.
7. The method of claim 1, wherein classifying the glyphs comprises:
changing by the processor the color of all glyphs to a first color;
generating by the processor a first image of the page;
changing by the processor the color of all glyphs to a second color;
generating by the processor a second image of the page; and
comparing by the processor the first and second images to detect differences in the colors of the glyphs between the first and the second images.
8. The method of claim 7, wherein comparing the first and second images comprises determining portions where the first and second images differ.
9. The method of claim 1, further comprising:
applying the visible glyphs to speech-to-text processing executed by the processor to generate an audio output of the visible glyphs.
10. A system, comprising:
one or more processor devices configured to:
determine portions of a page that include glyphs;
generate an image that includes non-glyph portions of the page by converting graphical content associated with the page into an image;
classify the glyphs into visible glyphs and non-visible glyphs;
remove the non-visible glyphs;
overlay the visible glyphs on the image of the non-glyph portions of the page when rendering the page; and
a display device coupled to the one or more processor devices.
11. The system of claim 10, wherein the processor device generates the image as a bitmap image of the non-glyph portions of the page.
12. The system of claim 10, wherein the processor device is configured to classify the glyphs by determining whether a glyph is hidden by an image or graphic.
13. The system of claim 10, wherein the processor configured to classify the glyphs comprises the processor configured to:
change a property associated with all glyphs to a first value;
generate a first image of the page based on the first value of the property;
change the property of all glyphs to a second, different value;
generate a second image of the page based on the second value of the property; and
compare the first and second images to detect differences in the property of the glyphs between the first and the second images.
14. The system of claim 10, wherein the processor configured to classify the glyphs comprises the processor configured to:
change the color of all glyphs to a first color;
generate a first image of the page;
change the color of all glyphs to a second color;
generate a second image of the page; and
compare the first and second images to detect differences in the colors of the glyphs between the first and the second images.
15. The system of claim 10, further comprising a speech-to-text unit configured to:
receive visible glyphs; and
generate an audio output of the visible glyphs.
16. A computer program product tangibly embodied in a computer readable hardware storage device, the computer program product comprising instructions to cause a processor to:
determine portions of a page that include glyphs;
generate an image that includes non-glyph portions of the page by converting graphical content associated with the page into an image;
classify the glyphs into visible glyphs and non-visible glyphs;
remove the non-visible glyphs; and
overlay the visible glyphs on the image of the non-glyph portions of the page when rendering the page.
17. The computer program product of claim 16, wherein the instructions to classify the glyphs comprise instructions to determine if a glyph is hidden by an image or graphic.
18. The computer program product of claim 16, wherein the instructions to classify the glyphs comprise instructions to:
change a property associated with all glyphs to a first value;
generate a first image of the page based on the first value of the property;
change the property of all glyphs to a second, different value;
generate a second image of the page based on the second value of the property; and
compare the first and second images to detect differences in the property of the glyphs between the first and the second images.
19. The computer program product of claim 16, wherein the instructions to classify the glyphs comprise instructions to:
change the color of all glyphs to a first color;
generate a first image of the page;
change the color of all glyphs to a second color;
generate a second image of the page; and
compare the first and second images to detect differences in the colors of the glyphs between the first and the second images.
20. A method comprises:
determining by a processor device those portions of a page that include glyphs; and
classifying by the processor device the glyphs into visible glyphs and non-visible glyphs by the processing device:
changing a property associated with at least one of the glyphs to a first value;
generating a first image of the page based on the first value of the property;
changing the property of at least one of the all glyphs to a second, different value;
generating a second image of the page based on the second value of the property; and
comparing the first and second images to detect differences in the property of the glyphs between the first and the second images.
21. The method of claim 20, wherein changing the property the first value comprises changing the property associated with all of the glyphs to the first value and changing the property to the second, different value comprises changing the property of all glyphs to the second, different value.
22. The method of claim 20, wherein the first property is a first color and the second property is a second, different color.
23. The method of claim 20, wherein comparing the first and second images comprises determining portions where the first and second images differ.
24. The method of claim 20, further comprising:
applying the visible glyphs to speech-to-text processing executed by the processor to generate an audio output of the visible glyphs.
US14/976,010 2010-09-01 2015-12-21 Systems and Methods For Rendering Graphical Content and Glyphs Abandoned US20160110905A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US14/976,010 US20160110905A1 (en) 2010-09-01 2015-12-21 Systems and Methods For Rendering Graphical Content and Glyphs

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US37909710P 2010-09-01 2010-09-01
US13/222,594 US9218680B2 (en) 2010-09-01 2011-08-31 Systems and methods for rendering graphical content and glyphs
US14/976,010 US20160110905A1 (en) 2010-09-01 2015-12-21 Systems and Methods For Rendering Graphical Content and Glyphs

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US13/222,594 Continuation US9218680B2 (en) 2010-09-01 2011-08-31 Systems and methods for rendering graphical content and glyphs

Publications (1)

Publication Number Publication Date
US20160110905A1 true US20160110905A1 (en) 2016-04-21

Family

ID=45696576

Family Applications (2)

Application Number Title Priority Date Filing Date
US13/222,594 Expired - Fee Related US9218680B2 (en) 2010-09-01 2011-08-31 Systems and methods for rendering graphical content and glyphs
US14/976,010 Abandoned US20160110905A1 (en) 2010-09-01 2015-12-21 Systems and Methods For Rendering Graphical Content and Glyphs

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US13/222,594 Expired - Fee Related US9218680B2 (en) 2010-09-01 2011-08-31 Systems and methods for rendering graphical content and glyphs

Country Status (1)

Country Link
US (2) US9218680B2 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20160314766A1 (en) * 2015-01-30 2016-10-27 E Ink Corporation Font control for electro-optic displays and related apparatus and methods

Families Citing this family (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100324895A1 (en) * 2009-01-15 2010-12-23 K-Nfb Reading Technology, Inc. Synchronization for document narration
US9472163B2 (en) * 2012-02-17 2016-10-18 Monotype Imaging Inc. Adjusting content rendering for environmental conditions
US9131192B2 (en) 2012-03-06 2015-09-08 Apple Inc. Unified slider control for modifying multiple image properties
US9202433B2 (en) 2012-03-06 2015-12-01 Apple Inc. Multi operation slider
US9041727B2 (en) 2012-03-06 2015-05-26 Apple Inc. User interface tools for selectively applying effects to image
US10282055B2 (en) 2012-03-06 2019-05-07 Apple Inc. Ordered processing of edits for a media editing application
US10319126B2 (en) 2016-08-16 2019-06-11 Microsoft Technology Licensing, Llc Ribbon to quick access toolbar icon conversion
US11443646B2 (en) 2017-12-22 2022-09-13 Fathom Technologies, LLC E-Reader interface system with audio and highlighting synchronization for digital books
US10671251B2 (en) 2017-12-22 2020-06-02 Arbordale Publishing, LLC Interactive eReader interface generation based on synchronization of textual and audial descriptors

Citations (30)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6456305B1 (en) * 1999-03-18 2002-09-24 Microsoft Corporation Method and system for automatically fitting a graphical display of objects to the dimensions of a display window
US6466210B1 (en) * 1997-12-22 2002-10-15 Adobe Systems Incorporated Blending image data using layers
US6594030B1 (en) * 1999-08-27 2003-07-15 Microsoft Corporation Intelligent automatic trapping of page objects
US20050132286A1 (en) * 2000-06-12 2005-06-16 Rohrabaugh Gary B. Resolution independent vector display of internet content
US20060117268A1 (en) * 2004-11-30 2006-06-01 Micheal Talley System and method for graphical element selection for region of interest compression
US20060251292A1 (en) * 2005-05-09 2006-11-09 Salih Burak Gokturk System and method for recognizing objects from images and identifying relevancy amongst images and information
US20070109322A1 (en) * 2005-11-14 2007-05-17 Brother Kogyo Kabushiki Kaisha Print control program product
US20070143669A1 (en) * 2003-11-05 2007-06-21 Thierry Royer Method and system for delivering documents to terminals with limited display capabilities, such as mobile terminals
US20070201752A1 (en) * 2006-02-28 2007-08-30 Gormish Michael J Compressed data image object feature extraction, ordering, and delivery
US20080168135A1 (en) * 2007-01-05 2008-07-10 Redlich Ron M Information Infrastructure Management Tools with Extractor, Secure Storage, Content Analysis and Classification and Method Therefor
US7412644B2 (en) * 2000-02-04 2008-08-12 Aol Llc, A Delaware Limited Liability Company System and process for delivering and rendering scalable web pages
US20090016605A1 (en) * 2007-07-11 2009-01-15 Hui Chao System and method for creating an editable template from a document image
WO2009049275A1 (en) * 2007-10-12 2009-04-16 Symantec Corporation Method for detecting and resolving hidden text salting
US20090110270A1 (en) * 2007-10-31 2009-04-30 Ctb/Mcgraw-Hill Llc Use of Composite Bitmapped Images in Conjunction with Display of Captured Data
US20090148039A1 (en) * 2007-12-05 2009-06-11 Canon Kabushiki Kaisha Colour document layout analysis with multi-level decomposition
US7600183B2 (en) * 2000-06-16 2009-10-06 Olive Software Inc. System and method for data publication through web pages
US20100232690A1 (en) * 2007-06-29 2010-09-16 Canon Kabushiki Kaisha Image processing apparatus, image processing method, and computer program
US20100246951A1 (en) * 2009-03-31 2010-09-30 Canon Kabushiki Kaisha Colour correcting foreground colours for visual quality improvement
US20110033080A1 (en) * 2004-05-17 2011-02-10 Exbiblio B.V. Processing techniques for text capture from a rendered document
US20110035345A1 (en) * 2009-08-10 2011-02-10 Yahoo! Inc. Automatic classification of segmented portions of web pages
US20110148909A1 (en) * 2009-12-17 2011-06-23 Canon Kabushiki Kaisha Generating object representation from bitmap image
US20110252315A1 (en) * 2010-04-07 2011-10-13 Canon Kabushiki Kaisha Image processing device, image processing method and non-transitory computer readable storage medium
US20110289395A1 (en) * 2002-03-01 2011-11-24 Xerox Corporation Method and system for document image layout deconstruction and redisplay
US20120093354A1 (en) * 2010-10-19 2012-04-19 Palo Alto Research Center Incorporated Finding similar content in a mixed collection of presentation and rich document content using two-dimensional visual fingerprints
US20130033523A1 (en) * 2011-08-04 2013-02-07 Research In Motion Limited Orientation-dependent processing of input files by an electronic device
US20130124968A1 (en) * 2009-09-25 2013-05-16 Lubomira A. Dontcheva System and Method for Using Design Features to Search for Page Layout Designs
US8498867B2 (en) * 2009-01-15 2013-07-30 K-Nfb Reading Technology, Inc. Systems and methods for selection and use of multiple characters for document narration
US8639680B1 (en) * 2012-05-07 2014-01-28 Google Inc. Hidden text detection for search result scoring
US9418171B2 (en) * 2008-03-04 2016-08-16 Apple Inc. Acceleration of rendering of web-based content
US9501460B1 (en) * 2013-02-28 2016-11-22 Google Inc. Detecting and processing invisible elements within a web page

Family Cites Families (34)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
AUPM704294A0 (en) * 1994-07-25 1994-08-18 Canon Information Systems Research Australia Pty Ltd Method and apparatus for the creation of images
AUPM704394A0 (en) * 1994-07-25 1994-08-18 Canon Information Systems Research Australia Pty Ltd Optimization method for the efficient production of images
AUPM704594A0 (en) * 1994-07-25 1994-08-18 Canon Information Systems Research Australia Pty Ltd Efficient methods for the compositing of graphical elements
US6415307B2 (en) 1994-10-24 2002-07-02 P2I Limited Publication file conversion and display
US8045204B2 (en) 2000-03-28 2011-10-25 Mongonet Methods and apparatus for facsimile transmissions to electronic storage destinations including tracking data
US6957384B2 (en) 2000-12-27 2005-10-18 Tractmanager, Llc Document management system
JP3733297B2 (en) * 2001-04-02 2006-01-11 キヤノン株式会社 Image processing method, image processing apparatus, and image processing system
US6973213B2 (en) * 2001-10-12 2005-12-06 Xerox Corporation Background-based image segmentation
US7139004B2 (en) * 2002-01-25 2006-11-21 Xerox Corporation Method and apparatus to convert bitmapped images for use in a structured text/graphics editor
US7453472B2 (en) 2002-05-31 2008-11-18 University Of Utah Research Foundation System and method for visual annotation and knowledge representation
US7278117B2 (en) * 2002-07-02 2007-10-02 Hewlett-Packard Development Company, L.P. Image segmentation and warping for specialized display viewing
US7376264B2 (en) * 2002-10-09 2008-05-20 Xerox Corporation Systems for spectral multiplexing of a source image and a background image to provide a composite image, for rendering the composite image, and for spectral demultiplexing of the composite images
EP1445954A1 (en) * 2003-02-10 2004-08-11 Thomson Licensing S.A. Method to transmit and receive font information in streaming systems
US7310769B1 (en) 2003-03-12 2007-12-18 Adobe Systems Incorporated Text encoding using dummy font
US7424672B2 (en) * 2003-10-03 2008-09-09 Hewlett-Packard Development Company, L.P. System and method of specifying image document layout definition
US20070300142A1 (en) 2005-04-01 2007-12-27 King Martin T Contextual dynamic advertising based upon captured rendered text
US7450268B2 (en) 2004-07-02 2008-11-11 Hewlett-Packard Development Company, L.P. Image reproduction
US7684648B2 (en) * 2005-01-14 2010-03-23 Ricoh Company, Limited Reducing the size of a document image
JP2006318208A (en) * 2005-05-12 2006-11-24 Canon Inc Image processing method and image processing system
US7593138B2 (en) 2005-09-09 2009-09-22 Xerox Corporation Special effects achieved by setoverprint/setoverprintmode and manipulating object optimize rendering (OOR) tags and colors
JP2007102545A (en) 2005-10-05 2007-04-19 Ricoh Co Ltd Electronic document creation apparatus, electronic document creation method, and electronic document creation program
US7667863B1 (en) 2005-10-27 2010-02-23 Eldred John H Method for modification of publication covers
AU2006201851A1 (en) * 2006-05-03 2007-11-22 Canon Kabushiki Kaisha Compressing page descriptions while preserving high quality
DE102006024078A1 (en) * 2006-05-23 2007-11-29 Andreas Stihl Ag & Co. Kg Combustion engine, comprises suction channel for supplying fuel and combustion air, where suction channel is connected by inlet opening with cleaning area of air filter
US7856142B2 (en) * 2007-01-26 2010-12-21 Sharp Laboratories Of America, Inc. Methods and systems for detecting character content in a digital image
US8014560B2 (en) 2007-05-25 2011-09-06 Xerox Corporation Preserving scanner signature using MRC technology
US20080304113A1 (en) 2007-06-06 2008-12-11 Xerox Corporation Space font: using glyphless font for searchable text documents
US8014596B2 (en) * 2007-10-30 2011-09-06 Sharp Laboratories Of America, Inc. Methods and systems for background color extrapolation
JP5078555B2 (en) 2007-10-31 2012-11-21 キヤノン株式会社 Form creation system, form creation method, program, storage medium
JP4581008B2 (en) 2008-07-11 2010-11-17 シャープ株式会社 Image transmission device
US8261186B2 (en) * 2009-01-02 2012-09-04 Apple Inc. Methods for efficient cluster analysis
US8331677B2 (en) 2009-01-08 2012-12-11 Microsoft Corporation Combined image and text document
US8650503B2 (en) 2009-07-08 2014-02-11 Microsoft Corporation User interface construction with mockup images
US8471867B2 (en) * 2009-10-16 2013-06-25 Research In Motion Limited Method and system for anti-aliasing clipped polygons and polylines

Patent Citations (30)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6466210B1 (en) * 1997-12-22 2002-10-15 Adobe Systems Incorporated Blending image data using layers
US6456305B1 (en) * 1999-03-18 2002-09-24 Microsoft Corporation Method and system for automatically fitting a graphical display of objects to the dimensions of a display window
US6594030B1 (en) * 1999-08-27 2003-07-15 Microsoft Corporation Intelligent automatic trapping of page objects
US7412644B2 (en) * 2000-02-04 2008-08-12 Aol Llc, A Delaware Limited Liability Company System and process for delivering and rendering scalable web pages
US20050132286A1 (en) * 2000-06-12 2005-06-16 Rohrabaugh Gary B. Resolution independent vector display of internet content
US7600183B2 (en) * 2000-06-16 2009-10-06 Olive Software Inc. System and method for data publication through web pages
US20110289395A1 (en) * 2002-03-01 2011-11-24 Xerox Corporation Method and system for document image layout deconstruction and redisplay
US20070143669A1 (en) * 2003-11-05 2007-06-21 Thierry Royer Method and system for delivering documents to terminals with limited display capabilities, such as mobile terminals
US20110033080A1 (en) * 2004-05-17 2011-02-10 Exbiblio B.V. Processing techniques for text capture from a rendered document
US20060117268A1 (en) * 2004-11-30 2006-06-01 Micheal Talley System and method for graphical element selection for region of interest compression
US20060251292A1 (en) * 2005-05-09 2006-11-09 Salih Burak Gokturk System and method for recognizing objects from images and identifying relevancy amongst images and information
US20070109322A1 (en) * 2005-11-14 2007-05-17 Brother Kogyo Kabushiki Kaisha Print control program product
US20070201752A1 (en) * 2006-02-28 2007-08-30 Gormish Michael J Compressed data image object feature extraction, ordering, and delivery
US20080168135A1 (en) * 2007-01-05 2008-07-10 Redlich Ron M Information Infrastructure Management Tools with Extractor, Secure Storage, Content Analysis and Classification and Method Therefor
US20100232690A1 (en) * 2007-06-29 2010-09-16 Canon Kabushiki Kaisha Image processing apparatus, image processing method, and computer program
US20090016605A1 (en) * 2007-07-11 2009-01-15 Hui Chao System and method for creating an editable template from a document image
WO2009049275A1 (en) * 2007-10-12 2009-04-16 Symantec Corporation Method for detecting and resolving hidden text salting
US20090110270A1 (en) * 2007-10-31 2009-04-30 Ctb/Mcgraw-Hill Llc Use of Composite Bitmapped Images in Conjunction with Display of Captured Data
US20090148039A1 (en) * 2007-12-05 2009-06-11 Canon Kabushiki Kaisha Colour document layout analysis with multi-level decomposition
US9418171B2 (en) * 2008-03-04 2016-08-16 Apple Inc. Acceleration of rendering of web-based content
US8498867B2 (en) * 2009-01-15 2013-07-30 K-Nfb Reading Technology, Inc. Systems and methods for selection and use of multiple characters for document narration
US20100246951A1 (en) * 2009-03-31 2010-09-30 Canon Kabushiki Kaisha Colour correcting foreground colours for visual quality improvement
US20110035345A1 (en) * 2009-08-10 2011-02-10 Yahoo! Inc. Automatic classification of segmented portions of web pages
US20130124968A1 (en) * 2009-09-25 2013-05-16 Lubomira A. Dontcheva System and Method for Using Design Features to Search for Page Layout Designs
US20110148909A1 (en) * 2009-12-17 2011-06-23 Canon Kabushiki Kaisha Generating object representation from bitmap image
US20110252315A1 (en) * 2010-04-07 2011-10-13 Canon Kabushiki Kaisha Image processing device, image processing method and non-transitory computer readable storage medium
US20120093354A1 (en) * 2010-10-19 2012-04-19 Palo Alto Research Center Incorporated Finding similar content in a mixed collection of presentation and rich document content using two-dimensional visual fingerprints
US20130033523A1 (en) * 2011-08-04 2013-02-07 Research In Motion Limited Orientation-dependent processing of input files by an electronic device
US8639680B1 (en) * 2012-05-07 2014-01-28 Google Inc. Hidden text detection for search result scoring
US9501460B1 (en) * 2013-02-28 2016-11-22 Google Inc. Detecting and processing invisible elements within a web page

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20160314766A1 (en) * 2015-01-30 2016-10-27 E Ink Corporation Font control for electro-optic displays and related apparatus and methods
US9928810B2 (en) * 2015-01-30 2018-03-27 E Ink Corporation Font control for electro-optic displays and related apparatus and methods

Also Published As

Publication number Publication date
US20120050306A1 (en) 2012-03-01
US9218680B2 (en) 2015-12-22

Similar Documents

Publication Publication Date Title
US9218680B2 (en) Systems and methods for rendering graphical content and glyphs
US8588528B2 (en) Systems and methods for displaying scanned images with overlaid text
US9471550B2 (en) Method and apparatus for document conversion with font metrics adjustment for format compatibility
US9898548B1 (en) Image conversion of text-based images
US8442324B2 (en) Method and system for displaying image based on text in image
JP5274305B2 (en) Image processing apparatus, image processing method, and computer program
US8494280B2 (en) Automated method for extracting highlighted regions in scanned source
US7310769B1 (en) Text encoding using dummy font
US8634644B2 (en) System and method for identifying pictures in documents
US8832541B2 (en) Method and system to convert visually orientated objects to embedded text
US20150070373A1 (en) Clarification of Zoomed Text Embedded in Images
US20060294460A1 (en) Generating a text layout boundary from a text block in an electronic document
US20150138220A1 (en) Systems and methods for displaying scanned images with overlaid text
US20120144292A1 (en) Providing summary view of documents
US20070185837A1 (en) Detection of lists in vector graphics documents
JP2002063215A (en) Method and system for displaying document, computer program and recording medium
CN107430595B (en) Method and system for displaying recognized text according to fast reading mode
US10095677B1 (en) Detection of layouts in electronic documents
US9741142B2 (en) Method and apparatus for enabling text editing in a scanned document while maintaining fidelity of the appearance of the text
JP2022067086A (en) Digitalized writing processing
US10216993B2 (en) Intelligent document elements harvest and presentation system and method
US8824806B1 (en) Sequential digital image panning
WO2022024068A1 (en) Systems and methods for assessing text legibility in electronic documents
US7676089B2 (en) Document layout analysis with control of non-character area
KR20110087620A (en) Layout based page recognition method for printed medium

Legal Events

Date Code Title Description
STPP Information on status: patent application and granting procedure in general

Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER

AS Assignment

Owner name: K-NFB READING TECHNOLOGY, INC., MASSACHUSETTS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:KURZWEIL, RAYMOND C.;ALBRECHT, PAUL;CHAPMAN, PETER;AND OTHERS;SIGNING DATES FROM 20110920 TO 20110922;REEL/FRAME:049380/0463

STPP Information on status: patent application and granting procedure in general

Free format text: FINAL REJECTION MAILED

AS Assignment

Owner name: EM ACQUISITION CORP., INC., NEW YORK

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:DIMENSIONAL STACK ASSETS, LLC;REEL/FRAME:051156/0695

Effective date: 20150910

STCV Information on status: appeal procedure

Free format text: NOTICE OF APPEAL FILED

STPP Information on status: patent application and granting procedure in general

Free format text: AMENDMENT AFTER NOTICE OF APPEAL

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION