WO2008094533A2 - Video downloading and scrubbing system and method - Google Patents

Video downloading and scrubbing system and method Download PDF

Info

Publication number
WO2008094533A2
WO2008094533A2 PCT/US2008/001139 US2008001139W WO2008094533A2 WO 2008094533 A2 WO2008094533 A2 WO 2008094533A2 US 2008001139 W US2008001139 W US 2008001139W WO 2008094533 A2 WO2008094533 A2 WO 2008094533A2
Authority
WO
WIPO (PCT)
Prior art keywords
video
file
video data
data
scrubbed
Prior art date
Application number
PCT/US2008/001139
Other languages
French (fr)
Other versions
WO2008094533A3 (en
Inventor
Andrew Gavin
Scott Shumaker
Original Assignee
Flektor, Inc.
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Flektor, Inc. filed Critical Flektor, Inc.
Priority claimed from US12/021,272 external-priority patent/US7986867B2/en
Publication of WO2008094533A2 publication Critical patent/WO2008094533A2/en
Publication of WO2008094533A3 publication Critical patent/WO2008094533A3/en

Links

Classifications

    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11BINFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
    • G11B27/00Editing; Indexing; Addressing; Timing or synchronising; Monitoring; Measuring tape travel
    • G11B27/02Editing, e.g. varying the order of information signals recorded on, or reproduced from, record carriers
    • G11B27/031Electronic editing of digitised analogue information signals, e.g. audio or video signals
    • G11B27/034Electronic editing of digitised analogue information signals, e.g. audio or video signals on discs
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/4302Content synchronisation processes, e.g. decoder synchronisation
    • H04N21/4307Synchronising the rendering of multiple content streams or additional data on devices, e.g. synchronisation of audio on a mobile phone with the video output on the TV screen
    • H04N21/43072Synchronising the rendering of multiple content streams or additional data on devices, e.g. synchronisation of audio on a mobile phone with the video output on the TV screen of multiple content streams on the same device
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/234Processing of video elementary streams, e.g. splicing of video streams, manipulating MPEG-4 scene graphs
    • H04N21/23424Processing of video elementary streams, e.g. splicing of video streams, manipulating MPEG-4 scene graphs involving splicing one content stream with another content stream, e.g. for inserting or substituting an advertisement
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/238Interfacing the downstream path of the transmission network, e.g. adapting the transmission rate of a video stream to network bandwidth; Processing of multiplex streams
    • H04N21/2387Stream processing in response to a playback request from an end-user, e.g. for trick-play
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/27Server based end-user applications
    • H04N21/274Storing end-user multimedia data in response to end-user request, e.g. network recorder
    • H04N21/2747Remote storage of video programs received via the downstream path, e.g. from the server
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/432Content retrieval operation from a local storage medium, e.g. hard-disk
    • H04N21/4325Content retrieval operation from a local storage medium, e.g. hard-disk by playing back content from the storage medium
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/44Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream, rendering scenes according to MPEG-4 scene graphs
    • H04N21/44008Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream, rendering scenes according to MPEG-4 scene graphs involving operations for analysing video streams, e.g. detecting features or characteristics in the video stream
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/47End-user applications
    • H04N21/472End-user interface for requesting content, additional data or services; End-user interface for interacting with content, e.g. for content reservation or setting reminders, for requesting event notification, for manipulating displayed content
    • H04N21/47202End-user interface for requesting content, additional data or services; End-user interface for interacting with content, e.g. for content reservation or setting reminders, for requesting event notification, for manipulating displayed content for requesting content on demand, e.g. video on demand
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/60Network structure or processes for video distribution between server and client or between remote clients; Control signalling between clients, server and network components; Transmission of management data between server and client, e.g. sending from server to client commands for recording incoming content stream; Communication details between server and client 
    • H04N21/61Network physical structure; Signal processing
    • H04N21/6106Network physical structure; Signal processing specially adapted to the downstream path of the transmission network
    • H04N21/6125Network physical structure; Signal processing specially adapted to the downstream path of the transmission network involving transmission via Internet
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/80Generation or processing of content or additional data by content creator independently of the distribution process; Content per se
    • H04N21/85Assembly of content; Generation of multimedia applications
    • H04N21/854Content authoring
    • H04N21/8549Creating video summaries, e.g. movie trailer
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N7/00Television systems
    • H04N7/16Analogue secrecy systems; Analogue subscription systems
    • H04N7/173Analogue secrecy systems; Analogue subscription systems with two-way working, e.g. subscriber sending a programme selection signal
    • H04N7/17309Transmission or handling of upstream communications
    • H04N7/17318Direct or substantially direct transmission and handling of requests

Definitions

  • the present invention relates to video downloading and scrubbing systems, and more particularly to a video downloading and scrubbing system and method for web-based video editing systems.
  • FIG. 1 is a block diagram of a web-based video editing system according to a first embodiment of the present invention.
  • FIG. Ia is a block diagram of a web-based video editing system according to some embodiments of the present invention.
  • FIG. 2 is a block diagram of an embodiment of a video downloading and scrubbing system of the web-based video editing system of FIG. 1.
  • FIG. 3 shows a diagram of one representation of the video files' composition and the manner in which the scrubbing system edits and manipulates them.
  • FIG. 4 shows a block diagram of the process by which the system transmits large video files.
  • FIG. 5 shows a flowchart diagram of a method of operation on the client computer for processing user input.
  • FIG. 6 shows a sample representation of video files with delta encoding.
  • FIG. 7 shows a sample representation of the video files with delta encoding and the manner in which the system manipulates them.
  • the video player downloads video files and scrubs to specific time indexes in one of several ways.
  • the first method known as progressive downloading, involves downloading the entire video file at once.
  • the data for the file is downloaded sequentially, thus the video player first downloads the data for the first frame of the video, followed by the next frame, and so forth until it reaches the last frame.
  • the user may play the downloaded portion of the file and may scrub to any portion of the video that has already been downloaded. If the user attempts to scrub past this point, the video player will typically scrub to the end of the downloaded portion of the file and will stop playing.
  • the video player will halt play when it reaches the end of the downloaded portion of the file.
  • FIG. 1 is a block diagram of a web-based video editing system according to a first embodiment of the present invention.
  • the editing system includes one or more communication devices 110 each having a graphical user interface 115, a server 120 having a connection manager 130 and a video downloading and scrubbing system 140 operating on the server, and a network 150 over which the one or more communication devices and the server communicate.
  • the communication devices may include, but are not limited to, a personal computer, a mobile telephone, a PDA, or any other communication device configured to operate as a client computer to the server.
  • a user may operate the communication device to develop a web- based video to be displayed on the graphical user interface.
  • the network to which the server and devices are coupled may be a wireless or a wireline network and may range in size from a local area network to a wide area network to the Internet.
  • a dedicated open socket connection exists between the connection manager and the communication devices. 61338P/F462
  • FIG. Ia is a block diagram of some embodiments of the web-based video editing system of FIG. 1.
  • the system does not include a connection manager for communication between the client computer and the server.
  • client computer 1 10a is an instance of client computer 110
  • graphical user interface 115a is an instance of grpahical user interface 115
  • server 120a is an instance of server 120
  • video downloading and scrubbing system 140a is an instance of video donloading and scrubbing system 140
  • internet 150a is an instance of internet 150. All the components in FIG. Ia are thus identical to those in FIG. 1,, and they are all configured to operate as described in FIG. 1.
  • one or more client computers are configured to transmit information to and receive information from the server.
  • each of the client computers is configured to send a query for information and the server is configured to respond to the query by sending the requested information to the client computer.
  • one or more of the client computers is configured to transmit commands to the server and the server is configured to perform functions in response to the commands.
  • each of the client computers is configured with an application for displaying multimedia on the graphical user interface of the client computer.
  • the application may be Adobe Flash® or any other application capable of displaying multimedia.
  • videos are as stored as files on the server or on a remote computer connected to the server.
  • the files may be Flash FLV format files or any other file suitable for storing videos that can be downloaded to a client computer.
  • connection manager is configured to determine the condition of the server and perform asynchronous messaging to one or more of the client computers over the dedicated open socket connection.
  • the content of the message is indicative of the state of the server. 61338P/F462
  • the server is configured to receive requests from one or more of the client computers and perform functions in response to the received requests.
  • the server performs any number of functions typically performed on the server of a web-based video editing system.
  • the server provides a video downloading and scrubbing system for the web-based video editing system.
  • the video downloading and scrubbing system is executed on the server. In other embodiments, the video downloading and scrubbing system may be executed on a computer that is remote from but in communication with the server.
  • the video downloading and scrubbing system is configured to allow a user to download all or portions of a video, scrub to specified time indices within the video once it has been downloaded, scrub to specified time indices in a video that is currently being downloaded, scrub to specified time indices in a video that has not yet started to download, and scrub to specified time indices within all or portions of a video without experiencing significant lag time.
  • FIG. 2 is a block diagram of an embodiment of a video downloading and scrubbing system of the web-based video editing system of FIG. 1.
  • the video downloading and scrubbing system includes a scrubbing subsystem 210 and a preview subsystem 220.
  • the scrubbing subsystem includes a processor 212, memory 214, and computer code product including instructions stored in the memory and adapted to cause the processor, and thereby the scrubbing subsystem, to receive and process user scrubbing requests.
  • the memory also stores information indicative of the user scrubbing requests.
  • the memory may be any type of read-write memory, including, but not limited to, random access memory.
  • the scrubbing subsystem receives input from the user including the identity of the user, the video the user wishes to view, and the time index in the video to which the user wishes to scrub.
  • the video may be stored in the editing system of the server (not shown), the scrubbing subsystem memory 214, the preview subsystem memory 224, or at a remote location connected to 61338P/F462
  • the preview subsystem includes a processor 222, memory 224, and computer code product including instructions stored on the memory and adapted to cause the processor, and thereby the preview subsystem, to receive and process user preview requests or preview requests from the scrubbing subsystem.
  • the memory also stores information indicative of the requests from the scrubbing subsytem.
  • the memory may be any type of read- write memory, including, but not limited to, random access memory.
  • the preview subsystem receives input from the user including the identity of the user, the video the user wishes to view, and the time index in the video to which the user wishes to scrub.
  • the preview subsystem receives this input from the scrubbing subsystem.
  • the preview subsystem generates previews frames. These preview frames may be selected from throughout the video or they may be from a particular portion of the video. For example, the frames may be selected from periods of time contiguous to that which the user has requested to scrub.
  • FIG. 3 shows a diagram of one representation of the video files' composition and the manner in which the scrubbing system edits and manipulates them.
  • Video file 300 includes a header 310 and data 320.
  • the header includes a signature, flags, a version number, an offset, and/or any other variables or information necessary for a video editor or player to recognize and process the file.
  • the data includes a stream of tags including one or more fields including fields for a timestamp, the previous tag size, the body length, padding, type of tag, and any other fields relating to data for a video file.
  • Each of the tags contains packets of audio, video, or meta data. 61338P/F462
  • the system when dealing with smaller size video files, receives input from the user indicating the time index to which he desires to scrub.
  • the system opens the video file 300, locates the point 330 in the data 320 within the file 300 that corresponds to the input for the user selected time index, and splices out the data 340 following that point.
  • Splicing includes any combination of copying to a new location in memory, providing pointers to particular location in memory, tagging particular locations in the file, or any other acceptable method or means for selecting data from a file and later streaming it to the client computer.
  • the amount of the data that is spliced varies for each embodiment. In some embodiments, the data only corresponds to a small snippet of the video.
  • the snippet of data only corresponds to the portion of the video that the particular user has been editing. No matter the embodiment, the snippet of data is generally smaller in size than the original file.
  • the system appends a new header 350 to the beginning of the snippet.
  • appending the header data may, for example, involve streaming header data to the client computer and subsequently streaming the spliced data.
  • appending the header may, for example, involve creating a new file containing the header and the spliced data.
  • the above examples for appending header data are illustrative only as persons having ordinary skill in the art would recognize.
  • a new video file 360 has been created containing only the portions of the video the user wishes to view and beginning at the time index to which the user indicated he wishes to scrub. Because the new file has the appropriate header data, it operates as any other video file would and any video player would download the new file and allow it to be viewed as if it were an original file because the video player will process the file as if it is downloading a full and complete video file. For example, if the user begins to view a one minute file and scrubs to the time index corresponding to 30 seconds within the video, the system will 61338P/F462
  • FIG. 4 shows a block diagram of the process by which the system transmits large video files.
  • the system receives 410 input from a user indicating that he wishes to view a video file.
  • the system closes 420 any existing video data stream to the client computer.
  • the system transmits 430 the video file to the client computer.
  • the client computer progressively downloads the video file from the beginning of the file. In progressive downloading, the client computer begins downloading the video file from the beginning.
  • the user may scrub to any time index in the video so long as the data within the video corresponding to that time index has already been downloaded to the client computer.
  • the system may receive 440 input from the user indicating that he wishes to scrub to another time index within the video. If the system determines 450 that this time index occurs at a position in the file that has already been downloaded, the system scrubs 460 to that time index on the client computer and continues to download the file.
  • the system determines 450 that the time index occurs in a portion of the file that has not yet been downloaded, the system closes 465 the data stream for the video file currently downloading and locates 470 the byte number in the video file on the server that corresponds with the time index requested by the user.
  • the system then streams 480 header data to the client computer and then transmits 490 this video file to the client computer, and the client computer begins to progressively download the new file.
  • the user may scrub to any time index corresponding to a downloaded portion of the file.
  • the system maintains a time line that shows the length of the original video and the time index in the original video even though the video currently being downloaded begins at the 61338P/F462
  • the system receives input indicating the user wishes to scrub to a portion of the video that occurs before the beginning the of the new video file, the system closes the video file/stream that is currently being downloaded.
  • the system opens the original video file and locates the byte number in the file corresponding to the newly selected time index.
  • the system then truncates the video data at that point and appends a header to the beginning portion of the data.
  • the new video file consists of the entirety of the original video data except for any point that occurs before the user selected time index.
  • the client computer then begins progressively downloading and playing this new video file.
  • the user may scrub to any portion of the file that has already been downloaded. [0031] Further, if the user attempts to scrub to a time index in the video that occurs past the downloaded portion, the system will once again close the current video file and create a new video file for download as described above and shown in FIG. 4.
  • FIG. 5 shows a flowchart diagram of a method of operation on the client computer for processing user input.
  • the client computer sends 520 a request to the server for data corresponding to the video.
  • the client begins receiving 530 the video data, processes, and plays 540 the video as it downloads.
  • the player continues to download and play the video until it receives 550 input from the user indicating that the user wishes to scrub to a different time index.
  • the system determines 560 whether the time index is within the already downloaded portion of the video. If it is, the system scrubs 570 to that time index within the video and continues to play and download the video until it receives 550 further input indicating that the user wishes to scrub to another time index. If, instead, the system determines 560 that the time index is not within the already downloaded portion of the 61338P/F462
  • meta data is injected into the video files containing the byte number in the file for frames in the video. This meta data also contains the time index for the corresponding frame. Depending on the embodiment and preferences during implementation, the meta data includes this information for the time index and byte number for each frame, for every set number of frames, or for any other process of selecting frames that best suits the needs of the current implementation. The system uses this data to locate the byte number for the frame corresponding to the time index selected by the user. In some embodiments, the meta data is in the form of two arrays.
  • FIG. 6 shows a sample representation of video files with delta encoding.
  • the system includes files using delta encoding.
  • Delta encoding is a way of storing or transmitting data in the form of differences between sequential data rather than as complete files.
  • the files 600 include a header 610 and data 620.
  • the header 610 includes a signature, flags, a version number, an offset, and any other variables or information necessary for a video editor or player to recognize and process the file.
  • the data 620 includes a stream of tags including one or more fields including fields for a timestamp, the previous tag size, the body length, padding, type of tag, and any other fields relating to data for a video file.
  • Each of the tags contains packets of audio, video, or meta data.
  • the video packets are encoded using delta encoding and include a series of keyframes 630 and delta frames 640.
  • the data for each keyframe 630 contains data corresponding to the entire image for one frame of the video.
  • the intervening delta frames 640 contain only the data for the changes in the image from the preceding frame. For example, if only three pixels change between one frame and the next, the data for the second frame would only include the information necessary to indicate the change in those three pixels rather than data for the entire image in the second frame. As a result, the delta frames are much smaller in size than the 61338P/F462
  • the number of key frames in a video varies per each video; however, the file size of the video increases greatly to coincide with its number of key frames whereas an increase in the number of delta frames does not greatly increase the file size.
  • the video files are in Flash FLV format including delta encoding.
  • the video files are also injected with meta data in the form of two arrays that contain the byte number and time index for each key frame in a video file. This metadata allows the video player to accurately seek within the video and do accurate re-buffering of the video file despite potentially only having been sent a section of the file.
  • the system when the system receives input from the client computer indicating that the user wishes to scrub to a particular time index of the video clip, the system locates in the video file on the server the last key frame 750 that precedes the frame 760 corresponding to the requested time index, truncates all the previous data 790 in the file, and appends the remaining portion of the file 795 to the new header 770.
  • the server then streams the file 799 to the client computer, and the client begins downloading the file as if this were the entirety of the file.
  • appending the header data involves, for example, streaming header data to the client computer and subsequently streaming the spliced data.
  • appending the header involves, for example, creating a new file containing the header and the spliced data.
  • the system transmits additional data to the viewer portion of the client computer system instructing it to not display the audio or visual aspects of the file 799 until it reaches the frame 760 corresponding to the requested time index.
  • the client begins downloading the file beginning at the nearest key frame 750 and applies each of the intervening delta frames 780 to the key frame 750 until it reaches the delta frame 760 corresponding to the requested time index.
  • the client computer processes the intervening delta frames in real time or processes them at the fastest possible speed for the computer. Because the size of the delta frames is extremely small in comparison to the size of the 61338P/F462
  • the server maintains two versions of each video file, one that is completely delta encoded, and one that has a large number of key frames.
  • This keyframe-heavy version is designed to be used in a web-based video editor, and frequent keyframes facilitate interactive scrubbing and video cropping because most client video implementations can only scrub to keyframes.
  • frequent keyframes greatly increase the size of video, so it is desirable to use the delta-encoded version of a video when downloaded by an audience.
  • a new copy of the video is rendered out in delta-encoded form for audience viewing.
  • a new copy of the video is generated in response to a client request by combining a heavily delta-encoded version of the video with the editor version of the video.
  • the system when the video was initially encoded, two versions are generated by the system - a keyframe-heavy editor version of the video, and a heavily delta-encoded version of the video with keyframes spaced at large intervals, such as once per second.
  • the system generates a video file by generating a header and initial keyframe using the editor video, as described above.
  • the system uses a server-side decoder to decode the delta frames and thus generate full keyframes and appends these keyframes to the generated video file.
  • the system uses the keyframe-heavy video to generate the keyframes, and in other embodiments, the system uses the delta-encoded version of the video. The system continues this process until a corresponding keyframe is reached in the delta-encoded 61338P/F462
  • the video downloading and scrubbing system includes a preview subsystem.
  • the preview subsystem may receive user input from the client computer indicating a time index to which a user wishes to scrub.
  • the preview subsystem locates the frame corresponding to the time index and splices only that frame out of the file, or it splices the nearest keyframe if delta encoding is being used.
  • the preview subsystem transmits this frame to the client computer and the client computer then displays this frame as a preview as the video downloads.
  • the scrubbing system also starts transmitting the video file to the client computer system in any of the above described manners.
  • the preview subsystem divides every video into a series of scenes.
  • What constitutes a scene can be determined by a variety of factors. For example, when a user is editing a video, the user may arbitrarily place markers indicating the beginning and ending of each scene.
  • the subsystem may also classify each individual video clip added to a project as a separate scene.
  • the system may also automatically search for places in the video that could constitute a break between scenes such as areas where the screen is completely black, where there is no sound, or where a user has added a transition.
  • the preview subsystem selects one or more frames from each scene within the video and transmits the frames to the client computer while the rest of the video, or portion of the video, downloads.
  • the client computer displays these preview frames in order such that the user sees an approximate representation of the goings-on in each scene of the video before the entire video has downloaded. In this manner, the user sees the entire layout of the video without having downloaded the entire file and may use this as a guide to determine to what point in the video he or she may wish to scrub while the video is still being downloaded. Further, in some embodiments, 61338P/F462
  • the preview subsystem when the user scrubs to a particular time index within the video, the preview subsystem generates a higher concentration of frames from the surrounding scenes (e.g., three frames per scene at different points in each scene rather than only one frame per scene) to help further guide the user in scrubbing within this portion of the video.
  • a higher concentration of frames from the surrounding scenes e.g., three frames per scene at different points in each scene rather than only one frame per scene
  • a video is divided into a series of discrete files on the server.
  • the full file is divided at any point where there is a hard cut in the video, such as where there is a transition or a scene change.
  • the system stores information relating to the time indices contained in each file in any manner suitable for processing by a video editor or video player.
  • each file may contain two arrays containing the byte number and time index for each frame.
  • the server transmits the files to the client computer, and the client computer stitches them back together to form a complete video file.
  • the system receives input from the client computer indicating that the user wishes to scrub to a time index of the video that has not yet been downloaded, the system closes the current download stream and start transmitting the portion of the video that has already been downloaded. Further, the client computer stores in memory any portions of the video that have completed download and stitches them together with any contiguous portions such that the client computer does not need to download them again should the system receive input indicating that the user wishes to scrub to a time index within one of those portions. This allows the client computer to download videos and to scrub to specific time indices in much the same manner as the above described embodiments. This embodiment also permits the client computer to store discrete sections of the video in memory so that it does not have to redownload portions of the video that have already been downloaded.
  • the system locates hardcuts by searching for areas in the video where there are simultaneous breaks in both the audio and visual portions of the video. In some embodiments of the invention, the system may stitch together otherwise separate video clips into one video file. 61338P/F462
  • the system when the system receives a request for a video from the client computer, the system first determines whether it already has a cached version of the video file. For example, if the client computer requests a portion of the video running from the third second in the video to the tenth second in the video, the system will determine whether a file for this portion of the video has already been created, either for that client computer or for another client computer. If such a file already exists, then the server will transmit this file to the client computer. If not, then the server will generate a new video file according to any method described above or by any other suitable method.
  • the name of the video file and the desired portion (start and end times) of the video are encoded together to form a unique filename for the video file.
  • the system encodes this information into a unique filename.
  • the system may thus locate a given section of video by encoding the name and requested time indices into a filename and by then checking the filesystem for that filename.
  • this information is stored in a database, which maps from the filename and section to a unique file on disk or in memory.

Abstract

A video downloading and scrubbing system for use with a web-based video editing system is provided. The downloading and scrubbing system includes: a scrubbing subsystem configured to: receive a user request for a portion of a video at a particular time index; create a data stream beginning containing video data relating to that time index in the video; and transmit the data; and a preview subsystem configured to provide a preview of video data to the user prior to the user completing the download of the video.

Description

61338P/F462
VIDEO DOWNLOADING AND SCRUBBING SYSTEM AND METHOD
FIELD OF THE INVENTION
[0001] The present invention relates to video downloading and scrubbing systems, and more particularly to a video downloading and scrubbing system and method for web-based video editing systems.
BRIEF DESCRIPTION OF THE DRAWINGS [0002] FIG. 1 is a block diagram of a web-based video editing system according to a first embodiment of the present invention.
[0003] FIG. Ia is a block diagram of a web-based video editing system according to some embodiments of the present invention.
[0004] FIG. 2 is a block diagram of an embodiment of a video downloading and scrubbing system of the web-based video editing system of FIG. 1.
[0005] FIG. 3 shows a diagram of one representation of the video files' composition and the manner in which the scrubbing system edits and manipulates them.
[0006] FIG. 4 shows a block diagram of the process by which the system transmits large video files. [0007] FIG. 5 shows a flowchart diagram of a method of operation on the client computer for processing user input.
[0008] FIG. 6 shows a sample representation of video files with delta encoding.
[0009] FIG. 7 shows a sample representation of the video files with delta encoding and the manner in which the system manipulates them. 61338P/F462
DETAILED DESCRIPTION OF THE INVENTION
[0010] In a traditional online video player program, the video player downloads video files and scrubs to specific time indexes in one of several ways. The first method, known as progressive downloading, involves downloading the entire video file at once. The data for the file is downloaded sequentially, thus the video player first downloads the data for the first frame of the video, followed by the next frame, and so forth until it reaches the last frame. As the player downloads the file, the user may play the downloaded portion of the file and may scrub to any portion of the video that has already been downloaded. If the user attempts to scrub past this point, the video player will typically scrub to the end of the downloaded portion of the file and will stop playing. Similarly, when the user is playing the file as it is being downloaded, if, due to lag, slow connection speed, or some other reason, the file plays faster than the remaining portion can be downloaded, the video player will halt play when it reaches the end of the downloaded portion of the file.
[0011] FIG. 1 is a block diagram of a web-based video editing system according to a first embodiment of the present invention. The editing system includes one or more communication devices 110 each having a graphical user interface 115, a server 120 having a connection manager 130 and a video downloading and scrubbing system 140 operating on the server, and a network 150 over which the one or more communication devices and the server communicate. The communication devices may include, but are not limited to, a personal computer, a mobile telephone, a PDA, or any other communication device configured to operate as a client computer to the server. In some embodiments, a user may operate the communication device to develop a web- based video to be displayed on the graphical user interface. The network to which the server and devices are coupled may be a wireless or a wireline network and may range in size from a local area network to a wide area network to the Internet. A dedicated open socket connection exists between the connection manager and the communication devices. 61338P/F462
[0012] FIG. Ia is a block diagram of some embodiments of the web-based video editing system of FIG. 1. In these embodiments, the system does not include a connection manager for communication between the client computer and the server. Otherwise, client computer 1 10a is an instance of client computer 110, graphical user interface 115a is an instance of grpahical user interface 115, server 120a is an instance of server 120, video downloading and scrubbing system 140a is an instance of video donloading and scrubbing system 140, and internet 150a is an instance of internet 150. All the components in FIG. Ia are thus identical to those in FIG. 1,, and they are all configured to operate as described in FIG. 1.
[0013] In some embodiments of the system, one or more client computers are configured to transmit information to and receive information from the server. In some embodiments, each of the client computers is configured to send a query for information and the server is configured to respond to the query by sending the requested information to the client computer. In another embodiment, one or more of the client computers is configured to transmit commands to the server and the server is configured to perform functions in response to the commands. [0014] In some embodiments, each of the client computers is configured with an application for displaying multimedia on the graphical user interface of the client computer. The application may be Adobe Flash® or any other application capable of displaying multimedia. [0015] In some embodiments, videos are as stored as files on the server or on a remote computer connected to the server. The files may be Flash FLV format files or any other file suitable for storing videos that can be downloaded to a client computer.
[0016] In some embodiments, the connection manager is configured to determine the condition of the server and perform asynchronous messaging to one or more of the client computers over the dedicated open socket connection. In some embodiments, the content of the message is indicative of the state of the server. 61338P/F462
[0017] The server is configured to receive requests from one or more of the client computers and perform functions in response to the received requests. The server performs any number of functions typically performed on the server of a web-based video editing system. In some embodiments, the server provides a video downloading and scrubbing system for the web-based video editing system.
[0018J In some embodiments, the video downloading and scrubbing system is executed on the server. In other embodiments, the video downloading and scrubbing system may be executed on a computer that is remote from but in communication with the server. The video downloading and scrubbing system is configured to allow a user to download all or portions of a video, scrub to specified time indices within the video once it has been downloaded, scrub to specified time indices in a video that is currently being downloaded, scrub to specified time indices in a video that has not yet started to download, and scrub to specified time indices within all or portions of a video without experiencing significant lag time.
[0019] FIG. 2 is a block diagram of an embodiment of a video downloading and scrubbing system of the web-based video editing system of FIG. 1. The video downloading and scrubbing system includes a scrubbing subsystem 210 and a preview subsystem 220. In some embodiments, the scrubbing subsystem includes a processor 212, memory 214, and computer code product including instructions stored in the memory and adapted to cause the processor, and thereby the scrubbing subsystem, to receive and process user scrubbing requests. The memory also stores information indicative of the user scrubbing requests. The memory may be any type of read-write memory, including, but not limited to, random access memory. In some embodiments, the scrubbing subsystem receives input from the user including the identity of the user, the video the user wishes to view, and the time index in the video to which the user wishes to scrub.
[0020] The video may be stored in the editing system of the server (not shown), the scrubbing subsystem memory 214, the preview subsystem memory 224, or at a remote location connected to 61338P/F462
the network of FIG. 1. The videos may be data provided by the web-based video editing system or data generated by the user. [0021] Still referring to FIG. 2, in some embodiments, the preview subsystem includes a processor 222, memory 224, and computer code product including instructions stored on the memory and adapted to cause the processor, and thereby the preview subsystem, to receive and process user preview requests or preview requests from the scrubbing subsystem. The memory also stores information indicative of the requests from the scrubbing subsytem. The memory may be any type of read- write memory, including, but not limited to, random access memory. In some embodiments, the preview subsystem receives input from the user including the identity of the user, the video the user wishes to view, and the time index in the video to which the user wishes to scrub. In some embodiments, the preview subsystem receives this input from the scrubbing subsystem. [0022] In some embodiments, the preview subsystem generates previews frames. These preview frames may be selected from throughout the video or they may be from a particular portion of the video. For example, the frames may be selected from periods of time contiguous to that which the user has requested to scrub.
[0023] In some embodiments, the preview subsystem receives further input relating to the quality or resolution of the preview and generates preview frames of that quality or resolution. [0024] FIG. 3 shows a diagram of one representation of the video files' composition and the manner in which the scrubbing system edits and manipulates them. Video file 300 includes a header 310 and data 320. The header includes a signature, flags, a version number, an offset, and/or any other variables or information necessary for a video editor or player to recognize and process the file. The data includes a stream of tags including one or more fields including fields for a timestamp, the previous tag size, the body length, padding, type of tag, and any other fields relating to data for a video file. Each of the tags contains packets of audio, video, or meta data. 61338P/F462
[0025] In some embodiments, when dealing with smaller size video files, the system receives input from the user indicating the time index to which he desires to scrub. The system opens the video file 300, locates the point 330 in the data 320 within the file 300 that corresponds to the input for the user selected time index, and splices out the data 340 following that point. Splicing includes any combination of copying to a new location in memory, providing pointers to particular location in memory, tagging particular locations in the file, or any other acceptable method or means for selecting data from a file and later streaming it to the client computer. [0026] The amount of the data that is spliced varies for each embodiment. In some embodiments, the data only corresponds to a small snippet of the video. In other embodiments, the snippet of data only corresponds to the portion of the video that the particular user has been editing. No matter the embodiment, the snippet of data is generally smaller in size than the original file. Once the snippet has been located and spliced, the system appends a new header 350 to the beginning of the snippet. In some embodiments, appending the header data may, for example, involve streaming header data to the client computer and subsequently streaming the spliced data. In other embodiments, appending the header may, for example, involve creating a new file containing the header and the spliced data. The above examples for appending header data are illustrative only as persons having ordinary skill in the art would recognize. [0027] As a result of appending a new header, a new video file 360 has been created containing only the portions of the video the user wishes to view and beginning at the time index to which the user indicated he wishes to scrub. Because the new file has the appropriate header data, it operates as any other video file would and any video player would download the new file and allow it to be viewed as if it were an original file because the video player will process the file as if it is downloading a full and complete video file. For example, if the user begins to view a one minute file and scrubs to the time index corresponding to 30 seconds within the video, the system will 61338P/F462
splice a portion of the video file data beginning at the 30 second mark and will append a new header to the portion. The system will then transmit the new smaller file to the client computer. [0028] FIG. 4 shows a block diagram of the process by which the system transmits large video files. In some embodiments, dealing with larger video files, the system receives 410 input from a user indicating that he wishes to view a video file. In some embodiments where the user may only view one video at a time, the system closes 420 any existing video data stream to the client computer. The system then transmits 430 the video file to the client computer. The client computer progressively downloads the video file from the beginning of the file. In progressive downloading, the client computer begins downloading the video file from the beginning. As the download progresses, the user may scrub to any time index in the video so long as the data within the video corresponding to that time index has already been downloaded to the client computer. [0029] While the larger file is downloading to the client computer, the system may receive 440 input from the user indicating that he wishes to scrub to another time index within the video. If the system determines 450 that this time index occurs at a position in the file that has already been downloaded, the system scrubs 460 to that time index on the client computer and continues to download the file. If the system determines 450 that the time index occurs in a portion of the file that has not yet been downloaded, the system closes 465 the data stream for the video file currently downloading and locates 470 the byte number in the video file on the server that corresponds with the time index requested by the user. The system then streams 480 header data to the client computer and then transmits 490 this video file to the client computer, and the client computer begins to progressively download the new file. As this new file progressively downloads, the user may scrub to any time index corresponding to a downloaded portion of the file. In some embodiments, the system maintains a time line that shows the length of the original video and the time index in the original video even though the video currently being downloaded begins at the 61338P/F462
selected time index and contains no data for the portion of the video that would proceed it in the original time index. [0030] If, while the new video file is downloading, the system receives input indicating the user wishes to scrub to a portion of the video that occurs before the beginning the of the new video file, the system closes the video file/stream that is currently being downloaded. The system opens the original video file and locates the byte number in the file corresponding to the newly selected time index. The system then truncates the video data at that point and appends a header to the beginning portion of the data. At this point, the new video file consists of the entirety of the original video data except for any point that occurs before the user selected time index. The client computer then begins progressively downloading and playing this new video file. As this new video file downloads, the user may scrub to any portion of the file that has already been downloaded. [0031] Further, if the user attempts to scrub to a time index in the video that occurs past the downloaded portion, the system will once again close the current video file and create a new video file for download as described above and shown in FIG. 4.
[0032] FIG. 5 shows a flowchart diagram of a method of operation on the client computer for processing user input. When the system receives 510 input from the user requesting a particular video, the client computer sends 520 a request to the server for data corresponding to the video. The client begins receiving 530 the video data, processes, and plays 540 the video as it downloads. The player continues to download and play the video until it receives 550 input from the user indicating that the user wishes to scrub to a different time index. The system then determines 560 whether the time index is within the already downloaded portion of the video. If it is, the system scrubs 570 to that time index within the video and continues to play and download the video until it receives 550 further input indicating that the user wishes to scrub to another time index. If, instead, the system determines 560 that the time index is not within the already downloaded portion of the 61338P/F462
video, the system closes 580 the current data stream and sends 590 a request to the server for that time index. The system then begins receiving 530 new video data that begins at that time index. [0033] In some embodiments, meta data is injected into the video files containing the byte number in the file for frames in the video. This meta data also contains the time index for the corresponding frame. Depending on the embodiment and preferences during implementation, the meta data includes this information for the time index and byte number for each frame, for every set number of frames, or for any other process of selecting frames that best suits the needs of the current implementation. The system uses this data to locate the byte number for the frame corresponding to the time index selected by the user. In some embodiments, the meta data is in the form of two arrays.
[0034] FIG. 6 shows a sample representation of video files with delta encoding. In some embodiments, the system includes files using delta encoding. Delta encoding is a way of storing or transmitting data in the form of differences between sequential data rather than as complete files.
The files 600 include a header 610 and data 620. The header 610 includes a signature, flags, a version number, an offset, and any other variables or information necessary for a video editor or player to recognize and process the file. The data 620 includes a stream of tags including one or more fields including fields for a timestamp, the previous tag size, the body length, padding, type of tag, and any other fields relating to data for a video file. Each of the tags contains packets of audio, video, or meta data. The video packets are encoded using delta encoding and include a series of keyframes 630 and delta frames 640. The data for each keyframe 630 contains data corresponding to the entire image for one frame of the video. The intervening delta frames 640 contain only the data for the changes in the image from the preceding frame. For example, if only three pixels change between one frame and the next, the data for the second frame would only include the information necessary to indicate the change in those three pixels rather than data for the entire image in the second frame. As a result, the delta frames are much smaller in size than the 61338P/F462
key frames. The number of key frames in a video varies per each video; however, the file size of the video increases greatly to coincide with its number of key frames whereas an increase in the number of delta frames does not greatly increase the file size.
[0035] In some embodiments, the video files are in Flash FLV format including delta encoding. [0036] In some embodiments, the video files are also injected with meta data in the form of two arrays that contain the byte number and time index for each key frame in a video file. This metadata allows the video player to accurately seek within the video and do accurate re-buffering of the video file despite potentially only having been sent a section of the file.
[0037] According to another embodiment of the invention, referring to FIG. 7, when the system receives input from the client computer indicating that the user wishes to scrub to a particular time index of the video clip, the system locates in the video file on the server the last key frame 750 that precedes the frame 760 corresponding to the requested time index, truncates all the previous data 790 in the file, and appends the remaining portion of the file 795 to the new header 770. The server then streams the file 799 to the client computer, and the client begins downloading the file as if this were the entirety of the file. In some embodiments, appending the header data involves, for example, streaming header data to the client computer and subsequently streaming the spliced data. In other embodiments, appending the header involves, for example, creating a new file containing the header and the spliced data. The system transmits additional data to the viewer portion of the client computer system instructing it to not display the audio or visual aspects of the file 799 until it reaches the frame 760 corresponding to the requested time index.
[0038] Thus, the client begins downloading the file beginning at the nearest key frame 750 and applies each of the intervening delta frames 780 to the key frame 750 until it reaches the delta frame 760 corresponding to the requested time index. The client computer processes the intervening delta frames in real time or processes them at the fastest possible speed for the computer. Because the size of the delta frames is extremely small in comparison to the size of the 61338P/F462
key frames, and the system has only had to download one key frame, download time is greatly decreased. As a result, the system has rapidly scrubbed to the requested time index without having to download a large amount of data. The system then makes the video visible and audible from this point forward. The user then can scrub to any time index within the downloaded portion of the file. If the user attempts to scrub to a time index before the file downloading began or to a time index that occurs after the portion of the file that has already been downloaded, the system will create a new file in the above manner that begins at that time index and will transmit it to the client. [0039] In another embodiment of the above described invention, the server maintains two versions of each video file, one that is completely delta encoded, and one that has a large number of key frames. This keyframe-heavy version is designed to be used in a web-based video editor, and frequent keyframes facilitate interactive scrubbing and video cropping because most client video implementations can only scrub to keyframes. However, frequent keyframes greatly increase the size of video, so it is desirable to use the delta-encoded version of a video when downloaded by an audience. In some embodiments, after the editor adjustments are made, a new copy of the video is rendered out in delta-encoded form for audience viewing. In some embodiments, a new copy of the video is generated in response to a client request by combining a heavily delta-encoded version of the video with the editor version of the video. In this approach, when the video was initially encoded, two versions are generated by the system - a keyframe-heavy editor version of the video, and a heavily delta-encoded version of the video with keyframes spaced at large intervals, such as once per second. The system generates a video file by generating a header and initial keyframe using the editor video, as described above. The system then uses a server-side decoder to decode the delta frames and thus generate full keyframes and appends these keyframes to the generated video file. In some embodiments, the system uses the keyframe-heavy video to generate the keyframes, and in other embodiments, the system uses the delta-encoded version of the video. The system continues this process until a corresponding keyframe is reached in the delta-encoded 61338P/F462
version of the video. Finally, the delta-encoded version of the video is then appended to the generated file. This file can be cached or streamed to the client computer as described in the other embodiments, above.
[0040] In another embodiment, the video downloading and scrubbing system includes a preview subsystem. The preview subsystem may receive user input from the client computer indicating a time index to which a user wishes to scrub. The preview subsystem then locates the frame corresponding to the time index and splices only that frame out of the file, or it splices the nearest keyframe if delta encoding is being used. The preview subsystem then transmits this frame to the client computer and the client computer then displays this frame as a preview as the video downloads. The scrubbing system also starts transmitting the video file to the client computer system in any of the above described manners. [0041] In another embodiment, the preview subsystem divides every video into a series of scenes. What constitutes a scene can be determined by a variety of factors. For example, when a user is editing a video, the user may arbitrarily place markers indicating the beginning and ending of each scene. The subsystem may also classify each individual video clip added to a project as a separate scene. The system may also automatically search for places in the video that could constitute a break between scenes such as areas where the screen is completely black, where there is no sound, or where a user has added a transition. When a user begins downloading a video to the client computer, the preview subsystem selects one or more frames from each scene within the video and transmits the frames to the client computer while the rest of the video, or portion of the video, downloads. The client computer displays these preview frames in order such that the user sees an approximate representation of the goings-on in each scene of the video before the entire video has downloaded. In this manner, the user sees the entire layout of the video without having downloaded the entire file and may use this as a guide to determine to what point in the video he or she may wish to scrub while the video is still being downloaded. Further, in some embodiments, 61338P/F462
when the user scrubs to a particular time index within the video, the preview subsystem generates a higher concentration of frames from the surrounding scenes (e.g., three frames per scene at different points in each scene rather than only one frame per scene) to help further guide the user in scrubbing within this portion of the video.
[0042] In another embodiment, a video is divided into a series of discrete files on the server. The full file is divided at any point where there is a hard cut in the video, such as where there is a transition or a scene change. Once the file has been divided into a series of discrete files, the system stores information relating to the time indices contained in each file in any manner suitable for processing by a video editor or video player. For example, each file may contain two arrays containing the byte number and time index for each frame. In this embodiment, the server transmits the files to the client computer, and the client computer stitches them back together to form a complete video file. If the system receives input from the client computer indicating that the user wishes to scrub to a time index of the video that has not yet been downloaded, the system closes the current download stream and start transmitting the portion of the video that has already been downloaded. Further, the client computer stores in memory any portions of the video that have completed download and stitches them together with any contiguous portions such that the client computer does not need to download them again should the system receive input indicating that the user wishes to scrub to a time index within one of those portions. This allows the client computer to download videos and to scrub to specific time indices in much the same manner as the above described embodiments. This embodiment also permits the client computer to store discrete sections of the video in memory so that it does not have to redownload portions of the video that have already been downloaded. In some embodiments, the system locates hardcuts by searching for areas in the video where there are simultaneous breaks in both the audio and visual portions of the video. In some embodiments of the invention, the system may stitch together otherwise separate video clips into one video file. 61338P/F462
[0043] In some embodiments, when the system receives a request for a video from the client computer, the system first determines whether it already has a cached version of the video file. For example, if the client computer requests a portion of the video running from the third second in the video to the tenth second in the video, the system will determine whether a file for this portion of the video has already been created, either for that client computer or for another client computer. If such a file already exists, then the server will transmit this file to the client computer. If not, then the server will generate a new video file according to any method described above or by any other suitable method.
[0044] In some embodiments, the name of the video file and the desired portion (start and end times) of the video are encoded together to form a unique filename for the video file. Thus, when caching sections of video files on disk or in memory, the system encodes this information into a unique filename. The system may thus locate a given section of video by encoding the name and requested time indices into a filename and by then checking the filesystem for that filename. In some embodiments, this information is stored in a database, which maps from the filename and section to a unique file on disk or in memory.

Claims

61338P/F462WHAT IS CLAIMED IS:
1. A video downloading and scrubbing system for use with a web-based video editing system, the downloading and scrubbing system comprising: a video server including a network output that transmits data to a first remote communication device over a network and a network input that receives data from a second remote communication device over the network, the video server configured to: send an initial file of video data to the first remote communication device using the network output, the initial file including an initial file header portion and an initial file data portion receive, before the initial file of video data has been completely sent, a request for a portion of the video data corresponding to a particular time index from the second remote computer using the network input; determine what portion of the file of video data has been sent; when it is determined that the video data corresponding to the particular time index is in the portion of the file of video data that has been sent, continue sending the initial file of video data; and when it is determined that the video data corresponding to the particular time index is not in the portion of the file of video data that has been sent, create a scrubbed file of video data, the scrubbed file of video data including a scrubbed header portion and a scrubbed data portion, the scrubbed data portion including the video data corresponding to the particular time index within a predetermined portion of the video data at the beginning of the scrubbed data portion, stop sending the initial file of video data, and send the scrubbed file of video data to the first remote communication device using the network output. 61338P/F462
2. The system of claim 1 wherein a single communication device is both the first remote communication device and the second remote communication device.
3. The system of claim 1 wherein the first remote communication device comprises a graphical user interface.
4. The system of claim 3 wherein the first remote communication device comprises at least one selected from the group consisting of: a personal computer, a laptop computer, a handheld computer, a phone, and a video player.
5. The system of claim 1 wherein the network is the Internet.
6. A method of downloading and scrubbing video data for use with a video server including a network output that transmits data to a first remote computer over a network and a network input that receives data from a second remote computer over the network, the method comprising: sending an initial file of video data to the first remote computer using the network output, the initial file including an initial file header portion and an initial file data portion receiving, before the initial file of video data has been completely sent, a request for a portion of the video data corresponding to a particular time index from the second remote computer using the network input; determining what portion of the file of video data has been sent; I 61338P/F462
when it is determined that the video data corresponding to the particular time index is in the portion of the file of video data that has been sent, continuing to send the initial file of 5 video data; and when it is determined that the video data corresponding to the particular time index is not in the portion of the file of video data that has been sent, creating a scrubbed file of video data, the scrubbed file of video data including a scrubbed header portion and a scrubbed data portion, the scrubbed data portion 10 including the video data corresponding to the particular time index within a predetermined portion of the video data at the beginning of the scrubbed data portion, ceasing sending the initial file of video data, and sending the scrubbed file of video data to the first remote computer using the network output. 15
7. The method of claim 6 wherein a single communication device is both the first remote communication device and the second remote communication device.
8. The method of claim 6 wherein the first remote communication device includes a 10 graphical user interface.
9. The method of claim 8 wherein the first remote communication device comprises at least one selected from the group consisting of: a personal computer, a laptop computer, a handheld computer, a phone, and a video player.
»5
10. The method of claim 1 wherein the network is the Internet.
PCT/US2008/001139 2007-01-26 2008-01-28 Video downloading and scrubbing system and method WO2008094533A2 (en)

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US89755207P 2007-01-26 2007-01-26
US60/897,552 2007-01-26
US12/021,272 US7986867B2 (en) 2007-01-26 2008-01-28 Video downloading and scrubbing system and method
US12/021,272 2008-01-28

Publications (2)

Publication Number Publication Date
WO2008094533A2 true WO2008094533A2 (en) 2008-08-07
WO2008094533A3 WO2008094533A3 (en) 2008-10-02

Family

ID=39674694

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2008/001139 WO2008094533A2 (en) 2007-01-26 2008-01-28 Video downloading and scrubbing system and method

Country Status (1)

Country Link
WO (1) WO2008094533A2 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP2242057A3 (en) * 2009-04-14 2010-12-01 MaxT Systems Inc. Multi-user remote video editing

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20050283547A1 (en) * 1999-04-06 2005-12-22 Microsoft Corporation Streaming information appliance with buffer read and write synchronization
US6993787B1 (en) * 1998-10-29 2006-01-31 Matsushita Electric Industrial Co., Ltd. Providing VCR functionality for data-centered video multicast
US20060184980A1 (en) * 2003-04-07 2006-08-17 Cole David J Method of enabling an application program running on an electronic device to provide media manipulation capabilities
US20060288392A1 (en) * 2005-05-31 2006-12-21 Canon Kabushiki Kaisha Frame scattering for video scrubbing

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6993787B1 (en) * 1998-10-29 2006-01-31 Matsushita Electric Industrial Co., Ltd. Providing VCR functionality for data-centered video multicast
US20050283547A1 (en) * 1999-04-06 2005-12-22 Microsoft Corporation Streaming information appliance with buffer read and write synchronization
US20060184980A1 (en) * 2003-04-07 2006-08-17 Cole David J Method of enabling an application program running on an electronic device to provide media manipulation capabilities
US20060288392A1 (en) * 2005-05-31 2006-12-21 Canon Kabushiki Kaisha Frame scattering for video scrubbing

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP2242057A3 (en) * 2009-04-14 2010-12-01 MaxT Systems Inc. Multi-user remote video editing
US8818172B2 (en) 2009-04-14 2014-08-26 Avid Technology, Inc. Multi-user remote video editing

Also Published As

Publication number Publication date
WO2008094533A3 (en) 2008-10-02

Similar Documents

Publication Publication Date Title
US7986867B2 (en) Video downloading and scrubbing system and method
US8332886B2 (en) System allowing users to embed comments at specific points in time into media presentation
US10735800B2 (en) Rendering content and time-shifted playback operations for personal over-the-top network video recorder
US6557042B1 (en) Multimedia summary generation employing user feedback
US10313714B2 (en) Audiovisual content presentation dependent on metadata
US9654815B2 (en) Advertising detection in adaptive bitrate streaming
US9535988B2 (en) Blog-based video summarization
US7941554B2 (en) Sparse caching for streaming media
US8365235B2 (en) Trick play of streaming media
US8793282B2 (en) Real-time media presentation using metadata clips
US20160360247A1 (en) Delivering Modified Content Meeting Time Constraints
US8036261B2 (en) Feature-vector generation apparatus, search apparatus, feature-vector generation method, search method and program
US7149359B1 (en) Searching and recording media streams
US20050120126A1 (en) Multi-level skimming of multimedia content using playlists
TWI403970B (en) Bookmarking in videos
US20020026521A1 (en) System and method for managing and distributing associated assets in various formats
US8584169B1 (en) System and method for creating and managing custom media channels
JP2002185917A (en) Method for providing video data and video index attaching device
US20080162623A1 (en) Video Encoder and Content Distribution System
KR20090130082A (en) Method and system for previewing media over a network
EP3531707A1 (en) Audio content playback control
WO2007130472A2 (en) Methods and systems for providing media assets over a network
US10575039B2 (en) Delivering media content
CN102550021B (en) Method and system for providing preview video, media server and playing terminal
US8806342B2 (en) Creation of a reference point to mark a media presentation

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 08713314

Country of ref document: EP

Kind code of ref document: A2

NENP Non-entry into the national phase

Ref country code: DE

32PN Ep: public notification in the ep bulletin as address of the adressee cannot be established

Free format text: NOTING OF LOSS OF RIGHTS PURSUANT TO RULE 112(1) EPC, EPO FORM 1205A SENT ON 10/11/09

122 Ep: pct application non-entry in european phase

Ref document number: 08713314

Country of ref document: EP

Kind code of ref document: A2