The invention is directed towards generation and use of multiclips in video editing.
In recent years, there has been a proliferation of video editing applications. These applications provide numerous editing tools that allow a user to create composite video presentations by combining one or more video and audio tracks and applying one or more video and/or audio effects to these tracks.
Most video editing applications do not provide a robust set of tools for multi-camera editing, i.e., for editing video clips from an event that has been captured by multiple cameras. This is a serious deficiency in many video-editing applications as the number of events that are captured by multiple cameras is increasing. Examples of such events include sporting events, concerts, music videos, reality shows, etc. Therefore, there is a need in the art for robust video editing tools that allow a video editor to easily perform multi-camera editing. Ideally, such editing tools will be seamlessly integrated with other video editing tools in a video editing application.
Some embodiments of the invention provide a method of generating a composite video clip from several video clips. The method automatedly groups the video clips into sets of related video clips. It then uses the sets of related video clips to generate the composite video clip. In some embodiments, the method can group the video clips based on their start times. For instance, the method can group video clips that start within a certain temporal offset of one another as a related set of video clips. Also, in some embodiments, the method can group video clips that overlap with each other by a required threshold amount as a related set of video clips.
The novel features of the invention are set forth in the appended claims. However, for purpose of explanation, several embodiments of the invention are set forth in the following figures.
In the following description, numerous details are set forth for purpose of explanation. However, one of ordinary skill in the art will realize that the invention may be practiced without the use of these specific details. In other instances, well-known structures and devices are shown in block diagram form in order not to obscure the description of the invention with unnecessary detail.
I. Overview
Some embodiments of the invention provide a method of generating a composite video clip from several video clips. The method automatedly groups the video clips into sets of related video clips. It then uses the sets of related video clips to generate the composite video clip. In some embodiments, the method can group the video clips based on their start times. For instance, the method can group video clips that start within a certain temporal offset of one another as a related set of video clips. Also, in some embodiments, the method can group video clips that overlap with each other by a required threshold amount as a related set of video clips.
In some embodiments, the video clips that are automatedly grouped are video clips that are captured by multiple cameras during an event (such as a music video, sporting event, reality show, etc.). Hence, in these embodiments, the invention facilitates multi-camera editing by automatedly grouping video clips captured by the multiple cameras. Each grouped video clip is referred to as a multiclip in the discussion below. An editor can easily generate a composite video clip for the event by defining different parts of the clips in the same or different multiclips to be different parts of the composite video clip.
Even though the invention is particularly useful for multi-camera editing, it is also useful to other video editing contexts. For instance, the invention can be used to generate composite video clips from video clips that are all not from the same event. Also, even in the multi-camera editing context, one or more of the automatedly grouped video clips might be edited before their grouping into multiclips.
Accordingly, as used below, a “video clip” can be a composite of one or more video sources, one or more audio tracks, and one or more video and audio effects. A video clip includes a number of frames, which are typically presented at a particular frame rate (e.g., at 25 fps, 30 fps, 60 fps). At times, each frame is presented in terms of two consecutive fields (e.g., is presented at 50 or 60 fields per second for a 25 or 30 fps video clip).
II. Graphical User Interface
Some embodiments of the invention are implemented by a video editing application that has a graphical user interface (“GUI”) 100 that is illustrated in
In the browser section 130, the video editing application lists individual and composite clips, as well as multiclips and multiclip sequences. The playback timeline 105 represents the time during the playback of video and audio clips. The GUI 100 illustrates video and audio clips as rectangular boxes on the video and audio tracks, which are defined in parallel to the playback timeline 105. During multiclip editing, video and audio clips of one or more multiclips are illustrated on the video and audio tracks, as further described below.
During playback, the GUI's time marker scrolls across the timeline and identifies the portion of the video and audio clips that are playing at any instance along the timeline. Specifically, the intersection of the time-marker line with a video clip or an audio clip identifies an image (e.g., a frame) in the video clip or a sample in the audio clip that is in the clip at the particular time specified by the position of the time marker on the timeline. An editor can also drag the time marker to a particular time on the timeline to view the video-clip frame or the audio-clip sample at that time.
The multiclip display sections 120 are for displaying one or more video clips during multiclip editing. Specifically, during multiclip editing, the display sections 120 display the video clips of a particular multiclip that is selected for display, as the time marker scrolls across the particular multiclip, as further described below. The composite-video preview section 125 provides a preview display of the composite video. For instance, at any particular time during the editing or playback of one or more video clips, the composite-video section 125 illustrates the frame in the composite video that is defined for the particular time.
III. Video Editing Process
As shown in
After 205, the process 200 sorts (at 210) the video clips that were selected at 205. In some embodiments, the process sorts the video clips based on their starting timecodes, which specify the start times of the video clips. Also, in some embodiments, the sorted order is an ascending order of starting timecodes (i.e., an order of the clip with the earliest timecode to the clip with the latest timecode).
Next, at 215, the process selects a video clip based on the order specified at 210. In its first iteration through 215, the process selects the first video clip in the specified order. In subsequent iterations through 215, the process selects the next video clip in the specified order. After 215, the process determines (at 220) whether it should define a multiclip for the video clip selected at 215. In some embodiments, the process needs to define (at 220) a multiclip for the selected video clip when (1) the video clip selected at 215 should be grouped with any other video clips selected at 205 and such a grouping has not been identified in a previous iteration through 220, or (2) the video clip should not be grouped with any other video clips selected at 205.
In some embodiments, the process uses (at 220) a set of matching criteria to determine whether two video clips should be grouped into a multiclip. In some embodiments, the video editing application allows the user to specify one of two criteria for the process 200 to use. One criterion is that two clips should be part of one multiclip when their starting timecodes is within a user-defined offset of each other. Another criterion is that two clips should be part of one multiclip when their durations overlap by a user-defined percentage of overlap.
In the window 705, the editor can change the matching criteria or the parameter values for these criteria. For instance,
In
Going back to
At 225, the process 200 defines a multiclip for the video clip selected at 215 and the set of video clips that should be grouped with the selected video clip based on the particular set of matching criteria used for grouping clips. When the process determines (at 220) that the selected video clip should not be grouped with any other video clips, the set of video clips that are grouped with the selected video clip in the multiclip created at 225 is an empty set of video clips.
Next, the process transitions from 225 to 230, where it assigns the newly defined multiclip to a video track not used by any other multiclip during the duration of the newly defined multiclip. After 230, the process transitions to 235. The process also transitions to 235 from 220 when it determines that it does not need to create a multiclip for the video clip selected at 225. In some embodiments, the process determines that it does not need to create a multiclip for the selected video clip when it determines that the selected video clip was part of a previously defined multiclip(s) and that it should not be part of any other multiclips based on the matching analysis performed at 220.
At 235, the process determines whether it has examined all the video clips. If not, it returns to 215 to select the next video clip in the sorted order, and then repeats operations 220-235 for this video clip. When the process determines (at 235) that it has examined all the video clips, it presents (at 240) the multiclips to the video editor. At this stage, the video editor can edit the defined multiclips by adding or removing one or move video clips to each multiclip.
After 240, the process displays one or more multiclips on one or more video tracks of in the GUI of the video editing application. In the GUI examples illustrate in
In some embodiments, the multiclip list (such as the ones illustrated in
When the editor selects the entry for the multiclip sequence (e.g., by double clicking this entry), the video editing application displays the multiclip sequence to the editor by presenting all of its multiclips along one or more video and audio tracks, as shown in
After 245, the process allows (at 250) the video editor to generate the composite video clip by editing the multiclip sequence with the multiclips defined at 245. As further described below, the video editor can easily generate the composite video clip by selecting (through simple GUI operations) different parts of the clips in the same or different multiclips to be different parts of the composite video clip. In some embodiments, these selections cause the video editing application to generate one or more multiclips during this editing process, as further described below.
In some embodiments, each multiclip has only one active video clip. This active video clip is illustrated within the composite video preview window 125. For instance, in
Some embodiments allow the video editor to change the video clip that forms the video composite at any time in the timeline that has one or more video clips of one or more multiclips associated with it, by simply selecting (e.g., clicking) a video clip that is playing in one of the multiclip display sections. For instance, in the example illustrated in
Two multiclips may overlap by default or through some action of the video editor (e.g., the video editor might drag one multiclip into the same time period as another multiclip). For instance,
In some embodiments, each multiclip is viewed as an opaque object, which blocks out each multiclip that is below it. Also, in some embodiments, each subsequent video track is in front of each video track that preceded it in the video track order, e.g., video track 2 is in front of video track 1, video track 3 is in front of video track 2, and so on. Hence, when two multiclips overlap, the video editing application in some embodiments defaults to the multiclip that is on a higher track number in some embodiments. This is shown in
When two multiclips overlap, the video editor can change the content of the composite video from one multiclip to another. In some embodiments, the video editor simply drags the desired multiclip from the lower track to the higher track that contains the multiclip that is obscuring it. Alternatively, the video editor can disable the track that is obscuring the desired multiclip by clicking a track enable button that is to the left of the track, in some embodiments.
IV. Data Structures for Clip, Multiclip and Multiclip Sequence
Some embodiments have three classes of objects to define a multiclip sequence. These three types are a clip class, a multiclip class, and a multi-sequence class. A clip class can be used to define a clip object, which is a container for containing temporal, spatial, format, and file information that can be used to specify data within a multimedia application. While much of the data contained in the clip can come directly from interpreting the file embedded in the clip, other information can be altered and specified by the user, such as additional effect processing, marked portions to be used for editing, and other various descriptive data that alters its interpretation within the multimedia application. A clip can hold video or audio information, or both in the more common case.
The following is pseudo code for a clip object, which defines its data attributes.
A multiclip is a type of clip, i.e., the multiclip class inherits from the clip class. A multiclip serves as a container of clips that are grouped together in a logical manner based on user defined temporal specification. This specification can be one of several different time points that are used to arrange the clips within the container such that they align themselves with one another synchronized at the temporal point specified by the user. This can be a manually set point in time, or as is the case with making a multiclip sequence, source timecode. The clips themselves are contained in an angles object, which is essentially just an stl map of a custom type. A multiclip can have as few as 1 clip and as many as 128 clips contained within its data structure. Of those 128, as few as 1 and as many as 16 can be visible/viewed at any given moment in the Viewer.
The following is pseudo code for a multiclip object, which defines its data attributes.
MulticlipObject
A multiclip sequence is a spatio-temporal collection of clip objects (i.e., media) that can be arranged by user interaction, or as is the case in making a multiclip sequence, automatically based on their temporal attributes. A sequence generally contains several attributes that describe its video and audio format, frame-rate, and other characteristics for determining image-processing quality. The sequence contains a starting timecode value, which, in the case of making a multiclip sequence is set to match the earliest starting timecode found in the set of all multiclips that will be automatically edited into the sequence. In addition, the format specifications of the sequence created in this case is also specified to match the format of the multiclips that are to be automatically edited into the sequence.
The following is pseudo code for a multiclip sequence object, which defines its data attributes.
V. Computer System
From these various memory units, the processor 2010 retrieves instructions to execute and data to process in order to execute the processes of the invention. The read-only-memory (ROM) 2020 stores static data and instructions that are needed by the processor 2010 and other modules of the computer system.
The permanent storage device 2025, on the other hand, is read-and-write memory device. This device is a non-volatile memory unit that stores instruction and data even when the computer system 2000 is off. Some embodiments of the invention use a mass-storage device (such as a magnetic or optical disk and its corresponding disk drive) as the permanent storage device 2025.
Other embodiments use a removable storage device (such as a floppy disk or Zip® disk, and its corresponding disk drive) as the permanent storage device. Like the permanent storage device 2025, the system memory 2015 is a read-and-write memory device. However, unlike storage device 2025, the system memory is a volatile read-and-write memory, such as a random access memory. The system memory stores some of the instructions and data that the processor needs at runtime. In some embodiments, the invention's processes are stored in the system memory 2015, the permanent storage device 2025, and/or the read-only memory 2020.
The bus 2005 also connects to the input and output devices 2030 and 2035. The input devices enable the user to communicate information and select commands to the computer system. The input devices 2030 include alphanumeric keyboards and cursor-controllers. The output devices 2035 display images generated by the computer system. For instance, these devices display the GUI of a video editing application that incorporates the invention. The output devices include printers and display devices, such as cathode ray tubes (CRT) or liquid crystal displays (LCD).
Finally, as shown in
While the invention has been described with reference to numerous specific details, one of ordinary skill in the art will recognize that the invention can be embodied in other specific forms without departing from the spirit of the invention. Thus, one of ordinary skill in the art would understand that the invention is not to be limited by the foregoing illustrative details, but rather is to be defined by the appended claims.
This Application is a continuation application of U.S. patent application Ser. No. 11/107,330, filed Apr. 16, 2005. U.S. patent application Ser. No. 11/107,330 is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5404316 | Klingler et al. | Apr 1995 | A |
5519828 | Rayner | May 1996 | A |
5659792 | Walmsley | Aug 1997 | A |
5659793 | Escobar et al. | Aug 1997 | A |
5682326 | Klingler et al. | Oct 1997 | A |
5732184 | Chao et al. | Mar 1998 | A |
5850352 | Moezzi | Dec 1998 | A |
5926603 | Tanaka et al. | Jul 1999 | A |
5969716 | Davis et al. | Oct 1999 | A |
6144375 | Jain et al. | Nov 2000 | A |
6188396 | Boezeman et al. | Feb 2001 | B1 |
6246402 | Setogawa | Jun 2001 | B1 |
6353461 | Shore et al. | Mar 2002 | B1 |
6400378 | Snook | Jun 2002 | B1 |
6404978 | Abe | Jun 2002 | B1 |
6414686 | Protheroe et al. | Jul 2002 | B1 |
6469718 | Setogawa | Oct 2002 | B1 |
6515656 | Wittenburg et al. | Feb 2003 | B1 |
6624846 | Lassiter | Sep 2003 | B1 |
6642939 | Vallone et al. | Nov 2003 | B1 |
6760538 | Bumgardner et al. | Jul 2004 | B1 |
6888999 | Herberger et al. | May 2005 | B2 |
7006154 | Dudkowski | Feb 2006 | B2 |
7015954 | Foote | Mar 2006 | B1 |
7073127 | Zhao et al. | Jul 2006 | B2 |
7200656 | Cousins | Apr 2007 | B1 |
7313755 | Rahman et al. | Dec 2007 | B2 |
7398002 | Hsiao | Jul 2008 | B2 |
7467400 | Moss | Dec 2008 | B1 |
7565060 | Hamada | Jul 2009 | B2 |
7631261 | Williams | Dec 2009 | B2 |
7823056 | Davey et al. | Oct 2010 | B1 |
8006186 | Kellock | Aug 2011 | B2 |
8020100 | Ubillos et al. | Sep 2011 | B2 |
8954477 | Agnoli et al. | Feb 2015 | B2 |
9111579 | Meaney et al. | Aug 2015 | B2 |
9437247 | Pendergast et al. | Sep 2016 | B2 |
20010020953 | Moriwake et al. | Sep 2001 | A1 |
20020001449 | Sato | Jan 2002 | A1 |
20020154156 | Moriwake et al. | Oct 2002 | A1 |
20020174430 | Ellis | Nov 2002 | A1 |
20020194038 | Sauser | Dec 2002 | A1 |
20030112354 | Ortiz | Jun 2003 | A1 |
20030164925 | Kutner | Sep 2003 | A1 |
20030189589 | LeBlanc | Oct 2003 | A1 |
20040032495 | Ortiz | Feb 2004 | A1 |
20040125133 | Pea | Jul 2004 | A1 |
20040143602 | Ruiz | Jul 2004 | A1 |
20040179816 | Takehana | Sep 2004 | A1 |
20040239763 | Notea | Dec 2004 | A1 |
20040268224 | Balkus et al. | Dec 2004 | A1 |
20050220361 | Yamasaki | Oct 2005 | A1 |
20060041589 | Helfman | Feb 2006 | A1 |
20060150100 | Braun et al. | Jul 2006 | A1 |
20100183280 | Beauregard et al. | Jul 2010 | A1 |
20100278504 | Lyons et al. | Nov 2010 | A1 |
20100281372 | Lyons et al. | Nov 2010 | A1 |
20100281377 | Meaney et al. | Nov 2010 | A1 |
20100281382 | Meaney et al. | Nov 2010 | A1 |
20100281386 | Lyons et al. | Nov 2010 | A1 |
20130124999 | Agnoli et al. | May 2013 | A1 |
20130125000 | Fleischhauer et al. | May 2013 | A1 |
Number | Date | Country |
---|---|---|
2387710 | Oct 2003 | GB |
Entry |
---|
U.S. Appl. No. 11/107,330, filed Apr. 16, 2005, Johnson, Gary. |
Author Unknown, “Apple Announces Final Cut Pro 4,” NAB, Apr. 6, 2003, 3 pages, Apple Inc., Las Vegas, USA. |
Number | Date | Country | |
---|---|---|---|
Parent | 11107330 | Apr 2005 | US |
Child | 15268589 | US |