Method and system for capturing, storing, sharing, and managing notes taken during a computer based meeting
A method and system for capturing and managing electronic notes in a computer based application is presented. Electronic notes are captured in a note object and the context of the captured note is associated to the note object. Note objects are stored in a notes database for later retrieval. The notes can be queried, filtered, and sorted to obtain useful information from the notes.
Latest Hewlett Packard Patents:
The present invention pertains generally to computer-based meeting applications, and more particularly to a method and system for capturing, storing, sharing, and managing electronic notes generated in a computer based application.
BACKGROUND OF THE INVENTIONComputer based collaboration tools, which allow two or more remotely located users to simultaneously view data and communicate over a computer network, allow remotely located users to conduct online meetings. Just as in face-to-face meetings, the ability to take notes is important in online meetings for the purpose of capturing the events, issues, action items, and decisions made during the meeting. In the past, notes taken by participants of an online meeting are typically taken individually by the various meeting participants and then distributed via paper memos or email. The current computer-based note-taking capabilities are problematic for several reasons.
First, current solutions often do not capture enough context to understand the note (e.g., the issue or decision made during the online meeting). This is due in part to the fact that notes are often limited to text, missing important graphical information about what was being discussed (such as the state of the computer display) at the time the note was taken.
A further problem with current note-taking solutions is that captured notes are usually unmanaged, meaning that there is no way to query the system for decisions made at a meeting or about a particular subject or for action items assigned to specific people. It is often difficult to track the status of notes, such as the status of actions items.
Yet a further problem is that different participants take notes that often disagree with each other. This is especially true in the case where each participants' notes cannot be easily displayed to the other participants.
Accordingly, an improved online note-taking technique is needed that supports the capture, storage, sharing, management of, and extraction of information from notes generated during an online meeting.
SUMMARY OF THE INVENTIONThe present invention is a method and system for capturing, storing, sharing and managing notes in a computer based software application. In particular, the invention is directed to collaborative online meeting environments, but may also be used in stand-alone computer applications which require note-taking and note-management capability.
In accordance with the invention, electronic notes are captured, preferably along with the creation time, author, and appropriate context information. For example, the topic under discussion and the current state of the display screen may also be captured and associated with the note. The context associated with the captured note thereby allows a user to more fully understand the meaning of the note when the note is retrieved at a later time.
The invention also allows users to categorize notes according to type (e.g., General, Action Item, Issue, Decision) and to query on specific note attributes (e.g., creation time, author, etc.) to retrieve information from the notes more quickly. The system also provides a mechanism for updating the status of the notes, thereby allowing users to see the current state of an issue or action item as well as the state at the time the note was created.
The system can be used in stand-alone environments as well as collaboration environments with multiple online meeting participants to capture, store, share, and manage notes.
In accordance with the invention, the system comprises a capture module, a storage module, a retrieval module, and a management module. The capture module provides the capability for capturing the note along with note-specific information and the state of the display screen.
The storage module provides the capability for storing captured information in persistent storage for later recall. The persistent storage module can be implemented in various ways, for example with a relational database or a document management system.
The retrieval module retrieves information from the persistent storage module and displays the results to the user. This module allows the user to specify the type of information to be retrieved.
The management module allows a user to update the status of the note, and with the appropriate permissions, modify the contents of and/or delete notes.
The invention will be better understood from a reading of the following detailed description taken in conjunction with the drawing in which like reference designators are used to designate like elements, and in which:
The Note Data 14 attribute contains data captured by the note (i.e., the actual note content), such as ASCII text, image data, audio data, and other object data. The data contained in the Note Data 14 attribute is not interpreted by the Notes Service 20.
Add Note 22a captures a note and adds it to a notes list managed by the Notes Service 20 for a particular application session. In the illustrative embodiment, the note is broadcast as an XML string, where the attributes are encoded in the XML. The Note ID 12a is an XML string which is used to refer to the note object 10 when subsequently accessing the note.
Delete Note 22b deletes a specified note object 10 (including all note-descriptive attributes 12 and note data 14) from the notes list associated with a particular application session.
Add Attributes 22c allows a list of attributes to be added to an existing note object 10. These attributes can either add new attributes for a note object 10 or modify existing note attributes.
Delete Attributes 22d deletes specified attributes from the list of attributes of a note object 10 associated with a Note ID 12a.
Get Note Attribute 22e returns the list of attributes associated with a specified note object 10.
Lock Note 22f locks a note object 10 so that it cannot be modified except by the client who issued the lock to provide access control of the note while in a session. Unlock Note 22g allows the client who issued the lock (or others with appropriate permission) to unlock a note object 10 to allow modifications to the note object 10.
List Notes 22h returns a list of notes, with their associated attributes, that are associated with a particular application session. In the illustrative embodiment, List Notes 22h returns the list of notes including note-descriptive attributes 12 and note data 14 as a series of XML descriptions that are wrapped in start and end tags so that clients can detect the end of the list.
Add Note Data 22i adds data to the note data 14 attribute of a specified note object 10. The note data 14 is a stream of bytes and is not interpreted by the Notes Service 20; however, the proper note-descriptive attributes 12 are set on the note to describe the data.
Delete Note Data 22j deletes the note data 14 associated with a specified note object 10.
Get Note Data 22k returns the note data 14 associated with a specified note object 10. The Note ID 12a is sent to the Notes Services 20 server, and the Note Data 14 associated with the note object 10 identified by the Note ID 12a is returned to the requesting client 15a, . . . , 15n. The requesting client 15a, . . . , 15n will preferably know the type of data (by querying the note object 10 attributes 12 (such as Note Type 12b). Accordingly, in the illustrative embodiment, only the byte stream of data is returned.
Display Note 22l causes the details of a specified note to be displayed, for example in a pop-up window. In a collaboration environment, Display Note 22l communicates to all connected clients 15a, . . . , 15n in a given session to display the details of a specific note object 10 in a display window.
Storage module 24 provides the capability for storing captured notes and associated context information in the Notes Database 30 (i.e., persistent storage) for later recall. Notes Database 30 can be implemented in various ways, for example as a relational database or a document management system such as WorkManager, developed by CoCreate Software, Inc.
Retrieval module 26 provides the capability for retrieving information from Notes Database 30. Retrieval module 26 allows the user to specify the type of information to be retrieved using queries, filters and sorts.
Management module 28 allows a user to administer the Notes Database 30. In particular, management module 28 allows a user to modify, delete, and update the status of a note object 10. The updating of a note object 10 can either be accomplished using a versioning algorithm or by modifying the attributes of a given note.
Application 15 typically accesses a data source 16 containing information on which the application operates. For example, application 15 may be a collaboration application such as OneSpace, developed by CoCreate Software, Inc., used to display 3-D models of engineering parts that are stored in a parts database data source. As another example, application 15 may be a personal organizer application storing calendar and contact information in a personal information data source file.
The create note dialog 120 includes user capabilities to set the attributes of a note. In particular, the create note dialog 120 allows the user to select the type of note to be created. In the illustrative embodiment, the type of note is selectable via a drop-down menu 121, which allows the user to set the note type to one of either a General Note 121a, an Action Item 121b, a Decision 121c, or an Issue 121d. Each note type has a set of note type specific attributes which are displayed in the create note dialog 120 upon selection of the note type by the user. The note type specific attributes include a different set of attributes for each note type. For example, the General Note 121a type may display only the standard editable Author attribute 122 and Creation Time attribute 123. These attributes may be filled in by the author of the note, or alternatively may be filled in automatically (with overwrite capability) by the Notes Service 20 using user configuration information. If instead the Action Item type 121b is selected, for example, additional editable attributes including an Assigned To attribute 141, a Due Date attribute 142, and a Status attribute 143 (see
In each note type, a content field 124 is displayed. The content field 124 may be filled in by the user and/or a file may be attached to the note via an Attach dialog (not shown) accessed by clicking on an Attach button 125.
In the illustrative embodiment, the create note dialog 120 includes a Link button 126 which allows the user to link the note object to another object (preferably of any type, for example, a 3-D data file, a web-site URL, an audio or video file, a text document, etc.) to create a relation. The links associated with the object note are displayed in a Links display panel 124b. In the illustrative embodiment, the Notes Service 20 may automatically create a note and link it to an object used by the client application 15 whenever the object used by the client application 15 is modified. For example, if the client application 15 is a CAD application that creates or utilizes 3-D models of objects, the Notes Service 20 may be configured to automatically generate a note object whenever the 3-D object model is modified, recording the author of the modification and the modification date. A pop-up dialog may prompt the user for a description of the changes made to the 3-D model. User created and automatically created note objects may be stored in separate areas of the Notes database 30 and displayed separately, or may be stored and displayed together, depending on the particular implementation. Preferably, the create note dialog 120 also includes a Save Screen checkbox option 126b that allows the user the option of saving the state of the current screen for later viewing to provide context for the current note.
A New button 127 allows a user to create a new note without popping down the current Create Note dialog 120. A Subnote button 128 allows the user to create a subnote to the currently active note, thereby allowing the creation of hierarchical relationships between note objects.
Cancel button 129 allows a user to cancel the current note prior to being stored in the Notes Service 20. If the Cancel button 129 is activated, the currently active note object is discarded—that is, the memory occupied by the currently active note object is freed and it is not saved in persistent storage.
Display notes dialog 130 allows the user to sort the displayed notes according to various criteria. For example, clicking on the Creation Time header 132c sorts the notes in order of Creation Time. Clicking on the Author header 132d sorts the notes in terms of Author names in alphabetical order. The other headers may be clicked on to similarly sort the notes in terms of the contents of their respective columns. Notes may also be sorted according to criteria specified in a sort dialog (not shown) accessed by clicking on a Sort button 133a.
Display notes dialog 130 may also include filtering capabilities, such as the ability to filter note objects based on a date range for the Creation Time attribute or Last Modified attribute. Filtering capabilities may be configured in a Filter dialog (not shown) accessed by clicking on a Filter button 133b.
In the illustrative embodiment, if a note in the Notes Table 135 is double-clicked, or if the note in the Notes Table 135 is selected and then a Detail button 133c is clicked, a Note Detail window 140 pops up, illustrated in
Turning back to
In a collaborative environment, notes are public information; when a note object is created, all participant members of the same collaboration session see the note. Likewise, when a note is displayed or a query run, all participant members see the displayed note or query results.
Notes can be related to other objects within a collaboration session, such as CAD geometry (parts, edges, faces, features, assemblies), other notes, a screenshot (static 2D image), or other objects such as markups, documents, and even to objects outside of the application 10.
The Links List field of each note contains a pointer to a linked list of associated note links. Alternatively, the links associated with various notes are implemented in a separate Links table, illustrated in
Although the invention has been described in terms of the illustrative embodiments, it will be appreciated by those skilled in the art that various changes and modifications may be made to the illustrative embodiments without departing from the spirit or scope of the invention. It is intended that the scope of the invention not be limited in any way to the illustrative embodiment shown and described but that the invention be limited only by the claims appended hereto.
Claims
1. A notes service for a computer aided design (CAD) application stored on a memory, comprising:
- a note creation module which captures an electronic note associated with a change in a three-dimensional model of said CAD application;
- a note storage module which stores said captured note and an associated data file for later retrieval; and
- a note retrieval module for retrieving and displaying said captured note with a display screen of said three-dimensional model, that existed when said note was generated, using said associated data file.
2. The notes service of claim 1, wherein said note retrieval module receives a query condition and retrieves said captured note and associated data file if said note meets said query condition.
3. The notes service of claim 1, comprising:
- a note management module which enables a user to modify a captured note.
4. The notes service of claim 1, comprising:
- a collaboration function which allows a plurality of collaboration session members to synchronously view a graphical user interface of said notes service.
5. A method for capturing and managing electronic notes in a computer aided design (CAD) based application, comprising:
- capturing a note in a note object;
- associating a data file with said captured note, wherein said data file is used to generate a display of a three-dimensional model of said CAD application that existed when said note was captured;
- storing said note object and said associated data file in persistent storage for later retrieval;
- receiving a query condition; and
- retrieving said note object and said associated data file if attributes of said note object meet said query condition.
6. The method of claim 5, comprising:
- displaying said note captured in said note object.
7. The method of claim 6, comprising:
- presenting said display of said three-dimensional model using said data file.
8. The method of claim 5, comprising:
- capturing a second note and linking said second captured note to said captured note in an hierarchical relationship.
9. The method of claim 5, comprising:
- connecting to a collaboration session; and
- synchronously displaying a notes service graphical user interface to all members connected to said collaboration session.
10. The method of claim 9, comprising:
- locking said note to prevent other members of said collaboration session from changing said note.
11. A computer readable storage medium tangibly embodying program instructions implementing a method for capturing and managing electronic notes in a computer based application the method comprising the steps of:
- capturing a note in a note object;
- associating a data file with said captured note, wherein said data file is used to generate a display of a three-dimensional model of said CAD application that existed at the time the note was captured;
- receiving a query condition; and
- retrieving said note object and said associated data file if attributes of said note object meet said query condition.
12. The computer readable storage medium of claim 11, the method comprising:
- storing said note object and said associated data file in persistent storage for later retrieval.
13. The computer readable storage medium of claim 11, the method comprising:
- displaying said note captured in said note object.
14. The computer readable storage medium of claim 11, the method comprising:
- presenting said display of said three-dimensional model using said data file.
15. The computer readable storage medium of claim 11, the method comprising:
- capturing a second note and linking said second captured note to said captured note in an hierarchical relationship.
16. The computer readable storage medium of claim 11, the method comprising:
- connecting to a collaboration session; and
- synchronously displaying a notes service graphical user interface to all members connected to said collaboration session.
17. The computer readable storage medium of claim 16, the method comprising:
- locking said note to prevent other members of said collaboration session from changing said note.
6342906 | January 29, 2002 | Kumar et al. |
6487569 | November 26, 2002 | Lui et al. |
6564246 | May 13, 2003 | Varma et al. |
6594693 | July 15, 2003 | Borwankar |
6654032 | November 25, 2003 | Zhu et al. |
20020032592 | March 14, 2002 | Krasnick et al. |
20030167281 | September 4, 2003 | Cohen et al. |
20070208669 | September 6, 2007 | Rivette et al. |
20080046417 | February 21, 2008 | Jeffery et al. |
- Conference Papers in English, Ana Sayfaya Donus, pp. 1-4□□http://www3.itu.edu.tr/˜nerdogan/yabbil.html.
- Conference Papers, pp. 1-7, http://www.cmpe.boun.edu.tr/˜akin/bildiri.html.
- Adobe Press Office; Adobe Acrobat 4.0 Software Bridges the Gaps in Today's Office Documentation Workflows; Adobe System UK; Feb. 16, 1999; pp. 1-4.
- Akin, M., “Nasneye Yonelik Tasarim Desenleri ve Uygulamalari,” Istanbul Taknik Universitesi, FBE, 2000; “Using Object Oriented Design Patterns to Develop and Interactive Command System for a CAD Software with Undo and Redo Support,” Proc. 15th International Symp. on Computer and Information Sciences (ISCIS XV), Istanbul, Turkey; 2000, pp. 410-417.
Type: Grant
Filed: Oct 13, 2000
Date of Patent: Jun 24, 2008
Assignee: Hewlett-Packard Development Company, L.P. (Houston, TX)
Inventors: Daniel Garfinkel (Fort Collins, CO), James Cooke (Fort Collins, CO), Maureen Gillis (Fort Collins, CO), Hugh-John Flemming (Fort Collins, CO), John Christopher Dale (Fort Collins, CO)
Primary Examiner: Stephen Hong
Assistant Examiner: Matthew J Ludwig
Application Number: 09/687,774
International Classification: G06F 17/00 (20060101);