The present invention relates to systems, methods and computer program products containing instructions for assigning visual characteristics to records of data structures such as databases and emails. Records of data structures may have attributes with values. For example, emails may have values associated with various attributes, such as “Date,” “Sender” and “Subject.” It may be desirable to treat records having attribute values that correspond to each other (e.g. all emails sent from “richard@xyz.com”) similarly. In such a scenario, the records may be sorted by values of a selected attribute so that records having corresponding attribute values are grouped together visually. Once sorted, records having corresponding attribute values may be acted upon (e.g., deleted or moved to a particular logical location) together.
A user may wish to isolate records having a particular attribute value, which may require the user to sort the records and then visually scan the records closely to determine where records having one attribute value stop and records having a different attribute value start. However, when a data structure has hundreds or even thousands of records, the user may be more likely to make mistakes in identifying corresponding records, and identifying groups of like records may become cumbersome where all the records look similar and there is little to no visual indication separating groups of like records.
Systems, methods and computer program products containing instructions for assigning visual characteristics to records are disclosed herein. Records of a data structure may be sorted by values of a selected attribute of the records. A first set of records having values of the selected attribute that correspond to a first value may be identified. A second set of records having values of the selected attribute that correspond to a second value may also be identified. A first visual characteristic may be automatically assigned to each record of the first set of records, and a second visual characteristic, that is different from the first visual characteristic, may be automatically assigned to each record of the second set of records.
As will be appreciated by one skilled in the art, aspects of the present invention may be embodied as a system, method or computer program product. Accordingly, aspects of the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit.” “module” or “system.” Furthermore, aspects of the present invention may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied thereon.
Any combination of one or more computer readable medium(s) may be utilized. The computer readable medium may be a computer readable signal medium or a computer readable storage medium. A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.
Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
Computer program code for carrying out operations for aspects of the present invention may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
Aspects of the present invention are described below with reference to flowchart illustrations and/or cluster diagrams of methods, apparatus (systems) and computer program products according to embodiments of the invention. It will be understood that each cluster of the flowchart illustrations and/or cluster diagrams, and combinations of clusters in the flowchart illustrations and/or cluster-diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or cluster diagram cluster or clusters.
These computer program instructions may also be stored in a computer readable medium that can direct computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or cluster diagram cluster or clusters.
The computer program instructions may also be loaded onto a computer; other programmable data processing apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatus or ether devices to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or cluster diagram cluster or clusters.
Referring to
As noted above, systems, methods and computer program products are disclosed herein for assigning visual characteristics to records of a data structure. A data structure may be any series of data records, including a database, emails, text messages, employee records and so forth.
Referring now to
Referring back to the exemplary method of
In step 104, a first set of records having values of the selected attribute that correspond to a first value are identified. The first value may be the value of the selected attribute for the first record (after sorting). As used herein, a record has an attribute with a value that “corresponds to” another value where the values meet some relationship criteria. Exemplary relationship criteria may include equality (i.e., two records having identical attribute values), but also may be more flexible. For example, if a first value is a subset of a second value (e.g., “trip this weekend” is a subset of “RE: trip this weekend”), then the first value may be considered to “correspond to” the second value. The level of similarity required for values to match may be configured by the user.
In step 106, similar to step 104, a second set of records having values of the selected attribute that correspond to a second value are identified. The second value typically will be different than the first value, and in any event, values that correspond to the first value do not correspond to the second value.
In step 108, a first visual characteristic is automatically assigned to each record of the first set of records. “Visual characteristics” that may be assigned to records may include color (e.g., the text of the record or the record's background may be assigned a color), font (e.g., text of each record in a particular set may rendered in a particular font), outline of the records, and so forth.
In step 110, a second visual characteristic is automatically assigned to each record of the second set of records. The visual characteristic assigned to each record of the second set of records is different than the first visual characteristic assigned to each record of the first set of records. As a result, the first and second sets of records are visually distinguishable from each other when displayed and are identifiable as separate groups of related records.
Steps 106-110 may be repeated as many times as necessary in order to visually distinguish groups of records that are displayed. In some embodiments, such as those shown in
As used herein, the term “automatically” means that the step that is modified by the term is performed without additional user input or action. In particular, one or more of steps 102-112 may be performed automatically after a user selects an attribute in step 100, without the user taking additional steps such as manually assigning visual characteristics to records of particular sets of records. For example, and as seen in
In step 112, adjacent display positions are assigned to the first and second sets of records. For example, a web server implementing disclosed methods may, generate an HTML page to be delivered to a client web browser. In the HTML page, the first and second sets of records may be assigned positions adjacent each other, in a table for instance. In this manner, the web browser may display groups of records having different visual characteristics adjacent each other. In examples where disclosed methods are implemented on the same system (e.g., desktop computer, laptop computer, smart phone) at which the records are to be displayed, the first and second sets of records may be rendered adjacent to each other by the system's graphics hardware and/or software.
Examples where the visual characteristics assigned to records are colors are seen in
As noted above, in some instances, methods and computer program products described herein for assigning visual characteristics to records may be implemented on separate data processing apparatus such as data processing apparatus 208, which in turn may communicate resulting information to data processing apparatus 200 for display. For example, data processing apparatus 208 may be a web server configured to generate HTML code dynamically and transmit it to data processing apparatus 200. The generated HTML code may include tables or other similar structures that are configured to cause a web browser computer program executing on data processing apparatus 200 to display the records with their assigned visual characteristics.
A first set of records 210 having values of the attribute “Date” that correspond to “Jan. 4, 2009” are identified (step 104) and assigned the color yellow (step 108). A second set of records 212 having values of the attribute “Date” that correspond to “Jan. 5, 2009” are identified (step 106) and assigned a first color (step 110). A third set of records 214 having values of the attribute “Date” that correspond to “Jan. 6, 2009” are identified (step 104) and assigned a second color that is different than the first color (step 108). A fourth set of records 216 having values of the attribute “Date” that correspond to “Jan. 7, 2009” are identified (step 106) and assigned the first color (step 110). In this manner, sets of records are visually distinguishable from one another, and particularly from adjacent sets of records.
In
In
A first set of records 400 having values of the attribute “Subject” that correspond to “How to invest your recent inheritance” are identified (step 104) and assigned the first color (step 108). A second set of records 402 having values of the attribute “Subject” that correspond to “trip this weekend” are identified (step 106) and assigned the second color (step 110). It can be seen here that each of the records in the second set of records 402 has a value of the attribute “Subject” that is a subset of the value (“FW: RE: trip this weekend”). A third set of records 404 having values of the attribute “Subject” that correspond to “your 401k” are identified (step 104) and assigned the first color (step 108).
As noted above, the records in
In step 602, records of a data structure are automatically sorted by values of the attribute that was selected in step 600. Examples of this are seen in
In step 604, a first record having a first value of the selected attribute is displayed with a first visual characteristic. In step 606, a value of the selected attribute of a second record is examined to determine whether meets a relationship criteria to the first value. If so, then in step 608, the second record is displayed adjacent the first record with the first visual characteristic. In this way, the second record is visually identifiable as being part of the same set as the first record.
If in step 606 it is determined that the value of the selected attribute of the second attribute does not meet a relationship criteria to the first value, then in step 610, the second record is displayed adjacent the first record with a second visual characteristic that is different from the first visual characteristic. In this manner, the second record is visually identifiable as being part of a different set than the first record. Steps 606-610 can be repeated for each record of a data set, in each case comparing a value of an attribute of a current record to a value of the same attribute of a previous (e.g., adjacent) record to determine whether the current record is part of the same set as the previous record, or if it is part of a new set.
The flowchart and cluster diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present invention. In this regard, each cluster in the flowchart or cluster diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the cluster may occur out of the order noted in the figures. For example, two clusters shown in succession may, in fact, be executed substantially concurrently, or the clusters may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each cluster of the cluster diagrams and/or flowchart illustration, and combinations of clusters in the cluster diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms “an” and “the” are intended to include the plural forms as well unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or clusters thereof.
The corresponding structures, materials, acts, and equivalents of all means or step plus function elements in the claims below are intended to include any structure, material, or act for performing the function in combination with other claimed elements as specifically claimed. The description of the present invention has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the invention. The embodiment was chosen and described in order to best explain the principles of the invention and the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.