When a media player application is first released, it has a limited number of supported or native file formats. It is not feasible for a media player application to natively support all file types, codecs, and Digital Rights Management (DRM) schemes. Further, the media player application does not support different file types, codecs, and DRM schemes developed after the release of the media player application.
To overcome this limitation, media player application developers have provided Application Program Interface specifications (API's) that allow third-party developers to interface with the media player. When a file of a certain type is selected for rendering by the media player, the software from the third-party developer is called to render the contents of the file. In this method, the file may be unreadable, metadata may not be available, a codec compatible with the media player may not be available, or the media player may not recognize the DRM scheme.
In one embodiment, the invention provides a system and method for invoking plug-ins to convert a media file to a format usable by the media player. This embodiment stores the original file and the converted file. Because of the way in which the original and converted files are stored, one embodiment of the invention provides for creating or recreating a database that identifies all of the media content available to the media player or file library system and correlates original files to their associated converted files.
In another embodiment, a system and method are provided for synchronizing media content to a media device. The media player or file library system determines supported and preferred file formats from the media device. The media player or file library system then provides the original file or the converted file, depending on which format the device prefers. Optionally, the media player or file library system may convert the media content to a preferred format if the media content is not immediately available to the media player or file library system in a preferred file format.
This summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
Other features will be in part apparent and in part pointed out hereinafter.
Corresponding reference characters indicate corresponding parts throughout the drawings.
In one embodiment of the invention as illustrated in
A media library 120, or file library system, for use with one embodiment of the invention may be integral with the media player 108 or separate, even residing on a separate computing device. In the embodiment shown in
One skilled in the art will recognize that many variations are possible regarding implementations of a file library system for use with the invention such as the media library 120. For example, the shadow file cache 126 may be hidden from the user 102, or shadow files may be stored in the same location as primary files and the shadow files themselves hidden from the user 102. Alternatively, the shadow files may be visible to the user 102. A shadow file may be renamed or stored in a location based on its contents and a predetermined naming or locating convention. A shadow file may or may not be linked to its corresponding primary file in a database. Naming or locating shadow files based on their contents allows a file library system to associate corresponding primary files and shadow files without having a database, and allows a lost or corrupted database to be reconstructed by a simple utility that could be embedded in the file manager 122 or separate.
Referring now to
A synchronization component 130 also shown in
A media device may prefer a particular file format for one or more reasons. For example, some file formats support advanced DRM schemes, and other file formats only support certain DRM schemes such that when converting between file formats, the DRM data is lost. Manufacturers of media devices and media content providers may wish to preserve the DRM information. Even though media player 108 does not natively support a particular file format and DRM scheme, it can support the use of the file format and DRM scheme by preserving a file it receives in that file format (e.g., storing a shadow file) and later providing that file to other applications or media devices such as media device 132. Another reason to prefer certain file formats is compression; a file in one file format is smaller than a file in another format having the same media content (e.g., a song stored in WMA file format may be smaller than the same song stored in MP3 file format). Media devices having relatively little memory may prefer a file format utilizing better compression to maximize the amount of media content that the media device can store.
Referring now to
Referring to
One skilled in the art will recognize that many variations of the synchronization component 130 and its method of operation are possible. A user may select media content from a database corresponding to a primary media file instead of directly selecting a media file in a media library, database, or other file library system. The user may select one or more files to be synchronized by the synchronization component 130. There may also be more than one shadow file for the selected media content or media file. The synchronization component 130 may determine formats supported by and preferred by the media device before a file or media content is selected for synchronization. The media device 132 may automatically provide a list or parameter indicative of its supported and preferred file formats such that the synchronization component 130 is not required to query the media device 132.
The exemplary operating environment for a media player application according to the invention includes a general purpose computing device such as a computer executing computer-executable instructions. The computing device typically has at least some form of computer readable media. Computer readable media, which include both volatile and nonvolatile media, removable and non-removable media, may be any available medium that may be accessed by the general purpose computing device. By way of example and not limitation, computer readable media comprise computer storage media and communication media. Computer storage media include volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data. Communication media typically embody computer readable instructions, data structures, program modules, or other data in a modulated data signal such as a carrier wave or other transport mechanism and include any information delivery media. Those skilled in the art are familiar with the modulated data signal, which has one or more of its characteristics set or changed in such a manner as to encode information in the signal. Wired media, such as a wired network or direct-wired connection, and wireless media, such as acoustic, RF, infrared, and other wireless media, are examples of communication media. Combinations of any of the above are also included within the scope of computer readable media. The computing device includes or has access to computer storage media in the form of removable and/or non-removable, volatile and/or nonvolatile memory. A user may enter commands and information into the computing device through input devices or user interface selection devices such as a keyboard and a pointing device (e.g., a mouse, trackball, pen, or touch pad). Other input devices, such as a microphone, may be connected to the computing device. A monitor or other type of display device is also connected to the computing device. In addition to the monitor, computers often include other peripheral output devices such as a printer and speakers, which may be connected through an output peripheral interface.
The computer may operate in a networked environment using logical connections to one or more remote computers. The remote computer may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer. Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets, and global computer networks (e.g., the Internet).
Although described in connection with an exemplary computing system environment, embodiments of the invention are operational with numerous other general purpose or special purpose computing system environments or configurations. The computing system environment is not intended to suggest any limitation as to the scope of use or functionality of embodiments of the invention. Moreover, the computing system environment should not be interpreted as having any dependency or requirement relating to any one or combination of components illustrated in the exemplary operating environment. Examples of well known computing systems, environments, and/or configurations that may be suitable for use in embodiments of the invention include, but are not limited to, personal computers, server computers, hand-held or laptop devices, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, mobile telephones, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
Embodiments of the invention may be described in the general context of computer-executable instructions, such as program modules, executed by one or more computers or other devices. Generally, program modules include, but are not limited to, routines, programs, objects, components, and data structures that perform particular tasks or implement particular abstract data types. Embodiments of the invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote computer storage media including memory storage devices.
The order of execution or performance of the operations in embodiments of the invention illustrated and described herein is not essential, unless otherwise specified. That is, the operations may be performed in any order, unless otherwise specified, and embodiments of the invention may include additional or fewer operations than those disclosed herein. For example, it is contemplated that executing or performing a particular operation before, contemporaneously with, or after another operation is within the scope of aspects of the invention.
Embodiments of the invention may be implemented with computer-executable instructions. The computer-executable instructions may be organized into one or more computer-executable components or modules. Aspects of the invention may be implemented with any number and organization of such components or modules. For example, aspects of the invention are not limited to the specific computer-executable instructions or the specific components or modules illustrated in the figures and described herein. Other embodiments of the invention may include different computer-executable instructions or components having more or less functionality than illustrated and described herein.
When introducing elements of aspects of the invention or the embodiments thereof, the articles “a,” “an,” “the,” and “said” are intended to mean that there are one or more of the elements. The terms “comprising,” “including,” and “having” are intended to be inclusive and mean that there may be additional elements other than the listed elements.
Having described aspects of the invention in detail, it will be apparent that modifications and variations are possible without departing from the scope of aspects of the invention as defined in the appended claims. As various changes could be made in the above constructions, products, and methods without departing from the scope of aspects of the invention, it is intended that all matter contained in the above description and shown in the accompanying drawings shall be interpreted as illustrative and not in a limiting sense.
Number | Name | Date | Kind |
---|---|---|---|
5410698 | Danneels et al. | Apr 1995 | A |
5506932 | Holmes et al. | Apr 1996 | A |
6094684 | Pallmann | Jul 2000 | A |
6269368 | Diamond | Jul 2001 | B1 |
6476802 | Rose et al. | Nov 2002 | B1 |
6549922 | Srivastava et al. | Apr 2003 | B1 |
6609130 | Saulpaugh et al. | Aug 2003 | B1 |
6742176 | Million et al. | May 2004 | B1 |
6934467 | Herz | Aug 2005 | B1 |
6961430 | Gaske et al. | Nov 2005 | B1 |
7039643 | Sena et al. | May 2006 | B2 |
7200668 | Mak et al. | Apr 2007 | B2 |
7401100 | Jung et al. | Jul 2008 | B2 |
7636738 | Shibata et al. | Dec 2009 | B2 |
20020138619 | Ramaley et al. | Sep 2002 | A1 |
20020174135 | Pellegrin et al. | Nov 2002 | A1 |
20030001978 | Smith et al. | Jan 2003 | A1 |
20030126608 | Safadi et al. | Jul 2003 | A1 |
20030182450 | Ong et al. | Sep 2003 | A1 |
20030185542 | McVeigh et al. | Oct 2003 | A1 |
20040064500 | Kolar et al. | Apr 2004 | A1 |
20040186854 | Choi | Sep 2004 | A1 |
20040237750 | Smith et al. | Dec 2004 | A1 |
20040242269 | Fadell | Dec 2004 | A1 |
20040260786 | Barile | Dec 2004 | A1 |
20050005760 | Hull et al. | Jan 2005 | A1 |
20050246451 | Silverman et al. | Nov 2005 | A1 |
20050286497 | Zutaut et al. | Dec 2005 | A1 |
20050289617 | Safadi et al. | Dec 2005 | A1 |
20060007479 | Henry et al. | Jan 2006 | A1 |
20060020636 | Murotani | Jan 2006 | A1 |
20060031889 | Bennett et al. | Feb 2006 | A1 |
20060069803 | Clark et al. | Mar 2006 | A1 |
20060123064 | Kim et al. | Jun 2006 | A1 |
20060184573 | Koori | Aug 2006 | A1 |
20070067242 | Lotspiech et al. | Mar 2007 | A1 |
20070073747 | Jung et al. | Mar 2007 | A1 |
20070078898 | Hayashi et al. | Apr 2007 | A1 |
20070088727 | Kindig | Apr 2007 | A1 |
20070143346 | Matsutani | Jun 2007 | A1 |
20070185909 | Klein et al. | Aug 2007 | A1 |
20070220024 | Putterman et al. | Sep 2007 | A1 |
20070220048 | Ott | Sep 2007 | A1 |
20070260615 | Shen | Nov 2007 | A1 |
20080046466 | Yun | Feb 2008 | A1 |
20090070438 | Bartholomew | Mar 2009 | A1 |
20090216776 | Carol et al. | Aug 2009 | A1 |
Number | Date | Country | |
---|---|---|---|
20070226238 A1 | Sep 2007 | US |