US20010013068A1 - Interleaved multiple multimedia stream for synchronized transmission over a computer network - Google Patents

Interleaved multiple multimedia stream for synchronized transmission over a computer network Download PDF

Info

Publication number
US20010013068A1
US20010013068A1 US08/826,345 US82634597A US2001013068A1 US 20010013068 A1 US20010013068 A1 US 20010013068A1 US 82634597 A US82634597 A US 82634597A US 2001013068 A1 US2001013068 A1 US 2001013068A1
Authority
US
United States
Prior art keywords
video
audio
file
packet
annotation
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
US08/826,345
Other versions
US6449653B2 (en
Inventor
Anders Edgar Klemets
Philip A. Chou
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Microsoft Technology Licensing LLC
Original Assignee
Individual
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 Individual filed Critical Individual
Priority to US08/826,345 priority Critical patent/US6449653B2/en
Assigned to VXTREME, INC. reassignment VXTREME, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: CHOU, PHILIP A., KLEMETS, ANDERS EDGAR
Assigned to MICROSOFT CORPORATION reassignment MICROSOFT CORPORATION MERGER (SEE DOCUMENT FOR DETAILS). Assignors: VXTREME, INC.
Publication of US20010013068A1 publication Critical patent/US20010013068A1/en
Application granted granted Critical
Publication of US6449653B2 publication Critical patent/US6449653B2/en
Assigned to MICROSOFT TECHNOLOGY LICENSING, LLC reassignment MICROSOFT TECHNOLOGY LICENSING, LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: MICROSOFT CORPORATION
Anticipated expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/80Responding to QoS
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/1066Session management
    • H04L65/1101Session protocols
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/75Media network packet handling
    • H04L65/752Media network packet handling adapting media to network capabilities
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/75Media network packet handling
    • H04L65/762Media network packet handling at the source 
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/40Network security protocols

Definitions

  • the present invention relates to multimedia communications. More particularly, the present invention relates to the delivery of an interleaved multimedia stream over a diverse computer network.
  • Pending patent application VXT — 703 describes the production of separate video, audio and annotation streams for synchronous delivery from a stream server to a client computer.
  • the stream server is not available or not affordable to the end user at the client computer, then the client computer may only have access to web servers which are not designed to provide synchronous delivery capability of the separate video, audio and annotation streams.
  • the present invention provides interleaved multimedia streams for servers and client computers coupled to each other by a diverse computer network which includes local area networks (LANs) and/or wide area networks (WANs) such as the internet.
  • Interleaved multimedia streams can include compressed video frames for display in a video window, accompanying compressed audio frames and annotation frames.
  • a producer captures separate video/audio frames and generates an interleaved multimedia file.
  • the interleaved file include annotation frames which provide either pointer(s) to the event(s) of interest or include displayable data embedded within the annotation stream.
  • each annotation frame includes either an event locator or an event data.
  • each annotation frame includes an event time marker which corresponds to the time stamp(s) of associated video frame(s) within the video stream.
  • the interleaved file is then stored in the web server for subsequent retrieval by client computer(s) in a coordinated manner, so that the client computer(s) is able to synchronously display the video frames and displayable event(s) in a video window and event window(s), respectively.
  • the interleaved file includes packets with variable length fields, each of which are at least one numerical unit in length.
  • FIG. 1 is a block diagram of an exemplary computer system for practicing the various aspects of the present invention.
  • FIG. 2 is a block diagram showing an exemplary hardware environment for practicing the annotated video-on-demand (VOD) system of the present invention.
  • VOD video-on-demand
  • FIG. 3A shows one embodiment of a producer which includes a capture module and an author module.
  • FIG. 3B shows another embodiment of the producer in which the capture module generates an interleaved stream.
  • FIG. 4A is a flowchart illustrating the capture of a live video/audio stream from a video camera or from a previously stored video file.
  • FIGS. 4B and 4C are flowcharts illustrating a locator annotation stream and a data annotation stream, respectively.
  • FIG. 5 shows an exemplary format for storing and delivering a compressed video stream.
  • FIG. 6 shows an exemplary customized LiveScreen display which includes a video window, a set of VCR-like control buttons, a selectable table of contents (TOC) and an HTML page window.
  • TOC selectable table of contents
  • FIG. 7 illustrates an author tool provided by an author module for the designer to visually creating annotation streams.
  • FIGS. 8A and 8B are exemplary formats illustrating a locator annotation stream and a data annotation stream, respectively.
  • FIG. 9A illustrates one embodiment of the client computer which includes a web browser and a browser plug-in module for interfacing a web browser with a client module.
  • FIG. 9B illustrates another embodiment of the client computer in which the browser plug-in module receives an interleaved stream from the web server and distributes the video/audio stream(s) to the video/audio decoder(s) and the annotation stream(s) to the annotation interpreter.
  • FIGS. 10A and 10B are flowcharts illustrating the operation of the client module.
  • FIG. 11 is a flowchart illustrating the use of a table of content with content labels enabling a viewer to skip forward or backward to predetermined locations in the video/audio stream.
  • FIGS. 12A and 12B are two portions of a flowchart illustrating the combination of video frames from a video file and audio frames from an audio file into an interleaved file.
  • FIGS. 13A and 13B illustrate an exemplary format of the interleaved file which includes a plurality of data packets for storing video and audio frames with a variable packet length field.
  • FIGS. 14A, 14B, and 14 C show three exemplary formats for the variable packet length field of FIG. 13B.
  • FIG. 15 is a flowchart illustrating the selection of a suitable format for writing a packet into the interleaved file.
  • FIG. 16 is a flowchart illustrating the interpretation of the exemplary variable packet length field formats of FIGS. 14A, 14B and 14 C, respectively.
  • FIG. 1 is a block diagram of an exemplary computer system 100 for practicing the various aspects of the present invention.
  • Computer system 100 includes a display screen (or monitor) 104 , a printer 106 , a floppy disk drive 108 , a hard disk drive 110 , a network interface 112 , and a keyboard 114 .
  • Computer system 100 includes a microprocessor 116 , a memory bus 118 , random access memory (RAM) 120 , read only memory (ROM) 122 , a peripheral bus 124 , and a keyboard controller 126 .
  • RAM random access memory
  • ROM read only memory
  • Computer system 100 can be a personal computer (such as an Apple computer, e.g., an Apple Macintosh, an IBM personal computer, or one of the compatibles thereof), a workstation computer (such as a Sun Microsystems or Hewlett-Packard workstation), or some other type of computer.
  • a personal computer such as an Apple computer, e.g., an Apple Macintosh, an IBM personal computer, or one of the compatibles thereof
  • a workstation computer such as a Sun Microsystems or Hewlett-Packard workstation
  • some other type of computer such as an Apple computer, e.g., an Apple Macintosh, an IBM personal computer, or one of the compatibles thereof.
  • Microprocessor 116 is a general purpose digital processor which controls the operation of computer system 100 .
  • Microprocessor 116 can be a single-chip processor or can be implemented with multiple components. Using instructions retrieved from memory, microprocessor 116 controls the reception and manipulation of input data and the output and display of data on output devices.
  • Memory bus 118 is used by microprocessor 116 to access RAM 120 and ROM 122 .
  • RAM 120 is used by microprocessor 116 as a general storage area and as scratch-pad memory, and can also be used to store input data and processed data.
  • ROM 122 can be used to store instructions or program code followed by microprocessor 116 as well as other data.
  • Peripheral bus 124 is used to access the input, output, and storage devices used by computer system 100 .
  • these devices include display screen 104 , printer device 106 , floppy disk drive 108 , hard disk drive 110 , and network interface 112 .
  • Keyboard controller 126 is used to receive input from keyboard 114 and send decoded symbols for each pressed key to microprocessor 116 over bus 128 .
  • Display screen 104 is an output device that displays images of data provided by microprocessor 116 via peripheral bus 124 or provided by other components in computer system 100 .
  • Printer device 106 when operating as a printer provides an image on a sheet of paper or a similar surface.
  • Other output devices such as a plotter, typesetter, etc. can be used in place of, or in addition to, printer device 106 .
  • Floppy disk drive 108 and hard disk drive 110 can be used to store various types of data.
  • Floppy disk drive 108 facilitates transporting such data to other computer systems, and hard disk drive 110 permits fast access to large amounts of stored data.
  • Microprocessor 116 together with an operating system operate to execute computer code and produce and use data.
  • the computer code and data may reside on RAM 120 , ROM 122 , or hard disk drive 120 .
  • the computer code and data could also reside on a removable program medium and loaded or installed onto computer system 100 when needed.
  • Removable program mediums include, for example, CD-ROM, PC-CARD, floppy disk and magnetic tape.
  • Network interface circuit 112 is used to send and receive data over a network connected to other computer systems.
  • An interface card or similar device and appropriate software implemented by microprocessor 116 can be used to connect computer system 100 to an existing network and transfer data according to standard protocols.
  • Keyboard 114 is used by a user to input commands and other instructions to computer system 100 .
  • Other types of user input devices can also be used in conjunction with the present invention.
  • pointing devices such as a computer mouse, a track ball, a stylus, or a tablet can be used to manipulate a pointer on a screen of a general-purpose computer.
  • the present invention can also be embodied as computer readable code on a computer readable medium.
  • the computer readable medium is any data storage device that can store data which can be thereafter be read by a computer system. Examples of the computer readable medium include read-only memory, random-access memory, magnetic data storage devices such as diskettes, and optical data storage devices such as CD-ROMs.
  • the computer readable medium can also be distributed over a network coupled computer systems so that the computer readable code is stored and executed in a distributed fashion.
  • FIG. 2 is a block diagram showing an exemplary hardware environment for practicing the annotated video-on-demand (VOD) system of the present invention.
  • the VOD system includes a production station 210 , a stream server 220 , at least one web server 230 and at least one client computer 240 , each of which can be implemented using computer system 100 described above.
  • Stream server 220 and web server 230 are coupled to client computer 240 via a computer network 290 , e.g., the internet.
  • the disclosed hardware environment is exemplary.
  • production station 210 and stream server 220 can be implemented using two separate computer systems or using one computer system.
  • an optional direct connection (not shown) between production station 210 and stream server 220 can provide faster uploads of compressed video and annotation streams.
  • an audio stream optionally accompanies each video stream.
  • a producer 215 installed in production station 210 , is a user-friendly tool for use by a designer 219 to create a synchronization script which includes annotation stream(s).
  • the annotation stream(s) define the content(s) of a LiveScreen display 245 to be displayed on client computer 240 for a viewer 249 .
  • LiveScreen 245 display provides a graphical user interface (GUI) with multiple windows for synchronously displaying a video stream from stream server 220 and at least one displayable event stream. Examples of displayable events include textual/graphical information such as HTML-scripted web page(s) from web server 230 .
  • GUI graphical user interface
  • producer 215 a includes a capture module 317 a and an author module 318 a .
  • Production station 210 includes 16 MB of RAM and a 1 GB hard disk drive for capturing and storing an uncompressed or precompressed video stream.
  • Sources for generating video streams include a video camera 312 , a video cassette recorder (VCR) (not shown) or a previously digitized video file 314 , e.g., a Video for Windows (.avi) file.
  • VCR video cassette recorder
  • producer 215 a is implemented in a host environment which includes a window-based operating system such as Microsoft Windows 95 and a web browser such as Netscape's Navigator 3.x.
  • step 410 capture module 317 a captures a live video/audio stream from video camera 312 or from the previously stored video file 314 . If video camera 312 provides an analog video stream, e.g., an NTSC signal, a hardware capture card (not shown) provides the required conversion from the analog video stream to a digitized video stream. Because temporary storage of uncompressed video data is memory intensive, some form of pre-compression can be used to reduce the memory storage requirement of the input video stream during capture step 410 and prior to compression step 420 .
  • an analog video stream e.g., an NTSC signal
  • a hardware capture card not shown
  • some form of pre-compression can be used to reduce the memory storage requirement of the input video stream during capture step 410 and prior to compression step 420 .
  • step 420 capture module 420 compresses the digitized video stream using a suitable compression technique.
  • a suitable compression technique e.g., depending on the bandwidth capacity of the connection provided by network 290 between stream server 220 and client computer 240 , e.g., a POTS modem, ISDN or Ethernet, a suitable frame resolution and frame rate combination is selected.
  • FIG. 5 shows an exemplary format 500 for storing and delivering a compressed video stream.
  • a similar format can also be used to store and deliver a separate compressed audio stream. It is also possible to combine, e.g., interleave a compressed video and audio data into one stream for delivery.
  • Audio encoders/decoders are available from a number of commercial sources. Examples include ToolVox from Voxware Inc., 305 College Road East, Princeton, N.J. 08540, and QCELP from QUALCOMM Inc., 10555 Sorrento Valley Road, San Diego, Calif. 92121.
  • FIG. 6 shows an exemplary customized LiveScreen display 600 which includes a video window 610 , a set of VCR-like control buttons 620 , a selectable table of contents (TOC) 630 and an HTML page window 640 .
  • Examples of other displayable event windows include but is not limited to ticker tape windows (not shown).
  • LiveScreen templates 319 are available for designer 219 to use as starting points for composing customized LiveScreen formats.
  • FIG. 7 illustrates an author tool 700 provided by author module 318 a for designer 219 to visually creating annotation streams (step 440 ).
  • annotation streams There are two types of annotation streams.
  • the first type of annotation streams are data annotation streams in which the displayable event data are embedded within the annotation streams.
  • Examples of data annotation streams include ticker annotation streams which include ticker tape data embedded within the annotation stream.
  • the second type of annotation streams are locator annotation streams in which the displayable data is either too cumbersome and/or is continually evolving to be embedded as static data within the annotation stream. Instead, event locator(s) pointing to the location of the displayable data are stored in the annotation streams instead of the displayable data. Examples include URL addresses pointing to HTML pages.
  • Designer 219 may view frames from video stream 500 displayed in video window 720 for referencing and selecting appropriate time stamps to use in generating annotation streams.
  • VCR function buttons e.g., a rewind button 724 , a play button 726 and a fast forward button 728 , are available for designer 219 to quickly traverse video stream 500 . Since video window 720 is provided as a convenience for designer 219 , if designer 219 has prior knowledge of the content of the video stream, designer 219 may proceed with the generation of the annotation streams without viewing video window 720 .
  • author tool 700 displays a flipper time track 750 , a video time track 760 , an audio time track 770 , a ticker time track 780 and a table of contents (TOC) time track 790 .
  • Flipper time track 750 and ticker time track 780 aid designer 217 in generating a flipper annotation stream and a ticker annotation stream, respectively.
  • Another visual control aid, zoom bar 716 enables designer 219 to select the respective portions of the complete time tracks 750 , 760 , 770 , 780 and 790 , as defined by start time indicator 712 and end time indicator 718 , which is currently displayed by author tool 700 .
  • annotation frames are generated by designer 217 to form customized annotation streams (step 440 ).
  • a time hairline 715 spanning time tracks 750 , 760 , 770 , 780 and 790 provides designer 217 with a visual aid to select an appropriate time, displayed in time indicator 714 , for synchronizing a displayable event.
  • the exemplary format of time indicators 712 , 714 and 718 are “hours:minutes:seconds”.
  • FIGS. 4B and 8A are a flowchart and an exemplary format, respectively, illustrating a locator annotation stream 800 a .
  • Locator annotation stream 800 a includes an annotation stream header 810 a , and a plurality of annotation frames 820 a , 830 a , 840 a , . . . 890 a .
  • Each annotation frame includes an event locator and an event time marker, e.g., annotation frame 820 a includes event locator 822 a and event time marker 824 a .
  • One example of a locator annotation stream is a flipper stream.
  • Flipper time track 750 provides a convenient way to select suitable event time marker values, e.g., flipper time markers 751 , 752 , 753 , 754 , for the respective event locators.
  • suitable event time marker values e.g., flipper time markers 751 , 752 , 753 , 754 .
  • URL addresses (event locators) pointing to HTML pages enable client computer 240 to subsequently retrieve textual and/or graphical elements to be displayed at predetermined time as defined by the time markers of the flipper stream.
  • FIGS. 4C and 8B are a flowchart and an exemplary format, respectively, illustrating a data annotation stream 800 b .
  • Locator annotation stream 800 a includes an annotation stream header 810 a , and a plurality of annotation frames 820 a , 830 a , 840 a , . . . 890 a .
  • Each annotation frame includes an event locator and an event time marker, e.g., annotation frame 820 a includes event locator 822 a and event time marker 824 a .
  • One example of a data annotation stream is a ticker stream. The generation of the ticker stream is somewhat similar to that of the flipper stream. However, in the case of the ticker stream, instead of event locators, displayable data is embedded directly into the ticker stream as event data.
  • annotation stream e.g., the flipper stream
  • the annotation stream is given a file name and loaded into a convenient server, e.g., stream server 220 , for subsequent retrieval by client computer 240 .
  • stream server 220 e.g., stream server 220
  • LiveScreen display 600 also includes a table of contents (TOC) 630 , enabling viewer 249 at client computer 240 to skip forward or backward to a point within the entire video/audio stream 500 .
  • TOC 630 include one or more content labels, each indexed to a corresponding time stamp in video stream 500 , as defined by TOC time markers 791 , 792 , 793 , 794 in LiveScreen display 600 .
  • client computer 240 includes a web browser 950 and a browser plug-in module 952 a for interfacing web browser 950 with a main client module 960 .
  • Client module 960 includes an event registry 962 , playout buffer(s) 966 , video/audio decoder(s) 964 , video/audio renderer(s) 965 and one or more dynamically loadable event applet(s), e.g., flipper applet 967 , ticker applet 968 and VCR applet 969 .
  • event registry 962 also functions as an annotation interpreter 963 .
  • FIG. 10A is a flowchart illustrating the operation of client module 960 .
  • viewer 249 has not previously loaded client module 960 in client computer 240 , but has already loaded a web browser 950 , e.g., Netscape's Navigator (step 1010 ).
  • Viewer 249 surfs the world-wide web (www) via the internet and locates a web site of interest to viewer 249 .
  • the web site of interest is hosted on web server 230 .
  • a target web page is downloaded from web server 230 and displayed on client computer 240 .
  • the target web page includes a link to a customized LiveScreen display, e.g., display 600 . If client module 960 has not been previously loaded, client module 960 is now loaded over web browser 950 for processing video/audio and annotation streams (step 1020 ). Depending on the implementation, a copy of client module 960 may be available from the web site of interest. Alternatively, the target web page may provide a HTML link to another web server which has an updated copy of client module 960 .
  • browser plug-in module 952 a is installed over web browser 950 (step 1022 ).
  • plug-in module 952 a provides the interface between client module 960 and web browser 950 .
  • the target web page provides a HTML link to the format for LiveScreen display 600 .
  • the LiveScreen display format is retrieved and display 600 is installed on client computer 240 using web browser 950 (step 1024 ).
  • event registry 962 begins a registration/load process of the event applets, e.g., flipper applet 967 , ticker applet 968 and VCR applet 969 (step 1026 ).
  • Event registry 962 is capable of dynamically registering event applets, i.e., registry 962 is capable of registering additional event applets after the initial registration process, thereby making it possible to add new event windows to LiveScreen display 600 of client computer 240 without having to re-install client module 960 .
  • Each event applet has a tag which includes attributes such as Java class, command stream format RTP://server name and file name (location of stream).
  • each applet provides event registry 962 with a list of its respective function(s).
  • encoded video/audio frames and associated annotation frames are streamed from stream server 220 to client computer 240 for synchronous display (step 1030 ).
  • Streaming video and audio streams over a network is very efficient because streaming eliminates the need for a large buffer at client computer 240 .
  • streaming also provides flexibility, e.g., switching video sources midstream is possible without wasting network resources since streaming is based on a pseudo just-in-time (JIT) protocol and does not involve downloads of the entire video stream prior to display at client computer 240 .
  • JIT pseudo just-in-time
  • video, audio and annotation packets are initially “pulled” by client computer 240 from server 220 using HTTP “get” packet(s).
  • the encoded video/audio streams are decoded by decoder 964 , i.e., decompressed using a suitable technique, and then displayed at client computer 240 by renderer 965 (step 1040 ).
  • annotation frames streamed from stream server 220 are encoded in Visual Basic script.
  • annotation streams 800 a , 800 b include stream headers 810 a , 810 b , respectively, followed by one or more annotation frames.
  • Annotation interpreter 963 parses annotation frames in real-time in the form of messages from stream server 220 , and converts the messages into a C++ function calls for the respective event applets (step 1050 ).
  • each annotation frame includes a HTML address and an event time marker.
  • ticker stream 800 b each annotation frame includes ticker data and an event time marker. Note that an event time marker need not be identical to a corresponding video time stamp.
  • Client computer 240 is capable of switching to a new displayable event together with a video frame or in between two video frames.
  • annotation frames may differ, from the perspective of stream streamer 220 , the event data or event locator are simply arguments to be passed on to client computer 240 to be processed by client computer 240 .
  • all annotation frames are processed in the same manner by stream server 220 , i.e., annotation frames are streamed to client computer 240 at the appropriate time in accordance with their respective event time markers.
  • event registry 962 is capable of dynamic registration of event applets.
  • annotation interpreter 963 is adaptable, and capable of automatic installation and linking of new event applet(s) to add new class(es) of displayable events for client computer 240 .
  • flipper applet 967 After registering with event registry 962 , flipper applet 967 provides the location of the flipper stream to broswer 950 which then begin receiving the flipper stream from stream server 220 .
  • Flipper annotation frames are provided by stream server 220 synchronously with the video/audio frames to client module 960 so that the annotations, i.e., displayable events can be synchronized for display at client computer 240 (step 1060 ).
  • URL addresses for synchronizing HTML page flips with video stream are provided to web broswer 950 thereby permitting client computer 240 to subsequently retrieve and display various textual and graphical elements changing at predetermined points corresponding to the timeline of the video stream.
  • HTML pages can be retrieved from one or more web server(s) 230 .
  • ticker (tape) applet 968 provides the location of the ticker stream to broswer 950 which then begins receiving the ticker stream from stream server 220 .
  • Ticker annotation frames are provided by stream server 220 synchronously with the video/audio frames so that the annotations, i.e., displayable ticker data can be synchronized for display at client computer 240 at predetermined points corresponding to the timeline of the video stream.
  • Another window may be used to display documents delivered via a data annotation stream and a “PowerPoint” viewer.
  • Another exemplary variation includes providing an annotation stream to an “ActiveX” object for viewing displayable event(s) associated with a HTML page.
  • VCR control applet 969 After registration, VCR control applet 969 provides VCR-like control buttons 620 such as play, rewind, fast forward, pause, and live-play. Note that since VCR buttons are under the interactive control of viewer 249 , activation points in the time line cannot be predicted in advance, and so no annotation stream is used. Instead, when a VCR-type function such as rewind (“REW”) is activated, VCR applet 969 sends an appropriate message is sent to stream server 220 , which resets both the video/audio streams and annotation stream(s) to the viewer selected point in time.
  • VCR-like control buttons 620 such as play, rewind, fast forward, pause, and live-play. Note that since VCR buttons are under the interactive control of viewer 249 , activation points in the time line cannot be predicted in advance, and so no annotation stream is used. Instead, when a VCR-type function such as rewind (“REW”) is activated, VCR applet 969 sends an appropriate message is sent to stream
  • a table of content 630 with content labels enables viewer 249 to skip forward or backward to predetermined locations in the video/audio stream.
  • viewer 249 selects a content label of interest (step 1110 ).
  • suitable content labels are section headings of the video stream.
  • client module 960 sends a message to stream server 220 with the time stamp of an I-frame from the video stream whose location is close to selected content label (step 1120 ).
  • an I-frame is a video frame which includes data for a complete video frame.
  • step 1130 stream server 220 resets the video/audio stream and the annotation stream(s) to correspond to the selected I-frame.
  • Stream server 220 is now ready to resume transmission of the video/audio stream and the annotation stream(s) to client computer 240 for viewing (step 1140 ).
  • an interleaved video/audio/annotation file is produced by producer 215 b , stored in web server 230 , and subsequently provided to client module 960 on demand via web browser 950 .
  • an interleaved file can include any two or more frame types, e.g., video and audio frames, video and annotation frames, or audio and annotation frames.
  • Advantages of this embodiment include simplified synchronous delivery of video, audio and annotation frames to client computer 240 . Simplicity is accomplished by eliminating the need for stream server 220 , whose primary function is to manage the transmission of several separate video, audio and annotation streams from stream server 220 to client computer 240 . In this embodiment, since all the video, audio and annotation frames are combined into a single interleaved stream and are pre-sorted by timestamp values, the interleaved stream can now be stored in web server 230 and delivered in the form of HTTP data.
  • FIGS. 12A and 12B are two portions of a flowchart illustrating the combination of video frames from a video file and audio frames from an audio file into an interleaved file by producer 215 b .
  • the audioframe and videoframe buffers are initialized to “null” (step 1210 ). Note that null can be represented by any one of a variety of ways known to one skilled in the art.
  • step 1222 if the audioframe buffer is empty, i.e., set to null, then producer 215 b retrieves the next audio frame from the audio file (step 1224 ). If the retrieval is successful (step 1226 ), then the audiotimestamp is set to the timestamp of the retrieved audio frame (step 1228 ).
  • step 1232 if the videoframe buffer is empty, i.e., set to null, then producer 215 b retrieves the next video frame from the video file (step 1234 ). If the retrieval is successful (step 1236 ), then the videotimestamp is set to the timestamp of the retrieved video frame (step 1238 ).
  • step 1252 producer 215 b writes the audio frame in the audioframe buffer to the interleaved file, sets the audioframe buffer to null, and returns ( 1270 ) to step 1222 (step 1254 ).
  • step 1262 producer 215 b writes the video frame in the videoframe buffer to the interleaved file, sets the videoframe buffer to null, and returns ( 1270 ) to step 1222 (step 1264 ).
  • both audioframe and videoframe buffers will be empty again and results of steps 1252 and 1262 will both be negative, indicating that all the frames in both video and audio files are been processed, and the interleaved video and audio file is now complete.
  • the above described algorithm for generating an interleaved file from two input files can be adapted to generating an interleaved file from three or more input files, e.g., by adding the appropriate number of buffers, one for each additional input file.
  • the data packets 1320 , 1330 , . . . 1390 for streaming video and audio frames include a variable packet length field 1324 as shown in FIGS. 13A and 13B.
  • a variable packet length field 1324 as shown in FIGS. 13A and 13B.
  • FIGS. 14A, 14B, and 14 C three exemplary formats 1324 a , 1324 b , and 1324 c of the variable packet length field 1324 are shown.
  • the length of the variable packet length field is in multiples of number units.
  • formats 1324 a , 1324 b and 1324 c can be one numerical unit in length, three numerical units in length and seven numerical units in length, respectively.
  • the packet length can be represented by a number of different methods, such as simple binary, one's complement, BCD and floating point.
  • FIG. 15 is a flowchart illustrating the selection of a suitable format for writing a packet into the interleaved file. If the size of packet length 1324 is less than one numerical unit (step 1510 ), then the first format 1324 a (FIG. 14A) with one numerical unit length is sufficient to store packet length 1324 (step 1520 ).
  • step 1540 a null number, one numerical unit in size, is written (step 1540 ).
  • null can be represented in any one of a number of ways known to one skilled in the art.
  • producer 215 b writes packet length 1324 up to two numerical units in size as shown in FIG. 14B (step 1545 ).
  • step 1530 Else if the size of packet length 1324 is greater than two numerical units (step 1530 ), then three null numbers, each one numerical unit in size, are written (step 1550 ). Next, producer 215 b writes packet length 1324 up to four numerical units in size as shown in FIG. 14C (step 1555 ).
  • FIG. 16 is a flowchart illustrating the interpretation of the variable packet length field formats 1324 a , 1324 b , and 1324 c of FIGS. 14A, 14B and 14 C, respectively. If the first number (one numeral unit in size) is not null (step 1610 ), then the first number is the value of variable packet length 1324 (step 1620 ).
  • step 1610 Else if the first number is null, but the second number and the third number are not both null (steps 1610 and 1630 ), then the second number and the third number represent the value of variable packet length 1324 (step 1640 ).
  • step 1610 Else if the first, second and third numbers are all null (steps 1610 and 1630 ), then the fourth, fifth, sixth and seventh numbers represent the value of variable packet length 1324 (step 1640 ).
  • capture module 317 b may generate separate compressed video files and audio files and leave the entire interleaving step to author module 318 b which receives the separate video and audio frames, generates the annotation frames, and then combines the video, audio and annotation frames into an interleaved file.
  • client module 960 may pass on the interleaved stream to client module 960 which then separates the interleaved stream into its component frames.

Abstract

The production of an interleaved multimedia stream for servers and client computers coupled to each other by a diverse computer network which includes local area networks (LANs) and/or wide area networks (WANs) such as the internet. Interleaved multimedia streams can include compressed video frames for display in a video window, accompanying compressed audio frames and annotation frames. In one embodiment, a producer captures separate video/audio frames and generates an interleaved multimedia file. In another embodiment, the interleaved file include annotation frames which provide either pointer(s) to the event(s) of interest or include displayable data embedded within the annotation stream. The interleaved file is then stored in the web server for subsequent retrieval by client computer(s) in a coordinated manner, so that the client computer(s) is able to synchronously display the video frames and displayable event(s) in a video window and event window(s), respectively. In some embodiments, the interleaved file includes packets with variable length fields, each of which are at least one numerical unit in length.

Description

    RELATED APPLICATIONS
  • Pending U.S. patent application Ser. No. ______, entitled “Production of a Video Stream with Synchronized Annotations over a Computer Network”, Attorney Docket Number VXT[0001] 703, assigned to VXtreme, Inc. and filed Mar. 14, 1997, is herein incorporated by reference in its entirety.
  • BACKGROUND OF THE INVENTION
  • 1. Field of the Invention [0002]
  • The present invention relates to multimedia communications. More particularly, the present invention relates to the delivery of an interleaved multimedia stream over a diverse computer network. [0003]
  • 2. Description of the Related Art [0004]
  • With the proliferation of connections to the internet by a rapidly growing number of users, the viability of the internet as a widely accepted medium of communication has increased correspondingly. Bandwidth requirements can vary significantly depending on the type of multimedia data being delivered. For example, a low resolution, low frame rate video telephone call may require only an ISDN connection, while a high resolution video broadcast of a live event to a large group of viewers may require the bandwidth of a T[0005] 1 connection. Hence, the ability to deliver of multimedia data over the internet is limited by bandwidth capacity and cost of the network connection and also by the computational capability of the server and client computers.
  • Pending patent application VXT[0006] 703 describes the production of separate video, audio and annotation streams for synchronous delivery from a stream server to a client computer. However, if the stream server is not available or not affordable to the end user at the client computer, then the client computer may only have access to web servers which are not designed to provide synchronous delivery capability of the separate video, audio and annotation streams.
  • In view of the foregoing, there are desired techniques for generating integrated multimedia content such as video and audio frames, for synchronous delivery from a web server client computer(s). [0007]
  • SUMMARY OF THE INVENTION
  • The present invention provides interleaved multimedia streams for servers and client computers coupled to each other by a diverse computer network which includes local area networks (LANs) and/or wide area networks (WANs) such as the internet. Interleaved multimedia streams can include compressed video frames for display in a video window, accompanying compressed audio frames and annotation frames. [0008]
  • In one embodiment, a producer captures separate video/audio frames and generates an interleaved multimedia file. In another embodiment, the interleaved file include annotation frames which provide either pointer(s) to the event(s) of interest or include displayable data embedded within the annotation stream. Accordingly, each annotation frame includes either an event locator or an event data. In addition, each annotation frame includes an event time marker which corresponds to the time stamp(s) of associated video frame(s) within the video stream. [0009]
  • The interleaved file is then stored in the web server for subsequent retrieval by client computer(s) in a coordinated manner, so that the client computer(s) is able to synchronously display the video frames and displayable event(s) in a video window and event window(s), respectively. In some embodiments, the interleaved file includes packets with variable length fields, each of which are at least one numerical unit in length. [0010]
  • These and other advantages of the present invention will become apparent upon reading the following detailed descriptions and studying the various figures of the drawings. [0011]
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 is a block diagram of an exemplary computer system for practicing the various aspects of the present invention. [0012]
  • FIG. 2 is a block diagram showing an exemplary hardware environment for practicing the annotated video-on-demand (VOD) system of the present invention. [0013]
  • FIG. 3A shows one embodiment of a producer which includes a capture module and an author module. [0014]
  • FIG. 3B shows another embodiment of the producer in which the capture module generates an interleaved stream. [0015]
  • FIG. 4A is a flowchart illustrating the capture of a live video/audio stream from a video camera or from a previously stored video file. [0016]
  • FIGS. 4B and 4C are flowcharts illustrating a locator annotation stream and a data annotation stream, respectively. [0017]
  • FIG. 5 shows an exemplary format for storing and delivering a compressed video stream. [0018]
  • FIG. 6 shows an exemplary customized LiveScreen display which includes a video window, a set of VCR-like control buttons, a selectable table of contents (TOC) and an HTML page window. [0019]
  • FIG. 7 illustrates an author tool provided by an author module for the designer to visually creating annotation streams. [0020]
  • FIGS. 8A and 8B are exemplary formats illustrating a locator annotation stream and a data annotation stream, respectively. [0021]
  • FIG. 9A illustrates one embodiment of the client computer which includes a web browser and a browser plug-in module for interfacing a web browser with a client module. [0022]
  • FIG. 9B illustrates another embodiment of the client computer in which the browser plug-in module receives an interleaved stream from the web server and distributes the video/audio stream(s) to the video/audio decoder(s) and the annotation stream(s) to the annotation interpreter. [0023]
  • FIGS. 10A and 10B are flowcharts illustrating the operation of the client module. [0024]
  • FIG. 11 is a flowchart illustrating the use of a table of content with content labels enabling a viewer to skip forward or backward to predetermined locations in the video/audio stream. [0025]
  • FIGS. 12A and 12B are two portions of a flowchart illustrating the combination of video frames from a video file and audio frames from an audio file into an interleaved file. [0026]
  • FIGS. 13A and 13B illustrate an exemplary format of the interleaved file which includes a plurality of data packets for storing video and audio frames with a variable packet length field. [0027]
  • FIGS. 14A, 14B, and [0028] 14C show three exemplary formats for the variable packet length field of FIG. 13B.
  • FIG. 15 is a flowchart illustrating the selection of a suitable format for writing a packet into the interleaved file. [0029]
  • FIG. 16 is a flowchart illustrating the interpretation of the exemplary variable packet length field formats of FIGS. 14A, 14B and [0030] 14C, respectively.
  • DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS
  • The present invention will now be described in detail with reference to a few preferred embodiments thereof as illustrated in the accompanying drawings. In the following description, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be apparent, however, to one skilled in the art, that the present invention may be practiced without some or all of these specific details. In other instances, well known process steps have not been described in detail in order to not unnecessarily obscure the present invention. [0031]
  • FIG. 1 is a block diagram of an [0032] exemplary computer system 100 for practicing the various aspects of the present invention. Computer system 100 includes a display screen (or monitor) 104, a printer 106, a floppy disk drive 108, a hard disk drive 110, a network interface 112, and a keyboard 114. Computer system 100 includes a microprocessor 116, a memory bus 118, random access memory (RAM) 120, read only memory (ROM) 122, a peripheral bus 124, and a keyboard controller 126. Computer system 100 can be a personal computer (such as an Apple computer, e.g., an Apple Macintosh, an IBM personal computer, or one of the compatibles thereof), a workstation computer (such as a Sun Microsystems or Hewlett-Packard workstation), or some other type of computer.
  • [0033] Microprocessor 116 is a general purpose digital processor which controls the operation of computer system 100. Microprocessor 116 can be a single-chip processor or can be implemented with multiple components. Using instructions retrieved from memory, microprocessor 116 controls the reception and manipulation of input data and the output and display of data on output devices.
  • [0034] Memory bus 118 is used by microprocessor 116 to access RAM 120 and ROM 122. RAM 120 is used by microprocessor 116 as a general storage area and as scratch-pad memory, and can also be used to store input data and processed data. ROM 122 can be used to store instructions or program code followed by microprocessor 116 as well as other data.
  • [0035] Peripheral bus 124 is used to access the input, output, and storage devices used by computer system 100. In the described embodiment(s), these devices include display screen 104, printer device 106, floppy disk drive 108, hard disk drive 110, and network interface 112. Keyboard controller 126 is used to receive input from keyboard 114 and send decoded symbols for each pressed key to microprocessor 116 over bus 128.
  • Display screen [0036] 104 is an output device that displays images of data provided by microprocessor 116 via peripheral bus 124 or provided by other components in computer system 100. Printer device 106 when operating as a printer provides an image on a sheet of paper or a similar surface. Other output devices such as a plotter, typesetter, etc. can be used in place of, or in addition to, printer device 106.
  • [0037] Floppy disk drive 108 and hard disk drive 110 can be used to store various types of data. Floppy disk drive 108 facilitates transporting such data to other computer systems, and hard disk drive 110 permits fast access to large amounts of stored data.
  • [0038] Microprocessor 116 together with an operating system operate to execute computer code and produce and use data. The computer code and data may reside on RAM 120, ROM 122, or hard disk drive 120. The computer code and data could also reside on a removable program medium and loaded or installed onto computer system 100 when needed. Removable program mediums include, for example, CD-ROM, PC-CARD, floppy disk and magnetic tape.
  • [0039] Network interface circuit 112 is used to send and receive data over a network connected to other computer systems. An interface card or similar device and appropriate software implemented by microprocessor 116 can be used to connect computer system 100 to an existing network and transfer data according to standard protocols.
  • [0040] Keyboard 114 is used by a user to input commands and other instructions to computer system 100. Other types of user input devices can also be used in conjunction with the present invention. For example, pointing devices such as a computer mouse, a track ball, a stylus, or a tablet can be used to manipulate a pointer on a screen of a general-purpose computer.
  • The present invention can also be embodied as computer readable code on a computer readable medium. The computer readable medium is any data storage device that can store data which can be thereafter be read by a computer system. Examples of the computer readable medium include read-only memory, random-access memory, magnetic data storage devices such as diskettes, and optical data storage devices such as CD-ROMs. The computer readable medium can also be distributed over a network coupled computer systems so that the computer readable code is stored and executed in a distributed fashion. [0041]
  • FIG. 2 is a block diagram showing an exemplary hardware environment for practicing the annotated video-on-demand (VOD) system of the present invention. The VOD system includes a [0042] production station 210, a stream server 220, at least one web server 230 and at least one client computer 240, each of which can be implemented using computer system 100 described above. Stream server 220 and web server 230 are coupled to client computer 240 via a computer network 290, e.g., the internet. Note that the disclosed hardware environment is exemplary. For example, production station 210 and stream server 220 can be implemented using two separate computer systems or using one computer system. In addition, if production station 210 and stream server 220 are implemented on separate computer systems as shown in FIG. 2, an optional direct connection (not shown) between production station 210 and stream server 220 can provide faster uploads of compressed video and annotation streams. In the following description, an audio stream optionally accompanies each video stream.
  • A [0043] producer 215, installed in production station 210, is a user-friendly tool for use by a designer 219 to create a synchronization script which includes annotation stream(s). The annotation stream(s) define the content(s) of a LiveScreen display 245 to be displayed on client computer 240 for a viewer 249. LiveScreen 245 display provides a graphical user interface (GUI) with multiple windows for synchronously displaying a video stream from stream server 220 and at least one displayable event stream. Examples of displayable events include textual/graphical information such as HTML-scripted web page(s) from web server 230.
  • In one embodiment, as shown in FIG. 3A, producer [0044] 215 a includes a capture module 317 a and an author module 318 a. Production station 210 includes 16 MB of RAM and a 1 GB hard disk drive for capturing and storing an uncompressed or precompressed video stream. Sources for generating video streams include a video camera 312, a video cassette recorder (VCR) (not shown) or a previously digitized video file 314, e.g., a Video for Windows (.avi) file. For ease of installation and use by designer 219, producer 215 a is implemented in a host environment which includes a window-based operating system such as Microsoft Windows 95 and a web browser such as Netscape's Navigator 3.x.
  • Referring also to the flowchart of FIG. 4A, in [0045] step 410 capture module 317 a captures a live video/audio stream from video camera 312 or from the previously stored video file 314. If video camera 312 provides an analog video stream, e.g., an NTSC signal, a hardware capture card (not shown) provides the required conversion from the analog video stream to a digitized video stream. Because temporary storage of uncompressed video data is memory intensive, some form of pre-compression can be used to reduce the memory storage requirement of the input video stream during capture step 410 and prior to compression step 420.
  • In [0046] step 420, capture module 420 compresses the digitized video stream using a suitable compression technique. In this embodiment, depending on the bandwidth capacity of the connection provided by network 290 between stream server 220 and client computer 240, e.g., a POTS modem, ISDN or Ethernet, a suitable frame resolution and frame rate combination is selected. FIG. 5 shows an exemplary format 500 for storing and delivering a compressed video stream.
  • A similar format can also be used to store and deliver a separate compressed audio stream. It is also possible to combine, e.g., interleave a compressed video and audio data into one stream for delivery. Audio encoders/decoders (codecs) are available from a number of commercial sources. Examples include ToolVox from Voxware Inc., 305 College Road East, Princeton, N.J. 08540, and QCELP from QUALCOMM Inc., 10555 Sorrento Valley Road, San Diego, Calif. 92121. [0047]
  • Referring back to FIGS. 3A and 4A, in [0048] step 430, designer 219 uses author module 318 a to compose a suitable LiveScreen display format which defines the layout of LiveScreen display 245 at client computer 240. FIG. 6 shows an exemplary customized LiveScreen display 600 which includes a video window 610, a set of VCR-like control buttons 620, a selectable table of contents (TOC) 630 and an HTML page window 640. Examples of other displayable event windows include but is not limited to ticker tape windows (not shown). In this implementation, LiveScreen templates 319 are available for designer 219 to use as starting points for composing customized LiveScreen formats.
  • FIG. 7 illustrates an [0049] author tool 700 provided by author module 318 a for designer 219 to visually creating annotation streams (step 440). There are two types of annotation streams. The first type of annotation streams are data annotation streams in which the displayable event data are embedded within the annotation streams. Examples of data annotation streams include ticker annotation streams which include ticker tape data embedded within the annotation stream. The second type of annotation streams are locator annotation streams in which the displayable data is either too cumbersome and/or is continually evolving to be embedded as static data within the annotation stream. Instead, event locator(s) pointing to the location of the displayable data are stored in the annotation streams instead of the displayable data. Examples include URL addresses pointing to HTML pages.
  • [0050] Designer 219 may view frames from video stream 500 displayed in video window 720 for referencing and selecting appropriate time stamps to use in generating annotation streams. Within video window 720, VCR function buttons, e.g., a rewind button 724, a play button 726 and a fast forward button 728, are available for designer 219 to quickly traverse video stream 500. Since video window 720 is provided as a convenience for designer 219, if designer 219 has prior knowledge of the content of the video stream, designer 219 may proceed with the generation of the annotation streams without viewing video window 720.
  • As shown in FIG. 7, [0051] author tool 700 displays a flipper time track 750, a video time track 760, an audio time track 770, a ticker time track 780 and a table of contents (TOC) time track 790. Flipper time track 750 and ticker time track 780 aid designer 217 in generating a flipper annotation stream and a ticker annotation stream, respectively. Another visual control aid, zoom bar 716, enables designer 219 to select the respective portions of the complete time tracks 750, 760, 770, 780 and 790, as defined by start time indicator 712 and end time indicator 718, which is currently displayed by author tool 700.
  • In accordance with one aspect of the invention, annotation frames are generated by designer [0052] 217 to form customized annotation streams (step 440). A time hairline 715 spanning time tracks 750, 760, 770, 780 and 790 provides designer 217 with a visual aid to select an appropriate time, displayed in time indicator 714, for synchronizing a displayable event. The exemplary format of time indicators 712, 714 and 718 are “hours:minutes:seconds”.
  • FIGS. 4B and 8A are a flowchart and an exemplary format, respectively, illustrating a locator annotation stream [0053] 800 a. Locator annotation stream 800 a includes an annotation stream header 810 a, and a plurality of annotation frames 820 a, 830 a, 840 a, . . . 890 a. Each annotation frame includes an event locator and an event time marker, e.g., annotation frame 820 a includes event locator 822 a and event time marker 824 a. One example of a locator annotation stream is a flipper stream. Flipper time track 750 provides a convenient way to select suitable event time marker values, e.g., flipper time markers 751, 752, 753, 754, for the respective event locators. For example, URL addresses (event locators) pointing to HTML pages enable client computer 240 to subsequently retrieve textual and/or graphical elements to be displayed at predetermined time as defined by the time markers of the flipper stream.
  • FIGS. 4C and 8B are a flowchart and an exemplary format, respectively, illustrating a data annotation stream [0054] 800 b. Locator annotation stream 800 a includes an annotation stream header 810 a, and a plurality of annotation frames 820 a, 830 a, 840 a, . . . 890 a. Each annotation frame includes an event locator and an event time marker, e.g., annotation frame 820 a includes event locator 822 a and event time marker 824 a. One example of a data annotation stream is a ticker stream. The generation of the ticker stream is somewhat similar to that of the flipper stream. However, in the case of the ticker stream, instead of event locators, displayable data is embedded directly into the ticker stream as event data.
  • When author module [0055] 318 a has completed building an annotation stream, e.g., the flipper stream, the annotation stream is given a file name and loaded into a convenient server, e.g., stream server 220, for subsequent retrieval by client computer 240. The use of the annotation streams is described in greater detail below with the description of client computer 240.
  • In accordance with another aspect of the invention, [0056] LiveScreen display 600 also includes a table of contents (TOC) 630, enabling viewer 249 at client computer 240 to skip forward or backward to a point within the entire video/audio stream 500. TOC 630 include one or more content labels, each indexed to a corresponding time stamp in video stream 500, as defined by TOC time markers 791, 792, 793, 794 in LiveScreen display 600.
  • Referring now to FIG. 9A, in one embodiment of the present invention, [0057] client computer 240 includes a web browser 950 and a browser plug-in module 952 a for interfacing web browser 950 with a main client module 960. Client module 960 includes an event registry 962, playout buffer(s) 966, video/audio decoder(s) 964, video/audio renderer(s) 965 and one or more dynamically loadable event applet(s), e.g., flipper applet 967, ticker applet 968 and VCR applet 969. In this embodiment, event registry 962 also functions as an annotation interpreter 963.
  • FIG. 10A is a flowchart illustrating the operation of client module [0058] 960. Assume that viewer 249 has not previously loaded client module 960 in client computer 240, but has already loaded a web browser 950, e.g., Netscape's Navigator (step 1010). Viewer 249 surfs the world-wide web (www) via the internet and locates a web site of interest to viewer 249. Typically, the web site of interest is hosted on web server 230. Accordingly, a target web page is downloaded from web server 230 and displayed on client computer 240.
  • The target web page includes a link to a customized LiveScreen display, e.g., [0059] display 600. If client module 960 has not been previously loaded, client module 960 is now loaded over web browser 950 for processing video/audio and annotation streams (step 1020). Depending on the implementation, a copy of client module 960 may be available from the web site of interest. Alternatively, the target web page may provide a HTML link to another web server which has an updated copy of client module 960.
  • Referring now to FIG. 10B, first, browser plug-in [0060] module 952 a is installed over web browser 950 (step 1022). As discussed above, plug-in module 952 a provides the interface between client module 960 and web browser 950. The target web page provides a HTML link to the format for LiveScreen display 600. The LiveScreen display format is retrieved and display 600 is installed on client computer 240 using web browser 950 (step 1024).
  • Next, [0061] event registry 962 begins a registration/load process of the event applets, e.g., flipper applet 967, ticker applet 968 and VCR applet 969 (step 1026). Event registry 962 is capable of dynamically registering event applets, i.e., registry 962 is capable of registering additional event applets after the initial registration process, thereby making it possible to add new event windows to LiveScreen display 600 of client computer 240 without having to re-install client module 960. Each event applet has a tag which includes attributes such as Java class, command stream format RTP://server name and file name (location of stream). During the registration process, each applet provides event registry 962 with a list of its respective function(s).
  • Referring back to FIG. 10A, encoded video/audio frames and associated annotation frames are streamed from [0062] stream server 220 to client computer 240 for synchronous display (step 1030). Streaming video and audio streams over a network is very efficient because streaming eliminates the need for a large buffer at client computer 240. In addition, streaming also provides flexibility, e.g., switching video sources midstream is possible without wasting network resources since streaming is based on a pseudo just-in-time (JIT) protocol and does not involve downloads of the entire video stream prior to display at client computer 240. If the underlying transmission protocol is HTTP, then video, audio and annotation packets are initially “pulled” by client computer 240 from server 220 using HTTP “get” packet(s).
  • Next, the encoded video/audio streams are decoded by [0063] decoder 964, i.e., decompressed using a suitable technique, and then displayed at client computer 240 by renderer 965 (step 1040).
  • In this implementation, annotation frames streamed from [0064] stream server 220 are encoded in Visual Basic script. As shown in FIGS. 8A and 8B, annotation streams 800 a, 800 b include stream headers 810 a, 810 b, respectively, followed by one or more annotation frames. Annotation interpreter 963 parses annotation frames in real-time in the form of messages from stream server 220, and converts the messages into a C++ function calls for the respective event applets (step 1050). In the case of flipper stream 800 a, each annotation frame includes a HTML address and an event time marker. In the case of ticker stream 800 b, each annotation frame includes ticker data and an event time marker. Note that an event time marker need not be identical to a corresponding video time stamp. Client computer 240 is capable of switching to a new displayable event together with a video frame or in between two video frames.
  • While the contents of annotation frames may differ, from the perspective of [0065] stream streamer 220, the event data or event locator are simply arguments to be passed on to client computer 240 to be processed by client computer 240. Hence, all annotation frames are processed in the same manner by stream server 220, i.e., annotation frames are streamed to client computer 240 at the appropriate time in accordance with their respective event time markers.
  • Further, since the video and annotation streams are handled synchronously but separately by [0066] video decoder 964 and annotation interpreter 963, respectively, steps 1040 and 1050 can occur concurrently or consecutively. As discussed above, event registry 962 is capable of dynamic registration of event applets. Accordingly, annotation interpreter 963 is adaptable, and capable of automatic installation and linking of new event applet(s) to add new class(es) of displayable events for client computer 240.
  • After registering with [0067] event registry 962, flipper applet 967 provides the location of the flipper stream to broswer 950 which then begin receiving the flipper stream from stream server 220. Flipper annotation frames are provided by stream server 220 synchronously with the video/audio frames to client module 960 so that the annotations, i.e., displayable events can be synchronized for display at client computer 240 (step 1060). In this example, URL addresses, for synchronizing HTML page flips with video stream are provided to web broswer 950 thereby permitting client computer 240 to subsequently retrieve and display various textual and graphical elements changing at predetermined points corresponding to the timeline of the video stream. Note that HTML pages can be retrieved from one or more web server(s) 230.
  • Similarly, after registering with [0068] event registry 962, ticker (tape) applet 968 provides the location of the ticker stream to broswer 950 which then begins receiving the ticker stream from stream server 220. Ticker annotation frames are provided by stream server 220 synchronously with the video/audio frames so that the annotations, i.e., displayable ticker data can be synchronized for display at client computer 240 at predetermined points corresponding to the timeline of the video stream.
  • Many types and combinations of display windows and/or content are possible. For example, another window may be used to display documents delivered via a data annotation stream and a “PowerPoint” viewer. Another exemplary variation includes providing an annotation stream to an “ActiveX” object for viewing displayable event(s) associated with a HTML page. [0069]
  • After registration, [0070] VCR control applet 969 provides VCR-like control buttons 620 such as play, rewind, fast forward, pause, and live-play. Note that since VCR buttons are under the interactive control of viewer 249, activation points in the time line cannot be predicted in advance, and so no annotation stream is used. Instead, when a VCR-type function such as rewind (“REW”) is activated, VCR applet 969 sends an appropriate message is sent to stream server 220, which resets both the video/audio streams and annotation stream(s) to the viewer selected point in time.
  • As shown in FIG. 11, a table of [0071] content 630 with content labels enables viewer 249 to skip forward or backward to predetermined locations in the video/audio stream. First, viewer 249 selects a content label of interest (step 1110). Examples of suitable content labels are section headings of the video stream. Next, client module 960 sends a message to stream server 220 with the time stamp of an I-frame from the video stream whose location is close to selected content label (step 1120). In this embodiment, an I-frame is a video frame which includes data for a complete video frame. Although computationally more intensive, it is also possible to select a P-frame and then reconstructed a complete video starting from a neighboring I-frame close to the selected P-frame.
  • In [0072] step 1130, stream server 220 resets the video/audio stream and the annotation stream(s) to correspond to the selected I-frame. Stream server 220 is now ready to resume transmission of the video/audio stream and the annotation stream(s) to client computer 240 for viewing (step 1140).
  • Referring now to FIGS. 3B and 9B, in another embodiment, instead of streaming three separate video, audio and annotation streams from [0073] stream server 220 to client computer 240, an interleaved video/audio/annotation file is produced by producer 215 b, stored in web server 230, and subsequently provided to client module 960 on demand via web browser 950. Note that an interleaved file can include any two or more frame types, e.g., video and audio frames, video and annotation frames, or audio and annotation frames.
  • Advantages of this embodiment include simplified synchronous delivery of video, audio and annotation frames to [0074] client computer 240. Simplicity is accomplished by eliminating the need for stream server 220, whose primary function is to manage the transmission of several separate video, audio and annotation streams from stream server 220 to client computer 240. In this embodiment, since all the video, audio and annotation frames are combined into a single interleaved stream and are pre-sorted by timestamp values, the interleaved stream can now be stored in web server 230 and delivered in the form of HTTP data.
  • FIGS. 12A and 12B are two portions of a flowchart illustrating the combination of video frames from a video file and audio frames from an audio file into an interleaved file by producer [0075] 215 b. First, the audioframe and videoframe buffers are initialized to “null” (step 1210). Note that null can be represented by any one of a variety of ways known to one skilled in the art.
  • In [0076] step 1222, if the audioframe buffer is empty, i.e., set to null, then producer 215 b retrieves the next audio frame from the audio file (step 1224). If the retrieval is successful (step 1226), then the audiotimestamp is set to the timestamp of the retrieved audio frame (step 1228).
  • In [0077] step 1232, if the videoframe buffer is empty, i.e., set to null, then producer 215 b retrieves the next video frame from the video file (step 1234). If the retrieval is successful (step 1236), then the videotimestamp is set to the timestamp of the retrieved video frame (step 1238).
  • If both the audioframe and videoframe buffers are full and the audiotimestamp is less than or equal to the videotimestamp, OR if the audiotimestamp is full and the videotimestamp is empty (step [0078] 1252), then producer 215 b writes the audio frame in the audioframe buffer to the interleaved file, sets the audioframe buffer to null, and returns (1270) to step 1222 (step 1254).
  • If both the audioframe and videoframe buffers are full and the videotimestamp is less than or equal to the audiotimestamp, OR if the videotimestamp is full and the audiotimestamp is empty (step [0079] 1262), then producer 215 b writes the video frame in the videoframe buffer to the interleaved file, sets the videoframe buffer to null, and returns (1270) to step 1222 (step 1264).
  • Eventually, both audioframe and videoframe buffers will be empty again and results of [0080] steps 1252 and 1262 will both be negative, indicating that all the frames in both video and audio files are been processed, and the interleaved video and audio file is now complete. The above described algorithm for generating an interleaved file from two input files can be adapted to generating an interleaved file from three or more input files, e.g., by adding the appropriate number of buffers, one for each additional input file.
  • In accordance with another aspect of this embodiment, the [0081] data packets 1320, 1330, . . . 1390 for streaming video and audio frames include a variable packet length field 1324 as shown in FIGS. 13A and 13B. Referring to FIGS. 14A, 14B, and 14C, three exemplary formats 1324 a, 1324 b, and 1324 c of the variable packet length field 1324 are shown. In this implementation, the length of the variable packet length field is in multiples of number units. For example, formats 1324 a, 1324 b and 1324 c can be one numerical unit in length, three numerical units in length and seven numerical units in length, respectively. As is known to one skilled in the art, regardless of the size of the packet length field, the packet length can be represented by a number of different methods, such as simple binary, one's complement, BCD and floating point.
  • FIG. 15 is a flowchart illustrating the selection of a suitable format for writing a packet into the interleaved file. If the size of [0082] packet length 1324 is less than one numerical unit (step 1510), then the first format 1324 a (FIG. 14A) with one numerical unit length is sufficient to store packet length 1324 (step 1520).
  • Else if the size of [0083] packet length 1324 between one numerical unit (step 1510) and two numerical units (step 1530), then a null number, one numerical unit in size, is written (step 1540). As discussed above, null can be represented in any one of a number of ways known to one skilled in the art. Next, producer 215 b writes packet length 1324 up to two numerical units in size as shown in FIG. 14B (step 1545).
  • Else if the size of [0084] packet length 1324 is greater than two numerical units (step 1530), then three null numbers, each one numerical unit in size, are written (step 1550). Next, producer 215 b writes packet length 1324 up to four numerical units in size as shown in FIG. 14C (step 1555).
  • FIG. 16 is a flowchart illustrating the interpretation of the variable packet length field formats [0085] 1324 a, 1324 b, and 1324 c of FIGS. 14A, 14B and 14C, respectively. If the first number (one numeral unit in size) is not null (step 1610), then the first number is the value of variable packet length 1324 (step 1620).
  • Else if the first number is null, but the second number and the third number are not both null (steps [0086] 1610 and 1630), then the second number and the third number represent the value of variable packet length 1324 (step 1640).
  • Else if the first, second and third numbers are all null (steps [0087] 1610 and 1630), then the fourth, fifth, sixth and seventh numbers represent the value of variable packet length 1324 (step 1640).
  • Many variations of this embodiment are also possible. For example, capture module [0088] 317 b may generate separate compressed video files and audio files and leave the entire interleaving step to author module 318 b which receives the separate video and audio frames, generates the annotation frames, and then combines the video, audio and annotation frames into an interleaved file. Modifications are also possible in client module 960. For example, instead of tasking browser plug-in module 952 b with the separation of the interleaved stream into its component video and audio frames and annotation messages, browser plug-in module 952 b may pass on the interleaved stream to client module 960 which then separates the interleaved stream into its component frames.
  • While this invention has been described in terms of several preferred embodiments, there are alterations, permutations, and equivalents which fall within the scope of this invention. For example, although the present invention is described using video, audio and annotation frames, the methods and apparatuses of the present invention are equally applicable other multimedia frames. It is therefore intended that the following appended claims be interpreted as including all such alterations, permutations, and equivalents as fall within the true spirit and scope of the present invention. [0089]

Claims (11)

What is claimed is:
1. In a computer having a processor and memory, said computer useful in association with a web server coupled to a client computer via a network, a method for producing an interleaved multimedia file from a video file and an audio file, the method comprising the steps of:
if a video frame buffer is empty, then retrieving a first video frame from the video file, said first video frame including a video timestamp;
if an audio frame buffer is empty, then retrieving a first audio frame from the audio file, said first audio frame including an audio timestamp; and
if the video timestamp is less than or equal to the audio timestamp, then
writing the first video frame to a first packet of the interleaved file; and
retrieving a second video frame from the video file;
else if the audio timestamp is less than or equal to the video timestamp, then
writing the first audio frame to a second packet of the interleaved file; and
retrieving a second audio frame from the audio file.
2. The method of
claim 1
wherein said first and second packet has a variable packet length field.
3. The method of
claim 2
wherein the size of the variable packet length field is at least one numerical unit, and said step of writing the first video frame to the first packet includes the steps of:
if the size of the first video frame is less than one numerical unit, then
writing the size into a length field of the variable packet length field of the first packet;
if the size of the first video frame is between one numerical unit and two numerical units, then
writing a null number into a null field of the variable packet length field of the first packet; and
writing the size into the length field of the variable packet length field of the first packet; and
if the size of the first video frame is greater than two numerical units, then
writing three null numbers into the null field of the variable packet length field of the first packet; and
writing the size into the length field of the variable packet length field of the first packet.
4. The method of
claim 1
further comprising the step of writing an annotation frame from an annotation file into said interleaved file.
5. A producer useful for generating an interleaved file configured to provide a synchronized playback of a video file and an audio file on a client computer, the producer comprising a capture module configured to generate an interleaved file from video frames from the video file and audio frames from the audio file, based on timestamps of the video frames and the audio frames.
6. The producer of
claim 5
further comprising an author module configured to combined said interleaved file with a plurality of annotation frames, based on the timestamps of the video frames, the audio frames and the annotation frames.
7. The producer of
claim 5
wherein said video and audio frames are stored in packets with variable packet length fields.
8. A computer-readable medium useful in association with a computer system having a processor and memory, the computer-readable medium comprising computer-readable code instructions configured to cause said computer system to execute the steps of:
if a video frame buffer is empty, then retrieving a first video frame from a video file, said first video frame including a video timestamp;
if an audio frame buffer is empty, then retrieving a first audio frame from an audio file, said first audio frame including an audio timestamp; and
if the video timestamp is less than or equal to the audio timestamp, then
writing the first video frame to a first packet of an interleaved file; and
retrieving a second video frame from the video file;
else if the audio timestamp is less than or equal to the video timestamp, then
writing the first audio frame to a second packet of the interleaved file; and
retrieving a second audio frame from the audio file.
9. The computer-readable medium of
claim 8
wherein said first and second packet has a variable packet length field.
10. The computer-readable medium of
claim 9
wherein the size of the variable packet length field is at least one numerical unit, and said step of writing the first video frame to the first packet includes the steps of:
if the size of the first video frame is less than one numerical unit, then
writing the size into a length field of the variable packet length field of the first packet;
if the size of the first video frame is between one numerical unit and two numerical units, then
writing a null number into a null field of the variable packet length field of the first packet; and
writing the size into the length field of the variable packet length field of the first packet; and
if the size of the first video frame is greater than two numerical units, then
writing three null numbers into the null field of the variable packet length field of the first packet; and
writing the size into the length field of the variable packet length field of the first packet.
11. The computer readable medium of
claim 8
further comprising computer-readable code instructions configured to cause said computer system to execute the step of writing an annotation frame from an annotation file into said interleaved file.
US08/826,345 1997-03-25 1997-03-25 Interleaved multiple multimedia stream for synchronized transmission over a computer network Expired - Lifetime US6449653B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US08/826,345 US6449653B2 (en) 1997-03-25 1997-03-25 Interleaved multiple multimedia stream for synchronized transmission over a computer network

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US08/826,345 US6449653B2 (en) 1997-03-25 1997-03-25 Interleaved multiple multimedia stream for synchronized transmission over a computer network

Publications (2)

Publication Number Publication Date
US20010013068A1 true US20010013068A1 (en) 2001-08-09
US6449653B2 US6449653B2 (en) 2002-09-10

Family

ID=25246300

Family Applications (1)

Application Number Title Priority Date Filing Date
US08/826,345 Expired - Lifetime US6449653B2 (en) 1997-03-25 1997-03-25 Interleaved multiple multimedia stream for synchronized transmission over a computer network

Country Status (1)

Country Link
US (1) US6449653B2 (en)

Cited By (41)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020047899A1 (en) * 2000-01-28 2002-04-25 Diva Systems Corporation Method and apparatus for preprocessing and postprocessing content in an interactive information distribution system
US20020083043A1 (en) * 2000-11-30 2002-06-27 Tetsuo Hoshi System for acquiring and analyzing personal profile data and providing the service of delivering various information
US20020112031A1 (en) * 2001-02-09 2002-08-15 Franklin Richard L. Enhanced data exchange and presentation/communication system
DE10146255A1 (en) * 2001-09-20 2003-04-10 Deutsche Telekom Ag Method for generating multimedia content from several multimedia elements
US20030118087A1 (en) * 2001-12-21 2003-06-26 Microsoft Corporation Systems and methods for interfacing with digital history data
US6636888B1 (en) 1999-06-15 2003-10-21 Microsoft Corporation Scheduling presentation broadcasts in an integrated network environment
WO2004059536A2 (en) * 2002-12-20 2004-07-15 International Business Machines Coporation System and method for annotating multi-modal characteristics in multimedia documents
US6802019B1 (en) * 2000-06-15 2004-10-05 Genesys Conferencing, Ltd. Method and system for synchronizing data
US20050039135A1 (en) * 2003-08-11 2005-02-17 Konstantin Othmer Systems and methods for navigating content in an interactive ticker
US20050050218A1 (en) * 2003-09-02 2005-03-03 Microsoft Corporation Video delivery workflow
US20050122974A1 (en) * 2003-11-25 2005-06-09 Friedemann Hubler Method and apparatus for storage or relocation of defined positions in a data stream
US20050132415A1 (en) * 2003-12-11 2005-06-16 Hillis W. D. Spatial-to-temporal data translation and transmission
US20050154996A1 (en) * 2003-08-11 2005-07-14 Core Mobility, Inc. Systems and methods for populating a ticker using multiple data transmission modes
US20050210391A1 (en) * 2003-08-11 2005-09-22 Core Mobility, Inc. Systems and methods for navigating content in an interactive ticker
EP1598741A1 (en) * 2003-02-28 2005-11-23 Sony Corporation Information processing apparatus and content information processing method
US20060089160A1 (en) * 2003-08-11 2006-04-27 Core Mobility, Inc. Systems and methods for displaying location-based maps on communication devices
GB2419975A (en) * 2004-11-09 2006-05-10 Nokia Corp Auxiliary content handling
US20070022465A1 (en) * 2001-11-20 2007-01-25 Rothschild Trust Holdings, Llc System and method for marking digital media content
US20070106814A1 (en) * 2000-01-28 2007-05-10 Son Yong H Method and Apparatus for Content Distribution Via Non-Homogeneous Access Networks
US20070113264A1 (en) * 2001-11-20 2007-05-17 Rothschild Trust Holdings, Llc System and method for updating digital media content
US20070168463A1 (en) * 2001-11-20 2007-07-19 Rothschild Trust Holdings, Llc System and method for sharing digital media content
US20070250573A1 (en) * 2006-04-10 2007-10-25 Rothschild Trust Holdings, Llc Method and system for selectively supplying media content to a user and media storage device for use therein
US7330875B1 (en) * 1999-06-15 2008-02-12 Microsoft Corporation System and method for recording a presentation for on-demand viewing over a computer network
US20080062940A1 (en) * 2006-08-17 2008-03-13 Skypop.Inc. Presence-based communication between local wireless network access points and mobile devices
US20080115148A1 (en) * 2004-09-15 2008-05-15 Toni Paila File Delivery Session Handling
US20080155006A1 (en) * 2001-02-09 2008-06-26 Comlet Technologies Headquarters Enhanced data exchange and functionality control system and method
WO2008088883A1 (en) * 2007-01-19 2008-07-24 Hewlett-Packard Development Company, L.P. Web-based video browsing
US7430724B2 (en) * 2003-08-11 2008-09-30 Core Mobility, Inc. Systems and methods for displaying content in a ticker
US7441203B2 (en) 2003-08-11 2008-10-21 Core Mobility, Inc. Interactive user interface presentation attributes for location-based content
US20090172744A1 (en) * 2001-12-28 2009-07-02 Rothschild Trust Holdings, Llc Method of enhancing media content and a media enhancement system
US7669111B1 (en) * 1997-01-29 2010-02-23 Philip R Krause Electronic text reading environment enhancement method and apparatus
US20100211650A1 (en) * 2001-11-20 2010-08-19 Reagan Inventions, Llc Interactive, multi-user media delivery system
US7925771B1 (en) * 2003-03-03 2011-04-12 Realnetworks, Inc. System and method for uninterrupted streaming
US7925978B1 (en) * 2006-07-20 2011-04-12 Adobe Systems Incorporated Capturing frames from an external source
US20130142496A1 (en) * 2005-06-23 2013-06-06 Hideo Ando Information recording and reproducing method using management information including mapping information
US20130145267A1 (en) * 2011-12-01 2013-06-06 Microsoft Corporation Video streaming in a web browser
WO2014106851A1 (en) * 2013-01-06 2014-07-10 Takes Llc. Determining start and end points of a video clip based on a single click
WO2017199086A3 (en) * 2016-05-16 2018-01-18 Glide Talk Ltd. System and method for interleaved media communication and conversion
US10187443B2 (en) * 2017-06-12 2019-01-22 C-Hear, Inc. System and method for encoding image data and other data types into one data format and decoding of same
US10225304B2 (en) * 2004-04-30 2019-03-05 Dish Technologies Llc Apparatus, system, and method for adaptive-rate shifting of streaming content
US11588872B2 (en) 2017-06-12 2023-02-21 C-Hear, Inc. System and method for codec for combining disparate content

Families Citing this family (152)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7111009B1 (en) 1997-03-14 2006-09-19 Microsoft Corporation Interactive playlist generation using annotations
US6253228B1 (en) * 1997-03-31 2001-06-26 Apple Computer, Inc. Method and apparatus for updating and synchronizing information between a client and a server
US6353929B1 (en) * 1997-06-23 2002-03-05 One River Worldtrek, Inc. Cooperative system for measuring electronic media
US6557171B1 (en) * 1998-02-02 2003-04-29 Matsushita Electric Industrial Co., Ltd. Digital tv broadcast sending apparatus, digital tv broadcast receiving apparatus, and digital tv broadcast sending / receiving system which facilitate preselection of tv programs, and computer readable recording medium storing a program for achieving a function of the digital tv broadcast receiving apparatus
US6105055A (en) * 1998-03-13 2000-08-15 Siemens Corporate Research, Inc. Method and apparatus for asynchronous multimedia collaboration
JPH11297040A (en) * 1998-04-07 1999-10-29 Sony Corp Reproduced signal processing apparatus
WO1999066679A1 (en) * 1998-06-19 1999-12-23 Matsushita Electric Industrial Co., Ltd. Data transmitting/receiving method and device, and program recorded medium
US7051275B2 (en) * 1998-09-15 2006-05-23 Microsoft Corporation Annotations for multiple versions of media content
US6956593B1 (en) 1998-09-15 2005-10-18 Microsoft Corporation User interface for creating, viewing and temporally positioning annotations for media content
US6715126B1 (en) * 1998-09-16 2004-03-30 International Business Machines Corporation Efficient streaming of synchronized web content from multiple sources
US6816909B1 (en) * 1998-09-16 2004-11-09 International Business Machines Corporation Streaming media player with synchronous events from multiple sources
US6901604B1 (en) 1999-02-19 2005-05-31 Chaincast, Inc. Method and system for ensuring continuous data flow between re-transmitters within a chaincast communication system
US7610607B1 (en) 1999-02-19 2009-10-27 Chaincast Networks, Inc. Chaincast method and system for broadcasting information to multiple systems within the internet
JP2000278290A (en) * 1999-03-29 2000-10-06 Matsushita Electric Ind Co Ltd Network managing system
US6453420B1 (en) 1999-04-21 2002-09-17 Research Investment Network, Inc. System, method and article of manufacture for authorizing the use of electronic content utilizing a laser-centric medium
US6941383B1 (en) * 2000-01-20 2005-09-06 Interactual Technologies, Inc. System, method and article of manufacture for java/javascript component in a multimedia synchronization framework
US6769130B1 (en) 2000-01-20 2004-07-27 Interactual Technologies, Inc. System, method and article of manufacture for late synchronization during the execution of a multimedia event on a plurality of client computers
US6529949B1 (en) 2000-02-07 2003-03-04 Interactual Technologies, Inc. System, method and article of manufacture for remote unlocking of local content located on a client device
US6625656B2 (en) * 1999-05-04 2003-09-23 Enounce, Incorporated Method and apparatus for continuous playback or distribution of information including audio-visual streamed multimedia
JP3836637B2 (en) * 1999-08-09 2006-10-25 富士通株式会社 INFORMATION DISTRIBUTION CONTROL DEVICE, INFORMATION DISTRIBUTION CONTROL METHOD, COMPUTER-READABLE RECORDING MEDIUM CONTAINING INFORMATION DISTRIBUTION CONTROL PROGRAM, AND COMPUTER-READABLE RECORDING MEDIUM CONTAINING INFORMATION REPRODUCTION CONTROL PROGRAM
US6736642B2 (en) * 1999-08-31 2004-05-18 Indeliq, Inc. Computer enabled training of a user to validate assumptions
US6708327B1 (en) * 1999-10-14 2004-03-16 Techonline, Inc. System for accessing and testing evaluation modules via a global computer network
US7386432B1 (en) * 1999-11-01 2008-06-10 Medical Learning Co., Inc./Web Simulator Web simulator
US7653925B2 (en) * 1999-11-17 2010-01-26 Ricoh Company, Ltd. Techniques for receiving information during multimedia presentations and communicating the information
US7299405B1 (en) * 2000-03-08 2007-11-20 Ricoh Company, Ltd. Method and system for information management to facilitate the exchange of ideas during a collaborative effort
JP2001357312A (en) * 1999-11-24 2001-12-26 Sega Corp Information processor, file server, method and system for charging management, and recording medium with program recorded
US20010033296A1 (en) * 2000-01-21 2001-10-25 Fullerton Nathan W. Method and apparatus for delivery and presentation of data
US20020016969A1 (en) * 2000-02-03 2002-02-07 International Business Machines Corporation Media on demand system and method
WO2001057734A1 (en) * 2000-02-03 2001-08-09 Sony Electronics Inc. Web browser plug-in for tv
US7149592B2 (en) * 2000-02-18 2006-12-12 Intervideo, Inc. Linking internet documents with compressed audio files
EP1297438A1 (en) * 2000-04-28 2003-04-02 Live365, Inc. System and method for reducing the resources required to deliver streaming media
US7080315B1 (en) * 2000-06-28 2006-07-18 International Business Machines Corporation Method and apparatus for coupling a visual browser to a voice browser
US6715061B1 (en) * 2000-07-12 2004-03-30 Via Technologies, Inc. Multimedia-instruction acceleration device for increasing efficiency and method for the same
AU9127601A (en) * 2000-08-25 2002-03-04 Intellocity Usa Inc Streaming media
US7103668B1 (en) * 2000-08-29 2006-09-05 Inetcam, Inc. Method and apparatus for distributing multimedia to remote clients
US7779097B2 (en) 2000-09-07 2010-08-17 Sonic Solutions Methods and systems for use in network management of content
US7689510B2 (en) 2000-09-07 2010-03-30 Sonic Solutions Methods and system for use in network management of content
FR2814027B1 (en) * 2000-09-14 2003-01-31 Cit Alcatel METHOD FOR SYNCHRONIZING A MULTIMEDIA FILE
US6920181B1 (en) * 2000-09-19 2005-07-19 Todd Porter Method for synchronizing audio and video streams
US20020145621A1 (en) * 2001-01-30 2002-10-10 Nguyen Nga Marie Web browser and set top box interface system and method
US6599130B2 (en) * 2001-02-02 2003-07-29 Illinois Institute Of Technology Iterative video teaching aid with recordable commentary and indexing
US6873344B2 (en) * 2001-02-22 2005-03-29 Sony Corporation Media production system using flowgraph representation of operations
US7277958B2 (en) * 2001-03-12 2007-10-02 Edgestream, Inc. Re-assembly of streaming files from separate connections
US7143353B2 (en) * 2001-03-30 2006-11-28 Koninklijke Philips Electronics, N.V. Streaming video bookmarks
FR2823343B1 (en) * 2001-04-05 2003-07-04 Cit Alcatel DEVICE FOR GENERATING A MULTIMEDIA FILE FOR A TELECOMMUNICATIONS TERMINAL AND ASSOCIATED MULTIMEDIA FILE
US7260827B1 (en) * 2001-04-23 2007-08-21 Unisys Corporation Manual mode method of testing a video server for a video-on-demand system
US20020194606A1 (en) * 2001-06-14 2002-12-19 Michael Tucker System and method of communication between videoconferencing systems and computer systems
JP2003032623A (en) * 2001-07-19 2003-01-31 Nec Commun Syst Ltd Synchronous process system when transforming moving image standard
JP2003060638A (en) * 2001-08-15 2003-02-28 Sony Corp Content providing device and method therefor
US7747943B2 (en) * 2001-09-07 2010-06-29 Microsoft Corporation Robust anchoring of annotations to content
KR100919313B1 (en) * 2001-09-18 2009-10-01 소니 가부시끼 가이샤 Transmission apparatus, transmission method, content delivery system, content delivery method, and recording medium where program in recorded
US20030076350A1 (en) * 2001-10-23 2003-04-24 Toshiba America Information Systems, Inc Interface for content development
US20040205479A1 (en) * 2001-10-30 2004-10-14 Seaman Mark D. System and method for creating a multimedia presentation
US20050226172A1 (en) * 2001-12-15 2005-10-13 Richardson John W Video conference call set up
US20030191805A1 (en) * 2002-02-11 2003-10-09 Seymour William Brian Methods, apparatus, and systems for on-line seminars
US7243301B2 (en) 2002-04-10 2007-07-10 Microsoft Corporation Common annotation framework
US7568151B2 (en) * 2002-06-27 2009-07-28 Microsoft Corporation Notification of activity around documents
US7549127B2 (en) * 2002-08-01 2009-06-16 Realnetworks, Inc. Method and apparatus for resizing video content displayed within a graphical user interface
US8737816B2 (en) * 2002-08-07 2014-05-27 Hollinbeck Mgmt. Gmbh, Llc System for selecting video tracks during playback of a media production
US7739584B2 (en) * 2002-08-08 2010-06-15 Zane Vella Electronic messaging synchronized to media presentation
US6850284B2 (en) * 2002-08-27 2005-02-01 Motorola, Inc. Method and apparatus for decoding audio and video information
US8307273B2 (en) * 2002-12-30 2012-11-06 The Board Of Trustees Of The Leland Stanford Junior University Methods and apparatus for interactive network sharing of digital video content
US7082572B2 (en) 2002-12-30 2006-07-25 The Board Of Trustees Of The Leland Stanford Junior University Methods and apparatus for interactive map-based analysis of digital video content
US7823058B2 (en) * 2002-12-30 2010-10-26 The Board Of Trustees Of The Leland Stanford Junior University Methods and apparatus for interactive point-of-view authoring of digital video content
US8027482B2 (en) * 2003-02-13 2011-09-27 Hollinbeck Mgmt. Gmbh, Llc DVD audio encoding using environmental audio tracks
US7657651B2 (en) * 2003-04-08 2010-02-02 International Business Machines Corporation Resource-efficient media streaming to heterogeneous clients
US20040215802A1 (en) * 2003-04-08 2004-10-28 Lisa Amini System and method for resource-efficient live media streaming to heterogeneous clients
US11106425B2 (en) 2003-07-28 2021-08-31 Sonos, Inc. Synchronizing operations among a plurality of independently clocked digital data processing devices
US11106424B2 (en) 2003-07-28 2021-08-31 Sonos, Inc. Synchronizing operations among a plurality of independently clocked digital data processing devices
US8234395B2 (en) 2003-07-28 2012-07-31 Sonos, Inc. System and method for synchronizing operations among a plurality of independently clocked digital data processing devices
US8290603B1 (en) 2004-06-05 2012-10-16 Sonos, Inc. User interfaces for controlling and manipulating groupings in a multi-zone media system
US8086752B2 (en) * 2006-11-22 2011-12-27 Sonos, Inc. Systems and methods for synchronizing operations among a plurality of independently clocked digital data processing devices that independently source digital data
US10613817B2 (en) 2003-07-28 2020-04-07 Sonos, Inc. Method and apparatus for displaying a list of tracks scheduled for playback by a synchrony group
US11294618B2 (en) 2003-07-28 2022-04-05 Sonos, Inc. Media player system
US11650784B2 (en) 2003-07-28 2023-05-16 Sonos, Inc. Adjusting volume levels
JP2005084875A (en) * 2003-09-08 2005-03-31 Nec Corp Media distribution device and method and recording media for recording program
JP4001091B2 (en) * 2003-09-11 2007-10-31 ヤマハ株式会社 Performance system and music video playback device
US20050125717A1 (en) * 2003-10-29 2005-06-09 Tsakhi Segal System and method for off-line synchronized capturing and reviewing notes and presentations
DE10353564A1 (en) * 2003-11-14 2005-06-16 Deutsche Thomson-Brandt Gmbh Method for the intermittent, discontinuous transmission of data in a network of distributed stations and network subscriber station as a request device in the implementation of such a method as well as network subscriber station as a source device in the implementation of such a method
US7689712B2 (en) 2003-11-26 2010-03-30 Ricoh Company, Ltd. Techniques for integrating note-taking and multimedia information
US7464330B2 (en) 2003-12-09 2008-12-09 Microsoft Corporation Context-free document portions with alternate formats
US7617447B1 (en) 2003-12-09 2009-11-10 Microsoft Corporation Context free document portions
US7558806B2 (en) * 2003-12-14 2009-07-07 Realnetworks, Inc. Method and apparatus for buffering streaming media
US7288712B2 (en) * 2004-01-09 2007-10-30 Yamaha Corporation Music station for producing visual images synchronously with music data codes
US20050183000A1 (en) * 2004-02-14 2005-08-18 Pu-Hua Mei Method for remarking image taken by digital camera
US8837921B2 (en) * 2004-02-27 2014-09-16 Hollinbeck Mgmt. Gmbh, Llc System for fast angle changing in video playback devices
US8238721B2 (en) * 2004-02-27 2012-08-07 Hollinbeck Mgmt. Gmbh, Llc Scene changing in video playback devices including device-generated transitions
US8165448B2 (en) * 2004-03-24 2012-04-24 Hollinbeck Mgmt. Gmbh, Llc System using multiple display screens for multiple video streams
US9374607B2 (en) 2012-06-26 2016-06-21 Sonos, Inc. Media playback system with guest access
US9977561B2 (en) 2004-04-01 2018-05-22 Sonos, Inc. Systems, methods, apparatus, and articles of manufacture to provide guest access
US7418652B2 (en) * 2004-04-30 2008-08-26 Microsoft Corporation Method and apparatus for interleaving parts of a document
US7512878B2 (en) 2004-04-30 2009-03-31 Microsoft Corporation Modular document format
US7487448B2 (en) 2004-04-30 2009-02-03 Microsoft Corporation Document mark up methods and systems
US7359902B2 (en) 2004-04-30 2008-04-15 Microsoft Corporation Method and apparatus for maintaining relationships between parts in a package
US7383500B2 (en) 2004-04-30 2008-06-03 Microsoft Corporation Methods and systems for building packages that contain pre-paginated documents
US7549118B2 (en) 2004-04-30 2009-06-16 Microsoft Corporation Methods and systems for defining documents with selectable and/or sequenceable parts
US8661332B2 (en) 2004-04-30 2014-02-25 Microsoft Corporation Method and apparatus for document processing
US8243317B2 (en) 2004-05-03 2012-08-14 Microsoft Corporation Hierarchical arrangement for spooling job data
US7755786B2 (en) * 2004-05-03 2010-07-13 Microsoft Corporation Systems and methods for support of various processing capabilities
US7634775B2 (en) * 2004-05-03 2009-12-15 Microsoft Corporation Sharing of downloaded resources
US7607141B2 (en) * 2004-05-03 2009-10-20 Microsoft Corporation Systems and methods for support of various processing capabilities
US7440132B2 (en) * 2004-05-03 2008-10-21 Microsoft Corporation Systems and methods for handling a file with complex elements
US7580948B2 (en) 2004-05-03 2009-08-25 Microsoft Corporation Spooling strategies using structured job information
US8363232B2 (en) 2004-05-03 2013-01-29 Microsoft Corporation Strategies for simultaneous peripheral operations on-line using hierarchically structured job information
US7519899B2 (en) 2004-05-03 2009-04-14 Microsoft Corporation Planar mapping of graphical elements
US7761259B1 (en) 2004-05-26 2010-07-20 William Brian Seymour Methods and systems for testing evaluation modules
US7984428B1 (en) 2004-05-26 2011-07-19 United Business Media Llc Methods and systems for testing evaluation modules
US8868698B2 (en) 2004-06-05 2014-10-21 Sonos, Inc. Establishing a secure wireless network with minimum human intervention
US8326951B1 (en) 2004-06-05 2012-12-04 Sonos, Inc. Establishing a secure wireless network with minimum human intervention
NZ534100A (en) * 2004-07-14 2008-11-28 Tandberg Nz Ltd Method and system for correlating content with linear media
KR100693598B1 (en) * 2004-09-08 2007-03-14 주식회사 팬택앤큐리텔 Wireless communication terminal and its method for generating moving picture using image and Wireless communication using the same
US7617450B2 (en) 2004-09-30 2009-11-10 Microsoft Corporation Method, system, and computer-readable medium for creating, inserting, and reusing document parts in an electronic document
US7667862B2 (en) * 2004-10-05 2010-02-23 Isee Media Inc. Method and system for streaming images to wireless devices
US7752539B2 (en) * 2004-10-27 2010-07-06 Nokia Corporation Receiving and sending content items associated with a multimedia file
US7584111B2 (en) * 2004-11-19 2009-09-01 Microsoft Corporation Time polynomial Arrow-Debreu market equilibrium
US7617451B2 (en) * 2004-12-20 2009-11-10 Microsoft Corporation Structuring data for word processing documents
US7617229B2 (en) 2004-12-20 2009-11-10 Microsoft Corporation Management and use of data in a computer-generated document
US7614000B2 (en) 2004-12-20 2009-11-03 Microsoft Corporation File formats, methods, and computer program products for representing presentations
US7617444B2 (en) 2004-12-20 2009-11-10 Microsoft Corporation File formats, methods, and computer program products for representing workbooks
US7620889B2 (en) 2004-12-20 2009-11-17 Microsoft Corporation Method and system for linking data ranges of a computer-generated document with associated extensible markup language elements
US7752632B2 (en) 2004-12-21 2010-07-06 Microsoft Corporation Method and system for exposing nested data in a computer-generated document in a transparent manner
US7770180B2 (en) 2004-12-21 2010-08-03 Microsoft Corporation Exposing embedded data in a computer-generated document
US8045845B2 (en) * 2005-01-03 2011-10-25 Hollinbeck Mgmt. Gmbh, Llc System for holding a current track during playback of a multi-track media production
US20060161838A1 (en) * 2005-01-14 2006-07-20 Ronald Nydam Review of signature based content
US7554576B2 (en) * 2005-06-20 2009-06-30 Ricoh Company, Ltd. Information capture and recording system for controlling capture devices
US8805929B2 (en) 2005-06-20 2014-08-12 Ricoh Company, Ltd. Event-driven annotation techniques
US20080301561A1 (en) * 2005-08-30 2008-12-04 David Bain Apparatus and method for automation of multimedia-enabled correspondence management systems (MCMS)
US9384178B2 (en) * 2005-12-09 2016-07-05 Adobe Systems Incorporated Review of signature based content
US20070239839A1 (en) * 2006-04-06 2007-10-11 Buday Michael E Method for multimedia review synchronization
US7954049B2 (en) 2006-05-15 2011-05-31 Microsoft Corporation Annotating multimedia files along a timeline
US20070276852A1 (en) * 2006-05-25 2007-11-29 Microsoft Corporation Downloading portions of media files
US7620899B2 (en) * 2006-06-30 2009-11-17 Microsoft Corporation Windows display synchronization
US8788080B1 (en) 2006-09-12 2014-07-22 Sonos, Inc. Multi-channel pairing in a media system
US8483853B1 (en) 2006-09-12 2013-07-09 Sonos, Inc. Controlling and manipulating groupings in a multi-zone media system
US9202509B2 (en) 2006-09-12 2015-12-01 Sonos, Inc. Controlling and grouping in a multi-zone media system
US20080120548A1 (en) * 2006-11-22 2008-05-22 Mark Morita System And Method For Processing User Interaction Information From Multiple Media Sources
US8234385B2 (en) 2007-05-16 2012-07-31 Microsoft Corporation Format negotiation for media remoting scenarios
JP2011523731A (en) * 2008-04-24 2011-08-18 チャーチル ダウンズ テクノロジー イニシアティブス カンパニー Individualized transaction management and media distribution system
US8380866B2 (en) 2009-03-20 2013-02-19 Ricoh Company, Ltd. Techniques for facilitating annotations
US8769589B2 (en) * 2009-03-31 2014-07-01 At&T Intellectual Property I, L.P. System and method to create a media content summary based on viewer annotations
US8887190B2 (en) * 2009-05-28 2014-11-11 Harris Corporation Multimedia system generating audio trigger markers synchronized with video source data and related methods
US11265652B2 (en) 2011-01-25 2022-03-01 Sonos, Inc. Playback device pairing
US11429343B2 (en) 2011-01-25 2022-08-30 Sonos, Inc. Stereo playback configuration and control
US9191686B2 (en) * 2011-07-22 2015-11-17 Honeywell International Inc. System and method of implementing synchronized audio and video streaming
US9729115B2 (en) 2012-04-27 2017-08-08 Sonos, Inc. Intelligently increasing the sound level of player
US9008330B2 (en) 2012-09-28 2015-04-14 Sonos, Inc. Crossover frequency adjustments for audio speakers
US20140129730A1 (en) * 2012-11-02 2014-05-08 Collaborative Knowledge Inc. d/b/a Zerellium Methods and apparatus for real time delivery of heterogeneous content
US8854361B1 (en) * 2013-03-13 2014-10-07 Cambridgesoft Corporation Visually augmenting a graphical rendering of a chemical structure representation or biological sequence representation with multi-dimensional information
US9226087B2 (en) 2014-02-06 2015-12-29 Sonos, Inc. Audio output balancing during synchronized playback
US9226073B2 (en) 2014-02-06 2015-12-29 Sonos, Inc. Audio output balancing during synchronized playback
US10248376B2 (en) 2015-06-11 2019-04-02 Sonos, Inc. Multiple groupings in a playback system
US10712997B2 (en) 2016-10-17 2020-07-14 Sonos, Inc. Room association based on name

Family Cites Families (51)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4931950A (en) 1988-07-25 1990-06-05 Electric Power Research Institute Multimedia interface and method for computer system
US5119474A (en) 1989-06-16 1992-06-02 International Business Machines Corp. Computer-based, audio/visual creation and presentation system and method
US5274758A (en) 1989-06-16 1993-12-28 International Business Machines Computer-based, audio/visual creation and presentation system and method
US5050161A (en) 1989-12-04 1991-09-17 Bell Communications Research, Inc. Congestion management based on multiple framing strategy
EP0523617B1 (en) 1991-07-15 1997-10-01 Hitachi, Ltd. Teleconference terminal equipment
CA2084575C (en) 1991-12-31 1996-12-03 Chris A. Dinallo Personal computer with generalized data streaming apparatus for multimedia devices
US5313454A (en) 1992-04-01 1994-05-17 Stratacom, Inc. Congestion control for cell networks
US5623690A (en) 1992-06-03 1997-04-22 Digital Equipment Corporation Audio/video storage and retrieval for multimedia workstations by interleaving audio and video data in data file
GB2268372B (en) 1992-06-11 1995-11-01 Roke Manor Research Improvements in or relating to data transmission systems
US5490252A (en) 1992-09-30 1996-02-06 Bay Networks Group, Inc. System having central processor for transmitting generic packets to another processor to be altered and transmitting altered packets back to central processor for routing
US5442389A (en) * 1992-12-28 1995-08-15 At&T Corp. Program server for interactive television system
US5455910A (en) 1993-01-06 1995-10-03 International Business Machines Corporation Method and system for creating a synchronized presentation from different types of media presentations
US5396497A (en) * 1993-02-26 1995-03-07 Sony Corporation Synchronization of audio/video information
US5481543A (en) * 1993-03-16 1996-01-02 Sony Corporation Rational input buffer arrangements for auxiliary information in video and audio signal processing systems
US5502727A (en) * 1993-04-20 1996-03-26 At&T Corp. Image and audio communication system having graphical annotation capability
US5574934A (en) * 1993-11-24 1996-11-12 Intel Corporation Preemptive priority-based transmission of signals using virtual channels
US5602992A (en) * 1993-11-29 1997-02-11 Intel Corporation System for synchronizing data stream transferred from server to client by initializing clock when first packet is received and comparing packet time information with clock
KR100283710B1 (en) * 1993-11-30 2001-03-02 제이 엘. 차스킨 Data word indicator in the transport data packet assembling system
US5583562A (en) * 1993-12-03 1996-12-10 Scientific-Atlanta, Inc. System and method for transmitting a plurality of digital services including imaging services
KR960008470B1 (en) * 1994-01-18 1996-06-26 Daewoo Electronics Co Ltd Apparatus for transferring bit stream data adaptively in the moving picture
US5504744A (en) 1994-03-09 1996-04-02 British Telecommunications Public Limited Company Broadband switching network
JPH07284077A (en) * 1994-04-06 1995-10-27 Matsushita Electric Ind Co Ltd Electronic conference terminal
US5583652A (en) * 1994-04-28 1996-12-10 International Business Machines Corporation Synchronized, variable-speed playback of digitally recorded audio and video
US5577258A (en) 1994-07-13 1996-11-19 Bell Communications Research, Inc. Apparatus and method for preprocessing multimedia presentations to generate a delivery schedule
US5594911A (en) 1994-07-13 1997-01-14 Bell Communications Research, Inc. System and method for preprocessing and delivering multimedia presentations
US5434848A (en) 1994-07-28 1995-07-18 International Business Machines Corporation Traffic management in packet communications networks
US5600775A (en) 1994-08-26 1997-02-04 Emotion, Inc. Method and apparatus for annotating full motion video and other indexed data structures
JPH08153113A (en) 1994-11-28 1996-06-11 Fujitsu Ltd Multimedia server
US5758257A (en) 1994-11-29 1998-05-26 Herz; Frederick System and method for scheduling broadcast of and access to video programs and other data using customer profiles
US6029195A (en) 1994-11-29 2000-02-22 Herz; Frederick S. M. System for customized electronic identification of desirable objects
US5793980A (en) * 1994-11-30 1998-08-11 Realnetworks, Inc. Audio-on-demand communication system
US5533021A (en) * 1995-02-03 1996-07-02 International Business Machines Corporation Apparatus and method for segmentation and time synchronization of the transmission of multimedia data
JP3547840B2 (en) 1995-03-16 2004-07-28 株式会社東芝 Multimedia server
US5978577A (en) 1995-03-17 1999-11-02 Csg Systems, Inc. Method and apparatus for transaction processing in a distributed database system
US5519701A (en) 1995-03-29 1996-05-21 International Business Machines Corporation Architecture for high performance management of multiple circular FIFO storage means
US5574724A (en) 1995-05-26 1996-11-12 Lucent Technologies Inc. Adjustment of call bandwidth during a communication call
US5982459A (en) 1995-05-31 1999-11-09 8×8, Inc. Integrated multimedia communications processor and codec
WO1997012486A1 (en) 1995-09-29 1997-04-03 Boston Technology, Inc. Multimedia architecture for interactive advertising
TW335480B (en) * 1995-09-29 1998-07-01 Matsushita Electric Ind Co Ltd Method and apparatus for encoding a bistream for multi-angle connection
US6732369B1 (en) 1995-10-02 2004-05-04 Starsight Telecast, Inc. Systems and methods for contextually linking television program information
JPH09139937A (en) * 1995-11-14 1997-05-27 Fujitsu Ltd Moving image stream converter
US5956088A (en) * 1995-11-21 1999-09-21 Imedia Corporation Method and apparatus for modifying encoded digital video for improved channel utilization
JPH09205618A (en) * 1996-01-29 1997-08-05 Mitsubishi Electric Corp Dynamic image sound expansion reproduction device and dynamic image sound synchronization controller
US6044170A (en) * 1996-03-21 2000-03-28 Real-Time Geometry Corporation System and method for rapid shape digitizing and adaptive mesh generation
JP3687188B2 (en) * 1996-04-05 2005-08-24 ソニー株式会社 Packet transmission method
US5916307A (en) * 1996-06-05 1999-06-29 New Era Of Networks, Inc. Method and structure for balanced queue communication between nodes in a distributed computing application
US6006241A (en) 1997-03-14 1999-12-21 Microsoft Corporation Production of a video stream with synchronized annotations over a computer network
US6122658A (en) 1997-07-03 2000-09-19 Microsoft Corporation Custom localized information in a networked server for display to an end user
US6014701A (en) 1997-07-03 2000-01-11 Microsoft Corporation Selecting a cost-effective bandwidth for transmitting information to an end user in a computer network
US5999906A (en) * 1997-09-24 1999-12-07 Sony Corporation Sample accurate audio state update
US6029045A (en) 1997-12-09 2000-02-22 Cogent Technology, Inc. System and method for inserting local content into programming content

Cited By (98)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7669111B1 (en) * 1997-01-29 2010-02-23 Philip R Krause Electronic text reading environment enhancement method and apparatus
US6636888B1 (en) 1999-06-15 2003-10-21 Microsoft Corporation Scheduling presentation broadcasts in an integrated network environment
US7330875B1 (en) * 1999-06-15 2008-02-12 Microsoft Corporation System and method for recording a presentation for on-demand viewing over a computer network
US20080126943A1 (en) * 1999-06-15 2008-05-29 Microsoft Corporation System and method for recording a presentation for on-demand viewing over a computer network
US7552228B2 (en) * 1999-06-15 2009-06-23 Microsoft Corporation System and method for recording a presentation for on-demand viewing over a computer network
US10257246B2 (en) 2000-01-28 2019-04-09 Comcast Ip Holdings I, Llc Content distribution via a distribution network and an access network
US20070106814A1 (en) * 2000-01-28 2007-05-10 Son Yong H Method and Apparatus for Content Distribution Via Non-Homogeneous Access Networks
US7159233B2 (en) * 2000-01-28 2007-01-02 Sedna Patent Services, Llc Method and apparatus for preprocessing and postprocessing content in an interactive information distribution system
US20020047899A1 (en) * 2000-01-28 2002-04-25 Diva Systems Corporation Method and apparatus for preprocessing and postprocessing content in an interactive information distribution system
US20060218611A1 (en) * 2000-01-28 2006-09-28 Son Yong H Method and apparatus for preprocessing and postprocessing content in an interactive information distribution system
US9172735B2 (en) * 2000-01-28 2015-10-27 Comcast Ip Holdings I, Llc Method and apparatus for content distribution via non-homogeneous access networks
US7836474B2 (en) 2000-01-28 2010-11-16 Cox Communications, Inc. Method and apparatus for preprocessing and postprocessing content in an interactive information distribution system
US9596284B2 (en) 2000-01-28 2017-03-14 Comcast Ip Holdings I, Llc Content distribution via a distribution network and an access network
US6988216B2 (en) 2000-06-15 2006-01-17 Genesys Conferencing, Ltd. Method and system for synchronizing data
US6802019B1 (en) * 2000-06-15 2004-10-05 Genesys Conferencing, Ltd. Method and system for synchronizing data
US20050034005A1 (en) * 2000-06-15 2005-02-10 Doug Lauder Method and system for synchronizing data
US20020083043A1 (en) * 2000-11-30 2002-06-27 Tetsuo Hoshi System for acquiring and analyzing personal profile data and providing the service of delivering various information
US6980977B2 (en) * 2000-11-30 2005-12-27 Yokogawa Electric Corporation System for acquiring and analyzing personal profile data and providing the service of delivering various information
US20090083370A1 (en) * 2001-02-09 2009-03-26 Comlet Technologies Headquarters Enhanced data exchange and presentation/communication system
US20020112031A1 (en) * 2001-02-09 2002-08-15 Franklin Richard L. Enhanced data exchange and presentation/communication system
US20080155006A1 (en) * 2001-02-09 2008-06-26 Comlet Technologies Headquarters Enhanced data exchange and functionality control system and method
US7831719B2 (en) 2001-02-09 2010-11-09 Comlet Technology LLC Enhanced data exchange and presentation/communication system
US7814213B2 (en) 2001-02-09 2010-10-12 Comlet Technologies Headquarters Enhanced data exchange and presentation/communication system
US7249190B2 (en) * 2001-02-09 2007-07-24 Comlet Technologies, Llc. Enhanced data exchange and presentation/communication system
US7797431B2 (en) 2001-02-09 2010-09-14 Willard Case Enhanced data exchange and functionality control system and method
US20080022010A1 (en) * 2001-02-09 2008-01-24 Franklin Richard L Enhanced data exchange and presentation/communication system
DE10146255A1 (en) * 2001-09-20 2003-04-10 Deutsche Telekom Ag Method for generating multimedia content from several multimedia elements
US20070022465A1 (en) * 2001-11-20 2007-01-25 Rothschild Trust Holdings, Llc System and method for marking digital media content
US9648364B2 (en) 2001-11-20 2017-05-09 Nytell Software LLC Multi-user media delivery system for synchronizing content on multiple media players
US20070113264A1 (en) * 2001-11-20 2007-05-17 Rothschild Trust Holdings, Llc System and method for updating digital media content
US20100223337A1 (en) * 2001-11-20 2010-09-02 Reagan Inventions, Llc Multi-user media delivery system for synchronizing content on multiple media players
US20100211650A1 (en) * 2001-11-20 2010-08-19 Reagan Inventions, Llc Interactive, multi-user media delivery system
US8122466B2 (en) 2001-11-20 2012-02-21 Portulim Foundation Llc System and method for updating digital media content
US8396931B2 (en) 2001-11-20 2013-03-12 Portulim Foundation Llc Interactive, multi-user media delivery system
US10484729B2 (en) 2001-11-20 2019-11-19 Rovi Technologies Corporation Multi-user media delivery system for synchronizing content on multiple media players
US20070168463A1 (en) * 2001-11-20 2007-07-19 Rothschild Trust Holdings, Llc System and method for sharing digital media content
US8909729B2 (en) 2001-11-20 2014-12-09 Portulim Foundation Llc System and method for sharing digital media content
US8838693B2 (en) 2001-11-20 2014-09-16 Portulim Foundation Llc Multi-user media delivery system for synchronizing content on multiple media players
US7146574B2 (en) * 2001-12-21 2006-12-05 Microsoft Corporation Systems and methods for interfacing with digital history data
US20030118087A1 (en) * 2001-12-21 2003-06-26 Microsoft Corporation Systems and methods for interfacing with digital history data
US20090172744A1 (en) * 2001-12-28 2009-07-02 Rothschild Trust Holdings, Llc Method of enhancing media content and a media enhancement system
US8046813B2 (en) 2001-12-28 2011-10-25 Portulim Foundation Llc Method of enhancing media content and a media enhancement system
WO2004059536A2 (en) * 2002-12-20 2004-07-15 International Business Machines Coporation System and method for annotating multi-modal characteristics in multimedia documents
WO2004059536A3 (en) * 2002-12-20 2004-12-29 Ibm System and method for annotating multi-modal characteristics in multimedia documents
US7996538B2 (en) 2003-02-28 2011-08-09 Sony Corporation Information processing apparatus and content information processing method for transmitting content and event information to a client
US20060195545A1 (en) * 2003-02-28 2006-08-31 Sony Corporation Information processing apparatus and content information processing method
EP1598741A1 (en) * 2003-02-28 2005-11-23 Sony Corporation Information processing apparatus and content information processing method
EP1598741A4 (en) * 2003-02-28 2011-03-23 Sony Corp Information processing apparatus and content information processing method
US7925771B1 (en) * 2003-03-03 2011-04-12 Realnetworks, Inc. System and method for uninterrupted streaming
US20110167169A1 (en) * 2003-03-03 2011-07-07 Realnetworks, Inc. System and method for uninterrupted streaming
US9253232B2 (en) * 2003-03-03 2016-02-02 Intel Corporation System and method for uninterrupted streaming
US7343564B2 (en) 2003-08-11 2008-03-11 Core Mobility, Inc. Systems and methods for displaying location-based maps on communication devices
US7747963B2 (en) 2003-08-11 2010-06-29 Core Mobility, Inc. Displaying location-based content in a ticker of a handheld mobile communication device
US7747962B2 (en) 2003-08-11 2010-06-29 Core Mobility, Inc. Systems and methods for displaying location-based maps on communication devices
US8458611B2 (en) 2003-08-11 2013-06-04 Smith Micro Software, Inc. Displaying a map on a handheld wireless telecommunication device
US20090132378A1 (en) * 2003-08-11 2009-05-21 Core Mobility, Inc. Displaying location-based content in a ticker of a handheld mobile communication device
US8539371B2 (en) 2003-08-11 2013-09-17 Smith Micro Software, Inc Formatting ticker content in a handheld wireless telecommunication device
US7441203B2 (en) 2003-08-11 2008-10-21 Core Mobility, Inc. Interactive user interface presentation attributes for location-based content
US7430724B2 (en) * 2003-08-11 2008-09-30 Core Mobility, Inc. Systems and methods for displaying content in a ticker
US20080155453A1 (en) * 2003-08-11 2008-06-26 Core Mobility, Inc. Systems and methods for displaying location-based maps on communication devices
US7370283B2 (en) 2003-08-11 2008-05-06 Core Mobility, Inc. Systems and methods for populating a ticker using multiple data transmission modes
US8219926B2 (en) 2003-08-11 2012-07-10 Smith Micro Software, Inc Displaying a map on a handheld wireless telecommunication device
US20060089160A1 (en) * 2003-08-11 2006-04-27 Core Mobility, Inc. Systems and methods for displaying location-based maps on communication devices
US20050210391A1 (en) * 2003-08-11 2005-09-22 Core Mobility, Inc. Systems and methods for navigating content in an interactive ticker
US20050154996A1 (en) * 2003-08-11 2005-07-14 Core Mobility, Inc. Systems and methods for populating a ticker using multiple data transmission modes
US20050039135A1 (en) * 2003-08-11 2005-02-17 Konstantin Othmer Systems and methods for navigating content in an interactive ticker
US8214738B2 (en) 2003-08-11 2012-07-03 Smith Micro Software, Inc Displaying location-based content in a handheld device
US8219925B2 (en) 2003-08-11 2012-07-10 Smith Micro Software, Inc Formatting ticker content in a handheld wireless telecommunication device
US7606925B2 (en) * 2003-09-02 2009-10-20 Microsoft Corporation Video delivery workflow
US20050050218A1 (en) * 2003-09-02 2005-03-03 Microsoft Corporation Video delivery workflow
US20050122974A1 (en) * 2003-11-25 2005-06-09 Friedemann Hubler Method and apparatus for storage or relocation of defined positions in a data stream
US7664105B2 (en) * 2003-11-25 2010-02-16 Thomson Licensing Method and apparatus for storage or relocation of defined positions in a data stream
US20050132415A1 (en) * 2003-12-11 2005-06-16 Hillis W. D. Spatial-to-temporal data translation and transmission
US10225304B2 (en) * 2004-04-30 2019-03-05 Dish Technologies Llc Apparatus, system, and method for adaptive-rate shifting of streaming content
US8819702B2 (en) 2004-09-15 2014-08-26 Nokia Corporation File delivery session handling
US20080115148A1 (en) * 2004-09-15 2008-05-15 Toni Paila File Delivery Session Handling
US20080301314A1 (en) * 2004-11-09 2008-12-04 Nokia Corporation Auxiliary Content Handling Over Digital Communication Systems
GB2419975A (en) * 2004-11-09 2006-05-10 Nokia Corp Auxiliary content handling
US20130142496A1 (en) * 2005-06-23 2013-06-06 Hideo Ando Information recording and reproducing method using management information including mapping information
US20070250573A1 (en) * 2006-04-10 2007-10-25 Rothschild Trust Holdings, Llc Method and system for selectively supplying media content to a user and media storage device for use therein
US8504652B2 (en) 2006-04-10 2013-08-06 Portulim Foundation Llc Method and system for selectively supplying media content to a user and media storage device for use therein
US7925978B1 (en) * 2006-07-20 2011-04-12 Adobe Systems Incorporated Capturing frames from an external source
US9142254B2 (en) 2006-07-20 2015-09-22 Adobe Systems Incorporated Capturing frames from an external source
US20080062940A1 (en) * 2006-08-17 2008-03-13 Skypop.Inc. Presence-based communication between local wireless network access points and mobile devices
US8788938B2 (en) 2007-01-19 2014-07-22 Hewlett-Packard Development Company, L.P. Web-based video browsing
WO2008088883A1 (en) * 2007-01-19 2008-07-24 Hewlett-Packard Development Company, L.P. Web-based video browsing
US10565288B2 (en) 2011-12-01 2020-02-18 Microsoft Technology Licensing, Llc Video streaming in a web browser
US20130145267A1 (en) * 2011-12-01 2013-06-06 Microsoft Corporation Video streaming in a web browser
US9569097B2 (en) * 2011-12-01 2017-02-14 Microsoft Technology Licesing, LLC Video streaming in a web browser
WO2014106851A1 (en) * 2013-01-06 2014-07-10 Takes Llc. Determining start and end points of a video clip based on a single click
WO2017199086A3 (en) * 2016-05-16 2018-01-18 Glide Talk Ltd. System and method for interleaved media communication and conversion
US10986154B2 (en) 2016-05-16 2021-04-20 Glide Talk Ltd. System and method for interleaved media communication and conversion
US10992725B2 (en) 2016-05-16 2021-04-27 Glide Talk Ltd. System and method for interleaved media communication and conversion
US11553025B2 (en) 2016-05-16 2023-01-10 Glide Talk Ltd. System and method for interleaved media communication and conversion
US10187443B2 (en) * 2017-06-12 2019-01-22 C-Hear, Inc. System and method for encoding image data and other data types into one data format and decoding of same
US11330031B2 (en) 2017-06-12 2022-05-10 C-Hear, Inc. System and method for encoding image data and other data types into one data format and decoding of same
US11588872B2 (en) 2017-06-12 2023-02-21 C-Hear, Inc. System and method for codec for combining disparate content
US11811521B2 (en) 2017-06-12 2023-11-07 C-Hear, Inc. System and method for encoding image data and other data types into one data format and decoding of same

Also Published As

Publication number Publication date
US6449653B2 (en) 2002-09-10

Similar Documents

Publication Publication Date Title
US6449653B2 (en) Interleaved multiple multimedia stream for synchronized transmission over a computer network
US6173317B1 (en) Streaming and displaying a video stream with synchronized annotations over a computer network
US6230172B1 (en) Production of a video stream with synchronized annotations over a computer network
US7424730B2 (en) Multimedia presentation latency minimization
US5918002A (en) Selective retransmission for efficient and reliable streaming of multimedia packets in a computer network
US6868440B1 (en) Multi-level skimming of multimedia content using playlists
US6715126B1 (en) Efficient streaming of synchronized web content from multiple sources
US9584571B2 (en) System and method for capturing, editing, searching, and delivering multi-media content with local and global time
US9171545B2 (en) Browsing and retrieval of full broadcast-quality video
US6754715B1 (en) Methods and apparatus for implementing control functions in a streamed video display system
US20050154679A1 (en) System for inserting interactive media within a presentation
US7877774B1 (en) Browsing and retrieval of full broadcast-quality video
JP3523217B2 (en) Media data processor
EP0669587A2 (en) Networked system for display of multimedia presentations
US20020112004A1 (en) Live navigation web-conferencing system and method
EP1110394A1 (en) Simulating two way connectivity for one way data streams for multiple parties
JP6700957B2 (en) Subtitle data generation device and program
WO2001019088A1 (en) Client presentation page content synchronized to a streaming data signal
England et al. Rave: Real-time services for the web
NZ521644A (en) Insertion of asynchronous data into a synchronous stream
EP0737930A1 (en) Method and system for comicstrip representation of multimedia presentations
Katseff et al. Predictive prefetch in the Nemesis multimedia information service
US20020054026A1 (en) Synchronized transmission of recorded writing data with audio
WO2001024530A2 (en) Streaming media encoding agent for temporal modifications
Gibbon et al. Browsing and Retrieval of Full Broadcast-Quality Video

Legal Events

Date Code Title Description
AS Assignment

Owner name: VXTREME, INC., CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:KLEMETS, ANDERS EDGAR;CHOU, PHILIP A.;REEL/FRAME:008472/0213

Effective date: 19970324

AS Assignment

Owner name: MICROSOFT CORPORATION, WASHINGTON

Free format text: MERGER;ASSIGNOR:VXTREME, INC.;REEL/FRAME:009550/0128

Effective date: 19980302

STCF Information on status: patent grant

Free format text: PATENTED CASE

CC Certificate of correction
FPAY Fee payment

Year of fee payment: 4

FPAY Fee payment

Year of fee payment: 8

FPAY Fee payment

Year of fee payment: 12

AS Assignment

Owner name: MICROSOFT TECHNOLOGY LICENSING, LLC, WASHINGTON

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICROSOFT CORPORATION;REEL/FRAME:034541/0001

Effective date: 20141014