The present invention relates to selection of an object, and more particularly to a method, apparatus and program for readily selecting a desired object on a display screen.
In the use of word processors, WYSIWYG-type HTML editors, graphic tools or other tools, it is necessary to “select” an object to perform editing operations such as copying, cutting, pasting, or deleting of an object or changing of the attribute values thereof. One of the simplest ways to do so is to use mouse clicks for selection. However, in the case of a Web page, for example, where many objects are arranged in an overlapped or nested manner, it is difficult to click on a target object due to a narrow area for clicking, resulting in repeated failure in clicking on the target object, and an alternative way, such as designation of a rectangular area, keyboard operation or the like, may be required. Therefore, there is a demand for a method enabling easy selection of a target object even in such a case where the objects are arranged in a complicated manner. Some methods enabling selection of an object from among those complicatedly arranged on a display screen are known, which include an object stack in WebArt Designer included in IBM® Homepage Builder™ (Non-Patent Document 1), and a layer palette in Adobe® Photoshop® (Non-Patent Document 2). The object stack and the layer palette are each for displaying items corresponding to all the objects arranged on the display screen in a specific location (object stack or layer palette) in the form of a list for selection. In the list, the items are displayed to indicate the stacked order of the corresponding objects, and when a mouse is clicked on a specific item among them, the corresponding object is selected. In addition, there is known a technique where the object elements are displayed in the form of a tree, and when a mouse is clicked on an element on the tree, the corresponding object is selected on the editor.
While all the objects are listed for display in each of the conventional techniques described above, there is also known a technique where only the objects satisfying a prescribed condition are extracted for display in a list. See Japanese Unexamined Patent Publication (Kokai) No. 2002-366974. According to this known technique, the objects through which a straight line connecting the view point and the cursor position transmits are extracted as selection candidate objects and listed for display in a list dialog box. See also “Method for selecting a plurality of objects at the same time in WebArt Designer”
With the method of listing and displaying all the objects, the location for displaying the list is fixed, and thus, if the location is far from a selected object, it would be necessary to move the mouse a relative long distance. Further, since all the objects are displayed on the list, if the number of objects increases, it may be troublesome to select a desired object. With the method disclosed in Japanese Unexamined Patent Publication (Kokai) No. 2002-366974, although such trouble may be saved, the selection candidates are determined according to whether the straight line connecting the view point and the cursor position transmits through the objects, and thus, if a user wishes to designate a small object hidden behind a large object as a selection candidate, a plurality of clicking operations would be necessary.
In view of the foregoing, an object of the present invention is to realize selection of an object which can solve the above-described problems.
According to the present invention, there is provided a method for facilitating selection of an object on a display screen of a computer, which includes: a step of selecting a specific object on the display screen in response to a user input; a step of extracting any of a plurality of objects displayed on the display screen that overlaps the selected specific object as a selection candidate by following a tree structure of the objects; and a step of displaying a selection switching view including an element representing the selection candidate in the vicinity of the selected specific object. Further, an apparatus for implementing the method, and a program for causing a computer to execute the method are also provided.
Preferably, in response to the user selecting a specific element included in the selection switching view, the object corresponding to the specific element is highlighted, and selection is switched to the object. This allows the user to perform an editing or other operation on the selected object.
While the selection switching view is preferably in the form of tabs from the standpoint of decreasing the display area, the view may be of any form, besides the tab form, as long as it can list and display the elements representing the selection candidates. For example, it may be displayed in the form of a tree.
If the number of elements included in the selection switching view increases too much, it would be difficult to list and display them, and thus, extraction of the selection candidates is preferably terminated at the time point when the number of the extracted selection candidates reaches a predetermined number.
A best mode for carrying out the present invention (hereinafter, simply referred to as an “embodiment”) will now be described with reference to the drawings. It is needless to say that the embodiment will be described only by way of example and that the present invention is not restricted to the configuration of the embodiment.
In the example shown in
To select an object, for example, a user may move a mouse cursor 16 to an object the user wishes to select and click thereon. However, in the case where the object to be selected is hidden beneath a larger object or a region to be clicked is small in size, it may be difficult for a person inexperienced with mouse operation to quickly select a desired object. Further, the user may click on the data cell TD or the row TR despite the intention to select the table 12, for example.
In the present invention, when a user moves the cursor 16 to a specific object on a display screen and clicks thereon, a tree structure as shown in
While the selection switching view 30 in the example in
When a user clicks the left button of a mouse (not shown), for example, the object selecting portion 42 selects the object including the clicked position therein. Such selection is possible by comparing the coordinates of the clicked position included in the user input with the coordinate information of the respective objects stored in the storage portion 48. When there are two or more objects including the clicked position therein, the object located at the forefront among those overlapping each other is selected.
The selection candidate extracting portion 44 extracts the object selected by the object selecting portion 42 as well as any object having a specific relationship with the selected object, i.e., any object overlapping the selected object, as the selection candidates. Such overlapping of the objects may be detected by comparing the coordinates of the related objects. The selection candidate extracting portion 44 uses the identifiers of the objects extracted as the selection candidates to generate a selection switching view in the form of a table, as shown in
The display control portion 46 displays the selection switching view created by the selection candidate extracting portion 44 visually in the vicinity of the selected object, the view including the elements indicating the selection candidates (for example, the names of the selection candidates). In the example shown in
Next, an operation of the selection switching view generating apparatus 40 shown in
Firstly, in the first step S1 in
Next, in step S2, the selection candidate extracting portion 44 searches for a parent object of the selected object Y (in the example in
Next, in step S3, the operation of the selection candidate extracting portion 44 moves to the subroutine A shown in
In the first step S11 in the subroutine A, the selection candidate extracting portion 44 sets the input object as a parameter Z, and in the following step S12, repeats steps S13 through S19 as will be described below for each child element Zi (i=0, 1, 2, . . . ) of Z. The child element Zi is located, e.g., between <Z> and </Z> in the tree structure shown in
In the first step S13 in the repetitive loop, the selection candidate extracting portion 44 determines whether the number of objects included in the selection switching view is less than a threshold value. If the number of objects displayed on the selection switching view increases too much, it will be difficult to select one of them, and thus, the number of objects to be the selection candidates is preferably restricted to a prescribed number or less, for example five or less. If the number of objects included in the selection switching view has reached the threshold value, the process returns to the main flow in
In step S14, the selection candidate extracting portion 44 determines whether the child element Zi was checked for the overlapping with the selected object Y during the previous call of the subroutine. If it has already been checked, the step S13 and the subsequent steps are repeated for the next child element Zi+1; whereas if it has not been checked, the process proceeds to step S15 to determine whether the child element Zi overlaps the selected object Y. Such overlapping of the objects can be detected by comparing the coordinates of the objects stored in the storage portion 48, as described above. If Zi overlaps Y, the process proceeds to step S16; otherwise, the process proceeds to step S18.
In step S16, the selection candidate extracting portion 44 adds the child element Zi overlapping the selected object Y as a selection candidate to the selection switching view, and increments the number of objects included in the selection switching view by 1. To add a child element (object) to the selection switching view, the identifier of the child element may be written into the selection switching view 30 shown in
In the next step S17, the selection candidate extracting portion 44 determines whether the child element Zi added to the selection switching view 30 corresponds to the selected object Y. Although step S17 is provided assuming that overlapping is not checked for the child element of the selected object Y, if such consideration is unnecessary, step S17 may be omitted. If Zi=Y in step S17, the step S13 and the subsequent steps are repeated for the next child element Zi+1; otherwise, the process proceeds to step S18, and it is determined whether the child element Zi has any child element. If so, the process proceeds to step S19, and the same subroutine A is performed for each child element of the child element Zi. When all of the child elements Zi are checked, the process exits from the subroutine in
In step S4 in the main flow, the selection candidate extracting portion 44 determines whether the parent object X is a root object. If so, the main flow is terminated; otherwise, the process proceeds to step S5. In step S5, the selection candidate extracting portion 44 determines whether the number of objects included in the selection switching view is less than the threshold value. If not, i.e., if the number has reached the threshold value, the main flow is terminated. Otherwise, the process proceeds to step S6 to set the parent object of X as a new parent object X, and returns to step S3 to call the subroutine in
Hereinafter, specific processing for the example in
In the first step S11 in the subroutine, the identifier “UL” of the unordered list, which is the input object, is set as the parameter Z, and in step S12 and the subsequent steps, all the child elements, i.e., the list items LI1 through LI3 are checked. In the first place, there is no object in the selection switching view, and none of the list items LI1 through LI3 has been checked, and thus, the process proceeds from step S13 through S14 to S15. As evident from
When the list items LI1 through LI3 are all checked, the process returns to the main flow in
In this second call, the table (TABLE) 12 and the unordered list (UL) 14 being the child elements of the body (BODY) 10 are checked in steps S13 through S19. Although description here is made assuming that the parent object of the selected object Y is to be checked first, i.e., Z0=UL and Z1=TABLE, the order may be determined arbitrarily.
The number of objects in the selection switching view checked in step S13 is currently 1 (because only the list item LI1 is included as described above), and if the threshold value is 5 for example, the number of objects is less than the threshold value, and thus, the process proceeds from step S13 to step S14. In step S14, the first child element of BODY 14, i.e., UL 14, has not been checked yet, and therefore, the process proceeds to step S15 to check the overlapping with the selected object Y, i.e., the list item LI1. As evident from
On the checking of TABLE 12, the number of objects in the selection switching view (currently 2) is still less than the threshold value (YES in S13), and TABLE 12 has not been checked yet (NO in S14), and further, TABLE 12 overlaps the list item LI1 being the selected object (YES in S15), and therefore, in step S16, TABLE 12 is added to the selection switching view as a selection candidate, and the number of objects is incremented by 1 to be 3. As in the case of UL 14, TABLE 12 differs from the list item LI1 being the selected object, and thus, the process proceeds from step S17 to step S18. In the example shown in
In this recursive call, the rows TR1 and TR2 being the child elements of TABLE 12 are checked in steps S13 through S19. This time, only the row TR2 overlaps the list item LI1 as the selected object Y, and thus, in step S16, the row TR2 is added to the selection switching view as a selection candidate, and the number of objects is further incremented by 1 to be 4. The row TR2 differs from the list item LI1 (NO in S17), and it has data cells TD3 and TD4 as its child elements (YES in S18), and thus, in step S19, the subroutine in
Checked this time are the data cells TD3 and TD4 being the child elements of the row TR2, and the data cell TD4 alone overlaps the list item LI1, and thus, in step S16 in this recursive call, the data cell TD4 is added to the selection switching view as a selection candidate, and the number of objects in the selection switching view is incremented by 1 to be 5. Here, although the data cell TD4 differs from the list item LI1 (NO in S17), both of the data cells TD3 and TD4 do not have any child element (NO in S18), and thus, the recursive call is terminated. Further, since every child element of BODY 10 has been checked, the process returns to step S4 in the main flow. At this time, since BODY 10 being the parent object X is the root object (YES in S4), the main flow is terminated at this time point. The selection switching view as shown in
In the example of the display screen shown in
Alternatively, it may be configured such that, when the user clicks on the tab “TD4” in
As described above, according to the flowcharts shown in
A PCI bus bridge 214 connected to the I/O bus 212 provides an interface for a PCI local bus 216. A modem 218, a network adaptor 220 and other communication devices, as well as other peripheral devices may be connected to the PCI local bus. In a typical implementation, the PCI bus is provided with four PCI extension slots or extension connectors.
Additional PCI bus bridges 222 and 224 provide interfaces for additional PCI local buses 226 and 228, respectively, for accepting additional peripheral devices. As shown in
An operating system runs on the processors 202 and 204 to control various components in the data processing system 200 in
Those skilled in the art will sufficiently understand that the hardware shown in
While the present invention has been explained in the context of a fully functioning data processing system, those skilled in the art will appreciate that the processes of the present invention are capable of being distributed in the form of a computer readable medium of instructions as well as in various forms, and that the present invention applies equally regardless of the specific type of signal bearing media actually used to carry out the distribution. Examples of the computer readable media include recordable type media such as a flexible disk, hard disk drive, RAM, CD-ROM, and DVD-ROM, as well as transmission type media such as digital and analog communications links, wired or wireless communications links using transmission forms such as, for example, radio frequency and light wave transmissions. The computer readable media may take the form of coded formats that are decoded for actual use in a specific data processing system.
The foregoing description of the present invention has been presented for purposes of illustration and description, and is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those skilled in the art. The embodiment has been selected and described in order to best explain the principles of the present invention and the practical application, and to enable those skilled in the art to understand the present invention for various embodiments with various modifications as are suited to the particular use contemplated.
Number | Date | Country | Kind |
---|---|---|---|
2007-238668 | Sep 2007 | JP | national |