EP1800222A4 - Systeme d'annotation partage et son procede - Google Patents
Systeme d'annotation partage et son procedeInfo
- Publication number
- EP1800222A4 EP1800222A4 EP05794986A EP05794986A EP1800222A4 EP 1800222 A4 EP1800222 A4 EP 1800222A4 EP 05794986 A EP05794986 A EP 05794986A EP 05794986 A EP05794986 A EP 05794986A EP 1800222 A4 EP1800222 A4 EP 1800222A4
- Authority
- EP
- European Patent Office
- Prior art keywords
- user
- annotation
- document
- annotations
- content
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Withdrawn
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION 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
- G06Q10/00—Administration; Management
- G06Q10/10—Office automation; Time management
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F40/00—Handling natural language data
- G06F40/10—Text processing
- G06F40/166—Editing, e.g. inserting or deleting
- G06F40/169—Annotation, e.g. comment data or footnotes
Definitions
- the inventions disclosed herein relate generally to collaborative systems and more particularly to shared annotation systems.
- One issue associated with network collaboration is synchronicity. For example, users often collaborate by exchanging versions of documents via e-mail or other similar means.
- a first user edits or otherwise comments a document and then sends the revised version to a second user for further input.
- the second user makes or otherwise provides their input and then e-mails the new document back to the first user.
- the first user is editing the document, however, the second user cannot provide input since they do not possess the current version of the document (currently being edited by the first user) and therefore do not know what changes the first user might be making.
- the first user cannot provide further input while the document is being edited by the second user. It is thus desirable for users to be able to provide synchronous comments and edits without having to wait for other users.
- Discussions are stored separately from their related documents. When a particular document is requested by a user, any related discussions associated with the identifier for the document are also retrieved.
- the system discussed in the '564 application has a number of shortcomings. For example, in the '564 patent, only HTML text associated with a discussion is stored. If the discussion is linked to another item, for example a media item, such as a graphic, a video clip, an audio clip, etc., the media file is not stored in the system database containing the HTML text and other data associated with the discussion. Also, only a link to the media is stored.
- the present invention addresses, among other things, the problems discussed above with shared annotation systems.
- computerized methods are provided for enabling a plurality of users to collaborate or otherwise provide annotations and other input and feedback related to shared documents and content in a computer network. Users are able to synchronously navigate content via multi- portion displays in which indicators related to the annotations are embedded in document content in a first portion of the display and the related annotations are synchronously presented in at least a second portion of the display.
- the system also generates custom documents based on annotated content, provides commerce opportunities related to annotated content, persistently presents selected multimedia content while navigating a plurality of document pages, and accepts and indexes annotations related to visual content elements such as graphics and photographs.
- the system enables a method for automatically navigating a document in a display having at least a first portion and a second portion, the method comprising: receiving an annotation related to the document, the annotation generated by a user at a first client; associating the annotation with a first indication in the document; receiving, from a user at a second client, an input to navigate a first portion of a display at the second client, the input causing the first indication to be displayed in the first portion of the display; and in response to the input, automatically displaying the annotation in a second portion of the display at the second client.
- the display comprises a browser window, such as an Internet browser.
- the document comprises an electronic book, a digital photo album containing one or more digital photos, a web page, a text document, or a multimedia document.
- the annotation comprises a text annotation, such as a comment related to the document.
- the annotation comprises a graphical annotation, such as a photograph.
- the annotation comprises an audio annotation, a video annotation, a multimedia annotation, or a discussion group related to the document.
- the input comprises an input to scroll the first portion of the display or an input to navigate to a portion of the document containing the first indication.
- the first indication comprises a graphical indication, such as an icon.
- receiving an annotation comprises receiving form data submitted by the user at the first client, such as receiving HTML form data.
- associating the annotation with a first indication in the document comprises: identifying a portion of the document to which the annotation relates; and associating the first indication with the portion of the document to which the annotation relates.
- the annotation comprises a discussion group related to the portion of the document.
- the annotation is added to a data structure stored in memory, the data structure comprising a list of annotations relating to portions of one or more documents.
- the list of annotations comprises a list of bookmarks.
- the system receives input selecting an annotation from the list of bookmarks and displays, in the first portion of the display, at least a portion of a document to which the annotation is related and displays at least the selected annotation in the second portion of the display.
- associating the first indication comprises embedding the first indication in the portion of the document to which the annotation relates.
- embedding the first indication comprises: receiving location data related to the portion of the document; processing the location data to determine a first location within the document relative to a location of the portion within the document; and generating a new * version of the document, the new version of the document containing the first indication embedded at the first location.
- the location data comprises one or more from the group comprising: a document identifier, a section identifier, a chapter identifier, a bookmark identifier, a portion length, and a portion offset.
- the invention also includes systems and methods for replacing a first version of the document stored in memory with the new version of the document, for example by overwriting a first version of the document with a new version of the document.
- receiving an annotation comprises receiving an annotation related to an image contained in the document, for example receiving information identifying one or more subjects of the image.
- the system also includes methods for associating the one or more subjects with the image, such as by updating a data structure stored in memory, the data structure storing associations between one or more images and one or more subjects of the one or more images.
- the annotation comprises a commercial offer, such as an offer to purchase a product related to the document.
- the system also includes methods for processing a request by a user at a client to purchase the product, such as methods for transmitting the product and the document to the user.
- the system also includes methods for communicating, to a user at a client, an offer to purchase the document and a set of annotations related to the document, such as a set of annotations selected by the user.
- the system processes the user request to purchase the document and the set of annotations, for example by printing the document and the set of annotations.
- the system prints the annotation and the related portion of the document on the same page.
- processing the user request comprises transmitting the document and the set of annotations to the user.
- the system also includes methods for authenticating the user at a first client and authorizing the user at the first client to provide the annotation; and authenticating the user at the second client and authorizing the user at the second client to navigate the document.
- the system includes methods to annotate content of a web page. An indication is inserted in and associated with content according to markup language describing offsets including a starting point and an endpoint for the indication, the starting point and endpoint offsets corresponding to a number of characters from a location within the content.
- the system includes program code that captures user inputs identifying selections according to a paragraph identifier, a starting point value, and an ending point value.
- the system enables a method for selecting an arbitrary string of characters on a web page and posting the selection, including related metadata, to an application server.
- the related metadata includes positional metadata and content identifiers.
- the system enables a method for creating a custom memory book including original content supplied by a first party, annotations provided by one or more users, and multimedia elements provided by other users. For example, in some embodiments, users create a memory book by customizing existing content provided by content creators.
- the original article also generally contains indications and corresponding annotations input by various users responding to the original article.
- a user can then create any number of custom memory books from the original article by uploading additional multimedia elements and selecting specific annotations to include in their personal memory book.
- a user uploads their own personal pictures to replace or supplement the pictures in the original article posted by the content provider.
- a user also uses pictures posted as annotations by other users to replace or supplement pictures of the original article or they use additional pictures provided by the content provider or other content providers.
- users also select custom annotations to include with the memory book by filtering or otherwise selecting annotations from the set of annotations posted by other users regarding the original article.
- a user automatically selects annotation from a list of friends who post annotations.
- users select annotations individually or based on criteria such as ratings from other users or annotation type.
- the system enables a method for printing and binding the custom memory book, such as by using standard book publishing equipment and techniques.
- FIG. 1 is a block diagram of a shared annotation system according to an embodiment of the present invention
- FIG. 2 is a block diagram of functional modules in a shared annotation system according to an embodiment of the present invention.
- FIG. 3 is a flow chart of a method to synchronously navigate shared annotations according to an embodiment of the present invention
- FIG. 4a is a block diagram of an exemplary screen display of a shared annotation system according to an embodiment of the present invention.
- Fig. 4b is a block diagram of two exemplary screen displays of a shared annotation system according to an embodiment of the present invention.
- Fig. 5 is a flow chart of a method for processing an annotation according to an embodiment of the present invention
- FIG. 5 A presents an exemplary sample of code for an XHTML formatted page of content according to one embodiment of the invention
- Fig. 5B presents an exemplary sample of code for an XHTML formatted page of content according to one embodiment of the invention
- Fig. 6 is a flow chart of a method of annotating a visual element according to an embodiment of the present invention.
- Fig. 6A is a flow chart of a method of recreating a page of content according an embodiment of the invention.
- Fig. 6B is a flow chart of a method of processing an element during page creation according to an embodiment of the invention;
- Fig. 7 is a flow chart of a method of providing a customized document related to a shared annotation system according to an embodiment of the present invention
- Fig. 8 is a block diagram of a sample page from a customized document related to a shared annotation system according to an embodiment of the present invention
- Fig. 8A is a screenshot of an exemplary article page of a memory book according to an embodiment of the present invention
- Fig. 8B is a screenshot of an exemplary comments page of a memory book according to an embodiment of the present invention
- Fig. 8C is a screenshot of an exemplary dynamic print page according to an embodiment of the invention.
- Fig. 9 is a flow chart of a method of presenting a selected multimedia element while navigating a document in shared annotation system according to an embodiment of the present invention.
- the system also generates custom documents based on annotated content, provides commerce opportunities related to annotated content, persistently presents selected multimedia content while navigating a plurality of document pages, and accepts and indexes annotations related to visual content elements such as graphics and photographs. Additional aspects and features of the system will also be appreciated by one skilled in the art as further described below.
- Fig. 1 presents a block diagram of a shared annotation system according to an embodiment of the present invention.
- the system includes one or more clients including first client 105, a second client 110, and an nth client 115, connected to a network 120, a content server 125 including a content processor 130 communicatively coupled to a data store 135, and one or more additional computers including a moderator computer 140, an administrator computer 145, and a support computer 150.
- Clients 105, 110, and 115, and other computers in the system including personal computers and other computing devices known in the art including personal digital assistants ("PDAs"), tablet computers, cellular telephones, and other devices.
- PDAs personal digital assistants
- the clients are communicatively coupled to the content server 125 via a computer network 120, such as the Internet or a local area network (“LAN").
- a computer network 120 such as the Internet or a local area network (“LAN").
- LAN local area network
- Users of the client's devices collaborate or otherwise provide annotations and other input and feedback related to shared documents and content in the network.
- the users collaborate or otherwise provide annotations regarding the content via one or more software modules including a display module.
- users interact with content and provide annotations via a web browser, such as Microsoft Internet Explorer or Netscape Navigator.
- the content server 125 contains a content processor 130 and other modules directed to receiving and processing user requests regarding content. Requests include annotations regarding content, requests for new content, navigation inputs regarding content, and other user requests.
- the content server 125 is communicatively coupled to a data store 135.
- the data store 135 stores a variety of data including document content for delivery to users, user account and registration information, annotations and other information generated by users regarding content, and other related data.
- annotations generally include content-related input provided by users including text input, graphical input, audio input, video input, and other types of input, associated in some way with a particular selected character sequence in a primary set of content. For example, a user may input a textual comment or a user may upload a picture related to content.
- a user may also provide a voice recording or other recording related to content or even a video clip as an annotation.
- Annotations may also include a discussion group or other similar forum or means to facilitate threaded discourse or other interaction between users regarding a particular portion of a document. For example, a user may find a particular paragraph of a document very important and create a location-specific discussion group regarding the paragraph as an annotation.
- Additional computers are also connected to the network 120 and interface with content server 125 and client computers to provide additional functionality.
- moderator computer 140 may be used by a moderator to review and approve user comments and annotations.
- An administrator computer 145 may manage other aspects of user interaction with the system such as user registration or security related issues.
- Support personnel may use support computer 150 to interface with users and provide additional assistance or help regarding user concerns. Additional computers of remote clients may also be employed or used by role-based personnel such as a picture moderator, a comments moderator, a topic approver, a new edition creator, a discussion group moderator, etc.
- Fig. 2 presents a block diagram of functional modules in a shared annotation system according to an embodiment of the invention.
- the system is implemented using Model View Controller ("MVC") architecture as known in the art.
- MVC Model View Controller
- Four tiers are presented including a client tier 153, a presentation tier 163, and an application tier 167, as well as a data store 135 or integration tier containing the data model.
- modules are distributed among one or more content servers 125 and clients 105, 110, 115.
- the system may also implement multiple tiers and distribute modules to distribute functionality in order to improve system efficiency or otherwise load balance processing operations.
- the client tier 153 includes a highlight module 155, a synchronization module 157, an annotation module 159, and a view modes module 161.
- the client tier includes code, such as JavaScript code, that executes on various pages, such as DHTML pages.
- the highlight module 155 is generally directed to managing selection and highlighting of annotations and text in the original content. For example, if a user clicks on an image annotation, the highlight module manages highlighting the corresponding text in the first portion of the display as well as the image annotation in the second portion of the display. Conversely, if a user selects or otherwise interacts with an annotation in the second portion of the display, the corresponding text or other visual elements are highlighted in the first portion of the display by the highlight module.
- the synchronization module 157 manages relationships between original content in the first portion of the display and corresponding annotations in the second portion of the display.
- annotations are presented corresponding to content in the first portion of the display as the user scrolls the first portion of the display.
- the first portion of the display also synchronously scrolls ensuring that original content in the first portion corresponding to the annotations in the second portion is consistently displayed.
- the synchronization module 157 also prevents unnecessary scrolling which might cause flicker. For example, no scrolling is performed if an icon or other indication present in the first portion of the display corresponds to an annotation already visible in the second portion of the display.
- the second part of the display is scrolled to find the next annotation only when a navigation input changes the display such that an indication in the first portion of the display disappears and vice-versa.
- the annotation module 159 generally manages and processes annotations of images and other multimedia content. For example, when a user selects a photo for annotation, the annotation module 159 presents a rectangular selection box over the photo that may be resized to precisely indicate the portion of the photo to which an annotation refers. Multiple selection rectangles or other selection shapes may be drawn over a photo each corresponding to individual annotations. Upon receipt of an appropriate input, for example when a save or post annotation(s) button is selected, the annotation module also handles communicating the selection input(s) and related annotation information to other modules of the system as further described herein.
- the view modes module 161 generally manages and controls presentation modes for content. For example, the view modes module switches between modes such as “embedded mode” in which indications or icons are presented inline with original content, "non- embedded mode” in which indications are presented to the left of the original content with one indication type per paragraph, and “memory book mode” in which indications are aggregated by type and presented inline at the end of individual paragraphs as opposed to directly in the text or to the left of the text.
- the presentation tier 163 generally includes a number of modules 165 running code within the web container.
- the code modules 165 generally include a controller responsive to data and inputs received from the client tier 163 as well as the business tier 167.
- Exemplary code modules 165 correspond to modules of the business tier 167 as further described herein and include a back office module, a book module, a bookmark module, a comment module, a conversion module, an ecommerce module, a print module, an image module, a media module, a profile module, a search module, and a user management module.
- Code modules 165 provide a bridge between application logic provided by the business tier and client inputs or presentation outputs.
- the business tier 167 generally includes a number modules including a back office module 169, a book or content module 171, a bookmarks module 173, a user management module 175, a content serialization module ("CSE") 177, a media module 179, a comments module 181, a statistics module 183, a conversion module 185, an ecommerce module 187, a print module 189, a personalization module 191, a profile module 193, a search module 195, a payment gateway module 197, and a print services module 199.
- CSE content serialization module
- the user management module 175 is generally responsible for handling user-related operations such as registration, authentication, and membership rights and approvals (such as for administrators, regular members, etc.).
- the book or content module 171 generally manages and directs content-related operations such as navigation to other pages and tracking user preferences. For example, the content module 171 tracks preferred viewing modes and last pages visited for users. Generally, the content module is not directly responsible for serving content, however, since this is handled and resolved in the presentation tier by the corresponding book code module of the presentation tier and other code modules for the sake of improved performance.
- the bookmarks module 173 generally manages the user's private bookmarks list for content and annotations.
- the bookmarks module 173 maintains a data structure containing pointers to locations for content or annotations that a user may wish to revisit or otherwise mark as a favorite.
- the system automatically navigates to and presents the related content or annotation corresponding to the selected bookmark.
- the comments module 181 is generally directed to processing operations associated with posing annotations.
- the comments module 181 manages inputs posting or replying to annotations, applying automatic moderation to posted annotations, and notifying moderators when annotations trigger various notification filters.
- the comments module 181 also notifies annotation authors when a reply or other corresponding annotation is posted regarding their authored annotation.
- media module 179 processes graphical annotations and other graphical information provided by users.
- the media module 179 processes photo, video, and audio annotations processing posts and notifying moderators of certain posts, as well as managing user replies.
- the media module also processes video annotations by capturing and presenting a particular frame (such as the first frame) as a thumbnail image representing the video in the annotations portion of the display.
- the content serialization engine 177 interfaces with the database 135 to lock content, update content, and otherwise process user annotations.
- the CSE 177 facilitates content delivery among multiple users. For example, when a first user provides an annotation regarding a particular page of content, in some embodiments, synchronization module 165 locks that page and prevents access to the page by other users until the annotation process is complete. In some embodiments, the CSE 177 maintains a queue of new annotations and processes annotations by creating new content pages and media pages containing the new annotations as further described herein.
- the statistics module 183 generally tracks data related to posted annotations. For example, in some embodiments, the statistics module 183 tracks the number of annotations posted for each page in a given document and presents an indication of which page has the most number of new posts or a certain number of posts within a given period of time, such as in memory book mode as further described herein.
- the print module 189 is generally directed to printing or otherwise outputting content according to user inputs and preferences. For example, the print module 189 creates PDF files or other document files for versions of content output such as dynamic print and memory book creation as further described herein.
- the conversion module 185 is generally responsible for processing and formatting raw original content for use by the system and for users to annotate.
- the conversion module parses original content into paragraphs, formats the content for presentation, and creates bookmark IDs or other identifiers for each paragraph used by the CSE 177 to create new pages when annotations are added as further described herein.
- the ecommerce module 187 processes payments and generally handles monetary transactions associated with use of the system. For example, the ecommerce module manages shopping carts and other purchase vehicles, processes credit card payments and other payments, and also interfaces with other modules such as integration modules including the payment gateway 197 and external print services 199.
- the personalization module 191 and the profile module 193 are generally responsible for processing inputs regarding user accounts. For example, the profile module 193 processes user administrative requests regarding password and address changes.
- the personalization module 19 handles other inputs such as associating a personal photo or icon to present next to user postings or in a user's business card, as well as other general information about the user such as hobbies, favorite websites, etc.
- the search module 195 is generally responsible for indexing and processing search operations on both original text and on annotations.
- search module 195 allows users to search not only document content, but also annotations provided by other users and other information. Users can search for annotations provided by a particular user, for a particular text string contained in annotations, and input other search expressions to locate information.
- the system also includes various modules, such as a payment gateway module 197 and a print services module 199, for integration with external or third-party systems.
- the payment gateway module 197 provides an interface to process all or part of the payments using a third-party payment provider.
- the print services module 199 provides an interface for printing special jobs, such as hardcover book binding or other types of book creation of content, using a third-party or other external print services provider.
- the business tier also includes a commons module 201.
- the commons module generally includes a utility library of various APIs and other system calls used for interfacing with the operating system, hardware components, the data store 135, modules in the various other tiers, etc.
- the system receives an annotation generated by a first user at a first client, step 230.
- the annotation is associated with a first indication, step 235.
- the annotation may be associated with an icon or other indication embedded in the document.
- the navigation input causes the first indication to be displayed in the first portion of the display at the second client.
- the system automatically displays the annotation in the second portion of the display at the second client, step 245.
- the system also processes and navigation inputs navigating the second portion of the display.
- the system also can receive an input from a second user at a second computer to navigate a second portion of a display at the second client.
- the navigation input causes the annotation to be displayed in the second portion of the display at the second client and, in response to the input, the system automatically displays the first indication in the first portion of the display at the second client.
- the system divides content into a plurality of pages. Thus, a book might be divided into chapters and each chapter formatted as a particular HTML or other similarly encoded page.
- the system loads an entire page of original content into the first portion of the display and also the entire page of related annotations for the page in the second portion of the display.
- the system first loads only those annotations corresponding to indications immediately displayed upon loading the page into the first portion and then loads annotations corresponding to off-screen indications which achieves, among other benefits, a performance boost in terms of load times.
- code such as a JavaScript synchronization module monitors user navigation inputs and mouse inputs and states to determine whether and when to synchronously scroll or otherwise display indications and their related annotations in the first and second portions of the display.
- a JavaScript event or other similar program code returns identifiers corresponding to indications that are visibly displayed in the first portion.
- the system employs a naming convention correlating indications with annotations.
- an indication labeled Il would have its corresponding annotation labeled Al and an indication with an identifier of 12 would have its corresponding annotation identified as A2, etc.
- the system determines, based on the JavaScript event data and indication identifiers, any indications visible in the first portion of the display and then automatically executes JavaScript code or other program code to display, in the second portion of the display, their corresponding annotations according to the naming convention. For example, if the system identifies indication Il as visible in the first portion of the display, then it automatically executes code to display Al in the second portion of the display.
- the system when a number of indications are visible in the first portion of the display and there is insufficient screen space in the second portion of the display to display all of the corresponding annotations, the system, starting with the first indication displayed, displays as many corresponding annotations as possible in the second portion of the display. [0067] In some embodiments, when a navigation input is received related to the second portion of the display, the system determines, based on the JavaScript event data and annotation identifiers, any annotations visible in the second portion of the display. The system also determines any indications visible in the first portion of the display as previously described herein. If the first portion of the display already shows the indication corresponding to the first annotation appearing in the second portion of the display, then the system does not redraw the screen.
- the system executes JavaScript code or other program code to display, in the first portion of the display, the indication corresponding to the first annotation appearing in the second portion of the display according to the naming convention. For example, if the system identifies annotation Al as visible in the second portion of the display, then it checks if indication Il is visible in the first portion of the display. If the indication is not visible, the system automatically executes code to display Il in the second portion of the display. [0068]
- users at a plurality of clients are able to view content, as well as collaboratively annotate and view annotations provided by other users. For example, several users may negotiate a contract by sharing feedback and other annotations to produce a final version of the contract.
- Fig. 4A presents a block diagram of an exemplary screen display of a shared annotation system according to an embodiment of the invention.
- a display 250 such as a browser display or other software application display, is divided into a first portion of 252 and a second portion 254.
- the first portion 252 contains information content provided by a server and the second portion 254 contains annotations related to the content in the first portion.
- a user requests content from the content server and the content is delivered via the network to the user at a client and presented in the first portion of the display 252.
- Content may include, for example, the text of a book, graphical content such as a picture album or photo album, a proposed legal document or business agreement, multimedia content, or other types of content.
- the text of a book appears in the first portion 252 of the display 250.
- Indications associated with user annotations are embedded within the content of the first portion of the display.
- indication 256 corresponding to user annotation 262 and indication 258 corresponding to user annotation 264 are embedded in the content of the first portion 252.
- the actual annotations 262 and 264 are presented in the second portion of the display 254.
- the display 250 also includes a third portion 260 including additional references to indications contained in the first portion 252.
- additional indications 266, and 268 corresponding to indications 256 and 258 are presented in a third portion of the display 260. Users can scan the third portion of the display 260 to quickly determine whether indications exist in the content presented in the first portion of the display 252.
- the system also presents navigation interfaces such as scroll bars 272 and 274, as well as a menu bar 276 at the bottom of the display 250 which provides users with an interface to navigate a document divided into chapters/sections or jump to additional pages, etc.
- the system also presents standard interface elements such as final, edit, view, favorites, tools and help menus 278 as known in the art and common in Internet browsers.
- the system presents a plurality of icons 280 designed to provide an interface for common operations that users might want to perform when viewing content such as a document, a photo album, or a book.
- Fig. 4B presents a block diagram of two exemplary screen displays of a shared annotation system according to one embodiment of the invention.
- the two screen displays 282 and 300 show versions of the same display at two different points in time.
- the display is divided into a first portion 284 and a second portion 286.
- the first portion contains content as well as indications 288 and 290 associated with user annotations 292 and 294 respectively.
- Navigation means such as scroll bars 296 and 298, are also provided.
- a user navigating the display 282 for example, by using slider 296, would cause the display 282 to change as shown in a second screen display 300 of the same display at a later point in time after the system processes the navigation input.
- the user scrolls the content in the first portion 284 such that indication 288 disappears from the first portion 284 and indication 302 appears.
- annotation 292 associated with indication 288 automatically disappears in the second portion 286 of the display 300 and annotation 304 corresponding to indication 302 automatically appears in the second portion 286.
- the system also conversely scrolls content in the first portion 284 of the display 282 when a user navigates content in the second portion 286 of the display 282.
- the system automatically scrolls content in the first portion 284 of the display 282 according to a user input, such as a scroll bar slider 298 or other similar means, to navigate annotations in the second portion 286 of the display 282.
- a user input such as a scroll bar slider 298 or other similar means
- Fig. 5 presents a flow chart of a method for processing an annotation according to an embodiment of the present invention.
- a user selects content via a selection tool or other means, step 330.
- a user might employ a text tool to highlight and select several words in the text of a document which the user wishes to annotate with a textual comment, an uploaded picture, a video, a sound recording, etc.
- JavaScript event code or other program code related to mouse inputs and other user inputs captures various metadata regarding the user selection.
- the event code captures and returns a unique paragraph identifier tag, a starting point value or offset (in characters from the start of the identified paragraph, pixels, or other metrics known in the art), and ending point value or offset.
- a user can crop one or more areas of a picture the user desires to annotate.
- a user could crop a single area of a picture for an annotation or a user could crop several different (or overlapping) areas of the same picture for several different annotations.
- the user selects the area using a rectangular cropping tool.
- the system captures the x,y coordinates of the corners of the rectangle to create a mapping or overlay representing the selection of the original image.
- the user may also assign additional attributes to the selection (such as a person name, a product identifier, a price, a location, a theme, a date, etc.).
- users may also indicate a frame or other location in a video using similar selection means for individual frames of a video.
- the system expands the selection to an appropriate level of granularity, step 335. A user might select several letters of a word and the system might expand the selection by highlighting the entire word.
- the system imposes a pre-set limit on the ability of a user to annotate text to a certain level of granularity.
- a user may only be able to annotate whole words or only words at the end of a sentence.
- a single word such as "Kennedy” might have as many as seven distinct indications (corresponding to the total number of letters in the word) presented with the word. This would likely render display of content in the first portion of the display extremely cumbersome and severely limit the ability of the system to efficiently present information to users.
- the system may also limit the number of indications presented related to particular sections of text or other content. Indications may be consolidated or combined in the interest of making content more readable, visually comprehensive, or otherwise accessible. For example, annotations provided by four different users might be associated with a single indication embedded in the content and displayed in the first portion of the display rather than with four separate indications in the first portion. In the second portion, however, each individual annotation provided would automatically be displayed when its corresponding indication is presented in the first portion of the display. [0080] After the user selects the desired content, the user indicates its desire to post an annotation related to the selected content, step 340. For example, a user may select a section of text and then click a "post" button or icon.
- the system presents a form or other similar input mechanism, step 345, which allows the user to input and submit/upload the desired annotation to the content server, step 350.
- a form window may open allowing the user to input a text annotation or a tree-view directory structure may be presented allowing the user to select a file (such as a picture, a video, an audio clip, etc.) to upload as an annotation.
- the annotation input by the user and any related metadata are then uploaded via the network to the content server and stored in the data store for further processing, step 355.
- the system generally communicates metadata indicating, among other things, the desired position of the annotation within the content of the first portion, the user's identity, the type of annotation, etc.
- JavaScript code captures the events of a mouse click indicating the beginning of a selection, mouse drag changing the x,y coordinates for the selection, and a mouse up or un-click ending the selection. This data is saved into an HTML form attribute and transmitted to the server when the form is submitted.
- the system also indicates the position of a desired annotation by providing metadata indicating an offset from a particular starting point within the document content and a selection length corresponding to the user selection of steps 330 and 335. For example, if a user selects text several sentences into a paragraph or other arbitrary section of a document, the system may communicate metadata indicating, from the start of the paragraph or other section, an offset corresponding to the number of characters at which the annotation begins and a length corresponding to the number of characters selected for the annotation.
- the system uses a content serialization engine (“CSE”) or other similar means to lock the page of the document to which the annotation relates, step 360.
- CSE content serialization engine
- this prevents multiple CSEs from accessing and updating the page at the same time.
- each CSE locks an individual page prior to updating the page to prevent other CSEs from accessing and simultaneously updating the page which would create problems such as content synchronization, etc.
- the CSE lock also prevents other users from requesting the page from the content server while the system is processing the user's submitted annotation and embedding a related indication in the page of the document.
- the system parses the metadata associated with the annotation, step 365. Using the length, offset, and other data provided with the metadata, the system determines a location in the document content at which to embed an indication corresponding to the annotation. The system then recreates the original page (including any additional pages created by the annotation) to embed an indication corresponding to the annotation, step 370, and updates the database with the new page, step 371. In some embodiments, the system replaces the old page stored in the database with the new page. In other embodiments, the old page is retained in order to track document versions and related annotations. The CSE lock is removed, step 372 and users at other clients are then able to request, retrieve, and view the new page containing the new indication corresponding to the new annotation. [0084] Fig. 5 A presents an exemplary sample of code for an XHTML formatted page of content containing an indication corresponding to an annotation which would be presented in the first portion of a display according to one embodiment of the invention.
- the code sample uses various XHTML elements such as Div elements, Span elements, Highlight elements, and Content elements to present the content and corresponding indication.
- Div element class shrdbk_main 373 is a div element that wraps the whole book text. In some embodiments, this element is used in a non-embedded mode to separate the indications or book items icons from the page text/content. Thus, a user would be able to toggle presentation of content both with and without indications being displayed. [0087] The system also uses a number of different types of Span elements. Span elements are tags generally used to group inline elements in a document. Span element shrdbk_start_element 374 is span element that is used as an indicator for the start location of the related text of the book item.
- the id attribute contains the type of the book item or indication ('C for comment, T for image, 'A' for audio and 'V for video), an identifier for the indication, and a starting location of this element in a numerical representation corresponding to a number of characters or other metric (e.g. _554).
- the indication identifier is used in varying embodiments to distinguish between indications and also to assist in content navigation, for example if a user wishes to jump to the next indication, etc.
- Span element shrdbk_end_element 375 is a span element that is used as an indicator for the end location of the related text of the book item or indicator.
- the id attribute contains the type of the book item, the book item id, and a location or offset of this element in a numerical representation (e.g. _681).
- Span element shrdbk_icons 376 is a span element that contains the image of the icon or indication to be embedded. For each location in the content, such as the book text, a different type of indication icon is used to represent each different type of annotation (e.g. - text annotation, multimedia annotation, etc.).
- the image element that is included for the indication represents the type of the items and the index number of the first item at this location, according to its appearance order within the book text.
- Highlights Div elements idYellow, idFirstLine, and idLastLine 377 are a set of div elements that are used for highlighting the related text corresponding to the annotation. For example, when a book item is selected, by clicking on its title, the text range that represents the related text is located according to the start and end span elements. Text rectangles are created from the given text range and these div elements positions are set according to the text rectangles.
- each shrdbk_icons span element there is also a corresponding div element, Content Div 378, which includes a representation of each of the item(s) that the span element contains for the specific location.
- This div element is generally displayed when the mouse cursor is over the image icon.
- the div element contains links for the related text of each of the book items and when clicking on those links the related text is highlighted.
- another role of those links is to synchronize the media area/first portion with the current viewed item.
- the media area automatically scrolls to the appropriate item in the second portion of the screen.
- Fig. 5B presents an exemplary sample of code for an XHTML formatted page of content containing an indication corresponding to an annotation which would be presented in the first portion of a display according to one embodiment of the invention.
- the code sample also uses various XHTML elements such as Div elements, Span elements, Highlight elements, and Content elements to present the content and corresponding indication. More specifically, the code sample provides exemplary span elements for presenting content in embedded and non-embedded modes.
- span elements 379 are used for displaying icons and other content in non-embedded mode.
- the element at the beginning of the paragraph is used as an anchor for the book item icon.
- the content element is placed in the bottom of the HTML document and includes the book item title as well as any relevant functionality.
- Span elements 380 are used for displaying icons and other content in embedded mode.
- the element within the paragraph is used as an anchor for the book item icon.
- the content element is similarly placed in the bottom of the HTML document and includes the book item title as well as any relevant functionality.
- Span elements 381 present exemplary uses of span elements as start and end anchors for highlighting selected or annotated content.
- Fig. 6 presents a flow chart of a method of annotating a visual element according to an embodiment of the present invention.
- users may wish to provide annotations corresponding to visual elements such as pictures or video clips.
- the user views a visual element, such as a picture, step 385, and selects a picture element to annotate, step 387.
- the user might use a selection tool to crop or otherwise select picture elements, for example, by drawing a box around or otherwise selecting a person in a photo.
- the system presents an annotation form or other input means, step 389, and the user inputs and submits the annotation, step 391.
- the system allows the user to submit multiple annotations for a single picture.
- control may return to step 387 for the user to select additional picture elements.
- the user may select a first element and input an annotation for the first element and then select a second element and input a second annotation for the second element, etc.
- the annotation(s) are then uploaded via the network to a content server and stored in a data store where they are associated with the visual element(s), step 393.
- the system also maintains and updates an index of annotations corresponding to visual elements, step 395. For example, users may provide annotations identifying subjects in visual elements and the system maintains an index of identified subjects cross-referenced with their corresponding visual elements.
- Fig. 6A presents a flow chart of a method of recreating a page of content according an embodiment of the invention.
- content generally comprises various XML tag elements corresponding to user selections and other content related to annotations.
- the CSE organizes elements into a list corresponding to their location on the page. If no further elements remain to be processed, control proceeds to step 408 and the routine ends. [0100] Otherwise, the system determines whether the next element in the list is associated with a content identifier, step 403. For example, in one embodiment, the system determines whether the element has a sharedbk XML tag identifier. If the element does not have an identifier, then it is generally not associated with an annotation and recreation of the element is generally not required and thus control passes to step 407 and the system proceeds to process the next element in the list.
- Fig. 6B presents a flow chart of a method of processing an element during page creation according to an embodiment of the invention.
- the system After the system determines that an element should be recreated (or in some embodiments originally created), the system orders all annotations associated with the element into a list according to their location, step 409. Thus, for a particular sentence, paragraph, page, etc. the system creates an ordered list of all annotations using the offsets and location metadata stored with the annotations. If no further annotations remain to be processed, control passes to step 417 and the routine exits.
- the system processes the location metadata associated with the annotation to determine the location in the first portion of the display to place an indication or icon corresponding to the annotation in the second portion of the display, step 411.
- the system processes the annotations in the list to determine whether there are multiple annotations associated with the same location, step 412. If there are multiple annotations, then the CSE creates the XHTML code or other code, inserting a multiple annotation indication or icon, step 413. If there are not multiple annotations, then the CSE creates the XHTML code or other code, inserting a single annotation indication or icon, step 414. For example, in some embodiments, certain indications indicate that they correspond only to a single annotation.
- An image indication corresponds to an image annotation
- an audio indication corresponds to an audio annotation
- the system embeds or otherwise places a multiple annotation indication which indicates that more than one annotation has been made at a particular place in the original content.
- the CSE also creates XHTML code or other code, generating a rollover action associated with the indication, step 415.
- the CSE engine retrieves metadata associated with the annotation(s) for a particular location and indication which lists a title for the annotation, the annotation's author(s), etc. The system then proceeds to process the next element, step 416 and control returns to step 410.
- Fig. 7 presents a flow chart of a method of providing a customized document related to a shared annotation system according to an embodiment of the present invention.
- a user may view a book on home repair in which the main document content of the book provides chapters on framing, wiring, plumbing, etc. Within each chapter, other users may have provided annotations related to various tasks described, etc.
- One user might indicate a particular brand of pipe that they found useful in completing a certain project or a particular type of light fixture well-suited to applications.
- Another user might provide additional photographs of their project with additional text comments, etc. to supplement the information of the original book.
- users may wish to view and wish to purchase or otherwise obtain customized documents, including these related annotations and other items such as tools required to complete certain projects, etc.
- a block diagram of a sample page 455 from a customized document according to an embodiment of the present invention is presented.
- the sample page 455 includes the document content 460 corresponding to the content of the document presented in the first portion of the display.
- the page 455 also includes annotations and other comments related to the document content 460 such as textual annotations 465, picture annotations 466, audio or video annotations 467, annotations related to discussion group content 468, advertisements 469, links to related merchandise 470, and other information.
- annotations and other comments related to the document content 460 such as textual annotations 465, picture annotations 466, audio or video annotations 467, annotations related to discussion group content 468, advertisements 469, links to related merchandise 470, and other information.
- this information could be presented in a variety of manners or layouts. For example, as shown in Fig.
- the document content 460 is centrally displayed and surrounded by related annotations including callouts to indications contained in the content 460 and other visual cues.
- the user selects a particular book edition, step 420.
- a user may select among a number of different books or documents containing content related to a desired subject or a user may only select certain chapters within a book. For example, a user may consult a home repair manual, but only be interested in the chapter on plumbing or on wiring and not wish to be provided with the entire book.
- the user also determines and selects annotations they wish provided with their customized document/book, step 425.
- a user may wish to be provided with all annotations related to the desired content, only annotations authored by an arbitrary/particular user, only a specific annotation containing certain information the user finds useful, such as supplemental photos, video, other types of annotations, etc.
- the system also offers the user a promotion or other offer associated with the content and the user determines whether or not to accept the promotion, step 430.
- a user purchasing a home repair manual chapter related to dry walling might also be presented with the option to purchase items and merchandise related to the project such as hammers, nails, screws, plaster, tape, drywall, or even other books or information related to the project.
- the system may also offer a video of how to complete a sample project for an additional premium.
- Fig. 8A presents a screenshot of an exemplary article page of a memory book according to an embodiment of the present invention.
- a memory book generally comprises a customized printout of content and related annotations. In some embodiments, memory books are compiled and bound according to user preferences.
- users create a memory book by customizing existing content provided by content creators.
- a content provider might use the system to post an original article to the Web containing text, photos, and other multimedia elements recounting or otherwise related to an event such as a Harley Davidson rally or a Britney Spears concert.
- the original article also generally contains indications and corresponding annotations input by various users responding to the original article.
- a user can then create any number of custom memory books from the original article by uploading additional multimedia elements and selecting specific annotations to include in their personal memory book.
- a user attending the Harley Davidson rally can create a memory book containing photos, annotations, and other elements related to that user's own personal experience at the Harley Davidson rally.
- a user attending the Britney Spears concert creates a memory book related to their own personal concert experience with their own photos from before the show, after the show, photos from during the show, related annotations, the user's own textual inputs, etc.
- a user who went to the Harley Davidson rally uploads their own pictures taken at the rally to replace or supplement the pictures in the original article posted by the content provider.
- a user also uses pictures posted as annotations by other users to replace or supplement pictures of the original article or they use additional pictures provided by the content provider or other content providers.
- Users also select custom annotations to include with the memory book by filtering or otherwise selecting annotations from the set of annotations posted by other users regarding the original article.
- a user automatically selects annotation from a list of friends who post annotations.
- users select annotations individually or based on criteria such as ratings from other users, annotation type, etc.
- a user creates their own personal memory book from the original article.
- the personal memory book generally contains the text and other content of the original article including additional pictures, text, videos, and related annotations selected or otherwise input by the user.
- the user then has the option to print out the memory book and have it bound or otherwise preserved, for example as a souvenir.
- An article page of a memory book generally includes article text of the original content along with embedded photos with captions, embedded indications, and other items as further described herein.
- the presentation of the article page is formatted as closely as possible to the view a user would be presented with online. In some embodiments, however, the pagination is different since the content is now being produced on a printed page as opposed to on a display.
- the article page includes one or more of the following: a header 471, embedded images 472, image captions 473, embedded icons or indications 474, and a footer 475.
- the header 471 generally remains consistent across pages throughout a memory book, thus unifying content presentation, etc.
- the header includes a graphic, such as a logo, and heading text which may be used by the system to create a table of contents, an index, etc.
- Embedded images 472 include images originally presented in the original content as well as images selected by a user for inclusion in the memory book.
- images 472 also contain an image caption 473 which may include the poster's username, the date the photo was posted, a title for the image 472, etc.
- Embedded icons or indications 474 generally appear in the same location of the content as they do when presented in a display. In some embodiments, however, icons 474 are renumbered for each individual page (e.g. - starting from 1 for the first indication 474 on each page) and thus the numbering scheme for indications 474 may differ from the online version of the book.
- the article page also contains a footer 475 containing the book's title, page number, publisher information, etc.
- Fig. 8B presents a screenshot of an exemplary comments page of a memory book according to an embodiment of the present invention.
- the comments page of a memory book generally includes comments and other annotations input by users online and generally is included on one or more separate pages falling after the article page as opposed to on the same page as the article text itself.
- the article comments page includes one or more of the following: a header 476, a sub-header 477, a comment or reply icon 478, a comment title 479, a username and date of post 480, a comment text or other annotation content 481, one or more replies 482, and comments by various types of members 483.
- the header 476 of the article comments page is generally a graphic and corresponds to the header of the article page of the memory book.
- Sub-headers 477 indicate the printed page in the memory book which contains the article to which the annotations are related.
- Comments or reply icons 478 are generally graphics indicating a type of comment. For example, a text comment might have a balloon with text in it as an icon 478 and an audio comment might have a musical note as an icon 478.
- Comment titles 479 indicate any heading a user inputs to associate with their comment.
- comment titles are printed in different colors according to the type of user. For example, comments by regular members might be printed in black, comments by moderators 482 in red, etc.
- comment text 481 is also displayed in varying colors according to user types.
- a username and date of post 480 are also displayed for each annotation. Replies 482 associated with comments may also be presented.
- Fig. 8C presents a screenshot of an exemplary dynamic print page according to an embodiment of the invention.
- Dynamic print pages are generally formatted to include comments and other annotations just below the text to which they refer.
- the page includes the original text 484 including inline indications corresponding to the first portion of the display.
- the page also includes annotations such as text comments, images, etc. as would be presented online in the second portion of the display.
- Fig. 9 shows a method of presenting a selected multimedia element while navigating a document in shared annotation system according to an embodiment of the present invention.
- a multimedia element such as a chart, a table, a picture, etc.
- a user viewing several pages of a document related to a particular company's financial outlook might find it useful to retain a chart of the stock price or a table of pro forma income projections from one page while viewing information on a second page.
- the system achieves the goal by allowing users to select a multimedia element and then floating the selected element on top of or integrating the selected element with subsequent pages that are viewed.
- the user selects a multimedia element in a first page, such as a picture, using various input means previously described herein, step 495.
- the selected element is identified in the content database, step 500, and floated or otherwise displayed in the browser window, step 505.
- the user client communicates the selected element identifier to the content server which retrieves another instance of the element and floats the element in the browser window containing the original content or displays the selected element in a new window or frame.
- the system recreates the first page, removing the selected element and floats or otherwise displays the selected element over the location in the content where the selected element previously resided.
- the system does not immediately float or otherwise display the selected element, but instead only identifies the selected element and only floats the selected element when the system receives input to navigate to a second page, step 510.
- the system retrieves the original version of the second page stored in the database, step 515, and creates a new second page to display by modifying the second page and embedding the selected element from the first page, step 520. The modified second page is then presented with the original second page content now including the selected element, step 525.
- Systems and modules described herein may comprise 'software, firmware, hardware, or any combination(s) of software, firmware, or hardware suitable for the purposes described herein.
- Software and other modules may reside on servers, workstations, personal computers, computerized tablets, PDAs, and other devices suitable for the purposes described herein. Software and other modules may be accessible via local memory, via a network, via a browser or other application in an ASP context, or via other means suitable for the purposes described herein.
- Data structures described herein may comprise computer files, variables, programming arrays, programming structures, or any electronic information storage schemes or methods, or any combinations thereof, suitable for the purposes described herein.
- User interface elements described herein may comprise elements from graphical user interfaces, command line interfaces, and other interfaces suitable for the purposes described herein. Screenshots presented and described herein can be displayed differently as known in the art to input, access, change, manipulate, modify, alter, and work with information.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Business, Economics & Management (AREA)
- Physics & Mathematics (AREA)
- Entrepreneurship & Innovation (AREA)
- Human Resources & Organizations (AREA)
- Strategic Management (AREA)
- General Physics & Mathematics (AREA)
- General Business, Economics & Management (AREA)
- Health & Medical Sciences (AREA)
- Tourism & Hospitality (AREA)
- Operations Research (AREA)
- Marketing (AREA)
- Economics (AREA)
- Data Mining & Analysis (AREA)
- Quality & Reliability (AREA)
- Artificial Intelligence (AREA)
- Audiology, Speech & Language Pathology (AREA)
- Computational Linguistics (AREA)
- General Health & Medical Sciences (AREA)
- General Engineering & Computer Science (AREA)
- Document Processing Apparatus (AREA)
- Information Transfer Between Computers (AREA)
- User Interface Of Digital Computer (AREA)
Abstract
Applications Claiming Priority (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/936,788 US20070118794A1 (en) | 2004-09-08 | 2004-09-08 | Shared annotation system and method |
US11/099,817 US7506246B2 (en) | 2004-09-08 | 2005-04-06 | Printing a custom online book and creating groups of annotations made by various users using annotation identifiers before the printing |
US11/099,768 US20060053364A1 (en) | 2004-09-08 | 2005-04-06 | System and method for arbitrary annotation of web pages copyright notice |
PCT/US2005/031966 WO2006029259A2 (fr) | 2004-09-08 | 2005-09-07 | Systeme d'annotation partage et son procede |
Publications (2)
Publication Number | Publication Date |
---|---|
EP1800222A2 EP1800222A2 (fr) | 2007-06-27 |
EP1800222A4 true EP1800222A4 (fr) | 2009-08-05 |
Family
ID=36036997
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP05794986A Withdrawn EP1800222A4 (fr) | 2004-09-08 | 2005-09-07 | Systeme d'annotation partage et son procede |
Country Status (2)
Country | Link |
---|---|
EP (1) | EP1800222A4 (fr) |
WO (1) | WO2006029259A2 (fr) |
Families Citing this family (35)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7707039B2 (en) | 2004-02-15 | 2010-04-27 | Exbiblio B.V. | Automatic modification of web pages |
US8442331B2 (en) | 2004-02-15 | 2013-05-14 | Google Inc. | Capturing text from rendered documents using supplemental information |
US20060041484A1 (en) | 2004-04-01 | 2006-02-23 | King Martin T | Methods and systems for initiating application processes by data capture from rendered documents |
US7812860B2 (en) | 2004-04-01 | 2010-10-12 | Exbiblio B.V. | Handheld device for capturing text from both a document printed on paper and a document displayed on a dynamic display device |
US10635723B2 (en) | 2004-02-15 | 2020-04-28 | Google Llc | Search engines and systems with handheld document data capture devices |
US8621349B2 (en) | 2004-04-01 | 2013-12-31 | Google Inc. | Publishing techniques for adding value to a rendered document |
US8146156B2 (en) | 2004-04-01 | 2012-03-27 | Google Inc. | Archive of text captures from rendered documents |
US20060098900A1 (en) | 2004-09-27 | 2006-05-11 | King Martin T | Secure data gathering from rendered documents |
WO2008028674A2 (fr) | 2006-09-08 | 2008-03-13 | Exbiblio B.V. | Scanners optiques, tels que des scanners optiques portables |
US8793162B2 (en) | 2004-04-01 | 2014-07-29 | Google Inc. | Adding information or functionality to a rendered document via association with an electronic counterpart |
US7894670B2 (en) | 2004-04-01 | 2011-02-22 | Exbiblio B.V. | Triggering actions in response to optically or acoustically capturing keywords from a rendered document |
US20060081714A1 (en) | 2004-08-23 | 2006-04-20 | King Martin T | Portable scanning device |
US9143638B2 (en) | 2004-04-01 | 2015-09-22 | Google Inc. | Data capture from rendered documents using handheld device |
US7990556B2 (en) | 2004-12-03 | 2011-08-02 | Google Inc. | Association of a portable scanner with input/output and storage devices |
US9116890B2 (en) | 2004-04-01 | 2015-08-25 | Google Inc. | Triggering actions in response to optically or acoustically capturing keywords from a rendered document |
US20080313172A1 (en) | 2004-12-03 | 2008-12-18 | King Martin T | Determining actions involving captured information and electronic content associated with rendered documents |
US20070300142A1 (en) | 2005-04-01 | 2007-12-27 | King Martin T | Contextual dynamic advertising based upon captured rendered text |
US8713418B2 (en) | 2004-04-12 | 2014-04-29 | Google Inc. | Adding value to a rendered document |
US9460346B2 (en) | 2004-04-19 | 2016-10-04 | Google Inc. | Handheld device for capturing text from both a document printed on paper and a document displayed on a dynamic display device |
US8489624B2 (en) | 2004-05-17 | 2013-07-16 | Google, Inc. | Processing techniques for text capture from a rendered document |
US8620083B2 (en) | 2004-12-03 | 2013-12-31 | Google Inc. | Method and system for character recognition |
US8874504B2 (en) | 2004-12-03 | 2014-10-28 | Google Inc. | Processing techniques for visual capture data from a rendered document |
US8346620B2 (en) | 2004-07-19 | 2013-01-01 | Google Inc. | Automatic modification of web pages |
US20100278453A1 (en) * | 2006-09-15 | 2010-11-04 | King Martin T | Capture and display of annotations in paper and electronic documents |
US7975215B2 (en) | 2007-05-14 | 2011-07-05 | Microsoft Corporation | Sharing editable ink annotated images with annotation-unaware applications |
WO2010096193A2 (fr) | 2009-02-18 | 2010-08-26 | Exbiblio B.V. | Identification d'un document en effectuant une analyse spectrale des contenus du document |
US8447066B2 (en) | 2009-03-12 | 2013-05-21 | Google Inc. | Performing actions based on capturing information from rendered documents, such as documents under copyright |
WO2010105246A2 (fr) | 2009-03-12 | 2010-09-16 | Exbiblio B.V. | Accès à des ressources fondé sur la capture d'informations issues d'un document restitué |
US9081799B2 (en) | 2009-12-04 | 2015-07-14 | Google Inc. | Using gestalt information to identify locations in printed information |
US9323784B2 (en) | 2009-12-09 | 2016-04-26 | Google Inc. | Image search using text-based elements within the contents of images |
CN102346731B (zh) | 2010-08-02 | 2014-09-03 | 联想(北京)有限公司 | 一种文件处理方法及文件处理装置 |
US8977952B2 (en) * | 2011-11-07 | 2015-03-10 | Thomson Reuters Global Resources | Electronic book version and annotation maintenance |
CN105706408A (zh) * | 2013-07-03 | 2016-06-22 | 瑞典爱立信有限公司 | 提供电子书到用户设备 |
US9680697B2 (en) | 2013-12-17 | 2017-06-13 | International Business Machines Corporation | Dynamic product installation based on user feedback |
CN113867867A (zh) * | 2021-09-28 | 2021-12-31 | 北京达佳互联信息技术有限公司 | 界面处理方法、装置、电子设备及计算机可读存储介质 |
Family Cites Families (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5202828A (en) * | 1991-05-15 | 1993-04-13 | Apple Computer, Inc. | User interface system having programmable user interface elements |
US6081829A (en) * | 1996-01-31 | 2000-06-27 | Silicon Graphics, Inc. | General purpose web annotations without modifying browser |
JP3085245B2 (ja) * | 1997-05-14 | 2000-09-04 | 日本電気株式会社 | 文書管理方法及び文書管理システム並びにプログラムを記録した機械読み取り可能な記録媒体 |
US6687878B1 (en) * | 1999-03-15 | 2004-02-03 | Real Time Image Ltd. | Synchronizing/updating local client notes with annotations previously made by other clients in a notes database |
US6507865B1 (en) * | 1999-08-30 | 2003-01-14 | Zaplet, Inc. | Method and system for group content collaboration |
US6859909B1 (en) * | 2000-03-07 | 2005-02-22 | Microsoft Corporation | System and method for annotating web-based documents |
US20020026398A1 (en) * | 2000-08-24 | 2002-02-28 | Sheth Beerud D. | Storefront for an electronic marketplace for services |
-
2005
- 2005-09-07 WO PCT/US2005/031966 patent/WO2006029259A2/fr active Application Filing
- 2005-09-07 EP EP05794986A patent/EP1800222A4/fr not_active Withdrawn
Non-Patent Citations (1)
Title |
---|
No further relevant documents disclosed * |
Also Published As
Publication number | Publication date |
---|---|
EP1800222A2 (fr) | 2007-06-27 |
WO2006029259A3 (fr) | 2006-10-26 |
WO2006029259A2 (fr) | 2006-03-16 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7506246B2 (en) | Printing a custom online book and creating groups of annotations made by various users using annotation identifiers before the printing | |
WO2006029259A2 (fr) | Systeme d'annotation partage et son procede | |
JP6095596B2 (ja) | 補足情報コンテンツを伴う文書目視欄の描出 | |
US10853560B2 (en) | Providing annotations of a digital work | |
CA2594573C (fr) | Procede et systeme de distribution d'annotations relatives a une oeuvre numerique | |
US10346525B2 (en) | Electronic newspaper | |
US9275021B2 (en) | System and method for providing a two-part graphic design and interactive document application | |
US9372835B2 (en) | System and method for presentation creation | |
US20180165255A1 (en) | System and method to facilitate content distribution | |
US20040123244A1 (en) | Webpage generation tool and methtod | |
US20080092054A1 (en) | Method and system for displaying photos, videos, rss and other media content in full-screen immersive view and grid-view using a browser feature | |
US20130117665A1 (en) | System and method for individualized media publishing | |
US20020029236A1 (en) | Method and apparatus for processing scientific posters | |
KR100955750B1 (ko) | 문서 컨텐트의 복수 렌디션을 제공하는 시스템 및 방법 | |
KR100496981B1 (ko) | Xml을 이용한 pdf 문서 제공 방법 | |
JP2011103035A (ja) | 書込情報管理システム、書込情報管理方法及び書込情報管理プログラム | |
JP2005208768A (ja) | イメージページ作成支援装置 | |
WO2001052032A1 (fr) | Procede et appareil permettant l'affichage, le reperage, le classement et l'organisation de donnees et d'images de differents types |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PUAI | Public reference made under article 153(3) epc to a published international application that has entered the european phase |
Free format text: ORIGINAL CODE: 0009012 |
|
17P | Request for examination filed |
Effective date: 20070405 |
|
AK | Designated contracting states |
Kind code of ref document: A2 Designated state(s): AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IS IT LI LT LU LV MC NL PL PT RO SE SI SK TR |
|
DAX | Request for extension of the european patent (deleted) | ||
A4 | Supplementary search report drawn up and despatched |
Effective date: 20090703 |
|
RIC1 | Information provided on ipc code assigned before grant |
Ipc: G06F 17/21 20060101ALI20090629BHEP Ipc: G06F 17/24 20060101AFI20060725BHEP Ipc: G06Q 10/00 20060101ALI20090629BHEP |
|
17Q | First examination report despatched |
Effective date: 20160308 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: THE APPLICATION IS DEEMED TO BE WITHDRAWN |
|
18D | Application deemed to be withdrawn |
Effective date: 20160920 |