WO2006113291A2 - Registration of applications and complimentary features for interactive user interfaces - Google Patents

Registration of applications and complimentary features for interactive user interfaces

Info

Publication number
WO2006113291A2
WO2006113291A2 PCT/US2006/013731 US2006013731W WO2006113291A2 WO 2006113291 A2 WO2006113291 A2 WO 2006113291A2 US 2006013731 W US2006013731 W US 2006013731W WO 2006113291 A2 WO2006113291 A2 WO 2006113291A2
Authority
WO
WIPO (PCT)
Prior art keywords
application
computer
exemplary
graphical user
host computer
Prior art date
Application number
PCT/US2006/013731
Other languages
French (fr)
Other versions
WO2006113291A3 (en
Inventor
David Ethan Zoller
David R. Fulmer
Dean W. Talley
Hugh C. Vidos
Michael E. Creasy
John Elsbree
Original Assignee
Microsoft Corporation
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Microsoft Corporation filed Critical Microsoft Corporation
Priority to JP2008506652A priority Critical patent/JP5123169B2/en
Priority to EP06749936A priority patent/EP1872584A4/en
Priority to CN2006800173593A priority patent/CN101490656B/en
Publication of WO2006113291A2 publication Critical patent/WO2006113291A2/en
Publication of WO2006113291A3 publication Critical patent/WO2006113291A3/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0481Interaction techniques based on graphical user interfaces [GUI] based on specific properties of the displayed interaction object or a metaphor-based environment, e.g. interaction with desktop elements like windows or icons, or assisted by a cursor's changing behaviour or appearance
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/451Execution arrangements for user interfaces
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/47End-user applications
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/47End-user applications
    • H04N21/472End-user interface for requesting content, additional data or services; End-user interface for interacting with content, e.g. for content reservation or setting reminders, for requesting event notification, for manipulating displayed content
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2209/00Indexing scheme relating to G06F9/00
    • G06F2209/54Indexing scheme relating to G06F9/54
    • G06F2209/545Gui
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/47End-user applications
    • H04N21/478Supplemental services, e.g. displaying phone caller identification, shopping application

Definitions

  • WINDOWS® XP® MEDIA CENTER WINDOWS® XP® MEDIA CENTER
  • operating system includes features that allow a user to store, share, and enjoy
  • PC media center personal computer
  • a user interface and associated input methods differs in many ways when compared to the user experience associated with input via a keyboard and a mouse.
  • a user interface and associated input methods differs in many ways when compared to the user experience associated with input via a keyboard and a mouse.
  • the 2' context is more akin to reading a
  • exemplary methods, devices, systems, etc. pertain to establishing or managing
  • An exemplary computer-implementable method includes receiving a
  • the registering comprises providing one or more entry points
  • each entry point corresponds to at least one of the
  • FIG. 1 is a diagram of an exemplary context that includes a display to
  • FIG. 2 is a diagram of an exemplary registration method
  • FIG. 3 is a diagram of an exemplary registration application for
  • FIG. 4 is a diagram of an exemplary arrangement whereby a
  • registration application optionally allows for registration of an application that can
  • FIG. 5 is a diagram of an exemplary registration application
  • FIG. 6 is a diagram of an exemplary computing environment, which
  • an application is registered with a host.
  • registration or complimentary features may provide security such as restricting the
  • security features may apply to an application that communicates with the host via a
  • FIG. 1 shows an exemplary context 100 that has a context boundary
  • the context boundary 102 is typically defined by a distance or distances between a user and a user interface (UI).
  • UI user interface
  • context 100 is akin to a distance typically found in viewing TV.
  • a display 110 displays a UI 112 and a remote control 120
  • a wireless communication port e.g., infrared, etc.
  • controller for the display 110 may be a computer located proximate to the display
  • a user interface that works well at a distance of about ten feet should
  • a typical remote control (e.g., the remote control 120) is
  • buttons are buttons. And while a greater viewing distance provides a more comfortable
  • a user interface e.g., a user interface
  • a UI refers to a graphical user interface, for example, as
  • a hosted application serves as a host for an application, which may be referred to as a hosted application.
  • shared viewport When the shared viewport is visible, it will cover any
  • the viewport may have a width of 274 pixels and a height of 192
  • framework manages execution of an application that runs concurrently with another
  • the platform served as a host to the
  • relationship between a platform and an application may be parent-child, child-
  • a platform typically serves as a host and an
  • platform may expose one or more functionalities to the application (e.g., through
  • a platform may also manage an application.
  • a platform generally refers to a media platform
  • a media platform may provide other functionality.
  • a media platform may provide
  • a media platform may be
  • appliances e.g., kitchen, climate, security, cleaning, etc.
  • a host may
  • a platform generally relies on a computer for operation.
  • a host
  • platform may execute on a host computer or a host system.
  • a host computer or a host system.
  • a host system For example, a host
  • computer may include software for media presentations, organization, acquisitions,
  • Such a host computer generally provides for display of graphical user interfaces. Further, such a host computer may receive directly or indirectly
  • modules, applications, etc. refer to a host system, a host platform or a host
  • a host may include
  • an HTML application may seek to establish a
  • script or other coded functionality may include script or other coded functionality (consider, e.g., dynamic HTML,
  • Such an assembly or other code e.g., managed,
  • an add-in to the Media Center EditionTM platform e.g., an add-in to the Media Center EditionTM platform.
  • the type of relationship between an add-in application and the platform may depend on any of a variety of
  • the platform may be considered a host and the add-
  • An add-in application typically extends the
  • An add-in may be a background add-in or an
  • exemplary platform may require that all applications (e.g., HTML applications and
  • a platform may use such information to manage the application, to allow for one or
  • platform may include an exemplary registration application that allows for
  • an exemplary registration application or method may allow for unregistration of an
  • Fig. 2 shows an exemplary scheme 200 that includes an exemplary
  • the registration application 210 can register or
  • pages 230 which are sometimes referred to as "pages" (consider, e.g., a
  • the UIs include UIs for categories such as “My Music”, “My TV”, “My Pictures”,
  • an entry point may be associated with a category that can determine the location(s)
  • a category such as
  • My Music may have a main page and various other pages that form a hierarchy
  • the user may invoke the on-demand add-in through entry points
  • add-in may include several UI components, an image (e.g., a Portable Network
  • PNG Graphics
  • point may also have an associated category that can determine the location(s) in the
  • An add-in may have
  • platform may limit an add-in application's ability to present UI components.
  • an add-in application may be associated with a Web site, an HTML
  • a registration process may add information to a
  • platform 220 or a user may restrict operations of the
  • the application 250 is typically a software
  • HTML application it may consist of one or more HTML pages that use XML
  • an HTML application typically seeks to display UI components.
  • application 210 may rely on information specified in the form of elements in a
  • markup language For example, sample syntax follows for an exemplary
  • HTML applications add-in applications or other types of applications, as
  • CompanyName company name
  • startlmage path to image
  • thunibnaillmage path to image
  • sample syntax includes various attributes including title, id, url,
  • the title attribute is a string that specifies the title of the
  • the id attribute is a string that specifies the globally unique identifier
  • the url attribute is a string that specifies the path to the application.
  • the bgColor attribute may be used or a BGColor property to set a
  • This attribute may also be referred to as a graphical user interface 230 Start menu. This attribute may also be referred to as a graphical user interface 230 Start menu. This attribute may also be referred to as a graphical user interface 230 Start menu. This attribute may also be referred to as a graphical user interface 230 Start menu. This attribute may also be referred to as a graphical user interface 230 Start menu. This attribute may also be referred to as a graphical user interface 230 Start menu. This attribute may also be referred to start menu.
  • the CompanyName attribute is a string that specifies the name of the
  • action provides the user with some degree of security during a registration process.
  • the startlmage attribute is a string that specifies a path to an image
  • the thumbnaillmage attribute is a string that
  • sharedViewport attribute is a string that indicates the state of a shared viewport.
  • the sharedViewport attribute may be used with so-called Media
  • MCL Center Link
  • file may be used to add or register an HTML application.
  • the exemplary registration application 210 may
  • An "entrypoint” element may be used to define each entry point into the platform 220.
  • an entrypoint element may be used to define each entry point into the platform 220.
  • entrypoint element includes the following sample syntax:
  • This sample element includes various attributes.
  • the id attribute is a
  • GUID i.e., a globally unique identifier
  • the url attribute is a string that specifies the path to an
  • the run attribute is a string that specifies
  • the addin attribute is a comma-separated string that
  • the title attribute is a string that identifies the entry point and it may appear at the top of a page when the entry point
  • the description attribute is a string that describes a purpose of the entry
  • the imageUrl attribute is a string that specifies a path to an image (e.g., PNG
  • the context attribute is an
  • the exemplary entrypoint element may be used by the registration
  • an entrypoint element for an application should include the url in the
  • attribute element can be a string in the following format: "className,
  • className is the full name (assembly and class) of the add-in application's
  • assemblyName is the name of the add-in application's assembly; version is the
  • the exemplary registration application 210 may also associate the
  • the platform 220 shows various graphical user interfaces 230 for
  • an exemplary category element may specify
  • This exemplary element includes a category attribute that is a string
  • this attribute may be "Background”.
  • this attribute may be
  • Services ⁇ Radio, and Services ⁇ TV An exemplary host suited for media presentation
  • Another exemplary element may specify capabilities required by the
  • the application 250 may require certain capabilities
  • a machine e.g., a computer such as in the
  • An exemplary element may have
  • a directX is a string that indicates whether the
  • An audio attribute is a string that indicates
  • a video attribute is a string that
  • attribute is a string that indicates whether the application contains graphics that
  • a console attribute is a string that indicates
  • registration process or an unregistration process (e.g., 204, 208) that may include
  • the application element may specify a
  • the category element may specifies an entry point into the platform 220; the category element
  • a user may optionally limit resources available to an application through, for example, selection
  • exemplary registration application 210 may be an exemplary method that uses the
  • sXMLApplnfo parameter is a string that contains the application, entrypoint, and
  • category elements e.g., as XML elements. Again, these elements identify the
  • this parameter can specify the path to a markup
  • the fUnRegister parameter is a Boolean
  • This parameter may have a return value, for
  • an entry point may be a link to a particular page in an HTML application, and may include an
  • each entry point is
  • parameter contains a single application element with one or more nested entrypoint
  • Each entrypoint element typically has at least one nested category
  • the host may display a dialog box
  • HTML application may request use of an HTML application or an entity may require a host system to
  • components of an application may require registration with the host system prior to
  • an application may call the exemplary method.
  • a surrogate or helper application may call the exemplary method to
  • the exemplary method may throw exceptions after being called, for
  • This exemplary segment includes a call to the exemplary method
  • RegisterApplication and it specifies various information as already discussed, such
  • GUIDs as, but not limited to, an entry point URL, a category, and various ids (e.g., GUIDs).
  • multiple entry points for an application may be registered with a host system.
  • an application may occur through use of an exemplary registration application or
  • FIG. 3 shows a block diagram of two exemplary scenarios 300 that use
  • an exemplary registration application 310 (e.g., consider the RegisterApplication
  • exemplary scenarios involves an application 350 resident on a remote computer 360
  • the network 302 may be any suitable network, such as, but not limited to, wired or
  • the former scenario pertains to an example where a remote system may seek to register an application with a platform via
  • Such an exemplary registration application may register or unregister applications.
  • a surrogate or helper application may operate on behalf of the
  • helper application 350 where the helper application is executing locally or remotely.
  • process includes calling the registration application 310 to register the application
  • the registration application 310 is an application program
  • API application programming interface
  • platform 320 or optionally other applications resident on the platform 320.
  • the registration application 310 includes a set of
  • the set of procedures for information exchange may be
  • the registration application 310 the registration application 310
  • an entry point element 314 for exchange of information about one or more entry points for the application 350 with respect to the platform
  • the platform 320 may include a page (e.g., graphical user interface)
  • Such a page may also list each registered application (e.g., a settings page). Such a page may also list each registered application (e.g., a settings page). Such a page may also list each registered application (e.g., a settings page).
  • An exemplary computer-implementable method includes receiving a
  • the host computer (or host platform or host system)
  • graphical user interfaces having a collection of graphical user interfaces (e.g., the graphical user interfaces
  • each entry point provides one or more entry points for the application wherein each entry point
  • an application corresponds to at least one of the graphical user interfaces of the collection of graphical user interfaces. According to such an exemplary method, an application
  • standalone executable code e.g., a stand alone executable code application
  • executing may be any type of hardware or firmware. According to such an exemplary method, executing may be any type of hardware. According to such an exemplary method, executing may be any type of hardware. According to such an exemplary method, executing may be any type of hardware. According to such an exemplary method, executing may be any type of hardware. According to such an exemplary method, executing may be any type of hardware. According to such an exemplary method, executing may be any type of hardware.
  • application may issue the call on behalf of the application where the helper
  • application is executing locally or remotely.
  • the application may be an HTML
  • each entry point may corresponds to a parameter
  • GUID globally unique identifier
  • an entry point may correspond to a new information graphical
  • application (e.g., the application 250 or the application 350) may include one or
  • graphical user interfaces full-screen or partial screen
  • audio user interfaces may also be included, generally, a hosted application includes
  • Fig. 4 shows an exemplary arrangement of features 400 that includes
  • the functional modules include a "Used for Services” module 482 (e.g., for media
  • a “New For Me” module 486 (e.g., for notification of "freshness",
  • module 486 may be referred to as a "New Information” module whereby an
  • the "Used for Service” module 482 provides for associating an
  • a user may access such a page from one or more extensibility applications (e.g., the application 250, the application 350, etc.).
  • a user may access such a page from one or more extensibility applications (e.g., the application 250, the application 350, etc.).
  • the module 486 may become visible
  • a "New For Me” item may include the title of the new
  • each item includes or
  • destination for possible consumption of the content e.g., purchase, download,
  • an application may interact with the registration application 410.
  • an application may interact with the registration application 410.
  • an application may interact with the registration application 410.
  • an application may interact with the registration application 410.
  • an application may interact with the registration application 410.
  • Restrictions may apply to the application's ability to register items, for example, a
  • a remote application may be prohibited from registering "New For
  • the exemplary "New For Me” module 486 may sort items by creating
  • time stamps for example, with the most recent item first on a list.
  • a platform may include a settings page. Such a page or other feature may allow a user to prevent a registered application from adding "New For Me"
  • Such features may be a component of a registration application (e.g., the
  • the registered application of the service may call the
  • the "New For Me” module 486 may include a method that can add or
  • This method includes a title parameter, which is a string with, for
  • an updated title and a description parameter, which is a string with an
  • This exemplary method may return a value (e.g., a Boolean
  • the exemplary "More With This" module 488 provides a context
  • menu for an item or various items e.g., image files, sound files, etc.
  • items e.g., image files, sound files, etc.
  • Fig. 4 shows an exemplary user interface 487 with a context menu 489.
  • context menu 489 includes a ⁇ other app.> item, which may be used as an entry
  • a context menu e.g., the context menu 489.
  • FIG. 5 shows an exemplary registration application 510 and various
  • exemplary platform, computer or system may include any of the various modules or
  • modules pertain to operation of an
  • Each exemplary module may be optionally embodied as computer-executable
  • An IsForegroundApplication module 571 includes a method that can
  • the module 571 may include one or more parameters.
  • an entryPointld parameter may be a string containing a
  • Such a module may restrict actions take by an application or a service
  • the application may
  • graphic may be available whereby an application that is not the foreground
  • an application can indicate that it has information for a user (e.g., a small icon, a small
  • Such a module may also provide an application permission to cause
  • the application may be able to cause display of various information, navigation of a user to a movie service page, delivery of
  • An IsMediaFullScreen module 572 is a property that includes a
  • a registered application may use this property to determine whether a
  • Such a full screen module may allow an application to determine
  • the application may cause presentation of
  • a screen may appear when a
  • an exemplary full screen module may allow a movie or other media application
  • a user uses an application to navigate to the
  • OSCAR(S)® ACADEMY AWARD(S)® web page (Academy of Motion Picture Arts and Sciences) and selects a "behind-the-scenes" video interview with actor X.
  • the video is displayed as full screen video or substantially full screen (e.g., a
  • the application may be able to
  • ASX files are textual command files that
  • ASX files are generally small in size (e.g., about
  • a browser application can
  • application may provide play list functionality, even for a play list generated or
  • an application may inquire as to its
  • Module 573 Return to Application
  • the ReturnToApplication module 573 includes a method that can
  • the module 573 may return a user to an
  • the module 573 may have syntax such as
  • module 572 to determine whether the current media is in full-screen mode.
  • modules 571, 572, 573 can enhance a user's
  • An exemplary computer-implementable method includes
  • an application e.g., the application 250, the application 350,
  • a host computer or host platform or host system
  • the host executing on a host computer (or host platform or host system)
  • the host executing on a host computer (or host platform or host system)
  • the host executing on a host computer (or host platform or host system)
  • the host executing on a host computer (or host platform or host system)
  • the host executing on a host computer (or host platform or host system)
  • the host executing on a host computer (or host platform or host system)
  • the host computer or host platform or host system
  • graphical user interfaces e.g., the graphical user
  • executing may occur, for example, as a web page or script in a
  • browser associated with the host computer e.g., an embedded browser
  • an application may be standalone executable code
  • a surrogate or helper application may issue the call on behalf of the
  • helper application where the helper application is executing locally or remotely.
  • the aforementioned exemplary method may provide a value that
  • Such an exemplary method may further include permitting or restricting an
  • an exemplary method may, in
  • response to a call by an application indicate whether the application is operating in
  • the module has invoked playing media in a full screen mode.
  • 572 may provide a value indicating whether the application is operating in a full
  • 573 may use such a value to indicate whether the application can regain the focus of
  • any of the various modules or methods described herein may be at least
  • a DoesMCLExist module 574 includes a method that can indicate
  • the module may include one or more parameters such as a category
  • Such a category parameter may be a number that
  • a URL parameter may be a
  • HTML Web application e.g., containing "http://"
  • the module 574 may return a Boolean value that indicates whether the MCL file
  • This module may throw an exception if the URL and the caller's fully
  • GUID level security mechanism may be used in addition to or as an alternative to
  • information may be denied (e.g., only information indicating that access was denied
  • navigational control may be denied. For example, where a match does not occur at
  • the calling application may have limited
  • Module 575 Entry Point Registered
  • An IsEntryPointRegistered module 575 includes a method that can
  • Such a method may include the
  • entryPointld is a string containing a GUID that uniquely identifies an application
  • This method may return a Boolean value that is true if the entry point is
  • a MediaCenterControlLevel module 576 is a property that includes a
  • module name includes “MediaCenter”, such a module
  • This property retrieves the
  • property value may be a read-only number that indicates a control level. It may be a
  • applications can retrieve settings that indicate the current status of the host system; and "4" applications can retrieve metadata associated with the host system or the
  • host system 's user(s), for example, a user's postal code.
  • a host system may include settings that let a
  • Such settings can determine whether such
  • the user may cause a registered user
  • the application may call an exemplary host control level module to
  • application of the media service can call and access metadata for the currently
  • registered application may notify the user "if you like the current song, then try this
  • a user may wish for a consistent experience
  • a registered application for a media service may
  • a user may listen to Song X whereby
  • the service provider is denied metadata identifying Song X as a currently played song, i.e., the service provider may, through use of a registered application calling a
  • An exemplary host control level module may provide for one or more
  • a first level may be a metadata level of access and a
  • second level may be a relatively unrestricted level of control over a host system.
  • module may provide the application with a script error. Access to levels or
  • information regarding access is optionally controllable by a user (e.g., selection per
  • a NavigateToPage module 577 includes a method that can direct a
  • Such a method may have the
  • a pageld parameter is a string
  • GUID identifier
  • a params parameter is a string that contains
  • the value of the pageld parameter determines
  • the host system may use the
  • the params parameter is a string containing the visualization
  • the host system may use the default visualization or the previously-selected preset. Similarly, if a preset is specified but not a visualization name, the host system may
  • an exemplary navigate to page module can allow an
  • the registered application may cause one or more of such
  • Such an application may have access to an
  • exemplary navigation module that navigates a user to a "My Pictures" page of the
  • the application may cause a slide show or other display or
  • the application may optionally rely on a slide show application of
  • An application may have access to file path
  • a user may use a registered application
  • a page may include a button that allows a user to
  • the application may then assist a user in next steps (e.g., sell, discard, view, rent
  • An onAPMResume module 578 operates as an event that occurs when
  • An application e.g., the application 250,
  • the application 350, etc. may use this event to refresh data once the host system
  • a user may also cause suspension by entering a command.
  • new service may have been a foreground application or assigned similar priority.
  • Display may be partial or full screen. Applications that are not news centric or otherwise dependent on timeliness of information may be denied
  • a ParentalControl module 579 is a property that retrieves an object
  • ParentalControlSelector object e.g., a ParentalControlSelector object that is used to select the type of parental
  • the property includes a property value which is a read ⁇
  • an application e.g., the application 250, the application 350, etc.
  • An exemplary parental control feature may rely on entry of a PIN to
  • a user may be prompted to enter such a PIN via
  • a registered application may request entry of
  • the application may call the exemplary parental control module 579 (e.g., an API call).
  • the application may be provided with limited information
  • a host system may include a single parental control setting (e.g.,
  • Logic may express the settings as
  • the application may call the exemplary parental
  • control module 579 to determine if the host system's settings permit viewing of the
  • the application may determine whether parental control
  • the host system is enabled by the host system.
  • the host system may return a
  • the module may return a blob of data expected and analyzable to some
  • the calling application may use the information
  • the application may call for entry of
  • an exemplary parental control module may
  • user input and others may require input of a user and return information substantially unrelated to the input (e.g., where entry of a PIN is requested, return
  • the exemplary module may
  • a user may optionally allow for release of certain information (e.g.,
  • a return from a call to such a module may indicate playing OK but harvesting of
  • An exemplary computer-implementable method includes receiving a
  • a host computer or host platform or host system
  • the host computer having a
  • graphical user interfaces e.g., the graphical user interfaces 230
  • an application may be standalone
  • executable code e.g., a stand alone executable code application executing on the host.
  • a surrogate or helper application may issue the call on
  • helper application is executing locally
  • the object may allow the
  • the object may allow the application to return a blob of data related to the
  • the object may
  • a parental control code e.g., a PIN
  • Module 580 User Location, Billing or Other ID
  • a PostalCode module 580 is a property that retrieves a host system
  • postal code e.g., ZIP code
  • WINDOWS MEDIA CENTER® platform provide guide listings based on a user' s
  • ZIP code which is information that is frequently specified by the user prior to use
  • the property value is a read-only string containing the postal code. If the user has
  • the property value is NULL. If the user's privacy
  • An exemplary postal code e.g., ZIP code
  • model may return this code (e.g., as metadata) when called by a registered
  • Location information enables applications (e.g., the application 250,
  • the application 350 to be customized according to a user's location.
  • a news provider could use the postal code to determine what local news
  • a cable television provider may use
  • a ScreenSaverEnabledHint module 581 is a property that can retrieve
  • application 250 the application 350
  • the property value is a read/write Boolean
  • a screen saver will be blocked. For example, a screen saver may be blocked only when the
  • the content is from a
  • the video is playing (not stopped or paused); the host system is in
  • an application e.g., the
  • appropriate pages e.g., HTML pages, etc.
  • the television show might be in a viewport and the
  • a call to an exemplary screen save hint module may allow the
  • logic may prevent music or audio alone from preventing
  • the exemplary screen saver hint module 581 may
  • Module 590 Schedule Recording
  • the schedule recording module is a method that issues a request to a
  • the media service may provide a television program, a radio program, etc.
  • the module relies on a parameter set in a markup language such as
  • markup language generally follows a markup language schema that
  • recording may include various tags or elements such as a ⁇ clickToRecord> element
  • ⁇ body> element As a root element, a ⁇ body> element, an optional digital signature element, a
  • ⁇ metadata> element one or more ⁇ programRecord> elements.
  • FIG. 6 illustrates an example of a suitable computing system
  • exemplary devices or systems may include any of the features of the
  • the computing system environment 600 is only one
  • computing environment 600 be interpreted as having any dependency or
  • exemplary system 100 of Fig. 1 the exemplary system 100 of Fig. 1
  • a remote computer may use a remote computer to generate information for display of a UI wherein the
  • program modules include routines,
  • remote processing devices that are linked through a communications network or
  • program modules may be located in both local and remote computer storage media
  • various exemplary methods includes a general purpose computing device in the
  • Computer 610 may include, but are not
  • a processing unit 620 a system memory 630, and a system bus 621 that
  • the system bus 621 may be any of several types of bus
  • ISA Industry Standard Architecture
  • MCA Micro Channel Architecture
  • EISA Enhanced ISA
  • VESA Video Electronics Standards Association
  • PCI Interconnect
  • Computer 610 typically includes a variety of computer readable instructions
  • Computer readable media can be any available media that can be accessed
  • computer 610 includes both volatile and nonvolatile media, removable and
  • non-removable media By way of example, and not limitation, computer readable instructions
  • Computer storage media may comprise computer storage media and communication media.
  • storage media includes both volatile and nonvolatile, removable and non-removable
  • Computer storage media includes, but is not limited to, RAM, ROM, EEPROM,
  • Communication media typically embodies computer readable instructions, data
  • a modulated data signal such as a
  • carrier wave or other transport mechanism includes any information delivery
  • modulated data signal means a signal that has one or more of its
  • communication media includes wired media such as a wired network or direct-wired connection, and wireless
  • the system memory 630 includes computer storage media in the form
  • ROM read only memory
  • RAM random access memory
  • BIOS basic input/output system
  • 632 typically contains data and/or program modules that are immediately accessible
  • processing unit 620 to and/or presently being operated on by processing unit 620.
  • processing unit 620 For example,
  • FIG. 6 illustrates operating system 634, application programs
  • the computer 610 may also include other removable/non-removable,
  • FIG. 641 illustrates a hard disk drive 641 that reads from or writes to non-removable
  • nonvolatile magnetic media a magnetic disk drive 651 that reads from or writes to
  • a removable, nonvolatile optical disk 656 such as a CD ROM or
  • operating environment include, but are not limited to, magnetic tape cassettes, flash
  • the hard disk drive 641 is typically connected to the system
  • bus 621 through a data media interface such as interface 640, and magnetic disk
  • optical disk drive 651 and optical disk drive 655 are typically connected to the system bus 621 a
  • optical disk drive use the data media interface 640.
  • hard disk drive 641 is illustrated as storing operating system 644,
  • program data 647 are given different numbers here to illustrate that, at a minimum,
  • a user may enter commands and information into the
  • a mouse commonly referred to as a mouse, trackball or touch pad.
  • Other input devices may include a microphone, joystick, game pad, satellite dish, scanner,
  • an interface such as a video
  • computers may also include other peripheral devices
  • peripheral output devices such as speakers and printer, which may be connected
  • the computer 610 may operate in a networked environment using
  • the remote computer 680 may be a personal computer, a server, a router, a

Abstract

An exemplary computer-implementable method includes receiving a call from an application executing on a host computer, the host computer having a collection of graphical user interfaces, and, in response to the call, registering the application whereby the registering comprises providing one or more entry points for the application wherein each entry point corresponds to at least one of the graphical user interfaces of the collection of graphical user interfaces. Various other exemplary methods, devices, systems, etc., are also disclosed.

Description

REGISTRATION QF APPLICATIONS AND COMPLIMENTARY FEATURES FOR INTERACTIVE USER INTERFACES
TECHNICAL FIELD
[0001] Subject matter disclosed herein relates generally to technology for
registering applications and complimentary features for such applications.
BACKGROUND OF THE INVENTION [0002] Recent technological innovations are turning the home computer into
a multimedia center. For example, the WINDOWS® XP® MEDIA CENTER
EDITION 2005™ platform or operating system (Microsoft Corporation, Redmond,
Washington) enables users to enjoy entertainment, personal productivity, and
creativity on a personal computer in an easy, complete, and connected way. This
operating system includes features that allow a user to store, share, and enjoy
photos, music, video, and recorded TV via a personal computer. In essence, such
features create a so-called media center personal computer (PC). Media center PCs
represent the evolution of PCs into digital media hubs that bring together
entertainment choices. A media center PC with the WINDOWS® XP® MEDIA
CENTER EDITION 2005™ operating system can even be accessed or controlled
using a single remote control.
[0003] With respect to use of a remote control for input, the user experience
differs in many ways when compared to the user experience associated with input via a keyboard and a mouse. Thus, a user interface and associated input methods
typically associated with a 2' context may not provide the user with a good
experience when implemented in a "10' context", i.e., where input is via a remote
control. Indeed, use of a UI and associated methods developed for a 2' context,
when used in a 10' context, may deter use.
[0004] In general, a user's visual experience in the 10' context is in many
ways more critical than in the 2' context. The 2' context is more akin to reading a
book (i.e., "normal" text and image presentation) and being able to point at the text
or images with your finger while the 10' context is more akin to watching TV,
where a remote control is aimed at a device, where viewing habits for users are
quite varied and where viewers are more accustomed to viewing images, single
words or short phrases, as opposed to lines of text. Without a doubt, the advent of
the 10' context has raised new issues in the development of user interfaces and
applications for use in such a context.
[0005] As described herein, various exemplary methods, devices, systems,
etc., aim to improve a user's experience outside of the 2' context or in instances
where a user must navigate a plurality of graphical user interfaces. Various
exemplary methods, devices, systems, etc., pertain to establishing or managing
relationships between applications and host system where the host system may be
suited for use in the 10' context. SUMMARY OF THE INVENTION
[0006] An exemplary computer-implementable method includes receiving a
call from an application executing on a host computer, the host computer having a
collection of graphical user interfaces, and, in response to the call, registering the
application whereby the registering comprises providing one or more entry points
for the application wherein each entry point corresponds to at least one of the
graphical user interfaces of the collection of graphical user interfaces. Various
other exemplary methods, devices, systems, etc., are also disclosed.
BRIEF DESCRIPTION OF THE DRAWINGS
[0007] Non-limiting and non-exhaustive examples are described with
reference to the following figures, wherein like reference numerals generally refer
to like parts throughout the various views unless otherwise specified.
[0008] FIG. 1 is a diagram of an exemplary context that includes a display to
display a user interface and a remote control for input and interaction with the user
interface.
[0009] FIG. 2 is a diagram of an exemplary registration method and an
exemplary unregistration method for an application.
[0010] FIG. 3 is a diagram of an exemplary registration application for
registering or unregistering an application, locally or remotely. [0011] FIG. 4 is a diagram of an exemplary arrangement whereby a
registration application optionally allows for registration of an application that can
then access various features associated with a user interface.
[0012] FIG. 5 is a diagram of an exemplary registration application and
various modules that may interact with the registration application or a registered
application.
[0013] FIG. 6 is a diagram of an exemplary computing environment, which
may be used to implement various exemplary technologies described herein.
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT
[0014] In the description that follows, various exemplary methods, devices,
systems, etc., are presented. These examples pertain generally to registration of
applications and complimentary features for such applications. In various
examples, an application is registered with a host. Various features related to
registration or complimentary features may provide security such as restricting the
application from obtaining information about the host or a user of the host. Such
security features may apply to an application that communicates with the host via a
network. Exemplary technology presented herein is particularly useful for
applications that rely on user interfaces for the 10' context; however, such
exemplary technology may be used for other contexts.
[0015] Fig. 1 shows an exemplary context 100 that has a context boundary
102 (e.g., 10' or other distance). The context boundary 102 is typically defined by a distance or distances between a user and a user interface (UI). The exemplary
context 100 is akin to a distance typically found in viewing TV. In the exemplary
context 100, a display 110 displays a UI 112 and a remote control 120
communicates with a controller for the display via a communication port 114,
which is typically a wireless communication port (e.g., infrared, etc.). The
controller for the display 110 may be a computer located proximate to the display
110 or located remote from the display 110. Various communication techniques
exist to allow a computer to provide display information to create a UI.
[0016] A user interface that works well at a distance of about ten feet should
account for the fact that a typical remote control (e.g., the remote control 120) is
smaller and easier to use than a conventional keyboard and mouse; however, it
generally provides a more limited form of user input (e.g., due to fewer keys or
buttons). And while a greater viewing distance provides a more comfortable
experience, it can necessitate features that provide a visual design style to ensure
clarity, coherence, and readability.
[0017] In both the 2' context and the 10' context, the user's expectations,
mobility, habits, etc., should be considered when constructing a user interface (e.g.,
the UI 112). With respect to expectations, the 10' experience is more like watching
television than using a computer. As a result, users expect a dynamic, animated
experience. They expect that the input device will make their experience simpler, not more complicated. They may also expect applications to be more convenient,
simpler to learn, and easier to use than applications controlled by the keyboard or
mouse. In general, a UI refers to a graphical user interface, for example, as
displayed on a screen, a monitor, by a projector, etc.
[0018] Consider an example where the WINDOWS® MEDIA CENTER
EDITION™ operating system or platform (Microsoft Corporation, Redmond, WA)
serves as a host for an application, which may be referred to as a hosted application.
In this example, when a user opens the hosted application while video or TV is
playing, an exemplary UI framework feature associated with the host platform
moves the video or TV playback into a small window at the lower left of the screen,
called a shared viewport. When the shared viewport is visible, it will cover any
content in the lower left corner of the hosted application's UI (i.e., displayed page).
For example, the viewport may have a width of 274 pixels and a height of 192
pixels for a screen resolution of 1024 x 768. In this manner, the exemplary UI
framework manages execution of an application that runs concurrently with another
application (e.g., a media presentation application or feature associated with the
host platform). Of course, a user may develop a UI with knowledge of such UI
behavior or behavior of other applications that may operate concurrently. As an
alternative, with respect to the viewport, a script to close the shared viewport could
be used, assuming the host allows for execution of such a script on behalf of the
hosted application. [0019] In the foregoing example, the platform served as a host to the
application in what may be referred to as a parent-child relationship. The
relationship between a platform and an application may be parent-child, child-
parent or peer. As described herein, a platform typically serves as a host and an
application typically seeks to establish a relationship with the platform whereby the
platform may expose one or more functionalities to the application (e.g., through
one or more APIs). A platform may also manage an application. Various
exemplary methods, presented below, demonstrate how functionalities may be
exposed to an application and how an application may be managed.
[0020] As described herein a platform generally refers to a media platform
that may include other functionality. For example, a media platform may provide
for control of appliances, property security control, etc. A media platform may be
usable in a home for presentation of media and for controlling various home
appliances (e.g., kitchen, climate, security, cleaning, etc.). Thus, a host may
communicate with various devices as appropriate.
[0021] A platform generally relies on a computer for operation. A host
platform may execute on a host computer or a host system. For example, a host
computer may include software for media presentations, organization, acquisitions,
etc. Such a host computer generally provides for display of graphical user interfaces. Further, such a host computer may receive directly or indirectly
commands issued via a remote control. While various exemplary methods,
modules, applications, etc., refer to a host system, a host platform or a host
computer may be substituted, as appropriate. While an exemplary computing
environment is shown in Fig. 6, with various associated features, a host may include
the same, less or more features.
[0022] Any of a variety of applications may seek to enter into a relationship
with a platform. For example, an HTML application may seek to establish a
relationship with a platform to present various UI components that allow a user to
browse media content (e.g., songs, movies, books, etc.). Such HTML applications
may include script or other coded functionality (consider, e.g., dynamic HTML,
etc.). With respect to the aforementioned 10' context, UI components of an HTML
application should generally provide for suitable viewing at a distance and
navigation via commands issued using a remote control.
[0023] As another example, consider a .NET® framework application
(Microsoft Corporation, Redmond, WA) built as a .NET® framework assembly,
which is a collection of types and resources that are built to work together and form
a logical unit of functionality. Such an assembly or other code (e.g., managed,
compiled, DLL, etc.) may be referred to as an "add-in" to an exemplary platform
(e.g., an add-in to the Media Center Edition™ platform). The type of relationship between an add-in application and the platform may depend on any of a variety of
factors and, where appropriate, the platform may be considered a host and the add-
in application a hosted application. An add-in application typically extends the
functionality of the target platform. An add-in may be a background add-in or an
on-demand add-in, the former of which is typically initiated by the host and the
latter of which is typically invoked by a user or other application as appropriate.
[0024] For a variety of reasons (e.g., logistic, operational, security, etc.), an
exemplary platform may require that all applications (e.g., HTML applications and
add-in applications) be registered. In general, a registration process for an
application adds information about the application to a platform or system registry.
A platform may use such information to manage the application, to allow for one or
more entry points to a collection of UIs associated with the platform, or for other
purposes.
[0025] As described herein, a registration process relies on an exemplary
registration application or method associated with a platform. Thus, an exemplary
platform may include an exemplary registration application that allows for
registration of one or more applications. Again, the types of applications that may
be registered or require registration will generally depend on any of a variety of
factors. While various exemplary registration applications pertain to registration, an exemplary registration application or method may allow for unregistration of an
application or a group of applications.
[0026] Fig. 2 shows an exemplary scheme 200 that includes an exemplary
method for registering applications 204 and an exemplary method for unregistering
applications 208. The exemplary methods 204, 208 rely on a registration
application 210. In this example, the registration application 210 can register or
unregister an application 250 with respect to a platform 220 that includes graphical
user interfaces 230, which are sometimes referred to as "pages" (consider, e.g., a
typical Web "page"). As already mentioned, registration or unregistration may also
account for entry points into the platform 220.
[0027] With respect to HTML applications or the like, an entry point is
generally a link to a particular page in the HTML application that may include an
identifier, a URL, a title, a description, or an image. In the example of Fig. 2 where
the UIs include UIs for categories such as "My Music", "My TV", "My Pictures",
an entry point may be associated with a category that can determine the location(s)
in the graphical user interfaces 230 where an entry point is placed. A category such
as "My Music" may have a main page and various other pages that form a hierarchy
of pages for the category. In some instances, such pages may be accessed directly
from a page associated with a different category. [0028] With respect to an entry point for add-in applications or the like,
consider an on-demand add-in application invoked by a user to perform a discrete,
synchronous task. The user may invoke the on-demand add-in through entry points
in the graphical user interfaces 230 of the platform 220. An entry point for such an
add-in may include several UI components, an image (e.g., a Portable Network
Graphics (PNG) format image, etc.), a title string, and a descriptive string that
describes the purpose of the entry point. An on-demand add-in application entry
point may also have an associated category that can determine the location(s) in the
graphical user interfaces 230 where the entry point appears. An add-in may have
multiple entry points in various locations in the platform 220. An exemplary
platform may limit an add-in application's ability to present UI components. In
some instances, an add-in application may be associated with a Web site, an HTML
application or UI components presented outside of the platform to provide for a
particular user experience or user input.
[0029] As already mentioned, a registration process may add information to a
registry. With respect to add-in applications the exemplary registration process 204
may add information about the add-in application and its entry points to a registry to
thereby enable the platform 220 to locate, load, and run the add-in application, and
to display its entry points in the collection of graphical user interfaces 230. [0030] Referring again to Fig. 2, the process of registration 204 generates
registration information 214 for the application 250. In particular, the information
214 generally allows for proper operation of the application 250 with respect to the
platform 220. The term "proper operation" is typically from the perspective of the
platform 220 or a user, as the platform 220 or a user may restrict operations of the
application 250 based on security, privacy, personal choice, etc.
[0031] As already discussed, the application 250 is typically a software
component that extends the capabilities of the platform 220 by adding new
functionality (e.g., a new service or media experience) that a user can access
through one or more graphical user interfaces 230. Where the application 250 is an
HTML application it may consist of one or more HTML pages that use XML,
scripting, ActiveX controls, or other familiar client-side Internet technologies. As
such, an HTML application typically seeks to display UI components.
[0032] The exemplary registration process 204 and exemplary registration
application 210 may rely on information specified in the form of elements in a
markup language. For example, sample syntax follows for an exemplary
application element, an exemplary category element and an exemplary entry point
element. These exemplary elements may include specific information that pertains
to HTML applications, add-in applications or other types of applications, as
appropriate. [0033] Sample Syntax for an Exemplary Application Element
application title="title" id="GUID of application" ui-l="URL of application" bgColor="RGB(rrr,ggg,bbb)" name="name"
CompanyName=" company name" startlmage="path to image" thunibnaillmage="path to image"
NowPlayingDirective="close" | "pause" | "stop" | "mute" >
</application>
[0034] The sample syntax includes various attributes including title, id, url,
bgColor, name, CompanyName, startlmage, thumbnaillmage, sharedViewport, and
NowPlayingDirective. The title attribute is a string that specifies the title of the
application. The id attribute is a string that specifies the globally unique identifier
(GUID) for the application. The url attribute is a string that specifies the path to the
application. The bgColor attribute may be used or a BGColor property to set a
background color of for an HTML application's page or pages. The name attribute
is a string that specifies the name that appears as a label on the application's button
in, for example, a graphical user interface 230 Start menu. This attribute may also
specify the name that appears on a thumbnail shortcut in a graphical user interface that lists more programs (i.e., more applications whether part of the platform or
registered). The CompanyName attribute is a string that specifies the name of the
company that authored the application. The exemplary registration application 210
optionally uses this name in a dialog box to query a user as to whether the user
wants to add a new application item from the specified company. This particular
action provides the user with some degree of security during a registration process.
[0035] The startlmage attribute is a string that specifies a path to an image
(e.g. PNG format, etc.) that appears, for example, when a start menu button for the
application is selected (e.g., has the focus as described with respect to the
exemplary context 100 of Fig. 1). The thumbnaillmage attribute is a string that
specifies a path to an image (e.g., PNG format, etc.) that appears, for example, on a
thumbnail icon in a "More Programs" page of the platform 220. The
sharedViewport attribute is a string that indicates the state of a shared viewport.
[0036] The sharedViewport attribute may be used with so-called Media
Center Link (MCL) files, which is typically a file that has a .mcl extension and
contains XML code defining the attributes and requirements of an application
hosted by, for example, the platform 220. In some instances, information in a MCL
file may be used to add or register an HTML application.
[0037] As already mentioned, the exemplary registration application 210 may
account for entry points for the application 250. An "entrypoint" element may be used to define each entry point into the platform 220. In a specific example, an
entrypoint element includes the following sample syntax:
[0038] Sample Syntax for An Exemplary Entry Point Element
<entrypoint id="entry point GUID" url="URL of entry-point page" run="path of .exe file" addin="className, assemblyName,Version=version,PublicKeyToken=publicKey,Culture=culture" title="title" description=" description" imageUrl="URL of image" context="context" >
</entrypoint>
[0039] This sample element includes various attributes. The id attribute is a
string containing a GUID (i.e., a globally unique identifier) that uniquely identifies
a particular entry point. The url attribute is a string that specifies the path to an
entry point page in the application 250. The run attribute is a string that specifies
the full or relative path to an executable file on the local machine that, for example,
uses the operating system 220. The addin attribute is a comma-separated string that
defines the attributes of an add-in application. The title attribute is a string that identifies the entry point and it may appear at the top of a page when the entry point
is selected. The description attribute is a string that describes a purpose of the entry
point. The imageUrl attribute is a string that specifies a path to an image (e.g., PNG
format image, etc.) that represents the entry point. The context attribute is an
application-defined string that the platform 220 may provide to the application 250
when the entry point is selected, which may be an arbitrary set of parameters for the
application 250. Again, such an attribute may be part of a security system for the
platform or user thereof.
[0040] The exemplary entrypoint element may be used by the registration
application "RegisterApplication" 210. With respect to the aforementioned url and
run attributes, an entrypoint element for an application should include the url in the
case of an HTML application or the run attribute in the case of an application that
runs outside of the platform's environment. Where the application is an add-in
application the entrypoint element should include the addin attribute. An addin
attribute element can be a string in the following format: "className,
assemblyName, Version=version, PublicKeyToken=publicKey, Culture=culture"
where className is the full name (assembly and class) of the add-in application's
implementation of a class that inherits from the IAddlnModule interface;
assemblyName is the name of the add-in application's assembly; version is the
version number of the add-in application; publicKey is the public portion of the
cryptographic key used to sign the add-in application; and culture is the cultural designation of the add-in application. It may be required that the version,
publicKey, and culture values be an exact match with the strong-name information
stored in the add-in application's assembly.
[0041] The exemplary registration application 210 may also associate the
application 250 with one or more categories of features, media, etc., of the platform
220. For example, the platform 220 shows various graphical user interfaces 230 for
the categories "My Music", "My TV", and "My Pictures". To provide for
association between the application 250 and one or more categories, a category
element may be used. For example, an exemplary category element may specify
one or more categories for each of an application's entry point(s).
[0042] Sample Syntax for an Exemplary Category Element
<category category="host system category"
>
</category>
[0043] This exemplary element includes a category attribute that is a string
that identifies the host system's category for the hosted application's particular
entry point. For a background add-in, this attribute may be "Background". For an
on-demand add-in application or an HTML application, this attribute may be
selected from various categories such as, but not limited to: Internet Radio, More Programs, More With This\Audio\Album, More With This\Audio\Artist, More
With This\Audio\Playlist, More With This\Audio\Song, More With
This\Audio\Genre, More With This\DVD, More With This\Picture, More With
This\ Video, New For Me ServicesVAudio, Services\Movies, Services\Pictures,
Services\Radio, and Services\TV. An exemplary host suited for media presentation,
organization, acquisition, etc., may use such categories or other categories.
[0044] Another exemplary element may specify capabilities required by the
application 250. For example, the application 250 may require certain capabilities
of the platform 220 as implemented on a machine (e.g., a computer such as in the
exemplary computing environment 600 of Fig. 6). An exemplary element may have
the following sample syntax:
[0045] Sample Syntax for an Exemplary Capabilities Element
<capabilitiesRequired directX="True | False" audio="True | False" video="True | False" intensiveRendering="True | False" console="True | False"
>
</capabilitiesRequired> [0046] The sample syntax for the exemplary capabilities element includes
various attributes. For example, a directX is a string that indicates whether the
application requires DirectX support. An audio attribute is a string that indicates
whether the application requires audio support. A video attribute is a string that
indicates whether the application requires video support. An intensiveRendering
attribute is a string that indicates whether the application contains graphics that
require high-end rendering capabilities. A console attribute is a string that indicates
whether the application requires resources that are only available or meaningful
from a computer's console, rather than from a remote session. For example, an
LCD projector application that turns the projector on and off through a COM port.
[0047] The aforementioned exemplary elements are optionally used in a
registration process or an unregistration process (e.g., 204, 208) that may include
specifying one or more entry points. These exemplary elements may pass markup
language code (e.g., XML code) to the exemplary registration application 210. The
various attributes listed for each exemplary element may be optional or others may
be included. In such an exemplary scenario, the application element may specify a
path to the application 250 and set various application attributes; the entrypoint
element may specifies an entry point into the platform 220; the category element
may specify a category for an entry point; and the exemplary capabilities element
may specify capabilities that are needed to successfully run the application 250 or
that are otherwise desirable for best operation of the application. A user may optionally limit resources available to an application through, for example, selection
of settings of a host where, depending on the settings, an application may be limited
in operation.
[0048] While various exemplary elements have been described, the
exemplary registration application 210 may be an exemplary method that uses the
following sample syntax: RegisterApplication(sXMLAppInfo, fUnRegister,
fAHUsers). Regarding the parameters of this particular exemplary method, the
sXMLApplnfo parameter is a string that contains the application, entrypoint, and
category elements (e.g., as XML elements). Again, these elements identify the
application, its entry point(s), and the category or categories in which the entry
point(s) appear. As an alternative, this parameter can specify the path to a markup
language file (e.g., an XML file) that contains the application, entrypoint, and
category elements for the application. The fUnRegister parameter is a Boolean
value that indicates whether to unregister the application. The fAllUsers parameter
is a Boolean value that indicates whether to register or unregister the application for
all users, or just for a current user. This parameter may have a return value, for
example, a number (long) that is zero if the exemplary method succeeded, and non¬
zero if it failed.
[0049] The exemplary method "RegisterApplication" registers an application
and its supported entry points with a host. As already mentioned, an entry point may be a link to a particular page in an HTML application, and may include an
identifier, a URL, a title, a description, and an image. In general, each entry point is
associated with at least one category associated with the host, which may determine
one or more locations in a plurality of host user interfaces where an entry point(s) is
(are) placed.
[0050] In a specific example, the XML code specified in the xmlAppInfo
parameter contains a single application element with one or more nested entrypoint
elements. Each entrypoint element typically has at least one nested category
element and may have more than one nested category element. In scenarios where
an application calls such an exemplary method, the host may display a dialog box
that lets the user confirm or cancel the registration process. For example, a user
may request use of an HTML application or an entity may require a host system to
use an HTML application for consumption of media, use of services, etc. As such
components of an application may require registration with the host system prior to
use or "being hosted", an application may call the exemplary method. As an
alternative, a surrogate or helper application may call the exemplary method to
thereby allow for registration of the application.
[0051] The exemplary method may throw exceptions after being called, for
example, the following exceptions may be thrown: "The specified application is
already registered", "The specified application is not registered", and "The specified application can not be registered, access denied". Of course, other
exceptions may be thrown as desired or required.
[0052] An exemplary segment of code for registering an application with one
entry point appears below in JScript:
[0053] Exemplary Code Segment for Registering an Application
function MyRegisterApp()
{ var strXML; strXML = "<application title=\"My MC Application" id=\"{A0E0DD28-6C4C-40c4-A8Al-F7B686786940}\" CompanyName="Microsoft">" + "<entryρoint id=\"{A0E0DD28-6C4C-40c4-A8Al-F7B686786941}\" url=\" ΛMyMCApp.html\" title=\"My Album ItemV description=\"Item 1\" ImageUrl=\".\Iteml.png\">"
+ "Category category=\"More With This\VAudio\\Album\"/>" + "</entrypoint>" + "</application>";
RegisterApplication(strXML, false, true) } [0054] This exemplary segment includes a call to the exemplary method
RegisterApplication and it specifies various information as already discussed, such
as, but not limited to, an entry point URL, a category, and various ids (e.g., GUIDs).
While this exemplary segment includes information for a single entry point,
additional entry points may be specified; thus, in a fairly small segment of code,
multiple entry points for an application may be registered with a host system.
[0055] As described with reference to Fig. 2, registration or unregistration of
an application may occur through use of an exemplary registration application or
method or an exemplary unregistration application or method. Registration of an
application may be a prerequisite to gain access to a platform's functionality or
information or to extend functionality of a platform.
[0056] Fig. 3 shows a block diagram of two exemplary scenarios 300 that use
an exemplary registration application 310 (e.g., consider the RegisterApplication
210) resident on a platform 320 (e.g., consider the platform 220). One of the
exemplary scenarios involves an application 350 resident on a remote computer 360
that can access the platform 320 via a network while in the other exemplary
scenario the application 350 is resident on the platform 320 and yet unregistered.
The network 302 may be any suitable network, such as, but not limited to, wired or
wireless (e.g., 802.11, satellite, etc.). The former scenario pertains to an example where a remote system may seek to register an application with a platform via
remote calls to the registration application 310 while the latter scenario pertains to
an example where an application stored in memory may seek registration via local
calls to the registration application 310. Other scenarios may be possible where
such an exemplary registration application may register or unregister applications.
In these scenarios, a surrogate or helper application may operate on behalf of the
application 350 where the helper application is executing locally or remotely.
[0057] In both of the exemplary scenarios, an exemplary registration
process includes calling the registration application 310 to register the application
350. In this example, the registration application 310 is an application program
interface (API, sometimes referred to as an application programming interface) of
the platform 320 which the application 350 relies on to make requests of the
platform 320 or optionally other applications resident on the platform 320.
[0058] As an API, the registration application 310 includes a set of
procedures for information exchange, for example, between the application 350 and
the platform 320. The set of procedures for information exchange may be
considered elements (or in a markup language "tags"), such as those described
above and shown in Fig. 3. In this example, the registration application 310
includes four elements: an application element 312 for exchange of information
about the application 350, an entry point element 314 for exchange of information about one or more entry points for the application 350 with respect to the platform
320, a category element 316 for exchange of information about associating the
application 350 with one or more functional or media-related categories of the
platform 320, and a capabilities element 318 for exchange of information about
capabilities required by the application 350 or about capabilities available on the
platform 320. The platform 320 may include a page (e.g., graphical user interface)
that lists each registered application (e.g., a settings page). Such a page may also
allow a user to restrict a registered application.
[0059] Thus, as described with reference to Figs. 2 and 3, an application may
be hosted by a platform whereby at least a registration process is required to register
the application and to optionally specify one or more entry points for the
application. Other features may pertain to capabilities, categories, security,
associations, etc.
[0060] An exemplary computer-implementable method includes receiving a
call from an application (e.g., the application 250, the application 350, etc.)
executing on a host computer, the host computer (or host platform or host system)
having a collection of graphical user interfaces (e.g., the graphical user interfaces
230) and, in response to the call, registering the application whereby the registering
provides one or more entry points for the application wherein each entry point
corresponds to at least one of the graphical user interfaces of the collection of graphical user interfaces. According to such an exemplary method, an application
may be standalone executable code (e.g., a stand alone executable code application
executing on the host). According to such an exemplary method, executing may
occur, for example, as a web page or script in a browser associated with the host
computer (e.g., an embedded browser), As an alternative, a surrogate or helper
application may issue the call on behalf of the application where the helper
application is executing locally or remotely.
[0061] In such an exemplary method, the application may be an HTML
application, an application built as an assembly, etc. With respect to the graphical
user interfaces of the host computer, one may allow a user to unregister the
application wherein unregistration removes all entry points for the application.
With respect to the entry points, each entry point may corresponds to a parameter
for a globally unique identifier (GUID) of a graphical user interface of the
collection of graphical user interfaces. In this exemplary method, an entry point
may correspond to an item of a context menu, which upon selection may launches
the application, or an entry point may correspond to a new information graphical
user interface that allows the application to present new information (see, e.g.,
"New for Me" below). Such an exemplary method may be at least in part embodied
on a computer-readable medium as computer-executable instructions for
performing, for example, registration of an application. [0062] With respect to the exemplary context 100 of Fig. 1 , a hosted
application (e.g., the application 250 or the application 350) may include one or
more graphical user interfaces (full-screen or partial screen) that are suitable for
viewing at a distance and can be navigated by using the remote control. While
audio user interfaces may also be included, generally, a hosted application includes
one or more graphical components. Various features are discussed further below.
[0063] Fig. 4 shows an exemplary arrangement of features 400 that includes
functional modules may interact with an exemplary registration application 410.
The functional modules include a "Used for Services" module 482 (e.g., for media
handlers, etc.), a "New For Me" module 486 (e.g., for notification of "freshness",
etc.), and a "More with This" module 488 (e.g., contextual links, etc.). Of course,
other names may be appropriate for such modules given the exemplary functionality
associated with each module as described below. For example, the "New For Me"
module 486 may be referred to as a "New Information" module whereby an
application (e.g., the application 250 or the application 350) acquires new
information such as new content or new capabilities.
[0064] The "Used for Service" module 482 provides for associating an
application with one or more categories of features. The "New for Me" module 486
provides a feature such as a particular page that a user may access to find new
content or new capabilities provided by one or more extensibility applications (e.g., the application 250, the application 350, etc.). A user may access such a page from
a "Start" page, a "More Programs" page, etc. The module 486 may become visible
or accessible to a user only when items become available to a "New For Me" or
other suitable page.
[0065] Where media content becomes available in association with a
registered application, a "New For Me" item may include the title of the new
content and a brief description of the new content. In general, each item includes or
operates as a link whereby selecting the item causes navigation to a specified
destination for possible consumption of the content (e.g., purchase, download,
stream, etc.).
[0066] As already mentioned, the various modules of the arrangement 400
may interact with the registration application 410. For example, an application may
register such "New For Me" items by calling the registration application 410.
Restrictions may apply to the application's ability to register items, for example, a
limit of one "New For Me" item for each registered application GUID may be
imposed. Further, "New For Me" entries may be restricted to registration by local
applications, i.e., a remote application may be prohibited from registering "New For
Me" items. The exemplary "New For Me" module 486 may sort items by creating
time stamps, for example, with the most recent item first on a list. As already
mentioned, a platform may include a settings page. Such a page or other feature may allow a user to prevent a registered application from adding "New For Me"
items. Such features may be a component of a registration application (e.g., the
registration application 410) used for registering applications.
[0067] As an example, consider a movie delivery service that relies on a
registered application to provide information to a user of a host system. Such a
service may desire to add a "New For Me" item when new media content becomes
available through the service. The registered application of the service may call the
registration application to "register" such an item.
[0068] The "New For Me" module 486 may include a method that can add or
update a "New For Me" item. For example, consider the sample method:
[0069] Sample Code for Exemplary Method for "New For Me"
public bool SubmitNewForMe( string title, string description
);
[0070] This method includes a title parameter, which is a string with, for
example, an updated title, and a description parameter, which is a string with an
updated description. This exemplary method may return a value (e.g., a Boolean
value) to indicate if update or entry occurred for the item. [0071] The exemplary "More With This" module 488 provides a context
menu for an item or various items (e.g., image files, sound files, etc.). For example,
Fig. 4 shows an exemplary user interface 487 with a context menu 489. The
context menu 489 includes a <other app.> item, which may be used as an entry
point for an application registered by the registration application 410. Thus, the
"More With This" module 488 interacts with the registration application 410 to
provide an entry point in a context menu (e.g., the context menu 489).
[0072] Fig. 5 shows an exemplary registration application 510 and various
exemplary modules 500 that may interact with the registration application 510. An
exemplary platform, computer or system may include any of the various modules or
other modules. In general, such exemplary modules pertain to operation of an
application with respect to a host. These exemplary modules are discussed below.
Each exemplary module may be optionally embodied as computer-executable
instructions on one or more computer-readable media, for example, as part of a host
platform and executable by a host computer.
Module 571 : Foreground [0073] An IsForegroundApplication module 571 includes a method that can
indicate, when called by a registered application, whether the registered application
is the current foreground application, or whether it has invoked the currently
playing media in a host system. The module 571 may include one or more parameters. For example, an entryPointld parameter may be a string containing a
GUID that uniquely identifies an entry point for the application. The module 571
may return a Boolean value to indicate if the calling application is the current
foreground application.
[0074] Such a module may restrict actions take by an application or a service
connected with such an application. For example, if an application is not the
current foreground application in a host system, then it may be restricted from
causing changes to the current graphical user interface. Thus, the application may
be restricted from causing display of pop-ups, audio, a foreground graphic,
returning the user to an HTML application, etc. In some instances, a notification
graphic may be available whereby an application that is not the foreground
application can indicate that it has information for a user (e.g., a small icon, a small
perimeter text window, etc.). However, in general, such notification mechanisms
are under user control and can be optionally deactivated.
[0075] Such a module may also provide an application permission to cause
presentation of graphics, audio or other actions in instances where a user invoked
the application. For example, consider a movie trailer that may run in a viewport
(e.g., a region of a graphical user interface). While this viewport may not be
considered the foreground application, due to the user having invoked the
application, once the trailer is finished, the application may be able to cause display of various information, navigation of a user to a movie service page, delivery of
discount coupons, movie tickets, etc.
Module 572: Full Screen
[0076] An IsMediaFullScreen module 572 is a property that includes a
property value (e.g., Boolean or other) to indicate whether a host system is in full¬
screen mode. A registered application may use this property to determine whether a
call to a ReturnToApplication function would be appropriate (see, e.g., the
ReturnToApplication module 573).
[0077] Such a full screen module may allow an application to determine
whether it has permission to take subsequent actions. For example, if an
application causes display of a movie trailer in full screen (e.g., as opposed to the
aforementioned viewport example), then the application may cause presentation of
another trailer upon completion of a trailer or it may navigate a user to a particular
page or graphical user interface. In some instances, a screen may appear when a
media file has reached the end of the file (e.g., finished display). The application
author may wish to return the user automatically to the page that invoked playback,
thus an exemplary full screen module may allow a movie or other media application
to avoid display of a blue screen or a blank screen.
[0078] In a particular example, a user uses an application to navigate to the
OSCAR(S)® ACADEMY AWARD(S)® web page (Academy of Motion Picture Arts and Sciences) and selects a "behind-the-scenes" video interview with actor X.
Where the video is displayed as full screen video or substantially full screen (e.g., a
border or small overlay for notifications, etc.), then the application may be able to
separately manage a play list, for example, of video interview with actor Y, actor Z,
etc. However, if the application is not displaying full screen, then it may not have
such control of the user interface of the host system. In some scenarios, such an
application may rely on an ASX file. ASX files are textual command files that
manage streaming of media files. ASX files are generally small in size (e.g., about
IK) because they usually contain only instructions. A browser application can
download an ASX file to a cache directory, launch a media player and then start
streaming media per the instructions. However, an ASX file is limited in that the
contents of the play list must be specified before any playback commences. By
detecting and managing playback state even when the content is full-screen, an
application may provide play list functionality, even for a play list generated or
modified by the user or application during playback.
[0079] As described with respect to the exemplary foreground module 571
and the exemplary full screen module 572, an application may inquire as to its
status on a host system and determine whether particular actions are permitted. In
general, an application should be prevented from acting in an unexpected manner
that may degrade a user's experience. Module 573 : Return to Application
[0080] The ReturnToApplication module 573 includes a method that can
cause a host system to return some degree of priority or control to a calling
registered application. In particular, the module 573 may return a user to an
application that invoked media playback or to a particular page of an application
that invoked media playback. The module 573 may have syntax such as
"ReturnToApplicationO" without parameters and without a return value. Consider
a registered application that plays video in full-screen mode. Such an application
can call this method to regain the focus after full-screen playback concludes.
Before a registered application calls the ReturnToApplication module 573, it may
call an IsApplicationActive module (not shown in Fig. 5) to determine whether the
registered application is being displayed. It may also call the IsMediaFullScreen
module 572 to determine whether the current media is in full-screen mode.
[0081] With respect to the modules 571, 572, 573, these can enhance a user's
media experience as they can individually or collectively aid in controlling display
of media or UIs. An exemplary computer-implementable method includes
receiving a call from an application (e.g., the application 250, the application 350,
etc.) executing on a host computer (or host platform or host system), the host
computer having a collection of graphical user interfaces (e.g., the graphical user
interfaces 230) wherein the application comprises an entry point associated with one of the collection of graphical user interfaces; providing a parameter value for
the entry point; and, in response to the call, based at least in part on the parameter
value, indicating whether the application has the focus of the host computer or the
application invoked media playing on the host computer. According to such an
exemplary method, executing may occur, for example, as a web page or script in a
browser associated with the host computer (e.g., an embedded browser). According
to such an exemplary method, an application may be standalone executable code
(e.g., a stand alone executable code application executing on the host). As an
alternative, a surrogate or helper application may issue the call on behalf of the
application where the helper application is executing locally or remotely. In
general, a foreground application will have the focus of the host computer. Again,
referring to the exemplary context 100 of Fig. 1, the use of a focus facilitates
navigation and control of media centric system.
[0082] The aforementioned exemplary method may provide a value that
indicates either that the application has the focus of the host computer or the
application invoked media playing on the host computer or that neither condition is
true. Such an exemplary method may further include permitting or restricting an
operation of the application if the indicating indicates that the application has the
focus of the host computer or the application invoked media playing on the host
computer. [0083] With respect to the module 572, an exemplary method may, in
response to a call by an application, indicate whether the application is operating in
a full screen mode or has invoked playing media in a full screen mode. The module
572 may provide a value indicating whether the application is operating in a full
screen mode or has invoked playing media in a full screen mode and the module
573 may use such a value to indicate whether the application can regain the focus of
the host computer after conclusion of the playing media in the full screen mode. In
general, any of the various modules or methods described herein may be at least
partially embodied as computer-executable instructions on a computer-readable
medium.
Module 574: MCL Exist
[0084] A DoesMCLExist module 574 includes a method that can indicate
whether an MCL file already exists for a particular category of a registered
application. The module may include one or more parameters such as a category
parameter and a URL parameter. Such a category parameter may be a number that
indicates a category for the registered application (e.g., "0" More Programs, "1"
Radio, "3" Games, "4" Temporary placeholder, etc.). A URL parameter may be a
string specifies a path to an HTML Web application (e.g., containing "http://").
The module 574 may return a Boolean value that indicates whether the MCL file
exists. This module may throw an exception if the URL and the caller's fully
qualified domain name are different. Such a process can increase security. [0085] With respect to security, a scenario where a user uses one service that
may wish to inquire whether the user also uses another service. For example,
consider a user that uses a sports service "Sports 1", which has a competitor "Sports
2". For purposes of security, a registered application associated with the Sport 1
service can only ask about itself, i.e., it cannot inquire whether the user also uses an
application associated with the Sports 2 service. Such a security mechanism relies
on, for example, a URL parameter whereby if the caller of information and a
qualified domain name differ access is denied to such information (e.g., an
exception is thrown or an indicator that access is denied is communicated to the
caller).
[0086] While the foregoing example mentions a "domain" level for checking,
a GUID level security mechanism may be used in addition to or as an alternative to
a domain level security mechanism. For example, if a calling application's GUID
does not match a currently executing application's GUID, then access to
information may be denied (e.g., only information indicating that access was denied
may be communicated). While access to information is mentioned, access to
navigational control may be denied. For example, where a match does not occur at
the domain level or at the GUID level, then the calling application may have limited
navigational control or other control (e.g., graphic, audio, other actions). Module 575: Entry Point Registered
[0087] An IsEntryPointRegistered module 575 includes a method that can
indicate whether a calling application (registered or unregistered) already has a
particular entry point registered with a host system. Such a method may include the
following syntax: IsEntryPointRegistered(entryPointld), wherein the parameter
entryPointld is a string containing a GUID that uniquely identifies an application
entry point. This method may return a Boolean value that is true if the entry point is
already registered, and false otherwise. In general, such a method does not verify
whether a particular application is registered, only whether a particular entry point
is registered for the calling application.
Module 576: Host Control Level
[0088] A MediaCenterControlLevel module 576 is a property that includes a
property value. While the module name includes "MediaCenter", such a module
may be referred to as a host control level module. This property retrieves the
current settings that determine the level of control that an application (e.g., the
application 250, the application 350, etc.) has with respect to a host system. The
property value may be a read-only number that indicates a control level. It may be a
combination of values such as "0" applications cannot control or query the host
system; "1" applications can control the host system and display notifications; "2"
applications can retrieve settings that indicate the current status of the host system; and "4" applications can retrieve metadata associated with the host system or the
host system's user(s), for example, a user's postal code.
[0089] As already discussed, a host system may include settings that let a
user place restrictions on applications (e.g., the application 250, the application 350,
etc.) for reasons of security and privacy. Such settings can determine whether such
applications are allowed to control a host system or retrieve its settings.
[0090] As an example, consider a user that has used the host system to
navigate to a media service for audio recordings. The user may cause a registered
application associated with the media service to play a particular audio recording.
In response, the application may call an exemplary host control level module to
retrieve or determine a host control level property setting. Once known, the
application can cause appropriate subsequent actions, such as, but not limited to,
notifying the user of "if you like the current song, then try this song".
[0091] As another example, consider a scenario where the currently played
song is not associated with the aforementioned media service, yet, a registered
application of the media service can call and access metadata for the currently
played song. Further, in response to retrieving and analyzing such metadata, the
registered application may notify the user "if you like the current song, then try this
song". While this latter example is more invasive than the former, such control may
be granted per a host control level property setting. [0092] In yet another example, a user may wish for a consistent experience
when consuming media with respect to information about the media. Thus, a
particular registered application may be used for presentation of information about
media regardless of the source of the media or the service provider. For example, a
particular registered application to cause media related information to be presented
in a particular information region of a user interface. It may do so using a particular
font, a ticker animation, etc. For a consistent experience, a user may wish to use
this application for presentation of media information regardless of source or
service provider.
[0093] Where a user uses more than one media service, a scenario may occur
where more than one service recommends media, optionally at particular prices. A
user may then decide based on such information which service to use (e.g., when
the services recommend the same song at different prices, etc.). Possible scenarios
include a registered application that allows a service to present offers for sale or
solely information related to media (e.g., a discography, a biography, performance
schedule, show times, venues, etc.).
[0094] In another example, a registered application for a media service may
be denied access to information about searches, browsing or consumption of media
provided by the media service. For example, a user may listen to Song X whereby
the service provider is denied metadata identifying Song X as a currently played song, i.e., the service provider may, through use of a registered application calling a
module, simply discover that the user is listening to a song.
[0095] An exemplary host control level module may provide for one or more
levels of access. For example, a first level may be a metadata level of access and a
second level may be a relatively unrestricted level of control over a host system. In
instances where an application attempts to have control at an unpermitted level, a
module may provide the application with a script error. Access to levels or
information regarding access is optionally controllable by a user (e.g., selection per
settings).
Module 577: Navigate to Page
[0096] A NavigateToPage module 577 includes a method that can direct a
host system to navigate to a specified page in the host systems graphical user
interfaces (e.g., the graphical user interfaces 230 of the host system 220 of Fig. 2)
and specify contents for that page if desired. Such a method may have the
following syntax: NavigateToPage(pageId, params). A pageld parameter is a string
that contains the identifier (GUID) of a page of the host system (e.g., a particular
graphical user interface in a hierarchy or collection of graphical user interfaces such
as the graphical user interfaces 230). A params parameter is a string that contains
additional parameters. After being called, if the method succeeds, it returns 0;
otherwise, it returns one of the following error values:
ERR COMMAND REMOVED WITH SPAD, which indicates that the destination page was removed with a Set Program Access and Defaults (SPAD)
tool; or ERR_NAVIGATION_FAILED, which indicates that the method failed.
[0097] In a specific example, the value of the pageld parameter determines
the value of the params parameter, as shown in the following table:
Figure imgf000044_0001
Figure imgf000045_0001
Figure imgf000046_0001
[0098] In instances where the pageld parameter is ExtensibilityEntryPoint
and no applicationGuid parameter is specified, the host system may use the
application GUID of the calling application. If the pageID parameter is
"Visualizations", then the params parameter is a string containing the visualization
name (e.g., from the registry) and preset, separated by a colon. For example,
"Ambience: Swirl". If a visualization name is specified but not a preset, the host
system may use the default visualization or the previously-selected preset. Similarly, if a preset is specified but not a visualization name, the host system may
use the default visualization or the previously-selected visualization.
[0099] In general, an exemplary navigate to page module can allow an
application to navigate to a particular page, for example, associated with a
collection or hierarchy of pages of a host system.
[0101] As an example, consider a registered application associated with a
media service that can navigate a user to a visualizations page to allow the user to
select a visualization for media consumed via the media service. In some instances,
where a standard visualization or set of visualizations may be expected to reside on
the host system, the registered application may cause one or more of such
visualization to be invoked during media play.
[0102] As another example, consider a registered application associated with
a photographic image service provider. Such an application may have access to an
exemplary navigation module that navigates a user to a "My Pictures" page of the
host system. In response, the application may cause a slide show or other display or
organization of image files linked with the "My Pictures" page or category therein.
In this example, the application may optionally rely on a slide show application of
the host system or another application. An application may have access to file path
information, for example, paths to image files. [0103] In yet another example, a user may use a registered application
associated with a movie service. A page may include a button that allows a user to
view icons of all movies downloaded, bought, or rented from the movie service.
The application may then assist a user in next steps (e.g., sell, discard, view, rent
again, etc.).
Module 578: Resume After Suspension
[0104] An onAPMResume module 578 operates as an event that occurs when
a host system resumes operation after being suspended to aid in power-saving,
noise- heat-reduction, or other reasons. An application (e.g., the application 250,
the application 350, etc.) may use this event to refresh data once the host system
resumes after being suspended.
[0105] When a host system is inactive for a period of time, the host system
may suspend substantially all operation, for example, with exception of one or more
input channels. A user may also cause suspension by entering a command. In
either instance, at the time of suspension, a registered application associated with a
new service may have been a foreground application or assigned similar priority.
Upon resuming operation, such an application may gain access to fresh information
and display the fresh information at the same priority (e.g., foreground application)
or at a different priority (e.g., background application or if not formerly foreground,
then at foreground). Display may be partial or full screen. Applications that are not news centric or otherwise dependent on timeliness of information may be denied
access to such features as provided by the exemplary resume module.
Module 579: Parental Control [0106] A ParentalControl module 579 is a property that retrieves an object
(e.g., a ParentalControlSelector object) that is used to select the type of parental
control settings to query. The property includes a property value which is a read¬
only object. This property and object (retrieved by the property) provide a way for
an application (e.g., the application 250, the application 350, etc.) to select the type
of parental control settings to query. Thus, such an application can, for example,
query current parental control settings for movie or TV viewing.
[0107] An exemplary parental control feature may rely on entry of a PIN to
access certain types of content. A user may be prompted to enter such a PIN via
remote control or other input mechanism. Where the correct PIN is not provided,
access to content is generally denied. A registered application may request entry of
a PIN when a user tries to access a certain type or types of content. Such an
application may call the exemplary parental control module 579 (e.g., an API call).
In response to such a call, the application may be provided with limited information
like an indicator that the correct PIN was entered or that the incorrect PIN was
entered or simply an indicator to proceed or to not proceed. [0108] A host system may include a single parental control setting (e.g.,
on/off) or it may include a variety of settings that optionally work according to
some control setting logic. For example, consider CSl cartoon-like violence "OK",
CS2, graphic NOK, CS3 artistic nudity OK, etc. Logic may express the settings as
a blob of data that a calling application may expect.
[0109] Consider a user that uses an application to watch a sitcom provided by
an internet content provider. The application may call the exemplary parental
control module 579 to determine if the host system's settings permit viewing of the
sitcom. In a first instance, the application may determine whether parental control
is enabled by the host system. In this instance, the host system may return a
Boolean that indicates control "on". In a second instance, the application may call
for information about the nature of the settings or level of parental control enabled.
In response, the module may return a blob of data expected and analyzable to some
degree by the calling application. The calling application may use the information
in the blob to avoid future calls for certain types of media or otherwise tailor access,
advertising, etc., of media. In a third instance, the application may call for entry of
a PIN, as discussed above.
[0110] Thus, as described herein, an exemplary parental control module may
provide for multiple call levels, some of these calls may return information without
user input and others may require input of a user and return information substantially unrelated to the input (e.g., where entry of a PIN is requested, return
does not include any information about the PIN). The exemplary module may
return a Boolean value or a blob of data depending on the particular call.
[0111] A user may optionally allow for release of certain information (e.g.,
metadata) or other tailoring of an exemplary parental control module. For example,
a return from a call to such a module may indicate playing OK but harvesting of
metadata is not OK. In general, user settings with respect to parental control aim to
enhance the user's experience and to increase security. The inclusion of Boolean
values as possible return values to a basic call (e.g., host system control enabled)
can prevent an application from failing in an undeterminable manner.
[0112] An exemplary computer-implementable method includes receiving a
call from an application (e.g., the application 250, the application 350) executing on
a host computer (or host platform or host system), the host computer having a
collection of graphical user interfaces (e.g., the graphical user interfaces 230), and,
in response to the call, retrieving an object usable to select the type of parental
control settings to query. According to such an exemplary method, executing may
occur, for example, as a web page or script in a browser associated with the host
computer (e.g., an application executing on an embedded browser of the host).
According to such an exemplary method, an application may be standalone
executable code (e.g., a stand alone executable code application executing on the host). As an alternative, a surrogate or helper application may issue the call on
behalf of the application where the helper application is executing locally or
remotely.
[0113] According to such an exemplary method, the object may allow the
application to determine whether parental control is enabled by the host computer
or the object may allow the application to return a blob of data related to the
parental control enabled by the host computer. In the latter instance, the object may
allow the application to call for entry of a parental control code (e.g., a PIN).
Module 580: User Location, Billing or Other ID
[0114] A PostalCode module 580 is a property that retrieves a host system
user's postal code (e.g., ZIP code) as a property value, if available. In general,
media platforms that allow for TV viewing (consider, e.g., the aforementioned
WINDOWS MEDIA CENTER® platform) provide guide listings based on a user' s
ZIP code, which is information that is frequently specified by the user prior to use
of other functionality of the platform, including applications that may be registered.
The property value is a read-only string containing the postal code. If the user has
not provided a postal code, the property value is NULL. If the user's privacy
settings block access to the postal code, attempting to read this property will cause
an exception to be thrown. [0115] Most service providers (e.g., media, access, etc.) require location
information from a user such as a postal code (e.g., ZIP code). An exemplary
model may return this code (e.g., as metadata) when called by a registered
application. Location information enables applications (e.g., the application 250,
the application 350, etc.) to be customized according to a user's location. For
example, a news provider could use the postal code to determine what local news,
sports, and weather information to provide. A cable television provider may use
such information to determine proper channel information (e.g., local channels and
specialized regional channels).
Module 581: Screen Saver
[0116] A ScreenSaverEnabledHint module 581 is a property that can retrieve
or set a value indicating whether a current page of an application (e.g., the
application 250, the application 350) allows the screen saver to interrupt, for
example, a user's media experience. The property value is a read/write Boolean
value that is true if the current application page allows the screen saver to interrupt
and false if it does not.
[0117] Various logic or criteria may be used to determine whether a screen
saver will be blocked. For example, a screen saver may be blocked only when the
current media experience meets all of the following criteria: the content is from a
hosted HTML application; the current HTML page has set the
ScreenSaverEnabledHint property to false; the current HTML page contains a custom viewport; the custom viewport contains video from TV5 My Videos, DVD5
or visualizations; the video is playing (not stopped or paused); the host system is in
full screen mode (that is, the host system shell is maximized). Because this
property is not persisted across pages, leaving a page that set the property to false
restores the property to true. To maintain the false state, an application (e.g., the
application 250, the application 350, etc.) must explicitly set this property on all
appropriate pages (e.g., HTML pages, etc.).
[0118] Consider an example wherein a television show includes trivia
questions that may be displayed on a user interface through use of a registered
application. In this example, the television show might be in a viewport and the
trivia question may appear in another viewport or as an overlay in the show
viewport. A call to an exemplary screen save hint module may allow the
application to prevent the screen saver from being launched while the trivia
question graphic is displayed. Without logic related to the calling application, an
application may attempt to launch a screen saver to the detriment of a user's
experience. In general, logic may prevent music or audio alone from preventing
the launch of a screen saver. The exemplary screen saver hint module 581 may
forget about a previous call or calls from an application and require the application
to call every time it wishes to alter screen saver behavior of a host system. Module 590: Schedule Recording
[0119] The schedule recording module is a method that issues a request to a
host system to record video or audio at as provided by a media service. For
example, the media service may provide a television program, a radio program, etc.
In this example, the module relies on a parameter set in a markup language such as
XML. The markup language generally follows a markup language schema that
includes defined elements related to recording of media (e.g., video, audio, etc.).
[0120] An exemplary markup language schema used for scheduling
recording may include various tags or elements such as a <clickToRecord> element
as a root element, a <body> element, an optional digital signature element, a
<metadata> element, one or more <programRecord> elements.
Exemplary Computing Environment
[0121] The various examples may be implemented in different computer
environments. The computer environment shown in Fig. 6 is only one example of a
computer environment and is not intended to suggest any limitation as to the scope
of use or functionality of the computer and network architectures suitable for use.
Neither should the computer environment be interpreted as having any dependency
or requirement relating to any one or combination of components illustrated in the
example computer environment. [0122] Fig. 6 illustrates an example of a suitable computing system
environment 600 on which various exemplary methods may be implemented.
Various exemplary devices or systems may include any of the features of the
exemplary environment 600. The computing system environment 600 is only one
example of a suitable computing environment and is not intended to suggest any
limitation as to the scope of use or functionality of the invention. Neither should the
computing environment 600 be interpreted as having any dependency or
requirement relating to any one or combination of components illustrated in the
exemplary operating environment 600.
[0123] Various exemplary methods are operational with numerous other
general purpose or special purpose computing system environments or
configurations. Examples of well known computing systems, environments, and/or
configurations that may be suitable for implementation or use include, but are not
limited to, personal computers, server computers, hand-held or laptop devices,
multiprocessor systems, microprocessor-based systems, set top boxes,
programmable consumer electronics, network PCs, minicomputers, mainframe
computers, distributed computing environments that include any of the above
systems or devices, and the like. For example, the exemplary system 100 of Fig. 1
may use a remote computer to generate information for display of a UI wherein the
displayed UI operates in conjunction with a remote control or other input device. [0124] Various exemplary methods, applications, etc., may be described in
the general context of computer-executable instructions, such as program modules,
being executed by a computer. Generally, program modules include routines,
programs, objects, components, data structures, etc., that perform particular tasks or
implement particular abstract data types. Various exemplary methods may also be
practiced in distributed computing environments where tasks are performed by
remote processing devices that are linked through a communications network or
other communication (e.g., infrared, etc.). In a distributed computing environment,
program modules may be located in both local and remote computer storage media
including memory storage devices.
[0125] With reference to Fig. 6, an exemplary system for implementing the
various exemplary methods includes a general purpose computing device in the
form of a computer 610. Components of computer 610 may include, but are not
limited to, a processing unit 620, a system memory 630, and a system bus 621 that
couples various system components including the system memory 630 to the
processing unit 620. The system bus 621 may be any of several types of bus
structures including a memory bus or memory controller, a peripheral bus, and a
local bus using any of a variety of bus architectures. By way of example, and not
limitation, such architectures include Industry Standard Architecture (ISA) bus,
Micro Channel Architecture (MCA) bus, Enhanced ISA (EISA) bus, Video Electronics Standards Association (VESA) local bus, and Peripheral Component
Interconnect (PCI) bus also known as Mezzanine bus.
[0126] Computer 610 typically includes a variety of computer readable
media. Computer readable media can be any available media that can be accessed
by computer 610 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 both volatile and nonvolatile, removable and non-removable
media implemented in any method or technology for storage of information such as
computer readable instructions, data structures, program modules or other data.
Computer storage media includes, but is not limited to, RAM, ROM, EEPROM,
flash memory or other memory technology, CD-ROM, digital versatile disks (DVD)
or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk
storage or other magnetic storage devices, or any other medium which can be used
to store the desired information and which can accessed by computer 610.
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 the
any of the above should also be included within the scope of computer readable
media.
[0127] The system memory 630 includes computer storage media in the form
of volatile and/or nonvolatile memory such as read only memory (ROM) 631 and
random access memory (RAM) 632. A basic input/output system 633 (BIOS),
containing the basic routines that help to transfer information between elements
within computer 610, such as during start-up, is typically stored in ROM 631. RAM
632 typically contains data and/or program modules that are immediately accessible
to and/or presently being operated on by processing unit 620. By way of example,
and not limitation, Fig. 6 illustrates operating system 634, application programs
635, other program modules 636, and program data 637.
[0128] The computer 610 may also include other removable/non-removable,
volatile/nonvolatile computer storage media. By way of example only, Fig. 6
illustrates a hard disk drive 641 that reads from or writes to non-removable,
nonvolatile magnetic media, a magnetic disk drive 651 that reads from or writes to
a removable, nonvolatile magnetic disk 652, and an optical disk drive 655 that reads
from or writes to a removable, nonvolatile optical disk 656 such as a CD ROM or
other optical media (e.g., DVD, etc.). 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, digital versatile disks, digital video tape, solid state RAM, solid state
ROM, and the like. The hard disk drive 641 is typically connected to the system
bus 621 through a data media interface such as interface 640, and magnetic disk
drive 651 and optical disk drive 655 are typically connected to the system bus 621 a
data media interface that is optionally a removable memory interface. For purposes
of explanation of the particular example, the magnetic disk drive 651 and the
optical disk drive use the data media interface 640.
[0129] The drives and their associated computer storage media discussed
above and illustrated in Fig. 6, provide storage of computer readable instructions,
data structures, program modules and other data for the computer 610. In Fig. 6,
for example, hard disk drive 641 is illustrated as storing operating system 644,
application programs 645, other program modules 646, and program data 647. Note
that these components can either be the same as or different from operating system
634, application programs 635, other program modules 636, and program data 637.
Operating system 644, application programs 645, other program modules 646, and
program data 647 are given different numbers here to illustrate that, at a minimum,
they are different copies. A user may enter commands and information into the
computer 610 through input devices such as a keyboard 662 and pointing device
661, 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
620 through a user input interface 660 that is coupled to the system bus 621, 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 691 or other type of display
device is also connected to the system bus 621 via an interface, such as a video
interface 690. In addition to the monitor 691, computers may also include other
peripheral output devices such as speakers and printer, which may be connected
through a output peripheral interface 695.
[0130] The computer 610 may operate in a networked environment using
logical connections to one or more remote computers, such as a remote computer
680. The remote computer 680 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 features described above relative to the computer 610. The
logical connections depicted in Fig. 6 include a local area network (LAN) 671 and a
wide area network (WAN) 673, but may also include other networks. Such
networking environments are commonplace in offices, enterprise-wide computer
networks, intranets and the Internet.
[0131] When used in a LAN networking environment, the computer 610 is
connected to the LAN 671 through a network interface or adapter 670. When used in a WAN networking environment, the computer 610 typically includes a modem
672 or other means for establishing communications over the WAN 673, such as
the Internet. The modem 672, which may be internal or external, may be connected
to the system bus 621 via the user input interface 660, or other appropriate
mechanism. In a networked environment, program modules depicted relative to the
computer 610, or portions thereof, may be stored in a remote memory storage
device. By way of example, and not limitation, Fig. 6 illustrates remote application
programs 685 as residing on the remote computer 680 (e.g., in memory of the
remote computer 680). It will be appreciated that the network connections shown
are exemplary and other means of establishing a communications HnIc between the
computers may be used.
[0132] Although various exemplary methods, devices, systems, etc., have
been described in language specific to structural features and/or methodological
acts, it is to be understood that the subject matter 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 subject matter.

Claims

1. A computer-implementable method comprising:
receiving a call from an application executing on a host computer, the host
computer having a collection of graphical user interfaces; and
in response to the call, registering the application whereby the registering
comprises providing one or more entry points for the application wherein each entry
point corresponds to at least one of the graphical user interfaces of the collection of
graphical user interfaces.
2. The exemplary method of claim 1 wherein the application comprises an
HTML application.
3. The exemplary method of claim 1 wherein the application comprises an
application built as an assembly.
4. The exemplary method of claim 1 wherein one of the graphical user
interfaces of the collection of graphical user interfaces allows a user to unregister
the application wherein unregistration removes all entry points for the application.
5. The exemplary method of claim 1 wherein each entry point corresponds to a
parameter for a globally unique identifier (GUID) of a graphical user interface of
the collection of graphical user interfaces.
6. The exemplary method of claim 1 wherein an entry point corresponds to an
item of a context menu.
7. The exemplary method of claim 6 wherein selection of the item launches the
application.
8. The exemplary method of claim 1 wherein an entry point corresponds to a
new information graphical user interface that allows the application to present new
information.
9. A computer-readable medium having computer-executable instructions for
performing the registering recited in claim 1.
10. A computer-implementable method comprising:
receiving a call from an application executing on a host computer, the host
computer having a collection of graphical user interfaces wherein the application
comprises an entry point associated with one of the collection of graphical user
interfaces;
providing a parameter value for the entry point; and in response to the call, based at least in part on the parameter value,
indicating whether the application has the focus of the host computer or the
application invoked media playing on the host computer.
11. The computer-implementable method of claim 10 wherein the indicating
comprises providing a value that indicates either that the application has the focus
of the host computer or the application invoked media playing on the host computer
or that neither condition is true.
12. The computer-implementable method of claim 10 further comprising
permitting or restricting an operation of the application if the indicating indicates
that the application has the focus of the host computer or the application invoked
media playing on the host computer.
13. The computer-implementable method of claim 10 further comprising, in
response to a call by the application, indicating whether the application is operating
in a full screen mode or has invoked playing media in a full screen mode.
14. The computer-implementable method of claim 13 wherein the indicating
whether the application is operating in a full screen mode or has invoked playing
media in a full screen mode comprises providing a value and further comprising using the value to indicate whether the application can regain the focus of the host
computer after conclusion of the playing media in the full screen mode.
15. A computer-readable medium having computer-executable instructions for
performing the indicating recited in claim 10.
16. A computer-implementable method comprising:
receiving a call from an application executing on a host computer, the host
computer having a collection of graphical user interfaces; and
in response to the call, retrieving an object usable to select the type of
parental control settings to query.
17. The computer-implementable method of claim 16 wherein the object allows
the application to determine whether parental control is enabled by the host
computer.
18. The computer-implementable method of claim 16 wherein the object allows
the application to return a blob of data related to the parental control enabled by the
host computer.
19. The computer-implementable method of claim 16 wherein the object allows
the application to call for entry of a parental control code.
20. A computer-readable medium having computer-executable instructions for
performing the retrieving recited in claim 16.
PCT/US2006/013731 2005-04-15 2006-04-13 Registration of applications and complimentary features for interactive user interfaces WO2006113291A2 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
JP2008506652A JP5123169B2 (en) 2005-04-15 2006-04-13 Registering applications and complementary functions for interactive user interfaces
EP06749936A EP1872584A4 (en) 2005-04-15 2006-04-13 Registration of applications and complimentary features for interactive user interfaces
CN2006800173593A CN101490656B (en) 2005-04-15 2006-04-13 Method for registration of applications and complimentary features for interactive user interfaces

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US11/108,067 2005-04-15
US11/108,067 US8214754B2 (en) 2005-04-15 2005-04-15 Registration of applications and complimentary features for interactive user interfaces

Publications (2)

Publication Number Publication Date
WO2006113291A2 true WO2006113291A2 (en) 2006-10-26
WO2006113291A3 WO2006113291A3 (en) 2009-01-08

Family

ID=37110092

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2006/013731 WO2006113291A2 (en) 2005-04-15 2006-04-13 Registration of applications and complimentary features for interactive user interfaces

Country Status (6)

Country Link
US (2) US8214754B2 (en)
EP (1) EP1872584A4 (en)
JP (1) JP5123169B2 (en)
KR (1) KR20080005499A (en)
CN (1) CN101490656B (en)
WO (1) WO2006113291A2 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR100898794B1 (en) 2008-04-25 2009-05-20 (주)셈투유 System For Downloading Contents

Families Citing this family (16)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8214754B2 (en) 2005-04-15 2012-07-03 Microsoft Corporation Registration of applications and complimentary features for interactive user interfaces
DE102006047813A1 (en) * 2006-10-06 2008-04-10 Lechmetall Landsberg Gmbh Edelstahlerzeugnisse Cooking appliance with automatic cooking program preselection and method for setting such a cooking appliance
US20080301744A1 (en) * 2007-05-30 2008-12-04 General Instrument Corporation Method and Apparatus for Locating Content in an Internet Protocol Television (IPTV) System
US20090070673A1 (en) * 2007-09-06 2009-03-12 Guy Barkan System and method for presenting multimedia content and application interface
US20130067050A1 (en) * 2011-09-11 2013-03-14 Microsoft Corporation Playback manager
CN102404627A (en) * 2011-11-03 2012-04-04 四川长虹电器股份有限公司 Intelligent television interaction method
CN103917951B (en) * 2012-09-19 2017-04-19 华为技术有限公司 Application invocation method, operating system and browser
CN102880514B (en) * 2012-10-26 2016-03-30 小米科技有限责任公司 A kind of method and apparatus of invokes application
CN104424248A (en) * 2013-08-28 2015-03-18 腾讯科技(北京)有限公司 Medium interaction method, device and system
KR102238534B1 (en) * 2014-02-26 2021-04-09 엘지전자 주식회사 Digital device and method of processing a screen saver thereof
EP2921933B1 (en) * 2014-02-26 2018-12-19 LG Electronics Inc. Digital device and method of processing screensaver thereof
US9519471B2 (en) 2014-12-31 2016-12-13 Microsoft Technology Licensing, Llc Surfacing visual representations of universal applications
CN104698861B (en) * 2015-02-10 2017-10-24 上海创景计算机系统有限公司 simulation software interaction control system
US10754838B1 (en) * 2016-03-31 2020-08-25 EMC IP Holding Company LLC Registration framework for an analytics platform
CN110764793A (en) * 2019-11-04 2020-02-07 广州市飞元信息科技有限公司 Software tool and registration, installation and operation method and tool management system thereof
US20220245124A1 (en) * 2021-02-04 2022-08-04 Google Llc Verified entity attributes

Family Cites Families (141)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US715094A (en) * 1901-12-26 1902-12-02 Charles S Langton Automatic pump for pneumatic tires.
US4718107A (en) * 1986-02-14 1988-01-05 Rca Corporation Parental control for CATV converters
EP0286352B1 (en) * 1987-04-10 1995-01-11 Tandem Computers Incorporated Entry point mapping and skipping method and apparatus
JPH0727543B2 (en) 1988-04-28 1995-03-29 インターナシヨナル・ビジネス・マシーンズ・コーポレーション Character recognition device
US5097533A (en) * 1988-11-29 1992-03-17 International Business Machines Corporation System and method for interfacing computer application programs written in different languages to a software system
US5455901A (en) 1991-11-12 1995-10-03 Compaq Computer Corporation Input device with deferred translation
JPH0676117A (en) 1992-08-25 1994-03-18 Canon Inc Method and device for processing information
JPH06324928A (en) 1993-05-14 1994-11-25 Mitsubishi Electric Corp Log generating device, device for arbitrating versions different in file and device for arbitrating version different in computer file being at different places
US5541738A (en) * 1994-04-12 1996-07-30 E. Guide, Inc. Electronic program guide
US5546538A (en) 1993-12-14 1996-08-13 Intel Corporation System for processing handwriting written by user of portable computer by server or processing by the computer when the computer no longer communicate with server
US5588147A (en) 1994-01-14 1996-12-24 Microsoft Corporation Replication facility
US5699456A (en) 1994-01-21 1997-12-16 Lucent Technologies Inc. Large vocabulary connected speech recognition system and method of language representation using evolutional grammar to represent context free grammars
JP3590688B2 (en) * 1995-04-05 2004-11-17 インターナショナル・ビジネス・マシーンズ・コーポレーション Method and system for constructing an installation plan object for installing an application
US5587560A (en) 1995-04-10 1996-12-24 At&T Global Information Solutions Company Portable handwritten data capture device and method of using
US5682524A (en) 1995-05-26 1997-10-28 Starfish Software, Inc. Databank system with methods for efficiently storing non-uniform data records
US5799315A (en) 1995-07-07 1998-08-25 Sun Microsystems, Inc. Method and apparatus for event-tagging data files automatically correlated with a time of occurence in a computer system
FR2741972B1 (en) * 1995-11-30 1998-01-02 Thomson Multimedia Sa DEVICE AND METHOD FOR LOADING A USER INTERFACE
US5806074A (en) 1996-03-19 1998-09-08 Oracle Corporation Configurable conflict resolution in a computer implemented distributed database
US5960204A (en) * 1996-10-28 1999-09-28 J.D. Edwards World Source Company System and method for installing applications on a computer on an as needed basis
US6460058B2 (en) * 1996-12-06 2002-10-01 Microsoft Corporation Object-oriented framework for hyperlink navigation
US7503057B2 (en) 1997-06-02 2009-03-10 Sony Corporation Client and server system
US6292857B1 (en) 1997-06-05 2001-09-18 Microsoft Corporation Method and mechanism for coordinating input of asynchronous data
US6084582A (en) 1997-07-02 2000-07-04 Microsoft Corporation Method and apparatus for recording a voice narration to accompany a slide show
US6008807A (en) 1997-07-14 1999-12-28 Microsoft Corporation Method and system for controlling the display of objects in a slide show presentation
US6401134B1 (en) 1997-07-25 2002-06-04 Sun Microsystems, Inc. Detachable java applets
EP1002274B1 (en) 1997-08-08 2014-04-02 Thomson Licensing Digital department system
US6279014B1 (en) 1997-09-15 2001-08-21 Xerox Corporation Method and system for organizing documents based upon annotations in context
US6240414B1 (en) 1997-09-28 2001-05-29 Eisolutions, Inc. Method of resolving data conflicts in a shared data environment
US6496979B1 (en) * 1997-10-24 2002-12-17 Microsoft Corporation System and method for managing application installation for a mobile device
US6260044B1 (en) 1998-02-04 2001-07-10 Nugenesis Technologies Corporation Information storage and retrieval system for storing and retrieving the visual form of information from an application in a database
AU2782799A (en) * 1998-02-24 1999-09-06 Gateway 2000, Inc. Software management system
US6446109B2 (en) 1998-06-29 2002-09-03 Sun Microsystems, Inc. Application computing environment
US6141010A (en) * 1998-07-17 2000-10-31 B. E. Technology, Llc Computer interface method and apparatus with targeted advertising
AR020608A1 (en) * 1998-07-17 2002-05-22 United Video Properties Inc A METHOD AND A PROVISION TO SUPPLY A USER REMOTE ACCESS TO AN INTERACTIVE PROGRAMMING GUIDE BY A REMOTE ACCESS LINK
US6574618B2 (en) * 1998-07-22 2003-06-03 Appstream, Inc. Method and system for executing network streamed application
US6343148B2 (en) 1998-07-22 2002-01-29 International Business Machines Corporation Process for utilizing external handwriting recognition for personal data assistants
US8232995B2 (en) 1998-07-29 2012-07-31 SAP America, Inc. Local relative layout of node-link structures in space with negative curvature
US6377259B2 (en) 1998-07-29 2002-04-23 Inxight Software, Inc. Presenting node-link structures with modification
TW463503B (en) 1998-08-26 2001-11-11 United Video Properties Inc Television chat system
WO2000016187A1 (en) 1998-09-14 2000-03-23 Microsoft Corporation Input device with forward/backward control
US6487583B1 (en) * 1998-09-15 2002-11-26 Ikimbo, Inc. System and method for information and application distribution
US6370686B1 (en) * 1998-09-21 2002-04-09 Microsoft Corporation Method for categorizing and installing selected software components
US6400382B1 (en) * 1998-10-13 2002-06-04 Hewlett-Packard Company Apparatus and method for a shortcut link creation system in a computer system
US6189147B1 (en) * 1998-10-13 2001-02-13 Hewlett-Packard Company Apparatus and method for an installation recovery system
US6342907B1 (en) 1998-10-19 2002-01-29 International Business Machines Corporation Specification language for defining user interface panels that are platform-independent
US6452609B1 (en) 1998-11-06 2002-09-17 Supertuner.Com Web application for accessing media streams
US6687876B1 (en) 1998-12-30 2004-02-03 Fuji Xerox Co., Ltd. Method and system for maintaining freeform ink annotations on changing views
US6714219B2 (en) 1998-12-31 2004-03-30 Microsoft Corporation Drag and drop creation and editing of a page incorporating scripts
US20010039594A1 (en) 1999-02-03 2001-11-08 Park Britt H. Method for enforcing workflow processes for website development and maintenance
US6333994B1 (en) 1999-03-31 2001-12-25 International Business Machines Corporation Spatial sorting and formatting for handwriting recognition
US6662365B1 (en) * 1999-08-17 2003-12-09 Gateway, Inc. Unified parental locks
US6442555B1 (en) 1999-10-26 2002-08-27 Hewlett-Packard Company Automatic categorization of documents using document signatures
US7152207B1 (en) 1999-11-05 2006-12-19 Decentrix Inc. Method and apparatus for providing conditional customization for generating a web site
JP3866466B2 (en) 1999-12-13 2007-01-10 株式会社東芝 Data structure management device, data structure management system, data structure management method, and recording medium for storing data structure management program
US7036083B1 (en) 1999-12-14 2006-04-25 Microsoft Corporation Multimode interactive television chat
US6665425B1 (en) 1999-12-16 2003-12-16 Xerox Corporation Systems and methods for automated image quality based diagnostics and remediation of document processing systems
JP2003519976A (en) 2000-01-04 2003-06-24 ユナイテッド ビデオ プロパティーズ, インコーポレイテッド Interactive program guide with graphic program listings
US7353262B2 (en) * 2000-01-21 2008-04-01 Scriptlogic Corporation Validation of configuration settings prior to configuration of a local run-time environment
US7454706B1 (en) * 2000-02-11 2008-11-18 Microsoft Corporation Multiple-page shell user interface
US7747782B2 (en) * 2000-04-26 2010-06-29 Novarra, Inc. System and method for providing and displaying information content
AU2001259558A1 (en) 2000-05-08 2001-11-20 Worldgate Service, Inc. System and method for broadcasting information in a television distribution system
US7346848B1 (en) * 2000-06-21 2008-03-18 Microsoft Corporation Single window navigation methods and systems
US20030204536A1 (en) 2000-06-30 2003-10-30 Keskar Dhananjay V. Technique for automatically associating desktop data items
US6704024B2 (en) 2000-08-07 2004-03-09 Zframe, Inc. Visual content browsing using rasterized representations
US20030220867A1 (en) 2000-08-10 2003-11-27 Goodwin Thomas R. Systems and methods for trading and originating financial products using a computer network
US6990654B2 (en) 2000-09-14 2006-01-24 Bea Systems, Inc. XML-based graphical user interface application development toolkit
US6788815B2 (en) 2000-11-10 2004-09-07 Microsoft Corporation System and method for accepting disparate types of user input
US20020090934A1 (en) * 2000-11-22 2002-07-11 Mitchelmore Eliott R.D. Content and application delivery and management platform system and method
US20020180803A1 (en) 2001-03-29 2002-12-05 Smartdisk Corporation Systems, methods and computer program products for managing multimedia content
US20020105546A1 (en) 2000-12-28 2002-08-08 Hamilton Scientific, Ltd. Browser container for hypertext application
US6731312B2 (en) 2001-01-08 2004-05-04 Apple Computer, Inc. Media player interface
WO2002063878A2 (en) 2001-02-02 2002-08-15 Opentv, Inc. A method and apparatus for reformatting of content fir display on interactive television
US7155681B2 (en) 2001-02-14 2006-12-26 Sproqit Technologies, Inc. Platform-independent distributed user interface server architecture
US20020128061A1 (en) * 2001-03-09 2002-09-12 Blanco Victor Keith Method and apparatus for restricting access to content in a gaming system
US7103586B2 (en) 2001-03-16 2006-09-05 Gravic, Inc. Collision avoidance in database replication systems
US6981223B2 (en) 2001-03-19 2005-12-27 Ecrio, Inc. Method, apparatus and computer readable medium for multiple messaging session management with a graphical user interface
US6948133B2 (en) 2001-03-23 2005-09-20 Siemens Medical Solutions Health Services Corporation System for dynamically configuring a user interface display
US7203678B1 (en) 2001-03-27 2007-04-10 Bea Systems, Inc. Reconfigurable query generation system for web browsers
US8949878B2 (en) * 2001-03-30 2015-02-03 Funai Electric Co., Ltd. System for parental control in video programs based on multimedia content information
US20020161865A1 (en) * 2001-04-25 2002-10-31 Gateway, Inc. Automated network configuration of connected device
US20030061279A1 (en) * 2001-05-15 2003-03-27 Scot Llewellyn Application serving apparatus and method
EP1390837B1 (en) 2001-05-31 2010-01-06 Empower Technologies, Inc. System and method of pen-based data input into a computing device
JP2003006084A (en) 2001-06-20 2003-01-10 Funai Electric Co Ltd Data updating method of network system
US7076734B2 (en) 2001-06-22 2006-07-11 Microsoft Corporation Systems and methods for providing a dynamically controllable user interface that embraces a variety of media
US7246326B2 (en) 2001-06-25 2007-07-17 Siemens Medical Solutions Health Services Corporation System and procedure for providing a user interface display
JP2003037789A (en) 2001-07-26 2003-02-07 Matsushita Electric Ind Co Ltd Reception terminal
US7152094B1 (en) 2001-07-31 2006-12-19 Sprint Communications Company L.P. Middleware brokering system adapter
WO2004023455A2 (en) 2002-09-06 2004-03-18 Voice Signal Technologies, Inc. Methods, systems, and programming for performing speech recognition
CA2460332A1 (en) 2001-09-12 2003-04-10 Opentv, Inc. A method and apparatus for disconnected chat room lurking in an interactive television environment
US8365230B2 (en) * 2001-09-19 2013-01-29 Tvworks, Llc Interactive user interface for television applications
JP2003122587A (en) 2001-10-11 2003-04-25 Sharp Corp Network equipment with software update function, software update processing program, and recording medium having software update processing program recorded therein
US7443401B2 (en) 2001-10-18 2008-10-28 Microsoft Corporation Multiple-level graphics processing with animation interval generation
KR100718613B1 (en) 2001-10-22 2007-05-16 애플 인크. Intelligent synchronization for a media player
US20030167318A1 (en) 2001-10-22 2003-09-04 Apple Computer, Inc. Intelligent synchronization of media player with host computer
AU2002219155A1 (en) 2001-11-23 2003-06-10 Nokia Corporation Television chat room
US6959285B2 (en) * 2002-02-28 2005-10-25 Palmsource, Inc. Method and a system for computer software distribution using networked software dispensing vending machines
US20070220580A1 (en) 2002-03-14 2007-09-20 Daniel Putterman User interface for a media convergence platform
US8216071B2 (en) * 2002-03-20 2012-07-10 Intel Corporation Method and apparatus for software delivery and management
US6941521B2 (en) 2002-03-29 2005-09-06 Intel Corporation Method for dynamically generating a user interface from XML-based documents
US7797446B2 (en) 2002-07-16 2010-09-14 Apple Inc. Method and system for updating playlists
US7899915B2 (en) 2002-05-10 2011-03-01 Richard Reisman Method and apparatus for browsing using multiple coordinated device sets
US7607107B2 (en) 2002-06-18 2009-10-20 The Directv Group, Inc. On-screen user interface device
US8370744B2 (en) 2002-06-19 2013-02-05 Microsoft Corporation User interface for operating a computer from a distance
US20040001217A1 (en) 2002-06-26 2004-01-01 Microsoft Corporation System and method for users of mobile computing devices to print documents
US7069259B2 (en) 2002-06-28 2006-06-27 Microsoft Corporation Multi-attribute specification of preferences about people, priorities and privacy for guiding messaging and communications
EP1525665A4 (en) 2002-07-19 2006-04-26 Intellisign Ltd Methods and apparatus for an interactive media display
JP2004062783A (en) 2002-07-31 2004-02-26 Sony Corp Television receiver and method for acquiring/executing software of television receiver
JP2004070651A (en) 2002-08-06 2004-03-04 Fujitsu Ten Ltd Electrical component control system and graphical user interface processing software structure
US7106905B2 (en) 2002-08-23 2006-09-12 Hewlett-Packard Development Company, L.P. Systems and methods for processing text-based electronic documents
US7426532B2 (en) 2002-08-27 2008-09-16 Intel Corporation Network of disparate processor-based devices to exchange and display media files
US8028023B2 (en) 2002-09-17 2011-09-27 At&T Intellecutal Property I, L.P. Extending functionality of instant messaging (IM) systems
US7543238B2 (en) * 2003-01-21 2009-06-02 Microsoft Corporation System and method for directly accessing functionality provided by an application
US7218779B2 (en) 2003-01-21 2007-05-15 Microsoft Corporation Ink divider and associated application program interface
EP1611708A4 (en) * 2003-03-10 2009-12-30 Cyberview Technology Inc Dynamic configuration of a gaming system
US7337330B2 (en) * 2003-03-10 2008-02-26 Cyberview Technology, Inc. Universal game download system for legacy gaming machines
US7325238B2 (en) 2003-03-21 2008-01-29 Microsoft Corporation Interface for determining the source of user input
US7234114B2 (en) 2003-03-24 2007-06-19 Microsoft Corporation Extensible object previewer in a shell browser
US7846023B2 (en) * 2003-03-27 2010-12-07 Microsoft Corporation Application-centric user interface techniques
US20050071477A1 (en) * 2003-03-27 2005-03-31 Microsoft Corporation Providing information links via a network
JP4229322B2 (en) 2003-07-15 2009-02-25 ソニー・エリクソン・モバイルコミュニケーションズ株式会社 Terminal device and display control program
US7426647B2 (en) 2003-09-18 2008-09-16 Vulcan Portals Inc. Low power media player for an electronic device
US7308649B2 (en) 2003-09-30 2007-12-11 International Business Machines Corporation Providing scalable, alternative component-level views
US20050081155A1 (en) * 2003-10-02 2005-04-14 Geoffrey Martin Virtual player capable of handling dissimilar content
WO2005035086A1 (en) * 2003-10-10 2005-04-21 Nokia Corporation Method and device for generating a game directory on an electronic gaming device
US20050091107A1 (en) 2003-10-22 2005-04-28 Scott Blum Media player and access system and method and media player operating system architecture
WO2005048101A2 (en) * 2003-11-07 2005-05-26 Computer Associates Think, Inc. Method and system for software installation
JP4360182B2 (en) 2003-11-14 2009-11-11 ソニー株式会社 Electronic device, operator guidance display method, electronic device program
US7464332B2 (en) 2003-11-18 2008-12-09 Aaa News, Inc. Devices, systems and methods for selecting the appearance of a viewer displaying digital content
US7712108B2 (en) 2003-12-08 2010-05-04 Microsoft Corporation Media processing methods, systems and application program interfaces
US20050132401A1 (en) 2003-12-10 2005-06-16 Gilles Boccon-Gibod Method and apparatus for exchanging preferences for replaying a program on a personal video recorder
US7512882B2 (en) 2004-01-05 2009-03-31 Microsoft Corporation Systems and methods for providing alternate views when rendering audio/video content in a computing system
DE602004030621D1 (en) 2004-02-03 2011-01-27 Corizon Ltd Method and apparatus for creating composite user interfaces
US7421454B2 (en) * 2004-02-27 2008-09-02 Yahoo! Inc. Method and system for managing digital content including streaming media
US7246134B1 (en) 2004-03-04 2007-07-17 Sun Microsystems, Inc. System and methods for tag library generation
US7516477B2 (en) * 2004-10-21 2009-04-07 Microsoft Corporation Method and system for ensuring that computer programs are trustworthy
US7599915B2 (en) 2005-01-24 2009-10-06 At&T Intellectual Property I, L.P. Portal linking tool
US9836729B2 (en) * 2005-03-11 2017-12-05 Microsoft Technology Licensing, Llc Media software navigation with conditional links
US20060224575A1 (en) * 2005-03-30 2006-10-05 Microsoft Corporation System and method for dynamic creation and management of lists on a distance user interface
US20060225037A1 (en) * 2005-03-30 2006-10-05 Microsoft Corporation Enabling UI template customization and reuse through parameterization
US8214754B2 (en) 2005-04-15 2012-07-03 Microsoft Corporation Registration of applications and complimentary features for interactive user interfaces
US7716583B2 (en) * 2005-07-12 2010-05-11 Hewlett-Packard Development Company, L.P. Shortcut for predetermined application

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
"Windows XP Media Center Edition SDK - Registering an Add-in with Media Center", MSDN LIBRARY, 10 February 2005 (2005-02-10), pages 1 - 2

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR100898794B1 (en) 2008-04-25 2009-05-20 (주)셈투유 System For Downloading Contents

Also Published As

Publication number Publication date
EP1872584A2 (en) 2008-01-02
US9336016B2 (en) 2016-05-10
US8214754B2 (en) 2012-07-03
CN101490656B (en) 2012-01-11
JP2008538622A (en) 2008-10-30
EP1872584A4 (en) 2009-12-16
US20060236337A1 (en) 2006-10-19
WO2006113291A3 (en) 2009-01-08
KR20080005499A (en) 2008-01-14
CN101490656A (en) 2009-07-22
JP5123169B2 (en) 2013-01-16
US20120266216A1 (en) 2012-10-18

Similar Documents

Publication Publication Date Title
US9336016B2 (en) Registration of applications and complimentary features for interactive user interfaces
KR101134862B1 (en) Browser interpretable document for controlling a plurality of media players and systems and methods related thereto
US7512892B2 (en) Method and system for displaying and interacting with paginated content
US7568165B2 (en) Sidebar engine, object model and schema
US7941761B2 (en) Third party service switching through command bar user interface
US11132333B2 (en) File access with different file hosts
US20080034309A1 (en) Multimedia center including widgets
US20060224575A1 (en) System and method for dynamic creation and management of lists on a distance user interface
US20060155672A1 (en) Systems and methods for single input installation of an application
CN102971688A (en) Cross-platform application framework
CN101978674A (en) Method for displaying information generated by a client
US20120011282A1 (en) Method and system for providing advertising content suitable for multiple platforms
US9645697B2 (en) Translating events in a user interface
US20130326402A1 (en) Master slave region branding
US9747941B2 (en) Method for applying supplementary attribute information to E-book content and mobile device adapted thereto
Williams Xamarin Blueprints
Trebilcox-Ruiz Android TV Apps Development: Building for Media and Games
Korhonen et al. Creating Mashups with Adobe Flex and AIR
Roberts et al. Let’s Make a Media Center
Trebilcox-Ruiz et al. Building a Media App
Delessio Sams Teach Yourself Google TV App Development in 24 Hours
Garofalo et al. Building Windows 8.1 Apps from the Ground Up
Kc Defining a Testing Platform for Smart TV Applications
Mori et al. Migrating the User Interface between the Digital TV and Mobile Devices
Calvo et al. Customizing Notifications for Wearables

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 200680017359.3

Country of ref document: CN

121 Ep: the epo has been informed by wipo that ep was designated in this application
ENP Entry into the national phase

Ref document number: 2008506652

Country of ref document: JP

Kind code of ref document: A

WWE Wipo information: entry into national phase

Ref document number: 7934/DELNP/2007

Country of ref document: IN

Ref document number: 1020077023618

Country of ref document: KR

Ref document number: 2006749936

Country of ref document: EP

NENP Non-entry into the national phase

Ref country code: DE

NENP Non-entry into the national phase

Ref country code: RU