1. Field of the Invention
The present invention generally relates to tables of data. More particularly, the present invention provides a method, system, and computer program product for type-based table navigation.
2. Related Art
An illustrative table 10 comprising a plurality of rows 12 and a plurality of columns 14 is depicted in
As can be seen in
In general, the present invention provides a method, system, and computer program product for type-based table navigation. In particular, the present invention allows a user to quickly navigate to and between cells of a table based on the data type contained within the cells. This reduces the number of cells a user is required to navigate because only the cells containing data of a desired data type are navigable and all other cells are skipped.
A first aspect of the present invention is directed to a method for type-based navigation of data, comprising: selecting a data type; activating a type-based navigation mode; and navigating exclusively between data of the selected data type in an arrangement of data, wherein data not of the selected data type in the arrangement of data is skipped.
A second aspect of the present invention is directed to a system for type-based navigation of data, comprising: a system for selecting a data type; a system for activating a type-based navigation mode; and a system for navigating exclusively between data of the selected data type in an arrangement of data, wherein data not of the selected data type in the arrangement of data is skipped.
A third aspect of the present invention is directed to a program product stored on a recordable medium for type-based navigation of data, which when executed comprises: program code for selecting a data type; program code for activating a type-based navigation mode; and program code for navigating exclusively between data of the selected data type in an arrangement of data, wherein data not of the selected data type in the arrangement of data is skipped.
A fourth aspect of the present invention is directed to a method for deploying an application for type-based navigation of data, comprising: providing a computer infrastructure being operable to: select a data type; activate a type-based navigation mode; and navigate exclusively between data of the selected data type in an arrangement of data, wherein data not of the selected data type in the arrangement of data is skipped.
A fifth aspect of the present invention is directed to computer software embodied in a propagated signal for type-based navigation of data, the computer software comprising instructions to cause a computer system to perform the following functions: select a data type; activate a type-based navigation mode; and navigate exclusively between data of the selected data type in an arrangement of data, wherein data not of the selected data type in the arrangement of data is skipped.
These and other features of this invention will be more readily understood from the following detailed description of the various aspects of the invention taken in conjunction with the accompanying drawings in which:
The drawings are merely schematic representations, not intended to portray specific parameters of the invention. The drawings are intended to depict only typical embodiments of the invention, and therefore should not be considered as limiting the scope of the invention. In the drawings, like numbering represents like elements.
As indicated above, the present invention provides a method, system, and computer program product for type-based table navigation. In particular, the present invention allows a user to quickly navigate to and between cells of a table based on the data type contained within the cells. This reduces the number of cells a user is required to navigate because only the cells containing data of a desired data type are navigable and all other cells are skipped.
An illustrative navigation path 100 in accordance with an embodiment of the present invention from the first cell 16 in table 10 (i.e., row 1, column 1) to the last cell 16 in table 10 containing an URL data type (i.e., row 5, column 4) is shown in
Navigation in the reverse direction to cells 16 of table 10 containing an URL data type can be accomplished using, for example, a conventional shift-tab key combination or using another predetermined key or key combination. Again, while navigating in the reverse direction, cells 16 in table 10 containing data types other than an URL data type are skipped.
It should be noted that navigation in the type-based navigation mode can be carried out using keyboard keys in addition to, or other than, the tab key. For example, the right and left arrow keys can be used to navigate forward and backward between cells of a selected data type in a table. Further, the up and down arrow keys can be used to navigate to a first instance (or the closest instance) of the selected data type in a higher or lower row, respectively, of a table. Other non-keyboard techniques can also be used to navigate between cells of the selected data type while in the type-based navigation mode. For example, while in the type-based navigation mode a user can click a button on a mouse or other input device to navigate between cells of the selected data type. Many other techniques are also possible.
An example of the use of the down arrow key is illustrated in
It should be also be noted that the present invention is not limited to use with tables. For example, the present invention can be used to navigate among the cells of a spreadsheet. In addition, the present invention can be used to navigate through an application containing fields (e.g., a 3270 or 5250 application), or through a dialog window having multiple graphical user interface (GUI) controls (cells). Many other possibilities also exist. In general, the present invention can be used to navigate through selectable data, cells, objects, fields, controls, and the like.
A flow diagram 200 of a method in accordance with the present invention is illustrated in
In step S2, the user navigates through the cells of a table using the tab key and/or arrow keys, or in any other suitable manner. Navigation continues in this manner until the user activates (step S3) the type-based navigation mode of the present invention. The type-based navigation mode can be activated, for example, by pressing and holding the space bar or other predetermined key (e.g., right arrow, F10, etc.) or key combination (e.g., control-key, alt-key, etc.) on the keyboard while navigating the table using the tab and/or arrow keys. In this case of the space bar, navigation in the type-based navigation mode continues (step S4) until the user releases the space bar. Upon deactivation of the type-based navigation mode (step S5), flow passes back to step S2. It should be noted that the user could alternatively activate the type-based navigation mode first and then select a data type to be searched while in the type-based navigation mode.
Many other techniques for activating/deactivating the type-based navigation mode are also possible, and can include, for example, pressing a key (e.g., space bar, function key, etc.) or key combination (e.g., control-key, alt-key, etc.) to activate the type-based navigation mode and subsequently pressing the same or different key or key combination to deactivate the type-based navigation mode. Further, the type-based navigation mode can be activated/deactivated by selecting a toolbar button, selecting a command from a menu, opening a dialog box and selecting an option to enter/leave the type-based navigation mode, etc. It will be apparent to one skilled in the art that any suitable now known or later developed technique can be used to activate/deactivate the type-based navigation mode of the present invention.
Another embodiment of the present invention is illustrated in
In the dialog box 300, it is assumed that the Use Blank button 302 is currently selected. Conventionally, the tab key would need to be pressed three times to move the focus of the dialog box 300 to the Settings button 304, even though the Settings button 304 is located directly below the Use Blank button 302. Likewise, the tab key would need to be pressed another two times to move the focus to the Clear History button 306, and another four times to move the focus to the Accessibility button 308. The navigation path 310 followed by the tab button through the dialog box 300 is depicted by the solid arrows 312 in
Using the type-based navigation of the present invention, however, assuming that a data type of “control button” has been selected, greatly simplifies navigation through the dialog box 300. Using the above example, after entering the type-based navigation mode, a user can intuitively use the down arrow to move the focus of the dialog box 300 directly downward from the Use Blank button 302 to the Setting button 304, the Clear History button 306, and Accessibility button 310. The navigation path 314 followed by the tab button through the dialog box 300 is depicted by the dashed arrows 316 in
Referring now to
Data 402 arranged in a form (e.g., table, spreadsheet, fields, buttons, etc.) that can be navigated using the methods of the present invention can be stored locally to computer system 400, for example, in storage unit 404, and/or may be provided to computer system 400 over a network 405. Storage unit 404 can be any system capable of providing storage for data and information under the present invention. As such, storage unit 404 may reside at a single physical location, comprising one or more types of data storage, or may be distributed across a plurality of physical systems in various forms. In another embodiment, storage unit 404 may be distributed across, for example, a local area network (LAN), wide area network (WAN) or a storage area network (SAN) (not shown). Network 405 is intended to represent any type of network over which data can be transmitted. For example, network 405 can include the Internet, a wide area network (WAN), a local area network (LAN), a virtual private network (VPN), a WiFi network, a personal area network (PAN), or other type of network. To this extent, communication can occur via a direct hardwired connection or via an addressable connection in a client-server (or server-server) environment that may utilize any combination of wireline and/or wireless transmission methods. In the case of the latter, the server and client may utilize conventional network connectivity, such as Token Ring, Ethernet, WiFi or other conventional communications standards. Where the client communicates with the server via the Internet, connectivity could be provided by conventional TCP/IP sockets-based protocol. In this instance, the client would utilize an Internet service provider to establish connectivity to the server.
As shown, computer system 400 generally includes a processor 406, memory 408, bus 410, input/output (I/O) interfaces 412 and external devices/resources 414. Processor 406 may comprise a single processing unit, or may be distributed across one or more processing units in one or more locations, e.g., on a client and server. Memory 408 may comprise any known type of data storage and/or transmission media, including magnetic media, optical media, random access memory (RAM), read-only memory (ROM), etc. Moreover, similar to processor 406, memory 408 may reside at a single physical location, comprising one or more types of data storage, or be distributed across a plurality of physical systems in various forms.
I/O interfaces 412 may comprise any system for exchanging information to/from an external source. External devices/resources 414 may comprise any known type of external device, including speakers, a CRT, LED screen, handheld device, keyboard, mouse, voice recognition system, speech output system, printer, monitor/display (e.g., display 416), facsimile, pager, etc.
Bus 410 provides a communication link between each of the components in computer system 400, and likewise may comprise any known type of transmission link, including electrical, optical, wireless, etc. In addition, although not shown, other components, such as cache memory, communication systems, system software, etc., may be incorporated into computer system 400.
Shown in memory 408 is a navigation controller 418, which may be provided as a computer program product. The navigation controller 418 is configured to provide type-based navigation through the data 402 in a table, spreadsheet, dialog box, application, etc., in accordance with the methods of the present invention.
The navigation controller 418 includes a data type selection system 420 that allows a user 422 to select a data type for navigation. User 422 can select the data type using a keyboard 424, via a menu 426 displayed on display 416, and/or using any other suitable or available method. Navigation controller 418 also includes an activation/deactivation system 428 that allows a user to selectively activate/deactivate the type-based navigation mode when navigating data. Navigation controller 418 further includes a navigation system 430 for providing conventional and type-based navigation of data based on the data type selected by a user via the data type selection system 420 and the state of the activation/deactivation system 428.
It should be appreciated that the teachings of the present invention can be offered as a business method on a subscription or fee basis. For example, computer system 400 could be created, maintained, supported, and/or deployed by a service provider that offers the functions described herein for customers. That is, a service provider could be used to provide type-based table navigation, as describe above.
It should also be understood that the present invention can be realized in hardware, software, a propagated signal, or any combination thereof Any kind of computer/server system(s)—or other apparatus adapted for carrying out the methods described herein—is suited. A typical combination of hardware and software could be a general purpose computer system with a computer program that, when loaded and executed, carries out the respective methods described herein. Alternatively, a specific use computer, containing specialized hardware for carrying out one or more of the functional tasks of the invention, could be utilized. The present invention can also be embedded in a computer program product or a propagated signal, which comprises all the respective features enabling the implementation of the methods described herein, and which—when loaded in a computer system—is able to carry out these methods. Computer program, propagated signal, software program, program, or software, in the present context mean any expression, in any language, code or notation, of a set of instructions intended to cause a system having an information processing capability to perform a particular function either directly or after either or both of the following: (a) conversion to another language, code or notation; and/or (b) reproduction in a different material form.
The foregoing description of the preferred embodiments of this invention has been presented for purposes of illustration and description. It is not intended to be exhaustive or to limit the invention to the precise form disclosed, and obviously, many modifications and variations are possible. Such modifications and variations that may be apparent to a person skilled in the art are intended to be included within the scope of this invention as defined by the accompanying claims.