WO2010101790A2 - Content rendering on a computer - Google Patents

Content rendering on a computer Download PDF

Info

Publication number
WO2010101790A2
WO2010101790A2 PCT/US2010/025678 US2010025678W WO2010101790A2 WO 2010101790 A2 WO2010101790 A2 WO 2010101790A2 US 2010025678 W US2010025678 W US 2010025678W WO 2010101790 A2 WO2010101790 A2 WO 2010101790A2
Authority
WO
WIPO (PCT)
Prior art keywords
document
content
rendered
portions
rendering
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.)
Ceased
Application number
PCT/US2010/025678
Other languages
English (en)
French (fr)
Other versions
WO2010101790A3 (en
Inventor
Gareth Alan Howell
Matthew James Ruhlen
Brendyn O'dell-Alexander
Nicholas Allen Robarge
Zhenjun Zhu
Sugandha Sudeshkumar Kapoor
Kiran Akella Venkata
Juraj Gottweis
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Microsoft Corp
Original Assignee
Microsoft Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Family has litigation
First worldwide family litigation filed litigation Critical https://patents.darts-ip.com/?family=42679330&utm_source=google_patent&utm_medium=platform_link&utm_campaign=public_patent_search&patent=WO2010101790(A2) "Global patent litigation dataset” by Darts-ip is licensed under a Creative Commons Attribution 4.0 International License.
Priority to JP2011552998A priority Critical patent/JP5537571B2/ja
Priority to MX2011009158A priority patent/MX2011009158A/es
Priority to AU2010221620A priority patent/AU2010221620B2/en
Priority to BRPI1007813A priority patent/BRPI1007813A2/pt
Priority to RU2011136691/08A priority patent/RU2571512C2/ru
Priority to SG2011050549A priority patent/SG172952A1/en
Priority to CA2749683A priority patent/CA2749683C/en
Priority to CN201080010824.7A priority patent/CN102341823B/zh
Application filed by Microsoft Corp filed Critical Microsoft Corp
Priority to EP10749134.2A priority patent/EP2404276A4/en
Publication of WO2010101790A2 publication Critical patent/WO2010101790A2/en
Publication of WO2010101790A3 publication Critical patent/WO2010101790A3/en
Priority to IL214057A priority patent/IL214057A/en
Priority to ZA2011/05214A priority patent/ZA201105214B/en
Anticipated expiration legal-status Critical
Ceased legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/957Browsing optimisation, e.g. caching or content distillation
    • G06F16/9574Browsing optimisation, e.g. caching or content distillation of access to content, e.g. by caching
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F15/00Digital computers in general; Data processing equipment in general
    • G06F15/16Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/957Browsing optimisation, e.g. caching or content distillation
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/957Browsing optimisation, e.g. caching or content distillation
    • G06F16/9577Optimising the visualization of content, e.g. distillation of HTML documents
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F17/00Digital computing or data processing equipment or methods, specially adapted for specific functions
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • G06F40/12Use of codes for handling textual entities
    • G06F40/123Storage facilities
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • G06F40/12Use of codes for handling textual entities
    • G06F40/151Transformation
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q50/00Information and communication technology [ICT] specially adapted for implementation of business processes of specific business sectors, e.g. utilities or tourism
    • G06Q50/10Services

Definitions

  • Productivity application programs such as word processing applications, spreadsheet applications, and presentation applications, enable users to create different types of documents. These documents may include data that is native to a particular document type and even to a particular application program. In order to view this native data, a user may view the document through the productivity application program that created the document. For example, a user may rely on a particular word processing application to view a word processing document that was created by the word processing application.
  • a problem can arise when documents are shared across the World Wide Web (hereinafter referred to as "web") through web browsers.
  • web World Wide Web
  • typical web browsers may not be capable of reading a given document in its native format.
  • a web server can be implemented to execute code that is capable of rendering a document from its native format into a web-compatible format that can be viewed through the web browser.
  • An application server is provided for rendering documents and other content from a native document format into a web-compatible format capable of being viewed through a web browser or other suitable application.
  • the application server includes a rendering module, which is operative to incrementally render documents. Through incremental rendering, the application server can provide portions of rendered documents to the web browser while the native documents are still being rendered.
  • Other example implementations of the technologies described herein include converting a document from one format into another format (e.g., transforming a document from a binary file format into an Office Open XML format, a Portable Document Format ("PDF”), and the like).
  • PDF Portable Document Format
  • a download manager is also provided in order to increase the throughput of the rendering module.
  • the download manager may begin retrieving other documents to be rendered at a later time. These other documents may be downloaded from a storage server and stored in a rendering queue on the application server. Once the rendering module becomes available, the rendering module can immediately begin rendering these other documents directly from the rendering queue without any downtime while waiting for documents to be retrieved.
  • One or more caches are also provided in order to reduce the amount of work utilized to retrieve documents and other content. Examples of caches include a document cache, an authorization cache, and a location cache. The document cache may be operative to store rendered documents in the front end, thereby eliminating the need to retrieve the rendered documents from other storage units in the back end.
  • the authorization cache may be operative to store authorization and authentication data, thereby eliminating the need to re-authorize or re-authenticate a user who later accesses the same document.
  • the location cache may be operative to store the location of a rendered document. Through the use of the location cache, the rendered document can be efficiently retrieved from the relevant storage unit without the need to query multiple storage units.
  • a method for rendering content for viewing through a web browser operating on a computer. Portions of the content are transformed into portions of rendered content. While the portions of the content are being transformed into portions of the rendered content, at least one of the portions of the rendered content can be provided to an application program.
  • FIGURE 1 is a block diagram showing an illustrative system architecture operative to render documents for viewing through a web browser, in accordance with embodiments;
  • FIGURE 2 is a block diagram showing an illustrative implementation of an application manager from the system architecture of FIGURE 1, in accordance with embodiments;
  • FIGURE 3 is a block diagram showing an illustrative implementation of a front end from the system architecture of FIGURE 1, in accordance with embodiments;
  • FIGURE 4A is a flow diagram showing an illustrative process for rendering content for viewing through a web browser, in accordance with embodiments;
  • FIGURE 4B is a flow diagram showing an illustrative process for fetching a portion of the rendered content, in accordance with embodiments; and
  • FIGURE 5 is a computer architecture diagram showing an illustrative computer hardware architecture for a computing system capable of implementing the embodiments presented herein.
  • an application server is provided that is operative to incrementally render a document or other content from its native format into another format, such as a web- compatible format.
  • another format such as a web- compatible format.
  • pre-rendering as content is being incrementally rendered, each discrete portion of the document or other content that has been rendered can be made available to the user.
  • One or more caches may also be provided in order to reduce the amount of work utilized to retrieve rendered content.
  • Embodiments described herein may refer to pages and slides as discrete portions of documents and rendered documents. However, it should be appreciated that pages and slides are merely examples of discrete portions and are not intended to be limiting. Other kinds of discrete portions, as contemplated by those skilled in the art, may be similarly implemented.
  • embodiments described herein primarily refer to documents and document rendering. However, it should be appreciated that the embodiments described herein may be similarly applied to any suitable content which can be rendered from a native format into another format. Such content may include any multimedia, such as text, images, audio, video, and combinations thereof. Further, embodiments described herein primarily refer to the rendered format as a web-compatible format capable of being viewed through a web browser. However, it should be appreciated that the rendered format may be other suitable formats as contemplated by those skilled in the art.
  • program modules include routines, programs, components, data structures, and other types of structures that perform particular tasks or implement particular abstract data types.
  • program modules include routines, programs, components, data structures, and other types of structures that perform particular tasks or implement particular abstract data types.
  • program modules include routines, programs, components, data structures, and other types of structures that perform particular tasks or implement particular abstract data types.
  • the subject matter described herein may be practiced with other computer system configurations, including hand-held devices, multiprocessor systems, microprocessor- based or programmable consumer electronics, minicomputers, mainframe computers, and the like.
  • FIGURE 1 is a block diagram showing a system architecture 100 operative to render documents and to retrieve rendered documents according to embodiments.
  • the architecture 100 includes a front end 102 that is operative to communicate with a computer 104.
  • the front end 102 may receive and process requests from a web browser 106 over a network 108, such as the Internet.
  • the front end 102 may receive a Hypertext Transfer Protocol ("HTTP") message with a request for a specific document, such as document HOA, stored in a document store 112.
  • HTTP Hypertext Transfer Protocol
  • the components of the architecture 100 may reside on the same server, according to further embodiments. Splitting the architecture 100 into the front ends and application servers is merely an implementation design choice and is not intended to be limiting.
  • the web front end 102 may attempt to retrieve, from an output store 114, a web-compatible rendered document HOB corresponding to the requested document HOA.
  • the rendered document HOB may be stored in the output store 114 if the document 11OA was recently rendered. If the output store 114 contains the rendered document HOB corresponding to the document 11OA, then the output store 114 may return the rendered document 11OB to the front end 102.
  • the application server 116 may retrieve the document 11OA from the document store 112.
  • a rendering module 118 in the application server 116 is operative to render (i.e., convert, transform) the document 11OA into the rendered document HOB.
  • the rendering module 118 may generate the rendered document 11OB in any format capable of being displayed by a suitable web browser.
  • Example formats may include an image format (e.g., Portable Network Graphics ("PNG”), Joint Photographic Experts Group (“JPEG”), etc.),
  • the rendering module 118 may also generate the rendered document HOB into a web-ready rendition that may include Extensible Markup Language (“XML”), scripts, Hypertext Markup Language (“HTML”), images, and/or the like, such that individual data types in the web-ready rendition can be understood collectively by the web browser. Each of these data types may be made available to the user upon being generated by the incremental rendering process described herein.
  • the rendering module 118 may also be operative to concurrently render multiple documents.
  • the application server 116 may store the rendered document 11OB in the output store 114 and return the rendered document 11OB to the front end 102.
  • the front end 102 may respond to the HTTP request by providing the rendered document 11OB to the web browser 106 via the HTTP protocol.
  • the web browser 106 can then display the rendered document HOB, which is a full-fidelity representation of the corresponding document 11OA.
  • the full- fidelity representation contains the same formatting (e.g., layout, resolution, content, etc.) found in the original representation.
  • the full-fidelity representation can be contrasted against a lower- fidelity representation in which, for example, the layout may be changed or the resolution and content may be reduced.
  • the rendered document HOB may be utilized for non-viewing scenarios, such as converting binary files to another document type for editing.
  • a MICROSOFT OFFICE binary file may be rendered into an OPEN OFFICE EXTENSIBLE MARKUP LANGUAGE ("OOXML”) file.
  • the architecture 100 may include additional front ends and/or additional application servers. Further, multiple front ends and/or multiple application servers may reside on the same server. For example, additional front ends may be utilized to handle a greater quantity of requests from web browsers. In one embodiment, the additional application servers are deployed to handle the rendering of heavier loads. In another embodiment, additional application servers are deployed to render different types of documents. For example, one application server may be dedicated to rendering word processing documents, while another application server may be dedicated to rendering presentations. In yet another embodiment, additional application servers are deployed to render different elements of a given document.
  • the rendered elements can then be combined to create the rendered document.
  • one application server may render video in a presentation, while another application server may render the text in the presentation.
  • the front end 102 may be operative to combine the results of the two application servers to form the rendered presentation.
  • the front end 102 in response to a single request to render a document in a given format, the front end 102 may direct the application server 116 to render the document into multiple formats in order to support multiple uses across multiple device types and web client configurations.
  • the web browser 106 may request from the front end 102 a given document rendered in ADOBE FLASH.
  • the front end 102 may determine, through a user profile associated with the user operating the web browser 106, that the user frequently accesses documents in ADOBE FLASH, MICROSOFT SILVERLIGHT, Portable Network Graphics ("PNG”), mobile, and full versions.
  • the front end 102 may also determine, through the user profile that the user frequently accesses documents in a web-ready rendition including a combination of XML, scripts, HTML, images, and/or the like. In this case, the front end 102 may fulfill the request by rendering the document in one or more of these versions.
  • Other suitable data may be similarly utilized to determine whether the front end 102 directs the application server 116 to render a document into multiple formats in response to a single render request.
  • the application server 116 further includes an application manager 120.
  • the application manager 120 is operative to manage incremental rendering of the document HOA into the rendered document HOB.
  • incremental rendering refers to providing portions of the rendered document 11OB as the document 11OA is being rendered by the rendering module 118.
  • the rendered first page of a word processing document or a rendered first slide of a presentation may be provided to the front end 102, which can then provide the rendered first page or the rendered first slide to the web browser 106 for display.
  • Other embodiments may render any particular page or slide in the document. Other embodiments may also render other portions of content besides pages or slides. As the remainder of the word processing document or presentation is being rendered by the rendering module 118, the application manager 120 may provide the additional rendered pages and rendered slides to the web browser 106.
  • the application manager 120 may make available portions of the rendered document 11OB as the document 11OA is being rendered by the rendering module 118.
  • the front end 102 can then retrieve these portions of the rendered document 11OB, as necessary, from the application server 116.
  • the portions of the rendered document HOB are stored in a backend cache 122 in the application server 116.
  • the pages or slides of a document may be rendered in any predefined order. The rendered pages or slides are then made available to the front end 102 in the same order as they were rendered.
  • the documents are rendered from the beginning of the document to the end of the document.
  • incremental rendering reduces the amount of rendering time before a user can view a portion, such as the beginning or some other portion, of the document. For example, in conventional pre-rendering, a user desiring to view a first page of a word processing document or a first slide of a presentation would need to wait until the entire word processing document or presentation is rendered. In an illustrative implementation of incremental rendering, the user can more quickly view the first page or the first slide prior to the remainder of the word processing document or the presentation being rendered.
  • the user may request a page N or a slide N of a document where the variable N represents any page or slide within the document.
  • the request may occur prior to or while the document is being rendered.
  • the application manager 120 may direct the rendering module 118 to render the page N or the slide N by seeking the particular page or slide within the document.
  • the rendered page N or slide N can then be made available to the front end 102.
  • the application manager 120 may proceed with rendering the remainder of the document.
  • the rendering module 118 is operative to incrementally render a document even when the document has yet to be fully downloaded. That is, the rendering module 118 may begin rendering the document while it is being downloaded from the document store 112, rather than wait until the entire file has been downloaded. This approach to rendering a document before it has fully downloaded may reduce the amount of time it takes for the rendering module 118 to render a document, especially if the document is relatively large.
  • FIGURE 2 is a block diagram showing the application manager 120 according to embodiments.
  • the application manager 120 includes a download manager 202 and a rendering queue 204.
  • the download manager 202 is operative to download documents from the document store 112 prior to the rendering module 118 rendering the documents.
  • the download manager 202 may then store the downloaded documents in the rendering queue 204 until the rendering module 118 is available to render the documents.
  • the rendering queue 204 may operate without the download manager 202.
  • the download manager 202 may be utilized to speed processing through the rendering queue 204. Further, even when the download manager 202 is present, the rendering queue 204 may operate independently of the download manager 202 to handle instances when the application manager 120 is overloaded.
  • the download manager 202 may download the first document 206A from the document store 112, and the rendering module 118 may begin rendering the first document 206A.
  • the download manager 202 may concurrently download the second document 206B from the document store 112 and store the second document 206B in the rendering queue 204.
  • the rendering module 118 can then immediately proceed to rendering the second document 206B from the rendering queue 204 without waiting for the second document 206B to be downloaded.
  • the rendering queue 204 may be configured to store any number of documents, as contemplated by those skilled in the art.
  • the download manager 202 may be configured by a user to adjust the number of documents being downloaded simultaneously and the maximum number of documents stored in the rendering queue 204 that are awaiting rendering. In this way, the user can ensure that the number of documents being downloaded and/or stored at any given time does not place an excessive burden on system resources.
  • FIGURE 3 is a block diagram showing the front end 102 according to embodiments.
  • the front end 102 includes a request merge module 302 and several caches 304, including a document cache 304A, an authorization cache 304B, and a location cache 304C.
  • the request merge module 302 maintains tracking data identifying a particular application server that is currently rendering a given document.
  • the request merge module 302 may utilize this tracking data to direct additional requests for the same document to the same application server. By directing additional requests for the same document to the same application server, redundant work between application servers is reduced, and other application servers are free to render other documents.
  • the system architecture 100 of FIGURE 1 may include multiple front ends and multiple application servers. These front ends may or may not be capable of communicating with each other.
  • the request merge module 302 may be configured to perform consistent hashing in order to identify a particular application server for a particular document request.
  • consistent hashing one or more aspects of a given document request may be analyzed in order to map these aspects to a particular application server.
  • An example of an aspect of a document request is the name of the document being requested.
  • the caches 304 may improve performance of the front end 102 by reducing the need for the front end 102 to access other parts of the system architecture 100, such as the output store 114 and the application server 116.
  • the document cache 304 A is operative to cache at least portions of rendered documents according to popularity.
  • the authorization cache 304B is operative to store authorization or authentication information associated with users. Access to the documents and the rendered documents may be restricted based on an authorization process whereby a user enters identification information, such as a username and password. For example, when a user attempts to access a particular document, the front end 102 may access an authorization module (not shown), which requests information, such as a login identifier and password, identifying the user. The authorization module may then determine whether the user has permission to access the document. The authorization module may be configured to permit access to the document only when the authorization module verifies that the user has permission.
  • the authorization cache 304B may store state information indicating that the user has been verified.
  • the front end 102 may utilize this state information to verify that the user has or does not have permission to access the document without the need for accessing the authorization module. In this way, the front end 102 is not required to send credentials to an remote authorization service, thereby optimizing performance of the front end 102. Further, the user does not have to re-enter identification information for additional requests to access the same document.
  • the state information stored in the authorization cache 304B may be particularly useful when a user requests only a portion of a given document at a time. For example, a user may initially request only a first page of a multi-page document.
  • the user may be required to enter identification information (i.e., credentials) in order to view the first page. If the user subsequently requests additional pages of the document, the front end 102 can expeditiously authorize the user based on the credentials stored in the authorization cache 304B. Thus, each authentication of the user does not necessarily result in the user being prompted for credentials. Further, the need to re-query other servers to authenticate and authorize the user can be eliminated.
  • the authorization cache 304B may be configured to store the state information for any amount of time after which the state information may be deleted.
  • the location cache 304C which may also be referred to as a "dictionary", is operative to store the location of a given rendered document.
  • the location cache 304C may indicate the particular storage unit that stores a particular rendered document.
  • Examples of storage units may include the output store 114 and the backend cache 122.
  • the storage units may be part of the system architecture 100 or separate from the system architecture 100.
  • FIGURE 4A is a flow diagram illustrating one method for rendering content for viewing through a web browser operating on a computer.
  • FIGURE 4B is a flow diagram illustrating one method for fetching a rendered portion of the content. The method of FIGURE 4B may be performed concurrently or after the method of FIGURE 4A is performed.
  • the logical operations described herein are implemented (1) as a sequence of computer implemented acts or program modules running on a computing system and/or (2) as interconnected machine logic circuits or circuit modules within the computing system. The implementation is a matter of choice dependent on the performance and other requirements of the computing system.
  • a routine 400 begins at operation 402, where the front end 102 receives a request from the web browser 106 for a document, such as the document HOA. The routine 400 then proceeds to operation 404, where the front end 102 directs the rendering module 118 to begin incrementally rendering the document HOA.
  • the rendering module 118 may retrieve the document 11OA from the document store 112. Upon retrieving the document 11OA from the document store 112, the rendering module 118 may render the first page or the first slide of the document 11OA. In some embodiments, the request may specify a particular slide or page of the document 11OA. In this case, the rendering module 118 may render the particular page or the particular slide instead of the first page or the first slide. Upon generating the first page or the first slide of the rendered document HOB, the routine proceeds to operation 406. [0045] At operation 406, the rendering module 118 determines whether the document
  • a routine 400B begins at operation 408, where the front end 102 receives a request from the web browser 106 for a document, such as the document 11OA. The routine 400B then proceeds to operation 410, where as pages or slides of the rendered document HOB are rendered by the rendering module 118, the application manager 120 may make available these pages or slides of the rendered document 11OB to the front end 102.
  • the application manager 120 may also make available that particular page or particular slide.
  • the rendering module 118 may make available the pages or slides of the rendered document HOB through the backend cache 122.
  • the front end 102 may then retrieve the pages or slides of the rendered document HOB from the backend cache 122 and transmit the pages or slides of the rendered document 11OB to the web browser 106 for display.
  • the routine 400B may be performed while the document 11OA is being incrementally rendered according to the routine 400A. That is, while the rendering module 118 is rendering pages or slides of the document 11OA according to routine 400A, the application manager 120 may fulfill requests for those rendered pages or slides according to routine 400B.
  • the front end 102 can continue to retrieve the additional pages or slides of the rendered document HOB without waiting for the entire rendered document 11OB to be generated. Further, while the application manager 120 is fulfilling requests for pages or slides of the rendered document HOB, the rendering module 118 may continue to render additional pages or slides from the document 11OA.
  • additional requests for other documents may be received by the front end 102.
  • the download manager 202 may retrieve the other documents from the document store 112 and store the documents in the rendering queue 204 while the rendering module 118 is still rendering the document 11OA.
  • the rendering module 118 can begin rendering these other documents without waiting for them to be retrieved from document store 112.
  • additional requests for the document 11OA may be directed to the same application server 116. In this way, other application servers can be available to render other documents. Further, according to some embodiments, the rendering module 118 may render the document 11OA into multiple formats in response to a single request.
  • the computer 500 includes a processing unit 502 ("CPU"), a system memory 504, and a system bus 506 that couples the memory 504 to the CPU 502.
  • the computer 500 further includes a mass storage device 512 for storing one or more program modules 514, such as the rendering module 118, and one or more databases 516, such as the document store 112.
  • Other program modules 514 may include the web browser 106, the download manager 202, and the request merge module 302.
  • Other databases 516 may include the output store 114, the rendering queue 204, and the caches 304.
  • the mass storage device 512 is connected to the CPU 502 through a mass storage controller (not shown) connected to the bus 506.
  • the mass storage device 512 and its associated computer-readable media provide non-volatile storage for the computer 500.
  • computer-readable media can be any available computer storage media that can be accessed by the computer 500.
  • computer-readable media may include volatile and non-volatile, removable and non-removable media implemented in any method or technology for storage of information such as computer-readable instructions, data structures, program modules, or other data.
  • computer-readable media includes, but is not limited to, RAM, ROM, EPROM, EEPROM, flash memory or other solid state memory technology, CD-ROM, digital versatile disks ("DVD”), HD-DVD, BLU-RAY, or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by the computer 500.
  • the computer 500 may operate in a networked environment using logical connections to remote computers through a network, such as the network 108.
  • the computer 500 may connect to the network 108 through a network interface unit 510 connected to the bus 506.
  • the network interface unit 510 may also be utilized to connect to other types of networks and remote computer systems.
  • the computer 500 may also include an input/output controller 508 for receiving and processing input from a number of input devices (not shown), including a keyboard, a mouse, a microphone, and a game controller. Similarly, the input/output controller 508 may provide output to a display or other type of output device (not shown).

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Databases & Information Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Data Mining & Analysis (AREA)
  • Health & Medical Sciences (AREA)
  • General Health & Medical Sciences (AREA)
  • Artificial Intelligence (AREA)
  • Audiology, Speech & Language Pathology (AREA)
  • Computational Linguistics (AREA)
  • Business, Economics & Management (AREA)
  • Software Systems (AREA)
  • Computer Hardware Design (AREA)
  • Tourism & Hospitality (AREA)
  • General Business, Economics & Management (AREA)
  • Human Resources & Organizations (AREA)
  • Marketing (AREA)
  • Primary Health Care (AREA)
  • Strategic Management (AREA)
  • Economics (AREA)
  • Mathematical Physics (AREA)
  • Information Transfer Between Computers (AREA)
  • Digital Computer Display Output (AREA)
  • Image Generation (AREA)
  • Processing Or Creating Images (AREA)
  • Auxiliary Devices For Music (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
PCT/US2010/025678 2009-03-04 2010-02-26 Content rendering on a computer Ceased WO2010101790A2 (en)

Priority Applications (11)

Application Number Priority Date Filing Date Title
EP10749134.2A EP2404276A4 (en) 2009-03-04 2010-02-26 Content rendering on a computer
SG2011050549A SG172952A1 (en) 2009-03-04 2010-02-26 Content rendering on a computer
MX2011009158A MX2011009158A (es) 2009-03-04 2010-02-26 Presentacion de contenido en una computadora.
AU2010221620A AU2010221620B2 (en) 2009-03-04 2010-02-26 Content rendering on a computer
BRPI1007813A BRPI1007813A2 (pt) 2009-03-04 2010-02-26 renderização de conteúdo em um computador
RU2011136691/08A RU2571512C2 (ru) 2009-03-04 2010-02-26 Преобразование контента на компьютере
CA2749683A CA2749683C (en) 2009-03-04 2010-02-26 Content rendering on a computer
JP2011552998A JP5537571B2 (ja) 2009-03-04 2010-02-26 コンピュータにおけるコンテンツレンダリング
CN201080010824.7A CN102341823B (zh) 2009-03-04 2010-02-26 计算机上的内容再现方法和系统
IL214057A IL214057A (en) 2009-03-04 2011-07-13 Computer processing content
ZA2011/05214A ZA201105214B (en) 2009-03-04 2011-07-14 Content rendering on a computer

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US12/397,351 US8347208B2 (en) 2009-03-04 2009-03-04 Content rendering on a computer
US12/397,351 2009-03-04

Publications (2)

Publication Number Publication Date
WO2010101790A2 true WO2010101790A2 (en) 2010-09-10
WO2010101790A3 WO2010101790A3 (en) 2011-01-13

Family

ID=42679330

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2010/025678 Ceased WO2010101790A2 (en) 2009-03-04 2010-02-26 Content rendering on a computer

Country Status (17)

Country Link
US (2) US8347208B2 (enExample)
EP (1) EP2404276A4 (enExample)
JP (1) JP5537571B2 (enExample)
KR (1) KR101626639B1 (enExample)
CN (1) CN102341823B (enExample)
AU (1) AU2010221620B2 (enExample)
BR (1) BRPI1007813A2 (enExample)
CA (1) CA2749683C (enExample)
CL (1) CL2011002084A1 (enExample)
IL (1) IL214057A (enExample)
MX (1) MX2011009158A (enExample)
MY (1) MY163751A (enExample)
RU (1) RU2571512C2 (enExample)
SG (1) SG172952A1 (enExample)
TW (1) TWI493441B (enExample)
WO (1) WO2010101790A2 (enExample)
ZA (1) ZA201105214B (enExample)

Families Citing this family (41)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP3075975B2 (ja) 1996-02-01 2000-08-14 富士電子工業株式会社 ワーク熱処理システム
US20080028302A1 (en) * 2006-07-31 2008-01-31 Steffen Meschkat Method and apparatus for incrementally updating a web page
US8434093B2 (en) 2008-08-07 2013-04-30 Code Systems Corporation Method and system for virtualization of software applications
US8776038B2 (en) 2008-08-07 2014-07-08 Code Systems Corporation Method and system for configuration of virtualized software applications
TWI471742B (zh) * 2009-05-13 2015-02-01 Alibaba Group Holding Ltd Web access / send method, client, server and network system
CN102487456B (zh) 2009-11-30 2015-06-17 国际商业机器公司 用于提供网络视频访问热度的方法和装置
US8954958B2 (en) 2010-01-11 2015-02-10 Code Systems Corporation Method of configuring a virtual application
US8959183B2 (en) * 2010-01-27 2015-02-17 Code Systems Corporation System for downloading and executing a virtual application
US9104517B2 (en) 2010-01-27 2015-08-11 Code Systems Corporation System for downloading and executing a virtual application
US9229748B2 (en) 2010-01-29 2016-01-05 Code Systems Corporation Method and system for improving startup performance and interoperability of a virtual application
US8763009B2 (en) 2010-04-17 2014-06-24 Code Systems Corporation Method of hosting a first application in a second application
US9047030B2 (en) * 2010-04-29 2015-06-02 Hewlett-Packard Development Company, L.P. Caching network service resources
US8782106B2 (en) 2010-07-02 2014-07-15 Code Systems Corporation Method and system for managing execution of virtual applications
US9021015B2 (en) 2010-10-18 2015-04-28 Code Systems Corporation Method and system for publishing virtual applications to a web server
US9209976B2 (en) 2010-10-29 2015-12-08 Code Systems Corporation Method and system for restricting execution of virtual applications to a managed process environment
US8996985B1 (en) 2011-03-16 2015-03-31 Google Inc. Online document processing service for displaying comments
US8812946B1 (en) 2011-10-17 2014-08-19 Google Inc. Systems and methods for rendering documents
US8397153B1 (en) 2011-10-17 2013-03-12 Google Inc. Systems and methods for rich presentation overlays
US10430388B1 (en) 2011-10-17 2019-10-01 Google Llc Systems and methods for incremental loading of collaboratively generated presentations
US8434002B1 (en) 2011-10-17 2013-04-30 Google Inc. Systems and methods for collaborative editing of elements in a presentation document
US20150199308A1 (en) 2011-10-17 2015-07-16 Google Inc. Systems and methods for controlling the display of online documents
US8266245B1 (en) * 2011-10-17 2012-09-11 Google Inc. Systems and methods for incremental loading of collaboratively generated presentations
US10108737B2 (en) * 2012-01-25 2018-10-23 Microsoft Technology Licensing, Llc Presenting data driven forms
US9367522B2 (en) 2012-04-13 2016-06-14 Google Inc. Time-based presentation editing
US10546047B1 (en) * 2012-09-27 2020-01-28 Open Text Corporation Method and system for stashing of document alteration information for quicker web preview
US9372840B1 (en) * 2012-09-28 2016-06-21 Emc Corporation Method and system for accelerated transformation of content based on predictive chunking
US9529785B2 (en) 2012-11-27 2016-12-27 Google Inc. Detecting relationships between edits and acting on a subset of edits
EP2943892A4 (en) 2013-01-11 2016-01-27 Presse Ltée DEVICE, METHOD AND SYSTEM FOR DISPLAYING DIGITAL EDITIONS
US9069986B2 (en) * 2013-06-18 2015-06-30 International Business Machines Corporation Providing access control for public and private document fields
US20150007041A1 (en) * 2013-06-26 2015-01-01 M-Files Oy Method and technical equipment for providing a user interface implementation
US9383902B2 (en) * 2013-06-28 2016-07-05 Successfactors, Inc. Systems and methods for presentations with live application integration
JP6192423B2 (ja) * 2013-08-12 2017-09-06 キヤノン株式会社 情報処理装置及び情報処理方法、情報処理システム、プログラム
US9971752B2 (en) 2013-08-19 2018-05-15 Google Llc Systems and methods for resolving privileged edits within suggested edits
JP6464587B2 (ja) * 2013-08-21 2019-02-06 株式会社リコー 情報処理システム、情報処理装置、情報送信方法及びプログラム
US9348803B2 (en) 2013-10-22 2016-05-24 Google Inc. Systems and methods for providing just-in-time preview of suggestion resolutions
JP6703370B2 (ja) * 2014-03-14 2020-06-03 国立大学法人 東京大学 ドキュメント提供システム、提供側装置、表示側装置、及びプログラム
US9639511B2 (en) 2014-11-24 2017-05-02 Google Inc. Systems and methods for editing a file in a non-native application using an application engine
US11783120B2 (en) 2015-08-26 2023-10-10 Roar Software Pty Ltd. System and process for generating an internet application
AU2015255223B2 (en) * 2015-08-26 2021-02-25 Roar Software Pty Ltd System and process for generating an internet application
CN107295052B (zh) 2016-04-11 2020-06-09 阿里巴巴集团控股有限公司 一种业务处理方法及装置
KR102036715B1 (ko) * 2018-04-02 2019-10-25 주식회사 한글과컴퓨터 브라우저를 통해 프레젠테이션 문서의 빠른 로딩이 가능한 웹 기반의 프레젠테이션 편집 장치 및 그 동작 방법

Family Cites Families (69)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5838906A (en) * 1994-10-17 1998-11-17 The Regents Of The University Of California Distributed hypermedia method for automatically invoking external application providing interaction and display of embedded objects within a hypermedia document
US5737599A (en) * 1995-09-25 1998-04-07 Rowe; Edward R. Method and apparatus for downloading multi-page electronic documents with hint information
US5778372A (en) * 1996-04-18 1998-07-07 Microsoft Corporation Remote retrieval and display management of electronic document with incorporated images
US6119137A (en) * 1997-01-30 2000-09-12 Tumbleweed Communications Corp. Distributed dynamic document conversion server
US6401131B1 (en) * 1997-06-19 2002-06-04 International Business Machines Corporation Web server enabling attachment of HTML and non-HTML files to web pages
US6336124B1 (en) * 1998-10-01 2002-01-01 Bcl Computers, Inc. Conversion data representing a document to other formats for manipulation and display
US20020111973A1 (en) * 1998-10-15 2002-08-15 John Maddalozzo Method of controlling web browser document image downloads and displays
US6613098B1 (en) * 1999-06-15 2003-09-02 Microsoft Corporation Storage of application specific data in HTML
US6565609B1 (en) * 1999-06-15 2003-05-20 Microsoft Corporation Translating data into HTML while retaining formatting and functionality for returning the translated data to a parent application
GB9917554D0 (en) * 1999-07-27 1999-09-29 Schlumberger Holdings Publishing system for intranet
US6658462B1 (en) * 1999-08-26 2003-12-02 International Business Machines Corporation System, method, and program for balancing cache space requirements with retrieval access time for large documents on the internet
US6590674B1 (en) * 1999-09-23 2003-07-08 Agile Software Method and apparatus for creating and maintaining graphic representations of documents under a universal format
US6654032B1 (en) * 1999-12-23 2003-11-25 Webex Communications, Inc. Instant sharing of documents on a remote server
JP2003525492A (ja) * 2000-03-01 2003-08-26 セルトレックス リミテッド 高速文書変換のためのシステムおよび方法
US6725426B1 (en) * 2000-03-17 2004-04-20 Broadvision, Inc. Mechanism for translating between word processing documents and XML documents
US7024621B1 (en) * 2000-05-19 2006-04-04 Renderx Methods and systems for rendering electronic data
US6763501B1 (en) * 2000-06-09 2004-07-13 Webex Communications, Inc. Remote document serving
US6704024B2 (en) * 2000-08-07 2004-03-09 Zframe, Inc. Visual content browsing using rasterized representations
US6745163B1 (en) 2000-09-27 2004-06-01 International Business Machines Corporation Method and system for synchronizing audio and visual presentation in a multi-modal content renderer
US6988241B1 (en) * 2000-10-16 2006-01-17 International Business Machines Corporation Client side, web-based spreadsheet
CA2349905A1 (en) * 2001-06-07 2002-12-07 Ibm Canada Limited-Ibm Canada Limitee System and method of mapping between software objects and structured language element based documents
US20020198963A1 (en) * 2001-06-21 2002-12-26 Wu Alex C. Method of timer based download and playback scheme for internet browser
US7346843B2 (en) * 2001-09-18 2008-03-18 International Business Machines Corporation Low-latency, incremental rendering in a content framework
JP2003108428A (ja) * 2001-09-27 2003-04-11 Nippon Telegr & Teleph Corp <Ntt> キャッシュ協調データ取得方法及びプロキシサーバ及びキャッシュ協調データ取得プログラム及びキャッシュ協調データ取得プログラムを格納した記憶媒体
US20050080804A1 (en) 2001-10-30 2005-04-14 Bradshaw Robert David System and method for maintaining componentized content
US20030106021A1 (en) * 2001-11-30 2003-06-05 Tushar Mangrola Apparatus and method for creating PDF documents
AUPR962001A0 (en) * 2001-12-19 2002-01-24 Redbank Manor Pty Ltd Document display system and method
KR100576487B1 (ko) 2002-02-08 2006-05-10 인터우븐 인코포레이티드 컴포넌트화된 콘텐츠를 유지하기 위한 시스템 및 방법
US20030191858A1 (en) * 2002-04-05 2003-10-09 Koteshwerrao Adusumilli Response time of transformed documents based on caching and dynamic transformation
US7398464B1 (en) * 2002-05-31 2008-07-08 Oracle International Corporation System and method for converting an electronically stored document
US7181682B1 (en) * 2002-06-27 2007-02-20 Siebel Systems, Inc. Document publishing and rendering
US20040030995A1 (en) * 2002-08-08 2004-02-12 International Business Machines Corporation Web-based document printing and conversion
US7721202B2 (en) * 2002-08-16 2010-05-18 Open Invention Network, Llc XML streaming transformer
US7409452B2 (en) * 2003-02-28 2008-08-05 Xerox Corporation Method and apparatus for controlling document service requests from a mobile device
JP4191063B2 (ja) * 2003-05-08 2008-12-03 株式会社リコー 画像処理装置、画像処理方法、画像処理プログラム
US20060259524A1 (en) * 2003-03-17 2006-11-16 Horton D T Systems and methods for document project management, conversion, and filing
FR2853788A1 (fr) * 2003-04-08 2004-10-15 Canon Kk Procede et dispositif d'acces a un document numerique dans un reseau de communication du type poste a poste
GB2416890A (en) * 2003-05-05 2006-02-08 Arbortext Inc System and method for managing dynamic content assembly
US20050216846A1 (en) 2004-03-26 2005-09-29 Mika Kalenius Normal versus small screen rendering with given URL
US20050268215A1 (en) * 2004-06-01 2005-12-01 Microsoft Corporation Method and apparatus for viewing and interacting with a spreadsheet from within a web browser
US7584422B2 (en) * 2004-07-12 2009-09-01 Informatica Corporation System and method for data format transformation
US7188312B2 (en) * 2004-08-12 2007-03-06 Ap-Mobile Technology Inc. Remote document viewing system, device, and method thereof
US20060069746A1 (en) * 2004-09-08 2006-03-30 Davis Franklin A System and method for smart persistent cache
US20140250361A1 (en) * 2004-09-30 2014-09-04 Macromedia, Inc. Preserving document construct fidelity in converting graphic-represented documents into text-readable documents
US9298675B2 (en) * 2004-09-30 2016-03-29 Adobe Systems Incorporated Smart document import
US7411693B2 (en) * 2004-10-15 2008-08-12 Agfa Inc. Image data dissemination system and method
US20060106822A1 (en) * 2004-11-17 2006-05-18 Chao-Chun Lee Web-based editing system of compound documents and method thereof
US7627592B2 (en) * 2004-12-16 2009-12-01 Microsoft Corporation Systems and methods for converting a formatted document to a web page
US20060212798A1 (en) 2005-01-12 2006-09-21 Lection David B Rendering content natively on local operating system
US20060242572A1 (en) * 2005-04-22 2006-10-26 Microsoft Corporation Viewer for protected content as a programming platform component
US7814410B2 (en) 2005-09-12 2010-10-12 Workman Nydegger Initial server-side content rendering for client-script web pages
US8775520B1 (en) * 2005-09-30 2014-07-08 Google Inc. Systems and methods for viewing non-HTML email attachments
US20070220417A1 (en) * 2006-03-17 2007-09-20 Sonolink Communications Systems, Llc System and method for editing online documents
CN101055577A (zh) * 2006-04-12 2007-10-17 龙搜(北京)科技有限公司 可扩展标记语言集中器
US20080120283A1 (en) * 2006-11-17 2008-05-22 Oracle International Corporation Processing XML data stream(s) using continuous queries in a data stream management system
US8745486B2 (en) * 2007-01-25 2014-06-03 Microsoft Corporation Streamable interactive rendering-independent page layout
CA2676692A1 (en) * 2007-02-09 2008-08-14 Novarra, Inc. Method and system for providing portions of information content to a client device
US9880980B2 (en) * 2007-03-05 2018-01-30 International Business Machines Corporation Document transformation performance via incremental fragment transformations
US8069433B2 (en) * 2007-04-18 2011-11-29 Microsoft Corporation Multi-format centralized distribution of localized resources for multiple products
WO2009026727A2 (en) * 2007-08-31 2009-03-05 Tree Technologies Inc. System and method for the automated creation of a virtual publication
US8561116B2 (en) * 2007-09-26 2013-10-15 Charles A. Hasek Methods and apparatus for content caching in a video network
WO2009073682A1 (en) * 2007-12-03 2009-06-11 Vuzit, Llc System and method for enabling viewing of documents not in html format
US8266524B2 (en) * 2008-02-25 2012-09-11 Microsoft Corporation Editing a document using a transitory editing surface
US20090235161A1 (en) * 2008-03-15 2009-09-17 Microsoft Corporation Lossless Web-Based Editor For Complex Documents
US20090276696A1 (en) * 2008-04-30 2009-11-05 Microsoft Corporation High-fidelity rendering of documents in viewer clients
US20090313574A1 (en) * 2008-06-16 2009-12-17 Microsoft Corporation Mobile document viewer
US8407576B1 (en) * 2008-09-02 2013-03-26 Sitscape, Inc. Situational web-based dashboard
US20110258535A1 (en) * 2010-04-20 2011-10-20 Scribd, Inc. Integrated document viewer with automatic sharing of reading-related activities across external social networks
US8549167B2 (en) * 2011-06-21 2013-10-01 Net Power And Light, Inc. Just-in-time transcoding of application content

Also Published As

Publication number Publication date
CA2749683C (en) 2019-01-08
WO2010101790A3 (en) 2011-01-13
BRPI1007813A2 (pt) 2017-01-17
MY163751A (en) 2017-10-31
CL2011002084A1 (es) 2012-02-03
CN102341823B (zh) 2014-11-26
KR20110134401A (ko) 2011-12-14
MX2011009158A (es) 2011-09-28
TW201035861A (en) 2010-10-01
RU2571512C2 (ru) 2015-12-20
IL214057A0 (en) 2011-08-31
US20100229086A1 (en) 2010-09-09
JP2012519907A (ja) 2012-08-30
ZA201105214B (en) 2012-09-26
IL214057A (en) 2016-02-29
SG172952A1 (en) 2011-08-29
KR101626639B1 (ko) 2016-06-02
US8347208B2 (en) 2013-01-01
RU2011136691A (ru) 2013-03-10
JP5537571B2 (ja) 2014-07-02
AU2010221620A1 (en) 2011-08-04
TWI493441B (zh) 2015-07-21
AU2010221620B2 (en) 2014-07-10
CA2749683A1 (en) 2010-09-10
US20120331377A1 (en) 2012-12-27
EP2404276A4 (en) 2018-01-24
CN102341823A (zh) 2012-02-01
EP2404276A2 (en) 2012-01-11

Similar Documents

Publication Publication Date Title
CA2749683C (en) Content rendering on a computer
JP5911304B2 (ja) ウェブ上の文書を閲覧するためのフォントの取扱い
US9740435B2 (en) Methods for managing content stored in cloud-based storages
US9176953B2 (en) Method and system of web-based document service
RU2555219C2 (ru) Использование предварительной обработки на сервере для развертывания представлений электронных документов в компьютерной сети
US9721015B2 (en) Providing a query results page
JP5042693B2 (ja) マークアップ言語ファイルの格納及び送信の最適化
US20130318089A1 (en) Catalog performance and integrity analysis
US20020092012A1 (en) Smart-caching system and method
US8108441B2 (en) Efficient creation, storage, and provision of web-viewable documents
US20170017574A1 (en) Efficient cache warm up based on user requests
US11853688B2 (en) Automatic detection and removal of typesetting errors in electronic documents
Hua et al. Design and performance studies of an adaptive scheme for serving dynamic web content in a mobile computing environment
CN112784195B (zh) 一种页面数据发布方法和系统
US20130124954A1 (en) Method and Apparatus for Merging Digital Content
US20150205766A1 (en) Serving combined resources to a browser client
EP2932364A1 (en) Consuming content incrementally
CN112818274B (zh) Pdf文件转换为分页html文件的方法及计算机设备
US10586078B2 (en) Document system, control method, and storage medium
CN104936044A (zh) 一种基于html5的传输视频文件的方法、客户端及服务器

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 201080010824.7

Country of ref document: CN

121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 10749134

Country of ref document: EP

Kind code of ref document: A2

WWE Wipo information: entry into national phase

Ref document number: 2749683

Country of ref document: CA

Ref document number: 2010221620

Country of ref document: AU

ENP Entry into the national phase

Ref document number: 2010221620

Country of ref document: AU

Date of ref document: 20100226

Kind code of ref document: A

WWE Wipo information: entry into national phase

Ref document number: 5999/CHENP/2011

Country of ref document: IN

WWE Wipo information: entry into national phase

Ref document number: 2011002084

Country of ref document: CL

WWE Wipo information: entry into national phase

Ref document number: MX/A/2011/009158

Country of ref document: MX

WWE Wipo information: entry into national phase

Ref document number: 2010749134

Country of ref document: EP

ENP Entry into the national phase

Ref document number: 20117020549

Country of ref document: KR

Kind code of ref document: A

WWE Wipo information: entry into national phase

Ref document number: 2011136691

Country of ref document: RU

NENP Non-entry into the national phase

Ref country code: DE

WWE Wipo information: entry into national phase

Ref document number: 2011552998

Country of ref document: JP

REG Reference to national code

Ref country code: BR

Ref legal event code: B01A

Ref document number: PI1007813

Country of ref document: BR

ENP Entry into the national phase

Ref document number: PI1007813

Country of ref document: BR

Kind code of ref document: A2

Effective date: 20110812