Many software applications provide a user with the ability to interact with the application in some manner. The mechanism by which a user is permitted to interact with a software application is referred to as a user interface (“UI”). User interfaces typically provide controls that can be engaged by a user to cause a predetermined result. For example, in Windows XP, Media Center edition (MCE), the “my music” gallery page allows a user to sort the music by artist, album, playlist or genre. A user might use their mouse to click on the “album” toolbar so that all albums stored in MCE are displayed by album cover. The background for the “my album” gallery page and the gallery page displaying the album covers has the same color (Windows blue).
UIs have, in the past, been generally fixed insofar as their layout, functionality and appearance is concerned. One primary reason for this stems from the desire to impart standardization to various UIs. Yet, against the backdrop of standardized UIs, interest has begun to surface with providing the ability to impart a different look to various UIs. For example, the background of most gallery pages in MCE (e.g., recorded tv gallery page) is tinted with the Windows blue, regardless of the UI. Increasingly, content partners who are providing the content for the UIs want the capability of “branding” their product. A content partner is any party that creates or distributes content. By way of example only, a content partner may be a television network (e.g., ABC), a movie studio (e.g., Paramount Studios) or a content aggregator (e.g., Netflix).
In computing, skins may be associated with themes such as custom graphical appearances that can be applied to certain software in order to suit the different tastes of different users. The process of writing or applying such a skin is known as “skinning.” Applying a skin changes the look and feel of a piece of software.
The technology described herein comprises a system and methods for generating a branded background for a UI. One example of a UI having a branded background is an “arrested development” television gallery page in MCE. The background of the “arrested development” gallery page may have a “theme” associated with the television show. For example, the background and various gallery content may be tinted orange (the color associated with “arrested development”), and include an image of one of the “arrested development” characters and the msn logo.
One aspect of the technology described herein is to brand a user interface associated with the content displayed in the UI. In one embodiment, a content partner chooses the layout of a user interface template. The UI template contains predetermined locations for displaying the content and designates a background for the UI. In one embodiment, each UI template preferably contains a predetermined location for displaying a logo, an image and various other content. In another embodiment, each UI template contains a specific background that can be tinted a color. In one embodiment, the content partner provides the logo, an image and a hue value, all associated with the content to be displayed in the UI.
Another aspect of the technology described herein is to generate a branded user interface. In one embodiment, the content partner provides a hue value associated with a particular color. The background of the user interface template is then tinted the specified color. If the content partner provides an image, the image is then placed the UI template's image location. If the content partner provides a logo, the logo is placed in the UI template's logo location. Once the UI template is generated, content is then layered over the branded UI template.
Yet another aspect of the technology described herein is to efficiently generate the branded user interface. In one embodiment, the log and image provided by the content partner are stored remotely. Tinting the background of the UI template, and importing image files from a remote location allows the system to pre-download the images while the branded user interface is being tinted. By only storing a locator to the images locally, the amount of storage space required by the system is reduced. In another embodiment, the size of the image files provided by the content partner is limited, allowing the system to quickly download and layer the images over the background.
Another aspect of the technology described herein is to provide a system that generates the branded user interface. In one embodiment, the system includes a memory and a processor. The memory is configured to store a background template, a hue value provided by the content partner, a logo provided by the content provider, and a locator associated with an image provided by the content provider. The processor is configured to retrieve the image provided by the content provider, place a watermarked version of the image in the background template, place the logo in the background template, and tint the background template with a color associated with the hue value. In another embodiment, the memory stores a locator associated with the logo and the processor is configured to retrieve the logo.
For discussion purposes only, the various aspects of the present technology will be discussed in reference to Windows XP, Media Center edition (“MCE”). The present technology is, of course, not limited to this specific product, and applies to any other user interface that may be skinned.
In step 102, the data supplied by the content partner is received and stored by the system. In one embodiment, the content partner provides a logo, a hue value and artwork. The artwork may also be referred to as an “image” or “piece of art.” In one embodiment, the data provided by the content partner will be stored locally. In another embodiment, some of the data may be stored remotely. For example, the artwork may be stored on a remote server, and is available through URL redirects.
In step 104, the method 100 provides the background template. The background template provides the background for the UI. In one embodiment, the background template is stored locally. Having a local background template allows for an efficient rendering of the branded UI. As will be discussed in more detail later, in one embodiment, the background template includes a mask and a predefined location for inserting the logo and artwork provided by the content partner.
In step 106, the mask of the background is tinted. The content partner may choose what color the mask will be tinted. The color the mask is tinted is based on the hue value received from the content partner in step 102. Suppose Microsoft Network (“msn”) has television gallery pages displayed in MCE for its popular television show “arrested development.” Msn may customize the “arrested development” gallery pages by providing a hue value specifying what color the mask should be tinted. The television show “arrested development” is often associated with a particular shade of orange. Thus, msn may provide a hue value that is associated with the particular shade of orange. When the branded background of the UI is being rendered, the mask will be tinted with the color associated with the hue value provided by msn. Additional details of the tinting process are provided hereinafter.
Msn may also want to further strengthen the theme or branding of the “arrested development” gallery pages. To do so, msn may provide artwork that will be displayed in the background. If the content partner provides artwork, in step 108, the method 100 places or inserts the artwork in the background template. The artwork is placed in the background in a predetermined image location set by the background template. In one embodiment, the content partner may not modify the image location in the background template. In an alternative embodiment, the content partner may modify or choose the image location within the background template.
For example, msn may want the background of the “arrested development” gallery page to display an image of one of the “arrested development” characters. In one embodiment of method 100, msn provides a full-color image of the character and the full-color image is stored in step 102. In an alternative embodiment, msn provides a black and white version of the image and the black and white version of the image is stored in step 102. In another embodiment, the size of image file provided by the content partner is restricted. Restricting the artwork file size allows for faster downloading of the image from the remote storage location.
Msn may also want to increase the branding of the “arrested development” gallery page by adding a logo in the background. If msn provides a logo file, in step 110, the logo is inserted into the background. As will be discussed in more detail later, the background template contains a predefined logo location. In one embodiment, the logo provided by the content partner is not altered in the background template.
Steps 102-110 illustrate exemplary steps for generating the background of the UI. The background generated based on the logo, hue value and artwork provided by msn, in one embodiment, will comprise the background for all “arrested development” gallery pages. In other words, as the user moves between “arrested development” gallery pages, the background remains uniform. For example, the msn logo and artwork is displayed in the background and the background is tinted the same shade of orange for every “arrested development” gallery page. In an alternative embodiment, the background may change depending on the gallery page selected by the user.
In step 112, the gallery content is layered over the background. For example, in the “arrested development” gallery page, the gallery content layered over the background may include scenes from various “arrested development” episodes, static or dynamic text, the title of the television show, and so on. In one embodiment, the gallery content is layered over the background in predetermined locations. This way, the gallery pages displayed in MCE present a similar look and feel to the user regardless of the branding.
In one embodiment, the content partner provides a full-color image. In another embodiment, the content partner provides a grey-scale image. In yet another embodiment, the content partner provides a black and white image. For purposes of describing method 200, suppose the content provider provided a full-color image. The full-color image may be stored locally or remotely. For example, the full-color image may be hosted or stored on the content partner's server (or any other storage device) with, for example, a corresponding URL stored in the local memory. Maintaining the image on the content partner's server reduces the amount of local memory required by the system. In step 202, the method 200 retrieves the artwork provided by the content partner.
In step 204, the full-color image provided by the content partner is placed or inserted in the background template. The image location in the background template is predetermined.
In step 206, the full-color image is de-saturated to remove the color from the image. De-saturating an image is known within the art and therefore, additional description is not required. In one embodiment, the full-color image is fully de-saturated. In another embodiment, the full-color image is partially de-saturated. In yet another embodiment, the full-color image is not desaturated at all. If the full-color image is not desaturated at all, step 206 would not be performed.
In step 208, the tinted mask is layered over the background template to blend the de-saturated image (if the image is de-saturated) into the background. In step 106, the mask in the background template was tinted. As shown in
In step 210, the opacity of the image is set in step 210. Setting the opacity gives the desaturated image a watermarked effect. For discussion purposes only, 100% opacity refers to artwork or an image that has near-infinite opacity and 0% opacity refers to an image or artwork that has near-zero opacity. In one embodiment, the opacity of the desaturated image is predefined by the background template. For example, the opacity of the desaturated image may be set to 20% opacity. The opacity of the image may be set to any suitable level regardless of whether the image is desaturated or not.
As discussed above, the content partner may provide a hue value to specify what color the mask will be tinted. In one embodiment, the hue value provided by the content partner is stored in local memory. In step 240, the hue value is retrieved from the local memory. In step 242, the method 230 determines the color associated with the hue value. The HSV model is commonly used in computer graphics applications. In various application contexts, a user must choose a color to be applied to a particular graphical element (e.g., each pixel of the mask). When used in this way, the HSV color wheel is often used. In it, the hue is represented by a circular region. A separate triangular region may be used to represent saturation and value. In this way, a color can be chosen by first picking the hue from the circular region, then selecting the desired saturation and value from the triangular region. In one embodiment, the saturation and value of each pixel in the mask is preset. Thus, by providing the hue, content partner provides the color the mask will be tinted.
Once the color associated with the hue is determined, the method 230 tints the mask with the color, in step 244. For example, if the mask contains a gradient pattern, step 244 tints each pixel in the pattern. In one embodiment, the hue provided by the content partner also provides the color for tinting the gallery content (e.g., text, program title, etc.). Tinting the mask as well as the gallery content strengthens the branding or theme for the entire UI.
The UI template 302 is an exemplary template for a television gallery page in MCE. The template 302 displays episodes of a television show by season. The template 302 includes a logo location 304, an image location 306, a show title location 308, a selected episode display location 310, other episode locations 312-318 and a summary location 320. Each of these locations is predefined in the template 302. In this embodiment, the logo location 304 and the image location 306 are elements or components of the background template. The other components of the UI template 302—the show title location 308, the selected episode display location 310, other episode locations 312-318 and the episode summary location 320—are referred to as “gallery content.” Similar to the logo location 304 and the image location 306, the location of the gallery content is predetermined in the UI template 302. In one embodiment, the content partner may choose the UI template. In another embodiment, the UI template is determined by the type of UI that will be displayed. For example, in MCE, the UI template may be the only layout choice for all television gallery pages.
In the UI template 302, the title of the television show is displayed in location 308. A selected episode 310 from a particular season is displayed in the center of the UI. The selected episode 310 is also the largest episode display. Additional episodes from the same season are displayed in locations 312-318. A summary of the selected episode is displayed in location 320 below the selected episode 310. As discussed above, the background components include the logo, the artwork and the mask. The logo 304 is displayed in the upper left-hand corner of the UI. The image 306 is displayed along the right side of the UI, and extends vertically across the UI substantially from the top to the bottom of the UI.
The episode displayed in the location 310, the additional episode displayed in locations 312-318, the title displayed in location 308 and the summary displayed in location 320 are provided by the content partner. The gallery content displayed in each of these locations will change depending on the user's actions. For example, suppose a user clicks on the episode displayed in locations 312. The mouse click triggers the execution of a callback that moves the episode the user clicked from the location 312 to the location 310. In addition, a summary of the episode the user clicked on is now displayed in location 320. This kind of programming is often referred to as event-driven programming. The event in the example is a mouse click. In event-driven programming, callback execution is asynchronous, controlled by events external to the software. Other methods for creating a UI are within the scope of the technology described herein.
The logo window 404 displays the logo provided by msn in the upper left-hand corner of the background 402 (because msn chose template 302). Here, the logo is msn's network logo—a stylize “msn” with a superscript butterfly image. Msn may, of course, provide any logo it chooses. A watermark version of the image provided by msn is displayed in the watermark window 406 (as predetermined by template 302).
The UI 400 in
The foreground 502 and the background 504 may be tinted “Netflix red.” Netflix initially provides a hue value based on the HSV model. Here, the hue value is associated with the shade of red Netflix would like the foreground 502 and the background 504 to be tinted. The particular color associated with the hue value provided by Netflix is identified. In step 244, the foreground 502 and background 504 are tinted with the color. In one embodiment, the foreground and background are tinted similar to tinting the mask described above. In this embodiment of the UI 500, the movie poster 508 and content partner logo 520 are not tinted. The UI template, similar to the UI template for the UI 400, presets the opacity for each piece of content displayed in the UI 500.
The user interface 500 contains various elements in the foreground 502. By way of example only, the foreground 502 contains a summary area 506, a poster area 508, viewing options 510, a movie summary 512, movie details 514 and the content partner logo 520. The summary 506 displays the title of the movie, the year the movie was released, a movie rating and the date/time the movie will be shown. The summary area 506 displays the movie title (“Babel”), the year Babel was released (2006), the movie rating (4 out of 5 stars) and the showing time (Thursday, June 24 at 8 pm). The summary 506 also includes an “HD” symbol indicating that Babel is available in high definition, and the channel to view the movie (Showtime, Ch. 574).
The UI 500 provides several viewing options. The viewing options 510 provided by the template 500 include “watch trailer,” “record” and “watch” movie. Other options may be available (e.g., download movie). A summary 512 of the movie is displayed below the viewing options 510. In this embodiment, the summary 512 provides a brief synopsis of the movie. Movie details 514 are displayed near the bottom of the UI 500, providing, among other things, the movie rating (R), the movie category (drama) and the available languages (French, English, etc.). The template 500 also includes pivots 530 and 532 for previewing the next movie gallery or a prior movie gallery. The template 500 may include other features.
Similar to the UI 400, the locations for the gallery content is predetermined. For example, the location of the summary 506, the movie poster 508, the viewing options 510, the summary 512 and the logo 520 are all predetermined by the UI template. In this embodiment, an image of the actual Babel movie poster is displayed along the right side of the foreground 502. The predefined location for the content partner's logo 520 is adjacent the movie poster 508. The summary 512 is located in the bottom center of the foreground 502 and has the larger text. The content partner can choose a different UI template to display the information in a different manner. Similar to the UI 400 described above, the content displayed in the UI 500 is provided by the content partner and is layered over the foreground 502.
With reference to
Computer 910 may include a variety of computer readable media. Computer readable media can be any available media that can be accessed by computer 910 and includes both volatile and nonvolatile media, removable and non-removable media. By way of example, and not limitation, computer readable media may comprise computer storage media and communication media. Computer storage media includes volatile and nonvolatile, as well as 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. Computer storage media includes, but is not limited to, random access memory (RAM), read only memory (ROM), EEPROM, flash memory or other memory technology, CD-ROMs, digital versatile discs (DVDs) or other optical disc storage, magnetic cassettes, magnetic tapes, magnetic disc storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by computer 410. Communication media typically 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.
The system memory 930 includes computer storage media in the form of volatile and/or nonvolatile memory such as ROM 931 and RAM 932. A basic input/output system (BIOS) 933, containing the basic routines that help to transfer information between elements within computer 910, such as during start-up, is typically stored in ROM 931. RAM 932 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 920. By way of example, and not limitation,
The computer 910 may also include other removable/non-removable, volatile/nonvolatile computer storage media. By way of example only,
Other removable/non-removable, volatile/nonvolatile computer storage media that can be used in the exemplary operating environment include, but are not limited to, magnetic tape cassettes, flash memory cards, DVDs, digital video tapes, solid state RAM, solid state ROM, and the like. The hard disc drive 941 is typically connected to the system bus 921 through a non-removable memory interface such as interface 940. Magnetic disc drive 951 and optical media reading device 955 are typically connected to the system bus 921 by a removable memory interface, such as interface 950.
The drives and their associated computer storage media discussed above and illustrated in
A user may enter commands and information into the computer 910 through input devices such as a keyboard 962 and a pointing device 961, commonly referred to as a mouse, trackball or touch pad. Other input devices (not shown) may include a microphone, joystick, game pad, satellite dish, scanner, or the like. These and other input devices are often connected to the processing unit 920 through a user input interface 960 that is coupled to the system bus 921, 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 991 or other type of display device is also connected to the system bus 921 via an interface, such as a video interface 990. In addition to the monitor, computers may also include other peripheral output devices such as speakers 997 and printer 996, which may be connected through an output peripheral interface 995.
The computer 910 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 980. The remote computer 980 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 910, although only a memory storage device 981 has been illustrated in
When used in a LAN networking environment, the computer 910 is connected to the LAN 971 through a network interface or adapter 970. When used in a WAN networking environment, the computer 910 typically includes a modem 972 or other means for establishing communication over the WAN 973, such as the Internet. The modem 972, which may be internal or external, may be connected to the system bus 921 via the user input interface 960, or other appropriate mechanism. In a networked environment, program modules depicted relative to the computer 910, or portions thereof, may be stored in the remote memory storage device. By way of example, and not limitation,
The foregoing detailed description of the inventive system has been presented for purposes of illustration and description. It is not intended to be exhaustive or to limit the inventive system to the precise form disclosed. Many modifications and variations are possible in light of the above teaching. The described embodiments were chosen in order to best explain the principles of the inventive system and its practical application to thereby enable others skilled in the art to best utilize the inventive system in various embodiments and with various modifications as are suited to the particular use contemplated. It is intended that the scope of the inventive system be defined by the claims appended hereto.