CHANNEL LINEUP REORGANIZATION BASED ON METADATA

Information

  • Patent Application
  • 20080313675
  • Publication Number
    20080313675
  • Date Filed
    June 12, 2007
    17 years ago
  • Date Published
    December 18, 2008
    15 years ago
Abstract
A user interface representing a channel lineup reorganization based on metadata may be described. An apparatus may comprise a user interface module to display at least one shorter list of relevant channels from a channel lineup. The at least one shorter list of relevant channels is determined by user input and metadata associated with content available via channels in the channel lineup. Other embodiments are described and claimed.
Description
BACKGROUND

Consumer electronics and processing systems are converging. Consumer electronics such as televisions and media centers are evolving to include processing capabilities typically found on a computer. The increase in processing capabilities may allow consumer electronics to execute more sophisticated system and application programs. Such programs typically require robust user interfaces, capable of displaying and navigating through ever increasing amounts of information. Accordingly, there may be a need for improved techniques to solve these and other problems.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 illustrates one embodiment of an environment.



FIG. 2 illustrates one embodiment of a user interface display.



FIG. 3 illustrates one embodiment of a user interface display.



FIG. 4 illustrates one embodiment of a logic flow.



FIG. 5 illustrates one embodiment of a media processing system.





DETAILED DESCRIPTION

Today's digital home environment provides the opportunity for hundreds of television channels. Each channel may represent an analog broadcast channel; a digital broadcast channel; audio-video data pre-recorded and stored on a digital recording device; audio-video data available for streaming, downloading or accessing via the Internet (e.g., Web site); audio-video data stored on a home local area network (LAN); and so forth. Since there may be hundreds of potential channels available, it may be particularly burdensome for a user to browse through the channels via a traditional “TV guide” type grid.


Various embodiments of the invention may be directed to a user interface for a relevant channel lineup reorganization based on metadata. Here, a shorter list of relevant channels from the total channel lineup is determined based on input from a user and metadata associated with content available via the channels. The shorter list of relevant channels Is a subset of the total channels. Both the shorter list of relevant channels and the ability to access the total channel lineup may be presented to the user. Software lensing techniques may be used to navigate, as necessary, through a vertical list of channels to aid a user in the selection of a channel in such a way that the user is not required to “page through”, “tab” or “scroll through” the options. Other embodiments are described and claimed.


Various embodiments may include a user interface arranged to accept user input from a remote control. For example, the user interface module may be arranged to receive movement information representing pointing movements of the remote control. The remote control may be arranged to provide movement information as a user moves the remote control through space, such as moving the remote control to point to different objects displayed on a screen. In this manner, a user may enter information into a media device such as a television or set top box using the remote control as an “air” mouse or free-form pointing device. Alternatively, a user may provide movement information to the user interlace module using other pointing devices implemented as either separate from the remote control or integrated with the remote control. The embodiments are not limited in this context.


Various embodiments may comprise one or more elements or components. An element may comprise any structure arranged to perform certain operations. Each element may be implemented as hardware, software, or any combination thereof, as desired for a given set of design parameters or performance constraints. Although an embodiment may be described with a limited number of elements in a certain topology by way of example, the embodiment may include more or less elements in alternate topologies as desired for a given implementation, it is worthy to note that any reference to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment,



FIG. 1 illustrates one embodiment of an environment in which embodiments of the invention may operate. Referring to FIG. 1, the environment may include a user interface module (UIM) 102 and a remote control 106, UIM 102 may include a media lensing module (MLM) 104. Remote control 106 may include an input/output (I/O) device 108, a gyroscope 110 and control logic 112. Each of these elements is described next in more detail.


In one embodiment, for example, a media processing sub-system may include various application programs, such as UIM 102, For example, UIM 102 may comprise a graphic user interface (GUI) to communicate information between a user and the media processing sub-system. UIM 102 may be used to navigate through large amounts of available channels, for example, via a networked digital home environment. An example media processing sub-system will be described in detail below with reference to FIG. 5.


In various embodiments, UIM 102 may include MLM 104. Alternatively, MLM 104 may be a separate component from UIM 102. MLM 104 may include the appropriate interfaces (e.g., API) to communicate information with UIM 102. MLM 104 may implement different software lensing techniques to increase, enlarge or magnify a size for identifiers associated with an information object or channel on a display when the pointer coincides with the channel, or the pointer is within a predefined distance from the channel. Identifiers may include channel name (e.g., NBC, ABC, BGTV); channel number; metadata associated with the content currently being offered by the channel (e.g., title of content or program, content description, year of release, ratings information, category, stars, a brief synopsis, etc.); a thumbprint of the channel logo; a thumbprint of visual data showing what is currently being offered by the channel; audio related to the visual data; and so forth. In general, a thumbprint may be a bitmap or graphic texture. These examples are not meant to limit the invention.


In various embodiments, UIM 102 may be arranged to receive user input via remote control 106. Remote control 106 may be arranged to allow a user to perform pointing operations similar to a mouse or other pointing device using gyroscope 110. UIM 102 and remote control 106 allow a user to control a pointer on a display even when situated a relatively far distance from the display, such as normal viewing distance (e.g., 10 feet or more), and without the need for typical wired connections.


Remote control 106 may be arranged to control, manage or operate the media processing sub-system of UIM 102 by communicating control information using infrared (IR) or radio-frequency (RF) signals. In one embodiment, for example, remote control 106 may include one or more light-emitting diodes (LED) to generate the infrared signals. The carrier frequency and data rate of such infrared signals may vary according to a given implementation. An infrared remote control may typically send the control information in a low-speed burst, typically for distances of approximately 30 feet, or more. In another embodiment, for example, remote control 106 may include an RF transceiver. The RF transceiver may match the RF transceiver used by the media processing sub-system. An RF remote control typically has a greater distance than an IR remote control, and may also have the added benefits of greater bandwidth and removing the need for line-of-sight operations. For example, an RF remote control may be used to access devices behind objects such as cabinet doors.


The control information may include one or more IR or RF remote control command codes (“command codes”) corresponding to various operations that the device is capable of performing. The command codes may be assigned to one or more keys or buttons included with I/O device 108 for remote control 106. I/O device 108 may comprise various hardware or software buttons, switches, controls or toggles to accept user commands. For example, I/O device 108 may include a numeric keypad, arrow buttons, selection buttons, power buttons, mode buttons, selection buttons, menu buttons, and other controls needed to perform the normal control operations typically found in conventional remote controls. There are many different types of coding systems and command codes, and generally different manufacturers may use different command codes for controlling a given device.


In addition to I/O device 108, remote control 106 may also include elements that allow a user to enter information into a user interface at a distance by moving the remote control through the air in two or three dimensional space. For example, remote control 106 may include gyroscope 110 and control logic 112. Gyroscope 110 may comprise a gyroscope typically used for pointing devices, remote controls and game controllers. For example, gyroscope 110 may comprise a miniature optical spin gyroscope. Gyroscope 110 may be an inertial sensor arranged to detect natural hand motions to move a cursor or graphic on a display, such as a television screen or computer monitor. Gyroscope 110 and control logic 112 may be components for an “in Air” motion-sensing technology that can measure the angle and speed of deviation to move a cursor or other indicator between Point A and Point B, allowing users to select content or enable features on a device waving or pointing remote control 106 in the air. In this arrangement, remote control 106 may be used for various applications, to include providing device control, content indexing, computer pointers, game controllers, content navigation and distribution to fixed and mobile components through a single, hand-held user interface device.


Although some embodiments are described with remote control 106 using a gyroscope 110 by way of example, it may be appreciated that other free-space pointing devices may also be used with remote control 106 or in lieu of remote control 106. For example, some embodiments may use a free-space pointing device made by Hillcrest Labs™ for use with the Welcome HoME™ system, a media center remote control such as WavIt MC™ made by ThinkOptics, Inc., a game controller such as WavIt XT™ made by ThinkOptics, Inc., a business presenter such as WavIt XB™ made by ThinkOptics, Inc., free-space pointing devices using accelerometers, and so forth. The embodiments are not limited in this context.


In one embodiment, for example, gyroscope 110 and control logic 112 may be implemented using the MG1101 and accompanying software and controllers as made by Thomson's Gyration, Inc., Saratoga, Calif. The MG1101 is a dual-axis miniature rate gyroscope that is self-contained for integration into human input devices such as remote control 106. The MG1101 has a tri-axial vibratory structure that isolates the vibrating elements to decrease potential drift and improve shock resistance. The MG1101 can be mounted directly to a printed circuit board without additional shock mounting. The MG1101 uses an electromagnetic transducer design and a single etched beam structure that utilizes the “Coriolis Effect” to sense rotation in two axes simultaneously. The MG1101 includes an integrated analog-to-digital converter (ADC) and communicates via a conventional 2-wire serial interface bus allowing the MG1101 to connect directly to a microcontroller with no additional hardware. The MG1101 further includes memory, such as 1K of available EEPROM storage on board, for example. Although the MG1101 is provided by way of example, other gyroscope technology may be implemented for gyroscope 110 and control logic 112 as desired for a given implementation. The embodiments are not limited in this context.


operation, a user may use remote control 106 to provide information for the user interface module 102 at a distance by moving remote control 106 through the air, similar to an air mouse. For example, a user may point remote control 106 to various objects displayed on the display. Gyroscope 110 may sense the movements of remote control 106, and send movement information representing the movements to a media processing node over wireless communications media 114. UIM 102 may receive the movement information, and move a pointer (e.g., mouse pointer) or cursor in accordance with the movement information on the display. UIM 102 may use the movement information and associated selection commands to perform any number of user defined operations for a networked digital home network, such as navigating option menus, selecting options, searching for media content, selecting media objects, and so forth.


In addition to operating as an air mouse or pointing device using gyroscope 110 and control logic 112, remote control 106 may use other techniques to control a pointer. For example, remote control 106 may include an integrated pointing device. The pointing device may include various types of pointer controls, such as a track or roller ball, a pointing stick or nub, a joystick, arrow keys, direction keys, and so forth. Integrating a pointing device with remote control 106 may facilitate pointing operations for a user. Alternatively, a user may use a pointing device separate from remote control 106, such as various different types of mice or controllers. The pointing device may also be part of another device other than remote control 106, such as a wired or wireless keyboard. The particular implementation for the pointing device may vary as long as the pointing device provides movement information for the user interface module and allows a user to generate the movement information from a distance (e.g., normal viewing distance). The embodiments are not limited in this context.


As discussed above, the networked digital home environment of today provides a user with many channels from which to choose. Typical electronic programming guide X/Y grids are too limiting. FIG. 2 illustrates one embodiment of a user interface display 200. User interface display 200 may provide an example of a GUI display generated by UIM 102. As shown in FIG. 2, user interface display 200 may display one or more shorter lists of relevant channels (i.e., a subset of the total channels), along with the ability to easily access the total channel lineup.


Embodiments of the invention use input from a user to generate one or more shorter lists of relevant channels. Here, the user provides an indication of a rank-order of interest for the channels. This user input or indication of a rank-order of interest may be provided in many ways. For example, a user may select a genre or class of content. Embodiments of the invention use the provided genre and metadata associated with content provided by channels in the lineup to determine relevant channels for the user For example, assume that the user provides the genre “music.” In embodiments, a search or filter is conducted that uses the genre “music” and searches through content metadata for all channels in the lineup. The search identifies channels in the lineup that have music on right now, for example.


Referring to FIG. 2, user interface display 200 may include a number of controls or boxes that are provided to the user to help the system filter the channel or media lineup to a smaller subset. As shown in FIG. 2, example controls or boxes include a box 202 that filters the channels numerically, a box 204 that filters the channels as user favorites, a box 206 that filters the channels alphabetically and a box 210 that filters the channels as a provided genre “comedy.”


For example, the selection of “music” (box 208) from user interface display 200 may create a channel lineup, as shown in FIG. 3. Referring to FIG, 3, two channel lineups 302 and 304 are illustrated. Channel lineup 302 is an example lineup for the selection of “music” from user interface display 200. Channel lineup 302 may include a lineup of three channels ABC, MTV and VH1, along with a small number of other channels ordered alphabetically, for example. The user may then browse through the lineup with the assistance of software lensing techniques (described in more detail below). Such a search easily answers the question for the user of “What is currently on right now that is related to music?”


In embodiments, a user may provide more than one genre. For example, the user may provide the genres of “music,” “comedy” and “sports.” Embodiments of the invention will provide three shorter lists of relevant channels, each list representing what is available to the user for each genre. In addition to the genre, the user may provide a rank ordering for the lineup to be displayed in, for example, numerically by channel or alphabetically by station name.


An indication of the active state of user interface display 200 (channel or box positioned under the cursor) may also be provided. As shown in FIG. 2, the active state may be presented by highlighting the channel or box in some fashion. Here, “music” is shown as the active state by highlighting box 208.


There are many other ways in which embodiments of the invention may determine relevant channels for a user. For example, favorites for a particular user may be determined and a shorter list of relevant channels generated and displayed that represent these favorites. Favorites for a user may be determined implicitly via history of viewing, for example. Favorites for a user may also be determined explicitly via information provided by the user. Referring to FIG. 2, assume that a user's favorites include “History Channel” and “Comedy Central,” among a few other channels. A shorter list of relevant channels that include all channels in the lineup that offer content related to a user's favorites is displayed, as is illustrated by channel lineup 304 in FIG. 3. A keyword search, for example, may be another way to determine relevant channels for a user. The provided examples are not meant to limit the invention.


Note that items in a shorter list of relevant channels of user interface display 200 may represent a channel or a genre, for example. When an item represents a channel, the user may activate the channel directly via a remote control (such as remote control 106 in FIG. 1). When an item represents a genre, the user may activate the item to display all of the channels that contain content relating to the genre.


An indication of “no content available in this particular genre” for user input may also be provided by user interface display 200. As shown in FIG 2, an indication of “no content available in this particular genre” may be presented by highlighting the genre or box in some fashion. Here, “comedy” is shown as having no media or content available, as indicated by the shading of box 210. Other ways to indicate “no content available” may be used by embodiments of the invention.


The user may also provide for a desired state of availability of content. Example states of availability may include: currently being provided or broadcasted, will be provided or broadcasted in the future, and was provided or recorded in the past. Accordingly, embodiments of the invention may consider the user's indication of rank-order of interest and the desired state of availability of content and generate a channel lineup reorganization based on metadata.


As mentioned above, user interface display 200 may display one or more shorter lists of relevant channels, along with the ability to easily access the total channel lineup or the “other” channels in the lineup that were not filtered as relevant channels. Referring to FIG 2, a box 212 labeled as “other” may be activated by the user. When activated, the user may be presented with a channel lineup that includes all channels not represented in one of the shorter lists of relevant channels. Software lensing techniques may be used to navigate, as necessary, through a long vertical list of channels to aid a user in the selection of a channel in such a way that the user is not required to “page through”, “tab” or “scroll through” the options. These software lensing techniques may be used for lists of all lengths, but are especially useful when the number of channels represented by the list is large and thus not easily navigated by the user,


In embodiments, the channel lineup may comprise multiple channels represented in a vertical, stacked or list format. In general, UIM 102 may display a greater number of channels (and its associated identifiers) as the size of each individual channel is decreased, and vice-versa. For example, the channels of the lineup may be relatively small. In some cases, for example, the channels have a font size and thumbprint size that is beyond the visual range of many viewers. As described above, a thumbprint, illustrates associated graphical metadata of what is currently being offered by a particular channel, e.g., image of the channel logo, still image of a television program arid live video clip of a television program. The channel lineup may display a relative large number of channels due in part to the smaller font and thumbprint size.


As a cursor or pointer approaches or coincides with a channel in the lineup, MLM 104 may increase the font size for applicable identifiers (e.g., channel name and number) and may increase the graphic size for applicable thumbprints (e.g., channel logo and visual data thumbprints) thereby making the identifiers large enough for viewing by a user in a real time fashion, just as if a magnifying glass were attached to the cursor (e.g., software lensing). MLM 104 may also increase the font and/or graphic size for identifiers within a predefined area around the channel of interest, such as adjacent to or near the channel under the cursor. This may allow a user to read identifiers for some of the channels within a certain predefined area around the channel of interest. The size of the surrounding channels, however, is typically smaller than the size of the channel of interest, thereby allowing a user to more readily discern the channel of interest. Color may be used as well to provide visual unambiguous feedback to the user which channel is currently the channel of interest. In this manner, a user interface display may convey a relatively larger amount of information (e.g., channels) to a viewer via a display, but only the area of interest plus any surrounding areas is large enough to be read by a viewer as controlled by the viewer via remote control 106. This may be accomplished while reducing the need for scrolling, paging or indexing operations as implemented by conventional user interfaces.


It may be appreciated that the various elements of user interface display 200 and user interface display 300 are provided by way of example only, and more or less elements in different arrangements may be used by UIM 102 and still fall within the intended scope of the embodiments. The embodiments are not limited in this context,


Operations for the above embodiments may be further described with reference to the following figures and accompanying examples. Some of the figures may include a logic flow. Although such figures presented herein may include a particular logic flow, it can be appreciated that the logic flow merely provides an example of how the general functionality as described herein can be implemented. Further, the given logic flow does not necessarily have to be executed in the order presented unless otherwise indicated. In addition, the given logic flow may be implemented by a hardware element, a software element executed by a processor, or any combination thereof. The embodiments are not limited in this context.



FIG. 4 illustrates one embodiment of a logic flow 400. Logic flow 400 may be representative of the operations executed by one or more embodiments described herein, such as UIM 102, and/or MLM 104. Referring to FIG, 4, it is determined how the user wants to reorganize the channel lineup (block 402). The user may enter the state of availability of the content (e.g., current, future or past) (block 404). One or more shorter lists of relevant channels from the total channel lineup is determined based on input from the user (i.e., how the user wants to reorganize the channel lineup) and metadata associated with content, available via the channels (block 406). Both the shorter list(s) of relevant channels and the ability to access the total channel lineup may be presented to the user. Software lensing techniques may be used to navigate, as necessary, through the lists of channels (block 408).



FIG. 5 illustrates one embodiment of a media processing system in which some embodiments of the invention may operate. FIG. 5 illustrates a block, diagram of a media processing system 500. In one embodiment, system 500 may represent a networked digital home environment, although system 500 is not limited in this context.


In one embodiment, for example, media processing system 500 may include multiple nodes. A node may comprise any physical or logical entity for processing and/or communicating information in the system 500 and may be implemented as hardware, software, or any combination thereof, as desired for a given set of design parameters or performance constraints. Although FIG. 5 is shown with a limited number of nodes in a certain topology, it may be appreciated that system 500 may include more or less nodes in any type of topology as desired for a given implementation. The embodiments are not limited in this context.


In various embodiments, a node may comprise, or be implemented as, a computer system, a computer sub-system, a computer, an appliance, a workstation, a terminal, a server, a personal computer (PC), a laptop, an ultra-laptop, a handheld computer, a personal digital assistant (PDA), a television, a digital television, a set top box (STB), a telephone, a mobile telephone, a cellular telephone, a handset, a wireless access point, a base station (BS), a subscriber station (SS), a mobile subscriber center (MSC), a radio network controller (RNC), a microprocessor, an integrated circuit such as an application specific integrated circuit (ASIC), a programmable logic device (PLD), a processor such as general purpose processor, a digital signal processor (DSP) and/or a network processor, an interface, an input/output (I/O) device (e.g., keyboard, mouse, display, printer), a router, a hub, a gateway, a bridge, a switch, a circuit, a logic gate, a register, a semiconductor device, a chip, a transistor, or any other device, machine, tool, equipment, component, or combination thereof. The embodiments are not limited in this context.


In various embodiments, a node may comprise, or be implemented as, software, a software module, an application, a program, a subroutine, an instruction set, computing code, words, values, symbols or combination thereof. The embodiments are not limited in this context.


In various embodiments, media processing system 500 may communicate, manage, or process information in accordance with one or more protocols. A protocol may comprise a set of predefined rules or instructions for managing communication among nodes. A protocol may be defined by one or more standards as promulgated by a standards organization, such as, the International Telecommunications Union (ITU), the International Organization for Standardization (ISO), the International Electrotechnical Commission (IEC), the Institute of Electrical and Electronics Engineers (IEEE), the Internet Engineering Task Force (IETF), the Motion Picture Experts Group (MPEG), and so forth. For example, the described embodiments may be arranged to operate in accordance with standards for media processing, such as the National Television Systems Committee (NTSC) standard, the Advanced Television Systems Committee (ATSC) standard, the Phase Alteration by Line (PAL) standard, the MPEG-1 standard, the MPEG-2 standard, the MPEG-4 standard, the Digital Video Broadcasting Terrestrial (DVB-T) broadcasting standard, the DVB Satellite (DVB-S) broadcasting standard, the DVB Cable (DVB-C) broadcasting standard, the Open Cable standard, the Society of Motion Picture and Television Engineers (SMPTE) Video-Codec (VC-1) standard, the ITU/IEC H.263 standard, Video Coding for Low Bitrate Communication, ITU-T Recommendation H.263v3, published November 2000 and/or the ITU/IEC H.264 standard, Video Coding for Very Low Bit Rate Communication, ITU-T Recommendation H.264, published May 2003, and so forth. The embodiments are not limited in this context.


In various embodiments, the nodes of media processing system 500 may be arranged to communicate, manage or process different types of information, such as media information and control information. Examples of media information may generally include any data or signals representing content meant for a user, such as media content, voice information, video information, audio information, image information, textual information, numerical information, alphanumeric symbols, graphics, and so forth. Control information may refer to any data or signals representing commands, instructions or control words meant for an automated system. For example, control information may be used to route media information through a system, to establish a connection between devices, instruct a node to process the media information in a predetermined manner, monitor or communicate status, perform synchronization, and so forth. The embodiments are not limited in this context.


In various embodiments, media processing system 500 may be implemented as a wired communication system, a wireless communication system, or a combination of both. Although media processing system 500 may be illustrated using a particular communications media by way of example, it may be appreciated that the principles and techniques discussed herein may be implemented using any type of communication


media and accompanying technology. The embodiments are not limited in this context.


In various embodiments, media processing system 500 may include one or more media source nodes 502-1-n. Media source nodes 502-1-n may comprise any media source capable of son icing or delivering media information and/or control information to media processing node 506. More particularly, media source nodes 502-1-n may comprise any media source capable of sourcing or delivering digital audio and/or video (AV) signals to media processing node 506. Examples of media source nodes 502-1-n may include any hardware or software element capable of storing and/or delivering media information, such as a. DVD device, a VHS device, a digital VHS device, a personal video recorder (PVR), a computer, a gaming console, a Compact Disc (CD) player, computer-readable or machine-readable memory (e.g., hard disk drive used to store PVR content), a digital camera, camcorder, video surveillance system, teleconferencing system, telephone system, medical and measuring instruments, scanner system, copier system, television system, digital television system, set top boxes, personal video records, server systems, computer systems, personal computer systems, digital audio devices (e.g., MP3 players), and so forth. Other examples of media source nodes 502-1-n may include media distribution systems to provide broadcast or streaming analog or digital AV signals to media processing node 506. Examples of media distribution systems may include, for example, Over The Air (OTA) broadcast systems, terrestrial cable systems (CATV), satellite broadcast systems, and so forth. It is worthy to note that media source nodes 502-1-n may be internal or external to media processing node 506, depending upon a given implementation. The embodiments are not limited in this context.


In various embodiments, media processing system 500 may comprise a media processing node 506 to connect to media source nodes 502-1-n over one or more communications media 504-1-n. Media processing node 506 may comprise any node that is arranged to process media information received from media source nodes 502-1-n.


In various embodiments, media processing node 506 may include a media processing sub-system 508. Media processing sub-system 508 may comprise a processor, memory, and application hardware and/or software arranged to process media information received from media source nodes 502-1-n. For example, media processing sub-system 508 may be arranged to perform various media operations and user interface operations as described in more detail below; Media processing sub-system 508 may output the processed media information to a display 510. The embodiments are not limited in this context.


To facilitate operations, media processing sub-system 508 may include a user interface module and a media lensing module (such as UIM 102 and MLM 104 of FIG. 1) to provide software lensing and remote user input. Software Sensing may refer to techniques for increasing, enlarging, or magnifying an area when a pointer or cursor coincides or approaches the area. This may be accomplished in real time with reduced delay, rather than by selection or loitering over a given area for a certain amount of time as in conventional techniques. Although software lensing is typically implemented in software, it may be appreciated that all or portions of the software lensing technique may be performed by software, hardware, or a combination of both. The embodiments are not limited in this context.


In various embodiments, the user interface module may allow a user to control certain operations of media processing node 506, such as various system programs or application programs. For example, assume media processing node 506 comprises a television that has access to user menu options provided via media source node 502-1-n. These menu options may be provided for viewing or listening to media content reproduced or provided by media source node 502-1-n. The user interface module may display user options to a viewer on display 510 in the form of a graphic user interface (GUI), for example. In such cases, a remote control (such as remote control 106 of FIG. 1) is typically used to navigate through such basic options.


Numerous specific details have been set forth herein to provide a thorough understanding of the embodiments. It will be understood by those skilled in the art, however, that the embodiments may be practiced without these specific details. In other instances, well-known operations, components and circuits have not been described in detail so as not to obscure the embodiments. It can be appreciated that the specific structural and functional details disclosed herein may be representative and do not necessarily limit the scope of the embodiments.


Various embodiments may be implemented using one or more hardware elements. In general, a hardware element may refer to any hardware structures arranged to perform certain operations. In one embodiment, for example, the hardware elements may include any analog or digital electrical or electronic elements fabricated on a substrate. The fabrication may be performed using silicon-based integrated circuit (IC) techniques, such as complementary metal oxide semiconductor (CMOS), bipolar, and bipolar CMOS (BiCMOS) techniques, for example. Examples of hardware elements may include processors, microprocessors, circuits, circuit elements (e.g., transistors, resistors, capacitors, inductors, and so forth), integrated circuits, application specific integrated circuits (ASIC), programmable logic devices (PLD), digital signal processors (DSP), field programmable gate array (FPGA), logic gates, registers, semiconductor device, chips, microchips, chip sets, and so forth. The embodiments are not limited in this context.


Various embodiments may be implemented using one or more software elements. In general, a software element may refer to any software structures arranged to perform certain operations. In one embodiment, for example, the software elements may include program instructions and/or data adapted for execution by a hardware element, such as a processor. Program instructions may include an organized list of commands comprising words, values or symbols arranged in a predetermined syntax, that when executed, may cause a processor to perform a corresponding set of operations. The software may be written or coded using a programming language. Examples of programming languages may include C, C++, BASIC, Perl, Matlab, Pascal, Visual BASIC, JAVA, ActiveX, assembly language, machine code, and so forth. The software may be stored using any type of computer-readable media or machine-readable media. Furthermore, the software may be stored on the media as source code or object code. The software may also be stored on the media as compressed and/or encrypted data. Examples of software may include any software components, programs, applications, computer programs, application programs, system programs, machine programs, operating system software, middleware, firmware, software modules, routines, subroutines, functions, methods, procedures, software interfaces, application program interfaces (API), instruction sets, computing code, computer code, code segments, computer code segments, words, values, symbols, or any combination thereof. The embodiments are not limited in this context.


Some embodiments may be described using the expression “coupled” and “connected” along with their derivatives. It should be understood that these terms are not intended as synonyms for each other. For example, some embodiments may be described using the term “connected” to indicate that two or more elements are in direct physical or electrical contact with each other. In another example, some embodiments may be described using the term “coupled” to indicate that two or more elements are in direct physical or electrical contact. The term “coupled,” however, may also mean that two or more elements are not in direct contact with each other, but yet still co-operate or interact with each other. The embodiments are not limited in this context.


Some embodiments may be implemented, for example, using any computer-readable media, machine-readable media, or article capable of storing software. The media or article may include any suitable type of memory unit, memory device, memory article, memory medium, storage device, storage article, storage medium and/or storage unit, such as any of the examples described with reference to memory. The media or article may comprise memory, removable or non-removable media, erasable or non-erasable media, writeable or re-writeable media, digital or analog media, hard disk, floppy disk. Compact Disk Read Only Memory (CD-ROM), Compact Disk Recordable (CD-R), Compact Disk Rewriteable (CD-RW), optical disk, magnetic media, magneto-optical media, removable memory cards or disks, various types of Digital Versatile Disk (DVD), subscriber identify module, tape, cassette, or the like. The instructions may include any suitable type of code, such as source code, object code, compiled code, interpreted code, executable code, static code, dynamic code, and the like. The instructions may be implemented using any suitable high-level, low-level, object-oriented, visual, compiled and/or interpreted programming language, such as C, C++, Java, BASIC, Perl, Matlab, Pascal, Visual BASIC, JAVA, ActiveX, assembly language, machine code, and so forth. The embodiments are not limited in this context.


Unless specifically stated otherwise, it may be appreciated that terms such as “processing,” “computing,” “calculating,” “determining,” or the like, refer to the action and/or processes of a computer or computing system, or similar electronic computing device, that, manipulates and/or transforms data represented as physical quantities (e.g., electronic) within the computing system's registers and/or memories into other data similarly represented as physical quantities within the computing system's memories, registers or other such information storage, transmission or display devices. The embodiments are not limited in this context.


As used herein any reference to “one embodiment” or “an embodiment” means that a particular element, feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment.


While certain features of the embodiments have been illustrated as described herein, many modifications, substitutions, changes and equivalents will now occur to those skilled in the art. It is therefore to be understood that the appended claims are intended to cover all such modifications and changes as fall within the true spirit of the embodiments.

Claims
  • 1. An apparatus, comprising: a user interface module to display at least one shorter list of relevant channels from a channel lineup, wherein the at least one shorter list of relevant channels is determined by user input and metadata associated with channels in the channel lineup.
  • 2. The apparatus of claim 1, wherein the user input is represented by one or more of a genre, a favorites indication for the user, and a keyword search.
  • 3. The apparatus of claim 1, wherein the channel lineup represents one of: what is currently being offered by the channels, what will be offered in the future by the channels, and what was offered in the past or recorded by the channels.
  • 4. The apparatus of claim 1, further comprising: a media lensing module to increase a size of one or more identifiers of a channel of interest in the channel lineup when a pointer coincides with the channel of interest.
  • 5. The apparatus of claim 1, wherein the channel lineup is displayed in a vertical format.
  • 6. The apparatus of claim 1, wherein the user interface module to receive movement information from a remote control, and move the pointer in response to the movement information.
  • 7. The apparatus of claim 6, wherein the remote control is a free-form pointing device.
  • 8. A method, comprising: determining at least one shorter list of relevant channels from a channel lineup, wherein the at least one shorter list of relevant channels is determined by user input and metadata associated with channels in the channel lineup; anddisplaying the at least one shorter list of relevant channels.
  • 9. The method of claim 8, wherein the user input is represented by one or more of a genre, a favorites indication for the user, and a keyword search.
  • 10. The method of claim 8, wherein the channel lineup represents one of: what is currently being offered by the channels, what will be offered in the future by the channels, and what was offered in the past or recorded by the channels.
  • 11. The method of claim 8, further comprising: increasing a size of one or more identifiers of a channel of interest in the channel lineup when a pointer coincides with the channel of interest.
  • 12. The method of claim 8, wherein the channel lineup is displayed in a vertical format.
  • 13. The method of claim 8, further comprising: receiving movement information from a remote control; andmoving the pointer in response to the movement information.
  • 14. The method of claim 13, wherein the remote control is a free-form pointing device.
  • 15. A machine-readable medium containing instructions which, when executed by a processing system, cause the processing system to perform a method, the method comprising: determining at least one shorter list of relevant channels from a channel lineup, wherein the at least one shorter list of relevant channels is determined by user input and metadata associated with channels in the channel lineup; anddisplaying the at least one shorter list of relevant channels.
  • 16. The machine-readable medium of claim 15, wherein the user input is represented by one or more of a genre, a favorites indication for the user, and a keyword search.
  • 17. The machine-readable medium of claim 15, wherein the channel lineup represents one of: what is currently being offered by the channels, what will be offered in the future by the channels, and what was offered in the past or recorded by the channels.
  • 18. The machine-readable medium of claim 15, further comprising: increasing a size of one or more identifiers of a channel of interest in the channel lineup when a pointer coincides with the channel of interest.
  • 19. The machine-readable medium of claim 15, wherein the channel lineup is displayed in a vertical format.
  • 20. The machine-readable medium of claim 15, further comprising; receiving movement information from a remote control; andmoving the pointer in response to the movement information,wherein the remote control is a free-form pointing device.
RELATED APPLICATIONS

This application is a related to a commonly owned U.S. patent application Ser. No. 11/323,088 titled “A User Interface For A Media Device” and filed on Dec. 30, 2005; a commonly owned U.S. patent application Ser. No. 11/322,937 titled “Techniques For Generating Information Using A Remote Control” and filed on Dec. 30, 2005; a commonly owned U.S. patent application Ser. No. 11/322,580 titled “A User Interface with Software Lensing” and filed on Dec. 30, 2005; a commonly owned U.S. patent application Ser. No. ______ titled “A User Interface with Software Leasing for Very Long Lists of Content” and filed on Jun. 12, 2007; and a commonly owned U.S. patent application Ser. No. ______ titled “A User Interface for Fast Channel Browsing” and filed on Jun. 12, 2007, all of which are incorporated herein by reference.