Aspects of the present invention relate to visual design surfaces. More specifically, aspects of the present invention provide user interfaces for visual design surfaces that include visually perceptible indicators next to design elements to represent characteristics.
Visual design surfaces are commonly used to illustrate and design systems using graphical notations. Microsoft Visio diagramming program, for example, includes a visual design surface that allows users to illustrate processes with flow charts. The shapes of the elements are used to represent different entities. A diamond shape, for example, may represent a decision process. Microsoft Visual Studio development system is another example of an application that includes a visual design surface. The visual design surface is used to model business processes.
One drawback of existing visual design surfaces is that the elements that represent different entities convey limited information to users. For example, several different decision processes may be represented with diamond shapes. Each of the decision processes may have characteristics that are important to the user. Decision making processes may be characterized as high importance, medium importance or low importance. With existing visual design surfaces it is not readily apparent to a user which decision processes have which level of the importance characteristic.
Therefore, there is a need in the art for visual design surface systems and methods that visually convey characteristics of design elements to users.
Aspects of the present invention address one or more of the issues mentioned above, thereby providing methods of representing characteristics of design elements on a visual design surface. The methods include representing design elements with shapes on a visual design surface. One or more characteristics of the design elements may be represented with auras associated with the design elements. The auras allow users to quickly determine design element characteristics.
Aspects of the present invention are described with respect to the accompanying figures, in which like reference numerals identify like elements, and in which:
Exemplary Operating Environment
A basic input/output system 160 (BIOS), containing the basic routines that help to transfer information between elements within the computer 100, such as during start-up, is stored in the ROM 140. The computer 100 also includes a hard disk drive 170 for reading from and writing to a hard disk (not shown), a magnetic disk drive 180 for reading from or writing to a removable magnetic disk 190, and an optical disk drive 191 for reading from or writing to a removable optical disk 192 such as a CD ROM or other optical media. The hard disk drive 170, magnetic disk drive 180, and optical disk drive 191 are connected to the system bus 130 by a hard disk drive interface 192, a magnetic disk drive interface 193, and an optical disk drive interface 194, respectively. The drives and their associated computer-readable media provide nonvolatile storage of computer readable instructions, data structures, program modules and other data for the personal computer 100. It will be appreciated by those skilled in the art that other types of computer readable media that can store data that is accessible by a computer, such as magnetic cassettes, flash memory cards, digital video disks, Bernoulli cartridges, random access memories (RAMs), read only memories (ROMs), and the like, may also be used in the example operating environment.
A number of program modules can be stored on the hard disk drive 170, magnetic disk 190, optical disk 192, ROM 140 or RAM 150, including an operating system 195, one or more application programs 196, other program modules 197, and program data 198. A user can enter commands and information into the computer 100 through input devices such as a keyboard 101 and pointing device 102. Other input devices (not shown) may include a microphone, joystick, game pad, satellite dish, scanner or the like. These and other input devices are often connected to the processing unit 110 through a serial port interface 106 that is coupled to the system bus, but may be connected by other interfaces, such as a parallel port, game port or a universal serial bus (USB). Further still, these devices may be coupled directly to the system bus 130 via an appropriate interface (not shown). A monitor 107 or other type of display device is also connected to the system bus 130 via an interface, such as a video adapter 108. In addition to the monitor, personal computers typically include other peripheral output devices (not shown), such as speakers and printers.
The computer 100 can operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 109. The remote computer 109 can be a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 100, although only a memory storage device 111 has been illustrated in
When used in a LAN networking environment, the computer 100 is connected to the local network 112 through a network interface or adapter 114. When used in a WAN networking environment, the personal computer 100 typically includes a modem 115 or other means for establishing communications over the wide area network 113, such as the Internet. The modem 115, which may be internal or external, is connected to the system bus 130 via the serial port interface 106. In a networked environment, program modules depicted relative to the personal computer 100, or portions thereof, may be stored in the remote memory storage device.
It will be appreciated that the network connections shown are illustrative and other techniques for establishing a communications link between the computers can be used.
The existence of any of various well-known protocols such as TCP/IP, Ethernet, FTP, HTTP, Bluetooth, IEEE 802.11x and the like is presumed, and the system can be operated in a client-server configuration to permit a user to retrieve web pages from a web-based server. Any of various conventional web browsers can be used to display and manipulate data on web pages.
Description of Illustrative Embodiments
Next, in step 204 the value of at least one characteristic of the design element is determined. Characteristics may include an identification of a namespace, an identification of an application layer, an identification of an importance level, an identification of an intended use or other characteristics. An aura is then associated with the characteristic in step 206. As used herein, an “aura” is a visually perceptible element that is placed next to, around or within a design element and that represents a characteristic of the element. Auras may include colored elements, patterned elements, symbols and the like.
In step 208, the aura is displayed in association with a shape on the design. Two elements are displayed in association with one another, for example, when a viewer would recognize that there is a specific relationship between the elements.
In the embodiment shown in
In step 210, steps 202-208 may be repeated for a plurality of design elements. The resulting design surface may look like the design surface shown in
A visual design surface may utilize any number of affinity regions and the affinity regions may have a variety of shapes and orientations.
In one embodiment of the invention, the value of a characteristic of a design element may be changed by dragging the element from one affinity region and hovering the element over another affinity region. For example, the layer value of design element 708 may be changed from 1 to 2 by moving element 708 from affinity region 702 to affinity region 706 and hovering the element over affinity region 706 before dropping the element. Hovering means holding an object stationary during a drag and drop operation for a period of time before dropping the object. Of course predetermined key sequences, pointing device buttons, menu options, etc. may also be used to indicate that a characteristic of a design element is to be changed during a drag and drop operation.
Labels associated with affinity regions may also be used to change values of characteristics. For example, changing label 706a to read “Layer=Layer 3” will change all of the layer values for the design elements in affinity region 706 to 3.
A visual design surface may be configured to allow a user to choose whether to display affinity regions, display labels, merge affinity regions, allow for changes in labels, etc. Moreover, a variety of different auras may be associated with design elements.
The present invention has been described in terms of preferred and exemplary embodiments thereof. Numerous other embodiments, modifications and variations within the scope and spirit of the appended claims will occur to persons of ordinary skill in the art from a review of this disclosure.