US20160110905A1 - Systems and Methods For Rendering Graphical Content and Glyphs - Google Patents
Systems and Methods For Rendering Graphical Content and Glyphs Download PDFInfo
- 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
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T11/00—2D [Two Dimensional] image generation
- G06T11/60—Editing 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
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.”
- 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.
- 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.
-
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. - Referring now to
FIG. 1 , asystem 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. Thesystem 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 aprocessor 14. In some examples, theprocessor 14 can be a Pentium based system from Intel Corporation, Santa Clara, Calif., although other processors could alternatively be used. In addition, to theprocessor 14, the computer system 12 includes main memory, 16 cache memory and bus interface circuits (not shown). The computer system 12 includes amass 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), astandard 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 inFIG. 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. Thepage 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. Theconversion 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 thepage conversion software 30 for converting a webpage or other document into a format that can be more quickly rendered is shown. Thepage 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. Thepage 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, thepage 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, thepage conversion software 30places 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 orpage 50. The rendered document orpage 50 includes visible non-glyph based portions and glyph-based portions. In this exemplary page, the non-glyph based items include a graphic of acow 54 and apage 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 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 inFIG. 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, theglyphs cow 54 and thepage 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 thecow 54 and thepage border 52. Thepage conversion software 30 generates a bitmap (or other image file) of the remaining graphical portions (e.g., the portions shown inFIG. 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 inFIG. 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 inFIG. 3B ) and a layer that includes all of the glyphs that is overlaid onto the graphical content layer (e.g., as shown inFIG. 3D ). -
FIG. 4 shows aprocess 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. Thepage conversion software 30changes 74 all of the glyphs to a first color. Thepage 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. Thepage conversion software 30changes 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) andstores 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. Thepage 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, thepage 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 describedpage conversion software 30 to identify the visible glyphs. As shown inFIG. 5A , the glyphs (both the visible 56, andnon-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 theportion 56 is visible and displayed in black font becauseportions FIG. 5C , the glyphs (both the visible 56 andnon-visible portions 58 and 60) are changed to a second color (here the color is grey). As shown inFIG. 5D , in a rendered image using the font of the second color, only theportion 56 is visible and displayed in grey font. When the rendered images (e.g., the images shown inFIG. 5B and 5D ) are compared, the color of the pixels in the two images changes only where the glyphs are visible. While theglyphs cow 54 and theborder 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 inFIG. 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)
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)
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)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8498866B2 (en) * | 2009-01-15 | 2013-07-30 | K-Nfb Reading Technology, Inc. | Systems and methods for multiple language document narration |
US9472163B2 (en) * | 2012-02-17 | 2016-10-18 | Monotype Imaging Inc. | Adjusting content rendering for environmental conditions |
US20130238747A1 (en) | 2012-03-06 | 2013-09-12 | Apple Inc. | Image beaming for a media editing application |
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 |
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)
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 |
US20110035345A1 (en) * | 2009-08-10 | 2011-02-10 | Yahoo! Inc. | Automatic classification of segmented portions of web pages |
US20110033080A1 (en) * | 2004-05-17 | 2011-02-10 | Exbiblio B.V. | Processing techniques for text capture from a rendered document |
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)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
AUPM704594A0 (en) * | 1994-07-25 | 1994-08-18 | Canon Information Systems Research Australia Pty Ltd | Efficient methods for the compositing of graphical elements |
AUPM704394A0 (en) * | 1994-07-25 | 1994-08-18 | Canon Information Systems Research Australia Pty Ltd | Optimization method for the efficient production of images |
AUPM704294A0 (en) * | 1994-07-25 | 1994-08-18 | Canon Information Systems Research Australia Pty Ltd | Method and apparatus for the creation of images |
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 |
AU2003247452A1 (en) | 2002-05-31 | 2004-07-14 | 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 |
US7155068B2 (en) * | 2002-10-09 | 2006-12-26 | Xerox Corporation | Systems for spectral multiplexing of source images to provide a composite image, for rendering the composite image, and for spectral demultiplexing the composite image, which achieve increased dynamic range in a recovered source image |
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 |
US8121403B2 (en) * | 2007-10-30 | 2012-02-21 | Sharp Laboratories Of America, Inc. | Methods and systems for glyph-pixel selection |
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 |
US8719701B2 (en) * | 2009-01-02 | 2014-05-06 | Apple Inc. | Identification of guides and gutters of a document |
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 |
-
2011
- 2011-08-31 US US13/222,594 patent/US9218680B2/en not_active Expired - Fee Related
-
2015
- 2015-12-21 US US14/976,010 patent/US20160110905A1/en not_active Abandoned
Patent Citations (30)
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)
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 | |
US8442324B2 (en) | Method and system for displaying image based on text in image | |
US9898548B1 (en) | Image conversion of text-based images | |
JP5274305B2 (en) | Image processing apparatus, image processing method, and computer program | |
US7310769B1 (en) | Text encoding using dummy font | |
US8331677B2 (en) | Combined image and text document | |
US8634644B2 (en) | System and method for identifying pictures in documents | |
US8832541B2 (en) | Method and system to convert visually orientated objects to embedded text | |
US20070253620A1 (en) | Automated method for extracting highlighted regions in scanned source | |
US20150070373A1 (en) | Clarification of Zoomed Text Embedded in Images | |
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 | |
US8824806B1 (en) | Sequential digital image panning | |
US10216993B2 (en) | Intelligent document elements harvest and presentation system and method | |
JP2022067086A (en) | Digitalized writing processing | |
US7676089B2 (en) | Document layout analysis with control of non-character area | |
KR20110087620A (en) | Layout based page recognition method for printed medium | |
JP5895828B2 (en) | Information processing apparatus and program | |
US9905030B2 (en) | Image processing device, image processing method, information storage medium, and program |
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 |