US20100214299A1 - Graphical manipulation of chart elements for interacting with chart data - Google Patents
Graphical manipulation of chart elements for interacting with chart data Download PDFInfo
- Publication number
- US20100214299A1 US20100214299A1 US12/772,154 US77215410A US2010214299A1 US 20100214299 A1 US20100214299 A1 US 20100214299A1 US 77215410 A US77215410 A US 77215410A US 2010214299 A1 US2010214299 A1 US 2010214299A1
- Authority
- US
- United States
- Prior art keywords
- chart
- elements
- data
- modifying
- graphical
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T11/00—2D [Two Dimensional] image generation
- G06T11/20—Drawing from basic elements, e.g. lines or circles
- G06T11/206—Drawing of charts or graphs
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T13/00—Animation
- G06T13/80—2D [Two Dimensional] animation, e.g. using sprites
Definitions
- the invention is related to computer-based data charting and graphing, and in particular, to a system for automatically animating transitions when changing from one chart or graph type to another and/or when changing data values associated with those charts and graphs.
- Computer-based charting and graphing software tools are well known to those skilled in the art. Such software tools are often used to generate data displays such as, for example, pie charts, bar charts, data graphs, etc.
- these types of software tools allow a user to select or enter one or more data sets, and then select a chart type for rendering a chart or graph display of that data. Then, whenever a user changes from one chart type to another, or whenever data is added or changed, a new chart is rendered and the original chart is simply replaced by the newly rendered chart.
- some conventional software tools will animate bars of data growing from a “no data” state to the current data (either one bar at a time or all bars in parallel).
- a “Charting Animator” enhances computer-based charting/graphing systems by rendering dynamic animations of chart display transitions.
- a user changes from one chart type to another, when new data is added to a chart, or when existing data is changed, sorted or deleted, a new chart appears to replace the old chart.
- Conventional charting systems simply replace the existing chart with a new chart.
- the Charting Animator renders an animated transition for dynamically morphing the original chart into the new chart.
- the animation provided by the Charting Animator avoids abrupt changes that can be disorienting to users.
- Examples of the animations provided by the Charting Animator include animating changes from one chart family to another (e.g., changing a “Bar Chart” into a “Pie Chart”, etc.), changes from one chart type within a chart family to another chart type (e.g., changing from a “2D Bar Chart” into a “3D Bar Chart” or a “Stacked Bar Chart”, etc.), changes to data, etc.
- these animations are timed to occur over a relatively short period of time that allows the user to visually perceive changes to displayed charts while being sufficiently short in time so that users do not perceive that they are waiting for the system.
- any desired animation length, including varying length for different types animations are enabled by the Charting Animator.
- elements of the displayed charts are user selectable and provide direct interactive manipulation and feedback with the underlying data.
- the Charting Animator provides the capability to directly manipulate elements of charts, such as, for example, the height of one or more bars in a bar chart, the size of a slice in a pie chart, individual peaks or points in a line chart, etc.
- Other direct manipulation includes moving chart elements from one location to another, including stacking or combining elements of the chart. For example, stacking one bar on top of another in a bar chart will serve to combine those bars into a single element, thereby combining the underlying data into a single data set.
- the Charting Animator allows combined elements or data sets to be separated back out at a later time, if desired.
- the Charting Animator provides the capability to directly add or delete elements from a chart, thereby creating, or deleting, an underlying data set. For example, inserting a new rectangular bar in a Bar Chart will create a corresponding data element for the new bar element, while deleting a pie slice from a pie chart will delete the underlying data element and expand the relative sizes of the remaining slice elements of the Pie Chart.
- a change to any chart elements via direct manipulation, insertion, or deletion causes the Charting Animator to immediately modify the underlying data, as well as any interrelated data or chart elements.
- the Charting Animator combines animation embodiments with direct manipulation embodiments. For example, in one combination embodiment, as the user manipulates one graphical element of a chart, such as, for example, the height of a bar in a bar chart, the underlying data set will change in correspondence to the graphical change. Simultaneously, any related data sets that are dependent upon the underlying data being changed by manipulation of the graphical element will also be automatically changed, with corresponding animations being simultaneously rendered for the corresponding graphical elements of the chart.
- the Charting Animator provides the capability to construct “composite charts” as a composition of one or more existing charts. As a result, two or more relatively simple charts can be combined to compose a more complex composite chart. Further, the Charting Animator described herein provides the capability to predefine composite chart types for user selection. A simple example of a composite chart enabled by the Charting Animator is termed a “Quantity Flow Diagram.”
- Quantity Flow Diagram is a composite data set that includes dates and amounts of incoming quantities and dates and amounts of outgoing quantities, such as, for example, cash flow or material (inventory) availability.
- the Charting Animator constructs the Quantity Flow Diagram as a composite chart that shows incoming quantities in a first Bar Chart (positive bars trending up from a common axis), a second Bar Chart below the first that shows the outgoing quantities (negative bars trending down from the common axis), and a Plateau Chart below the first and second Bar Charts showing the quantity flow (the difference of the two quantities over time).
- all of the elements of this three part composite chart are interrelated. Therefore, in one embodiment, changes made to any one element of the composite chart (or to the underlying data) will be immediately reflected in all related underlying data, as described above, with those changes also being rendered as an animation to any corresponding chart elements.
- Charting Animator described herein provides a unique system and method for rendering dynamic animations of chart displays and for manipulating the underlying data of those chart displays.
- other advantages of the Charting Animator will become apparent from the detailed description which follows hereinafter when taken in conjunction with the accompanying drawing figures.
- FIG. 1 is a general system diagram depicting a general-purpose computing device constituting an exemplary system for implementing various elements of a Charting Animator, as described herein.
- FIG. 2 illustrates an exemplary architectural system diagram showing exemplary program modules for implementing various embodiments of the Charting Animator, as described herein.
- FIG. 3 illustrates an exemplary method for animating graphical transitions between a Bar Chart element and an Area Chart element for enabling various chart type and chart family morphing embodiments of the Charting Animator, as described herein.
- FIG. 4 illustrates an exemplary method for animating graphical transitions between a Bar Chart element and a Pie Chart element for enabling various chart type and chart family morphing embodiments of the Charting Animator, as described herein.
- FIG. 5 illustrates an exemplary method for animating graphical transitions of line elements of a line chart for enabling various chart type and chart family morphing embodiments of the Charting Animator, as described herein.
- FIG. 6 Illustrates an example of a composite chart comprising a “Quantity Flow Diagram” produced by the Charting Animator, as described herein.
- FIG. 1 illustrates an example of a simplified computing environment on which various embodiments and elements of a “Charting Animator,” as described herein, may be implemented. It should be noted that any boxes that are represented by broken or dashed lines in FIG. 1 represent alternate embodiments of the simplified computing environment, as described herein, and that any or all of these alternate embodiments, as described below, may be used in combination with other alternate embodiments that are described throughout this document.
- the computing device must have at least some minimum computational capability, a display device, an optional input device, and some local or remote data storage and access capability.
- FIG. 1 illustrates an exemplary general computing system 100 .
- the computing system 100 is only one example of a suitable computing environment and is not intended to suggest any limitation as to the scope of use or functionality of the invention. Neither should the computing system 100 be interpreted as having any dependency or requirement relating to any one or combination of components illustrated in the exemplary computing system 100 .
- the invention is operational with numerous other general purpose or special purpose computing system environments or configurations.
- Examples of well known computing systems, environments, and/or configurations that may be suitable for use with the invention include, but are not limited to, personal computers, server computers, hand-held, laptop or mobile computer or communications devices such as cell phones, PDA's, pocket PC's or media players, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
- the invention may be described in the general context of computer-executable instructions, such as program modules, being executed by a computer or a computing device in combination with various hardware modules.
- program modules include routines, programs, objects, components, data structures, etc., that perform particular tasks or implement particular abstract data types.
- the invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network.
- program modules may be located in both local and remote computer storage media including memory storage devices.
- an exemplary system for implementing the invention includes a general-purpose computing device in the form of computing system 100 .
- Components of the computing system 100 may include, but are not limited to, one or more processing units 110 , a system memory 120 , one or more communications interfaces 130 , one or more input and/or output devices, 140 and 150 , respectively, and data storage 160 that is removable and/or non-removable, 170 and 180 , respectively.
- the computing system 100 may access data remotely via the communications interface 130 .
- the communications interface 130 is generally used for connecting the computing device 100 to other devices via any conventional interface or bus structure, such as, for example, an Ethernet port, a parallel port, a game port, a universal serial bus (USB), an IEEE 1394 interface, a BluetoothTM wireless interface, an IEEE 802.11 wireless interface, GSM cell phone network, etc.
- Such interfaces 130 are generally used to transfer information, data, or program modules to or from the computing device 100 .
- the input devices 140 generally include devices such as a keyboard and pointing device, commonly referred to as a mouse, trackball, or touch pad. Such input devices may also include other devices such as a joystick, game pad, satellite dish, scanner, GPS receiver, radio receiver, and a television or broadcast video receiver, or the like.
- Conventional output devices 150 include elements such as a computer monitors or other display devices, audio output devices, etc.
- Other input 140 and output 150 devices may include speech or audio input devices, such as a microphone or a microphone array, loudspeakers or other sound output device, etc.
- the data storage 160 of computing device 100 typically includes a variety of computer readable storage media.
- Computer readable storage media can be any available media that can be accessed by computing device 100 and includes both volatile and nonvolatile media, removable and non-removable media.
- Computer readable media may comprise computer storage media and communication media.
- Computer storage media includes volatile and nonvolatile removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules, or other data.
- Computer storage media includes, but is not limited to, RAM, ROM, PROM, EPROM, EEPROM, flash memory, or other memory technology; CD-ROM, digital versatile disks (DVD), or other optical disk storage; magnetic cassettes, magnetic tape, magnetic disk storage, hard disk drives, or other magnetic storage devices.
- Computer storage media also includes any other medium or communications media which can be used to store, transfer, or execute the desired information or program modules, and which can be accessed by the computing device 100 .
- Communication media typically embodies computer readable instructions, data structures, program modules or other data provided via any conventional information delivery media or system.
- the computing device 100 may also operate in a networked environment using logical connections to one or more remote computers, including, for example, a personal computer, 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 computing device 100 .
- the Charting Animator provides animated chart transitions in response to various user actions (e.g., changing from one chart type to another, adding new data to a chart, changing, sorting or deleting data, modifying one or more chart elements via selection and manipulation of those elements, etc.).
- animated chart transitions are initiated in response to automatic changes to the data (e.g., live data changes such as real-time stock quotes, sensor readings, reviewing sequences of recorded or simulated data or query changes, etc.).
- the result of the animated transition is to provide an animation that replaces the original chart by dynamically morphing the original chart into the new chart. Consequently, these animations avoid abrupt changes that can disorient users. Examples of these animations include animating changes from one chart family to another (e.g., changing from a “Bar Chart” to a “Pie Chart”), animating changes from one chart type within a chart family to another chart type (e.g., changing a Bar Chart to a 3D Bar Chart or a Stacked Bar Chart), animating changes to data, etc.
- animations include animating changes from one chart family to another (e.g., changing from a “Bar Chart” to a “Pie Chart”), animating changes from one chart type within a chart family to another chart type (e.g., changing a Bar Chart to a 3D Bar Chart or a Stacked Bar Chart), animating changes to data, etc.
- chart families includes one or more chart types.
- conventional “2D Bar Charts,” “3D Bar Charts,” and “Stacked Bar Charts” are members (chart types) of the more generic “Bar Chart” family.
- Examples of distinct chart families include “Bar Charts,” “Pie Charts,” “Area Charts,” “Line Charts,” etc.
- One of the advantages of the animated transitions provided by the Charting Animator is that these transitions provide the user with a visual indication of what changes are occurring when changing from one chart type to another (e.g., animating a transition from a 2D Bar Chart to a 3D Bar Chart), or from one chart family to another (e.g., animating a transition from a 3D Bar Chart to a Pie Chart).
- the Charting Animator described herein provides a computer-based charting/graphing system for rendering dynamic animations of chart displays, including, for example, Bar Charts, Pie Charts, Area Charts, Line Charts, etc.
- these dynamic animations operate to dynamically morph an original chart into a new chart to reflect changes either to the underlying data values defining elements of the original chart or to graphical elements of the original chart via user interaction with those elements via a graphical user interface.
- Charting Animator dynamically morphs one or more elements of the original chart into one or more elements in the new chart to provide an animated transition that smoothly changes the original chart into the new chart.
- the Charting Animator provides the capability for user selection and manipulation of one or more of the graphical elements of charts. This user selection and manipulation capability is combined with automatic interactive feedback with the underlying data. For example, if the user resizes the height of one or more bars in a Bar Chart (using conventional drag and drop type computer operations) the Charting Animator will automatically amend the underlying data to correspond to the new height of the resized bar elements of that Bar Chart.
- the Charting Animator provides the capability to directly add or delete elements from a chart, thereby creating, or deleting, an underlying data set. For example, inserting a new bar element in a Bar Chart will automatically cause the Charting Animator to create a corresponding data set for the new bar element. Similarly, deleting a pie slice from a Pie Chart will delete the underlying data set and cause the Charting Animator to expand the relative sizes of the remaining pie slice elements of the pie chart, with the expansion of the pie slice elements being animated, as described in further detail below in Section 3.
- the Charting Animator provides the capability to construct “composite charts” by combining one or more existing charts.
- these composite charts represent a combination of two or more charts that are combined to compose a more complex composite chart.
- both the underlying charts and the composite charts are displayed together to provide the user with a better understanding of how the data of the underlying charts relates to the composite chart.
- FIG. 2 illustrates the interrelationships between program modules for implementing the Charting Animator, as described herein. It should be noted that any boxes and interconnections between boxes that are represented by broken or dashed lines in FIG. 2 represent alternate embodiments of the Charting Animator described herein, and that any or all of these alternate embodiments, as described below, may be used in combination with other alternate embodiments that are described throughout this document.
- the Charting Animator generally begins operation by using a chart construction module 200 to define parameters used to construct one or more charts (e.g., Pie Charts, Bar Charts, Line Charts, Area Charts, Plateau Charts, etc.) using one or more sets of chart data 210 .
- the chart construction module 200 then provides these parameters to a chart animation rendering module 220 which renders the chart(s) 230 on the display device 155 .
- a user interface module 240 is used to modify one or more of data elements comprising the chart data 210 via a data input module 250 . Modifications to these data elements include changing the value of one or more of the data elements, adding one or more data elements, and deleting one or more data elements. In general, these data elements are maintained in a conventional computer readable format, such as, for example, in a list, table, database, etc. Consequently, direct modifications to the data elements by using a user interface to change the data elements via the data input module 250 is accomplished using conventional techniques.
- the chart construction module 200 immediately determines new chart parameters corresponding to the modified data elements, and passes those chart parameters to the chart animation rendering module 220 .
- the chart animation rendering module 220 then morphs the existing charts(s) 230 into new chart(s) 230 using a dynamic animation that smoothly transitions from the existing chart(s) to the new chart(s) on the display device 155 .
- changes to the rendered chart(s) 230 are enabled by directly modifying one or more elements of the chart(s), such as, for example, resizing the height of one or more bars on a Bar Chart, or changing the size of a pie slice in a Pie Chart.
- direct modification of the elements of the chart(s) is accomplished via the user interface module 240 which allows the user to select one or more individual elements of one or more charts 230 using a graphical user interface provided via a chart element change module 260 .
- This graphical user interface provides a graphical interface to chart(s) 230 being rendered on the display device 155 for resizing, moving, sorting, or deleting one or more of those chart elements.
- chart elements can also be added to one or more of the chart(s) 230 via the graphical user interface provided by the chart element change module 260 .
- resizing, moving, sorting, or deleting elements in the chart(s) 230 is accomplished using conventional drag and drop-type computer interaction with the displayed charts.
- resizing a bar in a Bar Chart is accomplished by selecting one corner or edge of the bar with a pointing device, then dragging that edge or corner to a desired position corresponding to a desired size for the bar.
- sorting of elements in one or more chart(s) 230 is accomplished by simply grabbing one or more chart elements using a pointing device, then dragging those elements to whatever new position within the chart is desired.
- adding elements to one or more chart(s) 230 is accomplished by using a pointing device to drag an outline of the desired element (having a desired size or magnitude) onto the chart(s). A new element having the desired size or magnitude is then automatically added to the chart as described in further detail below.
- the chart element change module 260 then automatically modifies the corresponding data elements of the chart data 210 (or adds new values to the chart data) to fit changes made to the chart elements. For example, if a bar in a Bar Chart originally had a value of “10,” then that bar was resized via the chart element change module 260 to show a value of “5” on the display device 155 , then the chart element change module will change the value of the corresponding data element to “5” in the chart data 210 .
- the chart construction module 200 immediately determines new chart parameters corresponding to the modified data elements, and passes those chart parameters to the chart animation rendering module 220 .
- the chart animation rendering module 220 then morphs the existing charts(s) 230 into new chart(s) 230 using a dynamic animation that smoothly transitions from the existing chart(s) to the new chart(s) on the display device 155 .
- a chart compositing module 270 is accessed via the user interface module 240 for creating a composite chart from two or more existing charts 230 .
- the user can use the chart compositing module 270 to specify (or select from a predefined list) some mathematical relationship between two or more existing charts 230 .
- This mathematical relationship is then used to construct a composite chart by passing composite chart parameters to the chart construction module which in turn passes those parameters to the chart animation rendering module which acts to render the composite chart on the display device as an animation that morphs the existing charts into the composite chart. Note that composite charts and predefined chart types, having predefined mathematical relationships, are discussed in greater detail below in Section 3.4.
- Charting Animator provides a computer-based charting/graphing system for rendering dynamic animations of chart displays.
- Charting Animator provides a computer-based charting/graphing system for rendering dynamic animations of chart displays.
- the following sections provide a detailed discussion of the operation of the Charting Animator, and of exemplary methods for implementing the program modules described in Section 2.
- chart data modifications ; chart element selection and modification; animations and techniques for morphing chart element size and shape; and composite charts.
- each chart is defined based on one or more sets of underlying data elements.
- a simple 2D Bar Chart may include data elements representing a magnitude for each of a plurality of bars to be displayed in the Bar Chart.
- the underlying data elements of particular charts may differ depending upon the chart type.
- each chart includes one or more sets of data elements that are used to define the chart parameters used to render those charts (e.g., x-y coordinates of a data point, magnitude of a data point, etc.).
- the extents of one or more of the axes of any displayed chart can also be changed in the same manner as any underlying data element. The result here is that all chart elements will be scaled to fit the new extents of the chart axes without changing the corresponding data elements of those chart elements.
- the Charting Animator provides several techniques for modifying one or more of the data elements of a displayed chart. For example, in one embodiment, data elements are manually changed by the user via a user interface which provides a mechanism for directly editing that data. This is how most conventional charting systems provide for modification of data elements.
- the Charting Animator automatically modifies data elements to correspond to changes made to the graphical elements of a displayed chart.
- each individual graphical element of a chart such as a bar in a Bar Chart, for example, is user selectable and can be directly modified (moved, resized, deleted, combined, etc.) via the user interface.
- any chart element is modified, the underlying data elements are automatically changed to reflect the modification to the corresponding element. For example, if a point on a Line Chart is moved in any direction in response to user interaction with that point, the value of the underlying data element is changed to reflect the new position of that point in the Line Chart. Similarly, if the height of a bar in a Bar Chart is increased, the corresponding data element is also automatically increased by the Charting Animator.
- the Charting Animator provides a two-way one-to-one correspondence between the data elements and the graphical representation of chart elements, such that a change to one is immediately reflected in the other. Further, this correspondence includes related data elements such that any data element that is dependent upon another data element is automatically changed to reflect changes in the related data element.
- a simple example is a case where a first data element is defined as being equal to twice a second data element. Whenever the second data element is changed, either via direct manipulation of the data, or via some modification of the corresponding chart element, the first data element will be automatically changed to maintain the defined relationship between the first and second data elements. Note that this capability also allows the Charting Animator to provide “what-if” type capabilities that allow the user to immediately see what effects changes on one or more data elements might have on other related data elements.
- data elements are changed or created in one of five ways: 1) direct manipulation of a data element via the user interface; 2) as an automatic response to user manipulation of a corresponding chart element; 3) as an automatic response to maintain a predefined relationship (as defined by the chart and/or the user) to another data element that is changed either via the user interface or in response to a change of the corresponding chart element; and 4) as an automatic response to the addition of a chart element to a chart; and 5) as a result of a external “data change” event (from a live data feed, from a hosting application, etc.)
- chart elements are selectable, either individually or in groups or two or more elements.
- chart elements can be selected in a group by selecting entire rows and/or columns of chart elements, depending upon the chart type.
- selection of these chart elements is achieved via a graphical user interface using either a pointing device such as a mouse, trackball, touch screen, etc., or a keyboard, or any desired combination of pointing device and keyboard. Selection of objects in this manner using a graphical user interface (or via selection from a menu listing selectable objects) is a concept that is well known to those skilled in the art, and will not be described in detail herein.
- Charting Animator provides the user with the capability to move, resize, delete, or combine (e.g., stacking bars in a Bar Chart, combining pie slices in a Pie Chart, etc.) those objects via the user interface.
- moving chart elements can be accomplished using a drag and drop type operation.
- Resizing chart elements can be accomplished by grabbing a control handle (typically an edge, corner, or point of the chart element) using a pointing device and/or keyboard, then dragging that control handle to some desired position to resize the chart element.
- Deleting chart elements can be accomplished by simply selecting any chart elements to be deleted, then either pressing a delete button, or selecting a delete option via a context sensitive popup menu, or the like.
- chart elements can be moved within a chart to any location that actually fits the context of the chart. This is interpreted as a manual sort operation.
- the Charting Animator will prevent the user from moving chart elements to locations within a chart that would not be allowed in creating the chart.
- a simple example would be to prevent the user from moving a point in a Line Chart to a position that would create a discontinuity in a continuous function corresponding to some predefined mathematical function or relationship being represented by a Line Chart for graphing that continuous function.
- An example of a permissible move is to allow the user to manually move either a single chart element, or one or more entire rows of chart elements from one place to another.
- the user can move one or more bars to any desired row/column, including a new row/column (which would expand the extents of the original 3D Bar Chart).
- the Charting Animator will decide whether the user initiated move is allowed, and will prevent the move, if necessary.
- Combining chart elements is accomplished in a manner similar to moving chart elements. For example, in one embodiment, chart elements are combined by using a drag and drop type operation to drop one chart element onto another chart element. These chart elements are then automatically combined. However, in one embodiment, the Charting Animator will query the user before combining chart elements to ensure that the user intended a combine operation rather than a move operation.
- the manual sort move operation is distinguished from the combining move operation by the shift key on the keyboard (or any other desired key or mouse button)—for example, in a tested embodiment, holding down the shift key indicates a manual sort move.
- the manual sort move operation is distinguished from the combining move operation based on where the chart element is dropped (i.e., the drop target)—if the drop target is another chart element, it is interpreted as a combining move; if the drop target is between chart elements, it is interpreted as a manual sort move. Further, different visual feedback is provided while dragging chart elements to indicate to the user which operation will be done on drop.
- Adding new chart elements to a chart is accomplished by either drawing a new chart element on the chart, or by selecting a chart element from a menu of chart elements, then dragging that selected chart element to the desired position on the chart (like moving a chart element) then sizing that chart element to the desired size.
- data elements corresponding to newly added chart elements are automatically created as soon as the chart element is added by the user.
- some data charts and/or data sets include “direct manipulation constraints”—metadata or other information that describes how the data can be changed through direct manipulation (e.g., data that must be specified in increments of 100, or data that must be within a specified minimum and maximum). This allows the user to get immediate feedback during manipulation on what values are allowed (vs. changing the value, finishing the UI operation, and then having to response to an “illegal value” type error message).
- direct manipulation constraints metadata or other information that describes how the data can be changed through direct manipulation
- Charting Animator allows user selection of one or more chart elements of any displayed chart to allow the user to move, resize, delete, combine, or add any of those chart elements. Changes to any chart element are automatically reflected in the underlying data elements and in any related or dependent data elements.
- the Charting Animator provides graphical displays of animated transitions that morph one chart into another whenever any of the underlying data elements defining any chart element are changed.
- changes to the underlying data elements occur in any of several ways, including, for example, direct user editing or modification of those data elements, as an automatic response to user modification of a corresponding chart element, or as an automatic response to maintain a predefined relationship to other data elements that are modified.
- animations take one of several different forms, depending upon the change being made or requested by the user.
- the chart type of the displayed chart is maintained when a user changes either any data elements of the chart or any chart elements of the chart.
- the animation will be generally limited to simply rendering animated morphing to resize and/or reposition any chart elements affected by user's changes.
- the chart type of the displayed chart is changed to another chart type, either in the same chart family, or in a different chart family (e.g., changing a pie chart to a bar chart).
- the underlying data elements are not changed by user action. Instead, the user simply selects a new chart type from a menu of available chart types and/or families. The displayed chart is then morphed into the newly selected chart type. For example, the same data can be used to render either bars in a Bar Chart or pie slices in a Pie Chart.
- an animation for morphing a 2D Bar Chart into a 3D Bar Chart that includes additional sets of data uses an animation where the row of bars (i.e., the x-axis, assuming vertical bars) from the 2D chart is the only row on an otherwise empty 3D floor. Then, in continuing the transition to the 3D chart, new rows (representing the additional sets of data) “grow” up from the floor as part of the transition animation. Conversely, when transitioning from a 3D Bar Chart to a 2D Bar Chart, the user will select a row to focus on before the transition. All other rows will then drop into the floor and disappear. Then the remaining row will transition to a 2D bar chart.
- these simple examples describe one way of many ways in which such transitions can be animated by the Charting Animator. As such, these examples are not intended to limit the type, scope, or order of transition effects, and are intended for purposes of explanation only.
- transition animations the general idea is to present the user with a smooth transition from the displayed chart type to the selected chart type. Therefore, geometric shapes are morphed, as needed, along with the shape of the chart itself, to create the newly selected chart. Further, since many chart elements may need to be changed, multiple animations are either chained together in a sequence, or rendered in parallel to provide a smoother transition from the original chart to the new chart.
- the Charting Animator provides the capability to rotate charts in multiple dimensions as another animation, and to allow the user to manually rotate 3D charts to a desired viewpoint.
- the capability to rotate charts is also useful for chart type changes that include transitions to a higher or lower dimensionality (e.g., transitioning from a 2D Bar Chart to a 3D Bar Chart).
- the primary animation is an animated movement from a virtual camera viewpoint to a different view point (e.g., a movement from a front view of the 2D chart to a perspective view of the 3D chart).
- the Charting Animator has the ability to morph chart elements of one shape into chart elements of another shape, such as, for example, morphing to or from a rectangle to a line segment, area segment, or pie slice. This morphing is generally accomplished by moving existing points of the various chart elements to create the new shapes, then rendering intermediate shapes to create the animated transition. Further, in addition to moving points to define a new shape, the Charting Animator introduces new points as needed. For example, a pie slice requires many more points than a rectangular bar of a Bar Chart; so, when transitioning from a bar to a pie slice, more points are added—and when transitioning away from a pie slice, those extra points are eliminated.
- Changing the shape of chart elements from one shape to another such as, for example, changing a rectangular bar of a Bar Chart to a polygon of an Area Chart, or changing a rectangular bar of a Bar Chart to a pie slice of a Pie Chart is accomplished by smoothly morphing the chart element from the original shape to the new shape to provide an animated transition between the shapes.
- This morphing can be accomplished using any of a number of morphing techniques.
- FIG. 3 a rectangular bar of a Bar Chart is morphed into a polygon of an Area Chart. Note that this example is not intended to limit the way in which shapes are morphed, and is provided only as a simple illustration of shape morphing techniques that may be utilized by the Charting Animator.
- a rectangle 300 defined by corner points ⁇ A, B, C, D ⁇ is changed to polygon 310 by translating point B by offset Y 2 , and translating point C by offset Y 2 .
- any of the four points of rectangle 300 can be translated in either the X or Y direction to provide the desired shape.
- translating some or all of the points, depending upon the shape is used for scaling the shape.
- translating two or more of points A, B and C towards (or away from) point D can be used to scale the size of rectangle 300 either up or down.
- any one of the four points of rectangle 300 can be collapsed into another of those points to create a triangle from the rectangle 300 .
- the animation from the original shape to the new shape is created by simply rendering a sequence of intermediate images in steps as small as one pixel for each point, over some period of time.
- FIG. 4 provides an example of one way in which a rectangular bar of a Bar Chart is morphed into a pie slice of a Pie Chart. Again, this example is not intended to limit the way in which shapes are morphed, and is provided only as a simple illustration of shape morphing techniques that may be utilized by the Charting Animator.
- a rectangle 400 defined by corner points ⁇ A, B, C, D ⁇ is changed to a pie slice 420 via at least one intermediate image step 410 .
- points A and B in the rectangle 300 are moved towards new point E in the intermediate shape 410 .
- the result is the triangular shape 410 .
- the line between points C and D is divided into a plurality of additional points, such as points ⁇ C, D, F, G, H, I ⁇ that will be used to provide the curved side of the pie slice 420 .
- each of these points ⁇ C, D, F, G, H, I ⁇ is translated to form an arc, with the end result being the pie slice 420 .
- these transitions can be animated either in series or in parallel to provide the desired effect.
- Translating each of these points, A through I, in the shape sequence 400 through 420 , in steps of at least one pixel, then rendering a set of corresponding intermediate shapes creates a smooth animation that morphs the rectangle 400 into the pie slice 420 .
- Similar transitions are used to morph line thicknesses, or to transition from a line to a polygon.
- the thickness of a line 510 defined by points ⁇ A, B ⁇ can be changed by specifying some line thickness 520 , then spreading points A and B into points C and D, respectively by the amount of the desired line thickness.
- the same technique effectively creates a four-point polygon from a two point line.
- including an offset value 530 allows for rotation of the resulting line or polygon.
- morphing of 3D chart elements is handled in a similar manner to the 2D morphing examples provided above.
- a bar in a 2D Bar Chart has 4 points defining one face.
- the transition from the 2D to the 3D case (or from the 3D to the 2D case) is a simple matter of extruding (or collapsing points), and of translating or rotating points to a new viewpoint, to define a sequence of intermediate shapes, then rendering those shapes to create the animations for each chart element.
- the Charting Animator also provides the capability to combine two or more charts to create a new chart a direct composition of one or more existing charts.
- One advantage of this embodiment is that two or more relatively simple charts can be combined to compose a more complex composite chart.
- charts are combined using various techniques, including, for example, drag and drop type operations where one displayed chart is dropped onto another, or by selecting charts to be combined, along with a selection of a desired composite chart type from a menu, list, button, or the like.
- the Charting Animator provides the capability for the user to define and store custom composite chart types that may then be selected at a later time.
- composition of charts is accomplished by selecting two or more charts to be overlaid on one another.
- the charts can be, but are not necessarily related, via some mathematical relationship.
- the Charting Animator renders an animation that scales and aligns the charts to fit each other along one or more common axes to create the new composite chart.
- two or more charts are combined by providing a user menu for selecting from a set of one or more predefined mathematical chart relationships, or allowing the user to define one or more new mathematical chart relationships.
- the Charting Animator acts to render the two or more charts being combined along with the new composite chart.
- these charts are related via some mathematical relationship, they will share one or more common axes.
- the Charting Animator renders all of the charts (the charts being combined and the new composite chart) together in a single display (that may include overlapping or adjacent charts, depending upon the composite chart type being rendered) relative to the common axes.
- Quantity Flow Diagram One example of a composite chart having a mathematical relationship to the charts used to construct the composite chart is termed a “Quantity Flow Diagram.”
- the Quantity Flow Diagram is a composite chart constructed from two existing charts: 1) a 2D Bar Chart 610 that includes dates and amounts of incoming quantities; and 2) a 2D Bar Chart 620 that includes dates and amounts of outgoing quantities. Examples of incoming and outgoing quantities include cash flow and material (inventory) availability, to name only two such examples.
- the user will first select two 2D Bar Charts ( 610 and 620 ) and designate one as being subtracted from the other (i.e., the user will select or specify the mathematical relationship between the charts).
- the Charting Animator then constructs the Quantity Flow Diagram 640 as a composite chart that shows incoming quantities in the first 2D Bar Chart 610 (positive bars trending up from a common axis), the second 2D Bar Chart 620 below the first 2D Bar Chart 610 that shows the outgoing quantities (negative bars trending down from the common axis), and a Plateau Chart 630 below the first and second 2D Bar Charts showing the quantity on-hand (as changed by the two in/out quantities ( 610 and 620 ) over time).
Landscapes
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Processing Or Creating Images (AREA)
Abstract
A “Charting Animator” enhances computer-based charting/graphing systems by rendering dynamic animations of chart transitions. In general, when a user changes from one chart type to another, adds new data to a chart, or changes, sorts or deletes data, a new chart is generated to replace the old chart. Conventional charting systems simply replace the existing chart with the new chart. In contrast to conventional systems, the Charting Animator renders animated transitions that dynamically morph the original chart into the new chart. Consequently, these animations avoid abrupt changes that can disorient users. Examples of these animations include animating changes from one chart family to another (e.g., changing from a “Bar Chart” to a “Pie Chart”), animating changes from one chart type within a chart family to another chart type (e.g., changing 2D Bar Charts to 3D Bar Charts or Stacked Bar Charts), animating data changes, animating sorts, etc.
Description
- This application is a Continuation Application of U.S. patent application Ser. No. 11/674,115, filed on Feb. 12, 2007, by Robertson, et al., and entitled “ANIMATED TRANSITIONS FOR DATA VISUALIZATION,” and claims the benefit of that prior application under Title 35, U.S. Code,
Section 120. - 1. Technical Field
- The invention is related to computer-based data charting and graphing, and in particular, to a system for automatically animating transitions when changing from one chart or graph type to another and/or when changing data values associated with those charts and graphs.
- 2. Related Art
- Computer-based charting and graphing software tools are well known to those skilled in the art. Such software tools are often used to generate data displays such as, for example, pie charts, bar charts, data graphs, etc. Conventionally, these types of software tools allow a user to select or enter one or more data sets, and then select a chart type for rendering a chart or graph display of that data. Then, whenever a user changes from one chart type to another, or whenever data is added or changed, a new chart is rendered and the original chart is simply replaced by the newly rendered chart. However, while not animating changes between charts, when presenting a new chart, some conventional software tools will animate bars of data growing from a “no data” state to the current data (either one bar at a time or all bars in parallel).
- One of the problems with simply replacing one chart with another is that the user doesn't really get a sense of how the data has changed, especially if those changes are subtle or if they involve multiple data elements (such as changes to several related bars in a bar chart). Further, since one chart simply replaces another (at computer display rendering speeds), the change is essentially immediate. Unfortunately, this type of abrupt change is often disorienting to users.
- Another feature of conventional charting and graphing software tools is that data is entered, and then the corresponding charts and/or graphs are rendered as a function of the data. Changes to those charts and graphs are accomplished by editing or otherwise changing the underlying data, at which point these conventional software tools will render a new chart or graph corresponding to the newly edited data. Unfortunately, this feature is typically one-way. In other words, charts and graphs are changed by direct manipulation of the underlying data, while the underlying data is not changed by direct manipulation of the corresponding chart or graph.
- This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
- A “Charting Animator” enhances computer-based charting/graphing systems by rendering dynamic animations of chart display transitions. In general, when a user changes from one chart type to another, when new data is added to a chart, or when existing data is changed, sorted or deleted, a new chart appears to replace the old chart. Conventional charting systems simply replace the existing chart with a new chart. However, unlike conventional charting systems, the Charting Animator renders an animated transition for dynamically morphing the original chart into the new chart.
- Consequently, the animation provided by the Charting Animator avoids abrupt changes that can be disorienting to users. Examples of the animations provided by the Charting Animator include animating changes from one chart family to another (e.g., changing a “Bar Chart” into a “Pie Chart”, etc.), changes from one chart type within a chart family to another chart type (e.g., changing from a “2D Bar Chart” into a “3D Bar Chart” or a “Stacked Bar Chart”, etc.), changes to data, etc. In general, these animations are timed to occur over a relatively short period of time that allows the user to visually perceive changes to displayed charts while being sufficiently short in time so that users do not perceive that they are waiting for the system. However, any desired animation length, including varying length for different types animations are enabled by the Charting Animator.
- Further, in various embodiments, elements of the displayed charts are user selectable and provide direct interactive manipulation and feedback with the underlying data. For example, in various embodiments, the Charting Animator provides the capability to directly manipulate elements of charts, such as, for example, the height of one or more bars in a bar chart, the size of a slice in a pie chart, individual peaks or points in a line chart, etc. Other direct manipulation includes moving chart elements from one location to another, including stacking or combining elements of the chart. For example, stacking one bar on top of another in a bar chart will serve to combine those bars into a single element, thereby combining the underlying data into a single data set. In related embodiments, the Charting Animator allows combined elements or data sets to be separated back out at a later time, if desired.
- Similarly, the Charting Animator provides the capability to directly add or delete elements from a chart, thereby creating, or deleting, an underlying data set. For example, inserting a new rectangular bar in a Bar Chart will create a corresponding data element for the new bar element, while deleting a pie slice from a pie chart will delete the underlying data element and expand the relative sizes of the remaining slice elements of the Pie Chart.
- In either case, a change to any chart elements via direct manipulation, insertion, or deletion causes the Charting Animator to immediately modify the underlying data, as well as any interrelated data or chart elements. Further, in various embodiments, the Charting Animator combines animation embodiments with direct manipulation embodiments. For example, in one combination embodiment, as the user manipulates one graphical element of a chart, such as, for example, the height of a bar in a bar chart, the underlying data set will change in correspondence to the graphical change. Simultaneously, any related data sets that are dependent upon the underlying data being changed by manipulation of the graphical element will also be automatically changed, with corresponding animations being simultaneously rendered for the corresponding graphical elements of the chart.
- Finally, in yet another embodiment, the Charting Animator provides the capability to construct “composite charts” as a composition of one or more existing charts. As a result, two or more relatively simple charts can be combined to compose a more complex composite chart. Further, the Charting Animator described herein provides the capability to predefine composite chart types for user selection. A simple example of a composite chart enabled by the Charting Animator is termed a “Quantity Flow Diagram.”
- An example of a Quantity Flow Diagram is a composite data set that includes dates and amounts of incoming quantities and dates and amounts of outgoing quantities, such as, for example, cash flow or material (inventory) availability. Given this example data set, the Charting Animator constructs the Quantity Flow Diagram as a composite chart that shows incoming quantities in a first Bar Chart (positive bars trending up from a common axis), a second Bar Chart below the first that shows the outgoing quantities (negative bars trending down from the common axis), and a Plateau Chart below the first and second Bar Charts showing the quantity flow (the difference of the two quantities over time). Further, all of the elements of this three part composite chart are interrelated. Therefore, in one embodiment, changes made to any one element of the composite chart (or to the underlying data) will be immediately reflected in all related underlying data, as described above, with those changes also being rendered as an animation to any corresponding chart elements.
- In view of the above summary, it is clear that the Charting Animator described herein provides a unique system and method for rendering dynamic animations of chart displays and for manipulating the underlying data of those chart displays. In addition to the just described benefits, other advantages of the Charting Animator will become apparent from the detailed description which follows hereinafter when taken in conjunction with the accompanying drawing figures.
- The specific features, aspects, and advantages of the present invention will become better understood with regard to the following description, appended claims, and accompanying drawings where:
-
FIG. 1 is a general system diagram depicting a general-purpose computing device constituting an exemplary system for implementing various elements of a Charting Animator, as described herein. -
FIG. 2 illustrates an exemplary architectural system diagram showing exemplary program modules for implementing various embodiments of the Charting Animator, as described herein. -
FIG. 3 illustrates an exemplary method for animating graphical transitions between a Bar Chart element and an Area Chart element for enabling various chart type and chart family morphing embodiments of the Charting Animator, as described herein. -
FIG. 4 illustrates an exemplary method for animating graphical transitions between a Bar Chart element and a Pie Chart element for enabling various chart type and chart family morphing embodiments of the Charting Animator, as described herein. -
FIG. 5 illustrates an exemplary method for animating graphical transitions of line elements of a line chart for enabling various chart type and chart family morphing embodiments of the Charting Animator, as described herein. -
FIG. 6 Illustrates an example of a composite chart comprising a “Quantity Flow Diagram” produced by the Charting Animator, as described herein. - In the following description of various embodiments of the present invention, reference is made to the accompanying drawings, which form a part hereof, and in which is shown by way of illustration specific embodiments in which the invention may be practiced. It is understood that other embodiments may be utilized and structural changes may be made without departing from the scope of the present invention.
-
FIG. 1 illustrates an example of a simplified computing environment on which various embodiments and elements of a “Charting Animator,” as described herein, may be implemented. It should be noted that any boxes that are represented by broken or dashed lines inFIG. 1 represent alternate embodiments of the simplified computing environment, as described herein, and that any or all of these alternate embodiments, as described below, may be used in combination with other alternate embodiments that are described throughout this document. - At a minimum, to enable a computing device to implement the “Charting Animator” (as described in further detail below), the computing device must have at least some minimum computational capability, a display device, an optional input device, and some local or remote data storage and access capability.
- In general,
FIG. 1 illustrates an exemplarygeneral computing system 100. Thecomputing system 100 is only one example of a suitable computing environment and is not intended to suggest any limitation as to the scope of use or functionality of the invention. Neither should thecomputing system 100 be interpreted as having any dependency or requirement relating to any one or combination of components illustrated in theexemplary computing system 100. - In fact, the invention is operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well known computing systems, environments, and/or configurations that may be suitable for use with the invention include, but are not limited to, personal computers, server computers, hand-held, laptop or mobile computer or communications devices such as cell phones, PDA's, pocket PC's or media players, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
- The invention may be described in the general context of computer-executable instructions, such as program modules, being executed by a computer or a computing device in combination with various hardware modules. Generally, program modules include routines, programs, objects, components, data structures, etc., that perform particular tasks or implement particular abstract data types. The invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote computer storage media including memory storage devices.
- For example, with reference to
FIG. 1 , an exemplary system for implementing the invention includes a general-purpose computing device in the form ofcomputing system 100. Components of thecomputing system 100 may include, but are not limited to, one ormore processing units 110, asystem memory 120, one ormore communications interfaces 130, one or more input and/or output devices, 140 and 150, respectively, anddata storage 160 that is removable and/or non-removable, 170 and 180, respectively. In addition, thecomputing system 100 may access data remotely via thecommunications interface 130. - The
communications interface 130 is generally used for connecting thecomputing device 100 to other devices via any conventional interface or bus structure, such as, for example, an Ethernet port, a parallel port, a game port, a universal serial bus (USB), an IEEE 1394 interface, a Bluetooth™ wireless interface, an IEEE 802.11 wireless interface, GSM cell phone network, etc.Such interfaces 130 are generally used to transfer information, data, or program modules to or from thecomputing device 100. - The
input devices 140 generally include devices such as a keyboard and pointing device, commonly referred to as a mouse, trackball, or touch pad. Such input devices may also include other devices such as a joystick, game pad, satellite dish, scanner, GPS receiver, radio receiver, and a television or broadcast video receiver, or the like.Conventional output devices 150 include elements such as a computer monitors or other display devices, audio output devices, etc.Other input 140 andoutput 150 devices may include speech or audio input devices, such as a microphone or a microphone array, loudspeakers or other sound output device, etc. - The
data storage 160 ofcomputing device 100 typically includes a variety of computer readable storage media. Computer readable storage media can be any available media that can be accessed by computingdevice 100 and includes both volatile and nonvolatile media, removable and non-removable media. By way of example, and not limitation, computer readable media may comprise computer storage media and communication media. Computer storage media includes volatile and nonvolatile removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules, or other data. - Computer storage media includes, but is not limited to, RAM, ROM, PROM, EPROM, EEPROM, flash memory, or other memory technology; CD-ROM, digital versatile disks (DVD), or other optical disk storage; magnetic cassettes, magnetic tape, magnetic disk storage, hard disk drives, or other magnetic storage devices. Computer storage media also includes any other medium or communications media which can be used to store, transfer, or execute the desired information or program modules, and which can be accessed by the
computing device 100. Communication media typically embodies computer readable instructions, data structures, program modules or other data provided via any conventional information delivery media or system. - The
computing device 100 may also operate in a networked environment using logical connections to one or more remote computers, including, for example, a personal computer, 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 thecomputing device 100. - The exemplary operating environments having now been discussed, the remaining part of this description will be devoted to a discussion of the program modules and processes embodying the “Charting Animator.”
- A “Charting Animator,” as described herein, enhances computer-based charting/graphing systems by rendering dynamic animations of chart displays. In various embodiments, the Charting Animator provides animated chart transitions in response to various user actions (e.g., changing from one chart type to another, adding new data to a chart, changing, sorting or deleting data, modifying one or more chart elements via selection and manipulation of those elements, etc.). Note also that in one embodiment, animated chart transitions are initiated in response to automatic changes to the data (e.g., live data changes such as real-time stock quotes, sensor readings, reviewing sequences of recorded or simulated data or query changes, etc.). In either case, the result of the animated transition is to provide an animation that replaces the original chart by dynamically morphing the original chart into the new chart. Consequently, these animations avoid abrupt changes that can disorient users. Examples of these animations include animating changes from one chart family to another (e.g., changing from a “Bar Chart” to a “Pie Chart”), animating changes from one chart type within a chart family to another chart type (e.g., changing a Bar Chart to a 3D Bar Chart or a Stacked Bar Chart), animating changes to data, etc.
- Note that the concept of “chart types” and “chart families” is well known to those skilled in the art. In general, a chart family includes one or more chart types. For example, conventional “2D Bar Charts,” “3D Bar Charts,” and “Stacked Bar Charts” are members (chart types) of the more generic “Bar Chart” family. Examples of distinct chart families include “Bar Charts,” “Pie Charts,” “Area Charts,” “Line Charts,” etc. One of the advantages of the animated transitions provided by the Charting Animator is that these transitions provide the user with a visual indication of what changes are occurring when changing from one chart type to another (e.g., animating a transition from a 2D Bar Chart to a 3D Bar Chart), or from one chart family to another (e.g., animating a transition from a 3D Bar Chart to a Pie Chart).
- As noted above, the Charting Animator described herein provides a computer-based charting/graphing system for rendering dynamic animations of chart displays, including, for example, Bar Charts, Pie Charts, Area Charts, Line Charts, etc. In general, these dynamic animations operate to dynamically morph an original chart into a new chart to reflect changes either to the underlying data values defining elements of the original chart or to graphical elements of the original chart via user interaction with those elements via a graphical user interface.
- For example, when a user changes from one “chart type” or “chart family” to another, when new data is added to a chart, or when existing data is changed, sorted or deleted, a new chart appears to replace the old chart. However, in contrast to conventional charting systems, the Charting Animator dynamically morphs one or more elements of the original chart into one or more elements in the new chart to provide an animated transition that smoothly changes the original chart into the new chart.
- In additional embodiments, the Charting Animator provides the capability for user selection and manipulation of one or more of the graphical elements of charts. This user selection and manipulation capability is combined with automatic interactive feedback with the underlying data. For example, if the user resizes the height of one or more bars in a Bar Chart (using conventional drag and drop type computer operations) the Charting Animator will automatically amend the underlying data to correspond to the new height of the resized bar elements of that Bar Chart.
- Similarly, in a related embodiment, the Charting Animator provides the capability to directly add or delete elements from a chart, thereby creating, or deleting, an underlying data set. For example, inserting a new bar element in a Bar Chart will automatically cause the Charting Animator to create a corresponding data set for the new bar element. Similarly, deleting a pie slice from a Pie Chart will delete the underlying data set and cause the Charting Animator to expand the relative sizes of the remaining pie slice elements of the pie chart, with the expansion of the pie slice elements being animated, as described in further detail below in
Section 3. - Finally, in yet another embodiment, the Charting Animator provides the capability to construct “composite charts” by combining one or more existing charts. In particular, these composite charts represent a combination of two or more charts that are combined to compose a more complex composite chart. In one embodiment, both the underlying charts and the composite charts are displayed together to provide the user with a better understanding of how the data of the underlying charts relates to the composite chart.
- The processes summarized above are further illustrated by the general system diagram of
FIG. 2 . In particular, the system diagram ofFIG. 2 illustrates the interrelationships between program modules for implementing the Charting Animator, as described herein. It should be noted that any boxes and interconnections between boxes that are represented by broken or dashed lines inFIG. 2 represent alternate embodiments of the Charting Animator described herein, and that any or all of these alternate embodiments, as described below, may be used in combination with other alternate embodiments that are described throughout this document. - In general, as illustrated by
FIG. 2 , the Charting Animator generally begins operation by using achart construction module 200 to define parameters used to construct one or more charts (e.g., Pie Charts, Bar Charts, Line Charts, Area Charts, Plateau Charts, etc.) using one or more sets ofchart data 210. Thechart construction module 200 then provides these parameters to a chartanimation rendering module 220 which renders the chart(s) 230 on thedisplay device 155. - Once the chart(s) 230 have been rendered on the
display device 155 changes to the rendered chart(s) are enabled using any of several embodiments. For example, in one embodiment, auser interface module 240 is used to modify one or more of data elements comprising thechart data 210 via adata input module 250. Modifications to these data elements include changing the value of one or more of the data elements, adding one or more data elements, and deleting one or more data elements. In general, these data elements are maintained in a conventional computer readable format, such as, for example, in a list, table, database, etc. Consequently, direct modifications to the data elements by using a user interface to change the data elements via thedata input module 250 is accomplished using conventional techniques. - As soon as any data elements have been modified, the
chart construction module 200 immediately determines new chart parameters corresponding to the modified data elements, and passes those chart parameters to the chartanimation rendering module 220. At this point, the chartanimation rendering module 220 then morphs the existing charts(s) 230 into new chart(s) 230 using a dynamic animation that smoothly transitions from the existing chart(s) to the new chart(s) on thedisplay device 155. - In another embodiment, changes to the rendered chart(s) 230 are enabled by directly modifying one or more elements of the chart(s), such as, for example, resizing the height of one or more bars on a Bar Chart, or changing the size of a pie slice in a Pie Chart. In various embodiments, direct modification of the elements of the chart(s) is accomplished via the
user interface module 240 which allows the user to select one or more individual elements of one ormore charts 230 using a graphical user interface provided via a chartelement change module 260. This graphical user interface provides a graphical interface to chart(s) 230 being rendered on thedisplay device 155 for resizing, moving, sorting, or deleting one or more of those chart elements. Similarly, chart elements can also be added to one or more of the chart(s) 230 via the graphical user interface provided by the chartelement change module 260. - Clearly, there are a number of conventional techniques for providing user interaction with graphical elements being rendered on a display device, including, for example, the use of keyboard controls, mice or other pointing devices, the use of a touch screen, voice commands, etc. While such techniques are generally well known in the art, they have not previously been applied to conventional charting systems. The Charting Animator is capable of operating with any such techniques. However, rather than describe each such technique, the following discussion will simply describe one example for purposes of explanation.
- For example, in one embodiment, resizing, moving, sorting, or deleting elements in the chart(s) 230 is accomplished using conventional drag and drop-type computer interaction with the displayed charts. For example, in one embodiment, resizing a bar in a Bar Chart is accomplished by selecting one corner or edge of the bar with a pointing device, then dragging that edge or corner to a desired position corresponding to a desired size for the bar. Similarly, in a related embodiment, sorting of elements in one or more chart(s) 230 is accomplished by simply grabbing one or more chart elements using a pointing device, then dragging those elements to whatever new position within the chart is desired. Similarly, in another embodiment, adding elements to one or more chart(s) 230 is accomplished by using a pointing device to drag an outline of the desired element (having a desired size or magnitude) onto the chart(s). A new element having the desired size or magnitude is then automatically added to the chart as described in further detail below.
- In particular, as soon as any chart elements have been modified (by resizing, moving, sorting, deleting, adding, etc.), the chart
element change module 260 then automatically modifies the corresponding data elements of the chart data 210 (or adds new values to the chart data) to fit changes made to the chart elements. For example, if a bar in a Bar Chart originally had a value of “10,” then that bar was resized via the chartelement change module 260 to show a value of “5” on thedisplay device 155, then the chart element change module will change the value of the corresponding data element to “5” in thechart data 210. - In addition, depending upon the chart(s) being displayed, many of the chart elements are often interdependent. Consequently, changes to one data element (either via the
data input module 250, or via the chart element change module 260) used to construct the chart will often have an effect either on other data values, or on the displayed chart(s) 230. For example, if a pie slice in a Pie Chart is deleted or resized, or the underlying data value is changed, the other slices in the Pie Chart must be resized so that the Pie Chart retains a full pie shape. Therefore, whenever a change to data elements of thechart data 210 occurs (by any mechanism described herein), thechart construction module 200 immediately determines new chart parameters corresponding to the modified data elements, and passes those chart parameters to the chartanimation rendering module 220. At this point, the chartanimation rendering module 220 then morphs the existing charts(s) 230 into new chart(s) 230 using a dynamic animation that smoothly transitions from the existing chart(s) to the new chart(s) on thedisplay device 155. - Finally, in yet another embodiment, a
chart compositing module 270 is accessed via theuser interface module 240 for creating a composite chart from two or more existingcharts 230. In general, the user can use thechart compositing module 270 to specify (or select from a predefined list) some mathematical relationship between two or more existingcharts 230. This mathematical relationship is then used to construct a composite chart by passing composite chart parameters to the chart construction module which in turn passes those parameters to the chart animation rendering module which acts to render the composite chart on the display device as an animation that morphs the existing charts into the composite chart. Note that composite charts and predefined chart types, having predefined mathematical relationships, are discussed in greater detail below in Section 3.4. - The above-described program modules are employed for implementing the Charting Animator described herein. As summarized above, this Charting Animator provides a computer-based charting/graphing system for rendering dynamic animations of chart displays. The following sections provide a detailed discussion of the operation of the Charting Animator, and of exemplary methods for implementing the program modules described in
Section 2. In particular, the following paragraphs describe chart data modifications; chart element selection and modification; animations and techniques for morphing chart element size and shape; and composite charts. - In general, each chart is defined based on one or more sets of underlying data elements. For example, a simple 2D Bar Chart may include data elements representing a magnitude for each of a plurality of bars to be displayed in the Bar Chart. Clearly, the underlying data elements of particular charts may differ depending upon the chart type. However, as with any conventional charting system, the basic idea is that each chart includes one or more sets of data elements that are used to define the chart parameters used to render those charts (e.g., x-y coordinates of a data point, magnitude of a data point, etc.). Note also that the extents of one or more of the axes of any displayed chart can also be changed in the same manner as any underlying data element. The result here is that all chart elements will be scaled to fit the new extents of the chart axes without changing the corresponding data elements of those chart elements.
- The Charting Animator provides several techniques for modifying one or more of the data elements of a displayed chart. For example, in one embodiment, data elements are manually changed by the user via a user interface which provides a mechanism for directly editing that data. This is how most conventional charting systems provide for modification of data elements.
- Alternately, in another embodiment, the Charting Animator automatically modifies data elements to correspond to changes made to the graphical elements of a displayed chart. For example, as described in further detail in Section 3.2, each individual graphical element of a chart, such as a bar in a Bar Chart, for example, is user selectable and can be directly modified (moved, resized, deleted, combined, etc.) via the user interface.
- Whenever any chart element is modified, the underlying data elements are automatically changed to reflect the modification to the corresponding element. For example, if a point on a Line Chart is moved in any direction in response to user interaction with that point, the value of the underlying data element is changed to reflect the new position of that point in the Line Chart. Similarly, if the height of a bar in a Bar Chart is increased, the corresponding data element is also automatically increased by the Charting Animator.
- In other words, in various embodiments, the Charting Animator provides a two-way one-to-one correspondence between the data elements and the graphical representation of chart elements, such that a change to one is immediately reflected in the other. Further, this correspondence includes related data elements such that any data element that is dependent upon another data element is automatically changed to reflect changes in the related data element. A simple example is a case where a first data element is defined as being equal to twice a second data element. Whenever the second data element is changed, either via direct manipulation of the data, or via some modification of the corresponding chart element, the first data element will be automatically changed to maintain the defined relationship between the first and second data elements. Note that this capability also allows the Charting Animator to provide “what-if” type capabilities that allow the user to immediately see what effects changes on one or more data elements might have on other related data elements.
- In addition, in the case where a chart element is added to a chart, as described in Section 3.2, a corresponding data element, or set of data elements, depending upon the type of chart element being added, is automatically created by the Charting Animator.
- In summary, data elements are changed or created in one of five ways: 1) direct manipulation of a data element via the user interface; 2) as an automatic response to user manipulation of a corresponding chart element; 3) as an automatic response to maintain a predefined relationship (as defined by the chart and/or the user) to another data element that is changed either via the user interface or in response to a change of the corresponding chart element; and 4) as an automatic response to the addition of a chart element to a chart; and 5) as a result of a external “data change” event (from a live data feed, from a hosting application, etc.)
- As noted above, in various embodiments, some or all chart elements (points, lines, bars, pie slices, etc.) are selectable, either individually or in groups or two or more elements. Similarly, chart elements can be selected in a group by selecting entire rows and/or columns of chart elements, depending upon the chart type. In any case, selection of these chart elements is achieved via a graphical user interface using either a pointing device such as a mouse, trackball, touch screen, etc., or a keyboard, or any desired combination of pointing device and keyboard. Selection of objects in this manner using a graphical user interface (or via selection from a menu listing selectable objects) is a concept that is well known to those skilled in the art, and will not be described in detail herein.
- In general, once one or more chart elements are selected, they are treated as a type of dynamic graphical object, and the Charting Animator provides the user with the capability to move, resize, delete, or combine (e.g., stacking bars in a Bar Chart, combining pie slices in a Pie Chart, etc.) those objects via the user interface.
- In particular, moving chart elements can be accomplished using a drag and drop type operation. Resizing chart elements can be accomplished by grabbing a control handle (typically an edge, corner, or point of the chart element) using a pointing device and/or keyboard, then dragging that control handle to some desired position to resize the chart element. Deleting chart elements can be accomplished by simply selecting any chart elements to be deleted, then either pressing a delete button, or selecting a delete option via a context sensitive popup menu, or the like.
- In one embodiment, chart elements can be moved within a chart to any location that actually fits the context of the chart. This is interpreted as a manual sort operation. In this respect, the Charting Animator will prevent the user from moving chart elements to locations within a chart that would not be allowed in creating the chart. A simple example would be to prevent the user from moving a point in a Line Chart to a position that would create a discontinuity in a continuous function corresponding to some predefined mathematical function or relationship being represented by a Line Chart for graphing that continuous function. An example of a permissible move is to allow the user to manually move either a single chart element, or one or more entire rows of chart elements from one place to another. For example, in a 3D Bar Chart, the user can move one or more bars to any desired row/column, including a new row/column (which would expand the extents of the original 3D Bar Chart). Again, the Charting Animator will decide whether the user initiated move is allowed, and will prevent the move, if necessary.
- Combining chart elements is accomplished in a manner similar to moving chart elements. For example, in one embodiment, chart elements are combined by using a drag and drop type operation to drop one chart element onto another chart element. These chart elements are then automatically combined. However, in one embodiment, the Charting Animator will query the user before combining chart elements to ensure that the user intended a combine operation rather than a move operation.
- In one embodiment, the manual sort move operation is distinguished from the combining move operation by the shift key on the keyboard (or any other desired key or mouse button)—for example, in a tested embodiment, holding down the shift key indicates a manual sort move. In another embodiment, the manual sort move operation is distinguished from the combining move operation based on where the chart element is dropped (i.e., the drop target)—if the drop target is another chart element, it is interpreted as a combining move; if the drop target is between chart elements, it is interpreted as a manual sort move. Further, different visual feedback is provided while dragging chart elements to indicate to the user which operation will be done on drop.
- Adding new chart elements to a chart is accomplished by either drawing a new chart element on the chart, or by selecting a chart element from a menu of chart elements, then dragging that selected chart element to the desired position on the chart (like moving a chart element) then sizing that chart element to the desired size. As noted above in Section 3.1, data elements corresponding to newly added chart elements are automatically created as soon as the chart element is added by the user.
- In making any of the above described modifications to chart elements (moving, resizing, deleting, combining, or adding), the accuracy of the display device, pointing device, and/or keyboard may become an issue, depending upon what changes are being made to the chart elements, and on the scale being used to render the chart. Consequently, in one embodiment, as modifications (such as resizing, for example) are being made to a chart element, a numerical readout of the values of data elements that will be created or changed is displayed while the user is making those modifications to the chart element. This embodiment is useful for ensuring that the modified element has whatever values are desired by the user. Further, once the chart element has been modified, the user can directly edit the underlying data elements, as described in Section 3.1, if necessary to address further accuracy issues.
- In addition, in various embodiments, some data charts and/or data sets include “direct manipulation constraints”—metadata or other information that describes how the data can be changed through direct manipulation (e.g., data that must be specified in increments of 100, or data that must be within a specified minimum and maximum). This allows the user to get immediate feedback during manipulation on what values are allowed (vs. changing the value, finishing the UI operation, and then having to response to an “illegal value” type error message).
- In summary, the Charting Animator allows user selection of one or more chart elements of any displayed chart to allow the user to move, resize, delete, combine, or add any of those chart elements. Changes to any chart element are automatically reflected in the underlying data elements and in any related or dependent data elements.
- In general, as described above, the Charting Animator provides graphical displays of animated transitions that morph one chart into another whenever any of the underlying data elements defining any chart element are changed. As described above in Sections 3.1 and 3.2, changes to the underlying data elements occur in any of several ways, including, for example, direct user editing or modification of those data elements, as an automatic response to user modification of a corresponding chart element, or as an automatic response to maintain a predefined relationship to other data elements that are modified. Further, animations take one of several different forms, depending upon the change being made or requested by the user.
- For example, in one embodiment, the chart type of the displayed chart is maintained when a user changes either any data elements of the chart or any chart elements of the chart. In this case, the animation will be generally limited to simply rendering animated morphing to resize and/or reposition any chart elements affected by user's changes.
- In another embodiment, the chart type of the displayed chart is changed to another chart type, either in the same chart family, or in a different chart family (e.g., changing a pie chart to a bar chart). In this case, the underlying data elements are not changed by user action. Instead, the user simply selects a new chart type from a menu of available chart types and/or families. The displayed chart is then morphed into the newly selected chart type. For example, the same data can be used to render either bars in a Bar Chart or pie slices in a Pie Chart.
- For example, in a tested embodiment, an animation for morphing a 2D Bar Chart into a 3D Bar Chart that includes additional sets of data uses an animation where the row of bars (i.e., the x-axis, assuming vertical bars) from the 2D chart is the only row on an otherwise empty 3D floor. Then, in continuing the transition to the 3D chart, new rows (representing the additional sets of data) “grow” up from the floor as part of the transition animation. Conversely, when transitioning from a 3D Bar Chart to a 2D Bar Chart, the user will select a row to focus on before the transition. All other rows will then drop into the floor and disappear. Then the remaining row will transition to a 2D bar chart. Clearly, these simple examples describe one way of many ways in which such transitions can be animated by the Charting Animator. As such, these examples are not intended to limit the type, scope, or order of transition effects, and are intended for purposes of explanation only.
- As with other transition animations, the general idea is to present the user with a smooth transition from the displayed chart type to the selected chart type. Therefore, geometric shapes are morphed, as needed, along with the shape of the chart itself, to create the newly selected chart. Further, since many chart elements may need to be changed, multiple animations are either chained together in a sequence, or rendered in parallel to provide a smoother transition from the original chart to the new chart.
- In addition to the basic animations describe above, in various embodiments, the Charting Animator provides the capability to rotate charts in multiple dimensions as another animation, and to allow the user to manually rotate 3D charts to a desired viewpoint. The capability to rotate charts is also useful for chart type changes that include transitions to a higher or lower dimensionality (e.g., transitioning from a 2D Bar Chart to a 3D Bar Chart). For example, when transitioning from a 2D Bar Chart to a 3D Bar Chart, the primary animation is an animated movement from a virtual camera viewpoint to a different view point (e.g., a movement from a front view of the 2D chart to a perspective view of the 3D chart). In addition, since the flat bars of the 2D Bar Chart in this example will appear to be three-dimensional in the new 3D Bar Chart, there is an additional animation that extrudes each chart element from a 2D object to a 3D object. In various embodiments, this extrusion animation runs either in series or in parallel with the animation of the view point change.
- Clearly, when animating the transition from one chart type to another, multiple chart elements will need to be morphed. While each chart element can be morphed in a serial animation, it has been observed that morphing all of the changes to chart elements in parallel animations provides the user with a better view of how the chart is changing from one chart type to another. As noted above, the length of an animation can be as long as desired. However, if it is too long, the user may have the perception that the overall system is too slow. Note that transition animations on the order of about one second in length worked well in a tested embodiment.
- In general, the Charting Animator has the ability to morph chart elements of one shape into chart elements of another shape, such as, for example, morphing to or from a rectangle to a line segment, area segment, or pie slice. This morphing is generally accomplished by moving existing points of the various chart elements to create the new shapes, then rendering intermediate shapes to create the animated transition. Further, in addition to moving points to define a new shape, the Charting Animator introduces new points as needed. For example, a pie slice requires many more points than a rectangular bar of a Bar Chart; so, when transitioning from a bar to a pie slice, more points are added—and when transitioning away from a pie slice, those extra points are eliminated.
- Changing the shape of chart elements from one shape to another, such as, for example, changing a rectangular bar of a Bar Chart to a polygon of an Area Chart, or changing a rectangular bar of a Bar Chart to a pie slice of a Pie Chart is accomplished by smoothly morphing the chart element from the original shape to the new shape to provide an animated transition between the shapes. This morphing can be accomplished using any of a number of morphing techniques.
- For example, in a tested embodiment of the Charting Animator, as illustrated by
FIG. 3 , a rectangular bar of a Bar Chart is morphed into a polygon of an Area Chart. Note that this example is not intended to limit the way in which shapes are morphed, and is provided only as a simple illustration of shape morphing techniques that may be utilized by the Charting Animator. - In particular, as illustrated by
FIG. 3 , arectangle 300 defined by corner points {A, B, C, D} is changed topolygon 310 by translating point B by offset Y2, and translating point C by offset Y2. Clearly, any of the four points ofrectangle 300 can be translated in either the X or Y direction to provide the desired shape. Similarly, translating some or all of the points, depending upon the shape, is used for scaling the shape. For example, translating two or more of points A, B and C towards (or away from) point D can be used to scale the size ofrectangle 300 either up or down. Further, any one of the four points ofrectangle 300 can be collapsed into another of those points to create a triangle from therectangle 300. In any case, once the points of the new shape have been determined, the animation from the original shape to the new shape is created by simply rendering a sequence of intermediate images in steps as small as one pixel for each point, over some period of time. -
FIG. 4 provides an example of one way in which a rectangular bar of a Bar Chart is morphed into a pie slice of a Pie Chart. Again, this example is not intended to limit the way in which shapes are morphed, and is provided only as a simple illustration of shape morphing techniques that may be utilized by the Charting Animator. - In particular, as illustrated by
FIG. 4 , arectangle 400 defined by corner points {A, B, C, D} is changed to apie slice 420 via at least oneintermediate image step 410. For example, when transitioning from therectangle 400 to thepie slice 420, points A and B in therectangle 300 are moved towards new point E in theintermediate shape 410. The result is thetriangular shape 410. At the same time, the line between points C and D is divided into a plurality of additional points, such as points {C, D, F, G, H, I} that will be used to provide the curved side of thepie slice 420. Specifically, each of these points {C, D, F, G, H, I} is translated to form an arc, with the end result being thepie slice 420. Note that as discussed above, these transitions can be animated either in series or in parallel to provide the desired effect. Translating each of these points, A through I, in theshape sequence 400 through 420, in steps of at least one pixel, then rendering a set of corresponding intermediate shapes creates a smooth animation that morphs therectangle 400 into thepie slice 420. - Similar transitions are used to morph line thicknesses, or to transition from a line to a polygon. For example, as illustrated by
FIG. 5 , the thickness of aline 510 defined by points {A, B} can be changed by specifying someline thickness 520, then spreading points A and B into points C and D, respectively by the amount of the desired line thickness. Note that the same technique effectively creates a four-point polygon from a two point line. Further, including an offsetvalue 530 allows for rotation of the resulting line or polygon. - In various embodiments, morphing of 3D chart elements is handled in a similar manner to the 2D morphing examples provided above. For example, a bar in a 2D Bar Chart has 4 points defining one face. In contrast, there are 6 faces for a bar in a 3D Bar Chart. However, even though there are more faces, the transition from the 2D to the 3D case (or from the 3D to the 2D case) is a simple matter of extruding (or collapsing points), and of translating or rotating points to a new viewpoint, to define a sequence of intermediate shapes, then rendering those shapes to create the animations for each chart element.
- In addition to the features described above, in various embodiments, the Charting Animator also provides the capability to combine two or more charts to create a new chart a direct composition of one or more existing charts. One advantage of this embodiment is that two or more relatively simple charts can be combined to compose a more complex composite chart. In various embodiments, charts are combined using various techniques, including, for example, drag and drop type operations where one displayed chart is dropped onto another, or by selecting charts to be combined, along with a selection of a desired composite chart type from a menu, list, button, or the like. Further, in one embodiment, the Charting Animator provides the capability for the user to define and store custom composite chart types that may then be selected at a later time.
- As noted above, in one embodiment, composition of charts is accomplished by selecting two or more charts to be overlaid on one another. With this type of composite, the charts can be, but are not necessarily related, via some mathematical relationship. In this case, the Charting Animator renders an animation that scales and aligns the charts to fit each other along one or more common axes to create the new composite chart.
- In an alternate embodiment, two or more charts are combined by providing a user menu for selecting from a set of one or more predefined mathematical chart relationships, or allowing the user to define one or more new mathematical chart relationships. In either case, once the mathematical chart relationship has been either selected or defined by the user, the Charting Animator acts to render the two or more charts being combined along with the new composite chart. In general, since these charts are related via some mathematical relationship, they will share one or more common axes. As such, the Charting Animator renders all of the charts (the charts being combined and the new composite chart) together in a single display (that may include overlapping or adjacent charts, depending upon the composite chart type being rendered) relative to the common axes.
- Furthermore, since all of the charts are related via the mathematical relationship in this embodiment, a plurality of the individual data elements of those charts will generally also have various mathematical relationships. Consequently, whenever any of the data elements or chart elements of any of the combined or composite charts is changed, the Charting Animator will automatically change any related data elements, as described above in Section 3.1, to maintain those various mathematical relationships. Then, in one embodiment, as soon as any of the underlying data elements are changed, the Charting Animator automatically renders an animation showing the changes to the corresponding chart elements in one or more of the combined or composite charts.
- One example of a composite chart having a mathematical relationship to the charts used to construct the composite chart is termed a “Quantity Flow Diagram.” An example of a Quantity Flow Diagram, as illustrated by
FIG. 6 . In general, the Quantity Flow Diagram is a composite chart constructed from two existing charts: 1) a2D Bar Chart 610 that includes dates and amounts of incoming quantities; and 2) a2D Bar Chart 620 that includes dates and amounts of outgoing quantities. Examples of incoming and outgoing quantities include cash flow and material (inventory) availability, to name only two such examples. - Given this example data set, the user will first select two 2D Bar Charts (610 and 620) and designate one as being subtracted from the other (i.e., the user will select or specify the mathematical relationship between the charts). The Charting Animator then constructs the Quantity Flow Diagram 640 as a composite chart that shows incoming quantities in the first 2D Bar Chart 610 (positive bars trending up from a common axis), the second
2D Bar Chart 620 below the first2D Bar Chart 610 that shows the outgoing quantities (negative bars trending down from the common axis), and aPlateau Chart 630 below the first and second 2D Bar Charts showing the quantity on-hand (as changed by the two in/out quantities (610 and 620) over time). - Further, all of the elements of this three part composite chart are interrelated. Therefore, in one embodiment, changes made to any one or more chart elements of the
composite Plateau chart 630, or to either of the two 2D Bar Charts (610 and 620), or to any of the underlying data elements, will be immediately reflected in all related data elements of those three charts, as described above, with those changes also being immediately rendered as an animation to any corresponding chart elements. - The foregoing description of the Charting Animator has been presented for the purposes of illustration and description. It is not intended to be exhaustive or to limit the invention to the precise forms disclosed. Many modifications and variations are possible in light of the above teaching. Further, it should be noted that any or all of the aforementioned alternate embodiments may be used in any combination desired to form additional hybrid embodiments of the Charting Animator. It is intended that the scope of the invention be limited not by this detailed description, but rather by the claims appended hereto.
Claims (20)
1. A method for interacting with data elements used to construct a chart, comprising steps for:
receiving at least one data set comprising a plurality of data elements;
automatically rendering a chart having a user selected chart type from corresponding data elements of the at least one data set;
wherein the chart includes a plurality of chart elements that provide graphical representations of corresponding data elements;
displaying the chart on a display device;
using a graphical user interface (GUI) to modify a visual representation of one or more of the chart elements; and
automatically modifying one or more corresponding data elements of the at least one data set to correspond to the visual modifications to the one or more chart elements.
2. The method of claim 1 wherein modifying the visual representation of one or more of the chart elements further comprises steps for selecting a group of two or more of the chart elements at the same time, and wherein all selected chart elements are simultaneously modified via the GUI by performing a joint modification of the group of chart elements.
3. The method of claim 1 wherein modifying the visual representation of one or more of the chart elements comprises steps for performing a drag and drop type operation via the GUI to reorder one or more of the chart elements within the chart, and wherein any corresponding data elements of the at least one data set are automatically sorted to correspond to the reordering of the one or more chart elements.
4. The method of claim 1 wherein modifying the visual representation of one or more of the chart elements comprises steps for resizing the chart elements, and wherein values of any corresponding data elements of the at least one data set are automatically changed to match the resizing of the one or more chart elements.
5. The method of claim 1 wherein modifying the visual representation of one or more of the chart elements comprises steps for deleting one or more of the chart elements from the displayed chart, and wherein any corresponding data elements of the at least one data set are automatically deleted from the at least one data set.
6. The method of claim 1 wherein modifying the visual representation of one or more of the chart elements comprises steps for adding a graphical representation of a chart element to the displayed chart, and wherein corresponding data elements for any added chart element are automatically created and added to the at least one data set.
7. The method of claim 1 wherein using the GUI to modify the visual representation of one or more of the chart elements further comprises moving one or more control handles associated with those chart elements to adjust the visual appearance of those chart elements.
8. The method of claim 1 wherein modifying the visual representation of one or more of the chart elements comprises steps for combining one or more of the chart elements by using a drag and drop type operation to drop one or more chart elements onto one or more other chart elements to construct combined chart elements, and wherein the corresponding data elements for any combined chart elements are automatically combined.
9. The method of claim 1 wherein modifying the visual representation of one or more of the chart elements comprises steps for displaying numerical readouts of the values of corresponding modified data elements while the visual modifications to the chart elements are being made.
10. A physical computer readable storage media having computer executable instructions stored thereon for interacting with chart data used to render a chart on a display device, comprising instructions for:
receiving a set of data elements comprising chart data;
selecting a chart type from a list of available chart types;
rendering a chart of the selected chart type on a display device as a function of the set of data elements, said chart being composed of a plurality of chart elements, each chart element providing a graphical representation of one or more of the data elements;
modifying a visual appearance of one or more of the chart elements via a graphical user interface (GUI); and
for each modified chart element, automatically modifying one or more corresponding data elements to correspond to the modifications of the visual appearance of the modified chart elements.
11. The computer executable instructions of claim 10 wherein modifying the visual appearance of one or more of the chart elements further comprises selecting a group of two or more of the chart elements at the same time, and wherein all selected chart elements are simultaneously modified via the GUI by performing a joint modification of the group of chart elements.
12. The computer executable instructions of claim 10 wherein modifying the visual representation of one or more of the chart elements comprises performing a drag and drop type operation via the GUI to reorder one or more of the chart elements within the chart, and wherein any corresponding data elements are automatically sorted to correspond to the reordering of the one or more chart elements.
13. The computer executable instructions of claim 10 wherein modifying the visual representation of one or more of the chart elements comprises resizing the chart elements, and wherein values of any corresponding data elements are automatically changed to match the resizing of the one or more chart elements.
14. The computer executable instructions of claim 10 wherein modifying the visual representation of one or more of the chart elements comprises deleting one or more of the chart elements from the displayed chart, and wherein any corresponding data elements are automatically deleted from the set of data elements.
15. The computer executable instructions of claim 10 wherein modifying the visual representation of one or more of the chart elements comprises adding a graphical representation of a chart element to the displayed chart, and wherein corresponding data elements for any added chart element are automatically created and added to the set of data elements.
16. The computer executable instructions of claim 10 wherein using the GUI to modify the visual representation of one or more of the chart elements further comprises moving one or more control handles associated with those chart elements to adjust the visual appearance of those chart elements.
17. A system for interacting with charts via a graphical user interface (GUI), comprising using a computing device for:
receiving a set of data elements, said data elements representing values for defining graphical elements of a chart;
selecting a chart type;
rendering a chart of the selected chart type on a display device using the set of data elements to define each graphical element of the chart;
using a GUI to modify one or more of the graphical elements; and
automatically modifying one or more corresponding data elements to correspond to the modifications to the one or more graphical elements.
18. The system of claim 17 wherein modifying the graphical elements comprises performing a drag and drop type operation via the GUI to reorder one or more of the graphical elements within the chart, and wherein any corresponding data elements are automatically sorted to correspond to the reordering of the one or more graphical elements.
19. The system of claim 17 further comprising using the GUI to add one or more graphical elements to the displayed chart, and wherein corresponding data elements for any added chart element are automatically created and added to the set of data elements.
20. The system of claim 17 further comprising displaying numerical readouts of the values of corresponding data elements while modifications to the graphical elements are being made.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/772,154 US20100214299A1 (en) | 2007-02-12 | 2010-04-30 | Graphical manipulation of chart elements for interacting with chart data |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/674,115 US7737979B2 (en) | 2007-02-12 | 2007-02-12 | Animated transitions for data visualization |
US12/772,154 US20100214299A1 (en) | 2007-02-12 | 2010-04-30 | Graphical manipulation of chart elements for interacting with chart data |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/674,115 Continuation US7737979B2 (en) | 2007-02-12 | 2007-02-12 | Animated transitions for data visualization |
Publications (1)
Publication Number | Publication Date |
---|---|
US20100214299A1 true US20100214299A1 (en) | 2010-08-26 |
Family
ID=39685453
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/674,115 Active 2028-12-08 US7737979B2 (en) | 2007-02-12 | 2007-02-12 | Animated transitions for data visualization |
US12/772,154 Abandoned US20100214299A1 (en) | 2007-02-12 | 2010-04-30 | Graphical manipulation of chart elements for interacting with chart data |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/674,115 Active 2028-12-08 US7737979B2 (en) | 2007-02-12 | 2007-02-12 | Animated transitions for data visualization |
Country Status (1)
Country | Link |
---|---|
US (2) | US7737979B2 (en) |
Cited By (28)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20100005411A1 (en) * | 2008-07-02 | 2010-01-07 | Icharts, Inc. | Creation, sharing and embedding of interactive charts |
US20100251151A1 (en) * | 2009-03-27 | 2010-09-30 | Quinton Alsbury | Displaying stacked bar charts in a limited display area |
US20120098834A1 (en) * | 2010-10-25 | 2012-04-26 | General Electric Company | Smart plot methodology |
US20120313957A1 (en) * | 2011-06-09 | 2012-12-13 | Microsoft Corporation | Staged Animated Transitions for Aggregation Charts |
US20130083034A1 (en) * | 2011-09-30 | 2013-04-04 | Microsoft Corporation | Animation engine decoupled from animation catalog |
US20130124958A1 (en) * | 2011-11-15 | 2013-05-16 | Microsoft Corporation | Enrichment of data using a semantic auto-discovery of reference and visual data |
US20130185624A1 (en) * | 2012-01-12 | 2013-07-18 | International Business Machines Corporation | Providing direct manipulation of an analytics data visualization within an analytics report |
US20130194313A1 (en) * | 2012-01-27 | 2013-08-01 | Motorola Mobility, Inc. | Method of Enhancing Moving Graphical Elements |
US8793567B2 (en) | 2011-11-16 | 2014-07-29 | Microsoft Corporation | Automated suggested summarizations of data |
US20140247268A1 (en) * | 2013-03-04 | 2014-09-04 | Microsoft Corporation | Particle based visualizations of abstract information |
US20140267296A1 (en) * | 2013-03-15 | 2014-09-18 | Fluke Corporation | Automated Combined Display of Measurement Data |
US20150161805A1 (en) * | 2013-12-10 | 2015-06-11 | Oracle International Corporation | Methods and Systems for Transitioning Between Arbitrary Shapes |
US9135233B2 (en) | 2011-10-13 | 2015-09-15 | Microsoft Technology Licensing, Llc | Suggesting alternate data mappings for charts |
US20150262395A1 (en) * | 2014-03-11 | 2015-09-17 | Sas Institute Inc. | Sample data computation for rendering of graph elements |
CN105027055A (en) * | 2012-10-10 | 2015-11-04 | 微软公司 | Techniques to present event information using an event timing visualization |
US20160104311A1 (en) * | 2014-10-14 | 2016-04-14 | Microsoft Technology Licensing, Llc. | Animation framework |
US9563674B2 (en) | 2012-08-20 | 2017-02-07 | Microsoft Technology Licensing, Llc | Data exploration user interface |
US9665654B2 (en) | 2015-04-30 | 2017-05-30 | Icharts, Inc. | Secure connections in an interactive analytic visualization infrastructure |
US9754392B2 (en) | 2013-03-04 | 2017-09-05 | Microsoft Technology Licensing, Llc | Generating data-mapped visualization of data |
US9766270B2 (en) | 2013-12-30 | 2017-09-19 | Fluke Corporation | Wireless test measurement |
US9990349B2 (en) | 2015-11-02 | 2018-06-05 | Microsoft Technology Licensing, Llc | Streaming data associated with cells in spreadsheets |
US10001897B2 (en) | 2012-08-20 | 2018-06-19 | Microsoft Technology Licensing, Llc | User interface tools for exploring data visualizations |
US10031906B2 (en) | 2015-11-02 | 2018-07-24 | Microsoft Technology Licensing, Llc | Images and additional data associated with cells in spreadsheets |
US10061473B2 (en) | 2011-11-10 | 2018-08-28 | Microsoft Technology Licensing, Llc | Providing contextual on-object control launchers and controls |
US10095659B2 (en) | 2012-08-03 | 2018-10-09 | Fluke Corporation | Handheld devices, systems, and methods for measuring parameters |
US10416871B2 (en) | 2014-03-07 | 2019-09-17 | Microsoft Technology Licensing, Llc | Direct manipulation interface for data analysis |
US10895972B1 (en) * | 2018-04-20 | 2021-01-19 | Palantir Technologies Inc. | Object time series system and investigation graphical user interface |
US11282247B2 (en) | 2018-04-20 | 2022-03-22 | Palantir Technologies Inc. | Object time series system |
Families Citing this family (110)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8225231B2 (en) | 2005-08-30 | 2012-07-17 | Microsoft Corporation | Aggregation of PC settings |
WO2009026589A2 (en) * | 2007-08-23 | 2009-02-26 | Fred Cohen | Method and/or system for providing and/or analizing and/or presenting decision strategies |
US20090096812A1 (en) * | 2007-10-12 | 2009-04-16 | Business Objects, S.A. | Apparatus and method for morphing data visualizations |
US8963923B2 (en) * | 2008-03-11 | 2015-02-24 | Enphase Energy, Inc. | Method and apparatus for electrical power visualization |
US8620635B2 (en) | 2008-06-27 | 2013-12-31 | Microsoft Corporation | Composition of analytics models |
US8411085B2 (en) | 2008-06-27 | 2013-04-02 | Microsoft Corporation | Constructing view compositions for domain-specific environments |
US8271892B2 (en) | 2008-07-02 | 2012-09-18 | Icharts, Inc. | Creation, sharing and embedding of interactive charts |
US8020338B2 (en) * | 2008-08-26 | 2011-09-20 | Roger Lee Brown | Spitting weedless surface fishing lure |
US20100058250A1 (en) * | 2008-08-28 | 2010-03-04 | Smartdraw.Com | Editing numeric charts |
US7721209B2 (en) * | 2008-09-08 | 2010-05-18 | Apple Inc. | Object-aware transitions |
US20100118037A1 (en) * | 2008-09-08 | 2010-05-13 | Apple Inc. | Object-aware transitions |
US20100238176A1 (en) * | 2008-09-08 | 2010-09-23 | Apple Inc. | Systems, methods, and devices for flash exposure control using preflash statistics |
US20100064222A1 (en) * | 2008-09-08 | 2010-03-11 | Apple Inc. | Object-aware transitions |
US8380684B2 (en) * | 2008-09-30 | 2013-02-19 | Microsoft Corporation | Data-tier application component fabric management |
US8432400B1 (en) * | 2008-12-02 | 2013-04-30 | Adobe Systems Incorporated | Transitional animation for generating tree maps |
US8314793B2 (en) | 2008-12-24 | 2012-11-20 | Microsoft Corporation | Implied analytical reasoning and computation |
US8228330B2 (en) * | 2009-01-30 | 2012-07-24 | Mellmo Inc. | System and method for displaying bar charts with a fixed magnification area |
US8810574B2 (en) * | 2009-04-02 | 2014-08-19 | Mellmo Inc. | Displaying pie charts in a limited display area |
US8836648B2 (en) | 2009-05-27 | 2014-09-16 | Microsoft Corporation | Touch pull-in gesture |
US8788574B2 (en) | 2009-06-19 | 2014-07-22 | Microsoft Corporation | Data-driven visualization of pseudo-infinite scenes |
US8692826B2 (en) | 2009-06-19 | 2014-04-08 | Brian C. Beckman | Solver-based visualization framework |
US9330503B2 (en) | 2009-06-19 | 2016-05-03 | Microsoft Technology Licensing, Llc | Presaging and surfacing interactivity within data visualizations |
US8493406B2 (en) | 2009-06-19 | 2013-07-23 | Microsoft Corporation | Creating new charts and data visualizations |
US8866818B2 (en) | 2009-06-19 | 2014-10-21 | Microsoft Corporation | Composing shapes and data series in geometries |
US8531451B2 (en) | 2009-06-19 | 2013-09-10 | Microsoft Corporation | Data-driven visualization transformation |
US8990717B2 (en) * | 2009-08-12 | 2015-03-24 | Apple Inc. | Context-aware charting |
EP2472374B1 (en) * | 2009-08-24 | 2019-03-20 | Samsung Electronics Co., Ltd. | Method for providing a ui using motions |
US8352397B2 (en) | 2009-09-10 | 2013-01-08 | Microsoft Corporation | Dependency graph in data-driven model |
US8589815B2 (en) | 2010-03-10 | 2013-11-19 | Microsoft Corporation | Control of timing for animations in dynamic icons |
US8751966B2 (en) * | 2010-04-22 | 2014-06-10 | Microsoft Corporation | Display of filtered data via ordered values |
US9043296B2 (en) | 2010-07-30 | 2015-05-26 | Microsoft Technology Licensing, Llc | System of providing suggestions based on accessible and contextual information |
US8839133B2 (en) * | 2010-12-02 | 2014-09-16 | Microsoft Corporation | Data visualizations including interactive time line representations |
US20120159383A1 (en) | 2010-12-20 | 2012-06-21 | Microsoft Corporation | Customization of an immersive environment |
US20120159395A1 (en) | 2010-12-20 | 2012-06-21 | Microsoft Corporation | Application-launching interface for multiple modes |
US8612874B2 (en) | 2010-12-23 | 2013-12-17 | Microsoft Corporation | Presenting an application change through a tile |
US8689123B2 (en) | 2010-12-23 | 2014-04-01 | Microsoft Corporation | Application reporting in an application-selectable user interface |
US9423951B2 (en) | 2010-12-31 | 2016-08-23 | Microsoft Technology Licensing, Llc | Content-based snap point |
US20120317509A1 (en) * | 2011-01-24 | 2012-12-13 | Ludwig Lester F | Interactive wysiwyg control of mathematical and statistical plots and representational graphics for analysis and data visualization |
US9383917B2 (en) | 2011-03-28 | 2016-07-05 | Microsoft Technology Licensing, Llc | Predictive tiling |
US9104307B2 (en) | 2011-05-27 | 2015-08-11 | Microsoft Technology Licensing, Llc | Multi-application environment |
US20120304132A1 (en) | 2011-05-27 | 2012-11-29 | Chaitanya Dev Sareen | Switching back to a previously-interacted-with application |
US9158445B2 (en) | 2011-05-27 | 2015-10-13 | Microsoft Technology Licensing, Llc | Managing an immersive interface in a multi-application immersive environment |
US9658766B2 (en) | 2011-05-27 | 2017-05-23 | Microsoft Technology Licensing, Llc | Edge gesture |
US8893033B2 (en) | 2011-05-27 | 2014-11-18 | Microsoft Corporation | Application notifications |
US9104440B2 (en) | 2011-05-27 | 2015-08-11 | Microsoft Technology Licensing, Llc | Multi-application environment |
US8687023B2 (en) | 2011-08-02 | 2014-04-01 | Microsoft Corporation | Cross-slide gesture to select and rearrange |
US20130057587A1 (en) | 2011-09-01 | 2013-03-07 | Microsoft Corporation | Arranging tiles |
US9557909B2 (en) | 2011-09-09 | 2017-01-31 | Microsoft Technology Licensing, Llc | Semantic zoom linguistic helpers |
US8922575B2 (en) | 2011-09-09 | 2014-12-30 | Microsoft Corporation | Tile cache |
US10353566B2 (en) | 2011-09-09 | 2019-07-16 | Microsoft Technology Licensing, Llc | Semantic zoom animations |
US8933952B2 (en) | 2011-09-10 | 2015-01-13 | Microsoft Corporation | Pre-rendering new content for an application-selectable user interface |
US9244802B2 (en) | 2011-09-10 | 2016-01-26 | Microsoft Technology Licensing, Llc | Resource user interface |
US9146670B2 (en) | 2011-09-10 | 2015-09-29 | Microsoft Technology Licensing, Llc | Progressively indicating new content in an application-selectable user interface |
US9171098B2 (en) * | 2011-09-30 | 2015-10-27 | Microsoft Technology Licensing, Llc | Decomposing markup language elements for animation |
US9262849B2 (en) * | 2011-11-14 | 2016-02-16 | Microsoft Technology Licensing, Llc | Chart animation |
US9223472B2 (en) | 2011-12-22 | 2015-12-29 | Microsoft Technology Licensing, Llc | Closing applications |
US9224217B2 (en) * | 2012-01-06 | 2015-12-29 | Apple Inc. | Analytical charting |
US9128605B2 (en) | 2012-02-16 | 2015-09-08 | Microsoft Technology Licensing, Llc | Thumbnail-image selection of applications |
US20140046923A1 (en) | 2012-08-10 | 2014-02-13 | Microsoft Corporation | Generating queries based upon data points in a spreadsheet application |
US10809865B2 (en) | 2013-01-15 | 2020-10-20 | Microsoft Technology Licensing, Llc | Engaging presentation through freeform sketching |
KR102029055B1 (en) * | 2013-02-08 | 2019-10-07 | 삼성전자주식회사 | Method and apparatus for high-dimensional data visualization |
US10359919B2 (en) * | 2013-03-14 | 2019-07-23 | Microsoft Technology Licensing, Llc | Staged animation of charts for data updates |
US9760262B2 (en) * | 2013-03-15 | 2017-09-12 | Microsoft Technology Licensing, Llc | Gestures involving direct interaction with a data visualization |
US20140280057A1 (en) * | 2013-03-15 | 2014-09-18 | Sage Clarity Llc | Method and system for analyzing data |
US9818211B1 (en) * | 2013-04-25 | 2017-11-14 | Domo, Inc. | Automated combination of multiple data visualizations |
US9665259B2 (en) | 2013-07-12 | 2017-05-30 | Microsoft Technology Licensing, Llc | Interactive digital displays |
US9360992B2 (en) | 2013-07-29 | 2016-06-07 | Microsoft Technology Licensing, Llc | Three dimensional conditional formatting |
US9418336B2 (en) | 2013-08-02 | 2016-08-16 | Microsoft Technology Licensing, Llc | Automatic recognition and insights of data |
US10372302B2 (en) * | 2013-08-29 | 2019-08-06 | Sui Yan | Dimension based dynamic determination of visual analytics |
US9715556B2 (en) * | 2013-11-08 | 2017-07-25 | Business Objects Software Ltd. | Techniques for creating dynamic interactive infographics |
KR102298602B1 (en) | 2014-04-04 | 2021-09-03 | 마이크로소프트 테크놀로지 라이센싱, 엘엘씨 | Expandable application representation |
WO2015154276A1 (en) | 2014-04-10 | 2015-10-15 | Microsoft Technology Licensing, Llc | Slider cover for computing device |
WO2015154273A1 (en) | 2014-04-10 | 2015-10-15 | Microsoft Technology Licensing, Llc | Collapsible shell cover for computing device |
US10192181B2 (en) * | 2014-06-26 | 2019-01-29 | Oracle International Corporation | Resource demand-based project team staffing |
US10628765B2 (en) | 2014-07-14 | 2020-04-21 | Oracle International Corporation | Project chart with soft constraint |
US9846687B2 (en) * | 2014-07-28 | 2017-12-19 | Adp, Llc | Word cloud candidate management system |
US10678412B2 (en) | 2014-07-31 | 2020-06-09 | Microsoft Technology Licensing, Llc | Dynamic joint dividers for application windows |
US10592080B2 (en) | 2014-07-31 | 2020-03-17 | Microsoft Technology Licensing, Llc | Assisted presentation of application windows |
US10254942B2 (en) | 2014-07-31 | 2019-04-09 | Microsoft Technology Licensing, Llc | Adaptive sizing and positioning of application windows |
US10347027B2 (en) | 2014-09-08 | 2019-07-09 | Tableau Software, Inc. | Animated transition between data visualization versions at different levels of detail |
US10347018B2 (en) | 2014-09-08 | 2019-07-09 | Tableau Software, Inc. | Interactive data visualization user interface with hierarchical filtering based on gesture location on a chart |
US10380770B2 (en) * | 2014-09-08 | 2019-08-13 | Tableau Software, Inc. | Interactive data visualization user interface with multiple interaction profiles |
US10521092B2 (en) | 2014-09-08 | 2019-12-31 | Tableau Software, Inc. | Methods and devices for adjusting chart magnification asymmetrically |
US10635262B2 (en) | 2014-09-08 | 2020-04-28 | Tableau Software, Inc. | Interactive data visualization user interface with gesture-based data field selection |
US10642365B2 (en) | 2014-09-09 | 2020-05-05 | Microsoft Technology Licensing, Llc | Parametric inertia and APIs |
US10031939B2 (en) | 2014-09-30 | 2018-07-24 | Microsoft Technology Licensing, Llc | Automated supplementation of data model |
WO2016065568A1 (en) | 2014-10-30 | 2016-05-06 | Microsoft Technology Licensing, Llc | Multi-configuration input device |
US20160162165A1 (en) * | 2014-12-03 | 2016-06-09 | Harish Kumar Lingappa | Visualization adaptation for filtered data |
US9892531B2 (en) * | 2015-07-01 | 2018-02-13 | Oracle International Corporation | Chart data-binding design time user experience with dynamic sample generation |
US11997123B1 (en) | 2015-07-15 | 2024-05-28 | Management Analytics, Inc. | Scaleable cyber security assessment system and method |
US10416841B2 (en) * | 2015-08-10 | 2019-09-17 | Microsoft Technology Licensing, Llc | Animated data visualization video |
US10089760B2 (en) * | 2015-08-20 | 2018-10-02 | Autodesk, Inc. | Techniques for dynamically displaying pie charts for direct comparison |
US10896532B2 (en) | 2015-09-08 | 2021-01-19 | Tableau Software, Inc. | Interactive data visualization user interface with multiple interaction profiles |
US10115213B2 (en) * | 2015-09-15 | 2018-10-30 | Salesforce, Inc. | Recursive cell-based hierarchy for data visualizations |
US10089368B2 (en) | 2015-09-18 | 2018-10-02 | Salesforce, Inc. | Systems and methods for making visual data representations actionable |
US20170091967A1 (en) * | 2015-09-25 | 2017-03-30 | Sap Se | Animating transitions to circular data visualizations |
US10109086B1 (en) | 2016-01-25 | 2018-10-23 | Google Llc | Animated transitions between graphs |
US10347017B2 (en) * | 2016-02-12 | 2019-07-09 | Microsoft Technology Licensing, Llc | Interactive controls that are collapsible and expandable and sequences for chart visualization optimizations |
US10748312B2 (en) * | 2016-02-12 | 2020-08-18 | Microsoft Technology Licensing, Llc | Tagging utilizations for selectively preserving chart elements during visualization optimizations |
US11086498B2 (en) | 2016-12-30 | 2021-08-10 | Microsoft Technology Licensing, Llc. | Server-side chart layout for interactive web application charts |
US10395412B2 (en) | 2016-12-30 | 2019-08-27 | Microsoft Technology Licensing, Llc | Morphing chart animations in a browser |
US10304225B2 (en) | 2016-12-30 | 2019-05-28 | Microsoft Technology Licensing, Llc | Chart-type agnostic scene graph for defining a chart |
US10672157B2 (en) * | 2017-08-17 | 2020-06-02 | Oracle International Corporation | Bar chart optimization |
CN109582403B (en) * | 2017-09-29 | 2021-08-13 | 北京国双科技有限公司 | Linkage display method and device for components in diagram |
CN109241507A (en) * | 2018-07-27 | 2019-01-18 | 阿里巴巴集团控股有限公司 | A kind of chart generation method and device, a kind of calculating equipment and storage medium |
EP3867879A1 (en) * | 2018-10-21 | 2021-08-25 | Oracle International Corporation | Interactive data explorer and 3-d dashboard environment |
US20200234163A1 (en) * | 2019-01-17 | 2020-07-23 | Repsol, S. A. | Pre-visit data room content evaluation method and program product |
JP7311319B2 (en) * | 2019-06-19 | 2023-07-19 | ファナック株式会社 | Time-series data display device |
US12032813B1 (en) * | 2019-09-15 | 2024-07-09 | Charles Schwab & Co., Inc. | System and method for a user interface to facilitate comparisons of data |
CN111414368A (en) * | 2020-04-03 | 2020-07-14 | 中国建设银行股份有限公司 | Method and device for processing data |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5553212A (en) * | 1991-05-17 | 1996-09-03 | International Business Machines Corporation | Method and apparatus for solving numerical planning problems with inequalities on a computer system |
US6320586B1 (en) * | 1998-11-04 | 2001-11-20 | Sap Aktiengesellschaft | System an method for the visual display of data in an interactive split pie chart |
US7239316B1 (en) * | 2000-11-13 | 2007-07-03 | Avaya Technology Corp. | Method and apparatus for graphically manipulating data tables |
Family Cites Families (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5359712A (en) * | 1991-05-06 | 1994-10-25 | Apple Computer, Inc. | Method and apparatus for transitioning between sequences of digital information |
US5353391A (en) * | 1991-05-06 | 1994-10-04 | Apple Computer, Inc. | Method apparatus for transitioning between sequences of images |
US6256649B1 (en) * | 1998-06-17 | 2001-07-03 | Xerox Corporation | Animated spreadsheet for dynamic display of constraint graphs |
AU2322000A (en) * | 1999-01-29 | 2000-08-18 | Scale Inc. | Time-series data processing device and method |
US6462742B1 (en) * | 1999-08-05 | 2002-10-08 | Microsoft Corporation | System and method for multi-dimensional motion interpolation using verbs and adverbs |
US6995768B2 (en) * | 2000-05-10 | 2006-02-07 | Cognos Incorporated | Interactive business data visualization system |
US7917382B2 (en) * | 2003-03-05 | 2011-03-29 | Teradata Us, Inc. | Integration of visualizations, reports, and data |
US7669129B2 (en) * | 2003-04-04 | 2010-02-23 | Avid Technology, Inc. | Graphical user interface for providing editing of transform hierarchies within an effects tree |
KR100695126B1 (en) * | 2003-12-02 | 2007-03-14 | 삼성전자주식회사 | Input file generating method and system using meta representation on compression of graphic data, AFX coding method and apparatus |
-
2007
- 2007-02-12 US US11/674,115 patent/US7737979B2/en active Active
-
2010
- 2010-04-30 US US12/772,154 patent/US20100214299A1/en not_active Abandoned
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5553212A (en) * | 1991-05-17 | 1996-09-03 | International Business Machines Corporation | Method and apparatus for solving numerical planning problems with inequalities on a computer system |
US6320586B1 (en) * | 1998-11-04 | 2001-11-20 | Sap Aktiengesellschaft | System an method for the visual display of data in an interactive split pie chart |
US7239316B1 (en) * | 2000-11-13 | 2007-07-03 | Avaya Technology Corp. | Method and apparatus for graphically manipulating data tables |
Cited By (70)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20100005411A1 (en) * | 2008-07-02 | 2010-01-07 | Icharts, Inc. | Creation, sharing and embedding of interactive charts |
US9979758B2 (en) * | 2008-07-02 | 2018-05-22 | Icharts, Inc. | Creation, sharing and embedding of interactive charts |
US9716741B2 (en) * | 2008-07-02 | 2017-07-25 | Icharts, Inc. | Creation, sharing and embedding of interactive charts |
US20150058755A1 (en) * | 2008-07-02 | 2015-02-26 | Icharts, Inc. | Creation, sharing and embedding of interactive charts |
US9712595B2 (en) * | 2008-07-02 | 2017-07-18 | Icharts, Inc. | Creation, sharing and embedding of interactive charts |
US20150237085A1 (en) * | 2008-07-02 | 2015-08-20 | iCharts. Inc. | Creation, sharing and embedding of interactive charts |
US9270728B2 (en) * | 2008-07-02 | 2016-02-23 | Icharts, Inc. | Creation, sharing and embedding of interactive charts |
US8520000B2 (en) * | 2008-07-02 | 2013-08-27 | Icharts, Inc. | Creation, sharing and embedding of interactive charts |
US20150095807A1 (en) * | 2008-07-02 | 2015-04-02 | Icharts, Inc. | Creation, sharing and embedding of interactive charts |
US20140040061A1 (en) * | 2008-07-02 | 2014-02-06 | Icharts, Inc. | Creation, sharing and embedding of interactive charts |
US8239765B2 (en) * | 2009-03-27 | 2012-08-07 | Mellmo Inc. | Displaying stacked bar charts in a limited display area |
US20100251151A1 (en) * | 2009-03-27 | 2010-09-30 | Quinton Alsbury | Displaying stacked bar charts in a limited display area |
US20120098834A1 (en) * | 2010-10-25 | 2012-04-26 | General Electric Company | Smart plot methodology |
CN102567568A (en) * | 2010-10-25 | 2012-07-11 | 通用电气公司 | Smart plot methodology |
US20120313957A1 (en) * | 2011-06-09 | 2012-12-13 | Microsoft Corporation | Staged Animated Transitions for Aggregation Charts |
US20130083034A1 (en) * | 2011-09-30 | 2013-04-04 | Microsoft Corporation | Animation engine decoupled from animation catalog |
US8884971B2 (en) * | 2011-09-30 | 2014-11-11 | Microsoft Corporation | Animation engine decoupled from animation catalog |
US9135233B2 (en) | 2011-10-13 | 2015-09-15 | Microsoft Technology Licensing, Llc | Suggesting alternate data mappings for charts |
US10019494B2 (en) | 2011-10-13 | 2018-07-10 | Microsoft Technology Licensing, Llc | Suggesting alternate data mappings for charts |
US10061473B2 (en) | 2011-11-10 | 2018-08-28 | Microsoft Technology Licensing, Llc | Providing contextual on-object control launchers and controls |
US9633110B2 (en) * | 2011-11-15 | 2017-04-25 | Microsoft Technology Licensing, Llc | Enrichment of data using a semantic auto-discovery of reference and visual data |
US20130124958A1 (en) * | 2011-11-15 | 2013-05-16 | Microsoft Corporation | Enrichment of data using a semantic auto-discovery of reference and visual data |
US8793567B2 (en) | 2011-11-16 | 2014-07-29 | Microsoft Corporation | Automated suggested summarizations of data |
US20130185624A1 (en) * | 2012-01-12 | 2013-07-18 | International Business Machines Corporation | Providing direct manipulation of an analytics data visualization within an analytics report |
US9037964B2 (en) * | 2012-01-12 | 2015-05-19 | International Business Machines Corporation | Providing direct manipulation of an analytics data visualization within an analytics report |
US20130194313A1 (en) * | 2012-01-27 | 2013-08-01 | Motorola Mobility, Inc. | Method of Enhancing Moving Graphical Elements |
US9728145B2 (en) * | 2012-01-27 | 2017-08-08 | Google Technology Holdings LLC | Method of enhancing moving graphical elements |
US10095659B2 (en) | 2012-08-03 | 2018-10-09 | Fluke Corporation | Handheld devices, systems, and methods for measuring parameters |
US9563674B2 (en) | 2012-08-20 | 2017-02-07 | Microsoft Technology Licensing, Llc | Data exploration user interface |
US10001897B2 (en) | 2012-08-20 | 2018-06-19 | Microsoft Technology Licensing, Llc | User interface tools for exploring data visualizations |
CN105027055A (en) * | 2012-10-10 | 2015-11-04 | 微软公司 | Techniques to present event information using an event timing visualization |
EP2907011A4 (en) * | 2012-10-10 | 2016-07-06 | Microsoft Technology Licensing Llc | Techniques to present event information using an event timing visualization |
US20160042540A1 (en) * | 2013-03-04 | 2016-02-11 | Microsoft Technology Licensing, Llc | Particle based visualizations of abstract information |
US9070227B2 (en) * | 2013-03-04 | 2015-06-30 | Microsoft Technology Licensing, Llc | Particle based visualizations of abstract information |
US9589378B2 (en) * | 2013-03-04 | 2017-03-07 | Microsoft Technology Licensing, Llc | Particle based visualizations of abstract information |
US20140247268A1 (en) * | 2013-03-04 | 2014-09-04 | Microsoft Corporation | Particle based visualizations of abstract information |
US9754392B2 (en) | 2013-03-04 | 2017-09-05 | Microsoft Technology Licensing, Llc | Generating data-mapped visualization of data |
US20140267296A1 (en) * | 2013-03-15 | 2014-09-18 | Fluke Corporation | Automated Combined Display of Measurement Data |
US10809159B2 (en) * | 2013-03-15 | 2020-10-20 | Fluke Corporation | Automated combined display of measurement data |
US11843904B2 (en) | 2013-03-15 | 2023-12-12 | Fluke Corporation | Automated combined display of measurement data |
US9350798B2 (en) * | 2013-12-10 | 2016-05-24 | Oracle International Corporation | Methods and systems for transitioning between arbitrary shapes |
US20150161805A1 (en) * | 2013-12-10 | 2015-06-11 | Oracle International Corporation | Methods and Systems for Transitioning Between Arbitrary Shapes |
US9766270B2 (en) | 2013-12-30 | 2017-09-19 | Fluke Corporation | Wireless test measurement |
US10416871B2 (en) | 2014-03-07 | 2019-09-17 | Microsoft Technology Licensing, Llc | Direct manipulation interface for data analysis |
US20150262395A1 (en) * | 2014-03-11 | 2015-09-17 | Sas Institute Inc. | Sample data computation for rendering of graph elements |
US9671950B2 (en) * | 2014-03-11 | 2017-06-06 | Sas Institute Inc. | Sample data computation for rendering of graph elements |
CN106852178A (en) * | 2014-10-14 | 2017-06-13 | 微软技术许可有限责任公司 | Animation framework |
US10810159B2 (en) | 2014-10-14 | 2020-10-20 | Microsoft Technology Licensing, Llc. | Modular updating of visualizations |
US20160104311A1 (en) * | 2014-10-14 | 2016-04-14 | Microsoft Technology Licensing, Llc. | Animation framework |
US10216750B2 (en) | 2014-10-14 | 2019-02-26 | Microsoft Technology Licensing, Llc | Annotated geometry |
US10430382B2 (en) | 2014-10-14 | 2019-10-01 | Microsoft Technology Licensing, Llc | Data visualization architecture |
US9665654B2 (en) | 2015-04-30 | 2017-05-30 | Icharts, Inc. | Secure connections in an interactive analytic visualization infrastructure |
US10031906B2 (en) | 2015-11-02 | 2018-07-24 | Microsoft Technology Licensing, Llc | Images and additional data associated with cells in spreadsheets |
US10503824B2 (en) | 2015-11-02 | 2019-12-10 | Microsoft Technology Licensing, Llc | Video on charts |
US10579724B2 (en) | 2015-11-02 | 2020-03-03 | Microsoft Technology Licensing, Llc | Rich data types |
US10599764B2 (en) | 2015-11-02 | 2020-03-24 | Microsoft Technology Licensing, Llc | Operations on images associated with cells in spreadsheets |
US10713428B2 (en) | 2015-11-02 | 2020-07-14 | Microsoft Technology Licensing, Llc | Images associated with cells in spreadsheets |
US11630947B2 (en) | 2015-11-02 | 2023-04-18 | Microsoft Technology Licensing, Llc | Compound data objects |
US10366157B2 (en) | 2015-11-02 | 2019-07-30 | Microsoft Technology Licensing, Llc | Images on charts |
US9990349B2 (en) | 2015-11-02 | 2018-06-05 | Microsoft Technology Licensing, Llc | Streaming data associated with cells in spreadsheets |
US11106865B2 (en) | 2015-11-02 | 2021-08-31 | Microsoft Technology Licensing, Llc | Sound on charts |
US11157689B2 (en) | 2015-11-02 | 2021-10-26 | Microsoft Technology Licensing, Llc | Operations on dynamic data associated with cells in spreadsheets |
US11200372B2 (en) | 2015-11-02 | 2021-12-14 | Microsoft Technology Licensing, Llc | Calculations on images within cells in spreadsheets |
US9990350B2 (en) | 2015-11-02 | 2018-06-05 | Microsoft Technology Licensing, Llc | Videos associated with cells in spreadsheets |
US10895972B1 (en) * | 2018-04-20 | 2021-01-19 | Palantir Technologies Inc. | Object time series system and investigation graphical user interface |
US20220147237A1 (en) * | 2018-04-20 | 2022-05-12 | Palantir Technologies Inc. | Object time series system and investigation graphical user interface |
US11579762B2 (en) * | 2018-04-20 | 2023-02-14 | Palantir Technologies Inc. | Object time series system and investigation graphical user interface |
US11282247B2 (en) | 2018-04-20 | 2022-03-22 | Palantir Technologies Inc. | Object time series system |
US11262904B2 (en) * | 2018-04-20 | 2022-03-01 | Palantir Technologies Inc. | Object time series system and investigation graphical user interface |
US11875436B2 (en) | 2018-04-20 | 2024-01-16 | Palantir Technologies Inc. | Object time series system |
Also Published As
Publication number | Publication date |
---|---|
US20080192056A1 (en) | 2008-08-14 |
US7737979B2 (en) | 2010-06-15 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7737979B2 (en) | Animated transitions for data visualization | |
US8095892B2 (en) | Graphical user interface for 3-dimensional view of a data collection based on an attribute of the data | |
US7839420B2 (en) | Auto stacking of time related images | |
US8533593B2 (en) | Hierarchical display and navigation of document revision histories | |
US8533595B2 (en) | Hierarchical display and navigation of document revision histories | |
US7761796B2 (en) | Animation on object user interface | |
US8701002B2 (en) | Hierarchical display and navigation of document revision histories | |
US8874525B2 (en) | Hierarchical display and navigation of document revision histories | |
US8533594B2 (en) | Hierarchical display and navigation of document revision histories | |
US7864978B2 (en) | Smart arrangement and cropping for photo views | |
US20100194778A1 (en) | Projecting data dimensions on a visualization data set | |
US20070182999A1 (en) | Photo browse and zoom | |
CN102938158A (en) | Constructing animation timeline through direct operation | |
US20090282325A1 (en) | Sparklines in the grid | |
US6867771B2 (en) | Controlled face dragging in solid models | |
US6469702B1 (en) | Method and system for editing function curves in two dimensions | |
JP2020149329A (en) | Information processing apparatus and program |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |
|
AS | Assignment |
Owner name: MICROSOFT TECHNOLOGY LICENSING, LLC, WASHINGTON Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICROSOFT CORPORATION;REEL/FRAME:034766/0509 Effective date: 20141014 |