The present invention relates to graphical user interfaces (GUIs), and more particularly to the layout and design of GUIs.
Graphical User Interface layout editors are commonly used by computer programmers and user interface designers to arrange GUI components on a user interface form during GUI layout and design. The place (i.e. screen area) within a layout editor where a person arranges GUI components is called a design area. Known layout editors usually present the entirety of a form being edited in the design area. When a designer works on a subset of the design, such as a menu bar or composite (i.e. dialog box), other GUI components not presently being edited continue to be displayed. The result is a cluttered design area in which the component(s) presently being edited may be effectively lost among the other components or may be displayed in a size that is too small to permit easy viewing of component features.
A solution that addresses the above noted difficulty would be desirable.
During GUI layout and design, selection of a GUI component causes either the selected component or an ancestor of the selected component to be displayed in a design area. If the selected component is capable of displaying other GUI components within its boundaries, it is the selected component that is displayed in the design area. Otherwise, an ancestor GUI component of the selected component that is capable of displaying other GUI components within its boundaries is displayed in the design area. The displayed component is displayed in a size that is larger than its usual display size, so that component features may more easily be seen and, if desired, manipulated. The larger size may fill the design area. Selection may be effected by a designer or by automatic programmatic selection, e.g., by layout editor software, and may in some cases be a reselection.
In accordance with an aspect of the present invention there is provided a method for use in graphical layout or design of a GUI, the method comprising: upon selection of a visual GUI component that is capable of displaying other GUI components within its boundaries, the visual GUI component having a display size that is less than a size of a design area, displaying the visual GUI component within the design area in an enlarged size greater than the display size.
In accordance with another aspect of the present invention there is provided a method for use in graphical layout or design of a GUI, the method comprising: upon selection of a visual GUI component that is not capable of displaying other GUI components within its boundaries: identifying an ancestor visual GUI component of the visual GUI component, the ancestor being capable of displaying other GUI components within its boundaries, the ancestor having a display size that is less than a size of a design area; and displaying the ancestor visual GUI component within the design area in an enlarged size greater than the display size.
In accordance with yet another aspect of the present invention there is be provided a computer readable medium for use in graphical layout or design of a GUI, the computer readable medium containing computer-executable instructions that, when performed by a processor in a computing device, cause the computing device to: upon selection of a visual GUI component that is capable of displaying other GUI components within its boundaries, the visual GUI component having a display size that is less than a size of a design area, display the visual GUI component within the design area in an enlarged size greater than the display size.
In accordance with still another aspect of the present invention there is be provided a computer readable medium for use in graphical layout or design of a GUI, the computer readable medium containing computer-executable instructions that, when performed by a processor in a computing device, cause the computing device to: upon selection of a visual GUI component that is not capable of displaying other GUI components within its boundaries: identify an ancestor visual GUI component of the visual GUI component, the ancestor being capable of displaying other GUI components within its boundaries, the ancestor having a display size that is less than a size of a design area; and display the ancestor visual GUI component within the design area in an enlarged size greater than the display size.
In accordance with yet another aspect of the present invention there is be provided a computing device for use in graphical layout or design of a GUI, the computing device comprising a processor and persistent storage memory in communication with the processor storing computer readable instructions for directing the device to: upon selection of a visual GUI component that is capable of displaying other GUI components within its boundaries, the visual GUI component having a display size that is less than a size of a design area, display the visual GUI component within the design area in an enlarged size greater than the display size.
In accordance with still another aspect of the present invention there is be provided a computing device for use in graphical layout or design of a GUI, the computing device comprising a processor and persistent storage memory in communication with the processor storing computer readable instructions for directing the device to: upon selection of a visual GUI component that is not capable of displaying other GUI components within its boundaries: identify an ancestor visual GUI component of the visual GUI component, the ancestor being capable of displaying other GUI components within its boundaries, the ancestor having a display size that is less than a size of a design area; and display the ancestor visual GUI component within the design area in an enlarged size greater than the display size.
Other aspects and features of the present invention will become apparent to those ordinarily skilled in the art upon review of the following description of specific embodiments of the invention in conjunction with the accompanying figures.
In the figures which illustrate an exemplary embodiment of this invention:
In the description which follows, the following definitions are applicable:
Referring to
Computing device 10 executes GUI layout editor software 18 exemplary of an embodiment of the present invention. GUI layout editor software 18 (or simply “layout editor 18”) allows a human designer to graphically lay out and design one or more GUIs for the purpose of displaying information and/or receiving user input. The GUI(s) created by software 18 at design time are intended for use at run time for data input and/or output. The layout editor software 18 may be loaded into the memory of the computing device 10 from a computer readable medium, such as resident non-volatile memory (e.g. a hard drive or a read only memory chip) (not shown) or a removable optical or magnetic disk 20.
Design area 202 is a work area within the GUI of the layout editor software 18 where a designer lays out a GUI that is presently being designed. The in-progress GUI design is displayed in a “WYSIWYG” (What You See Is What You Get) manner, i.e., as it will appear when ultimately put into use, with certain exceptions (e.g. size, highlighting may be different at design versus run time), as will become apparent.
In
Outline view 300 displays a graphical representation of the hierarchy of the GUI presently being edited using layout editor 18. As will be appreciated, outline view 300 is “tied” to design area 202, in the sense that outline view 300 may be used to select components for display in the neighboring design area 202 or may visually distinguish (e.g. highlight) a component that has just been selected in design area 202. Such highlighting is understood to be a design time rather than a run time occurrence. Outline view 300 is shown in greater detail in
As shown in
With reference to
The remainder of the GUI component hierarchy (e.g. toolbar 308, composite 310 and the remaining GUI components) is apparent from
As known in the art, each type of GUI component (e.g. form, view, menu bar etc.) has three characteristics. The first characteristic, referred to herein as the “parent” characteristic, reflects whether or not an instance of the component type can act as a parent to other GUI components. The second characteristic, referred to herein as the “visual” characteristic, reflects whether the component type is visual, i.e. whether an instance of the GUI component can be perceived by a user (i.e. occupies “screen real estate”) when the GUI is displayed. The third characteristic, referred to herein as the “container” characteristic, indicates whether an instance of the component type can display other GUI components within its boundaries when displayed (e.g. a composite is capable of containing push button components within its boundaries). Typical visual container GUI components include views, wizards, wizard pages, menu bars, and composites. It is noted that a GUI component that is a parent is not necessarily a container. A table summarizing the three above-noted characteristics for a number of GUI component types is provided below (Table 1).
In overview, during layout and design of a GUI, a designer using layout editor software 18 selects GUI components as necessary (e.g. using a pointing device such as a mouse) for purposes of arranging components, changing their properties, etc., in a conventional manner. Component selection may be performed in the design area (assuming the component is already displayed in the design area so as to permit selection) or from an outline view. Alternatively, component selection may be performed automatically (i.e. programmatically) by the layout editor software 18.
Upon selection of a GUI component, the layout editor 18 automatically displays in design area 202 an enlargement of either the selected component or an ancestor of the selected component. Specifically, if the selected component is a visual container component, then the selected component is displayed in the design area 202. If, on the other hand, the selected component is not a visual container component, then an ancestor of the selected component that is a visual container component is displayed in the design area 202 (with the selected component usually being visible within the boundaries of the displayed ancestor).
By “enlargement”, what is meant is that the displayed component is enlarged from a usual display size of the component in the layout editor 18. The enlargement may fill the design area 202. Enlargement of the displayed component is for the purpose of allowing component features to be more easily seen and to facilitate manipulation of any components contained by the displayed component.
Operation of the layout editor 18 for displaying GUI components based on component selection is illustrated in
Operation 500 is described in conjunction with FIGS. 6 to 11, 12A and 12B, which illustrate the effect of selecting different types of GUI components.
Initially, a determination is made as to whether the selected GUI component is a visual GUI component (S502). If the selected GUI component is not a visual GUI component (e.g. it is a form), the design area 202 is cleared (S504). This is shown at 600 in GUI 200 of
Instead, if it is determined in S502 that the selected GUI component is in fact a visual GUI component, a further determination is then made as to whether the selected component is already highlighted (S506). A determination in the positive would indicate that the component is currently being reselected, i.e., is being selected for a second consecutive time, with the first selection having triggered a previous execution of operation 500.
Assuming that the selected component is not highlighted, i.e. that this is an initial selection rather than a reselection, a determination is then made as to whether another component is highlighted (S508). If another component is in fact highlighted, that component is unhighlighted (S510) to reflect the current selection.
Thereafter, operation depends upon whether the selected component is visible, i.e., was already displayed in the design area 202 of
If the selected component is visible (S512), the component is highlighted (S514) and operation 500 terminates. This scenario is illustrated in
Referring back to
If the selected component is a visual container GUI component (S516), the component is automatically displayed so as to fill the design area (S518) and highlighted to reflect selection (S514). In the case of composite 702, this scenario is illustrated in
If, on the other hand, the selected component is not a visual container GUI component (S516—
Referring to
Referring back to
As should now be appreciated, selection of a visual container GUI component will cause that component to become the scoped component if the component was not already visible in the design area 202. Reselection of a visual container GUI component will invariably cause that component to become the scoped component in the present embodiment. On the other hand, selection of a GUI component that is not a visual container will not cause that component to become the scoped component, but instead will cause the closest ancestor visual container to become the scoped component (unless the selected component is not visual, in which the design area 202 is cleared).
As will be appreciated by those skilled in the art, modifications to the above-described embodiment can be made without departing from the essence of the invention. For example, alternative embodiments may invariably cause a visual container GUI component to become scoped upon its initial selection, even when it was already visible. That is, in such alternative embodiments, scoping of components is always performed on the basis of an initial selection (i.e. a designer needn't ever make a reselection in order for any component to become scoped). Of course, the display volatility of such embodiments may be somewhat higher than the embodiment described above.
It should also be appreciated that it is not necessary for a scoped component to fill the design area 202. For example, a scoped component may be enlarged from its usual display size, but not be made so large as to fill the design area 202.
It should further be understood that, while the design area 202 is described as a “screen area”, if the display 12 does not have a screen, the design area 202 may not in fact be a screen area. For example, if display 12 is a projector, design area 202 may be a projection area.
In another possible variation, when a component that is not a visual container is selected so as to result in the display of an ancestor visual container in the design area 202, the ancestor that is displayed need not necessarily be the closest visual container ancestor to the selected component. For example, a “second-closest” visual container ancestor may instead be displayed. This may be elected because enlargement of the closest ancestor visual container from its usual display size to fill the design area 202 would constitute an unnecessary degree of magnification.
Other modifications will be apparent to those skilled in the art and, therefore, the invention is defined in the claims.
Number | Date | Country | Kind |
---|---|---|---|
2,466,253 | May 2004 | CA | national |