System and method for programmatic link generation with media delivery

Information

  • Patent Grant
  • 8973072
  • Patent Number
    8,973,072
  • Date Filed
    Friday, October 19, 2007
    17 years ago
  • Date Issued
    Tuesday, March 3, 2015
    9 years ago
Abstract
a media file is electronically communicated by programmatically generating a link for an electronic communication, where the link identifies a media file that is stored on a given terminal of a user. Selection of the link at a remote terminal is detected, indicating that a recipient of the electronic communication has selected to view the media file. In response to the link in the message being selected from the remote terminal, streaming data from the media file to the recipient. An embodiment such as described may be performed from a user terminal or system, correspond to, for example, where the media file was recorded, created and/or stored.
Description
TECHNICAL FIELD

Embodiments of the invention relate a system and method for enabling the communication of media files. In particular, embodiments described herein provide a system and method for programmatic link generation with media delivery.


BACKGROUND

Email, text messaging and other forms of electronic communication have continued to grow in popularity as more and more devices are able to connect to the internet. Over the years, network connectivity has been extended to appliances such as refrigerators, home entertainment centers, and interactive box sets for use with television sets, digital cameras, and cell phones. With the evolution of these devices, there have been developments in home networks. For example, WIFI technology enables users to interconnect various network enabled devices wirelessly to form their own local area network. Various services and applications currently exist with the goal of establishing data connectivity between different network locations. The growth of the Internet and other types of networks has contributed to the numerous networking applications that currently exist.


Electronic messaging and networking capabilities have been extended to a number of portable devices including cell phones, personal digital assistants (PDAs), and personal computers. As these devices continue to evolve, electronic messages including email, text messages and instant messages may be transmitted between these web-enabled devices. However, sending a video message or other form of media data between these devices using email or other form electronic messaging is still relatively impractical as many media files may be too large to send using convention forms of electronic messaging. In addition, many devices that have capabilities to interact with networks and receive and send electronic messages, often have poor user-interface features, and limited processing/memory resources for receiving and playing back media files that are transmitted and received.


Additionally, there are various interoperability issues when different types of network enabled devices are coupled and media files are sent between devices. Often, the different devices operate on incompatible platforms or operating systems. This can cause problems in how these devices share data with one another. Furthermore, connected devices may use different data types (.WAV versus MPEG) and/or data formats that hinder the user's ability to share media files amongst devices. As an example, the size of the screen display on a cell phone is typically too small to render images from a digital camera, even if the cell phone is camera-enabled. Often, the result is that when users want to share data amongst connected devices, that user must perform numerous manual steps, such as manually converting data formats.


Even as various computer and electronic devices increase their functionality, their hardware components, environment and form-factor become limitations that need to be accounted for when devices are sought to operate with one another. For example, many devices are capable of rendering or playing back rich media (e.g. music or video), but these devices have different levels of suitability for these functions and most times large media files may not be transmitted to and stored by these devices.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 describes a method or technique for communicating a link that identifies a media file to a third party



FIG. 2 is a basic block diagram of a system for transmitting a media file using an electronic message.



FIG. 3 describes a method or technique for identifying and electronically sending a media file.



FIG. 4 illustrates a system architecture, under one or more embodiments of the invention.



FIGS. 5A-5C illustrate a programmatically generated link for use in an email message, under an embodiment of the invention.



FIG. 6 illustrates a selectable link included on a web blog, under an embodiment of the invention.





DETAILED DESCRIPTION

Embodiments described herein provide a method and system for enabling the programmatic transmission of media files through programmatic and/or automatic link generation. According to some embodiments, a method is provided for generating a selectable link for electronic communications (e.g. email or blog post), where the link locates and identifies a media file on a user's system, home network or so-called personal network. In one embodiment, individuals are able to share media that they host by communicating a link to that media, and enabling recipients of the link to access a corresponding media file to receive the media. As will be described, the link may be shared by electronic communication, including by messaging or by web posting.


In one embodiment, a media file may be created concurrently or contemporaneously with the composition of an electronic message that includes a link to locate that media file. For example, the media file may be recorded by the user and transmitted during the composition of the electronic message. Individuals who receive the message are able to select the link from a connected terminal. The link identifies a stored media file associated with the link, and causes portions of the stored media file to be transferred to a target device (device on which the link was selected).


According to embodiments described herein, communications that include links may be in the form of messages (e.g. emails) or web postings. For example, an individual may record a video file containing a personal message, store the message locally, and communicate a message (email, MMS, SMS, instant message etc.) containing a link to either the media file or a mirror to the media file.


As an alternative, the media file that is the subject of the communication may have been previously recorded or obtained (e.g. through a third party source). The media file may reside on the user's terminal or network (e.g. home network or personal network), and a link may be generated that enables a recipient of the link to receive media corresponding to the media file. (home or personal).


Embodiments described herein provide that when a media file is generated or selected by an individual, a link, corresponding to the identified media file, is generated and included in an electronic message or web posting. As used herein, a link is a selectable data element that can, either by itself, or with a combination of other data, enable a recipient user to remotely locate the media file, or a replication or similar resource of the media file. The link may serve to directly or indirectly locate the media file. Furthermore, the link may be automatically or manually included in the body of an electronic message or blog in response to some designated event, action or combination of events/actions. For example, the link may be programmatically generated in response to completion of a media recording, or the completion of a media recording in combination with a message being open or otherwise under a state of composition.


Embodiments described herein provide that when a media file is generated or selected by an individual, a link, corresponding to the identified media file, is generated and included in an electronic message or web posting or other electronic communication. As used herein, a link is a selectable data element that can, either by itself, or with a combination of other data, enable a user to remotely access a resource. When selected, a link may operate to identify a corresponding resource either directly or indirectly. The link may be automatically or manually included in the body of an electronic message or blog.


According to an embodiment, a media file is electronically communicated by programmatically generating a link for an electronic communication, where the link identifies a media file that is stored on a given terminal of a user. Selection of the link at a remote terminal is detected, indicating that a recipient of the electronic communication has selected to view the media file. In response to the link in the message being selected from the remote terminal, streaming data from the media file to the recipient. An embodiment such as described may be performed from a user terminal or system, correspond to, for example, where the media file was recorded, created and/or stored.


According to another embodiment, in response to a media recording event by a user, a link is generated for a web posting. The link identifies a media file that is stored on a given terminal of the user, and the media file includes data from the media recording event. The link is provided at a web page, and selection of the link from a remote terminal is detected. In response to the selection, data from the media file is streamed to the recipient.


Still further, an embodiment provides a software system that is executable on a computing device. The system includes a component that is configured to interface with a messaging application that is usable on or from the computing device. Additionally, the component is configured to (i) identify a media file selected by a person composing a message; (ii) generate a link for a message, wherein the link identifies a stored media file for a message; and (iii) automatically include the link in the message.


Under one embodiment, when an electronic communication is sent (e.g. message or a web post), the identified media file is securely transferred to either the composer's home computer or to a specified server on a user defined network. Thus, for example, the media file may be moved on recording to a location in a user's domain where other recipients of the link can obtain remote access.


As an alternative or option, the media file, or its copy, may automatically be moved offsite from the user's domain, particularly on a selective basis. For example, in the case where a user's media link on a web page becomes popular, the media file may automatically be moved offsite to a storage location where access to that media file is more readily available to the public.


Still further, one embodiment provides that a messaging application may be combined or operated with a plug-in application to communicate with a system that generates and includes the link into the message.


An embodiment such as described may be performed programmatically, or as a computer-implemented method. Programmatically means through the execution of code, or computer-executable instructions.


As used herein, a plug-in corresponds to an application that operates in connection with another application. In general, a plug-in is a smaller version of the application that is operated with, and resides as an application-layer program.


One or more embodiments described herein may be implemented using modules. A module may include a program, a subroutine, a portion of a program, or a software component or a hardware component capable of performing one or more stated tasks or functions. As used herein, a module can exist on a hardware component independently of other modules, or a module can be a shared element or process of other modules, programs or machines.


Furthermore, one or more embodiments described herein may be implemented through the use of instructions that are executable by one or more processors. These instructions may be carried on a computer-readable medium. Machines shown in figures below provide examples of processing resources and computer-readable mediums on which instructions for implementing embodiments of the invention can be carried and/or executed. In particular, the numerous machines shown with embodiments of the invention include processor(s) and various forms of memory for holding data and instructions. Examples of computer-readable mediums include permanent memory storage devices, such as hard drives on personal computers or servers. Other examples of computer storage mediums include portable storage units, such as CD or DVD units, flash memory (such as carried on many cell phones and personal digital assistants (PDAs)), and magnetic memory. Computers, terminals, network enabled devices (e.g. mobile devices such as cell phones) are all examples of machines and devices that utilize processors, memory, and instructions stored on computer-readable mediums.


Overview



FIG. 1 describes a method or technique for programmatically generating a link to a media resource and enabling the link to be available to a user at a destination that is remote to the media resource, under an embodiment of the invention. A method such as described with FIG. 1 may be used to enable a person at a remote destination to access media stored on another person's system or network.


Alternatively, such a method may be used to enable the provider of the link to specify media stored remotely from the link provider's system or network. The media file may be stored locally on a user's defined network, device, or computer system, or may be stored remotely on a server. According to one or more embodiments, a user can specify a media file that is stored on (i) the user's personal computer or computing device, (ii) the user's home network (i.e. on an appliance or terminal on the home network), (iii) the user's satellite or location on a personal network, such as described with U.S. Pat. No. 8,819,140, and/or (iv) on an Internet account or third-party network location.


Step 110 provides that a media file is identified for link generation. The media file may be in the process of being created, newly created (e.g. user stops recording a video file), or existing. Such a step may be performed manually, as in the case of a user may selecting a media file from his personal library. Alternatively, an embodiment provides that the step is performed automatically, such as in response to the user initiating or completing a recording of a video clip. According to one or more embodiments, a user can specify a media file that is stored on (i) the user's personal computer or computing device, (ii) the user's home network (i.e. on an appliance or terminal on the home network), (iii) the user's satellite or location on a personal network, such as described with U.S. patent application Ser. No. 10/888,606, U.S. Pat. No. 8,819,140, and/or (iv) on an Internet account or third-party network location. The identification may be made at either the time when the media file is created (e.g. during a live digital recording), or anytime after the media file has been stored. The identified media file may be in the form of audio, video, or a combination thereof. The media file may be in any one of various formats such as .MP3, .WAV, .MPEG, .MOV, .AVI, etc. For example, the media file identified may be a .MOV file stored on the user's personal computer, or on a device (e.g. camera, memory card) attached to the user's computer. Alternatively, the identified media file may be a digital video file that is in the process of being recorded by a audio/video capturing device.


In step 120, a link is programmatically generated that can be used by software running at a remote destination to identify and locate the identified media file. The link may correspond to a selectable data structure that can cause a program or resource using the link to access a particular network location. The network location may correspond to a source where the media file identified by the link resides, or the location of another terminal or server that has access to the media file. Still further, as described with an embodiment, the link may be selected to cause the resource that uses the link to indirectly access the media resource through one or more computers that mediate communications between the terminal on which the link was selected and the computer(s) that provide the media from file located by the link.


In one implementation, the link may be a data structure that specifies an address of the identified media file, such as a uniform resource locator (URL) or a portion thereof. As an example, step 120 may generate a URL which identifies the selected media file regardless of whether the file is stored remotely or locally. The URL may be generated regardless of whether the media file is currently being recorded or has been stored for a period of time. As mentioned, step 120 may alternatively generate a partial URL, or another form of identifier. For example, the link may communicate a file that can be selected on one terminal, and replaced or combined with an address on another terminal or server. Likewise, another implementation may provide the link is a partial URL or address (or other form of an identifier), which is completed on a server or terminal that is remote to the terminal where the link is received and selected.


In step 130, the link generated in step 120 may be communicated using an electronic medium. Sub-steps 140 and 150 describe different communication mechanisms that may be used to transfer or make the link usable from a remote location. The link may be communicated either through (i) an electronic message such as email, text messages, instant messages and the like, (ii) be published on a web-page, message board, or blog, or (iii) a combination of both. The communication may be intended for the public at large or select individuals or terminals.


In one embodiment, the link may be included in the body of an email. The individual composing the email message may choose close friends or family to receive the email message containing the generated link. However, if the link was generated for use on a web-page, blog, or message board, the individual composing the message may have no control over who views the posting and selects the link. Still further, the user may operate a server type software on a terminal from which the media file is provided. An example of such software is available at www.orb.com. Such software (or other similar applications) may cause selective distribution of the generated link (e.g. to those that the content provider selects), or the software may restrict who has access to the identified media file by checking to ensure the terminal/person making the link selection is authorized.


In sub-step 140, the link may be communicated to one or more remote destination by message delivery. The electronic message may be in the form of an email, short message service (SMS) or multimedia messaging service (MMS). According to an embodiment, once the media file has been identified, and the link generated, the link may be automatically included into the body of the electronic message. In one embodiment, plug-in for a messaging application may be used to automatically incorporate the link into the body of the electronic message. The plug-in may automatically include the link in the message at the time the link is generated or when the message is sent by the messaging application (e.g. the individual clicks “send”). Thus, the link may be automatically created with media file identification (step 110) and then included in the body of the email as one step, at least to the perspective of the user. Alternatively, the link may be manually placed in the body of the message by the individual composing the message. According to an embodiment, the link may be included, either automatically or manually, in the electronic message regardless of the type of messaging application or service being used (e.g. client-based email application, Internet email, Instant Messaging applications, SMS or MMS messages).


In an embodiment, when the link has been included in the message, the messaging application may then transmit the message containing the link to an intended recipient. In one implementation, the message is an email, and the user may provide a subject line and/or additional text. The user may perform a transmission action (e.g. click the send button) once the link is inserted, although alternative implementations may provide that the transmission action is automatically performed after the media file that is to be transmitted is identified.


On the receiving end, the message and link may be received by any web enabled device, including cell phones, personal digital assistants (PDA's), and personal computers. As described below, subsequent media delivery may be configured on-the-fly, from either a point of transmission of the media, or from an intermediary web service, to format the media for the receiving device. Thus, the link may be selectable regardless of the device on which the message is received. Once the link is communicated by the user, and the recipient selects the link through an application (such as a messaging application or web browser), portions of the media file that correspond to the link are transmitted (e.g. streamed) to the target device. The media may be configured to accommodate the target device, taking into account factors that include one or more of the following: (i) the platform that the target device uses, (ii) the application that is to render the media file, and the data format that the application can handle, (iii) hardware limitations or characteristics of the receiving device, including screen size and processing capabilities, and (iv) bandwidth available for the receiving device to receive media. The configurations required may be determined programmatically and automatically, just prior to the data from the media file being communicated to the receiving device.


As an alternative or addition to sub-step 140, sub-step 150 provides that the link is communicated by publishing the link on a web-page or web-site accessible by a web-browser. According to an embodiment, the link may be posted on a personal web-page, web log (blog), electronic message board, discussion board or other online forum. In an embodiment, an individual may create an entry for an online forum by selecting, identifying, or creating a media file to be included on the forum. According to an embodiment, the link may be automatically included when the media file has been identified/created by the user, or the link may be automatically included when the blog or web-page has been posted or published. The link may be included on the web-page or blog independent of the application used to create or publish the web-site, and regardless of the service hosting the blog site (e.g. www.myspace.com).


Various applications for embodiments described above are possible. In one scenario, a user creates a media file using a Universal Serial Bus (USB) video recorder that is connected to a terminal. The recording may be made as part of a messaging application. Thus, the user may interact with an interface created by, for example, a plug-in to a messaging application. When making the media file, the user may have a message in a state of composition, or alternatively a message selected for reply or forwarding action. Once the media file is created, the media file is stored on a user terminal, and a link to the file is automatically created. This link is then inserted into the message body of the email under composition. Alternatively, a new email may be created automatically, and the link is inserted into the body of the email (automatically or otherwise). The user can then perform a send action, or the send action may be performed immediately and automatically after the media file recording is complete.


In another scenario, the user may have a video clip in a media library on a terminal. The user may interface with a web publishing application or plug-in, which creates a link and publishes the link on a web page that is identified by the user.


Still further, the user may operate a cell phone or other roaming device and create a video clip from the phone's camera. The user may message (e.g. SMS or MMS) the clip to another phone or terminal. In one implementation, the clip on the phone may be transferred to an associated computer or account of the user, and the generated link may locate the clip on the associated computer or account.


As an alternative implementation, the link may be generated at a different location from where the media file is selected or created. For example, in the cell phone case described above, the user may send a video clip as an MMS message to a service, and the service then captures the video clip and forwards to one or more intended recipients a link to the video clip. The service may host the video clip. For example, the service may provide offsite broadband access to the video clip if the user's terminal has limited bandwidth, or if the video clip becomes popular.


Various alternatives, variations and/or combinations to embodiments and implementations described above are contemplated.


Link Generation and Media Delivery



FIG. 2 is a block diagram of a system for programmatically generating a link to be automatically included in an electronic message. When the link is selected on a web-enabled target device, media data that is associated with the link may be streamed to the target device. A system such as described with FIG. 2 may be used to implement one or more embodiments, such as described with FIG. 1. A system of FIG. 2 reflects use of various processes that combine to perform stated tasks. Each of the processes may be implemented through modules, using one or more computers and at one or more logical or physical locations. Furthermore, the combination of processes may be performed together at one time, or over a duration. Additionally, the processes can be performed independent of one another, or dependently off of each other as part of a larger process flow.


Embodiments such as described with FIG. 2 provide a way in which a link, corresponding to an identified media file, may be automatically included in an electronic message. The electronic message, including the link, may then be transmitted to a receiving party. When the message is received, the receiving party may select the link that corresponds to the identified media source. Selection of the link causes portions of the identified media file to be transmitted to the target device. In an embodiment, the media file is not transferred and stored on the target device, only portions of the media file are transferred to the target device (e.g. streamed). Various aspects of the transmission may undergo configurations for optimal transmission and/or reception on the receiving device, including transfer rate and configurations to accommodate the resources of the receiving device. For example, the rate of transfer may depend on the speed at which the target device is able connect to the Internet or the rate at which data may be transferred and played back on the target device.


According to an embodiment, media may be generated or created using a device that enables video/media capture 210. The result of the capture process 210 is the creation of a media file 255. Examples of such devices include a video camera, digital video or media recorder, webcam, cell phone or PDA with video recording capabilities, or any other device on which media may be recorded and/or stored. According to an embodiment, the recorded media file may be in various types of formats. The media file may be stored at anytime during the recording process. Video/Media capture 210 may also enable an individual to select pre-recorded media files or other types of media files from third party sources (e.g. movie clip) that have been stored on a personal computer, server, or other storage medium.


In one embodiment, captured media is stored as the media file 255 in a storage medium 265 for subsequent use. The storage medium 265 may be permanent (e.g. on a hard drive in a media library) or temporary (e.g. in cache on a temporary folder). Still further, the storage may be local, on a user's personal or home network, or on a server that provides services in connection with embodiments described herein. In some cases, multiple storage locations may be preferred. For example, a storage server may be provided as part of a service to host a media file if the terminal is programmatically (or through user-selection) deemed inadequate to host requests for the media file. In the example, both the server and the user's home terminal may store the media file.


In an embodiment, message create 220 enables an individual to create an electronic message and generate a link 270 to include in the outgoing message 290. The link 270 in the outgoing message 290 identifies the media file 255 created or selected from video/media capture 210 by location or otherwise. In one embodiment, the link 270 identifies an address or path to the media file 255 in the storage medium 265. Message create 220 may allow any form of electronic messaging such as an email, text, message, or instant message. Message create 220 may use any number of third party messaging applications, such as, for example, Outlook or Outlook Express by MICROSOFT, Eudora by QUALCOMM, and other web-based electronic messaging applications including Gmail, Hotmail, Yahoo Mail, instant messenger, windows messenger or AIM. According to an embodiment, message create 220 may use a plug-in for the third party messaging application.


According to an embodiment, the plug-in performs some or all of the following: (i) open the third party messaging application if it is not in use at the time the message is being composed, (ii) provide an interface where a media file may be selected or generated, (iii) generate the link corresponding to the identified media file, and (iv) automatically include the link in the message. In one implementation, the message create 220 also causes the message to be sent or transmitted automatically upon completion of the media recording.


Message create 220 receives file ID 250 that corresponds to the media file 255 generated or identified by video/media capture 210. According to an embodiment, file ID 250 may be generated by the plug-in to the messaging application. Alternatively, file ID 250 may be the file name the media file 255 was given as it was created and stored. For example, an individual creating the media file 255 may have named the file “mymovie.” In such a case, the file ID 250 would be “mymovie”. The file ID 250 may also show the path of directories where the media file has been stored (e.g. D:\Media Files\mymovie). In an embodiment, file ID 250 may be used to complete the URL (or partial URL) or link 270 generated by a plug-in or link generator. Continuing with the example, a partial URL (step 120, FIG. 1) may have been generated. The file ID 250 associated with the selected media file (mymovie) may be used in the partial URL to create a complete URL or link. File ID 250 may identify the media file 255 in any stage of composition, including media files currently being generated, or a media file that has previously been created and stored by the user.


In one embodiment, the plug-in for an independent or third party messaging application may be used to communicate with a media delivery system. Selection of the plug-in may enable an individual to record a video message for an outgoing text message or email. When the recorded media file 255 has been created, the generated link may be placed in the body of the message. The recorded media file may then be transferred to a personal computer, server, or other storage device (in or outside of the user's domain) where it may be accessed through use of the link 270.


When message create 220 has been completed (e.g. the email or text message has been completed by an individual) the link 270 may be generated and included as part of an outgoing message 290. As mentioned with other embodiments, the message may be an email, instant message, SMS or MMS message or other form of asynchronous communication between two locations. The link 270 may be generated by either the plug-in or by an independent application (“link generator”). The resulting link 270 may then be transmitted to messaging process 230, which sends the outgoing message 290. According to an embodiment, link 270 identifies the media file 255 by location and/or by name. The identification may be made directly or indirectly (such as through an intermediary or trusted proxy web service).


Performance of messaging process 230 may result in the electronic message, in whatever form it may take (e.g. email, SMS) being transmitted to the designated recipient(s). The message 290 may include the link 270, a portion of the link 270, or a data structure corresponding to link 270. The message may be communicated to accounts (email), devices, terminals and/or other destinations.


A media delivery process 240 may execute at a later time to deliver media data 260 from the media file 255 to the terminal that received the message 290. The media delivery may be responsive to a link selection action 280. According to an embodiment, a link selection action 280 is an action preformed by the recipient of the message. In this respect, the action 280 may be remote from the media delivery process 240 (i.e. on the receiving terminal), but communicated in the form of a request or other communication across a network to the location(s) where the media delivery process is performed. In one embodiment, link selection action 280 occurs when a recipient of the message selects the generated link 270 included in the body of the received message. Once the link 270 has been selected, media delivery process 240 accesses the media file 255 from the storage medium 265. Media delivery process 240 may then transmit data from the media file 255 to the target device where the link selection action 280 occurred. For example, the link 270 may be selected on a web-enabled target device, media delivery may then use link 270 to identify and locate the media file 255 on the storage medium 265. Upon identification of the media file 255, the media data 260 is streamed or otherwise transmitted to the target device by the media delivery process 240.


According to an embodiment, the identified media file 255 associated with the link is not transferred and stored on the target device. The media file 255 remains where it was originally stored and the media data is streamed to the destination. In one embodiment, the media delivery process 240 is provided by a client side server application that executes on a system of the user creating the message. An example of such an application is provided is provided as a download at www.orb.com. According to one or more embodiment, media delivery process 240 creates a media output 295 that is based on the media data 260. As described below, various functions may be performed by the media delivery process 240 on the media data 260 to generate the media output 295. The resulting media output 295 accounts for capabilities and resources available to the destination, including, for example, (i) the type of media player or browser in use at the device where the link selection action 280 was performed, (ii) the platform used by that device, (iii) the type of device (or device hardware capabilities) where the selection action 280 originated, and (iv) the available bandwidth for making the transmission. U.S. patent application Ser. No. 11/531,182, U.S. Pat. No. 8,787,164, entitled MEDIA DELIVERY SYSTEM AND METHOD FOR TRANSPORTING MEDIA TO A DESIRED TARGET, filed Sep. 12, 2006, (which is hereby incorporated in its entirety) provides description of a system that can execute to provide the media delivery process 240 may be executed to accommodate various resources and capabilities of the destination. Examples of accommodations that can be made by the media delivery process 240 for include (i) reducing stream size of media output 295 to accommodate bandwidth or processing resources, (ii) sizing image data as part of media output 295 to accommodate a display size on the receiving device, and (iii) formatting or reformatting the media output 295 to accommodate the media player, browser and/or platform on the destination device or site. To this end, the media delivery process 240 may perform functions that include (i) detecting or identifying pertinent capabilities and resources of the destination device, including one or more of network bandwidth, device type, platform, browser type, media player type and determining display size; (ii) reformatting media data 260 from a native format to a format that can be handled on the receiving device; (iii) resizing image data in media data 260; and/or (iv) reducing the transmission size (e.g. bit rate) of the media data 260 from its original size.


Still further, an embodiment provides that the media delivery process determines or otherwise identifies whether the terminal of the recipient includes a Digital Rights Management (DRM) engine. The determination of the DRM engine may influence or affect whether the media delivery takes place. Alternatively, the presence or type of DRM engine may affect the file format used and/or quality of the media that is delivered.


As described with an embodiment of FIG. 3, the video capture process 210 may be optional, in that a user may select any media file for delivery in the manner stated.



FIG. 3 describes a method or technique for identifying and electronically transmitting a media file, according to one or more embodiments of the invention. A method such as described may be performed using a system such as described with FIG. 2.


In step 310, a media file is identified. According to an embodiment, the media file may be identified by an individual selecting a particular media file. Selection may consist of an individual selecting a prerecorded or stored media file. The media file may be stored remotely on a server or other storage device, or the media file may be stored locally on a personal computer. For example, an individual may use an application (e.g. windows explorer) to browse or search stored media files on the individual's personal computer. Alternatively, a similar application and link generation process may be used to browse or search for media files stored remotely on a server or other storage medium. Still further, the user may browse or select from a personal network, such as described in U.S. patent application Ser. No. 10/888,606, U.S. Pat. No. 8,819,140, entitled “System and Method for Enabling the Establishment of a Personal Network,” filed Jul. 9, 2000 (hereby incorporated by reference). A personal network may provide a shared or combined memory covering memory locations at various network locations, from which the user may select a particular media file.


As an alternative, a media file may be identified through recordation. Recordation may consist of an individual recording a media file specifically for an electronic message (e.g. email or text message) currently being composed by the individual. For example, the individual composing the electronic message may, through the use of a webcam or other media recordation device, record a media file for the specific purpose of including it in the message. In such a scenario, the identification may be automatic and instant upon the user completing the recording.


Step 320 provides that a link is generated for an outgoing message. According to an embodiment, the link may be programmatically generated when the media file is identified. As explained with an embodiment of FIG. 2, the link may include a file ID 250 that corresponds to the media file identified in step 310. Alternatively, a link may be generated independent of the file ID 250 but still be associated with the identified media file.


Step 320 may also generate a link corresponding to an identified media file for use in a third party application or internet site. For example, the link may be generated and included on a web-page, blog posting, or other web-based application. The link may also be included in a word document application, web publishing application or service, or spreadsheet application. A plug-in to various third party software applications may be used to select or record a media file and generate a link for inclusion in the document. For example, if an individual was using MICROSOFT Outlook, for composing a message, a plug-in may be used to select/record a media file and generate the link that will be included in the message. A message may be an electronic message or a posting on a blog, web-page or message board.


Step 330 provides that the generated link is incorporated into a message. According to an embodiment, the link may be automatically or manually included in the body of a message. This step may be preformed programmatically, automatically or manually. For example, if the messaging application is open and running on a device the link may be placed in the body of the message. Alternatively, an individual may interact with a user interface of a link generator as will be described below. In cases where a plug-in is used, the plug-in may open a messaging application, create a link, and include the link in the body of the message. In the case of a web-page publication or blog posting, the link may be incorporated into the text of the blog or web-page. As with a messaging application, a plug-in may also be used to identify a media file and generate the corresponding link.


According to an embodiment, the link may be included in the electronic message when the message is sent by the individual composing the message. For example, if a media file has been identified and the link has been generated, the link may not be included in the message until the individual chooses to send the message by clicking “send” in the messaging application. In the case of web-pages, blogs, word documents and so forth, the link may not be incorporated into the text of the blog or document until the page has been posted, saved, or published. In an alternative embodiment, the link may be incorporated into the message, document, or web-posting immediately after the link has been generated in step 320.


In step 340, portions of the identified media file are delivered for rending to a target device. According to an embodiment, the message containing the link may be sent to designated recipients. When a recipient of the message selects the link contained in the message, media data is transferred to the device. According to an embodiment, the media file is not transferred to the device, but the media data is streamed to the target device.


In an embodiment, when the media file is streamed to the target device, the media file may be formatted, so as to enable it to be displayed according to the target device's playback capabilities (e.g. screen size, resolution etc.) The media data may also be formatted to a type that is compatible with the media player on the target device.


For example, if the link identified a media file that was in a .MOV format and the recipient of the message receives the message on a web-enabled PDA with Windows Media Player (.WMV format), the media data being transferred/streamed to the PDA will be converted from .MOV format to .WMV format. In addition, the media file will be formatted so to fit the smaller display size and resolution of the PDA. U.S. patent application Ser. No. 11/531,182, U.S. Pat. No. 8,787,164, entitled MEDIA DELIVERY SYSTEM AND METHOD FOR TRANSPORTING MEDIA TO DESIRED TARGET DEVICES, filed Sep. 12, 2006, which is incorporated by reference in this application, provides various descriptions on detecting capabilities of the receiving device and optimizing media delivery to the receiving device. The following paragraphs provide additional description of media delivery operations to make the media data transmission optimized, enabled or more conducive for use on the target device (the device that performs a selection operation on the link).


Data Reduction: If the media data being streamed to the target device has an inherently large transmission size, data reduction processes may be performed on the media data. The transmission size may correspond to a bit rate for the transmission. The bit rate is a function of a frame rate and picture quality. The bit rate is normally determined by the media source, which uses a high bit rate to improve picture quality and/or frame rate. The data reduction parameters may be set as one of preference or necessity. For example, in order to free network bandwidth, the user may have a preference as to lower transmission size. Additionally, the network bandwidth a device may need may be determined independent of the device's capabilities. Rather, the available bandwidth may be a function of the bandwidth on the communication channel to the device. In one embodiment, this profile information is determined programmatically, by sending a test message or communication to a specific target and measuring a response time. For example, an image or media clip may be transmitted periodically to the end target device from a component on the user's network system, and the component may measure the time it takes for a programmatic response or receipt to that message to be received back from the target. Based on response time, the profile information indicating bandwidth and/or data reduction parameters may be set.


Formatting: A determination may be made based on the target device's profile information to determine information about the data type of media that can be handled by the target device. For example, a profile for a target device may identify the type of media player (e.g. Windows Media Player) on the target device. The media data transmitted may not compatible with the media player on the target device. In such a case, formatting may be used to convert the transmitted media data into a format compatible with the media player on the target device. Implementation of the formatting process may correspond to identification of a specific process that converts the media data from its native format to another format suitable for consumption by the target device. For example, a process may be called to convert the media data from MOV to WMV.


Image Sizing: The media data may be inspected to determine whether image data is contained in the media data. If the media data has image data, profile information about the target device may be used to determine if any size constraints exist for the target device that is to receive the media data. For example, cellular phones have size limitations in their dimension and screen resolution. A determination may be made that the size of the image data portion of the media data needs to be resized in order to make the video or images of the media data compatible with the display hardware of the target device. In addition to size limitations, some target devices may have alternative size capabilities. For example, the device may have an elongated display and alternative display mode operations where the device may be operated in a landscape mode. The image data may resized to accommodate the landscape setting by extrapolating or stretching image data.


Link Generation and Media Delivery System



FIG. 4 illustrates a system architecture for generating and using links, under one or more embodiments of the invention. According to an embodiment, system 400 may generate a link corresponding to an identified media file and then enable communication of that link through an electronic medium. System 400 includes a media library 405 that stores generated media 410 and/or media files stored in a database library 415. The system 400 also includes a link generator 430 and a media delivery sub-system 455. As described with one or more other embodiments, a user of system 400 may create a media file 411 that contains data corresponding to media recordings. In particular, an embodiment provides that the user can make available personal media recordings (e.g. recording video clip or video message) in the media file 411, although numerous other forms of media (whether generated, recorded, or stored) may be used with embodiments described herein.


In an embodiment, the media library 405 may include an interface 425 to various sources of media, so as to enable a user to browse or select a media file from the media library 405. The media library 405 may contain a generated media 410 directory to store media. Generated media 410 may also store media transferred from devices capable of recording and storing media (e.g. video camera) within or as part of media file 411. Media library 405 may also contain library 415. Library 415 may be a database of media files stored in media library 405, including media files generated from third party sources. For example, library 415 may have media files downloaded from the internet (e.g. movie clips, mp3s, or television shows), or media files uploaded from a source other than a video recording device. Media library 405 may be stored locally on a personal computer or other storage device that is at the location where the user resides. Still further, one or more alternative embodiments or implementations provide that the media library 405 is stored remotely on a server, accessible through a user defined network, or on an interconnected terminal or peer. As another alternative or addition, in another embodiment, the media library 405 provides a combined memory and corresponding view, as described with U.S. patent application Ser. No. 10/888,606, U.S. Pat. No. 8,819,140, entitled “System and Method for Enabling the Establishment of a Personal Network.”


In an embodiment, interface 425 enables an individual to select a media file from media library 405. The interface 425 may enable an individual to either browse or search media library 405. Alternatively, the interface 425 may be provided by an independent application, such as a file manager of an operating system. For purpose of embodiments described below, the media file 411 is assumed selected, corresponding to media recorded (or in process of being recorded) from user action. For example, media file 411 may include data recording a live event in the presence of the user (e.g. the user pointing the video recorder to himself, or recording another event in his or her presence)


As described elsewhere, one or more embodiments provide that the link generator 430 may be operable to generate a link 450 corresponding to media file 411 on its creation. Link generator 430 may identify the network address of a computer or other device storing the identified media file 411, and use that address as a portion of the URL. Link generator 430 may also use part of the file name of the selected media file 411 to generate the link 450. Once generated, the link 450 can either by itself, or in combination with other data, locate the media file 411 from the media library 405.


In one implementation, link generator 430 may include a user-interface 435 to enable a user to select the media file 411 from other possible files in the library. The selection may result in the link 450 being programmatically generated. For example, the user may browse the media library 405 and select media file 411, then select a feature provided by the user-interface 435 (i.e. an icon) to cause the link generator 430 to be invoked. The link generator 430 may then automatically generate the link for the media file 411.


As an alternative or addition to the user-interface 435, the link generator 430 may be operable through execution of related programs. In one embodiment, a plug-in 445 for a messaging application 440 may invoke the link generator 430 when the plug-in is operated with the messaging application. Alternatively, the messaging application 440 may be configured to generate the link 450.


According to an embodiment, plug-in 445 may link the messaging application 440 to the link generator 430 and other components to enable programmatic link generation and link inclusion in outgoing messages (which may be e-mail, SMS, MMS or other transport). One implementation provides that plug-in 445 includes user-interface 435, so as to enable a user to select the media file 411 when the messaging application 440 has started. Plug-in 435 may also automatically include the link 450 into the body of the message being generated by messaging application 440. In another embodiment, plug-in 445 may open the messaging application if the application is closed, generate the link to be included in the message, and automatically include the link in the body of the outgoing message. In still another embodiment, plug-in 445 may enable an individual to generate media for the messaging application. For example, plug-in 445 may allow a user to access recordation device (e.g. webcam), connected to the system 400, and record a video message for a specific email currently being composed using messaging application 440. Once the media file has been generated, link generator 430 may generate link 450 and transmit it to plug-in 445. Plug-in 445 includes link 450 in the email message. Plug-in 445 may also allow an individual to manually include the link in the composed message. The recording may be stored in media file 411, and the link may identify the media file 411 to the recipient of the message.


As another alternative or addition, the link generator 430 may be invoked or otherwise used by a web publishing application 448, or by a plug-in (not shown) for the web publishing application 448. Usage from such an application may cause the resulting link 450 to be published on a blog or other web page. Web publishing application 448 may correspond to any web-page development program (e.g. Dreamweaver, Frontpage GoLive). Web publishing application 448 may alternatively be a third party service that hosts web-pages, blog sites (e.g. www.myspace.com), or other on-line mediums where media may be shared (e.g. www.youtube.com). In each of the above, link 450 may be included on the page, enabling a viewer of the page to select the link 450 and have the media streamed to the target device.


As an alternative or addition, the link generator 430 may generate the link 450 for web based electronic messages or posts. For example, the messaging application 440 may be a web-based email (e.g. such as GMAIL). The link generator 430, or a separate interface, may enable the link generator 430 to insert the link 450 to media file 411 in a web-based email or messaging application. Still further, the user may be able to upload the link 450 through a convention upload functionality provided on web pages. The link generator 430 may print the link 430 for the user to copy and paste into a post, or provide functionality to automate the insertion of the link into a web post. Thus, the link 450 may be communicated to, for example, a web page 424 hosted at a website 422 (e.g. user's personal blog) through either a client side application or through direct interface with the website or webpage.


As described with other embodiments, a media delivery process 455 is used once link 450 provided by the link generator 430 is selected from a remote terminal 465, where the remote terminal is operated by a recipient of the electronic communication. In the case where the electronic communication is in form of a message, the recipient may be the recipient of the message. In the case where the communication is a web page, the recipient may correspond to an individual with invitation or right of access to web page 424, or alternatively, to persons of the public. The act of selection by the recipient may correspond to the recipient selecting the link, or a representation of it, using a browser, media player, messaging program or other application. The selection action may be, for example, a “mouse-click” or equivalent (voice command, touch command, hover and focus etc.).


In response to receiving a communication corresponding to a link selection action 470, the media delivery system 455 transmits portions of the media file 411 (as identified by the particular link) to the target remote terminal 465 on which link 450 was selected. As described with, for example, an embodiment of FIG. 3, the media delivery system 455 may configure the delivered media 460 to accommodate capabilities and resources of the device 465.


By selection of link 450, remote terminal 465 may alternatively send the request 475 to a service 480 which has access to a user defined network (and to media file 411) and is able to communicate with the target remote terminal 465. The service 480 may then provide the media delivery 460 for the particular device. Such a delivery system is described in more detail in U.S. patent application Ser. No. 11/531,182, U.S. Pat. No. 8,787,164, which is incorporated by reference herein.


Regardless of whether link 450 enables remote terminal 465 to directly access the media file 411, or indirectly access media file 411 through service 480 or other intermediary, an embodiment provides that the media delivery system 465 configures the media delivery 460 for the various capabilities and characteristics of the remote terminal 465. As described elsewhere, these include configuring the media delivery 460 for the platform, media player, browser, device capabilities or type, DRM engine or other characteristics of the remote terminal 465.


According to an embodiment, system 400 may allow an individual to compose media file 411 (or its media) for a message or web-page. Media file 411 provides media file data 413 for media delivery 460 to the remote terminal 465 of the recipient. In one implementation, the media file 411 provides the data for a video message that is to be transmitted in an email. The media file 411 may also provide the data for a video message that is posted on web page 424 (e.g. which could be a blog site). In another implementation, media file 411 may be recorded or generated from any device capable of recording media files. For example, the media file 411 may include a recording made from a video camera, webcam, or a cell phone or PDA with media recording capabilities. Still further, the, media file 411 may be a pre-existing file, stored in media library 405 prior to the user forming an intent to generate link 450. Alternatively, the media file 411 may be stored on the recording device (e.g. cell phone or video camera) and transferred to media library 405 at a later time. For example, if an individual records a video message using a video camera, the video message may be stored on the video camera and then transferred to media library 405 once the recording is complete. If however, the individual recording the message used a device that has access to the media library 405, the message may be stored in media library 405 while the recording is made.


Web Media Publishing Features


As described above, system 400 enables a user to provide personalized web publishing of personal media, including of media recorded by the user or in the user's library. As also mentioned with an embodiment, user may publish media content from media file 411 by posting link 411 to the desired web location, such as on web page 424. In one embodiment, the media file 411 may be packaged or included with an embedded media player or “gadget” that is displayed or otherwise provided as an object or feature of the page 424 when the page is downloaded by users. Selection of the object or feature on remote terminal 465 causes the embedded media player to use the link to access the media file, and then to stream the media file to remote terminal 465. In one implementation, for example, the media player may be provided by a FLASH component.


As described with other embodiments, the link 450 may provide an indirect link to the media file 411. Thus, for example, in the case of the link being provided on web page 424, selection of the link may cause a browser of the remote terminal device 465 to send request 475 to the service 480. Service 480 may be provided, for example, in form of one or more servers that have their own domain (e.g. Internet site address). Furthermore, in one implementation, the service 480 has a separate and constant connection with one or more terminals of the system 400. Service 480 may identify, for example, the user terminal and media file 411 from the request. According to one or more embodiments, the service 480 may then either (i) retrieve media data 413 from the media file 411 that resides on the user system 400 (or terminal), and then stream or otherwise provide the media delivery 460 from the media data 413; or (ii) enable establishment of direct link between the user terminal and the remote terminal 465 of the recipient so that the user system or terminal provides the media delivery 460 (by streaming or otherwise).


As an alternative or addition, one or more embodiments provide for use of offsite storage 490 in connection with embodiments described. In particular with web publishing, embodiments recognize the potential that a user's media publishing may incur heavy traffic and numerous requests, and in such cases, the performance of the user's terminal to respond or even operate may be compromised. Accordingly, one or more embodiments contemplate that the media file 411 is transferred from the system 400 to the offsite storage 490. In one implementation, the offsite storage 490 may be part of service 480, and have particular use when media file 411 is used for web publishing. In such cases, the link 450 may identify the media file 411 independent of its location at either the system 400 or the storage 490. The request from remote terminal 465 may be directed to service 480, which then identifies the media file 411, and determines its location on the offsite storage 490. The service 480 may then retrieve the media data 413 from the media file 411 stored on the storage 490, rather than from the system 400. The service 480 may also perform the media delivery, by, for example, streaming the media delivery 460 to the remote terminal 465 using the media data 413.


In one embodiment, service 480 may use intelligence or code to determine automatically when the media file 411 should be moved from the system 400 to the offsite storage 490. For example, the service 480 may count the number of requests 475 for the particular media file, and when the count exceeds some criteria or threshold, the media file 411 may be copied and moved automatically. Subsequent requests 475 from other remote terminals 465 results in service 480 doing the retrieval from the offsite storage 490.


As another alternative or addition, embodiments recognize that some forms of remote terminal 465 (e.g. small form factor devices such as cell phones) may not be able to use embedded media players. An embodiment provides a tool or mechanism to automatically generate a bare or coded (but otherwise redundant) link on page 424 for directing a media player or web browser of such a device to use a local media player to access the media file 411, or alternatively, to retrieve the media player 411 needed for the playback.


Link Inclusion in and Selection from an Electronic Message



FIG. 5A illustrates a link that has been included in an electronic message according to an embodiment of the invention. As explained, an individual may use a third party messaging application 500 to compose a message 502. The individual composing the message may select or generate a media file to be included in the message. According to an embodiment, once the media file has been selected or generated, a link 504 is included in the body of the message 502. Once the link has been generated and included in the message, the individual may add or delete text in the message or send the message to the designated recipient(s).



FIG. 5B illustrates opening a media player when the link 504 is selected by a recipient of the message. According to an embodiment, once link 504 has been selected by the recipient of the message, a media player, pre-installed on the target device, is automatically launched if the media player is not already running on the target device.



FIG. 5C shows a media file 508 being streamed to a media player on a target device. When a recipient of the message selects the link 504, the media file that was selected or generated by the composer of the message is streamed to the media player of the target device. In the example shown, the video media of the person's face is represented by the cartoon depiction of the smiley face. As explained above, if necessary, the media file being streamed to the target device is formatted to be compatible with the media player on the target device.



FIG. 6 illustrates a selectable link being posted on a web log. According to an embodiment, a link may be automatically generated to be included on a web-page or web log (blog) site 600. In such a case, an individual may create or select a media file specifically for a particular blog posting 604. Once the media file has been selected or generated, a selectable link 602 enabling an individual to access the media file is generated and included on the blog posting 604. For example, an individual may create a profile for a blog site (e.g. myspace page) and create a media file (e.g. video message or greeting) specifically for that profile. Once the media file has been generated or selected, a link identifying that media file is included on the page. Selection of the link will stream the media file to the device on which the link was selected.


Conclusion


Although illustrative embodiments of the invention have been described in detail herein with reference to the accompanying drawings, it is to be understood that the invention is not limited to those precise embodiments. As such, many modifications and variations will be apparent to practitioners skilled in this art. Accordingly, it is intended that the scope of the invention be defined by the following claims and their equivalents. Furthermore, it is contemplated that a particular feature described either individually or as part of an embodiment can be combined with other individually described features, or parts of other embodiments, even if the other features and embodiments make no mentioned of the particular feature. Thus, the absence of describing combinations should not preclude the inventor from claiming rights to such combinations.

Claims
  • 1. A method for electronically communicating a media file, the method comprising: interconnecting a plurality of devices of a user to form a personal network, each of the plurality of devices being interconnected to one or more other devices of the personal network across one or more networks;generating a link for an electronic communication that is composed or communicated from a given terminal of the personal network, wherein the link identifies a media file that is stored on a resource of the user's personal network that is remote to the given terminal;detecting selection of the link from a remote terminal that is a recipient of the electronic communication;upon detecting selection of the link from the remote terminal, detecting, one or more capabilities of the remote terminal to receive streaming media from the given terminal, thenin response to selection of from the remote terminal, streaming data of the media file to the recipient, wherein streaming said data includes configuring transmission of the data to accommodate the detected one or more capabilities, including to accommodate a network bandwidth of the remote terminal to receive the streaming media file.
  • 2. The method of claim 1, wherein generating the link is performed automatically after either (i) the media file identified by the link is recorded by the user, or (ii) recording of the media file identified by the link is initiated.
  • 3. The method of claim 1, wherein detecting selection of the link from a remote terminal includes receiving a communication from an intermediate server or service that indicates the link was selected on the remote terminal.
  • 4. The method of claim 3, wherein generating a link for an electronic communication includes generating a Uniform Resource Locator (URL) or partial URL.
  • 5. The method of claim 1, wherein generating a link for an electronic communication includes generating a link for a message or a web posting.
  • 6. The method of claim 1, wherein generating a link for an electronic communication includes generating a link for one of a Short Message Service (SMS), Multimedia Message service (MMS), or Instant Message (IM).
  • 7. The method of claim 1, further comprising recording the media file to reflect a live event in presence of the user, and generating the link programmatically for the electronic communication in response to the completing or initiating recording of the live event.
  • 8. The method of claim 1, wherein the media file resides on a second device on the personal network that is different than the given terminal.
  • 9. The method of claim 1, wherein configuring transmission of the data to accommodate the detected one or more capabilities includes formatting the data for streaming based on one or more of (i) a type of platform used on the remote terminal, (ii) a type of browser or media player used on the remote terminal, or (iii) a display size of the remote terminal.
  • 10. The method of claim 1, wherein generating a link for an electronic communication includes generating the link for insertion into a web page.
  • 11. The method of claim 10, wherein generating the link includes embedding a media player with the link on the web page.
  • 12. The method of claim 11, further comprising generating a second link that is not included with the media player, and provided for devices that are not equipped for using embedded media players.
  • 13. The method of claim 1, further comprising enabling the link to be generated for any given media file stored on any of the plurality of devices that form the personal network.
  • 14. The method of claim 1, wherein streaming data of the media file to the recipient is performed from the given terminal on which the communication is composed or communicated.
RELATED APPLICATIONS

This application claims benefit of priority to Provisional U.S. Patent Application No. 60/862,206, filed Oct. 19, 2006, entitled “Media Delivery System and Method for Transporting Media to Desired Target Devices”; the aforementioned priority application being hereby incorporated by reference in its entirety and for all purposes.

US Referenced Citations (240)
Number Name Date Kind
5034807 Von Kohorn Jul 1991 A
5132992 Yurt et al. Jul 1992 A
5253275 Yurt et al. Oct 1993 A
5550863 Yurt et al. Aug 1996 A
5661516 Carles Aug 1997 A
5719786 Nelson et al. Feb 1998 A
5774170 Hite et al. Jun 1998 A
5831664 Wharton et al. Nov 1998 A
5966653 Joensuu et al. Oct 1999 A
6002720 Yurt et al. Dec 1999 A
6101534 Rothschild Aug 2000 A
6144702 Yurt et al. Nov 2000 A
6157621 Brown et al. Dec 2000 A
6161133 Kikinis Dec 2000 A
6209132 Harrison et al. Mar 2001 B1
6212282 Mershon Apr 2001 B1
6263503 Margulis Jul 2001 B1
6263505 Walker et al. Jul 2001 B1
6310886 Barton Oct 2001 B1
6312336 Handelman et al. Nov 2001 B1
6327608 Dillingham Dec 2001 B1
6349410 Lortz Feb 2002 B1
6424998 Hunter Jul 2002 B2
6430603 Hunter Aug 2002 B2
6430605 Hunter Aug 2002 B2
6437836 Huang et al. Aug 2002 B1
6466203 Van Ee Oct 2002 B2
6466971 Humpleman et al. Oct 2002 B1
6470378 Tracton et al. Oct 2002 B1
6477589 Suzuki et al. Nov 2002 B1
6496122 Sampsell Dec 2002 B2
6545722 Schultheiss et al. Apr 2003 B1
6567984 Allport May 2003 B1
6605038 Teller et al. Aug 2003 B1
6611863 Banginwar Aug 2003 B1
6629163 Balassanian Sep 2003 B1
6670974 McKnight et al. Dec 2003 B1
6718551 Swix et al. Apr 2004 B1
6742022 King et al. May 2004 B1
6754904 Cooper et al. Jun 2004 B1
6754907 Schumacher et al. Jun 2004 B1
6757684 Svendsen et al. Jun 2004 B2
6757906 Look et al. Jun 2004 B1
6763226 McZeal, Jr. Jul 2004 B1
6825858 Sato Nov 2004 B2
6826589 Berrada Nov 2004 B2
6836786 Zoller et al. Dec 2004 B1
6870547 Crosby et al. Mar 2005 B1
6904265 Valdivia et al. Jun 2005 B1
6928490 Bucholz et al. Aug 2005 B1
6956833 Yukie et al. Oct 2005 B1
6957086 Bahl et al. Oct 2005 B2
6959235 Abdel-Malek et al. Oct 2005 B1
6968179 De Vries Nov 2005 B1
6975836 Tashiro et al. Dec 2005 B2
7010002 Chow et al. Mar 2006 B2
7065778 Lu Jun 2006 B1
7072388 Blakeney et al. Jul 2006 B2
7089066 Hesse et al. Aug 2006 B2
7098772 Cohen Aug 2006 B2
7127261 Van Erlach Oct 2006 B2
7130582 Barilovits Oct 2006 B2
7165224 Pyhalammi Jan 2007 B2
7177872 Schwesig et al. Feb 2007 B2
7177881 Schwesig et al. Feb 2007 B2
7188312 Hsiu-Ping et al. Mar 2007 B2
7209817 Abdel-Malek et al. Apr 2007 B2
7213061 Hite et al May 2007 B1
7213766 Ryan et al. May 2007 B2
7219136 Danner et al. May 2007 B1
7233990 Debaty et al. Jun 2007 B1
7246009 Hamblen et al. Jul 2007 B2
7260600 Dunn et al. Aug 2007 B1
7263352 Neuhaus et al. Aug 2007 B2
7271780 Cok Sep 2007 B2
7275063 Horn Sep 2007 B2
7280533 Khartabil et al. Oct 2007 B2
7284046 Kreiner et al. Oct 2007 B1
7325057 Cho et al. Jan 2008 B2
7328173 Taratino et al. Feb 2008 B2
7360087 Jorgensen et al. Apr 2008 B2
7363258 Svendsen et al. Apr 2008 B2
7376696 Bell et al. May 2008 B2
7376901 Shen et al. May 2008 B2
7379464 Kreiner et al. May 2008 B2
7379986 Kikinis May 2008 B2
7468744 Edwards et al. Dec 2008 B2
7487112 Barnes, Jr. Feb 2009 B2
7502795 Svendsen et al. Mar 2009 B1
7519393 Bahl et al. Apr 2009 B2
7526314 Kennedy Apr 2009 B2
7561299 Elarde et al. Jul 2009 B2
7617279 Nakajima et al. Nov 2009 B2
7724281 Vale et al. May 2010 B2
20010045985 Edwards et al. Nov 2001 A1
20010052019 Walters et al. Dec 2001 A1
20010052942 MacCollum et al. Dec 2001 A1
20010053274 Roelofs et al. Dec 2001 A1
20020002707 Ekel et al. Jan 2002 A1
20020010925 Kiknis et al. Jan 2002 A1
20020026507 Sears et al. Feb 2002 A1
20020041398 Ikeda et al. Apr 2002 A1
20020046406 Chelehmal et al. Apr 2002 A1
20020056112 Dureau et al. May 2002 A1
20020069309 Balassanian Jun 2002 A1
20020100063 Herigstad et al. Jul 2002 A1
20020105534 Balassanian Aug 2002 A1
20020108125 Joao Aug 2002 A1
20020124258 Fritsch Sep 2002 A1
20020131072 Jackson Sep 2002 A1
20020162120 Mitchell Oct 2002 A1
20020188556 Colica et al. Dec 2002 A1
20020188867 Bushey et al. Dec 2002 A1
20030048295 Lilleness et al. Mar 2003 A1
20030063770 Svendsen et al. Apr 2003 A1
20030065407 Johnson et al. Apr 2003 A1
20030093791 Julia May 2003 A1
20030093813 Shintani et al. May 2003 A1
20030115284 Henry Jun 2003 A1
20030118014 Iyer et al. Jun 2003 A1
20030146977 Vale et al. Aug 2003 A1
20030157960 Kennedy Aug 2003 A1
20030192054 Birks et al. Oct 2003 A1
20030208472 Pham Nov 2003 A1
20030220835 Barnes Nov 2003 A1
20030220995 Hitaka et al. Nov 2003 A1
20030229667 Pedersen et al. Dec 2003 A1
20040004663 Kahn et al. Jan 2004 A1
20040004737 Kahn et al. Jan 2004 A1
20040015589 Isozu Jan 2004 A1
20040015820 Balassanian Jan 2004 A1
20040044723 Bell et al. Mar 2004 A1
20040045039 Harrison et al. Mar 2004 A1
20040049624 Salmonsen Mar 2004 A1
20040060071 Shteyn Mar 2004 A1
20040066419 Pyhalammi Apr 2004 A1
20040097251 Barilovits May 2004 A1
20040097259 Toor et al. May 2004 A1
20040100974 Kreiner et al. May 2004 A1
20040103313 Kreiner et al. May 2004 A1
20040103437 Allegrezza et al. May 2004 A1
20040117442 Thielen Jun 2004 A1
20040117845 Karaoguz et al. Jun 2004 A1
20040117846 Karaoguz et al. Jun 2004 A1
20040117849 Karaoguz et al. Jun 2004 A1
20040133694 Karaoguz et al. Jul 2004 A1
20040139172 Svendsen et al. Jul 2004 A1
20040148353 Karaoguz et al. Jul 2004 A1
20040172440 Nakajima et al. Sep 2004 A1
20040177319 Horn Sep 2004 A1
20040205168 Asher Oct 2004 A1
20040221163 Jorgensen et al. Nov 2004 A1
20040236442 Maymudes Nov 2004 A1
20040237122 Yamaguchi et al. Nov 2004 A1
20040250205 Conning Dec 2004 A1
20040267873 Shen et al. Dec 2004 A1
20050002640 Putterman et al. Jan 2005 A1
20050005025 Harville et al. Jan 2005 A1
20050021624 Herf et al. Jan 2005 A1
20050028208 Ellis et al. Feb 2005 A1
20050037706 Settle Feb 2005 A1
20050038923 Kamataki Feb 2005 A1
20050052469 Crosby et al. Mar 2005 A1
20050055455 Asher Mar 2005 A1
20050055716 Louie et al. Mar 2005 A1
20050062695 Cok Mar 2005 A1
20050076058 Schwesig et al. Apr 2005 A1
20050083904 Khartabil et al. Apr 2005 A1
20050107031 Wood et al. May 2005 A1
20050136949 Barnes, Jr. Jun 2005 A1
20050138560 Lee et al. Jun 2005 A1
20050153707 Ledyard et al. Jul 2005 A1
20050171661 Abdel-Malek et al. Aug 2005 A1
20050171692 Hamblen et al. Aug 2005 A1
20050172001 Zaner et al. Aug 2005 A1
20050183120 Jain et al. Aug 2005 A1
20050198040 Cohen et al. Sep 2005 A1
20050198222 Kohinata et al. Sep 2005 A1
20050201358 Nelson et al. Sep 2005 A1
20050201529 Nelson et al. Sep 2005 A1
20050215194 Boling et al. Sep 2005 A1
20050223409 Rautila et al. Oct 2005 A1
20050229243 Svendsen et al. Oct 2005 A1
20050232186 Karaoguz et al. Oct 2005 A1
20050234864 Shapiro Oct 2005 A1
20050235048 Costa-Requena et al. Oct 2005 A1
20050240558 Gil et al. Oct 2005 A1
20050242971 Dryer Nov 2005 A1
20050246757 Relan et al. Nov 2005 A1
20050256934 Motoyama Nov 2005 A1
20050259618 Ahya et al. Nov 2005 A1
20050283731 Saint-Hilaire et al. Dec 2005 A1
20050286497 Zutaut et al. Dec 2005 A1
20050289266 Illowsky et al. Dec 2005 A1
20060010255 Van Berkel et al. Jan 2006 A1
20060010270 Zhang Jan 2006 A1
20060015649 Zutaut et al. Jan 2006 A1
20060015664 Zhang Jan 2006 A1
20060020960 Relan et al. Jan 2006 A1
20060026271 Julia et al. Feb 2006 A1
20060047843 Julia et al. Mar 2006 A1
20060080452 Julia et al. Apr 2006 A1
20060085826 Funk et al. Apr 2006 A1
20060092176 Wang et al. May 2006 A1
20060095401 Krikorian May 2006 A1
20060095471 Krikorian May 2006 A1
20060095472 Krikorian May 2006 A1
20060161635 Lamkin et al. Jul 2006 A1
20060238335 Karaoguz et al. Oct 2006 A1
20060248554 Priddy Nov 2006 A1
20060253542 McCausland et al. Nov 2006 A1
20060253894 Bookman et al. Nov 2006 A1
20060256130 Gonzalez Nov 2006 A1
20060268738 Goerke et al. Nov 2006 A1
20060277318 Julia et al. Dec 2006 A1
20060280157 Karaoguz et al. Dec 2006 A1
20060288095 Torok et al. Dec 2006 A1
20070027957 Peters et al. Feb 2007 A1
20070038771 Julia et al. Feb 2007 A1
20070061857 Seki et al. Mar 2007 A1
20070067407 Bettis et al. Mar 2007 A1
20070078948 Julia et al. Apr 2007 A1
20070118535 Schwesig et al. May 2007 A1
20070118619 Schwesig et al. May 2007 A1
20070168543 Krikorian et al. Jul 2007 A1
20070173266 Barnes Jul 2007 A1
20070189476 Marsico et al. Aug 2007 A1
20070198532 Krikorian et al. Aug 2007 A1
20070207755 Julia et al. Sep 2007 A1
20070255785 Hayashi et al. Nov 2007 A1
20070266169 Chen et al. Nov 2007 A1
20070280138 Stern Dec 2007 A1
20080021921 Horn Jan 2008 A1
20080189766 Bell et al. Aug 2008 A1
20080232295 Kreiner et al. Sep 2008 A1
20080259818 Balassanian Oct 2008 A1
20080279098 Park Nov 2008 A1
20100017462 Thoen Jan 2010 A1
20100180307 Hayes et al. Jul 2010 A1
20100186034 Walker Jul 2010 A1
Foreign Referenced Citations (6)
Number Date Country
WO 0013688 Mar 2000 WO
WO 0131852 May 2001 WO
WO 0133839 May 2001 WO
WO 03052552 Jun 2003 WO
WO 2005122025 Dec 2005 WO
WO 2006010023 Jan 2006 WO
Non-Patent Literature Citations (60)
Entry
U.S. Appl. No. 09/304,973, filed May 4, 1999, Balassanian.
U.S. Appl. No. 09/498,016, filed Feb. 4, 2000, Balassanian.
U.S. Appl. No. 10/118,587, filed Apr. 8, 2002, Balassanian.
U.S. Appl. No. 60/341,574, filed Dec. 17, 2001, Balassanian.
U.S. Appl. No. 60/341,932, filed Dec. 18, 2001, Balassanian.
U.S. Appl. No. 60/577,833, filed Jun. 7, 2004, Krikorian.
Citrix, Winview for Networks, Installation Guide. 320pages, 1990-1994.
Discover Desktop Conference with NetMeeting 2.0, by Mike Britton and Suzanne Van Cleve. 305pages, 1997.
Final Office Action mailed Oct. 17, 2008 for US 2007/0207755 (U.S. Appl. No. 11/538,800) 16 pgs.
Final Office Action for U.S. Appl. No. 10/888,745 mailed Sep. 2, 2008, 28 pages.
Final Office Action for U.S. Appl. No. 10/888,633 mailed Sep. 3, 2008, 25 pages.
Final Office Action for U.S. Appl. No. 11/531,182 mailed Aug. 31, 2010.
Final Office Action mailed Jul. 9, 2009 for U.S. Appl. No. 11/244,424 18 pages.
Final Office Action mailed Apr. 6, 2010 for U.S. Appl. No. 11/422,419, 9 pages.
Final Office Action for U.S. Appl. No. 10/006,914 mailed Oct. 18, 2006, 15 pgs.
Final Office Action mailed Mar. 15, 2010 for U.S. Appl. No. 11/538,800, 14 pages.
Final Office Action for U.S. Appl. No. 10/006,914 mailed Feb. 4, 2008, 18 pgs.
Final Office Action for U.S. Appl. No. 10/006,914 mailed Jun. 22, 2009, 30 pgs.
Final Office Action for U.S. Appl. No. 10/888,606 mailed May 26, 2010, 36 pgs.
Final Office Action for U.S. Appl. No. 10/888,745 mailed May 20, 2010.
Final Office Action for U.S. Appl. No. 10/888,633 mailed Aug. 17, 2010.
Goldberg, et al., The Ninja Jukebox, conference proceedings from the 2nd USENIX Symposium on Internet Technologies and Systems, Oct. 11-14, 1999, pp. 37-46, Boulder, Colorado.
International Search Report and Written Opinion of the International Searching Authority for PCT/US05/24324 mailed Jul. 20, 2007.
Network, The Authoratative Dictionary of IEEE Standards Terms, 7th Edition 2000.
Non-Final Office Action for U.S. Appl. No. 10/888,633 mailed Jan. 9, 2008, 18 pages.
Non-Final Office Action for U.S. Appl. No. 10/006,914 mailed Jun. 12, 2007, 20 pgs.
Non-Final Office Action for U.S. Appl. No. 10/006,914 mailed Sep. 10, 2008, 23 pgs.
Non-Final Office Action for U.S. Appl. No. 10/888,745 mailed Feb. 12, 2008, 15 pages.
Non-Final Office Action mailed Nov. 30, 2009 for U.S. Appl. No. 10/888,633, pp. 20.
Non-Final Office Action for U.S. Appl. No. 10/006,914 mailed Jan. 26, 2006, 8 pgs.
Non-final Office Action mailed Sep. 15, 2008 for US 2006/0277318 (U.S. Appl. No. 11/244,424) 17 pgs.
Non-Final Office Action mailed Dec. 23, 2009 for U.S. Appl. No. 11/531,182, pp. 16.
Non-Final Office Action mailed Jun. 9, 2009 for U.S. Appl. No. 11/538,800, pp. 13.
Non-final Office Action mailed Jan. 17, 2008 for US 2007/0207755 (U.S. Appl. No. 11/538,800) 11 pgs.
Non-Final Office Action mailed Oct. 2, 2009 for U.S. Appl. No. 11/422,419, pp. 9.
Non-Final Office Action mailed Jun. 24, 2009 for U.S. Appl. No. 11/531,182, pp. 16.
Non-Final Office Action mailed Oct. 14, 2009 for U.S. Appl. No. 10/888,745, pp. 21.
Non-Final Office Action mailed Mar. 17, 2009 for U.S. Appl. No. 10/888,633, pp. 29.
Non-Final Office Action mailed Aug. 4, 2009 for U.S. Appl. No. 10/888,606, 24 pages.
Non-Final Office Action mailed Nov. 10, 2009 for U.S. Appl. No. 10/006,914, 24 pages.
Non-Final Office Action for U.S. Appl. No. 11/244,424 mailed May 7, 2010.
Path Construction for Multimedia Applications, website material from: bnrg.cs.berkeley.edu/˜zmao/cs294-1/multimediaReport.doc, circa Oct. 1999.
TV Brick Home Server, web site as of Dec. 2, 2003, <http://www.tvbrick.com>, provided by <http://archive.org> 4 pages.
TV Brick Home Server, web site as of May 20, 2004, <http://www.tvbrick.com>, provided by <http://archive.org> 4 pages.
TV Brick Home Server, web site as of Jul. 1, 2004, <http://www.tvbrick.com>, provided by <http://archive.org> 4 pages.
TV Brick Home Server, web site as of Jun. 12, <http://www.tvbrick.com>, provided by <http://archive.org> 4 pages.
TV Brick Home Server, web site as of Jun. 9, 2004, <http://www.tvbrick.com>, provided by <http://archive.org> 4 pages.
TV Brick Home Server, web site as of Jun. 8, 2004, <http://www.tvbrick.com>, provided by <http://archive.org> 4 pages.
TV Brick Home Server, web site as of May 25, 2004, <http://www.tvbrick.com>, provided by <http://archive.org> 4 pages.
TV Brick Home Server, web site as of May 8, 2004, <http://www.tvbrick.com>, provided by <http://archive.org> 4 pages.
TV Brick Home Server, web site as of Apr. 7, 2004, <http://www.tvbrick.com>, provided by <http://archive.org> 4 pages.
TV Brick Home Server, web site as of Mar. 22, 2004, <http://www.tvbrick.com>, provided by <http://archive.org> 4 pages.
TV Brick Home Server, web site as of Feb. 10, 2004, <http://www.tvbrick.com>, provided by <http://archive.org> 4 pages.
TV Brick Home Server, web site as of Dec. 28, 2003, <http://www.tvbrick.com>, provided by <http://archive.org> 4 pages.
TV Brick Home Server, web site as of Oct. 9, 2003, <http://www.tvbrick.com>, provided by <http://archive.org> 4 pages.
TV Brick Home Server, web site as of Jul. 19, 2003, <http://www.tvbrick.com>, provided by <http://archive.org> 4 pages.
TV Brick Home Server, web site as of Jul. 4, 2003, <http://www.tvbrick.com>, provided by <http://archive.org> 4 pages.
TV Brick Home Server, web site as of Jun. 29, 2003, <http://www.tvbrick.com>, provided by <http://archive.org> 4 pages.
TV Brick Home Server, web site as of Feb. 3, 2004, <http://www.tvbrick.com>, provided by <http://archive.org> 4 pages.
TV ‘brick’ opens up copyright can of worms, by Benoit Faucon, The Wall Street Journal (from Australian Financial Review) Jul. 1, 2003, published online Oct. 20, 2003 on http://mex-at-the-blogspot.com/search?q=brick, 1 page.
Related Publications (1)
Number Date Country
20080127289 A1 May 2008 US
Provisional Applications (1)
Number Date Country
60862206 Oct 2006 US