The present disclosure generally relates to online services, and more particularly to enabling customizations for such services and switching between such services.
Most media player applications provide a range of features that enable users to discover, acquire, and use media content. In addition, the exposure to, and use of, media content (e.g., through online media services, etc.) is increasingly becoming part of a user media experience that is relevant to other applications and to an overall operating system environment. With the exception of providing the media content itself, most media players provide and control all aspects of the user experience. That is, the media player controls the experience with respect to discovering and acquiring online media, in addition to providing a broad range of features for using the media, such as playing the media, burning the media (e.g., music files) to a CD, and transferring the media to a portable device.
There are various ways for online media services to advertise and deliver media content to customers/users. For example, in one scenario, users can use a browser application to browse media service Web pages and search for media content, and then purchase and download desired content through the browser application and mechanisms provided by the media service. In this case, the media discovery and acquisition process is generally controlled by the media service itself. From the media service's point of view, being able to control the media discovery and acquisition experience in this manner is a benefit, as it provides the service with the opportunity to attract more users through its own innovative and dynamic presentation of media content.
In another scenario, media services can deliver content to users through agreements made with media player developers. A media service provides the media content, but the media player controls how the user discovers and acquires (and plays/consumes) the content. This lack of control over the discovery and acquisition of its content is problematic for media services, however. Some media services have attempted to overcome this problem by writing their own media players and providing them to users. Although this alternative gives a media service control over the discovery, acquisition and playback of the media content, it also has important disadvantages. In particular, the cost of developing a media player can be significant, which typically means that the resulting media player is unable to offer the rich playback features provided by other media players that are readily available to users.
From a user's view point, both of the scenarios discussed above can be problematic. For example, the first scenario discussed above provides a disjointed experience for the user. The user browses (i.e., with a browser application) media service Web pages in search of desired content, and then purchases and downloads the content. To use the content (e.g., play, burn to CD, transfer to portable player, etc.) the user must then initiate a separate action through a media player application. Thus, the experience is a disjointed and sometimes time consuming combination of steps that necessitates the use of different applications.
In the second scenario discussed above, the user is limited to media content that is made available through the media player application, as well as being limited to the presentation of that content as dictated by the media player application. The variety of content accessible to the user is therefore limited to content secured by the media player through agreements with various media services. A user who desires a wider variety of media content may not be able to find the content they want through the media player, and thus be relegated to using a browser application to search for their desired content in the same type of disjointed experience as discussed above.
Accordingly, from an end-user perspective, a need exists for a way to provide an uninterrupted media experience that includes the discovery, acquisition, and use of a variety of media content within a feature rich player environment specifically, and within an overall operating system environment more generally. From a media services perspective, a corresponding need exists for a way to enable media services to have control over the way users discover and acquire media for use within a feature rich player environment and/or an overall operating system environment.
A system and methods enable switching between online services within participating applications (e.g., a media player application, operating system shell, etc.), and provide customization opportunities for the online services within the applications. A service becomes the active service when a user switches to that service. The active service controls the customization points within the application. When a user switches to another service, the other service becomes the active service and gains control over the customization points within the application.
A file that contains a list of valid services is maintained on a Web listing service and is retrieved each time a participating application goes online. The all-services file contains an updated list of online services to be managed within the application, along with information about the online services, such as friendly names, graphic icons, and URLs (universal resource locators) needed to populate a service menu within the application and to direct the application to additional information about each service.
Additional information about each valid service is found in a service information file retrieved from a URL identified by the valid service within the valid services list. Each valid service maintains its own service information file and manages customization points within the application through the service information file when the service is selected as the active service.
The same reference numerals are used throughout the drawings to reference like components and features.
Introduction
The following discussion is directed to a system and methods that enable switching between a plurality of online media services from within an application, such as a PC-based media player application. A user can switch to any one of a number of online services made available in a services menu and thereby make that service the active service. In addition, the currently active online service is given customization opportunities that permit the active service to customize parts of the media player or other application and/or operating system (e.g., by supplying Web pages using URLs from a service information file provided by the active service). Advantages of the described system and methods include providing online media services with an ability to control the way in which customers discover and purchase media from within the feature rich environment of various user applications such as a PC-based media player application. From a user's perspective, the advantages include an uninterrupted media experience that can involve the entire process of discovering, purchasing and using of a wide variety of media content all from within the feature rich environment of a media player application.
Exemplary Service Switching and Customization Environment
Computer 102 is typically implemented as a user's primary computing device, such as a desktop personal computer (PC). Computer 102 might also be implemented as other conventional computing devices generally configured to receive and render multi-media content (e.g., play back, burn to CD, transfer to portable playback device, etc.) from various online media services. An exemplary implementation of a computer 102 is depicted in
Online services 104 and Web listing service 106 are typically implemented as one or more server computers such as a Web server. Thus, online services 104 and Web listing service 106 may include a variety of general purpose computing devices such as workstation computers, and may be configured in a manner similar to an exemplary implementation of computer 102 such as described below in the Exemplary Computing Environment referring to
Exemplary Embodiments
An application 204 may be any of various applications and/or tools configured to perform various computing tasks such as emailing, word processing, financial analysis, and so on. An application 204 may also be an application or tool configured to receive and manipulate media content, such as from an online media service 104 or some other source. For example, application 204 may be an interactive TV service application that facilitates the recording of video (e.g., TV programming) directly off of a cable and/or satellite feed, a video capture component to transfer home video footage from a digital video recorder onto computer 102, a Web browser application that facilitates downloading media over a network 108, and so on. Thus, applications 204 may supply various forms of media content to a media library 208 on computer 102. Media content stored in media library 208 may include, for example, audio files in the form of MP3 and WMA files, video files in the form of AVI and MOV files, and image files in the form of GIF and JPEG files, and so on.
A specific example of an application 204 that is illustrated in
A service switching and customization architecture 210 is configured to be operatively interactive with any one or more of the components of computer 102 noted above for the general purpose of enabling switching between various online media services 104 and allowing an active service to customize portions of such components on computer 102. For example, in one embodiment, the service switching and customization architecture 210 may be an integral component of, and/or operatively interactive with, the media player application 206. Accordingly, although the current embodiment of the service switching and customization architecture 210 will be discussed herein with specific reference to the media player application 206, various aspects of service switching and customization may be generally applicable in similar ways to various components of computer 102 including, for example, the operating system 200 and its sub-components (e.g., shell 202), and various other applications 204.
The service switching and customization architecture 210 includes an online service manager component 212, an all-services file 214, and a number of service information files 216. The online service manager 212 is generally configured to populate a service menu list within the media player 206, and to manage switching between online services and to manage customizations made to the player that are provided by a currently active service. Each time computer 102 is connected to the network 108, the online service manager 212 fetches the all-services file 214 from a Web service listing 106. In the current embodiment, the all-services file 214 is an XML (Extended Markup Language) file that is kept up-to-date on the Web service listing 106 so that the online service manager 212 always has access to the latest list of valid online services 104. The all-services file 214 includes a list of all valid online services 104 and any other information needed to populate a service menu list within the media player 206. As discussed in more detail below, the online service manager 212 uses information in the all-services file 214 to determine where to retrieve a service information file 216 for each of the valid services identified in the all-services file 214.
When a valid all-services file 214 is retrieved from Web service listing 106, the service manager 212 populates the service menu list within the media player 206 with the list of valid online services from the file. Prior to a new selection being made by a user from the service menu list, the last active service is present in all the customization points within the media player 206.
A selection arrow is shown in
Referring to
As noted above, when a service is selected from the service menu list within the media player 206, the URL for the selected service is accessed and the service information file 216 for that service is retrieved. Like the all-services file 214 discussed above, the service information file 216 is preferably an XML file. Each valid online service in the all-services file 214 hosts it own service information file 216 and uses this file to manage the customization opportunities within the media player 206. Customization opportunities, or customization points, are places or areas within the media player 206 that the media player gives up control over so that the active service can customize them to its own preference. Three main categories of customization can generally be described as music, video (TV, movie), and radio. Referring to
An active/selected service provides an HTML page for display in task pane 300 for one or more task tabs 600. The HTML page typically provides access to a purchase experience. For example, an active music service may provide an HTML page that permits a user to search for a particular song or CD, after which the user can purchase and download the song or CD. A service can choose to include one or all of the three categories depending on the type of service. For example, a video service that offers only video products may only choose to use and customize the video category task tab and forego using the music and radio tabs.
In addition to the three main task tabs 600, an active service controls customization points regarding various media player functions, such as those represented by the function tabs 602 on the left side of the media player shown in
In addition to the “Now Playing” function as a customization opportunity for the currently active service, various other functions provide such customization opportunities within media player 206.
The <serviceinfo> element is required, and is the container element for the service information file 216. The <serviceinfo> element includes an optional version attribute that indicates the version of the XML file, and a required key attribute that is used by the media player 206 to uniquely identify the particular service. The <friendlyname> element is a required element that includes text that will be used to represent the name of the service on the service menu list in the media player 206. The <image> element is optional and it represents the graphical images that should be used to represent the service. The <image> element includes an optional MenuURL attribute that is a fully qualified URL to a 16×16 graphic image to use on the service menu list, an optional ServiceSmallURL that is a fully qualified URL to a 30×30 graphic image to use in the chrome, and an optional ServiceLargeURL that is a fully qualified URL to a 30×60 graphic image to use in the chrome. The file formats supported include .gif, .jpg, .bmp, and .png. PNG is the preferred file format as transparency is also supported and recommended. If the MenuURL attribute isn't specified, then no graphic is used on the menu. The ServiceLargeURL attribute for the chrome service image is used if both ServiceSmallURL and ServiceLargeURL are present. If the chrome images are wider than the image area (30 or 60 depending on which element), then the image area is animated over the image area when the user selects the service.
The <color> element is optional and is used to specify the service area button color and navigation bar color. The <color> element includes a required mediaplayer attribute of hex RGB value (#FFDDCC). The <servicetask1>, <servicetask2>, and <servicetask3> elements represent the three task pane tabs 600 (
The <infocenter> element is optional and is used to specify a customization of the “Now Playing” InfoCenter view. The <infocenter> element includes a required URL attribute that is a fully qualified URL that refers to an HTML page. As noted above, the <infocenter> view HTML page provided by the active service typically includes useful information regarding the music that is currently being played by the media player, such as track listings, artists, etc. The <albuminfo> element is an optional element that is used to specify a customization of the album information windows in the Burn to CD and Media Library panes. The <albuminfo> element includes a required URL that is a fully qualified URL that refers to an HTML page. The URL will be loaded into the album information window with parameters as a query. The <buycd> element is an optional element that is used to specify a purchase experience from various buy links within the media player 206. The <buycd> element includes a required MediaPlayerURL, an optional MediaCenterURL, and an optional BrowserURL that are each fully qualified URLs that refer to an HTML page for buying a CD or DVD in the media player 206. The “Now Playing” function includes a “Buy CD” shortcut link to the active service Web page that permits purchasing the media currently playing on the media player 206.
The <install> element is an optional element that is used by setup to install the default service code (if any) when setup is run online. The <install> element includes a required EULAURL that is a fully qualified URL that points to a .txt file for the code that the service wants installed, and a CodeURL that is a fully qualified URL that points to a cab file that will be installed during setup if the service is the default service. The <htmlview> element is an optional element that is used to allow Radio .ASX files to specify a trusted HTMLView file so that the page can have access to the external .NavigateTaskPane ULR function to link deeply into a service. The <htmlview> element includes a required BaseURL that is a fully qualified URL that points to the base URL to use for any new HTMLView to allow HTML access.
Exemplary Methods
Example methods for enabling switching between various online media services and allowing an active service to customize portions of an application on a computer will now be described with primary reference to the flow diagram of
A “processor-readable medium,” as used herein, can be any means that can contain, store, communicate, propagate, or transport instructions for use or execution by a processor. A processor-readable medium can be, without limitation, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, device, or propagation medium. More specific examples of a processor-readable medium include, among others, an electrical connection (electronic) having one or more wires, a portable computer diskette (magnetic), a random access memory (RAM) (magnetic), a read-only memory (ROM) (magnetic), an erasable programmable-read-only memory (EPROM or Flash memory), an optical fiber (optical), a rewritable compact disc (CD-RW) (optical), and a portable compact disc read-only memory (CDROM) (optical).
At block 902 of method 900, a list of online services is retrieved. An online service manager 212 related to an application 204 (e.g., a media player 206) executing on a computer, goes online via a network and accesses a Web listing service. The online service manager 212 retrieves an all-services XML file containing a list of valid online services and additional information.
At block 904, an online service is set as an initial active service based on the last active service previously chosen by the user. If the application has never run before, a default service specified by the all-services file is initially set as the active service.
At block 906, the online service manager 212 enables the selection of one of the online services as an active service. A service menu within a media player 206, for example, is populated with the list of online services. Each online service is represented in the service menu with a friendly and a graphical image if the name and image have been included by the active service in the retrieved list of online services. Selection of one of the online services includes accepting user input that identifies which online service the user desires to make the current active service within the media player.
At block 908, customization points within the media player 206 (or other application 204, operating system 200, etc.) are customized based on the active service. Customization includes retrieving a service information file from the active service and customizing the customization points within the media player 206 (and/or operating system shell 202 and applications 204) by enabling the active service, via the service information file, to control the content within the customization points. The customization points include, for example, task panes and task pane buttons within the media player. Customizations within a media player 206 (and/or operating system shell 202 and applications 204) can include a variety of content input and modifications made to parts of the software, including for example, identifying a name for a task pane button using text provided by the active service, displaying button tip text for the task pane button when a selection tool hovers over the task pane button, the button tip text being provided by the active service, displaying (in a task pane) an HTML page specified by the active service when a user selects the task pane button. Customizations can also include displaying an HTML page from the active service within a Now Playing task pane of the media player, where the HTML page provides an InfoCenter view that includes information related to music that is currently being played by the media player. Customizations can also include displaying an HTML page from the active service, where the HTML page provides album information in a burn-to-CD (compact disc) task pane and a Media Library task pane. Customizing can also include displaying a “Buy CD” link to a Web page of the active service within a Now Playing task pane, where the Web page permits purchasing the CD (compact disc) or DVD (digital video disc) that is currently playing on the media player.
At block 910, a user input selection is received through the service menu for a different service from the available online services. At block 912, the online service manager 212 retrieves a service information file for the different service. At block 914, the online service manager 212 switches the active service to the different service based on the input selection made by the user.
Exemplary Computing Environment
The computing environment 1000 includes a general-purpose computing system in the form of a computer 1002. The components of computer 1002 may include, but are not limited to, one or more processors or processing units 1004, a system memory 1006, and a system bus 1008 that couples various system components including the processor 1004 to the system memory 1006.
The system bus 1008 represents one or more of any of several types of bus structures, including a memory bus or memory controller, a peripheral bus, an accelerated graphics port, and a processor or local bus using any of a variety of bus architectures. An example of a system bus 1008 would be a Peripheral Component Interconnects (PCI) bus, also known as a Mezzanine bus.
Computer 1002 includes a variety of computer-readable media. Such media can be any available media that is accessible by computer 1002 and includes both volatile and non-volatile media, removable and non-removable media. The system memory 1006 includes computer readable media in the form of volatile memory, such as random access memory (RAM) 1010, and/or non-volatile memory, such as read only memory (ROM) 1012. A basic input/output system (BIOS) 1014, containing the basic routines that help to transfer information between elements within computer 1002, such as during start-up, is stored in ROM 1012. RAM 1010 contains data and/or program modules that are immediately accessible to and/or presently operated on by the processing unit 1004.
Computer 1002 may also include other removable/non-removable, volatile/non-volatile computer storage media. By way of example,
The disk drives and their associated computer-readable media provide non-volatile storage of computer readable instructions, data structures, program modules, and other data for computer 1002. Although the example illustrates a hard disk 1016, a removable magnetic disk 1020, and a removable optical disk 1024, it is to be appreciated that other types of computer readable media which can store data that is accessible by a computer, such as magnetic cassettes or other magnetic storage devices, flash memory cards, CD-ROM, digital versatile disks (DVD) or other optical storage, random access memories (RAM), read only memories (ROM), electrically erasable programmable read-only memory (EEPROM), and the like, can also be utilized to implement the exemplary computing system and environment.
Any number of program modules can be stored on the hard disk 1016, magnetic disk 1020, optical disk 1024, ROM 1012, and/or RAM 1010, including by way of example, an operating system 1026, one or more application programs 1028, other program modules 1030, and program data 1032. Each of such operating system 1026, one or more application programs 1028, other program modules 1030, and program data 1032 (or some combination thereof) may include an embodiment of a caching scheme for user network access information.
Computer 1002 can include a variety of computer/processor readable media identified as communication media. Communication media embodies 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 includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared, and other wireless media. Combinations of any of the above are also included within the scope of computer readable media.
A user can enter commands and information into computer system 1002 via input devices such as a keyboard 1034 and a pointing device 1036 (e.g., a “mouse”). Other input devices 1038 (not shown specifically) may include a microphone, joystick, game pad, satellite dish, serial port, scanner, and/or the like. These and other input devices are connected to the processing unit 1004 via input/output interfaces 1040 that are coupled to the system bus 1008, but may be connected by other interface and bus structures, such as a parallel port, game port, or a universal serial bus (USB).
A monitor 1042 or other type of display device may also be connected to the system bus 1008 via an interface, such as a video adapter 1044. In addition to the monitor 1042, other output peripheral devices may include components such as speakers (not shown) and a printer 1046 which can be connected to computer 1002 via the input/output interfaces 1040.
Computer 1002 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computing device 1048. By way of example, the remote computing device 1048 can be a personal computer, portable computer, a server, a router, a network computer, a peer device or other common network node, and the like. The remote computing device 1048 is illustrated as a portable computer that may include many or all of the elements and features described herein relative to computer system 1002.
Logical connections between computer 1002 and the remote computer 1048 are depicted as a local area network (LAN) 1050 and a general wide area network (WAN) 1052. Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets, and the Internet. When implemented in a LAN networking environment, the computer 1002 is connected to a local network 1050 via a network interface or adapter 1054. When implemented in a WAN networking environment, the computer 1002 includes a modem 1056 or other means for establishing communications over the wide network 1052. The modem 1056, which can be internal or external to computer 1002, can be connected to the system bus 1008 via the input/output interfaces 1040 or other appropriate mechanisms. It is to be appreciated that the illustrated network connections are exemplary and that other means of establishing communication link(s) between the computers 1002 and 1048 can be employed.
In a networked environment, such as that illustrated with computing environment 1000, program modules depicted relative to the computer 1002, or portions thereof, may be stored in a remote memory storage device. By way of example, remote application programs 1058 reside on a memory device of remote computer 1048. For purposes of illustration, application programs and other executable program components, such as the operating system, are illustrated herein as discrete blocks, although it is recognized that such programs and components reside at various times in different storage components of the computer system 1002, and are executed by the data processor(s) of the computer.
Although the invention has been described in language specific to structural features and/or methodological acts, it is to be understood that the invention defined in the appended claims is not necessarily limited to the specific features or acts described. Rather, the specific features and acts are disclosed as exemplary forms of implementing the claimed invention.