This invention relates in general to digital processing systems and more specifically to a digital processing system using a graphical representation of operations to advantageously accomplish processing of digital media productions.
Today's digital processing systems are used in many applications. One intensive application area uses digital production systems to create and process movies, video, animation, audio and other types of digital media. Such systems are referred to as production systems.
The demand on a production system is extremely high. A huge amount of information is present in even a few frames (less than one second) of a visual production, such as a movie. The type and number of possible complex operations that can performed on a movie require enormous processing power. Production systems provide incredible flexibility in applying different operations such as effects, transitions, editing, adjustments and other modifications. Each of dozens, or more, types of operations may in themselves have many different parameters, or other characteristics, which can be modified. The selection and application of operations on hundreds of selected areas of frames, clips and other parts of a production has become a highly specialized and complex task.
For example, a typical operation may be to composite two images together. The decision to perform a composite operation leads a human user of a production system down a path of myriad choices such as selecting frames or clips for compositing, cropping and scaling the images, performing color correction, erosion, blurring, light balancing, creating masks, etc. Several sets of operations may be required for different portions within a single frame, or screen area of a clip.
In present systems, the user interface (i.e., the display and user input devices) of productions systems is of great importance. Any improvement in ease of use and efficiency is often realizes a huge benefit in decreasing production times and providing better production results. However, the design of such user interfaces is difficult because the production system is usually limited to a relatively small display area (e.g., 1 or two display screens) to both display and play back the media, and to provide controls for navigating among thousands or production parts and for applying the complex operations.
Thus, it is desirable to provide an invention that improves upon the prior art user interfaces in production systems.
The present invention provides viewing features for an applications program such as a digital image processing program, non-linear editor, post-production system, etc. One aspect of the invention provides different ways for users to select an object and an action to be applied to the object. The user can select an object first and then an action, or vice versa. The user can also use gestural input to designate both an object and action virtually simultaneously.
Another aspect of the invention provides multiple views of a same image. Each view, or window, can be independently sized, zoomed, panned, etc. Any effects performed on the image appear in all of the windows since each window shows (potentially) different portions of the same image content.
Another aspect of the invention provides a navigation window to help a user move within a large image or diagram that does not fit entirely on a single display screen. The navigation window includes an inner box that shows, in miniature, the principal objects in the screen display. A region outside of the screen display is shown in the navigation box, relative to the inner box.
Another aspect of the invention derives an active area from multiple operations mark in/out points. Operations that are part of a group have their in/out points adjusted so that the operation does not occur outside of the group's own mark in/out points.
In one embodiment the invention provides a method for performing actions on objects, the method executing in a computer system including a processor coupled to a user input device, the method comprising
accepting signals from a user input device to first specify a first object and then select a first action to be performed on the first object; accepting signals from a user input device to first select a second action and then specify a second object on which the second action is to be performed; and accepting signals from a user input device to define a gesture that overlaps a third object, wherein the gesture is mapped to a third action to be performed on the third object.
In another embodiment the invention provides a method for displaying images on a display screen, the method comprising displaying multiple windows on the display screen; performing an operation on an image;
displaying the image in each of the multiple windows; and accepting input from a user input device to allow independent manipulation of the windows.
In another embodiment the invention provides a method for viewing an image on a display screen, wherein the display screen is coupled to a processor and user input device, the method comprising
displaying a navigator box on the display screen; displaying a miniature version of the image on the display screen within an inner box within the navigator box on the display screen, wherein the inner box is smaller than the navigator box, wherein portions of the image not displayed on the display screen are shown in miniature within the area of the navigator box that is outside of the inner box.
In another embodiment the invention provides a method for determining active intervals of operations to be performed on images, wherein each operation includes a start time and a stop time that defines an initial active interval for the operation, the method comprising selecting one or more operations to be members of a group; determining a start time and a stop time to define a group interval for the group; and setting the active region of each operation that is a member of the group to be the intersection of each operation's initial active interval with the group interval.
The present invention provides features whereby image content in a media production system is associated with a visual flowgraph representation of the operations used to create, or derive, the image content. A comprehensive association is maintained between production parts in image space and in flowgraph space. This allows a user to quickly move between working with an image representation of a part and the flowgraph (i.e., visual display of operations) representation.
A specific, preferred embodiment, production system is referred to as “Socratto” which is developed and marketed by VFX, a division of Sony Corporation. Although aspects of the present invention are described in connection with the Socratto system, it should be apparent that the invention is suitable for use with many different productions systems having different ways to present information and to accept user inputs. Also, although the invention is described herein primarily with reference to film or video production systems, the invention is applicable to other types of media production systems such as computer-aided design, audio, animation, modeling, etc. Various aspects of the invention are applicable to any type of application program or functional system.
In
In
Frames, or images, such as frame 132, 136 and 140 exist in image space. Clips typically include multiple frames and also exist in image space. Clips 102, 104 and 110 are shown in
Flowgraph space 130 is a second conceptual category that includes a visual presentation of operations that are performed to generate a production part. In a preferred embodiment, flowgraphs are associated with clips or clip sections (including single frames or portions of frames). The associations can be one-to-one, one-to-many or many-to-one; although a preferred embodiment maintains a one-to-one relationship between each unique clip section and the flowgraph that generated it. Any manner of correspondence or associations among production parts and clips are possible.
In
Each flowgraph's associated part represents the output of the operations that the flowgraph describes. For example, In
Flowgraph 116 illustrates the case where the output of a flowgraph, namely flowgraph 116, is a single frame, frame 106
Flowgraph 118 illustrates the case where two media sources (e.g., from computer RAM, disk storage, a digital network, optical scanning device, etc.) are used to product clip section 108. Clip 110 represents one of the media sources. The other media source is not shown. The dashed arrow indicates that clip 110 is not associated with flowgraph 118 since clip 110 is not generated by flowgraph 118.
The correspondence, or association, of data items between image space and flowgraph space can be by any means as is known in the art. Parts can be stored or represented in any image format. The flowgraphs can be stored or represented as any type of suitable data structure such as a list, relational database elements, etc. The association between images and flowgraphs can be made with pointers, lists, embedding a part with an associated flowgraph in a file, or by any suitable programming or data processing technique.
In the course of a typical production, many operations can be made to a part both in image space and in flowgraph space. This is illustrated in
All types of operations are paralleled. Storage/retrieval and transfer operations are symbolized at 168 and 170. When a part or flowgraph is stored, the associated flowgraph or part, respectively, is also stored in association so another session, program, process, etc., can retrieve the part-flowgraph pair. Note that the two types of representation need not be stored in the same logical or physical area or device. Also, portions of each representation can reside at different location, on different devices, etc., as desired. Similar to storage, when a part or flowgraph is transferred (e.g., over a network to a remote system), the counterpart representation is also made available to the destination.
Retrieval and transfer of a representation pair is illustrated by interfaces 172 and 156.
Thus, the maintenance of closely-linked and continuously updated image and flowgraph pair representations provides advantages in a production system.
In
Nodes have names that provide brief descriptions, or identifications, of the type of operation represented by the node. For example, node 180 has a name, “Color,” indicating that the node is a source for a predefined color output. Output port 190 is an output port for node 180. Connector 194 connects the output of node 180 to node 182 by connecting to node 182's input port 192. Node 182 is called “Clip_Output” which indicates the output of the flowgraph operations. In other words, the flowgraph output is generated at “Clip_Output.”
The present invention uses a “user input model” that provides an efficient way for a user to specify an action to be performed on an object. Objects in the system such as frames and clips in image space, or nodes representing effects or other operations in flowgraph space, can have an action applied. For example, an action, such as a color correction operation, can be applied to an object, such as a frame.
The system allows the user to specify object-action processing in three different ways. The first is “object/action” where an object is first identified and then an action is selected to apply to the object. A second type of object-action processing is “action/object” where an action is first selected and then an object to which to apply the action is identified. Finally, “gestural” object-action processing allows choosing an object and action at essentially the same time.
After the routine is entered, step 202 is executed to accept user input from an input device to specify an object. The object can be specified by any manner as is known in the art. For example, the object can be “clicked on” with a mouse and pointer, pen tablet, touch screen, trackball and pointer, etc. A pointer can select an object semi-automatically as where a pointer is moved into the vicinity of an object. See, for example, co-pending patent application Ser. No. 09/929,400 filed on Aug. 13, 2001, entitled “Media Production System Using Flowgraph Representation of Operations” referenced, above. The object can be scrolled to the center of the display screen to a “focus” area to become a specified object. The object can be a default object such as some previously specified object that is no longer on-screen. The object can be specified by name, as, for example, where the user types in a name or other identifier for an object. Other ways of specifying an object are possible.
In a preferred embodiment, once a user has specified an object, the object remains highlighted until an action is applied, another object is specified, or the specified object becomes de-specified. Multiple objects can be specified at once, or successively. Thus, the approach of selecting an object before an action allows multiple objects to easily be applied with one or more actions.
After an object is specified at step 202 of
After an action is selected, step 206 is executed to choose a destination. The destination can be by default—in which case there is no active step to choose the destination. For example, the destination can be the same location as the object. In other words, if the object is a clip stored on a disk, the destination can be to the same disk location to overwrite the original clip. Usually, the destination is preferably a different location in the same storage device as the original object, although any destination is possible. The user can specify a device destination as the default. For example, remote storage such as a redundant array of inexpensive disks (RAID) can be used over a network such as a local-area network (LAN) or the Internet.
After the object, action and destination have been obtained, the routine of flowchart 200 exits so that the system can perform the object-action process as directed.
In
In
In
In
In
Throughout all of the independent window and image manipulations, each image in the quad view is processed with any operations and effects in the same way. In other words, the bitmap representations of the content of each window is the same except for the viewing operations—which do not affect the image content. Thus, the user is provided with a convenient way to view the image simultaneously at different scales. The user can view effects in a very small area and also view the larger picture to see the image to the full scale, as it would appear in the final production. Naturally, any number of windows can be provided.
A navigator drawing mode provides a small “wide-area” indicator to help a user determine what portion of a larger image or diagram is being viewed on the display screen.
In
Navigator box 312 includes miniature representation 314 of display screen 300. Miniature representation, or “mini screen,” 314 includes the major items that can be seen on display screen 300. Namely, the nodes of visible flowgraph portion 301 are shown on the mini screen as 316, 318, 320, 322 and 324, respectively. Note that node 326 which is shown in navigator box 312 but not in mini screen 314 is an item that is part of the larger flowgraph diagram but which is not visible on display screen 300. Thus, the user can tell from the navigator box that scrolling the display screen view upwards will bring another node, corresponding to node 326, within view.
Navigator box 312 is preferably large enough to include viewing space around all four sides of mini screen 314 so that the user can effectively see what will come into view if the display screen view is scrolled in different directions.
Another feature of the present invention combines the navigator view with the quad view as shown in
In
The four different parts of a larger diagram are shown relative to each other in the diagram as mini windows 350, 352, 354 and 356 corresponding with windows 340, 342, 344 and 346, respectively. As each window is scrolled, zoomed, etc., the corresponding mini window is changed accordingly and the navigator box is manipulated to accommodate the display of all four mini windows.
The present invention uses the intersection of effects within a common group to determine the effective start/stop points to apply an effect.
In
In
A preferred embodiment of the invention uses the intersection of overlapping active areas to determine the active area for a sub-nodes of a group. In the example of
To further illustrate. If Group1 node is later made part of Group2, then all of the active areas are now intersected with Group2's active area, G-H, in order to obtain the nodes' active areas as part of Group2. Namely, Gamma node 402's active area in Group2 is G-B and Blur node 404's active area in Group2 is G-D. Group1's active area while in Group2 is G-F.
Basic Hardware
In
As with the external physical configuration shown in
Any suitable programming language can be used to implement the routines of the present invention including C, C++, Java, assembly language, etc. Different programming techniques can be employed such as procedural or object oriented. The routines can execute on a single processing device or multiple processors. Although the flowchart format demands that the steps be presented in a specific order, this order may be changed. Multiple steps can be performed at the same time. The flowchart sequence can be interrupted. The routines can operate in an operating system environment or as stand-alone routines occupying all, or a substantial part, of the system processing.
Steps can be performed by hardware or software, as desired. Note that steps can be added to, taken from or modified from the steps in the flowcharts presented in this specification without deviating from the scope of the invention. In general, the flowcharts are only used to indicate one possible sequence of basic operations to achieve a functional aspect of the present invention.
Although the present invention is described predominantly with respect to a visual image processing system, many types of systems that include media presentation features can employ the present invention. Such systems include, but are not limited to, audio, animation, modeling, computer-aided design, web browsing or access, etc. Other embodiments need not devote screen area to specific controls, such as the controls at 114 of
Although the invention has been discussed in connection with parameters and parameter values, other structures for modifying media instances, such as attribute/value pairs, arrays, lists, etc., can be employed. In general, a parameter, or other data structure, used to describe an image need not only have a single value. Multiple values, data structures, functions, etc., can be used to define parameter values either continuously or discretely. For example, where a function is used to define parameter values over space, time, etc., the present invention can check for different functions associated with shared parameter types as opposed to merely checking for different values, as described above.
Thus, the scope of the invention is to be determined solely by the appended claims.
This application is a continuation of the following application, U.S. patent application Ser. No. 09/930,115, entitled USER INTERFACE FOR A DIGITAL PRODUCTION SYSTEM INCLUDING MULTIPLE WINDOW VIEWING AND NAVIGATING, filed on Aug. 14, 2001, which is hereby incorporated by reference, as if it is set forth in full in this specification. This application claims priority from the following U.S. Provisional patent applications: 1. Application Ser. No. 60/271,376; filed Feb. 22, 2001, entitled “A System and Method for Editing”; and 2. Application Ser. No. 60/284,660; filed Apr. 17, 2001, entitled “Advanced System and Method for Editing”. This application is related to the following co-pending U.S. patent applications: 1. application Ser. No. 09/665,721; filed Sep. 18, 2000, entitled “System And Method For Optimizing The Processing Of Images”; 2. application Ser. No. 09/691,795; filed Oct. 18, 2000, “System And Method For Increasing Performance When Compositing Images”; 3. application Ser. No. 09/929,276; filed Sep. 13, 2001, entitled “User Interface for Generating Parameter Values in Media Presentations Based on Selected Presentation Instances”; 4. application Ser. No. 09/929,526; filed Aug. 13, 2001, entitled “Collaborative Computer-Based Production System Including Annotation, Versioning and Remote Interaction”; and, 5. application Ser. No. 09/929,400; filed Aug. 13, 2001, entitled “Media Production System Using Flowgraph Representation of Operations”;
Number | Name | Date | Kind |
---|---|---|---|
4482924 | Brownstein | Nov 1984 | A |
4532605 | Waller | Jul 1985 | A |
4538188 | Barker | Aug 1985 | A |
4751507 | Hama | Jun 1988 | A |
4831447 | Lake | May 1989 | A |
4953106 | Gansner | Aug 1990 | A |
5187776 | Yanker | Feb 1993 | A |
5237648 | Mills | Aug 1993 | A |
5253338 | Tanaka | Oct 1993 | A |
5263134 | Paal | Nov 1993 | A |
5404295 | Katz | Apr 1995 | A |
5438654 | Drebin | Aug 1995 | A |
5490246 | Brotsky | Feb 1996 | A |
5513306 | Mills | Apr 1996 | A |
5517607 | Nishimura | May 1996 | A |
5600775 | King | Feb 1997 | A |
5729673 | Cooper | Mar 1998 | A |
5760767 | Shore | Jun 1998 | A |
5771042 | Santos-Gomez | Jun 1998 | A |
5844563 | Harada | Dec 1998 | A |
5850545 | Matsushita | Dec 1998 | A |
5852449 | Esslinger | Dec 1998 | A |
5864782 | Mederer | Jan 1999 | A |
5870559 | Leshem | Feb 1999 | A |
5880858 | Jin | Mar 1999 | A |
5890130 | Cox | Mar 1999 | A |
5909220 | Sandow | Jun 1999 | A |
5920317 | McDonald | Jul 1999 | A |
5930446 | Kanda | Jul 1999 | A |
5982350 | Hekmatpour et al. | Nov 1999 | A |
6005535 | Takagi | Dec 1999 | A |
6046722 | Keil | Apr 2000 | A |
6085185 | Matsusawa | Jul 2000 | A |
6105063 | Hayes | Aug 2000 | A |
6204840 | Petelycky | Mar 2001 | B1 |
6229536 | Alexander | May 2001 | B1 |
6263346 | Rodriquez | Jul 2001 | B1 |
6266053 | French | Jul 2001 | B1 |
6307550 | Chen | Oct 2001 | B1 |
6340971 | Janse | Jan 2002 | B1 |
6392674 | Hiraki | May 2002 | B1 |
6404925 | Foote | Jun 2002 | B1 |
6430609 | Dewhurst | Aug 2002 | B1 |
6449653 | Klemets | Sep 2002 | B2 |
6452615 | Chiu | Sep 2002 | B1 |
6467080 | Devine | Oct 2002 | B1 |
6470100 | Horiuchi | Oct 2002 | B2 |
6529215 | Golovchinsky | Mar 2003 | B2 |
6587123 | Ando | Jul 2003 | B2 |
6590583 | Soohoo | Jul 2003 | B2 |
6597375 | Yawitz | Jul 2003 | B1 |
6683619 | Samra | Jan 2004 | B1 |
6694487 | Ilsar | Feb 2004 | B1 |
6750890 | Sugimoto | Jun 2004 | B1 |
6873344 | Samra | Mar 2005 | B2 |
6897880 | Samra | May 2005 | B2 |
7075536 | Goldschmidt | Jul 2006 | B1 |
7129961 | Samra | Oct 2006 | B1 |
7930418 | Samra | Apr 2011 | B2 |
20020032768 | Voskuil | Mar 2002 | A1 |
20020033837 | Munro | Mar 2002 | A1 |
20020158887 | Samra | Oct 2002 | A1 |
20030001844 | Driemeyer | Jan 2003 | A1 |
20040068567 | Moran | Apr 2004 | A1 |
20040078215 | Dahlin | Apr 2004 | A1 |
Entry |
---|
Piroumian, Vartan, “Java GUI Development: The Authoritative Solution”, Aug. 25, 1999, Sams, pp. 208, 217, 220. |
Nadas et al.; Grape: An Enviroment to Build Display Process; Jul. 1987; ACM; Computer Graphics; vol. 21; No. 4; pp. 75-84. |
Number | Date | Country | |
---|---|---|---|
20120294589 A1 | Nov 2012 | US |
Number | Date | Country | |
---|---|---|---|
60271376 | Feb 2001 | US | |
60284660 | Apr 2001 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 09930115 | Aug 2001 | US |
Child | 13298604 | US |