US20070006238A1 - Managing application states in an interactive media environment - Google Patents
Managing application states in an interactive media environment Download PDFInfo
- Publication number
- US20070006238A1 US20070006238A1 US11/352,662 US35266206A US2007006238A1 US 20070006238 A1 US20070006238 A1 US 20070006238A1 US 35266206 A US35266206 A US 35266206A US 2007006238 A1 US2007006238 A1 US 2007006238A1
- Authority
- US
- United States
- Prior art keywords
- application
- interactive media
- applications
- valid
- state
- Prior art date
- Legal status (The legal status 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 status listed.)
- Abandoned
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q50/00—Information and communication technology [ICT] specially adapted for implementation of business processes of specific business sectors, e.g. utilities or tourism
- G06Q50/10—Services
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F40/00—Handling natural language data
- G06F40/10—Text processing
- G06F40/103—Formatting, i.e. changing of presentation of documents
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input 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/01—Input arrangements or combined input and output arrangements for interaction between user and computer
- G06F3/048—Interaction techniques based on graphical user interfaces [GUI]
- G06F3/0481—Interaction 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
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/48—Program initiating; Program switching, e.g. by interrupt
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/48—Program initiating; Program switching, e.g. by interrupt
- G06F9/4806—Task transfer initiation or dispatching
- G06F9/4843—Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
- G06F9/485—Task life-cycle, e.g. stopping, restarting, resuming execution
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2209/00—Indexing scheme relating to G06F9/00
- G06F2209/48—Indexing scheme relating to G06F9/48
- G06F2209/482—Application
Definitions
- the described arrangements, systems and methods relate generally to interactive media and more particularly to managing application states in an interactive media environment.
- Interactive media environments are typically resource constrained in terms of available processing power, memory and other resources that are available to applications running in the environment.
- One common example of interactive media is video encoded on DVD (digital versatile disc) where users can interact with graphical menus to navigate to specific video content or invoke special features that are authored into the DVD.
- Applications are managed in an interactive media environment by the creation of a logical model for the lifetime of an application.
- Applications in the interactive media environment are used to create and manipulate graphical objects in a synchronous manner with video object to create a rich interactive experience.
- the model is applicable to concurrently and/or consecutively running applications and governs the creation of applications, manipulation of applications by other applications, resource consumption, visibility of an application to a user, and application shutdown in the interactive media environment using the construct of application “state.”
- a set of Booleans flags is utilized and unique combinations of elements in the Boolean flag set define a plurality of application states. Multiple applications typically run simultaneously and each moves from state to state and occupies transitional states during its runtime lifetime in the environment according to script (for example, ECMAScript standardized by Ecma International) and markup documents (for example, a World Wide Web Consortium (W3C) extensible markup language (XML) document file) which define the application, and interactions with the user.
- script for example, ECMAScript standardized by Ecma International
- markup documents for example, a World Wide Web Consortium (W3C) extensible markup language (XML) document file
- Presentation behavior of content in the environment are controlled, and resources such as events, pictures, sounds, fonts in the interactive media environment are managed (e.g., allocated, used and consumed by applications) according to application state of each of the applications in the environment.
- Application state management using the Boolean flag model is implemented, in an illustrative arrangement, using an interactive media player comprising an interactive content processor and a video content processor which mix the graphics and video in a real time on a synchronized basis.
- the interactive media player is realized in dedicated hardware in some settings, or alternatively using a software implementation employing computer readable media with a general purpose processor such as that found in a personal computer.
- the Boolean flag set has elements which include: Valid, Selected, Ready, Loaded and Active.
- the Boolean flag set may also be extended to include the additional elements of Shutdown in Process, Loading and Error.
- application state management provides a stable and predictable methodology for interactive media authors to implement multiple applications in a real-time setting where hardware resources including processor cycles and memory are limited.
- the logical application state management model provides interactive media authors with the ability to use a single application “library” that they can readily customize on a per disc basis, for example, to implement interactive graphical menus using different languages, but utilizing a common menu logic.
- FIG. 1 is an illustrative block diagram showing the elements making up an application used in an interactive media environment
- FIG. 2 is an illustrative diagram which show the relationship among multiple markup documents and script
- FIG. 3 is a block diagram of a first illustrative interactive media player including an interactive content processor, a video content processor and a mixer;
- FIG. 4 is a block diagram of a second illustrative interactive media player
- FIG. 5 shows a set of five elements used in first illustrative example of application state management employing Boolean flags
- FIG. 6 shows an extended set of eight elements used in a secondillustrative example of application state management employing Boolean flags
- FIG. 7 is a diagram of a state machine which illustrates transient and persistent application states.
- FIG. 8 is a flow chart showing an illustrative method for shutting d own an interactive media application.
- an illustrative block diagram of the elements making up an application 110 used in an interactive media environment is shown.
- Applications are typically used in the interactive media environment to enable interaction between a user and an interactive media player rendering graphics and video on a coupled display device (such as a television or monitor) through a user interface such as a remote control. More specifically, applications control presentation behavior of various content objects, including video playback, in the environment. Presentation of graphic objects such as menus and interactive buttons over the video is also realized using applications. Applications further manage and control audio playback and sounds in the environment. It is contemplated that multiple applications will generally be running simultaneously in most interactive media settings. However, there is no requirement the multiple applications run simultaneously and the decision to divide or aggregate applications in a particular setting is a design choice of the interactive media author. Applications may also be logically subdivided into application pages depending on the requirements of a specific setting.
- the application 110 comprises a script host 115 containing zero or more script files 117 and 119 and zero or more markup documents 120 that is used to generate a document object model (DOM).
- the markup documents 120 include information relating, for example, to content, style, timing and layout of graphic objects.
- the markup context is used generally to provide graphics on a graphics plane in the interactive media environment.
- the markup documents are XML document files in accordance with W3C standards. As indicated in FIG. 1 , multiple physical XML files may be accessed using the ⁇ include> element in the ⁇ head> section of the markup. In some settings it may be preferable for an application to not have more than one active markup at a time. However, an application may switch its markup 120 by using a ⁇ link> element in the markup. Alternatively, an application may switch its markup 120 by utilizing an application programming interface (API) that enables applications to gain access to functional objects within a current application. Using a loadMarkup ( ) call through the API, an application may switch markup files 120 by passing the Uniform Resource Identifier (URI) of the new markup through an API.
- API application programming interface
- the API call takes effect only after a current event handler in the application finishes executing its current task. Any current markup-related event handlers that are pending are also cancelled as the new markup, once loaded, will invalidate those event handlers.
- script host 115 contains script files 117 and 119 which are used along with the markup 120 to implement interactive media experiences.
- Script files 117 and 119 may be implemented, for example, using ECMAScript as defined by Ecma International in the ECMA- 262 specification. Common scripting programming languages falling under ECMA- 262 include JavaScript and JScript.
- Script context in most settings is utilized to deal with interactive control issues from user along with system events, graphics control, video playback, resource management (e.g. use of caching or persistent store resources) and other issues that are not readily or efficiently implemented using solely markup 120 .
- Resources include, for example, audio and video files, fonts, pictures and images (e.g., in common file formats including PNG, JPEG, GIF, BMP, TIFF etc.) and other resources as may be required by an application according to the circumstances of a specific setting.
- Each application 110 maintains its own script host 115 that maintains the context for the script's variables, functions and other states.
- variables and functions in one application are not visible to another application unless the applications are specifically set up to enable such cross-application visibility, for example, by using an object that is shared across all applications.
- the interactive media player object has a single instance that is shared across all applications.
- special objects may be placed inside script host 115 —for example, using a C++object—to implement singletons (i.e., a objects having limited instantiation) where the special objects all reference the same internal function, for example, of the player.
- This optional aspect enables interactive media script authors to logically treat common objects as singletons while still allowing the script host 115 to implement the functionality necessary to expose an object to the single script host.
- An application manifest 230 interacts with applications which, as noted above, are defined generally by resources 125 , script 205 , and markup documents 251 , 260 and 275 as shown. Each application typically uses a single application manifest file in most settings, but the application manifest is not part of the runtime state of the application.
- the application manifest 230 is encoded as an XML document file.
- the application manifest 230 describes the initial markup file 251 to be used by the application 110 ( FIG. 1 ) as well as the script files—collectively indicated by the rectangle with reference numeral 205 in FIG. 2 —contained in script host 115 ( FIG. 1 ). If the application manifest 230 lists more than one script, as in this illustrative example, then all the scripts are loaded into a script handling engine in the interactive media player. Thus, the multiple script files are treated and behave as if the script author had concatenated all of the script files into a single large file in the order listed in the application manifest 230 .
- the application manifest 230 refers to resources 125 .
- the resources available to an application in an interactive media environment form a directed graph, rooted by the resources 125 referenced in the application manifest 230 .
- the allowed extent of the graph for each application is proscribed by the application manifest 230 .
- FIG. 2 shows an application running in the interactive media environment.
- an application may only have one active markup at a time and application content is kept separate by the applications.
- the application is able to advance from markup page 251 to 260 , and then later from page 260 to 275 .
- playlist 290 which describes, among other things, the relationship among objects in the environment including presentation objects that are rendered by the player onto the display device.
- presentation objects typically include video (which may include multiple streams as described in more detail below) and graphics produced by the applications.
- Playlist 290 further manages resources across the interactive media environment as a single management entity in order to efficiently allocate and control the consumption of resources by applications.
- the playlist 290 may be advantageously embodied as an XML document file in most settings.
- the markup pages in FIG. 2 may be used in some settings to fire events into an execution context (created by the script files 117 and 119 in FIG. 1 ).
- the execution context then manipulates the DOM created by the current application markup.
- the markup is used in the interactive media environment to specify style, content, timing and layout of graphical objects in the environment (as represented by elements 253 262 and 277 in FIG. 2 )
- the combination of script and markup enables the creation of a comprehensive set of capabilities.
- FIG. 3 is a block diagram of a first illustrative interactive media player 305 including an interactive content processor (ICP) 335 , video content processor (VCP) 310 , and mixer 339 . It is noted that the arrangement presented in FIG. 3 provides a logical model which describe features and functions of the illustrative interactive media player 305 that are pertinent to application state management. Thus, an actual implementation of an interactive media player may utilize various structural forms while still operating as described herein to achieve the benefits of application state management.
- the interactive media player 305 is typically realized in dedicated hardware such as standalone consumer electronic device, or alternatively using a software implementation employing computer readable media with a general purpose processor such as that found in a personal computer.
- VCP 310 manages one or more media streams that may be received from multiple sources including a local optical drives such as a DVD drive or a high-definition DVD (HD-DVD) drive, a local memory or a remote broadband source over a network.
- VCP 310 includes one or more media processors 1 , 2 . . . N as indicated by elements 304 and 306 in FIG. 3 .
- Media processors 304 and 306 process the received media streams, which typically include audio and video, to decode and render the corresponding images and sound which are output as an audio/video stream on line 325 .
- Audio/video stream 325 may represent a plurality of video elements, for example to render multiple separate video windows using a “picture in picture” type configuration.
- Media processors 304 and 306 each comprise a media source interface, demultiplexer and decoder. Media processors 304 and 306 may optionally include decryption capabilities as well.
- a display device 355 is coupled to receive and display the audio/video stream.
- a media clock 312 is utilized so that each received media has an associated “Media Time.”
- Media Time When a video stream is paused on the interactive media player 305 then the media clock 312 is paused as well.
- the video stream is set by a user to go faster or slower than real time (for example, when the video is put into fast forward, rewind or slow-motion modes—using any of these modes is referred to as “trick play”), then the media clock 312 speeds up or slows down accordingly.
- the Media Time is thus derived from the media clock and the operation of the media processors 304 and 306 .
- the Media Time is passed to the playlist manager 337 in ICP 335 over line 315 .
- ICP 335 performs all application-related processing and may be arranged from several components that may be realized in hardware, software, firmware or a combination thereof.
- the components of ICP 335 include, for example, a markup processor, script language interpreter, and an XML parsing component (not shown).
- ICP 335 outputs a graphics stream on line 321 which is synchronous with the audio/video stream 325 .
- Mixer 339 takes the graphics stream on line 321 and the audio/video stream on line 325 so that the graphics are rendered in a graphics layer over the video stream to implement an interactive media session for a user.
- ICP 335 outputs graphics that are synchronized on a frame-by-frame basis with the video stream.
- synchronization may be performed using other bases, including, for example, time (including Title Time and Media time as defined below), content in the video, or other metadata embedded in the video that is used to indicate or mark a particular point in the stream.
- ICP 335 includes a playlist manager 337 and a task manager 330 .
- the playlist manager 337 is responsible for controlling presentation objects in the environment. These objects include video playback on the player 305 along with applications that are running to generate interactive graphics. Playlist manager 337 manages the playlist 290 which is described above in the text accompanying FIG. 2 .
- the playlist manager 337 also computes the “Title Time” associated with each portion of content in a media stream.
- a title is a unique sequence of video and audio content with a start and end time that is typically defined by the DVD author. However, what such author defines as a title can be arbitrary. Thus, particular content which is perceived in a video may be part of one title, a complete title, or run across multiple titles.
- Title Time is defined as the time elapsed since a given title started playing as shown on the media clock 312 .
- a presentation clock 360 is coupled to the playlist manager on line 362 .
- the presentation clock 360 is a clock whose time changes at the same pace as a realworld clock (i.e., it takes one second of real time for the presentation clock 360 to advance by one second). In contrast to the media clock 312 , the presentation clock 360 never stops and cannot be sped up or slowed down.
- the Presentation Time from the presentation clock 360 is passed to the task manager 330 which uses it to calculate “Application Time” and application “Page Time.”
- Application Time is the time elapsed since an application started (or enters an “Active” state as described in more detail below).
- each application has a notion of its own Application Time. For each application, Application Time always starts at zero when an application is started in the environment.
- App1 starts at Presentation Time of 20 arbitrary time units (which is 0 time units for App1) and application App2 starts at Presentation Time of 25 time units (which is 0 time units for App2)
- Appl's Application Time is 15 time units
- App2's Application Time is 10 time units.
- the Page Time is the time elapsed since a page of an application has been loaded.
- FIG. 4 is a block diagram of a second illustrative media player 405 including an ICP 435 , VCP 410 , and mixer 439 .
- Interactive media player 405 is similar in form and function to the interactive media player 305 shown in FIG. 3 .
- VCP 435 includes media processors, 1 , 2 . . . N (as indicated by elements 404 and 406 in FIG. 4 ) that are arranged to provide separate feeds 425 and 427 to mixer 439 .
- Such arrangement may be desirable in some settings where manipulation of the individual media streams is performed prior to mixing.
- image processing/selection techniques such panning and zooming of video in a media stream may be independently implemented on one or more of the N separate feeds represented by reference numerals 425 and 427 in FIG. 4 .
- the audio/video feeds 425 and 427 , along with the synchronous graphics stream from ICP 435 are mixed in mixer 439 and output on line 441 to a display device 455 .
- the other elements in FIG. 4 including ICP 435 (comprising playlist manager 437 and task manager 430 ), media clock 412 in VCP 410 and presentation clock 460 are configured and function in a similar manner as their counterparts shown in FIG. 3 and described in the accompanying text.
- FIG. 5 shows a set of five elements used in first illustrative example of application state management employing Boolean flags.
- the set comprises the elements: Valid, Selected, Ready, Loaded and Active.
- an application is in a “Valid” state when the Title Time is within a predetermined timespan specified for the application in the playlist 290 ( FIG. 2 ).
- an application may therefore become Valid as a result of trick play.
- another form of trick play is “jumping” to a point in title by using a chapter index in a DVD. Jumping to a particular chapter in the title could make the current title time to be within a valid range for a particular application as defined in the playlist 290 .
- An application is in a “Selected” state when the static attributes of the application match the current dynamics attributes of interactive media player 305 .
- Static attributes are those attributes that do not change over time.
- an author may construct the playlist 290 ( FIG. 2 ) to define an application to be keyed to a specific language.
- the interactive media player 305 ( FIG. 3 ) may be set at application runtime to operate using a language chosen by a user.
- the player's current language is a dynamic attribute since it is not determined in advance.
- the author designed an application to implement a menu system in French, then should the user sets language of the player 305 to be French, the French menu application enters the Selected state.
- it is possible that applications may always be Selected. For example, if the application author specifies no language (and thus the application matches any language selected for the player 305 ), then the application is Selected as its static attribute, language, matches a current dynamic attribute of the player 305 .
- Group ID is another example of a static attribute that may be used to match a dynamic attribute on the interactive media player 305 to thereby have an application become Selected.
- a group of applications may be accessed at some point during an interactive media session, for example when a game is launched. And in a similar way as with the example above, an application may always be Selected if it has no Group ID and thus not dependent on the currently selected group.
- autorun is in the “Ready” state once the application becomes Valid (i.e., the Valid Boolean flag is “true”). For example an application may use autorun to generate a “pop up” (i.e, a small text balloon with factoids describing the underlying video) that always begins at a given point in a video program.
- a “pop up” i.e, a small text balloon with factoids describing the underlying video
- a second mechanism to set an application into the Ready state is to access an API to set the Ready flag.
- another application must set the application's ready flag to true through the API if the application's autorun attribute is set to false.
- An application is set to the “Active” state when it is Valid, Selected, Ready and Loaded (i.e., the Valid, Selected, Ready and Loaded Boolean flags are true).
- an application is Active it is enabled to run script, handle events, access resources and the markup is processed and rendered onto the display as described above.
- an application is Active its Active Boolean flag is set to true. The use of the Active Boolean flag avoids any ambiguity at application shutdown when releasing memory and the Valid, Selected and Ready flags possibly become set again.
- FIG. 6 shows an extended set of eight elements used in a second illustrative example of application state management employing Boolean flags.
- the extended set of elements includes the elements Valid, Selected, Ready, Loaded and Active.
- the extended set further includes Shutdown in Progress, Loading and Error.
- an application is in the “Loading” state while activating and stays there only long enough to load before continuing to the Active state.
- the “Shutdown in Progress” state is entered when an application is engaged in the method shown below in FIG. 8 and described in the accompanying text.
- An application is set to the “Error” state in the event of a fatal error (i.e., an error that causes the application to crash or freeze—usually abruptly—for which there is no ability for the application to recover by itself).
- a fatal error i.e., an error that causes the application to crash or freeze—usually abruptly—for which there is no ability for the application to recover by itself.
- the use of the Error state enables the application to be driven back to idle when a fatal error occurs.
- FIGS. 5 and 6 show two sets of elements that are usable to implement application state management using Boolean flags. However, it is emphasized that these sets of elements are used to illustrate a valid logical model for managing application lifetime in an interactive media environment. Accordingly, the number and choice of elements used in specific circumstances may vary depending on the particular requirements at hand.
- FIG. 8 is a flow chart showing an illustrative method for shutting down an interactive media application. It is recognized that applications may need to perform some final processing as a part of shutting down. For example, an interactive game that is synchronized to a chapter in a movie video may need to save the user's score when the title concludes. Such needs can give rise to a variety of complicated issues. If the application leaves its valid time (i.e., is not in the Valid state) then it would need to execute program code and make multiple callbacks to script to perform the save (which implies asynchronous input/output) while not being valid. And, in order to execute script, the application would be holding onto resources while not being valid. Such a result would run counter to the notion of the playlist 290 ( FIG. 2 ) having single responsibility for resource management.
- applications must ordinarily reserve enough time to finish shutdown processing while still Valid.
- applications may not reserve sufficient time and a particular process for shutting down the application is followed in such instances. For example, when a trick play or jump out of an application's valid time occurs, the application must complete shutting down before the video and other applications may be started.
- the process starts at block 810 .
- decision block 815 a determination is made as to whether the application has registered a listener for an “OnShutdown” event. If it has not, then the application is allowed to shut down normally while Valid, as shown in block 819 . The process then ends at block 821 .
- the process continues at block 825 where the current title is paused.
- Title Time is frozen which results in an application remaining Valid while it runs scripts. And, no resource conflicts can arise because no new additional applications can become Valid if the Title time is not advancing.
- the presentation clock ( 360 and 460 in FIGS. 3 and 4 , respectively) continues to run which drives the application's Application Time and Page Time even though Media Time has been paused to allow the application to continue its shutdown processing.
- an OnShutdown event is sent to a handler in the application (i.e., an event listener) repeatedly until the handler returns a value of true, as shown at decision block 833 .
- a handler in the application i.e., an event listener
- the process indicated at blocks 825 and 845 may be optimized away.
- the current title is resumed as indicated in block 845 .
- the script host and markup are deleted from the application at block 848 .
- the order of these last two steps may be reversed so that the script host and markup deletion occurs prior to the resumption of the current title.
- the process ends at block 855 .
- authors may readily handle the typical shutdown case that occurs when a movie video “normally” progresses from chapter to chapter (i.e. without the use of trick play).
- the application author may be expected to extend the applications time in the Valid state in the playlist 290 ( FIG. 2 ) to allow sufficient valid time in the following movie video chapter to execute the typical shutdown process.
- the author may set up a timer to invoke a callback process executed at the end of the movie video chapter and use the callback to handle the save operation.
- the application may remove its event listener for the onShutdown event to thereby implement the optimizations described above.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Software Systems (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- Business, Economics & Management (AREA)
- General Health & Medical Sciences (AREA)
- Tourism & Hospitality (AREA)
- Health & Medical Sciences (AREA)
- Economics (AREA)
- Human Computer Interaction (AREA)
- Artificial Intelligence (AREA)
- Audiology, Speech & Language Pathology (AREA)
- Computational Linguistics (AREA)
- Human Resources & Organizations (AREA)
- Marketing (AREA)
- Primary Health Care (AREA)
- Strategic Management (AREA)
- General Business, Economics & Management (AREA)
- Television Signal Processing For Recording (AREA)
- Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)
- Signal Processing For Digital Recording And Reproducing (AREA)
Abstract
Description
- This application claims the benefit of provisional application no. 60/695,944, filed Jul. 1, 2005, which is incorporated by reference herein.
- The described arrangements, systems and methods relate generally to interactive media and more particularly to managing application states in an interactive media environment.
- Interactive media environments are typically resource constrained in terms of available processing power, memory and other resources that are available to applications running in the environment. One common example of interactive media is video encoded on DVD (digital versatile disc) where users can interact with graphical menus to navigate to specific video content or invoke special features that are authored into the DVD.
- In more complex interactive media environments, despite the limited resources, multiple applications are envisioned as needing to be run simultaneously without causing conflicts which might result in media content such as video to freeze or be otherwise disrupted. In addition, all applications that are used to define a particular interactive experience must always appear to be available to a user. Resource constraints may also dictate that applications be broken up and run sequentially over some time interval. In such cases, the implementation of a graceful transition between consecutive applications is necessary to prevent resource conflicts.
- Applications are managed in an interactive media environment by the creation of a logical model for the lifetime of an application. Applications in the interactive media environment are used to create and manipulate graphical objects in a synchronous manner with video object to create a rich interactive experience. The model is applicable to concurrently and/or consecutively running applications and governs the creation of applications, manipulation of applications by other applications, resource consumption, visibility of an application to a user, and application shutdown in the interactive media environment using the construct of application “state.”
- A set of Booleans flags is utilized and unique combinations of elements in the Boolean flag set define a plurality of application states. Multiple applications typically run simultaneously and each moves from state to state and occupies transitional states during its runtime lifetime in the environment according to script (for example, ECMAScript standardized by Ecma International) and markup documents (for example, a World Wide Web Consortium (W3C) extensible markup language (XML) document file) which define the application, and interactions with the user.
- Presentation behavior of content in the environment are controlled, and resources such as events, pictures, sounds, fonts in the interactive media environment are managed (e.g., allocated, used and consumed by applications) according to application state of each of the applications in the environment.
- Application state management using the Boolean flag model is implemented, in an illustrative arrangement, using an interactive media player comprising an interactive content processor and a video content processor which mix the graphics and video in a real time on a synchronized basis. The interactive media player is realized in dedicated hardware in some settings, or alternatively using a software implementation employing computer readable media with a general purpose processor such as that found in a personal computer.
- In an illustrative example, the Boolean flag set has elements which include: Valid, Selected, Ready, Loaded and Active. The Boolean flag set may also be extended to include the additional elements of Shutdown in Process, Loading and Error.
- Advantageously, application state management provides a stable and predictable methodology for interactive media authors to implement multiple applications in a real-time setting where hardware resources including processor cycles and memory are limited. In addition, the logical application state management model provides interactive media authors with the ability to use a single application “library” that they can readily customize on a per disc basis, for example, to implement interactive graphical menus using different languages, but utilizing a common menu logic.
-
FIG. 1 is an illustrative block diagram showing the elements making up an application used in an interactive media environment; -
FIG. 2 is an illustrative diagram which show the relationship among multiple markup documents and script; -
FIG. 3 is a block diagram of a first illustrative interactive media player including an interactive content processor, a video content processor and a mixer; -
FIG. 4 is a block diagram of a second illustrative interactive media player; -
FIG. 5 shows a set of five elements used in first illustrative example of application state management employing Boolean flags; -
FIG. 6 shows an extended set of eight elements used in a secondillustrative example of application state management employing Boolean flags; -
FIG. 7 is a diagram of a state machine which illustrates transient and persistent application states; and -
FIG. 8 is a flow chart showing an illustrative method for shutting d own an interactive media application. - Referring to
FIG. 1 , an illustrative block diagram of the elements making up anapplication 110 used in an interactive media environment is shown. Applications are typically used in the interactive media environment to enable interaction between a user and an interactive media player rendering graphics and video on a coupled display device (such as a television or monitor) through a user interface such as a remote control. More specifically, applications control presentation behavior of various content objects, including video playback, in the environment. Presentation of graphic objects such as menus and interactive buttons over the video is also realized using applications. Applications further manage and control audio playback and sounds in the environment. It is contemplated that multiple applications will generally be running simultaneously in most interactive media settings. However, there is no requirement the multiple applications run simultaneously and the decision to divide or aggregate applications in a particular setting is a design choice of the interactive media author. Applications may also be logically subdivided into application pages depending on the requirements of a specific setting. - The
application 110 comprises ascript host 115 containing zero ormore script files more markup documents 120 that is used to generate a document object model (DOM). Themarkup documents 120 include information relating, for example, to content, style, timing and layout of graphic objects. Thus, the markup context is used generally to provide graphics on a graphics plane in the interactive media environment. - In this illustrative example, the markup documents are XML document files in accordance with W3C standards. As indicated in
FIG. 1 , multiple physical XML files may be accessed using the <include> element in the <head> section of the markup. In some settings it may be preferable for an application to not have more than one active markup at a time. However, an application may switch itsmarkup 120 by using a <link> element in the markup. Alternatively, an application may switch itsmarkup 120 by utilizing an application programming interface (API) that enables applications to gain access to functional objects within a current application. Using a loadMarkup ( ) call through the API, an application may switchmarkup files 120 by passing the Uniform Resource Identifier (URI) of the new markup through an API. - In cases where an application accesses a new markup, the API call takes effect only after a current event handler in the application finishes executing its current task. Any current markup-related event handlers that are pending are also cancelled as the new markup, once loaded, will invalidate those event handlers.
- In this illustrative example,
script host 115 containsscript files markup 120 to implement interactive media experiences.Script files scripts markup 120. - The availability of APIs and resources to
application 110 is indicated byreference numeral 125 inFIG. 1 . Resources include, for example, audio and video files, fonts, pictures and images (e.g., in common file formats including PNG, JPEG, GIF, BMP, TIFF etc.) and other resources as may be required by an application according to the circumstances of a specific setting. - Each
application 110 maintains itsown script host 115 that maintains the context for the script's variables, functions and other states. In most settings, variables and functions in one application are not visible to another application unless the applications are specifically set up to enable such cross-application visibility, for example, by using an object that is shared across all applications. For example, in this illustrative example, the interactive media player object has a single instance that is shared across all applications. Optionally, therefore, special objects may be placed insidescript host 115—for example, using a C++object—to implement singletons (i.e., a objects having limited instantiation) where the special objects all reference the same internal function, for example, of the player. This optional aspect enables interactive media script authors to logically treat common objects as singletons while still allowing thescript host 115 to implement the functionality necessary to expose an object to the single script host. - Referring now to
FIG. 2 , an illustrative diagram showing the relationship among multiple markup documents and script is provided. Anapplication manifest 230 interacts with applications which, as noted above, are defined generally byresources 125,script 205, andmarkup documents application manifest 230 is encoded as an XML document file. - The
application manifest 230 describes theinitial markup file 251 to be used by the application 110 (FIG. 1 ) as well as the script files—collectively indicated by the rectangle withreference numeral 205 inFIG. 2 —contained in script host 115 (FIG. 1 ). If theapplication manifest 230 lists more than one script, as in this illustrative example, then all the scripts are loaded into a script handling engine in the interactive media player. Thus, the multiple script files are treated and behave as if the script author had concatenated all of the script files into a single large file in the order listed in theapplication manifest 230. - As shown in
FIG. 2 , theapplication manifest 230 refers toresources 125. The resources available to an application in an interactive media environment form a directed graph, rooted by theresources 125 referenced in theapplication manifest 230. The allowed extent of the graph for each application is proscribed by theapplication manifest 230. -
FIG. 2 shows an application running in the interactive media environment. As noted above, an application may only have one active markup at a time and application content is kept separate by the applications. As indicated by the arrows between the markup pages 251, 260 and 275, viascript 205, the application is able to advance frommarkup page 251 to 260, and then later frompage 260 to 275. - The progression of context execution by applications in the interactive media environment is guided by a
playlist 290 which describes, among other things, the relationship among objects in the environment including presentation objects that are rendered by the player onto the display device. These presentation objects typically include video (which may include multiple streams as described in more detail below) and graphics produced by the applications. -
Playlist 290 further manages resources across the interactive media environment as a single management entity in order to efficiently allocate and control the consumption of resources by applications. As with theapplication manifest 230 theplaylist 290 may be advantageously embodied as an XML document file in most settings. - The markup pages in
FIG. 2 may be used in some settings to fire events into an execution context (created by the script files 117 and 119 inFIG. 1 ). The execution context then manipulates the DOM created by the current application markup. As the markup is used in the interactive media environment to specify style, content, timing and layout of graphical objects in the environment (as represented byelements 253 262 and 277 inFIG. 2 ), the combination of script and markup enables the creation of a comprehensive set of capabilities. -
FIG. 3 is a block diagram of a first illustrativeinteractive media player 305 including an interactive content processor (ICP) 335, video content processor (VCP) 310, andmixer 339. It is noted that the arrangement presented inFIG. 3 provides a logical model which describe features and functions of the illustrativeinteractive media player 305 that are pertinent to application state management. Thus, an actual implementation of an interactive media player may utilize various structural forms while still operating as described herein to achieve the benefits of application state management. Theinteractive media player 305 is typically realized in dedicated hardware such as standalone consumer electronic device, or alternatively using a software implementation employing computer readable media with a general purpose processor such as that found in a personal computer. -
VCP 310 manages one or more media streams that may be received from multiple sources including a local optical drives such as a DVD drive or a high-definition DVD (HD-DVD) drive, a local memory or a remote broadband source over a network.VCP 310, in this illustrative example, includes one ormore media processors 1, 2 . . . N as indicated byelements FIG. 3 .Media processors line 325. Audio/video stream 325 may represent a plurality of video elements, for example to render multiple separate video windows using a “picture in picture” type configuration. -
Media processors Media processors display device 355 is coupled to receive and display the audio/video stream. - A
media clock 312 is utilized so that each received media has an associated “Media Time.” When a video stream is paused on theinteractive media player 305 then themedia clock 312 is paused as well. When the video stream is set by a user to go faster or slower than real time (for example, when the video is put into fast forward, rewind or slow-motion modes—using any of these modes is referred to as “trick play”), then themedia clock 312 speeds up or slows down accordingly. The Media Time is thus derived from the media clock and the operation of themedia processors playlist manager 337 inICP 335 overline 315. -
ICP 335 performs all application-related processing and may be arranged from several components that may be realized in hardware, software, firmware or a combination thereof. The components ofICP 335 include, for example, a markup processor, script language interpreter, and an XML parsing component (not shown).ICP 335 outputs a graphics stream online 321 which is synchronous with the audio/video stream 325.Mixer 339 takes the graphics stream online 321 and the audio/video stream online 325 so that the graphics are rendered in a graphics layer over the video stream to implement an interactive media session for a user. - In most settings,
ICP 335 outputs graphics that are synchronized on a frame-by-frame basis with the video stream. However, such synchronization may be performed using other bases, including, for example, time (including Title Time and Media time as defined below), content in the video, or other metadata embedded in the video that is used to indicate or mark a particular point in the stream. -
ICP 335 includes aplaylist manager 337 and atask manager 330. Theplaylist manager 337 is responsible for controlling presentation objects in the environment. These objects include video playback on theplayer 305 along with applications that are running to generate interactive graphics.Playlist manager 337 manages theplaylist 290 which is described above in the text accompanyingFIG. 2 . - The
playlist manager 337 also computes the “Title Time” associated with each portion of content in a media stream. A title is a unique sequence of video and audio content with a start and end time that is typically defined by the DVD author. However, what such author defines as a title can be arbitrary. Thus, particular content which is perceived in a video may be part of one title, a complete title, or run across multiple titles. - One example of a title is the copyright warning that precedes all pre-recorded video in both analog and digital format in the United States. The featured attraction (e.g., the main movie) on a DVD is another example and is often the longest title. In some settings, individual chapters in a movie might be designated as separates titles by the DVD author. For all such titles, Title Time is defined as the time elapsed since a given title started playing as shown on the
media clock 312. - A
presentation clock 360 is coupled to the playlist manager online 362. Thepresentation clock 360 is a clock whose time changes at the same pace as a realworld clock (i.e., it takes one second of real time for thepresentation clock 360 to advance by one second). In contrast to themedia clock 312, thepresentation clock 360 never stops and cannot be sped up or slowed down. The Presentation Time from thepresentation clock 360 is passed to thetask manager 330 which uses it to calculate “Application Time” and application “Page Time.” - Application Time is the time elapsed since an application started (or enters an “Active” state as described in more detail below). When multiple applications are in runtime, each application has a notion of its own Application Time. For each application, Application Time always starts at zero when an application is started in the environment.
- For example, if an application App1 starts at Presentation Time of 20 arbitrary time units (which is 0 time units for App1) and application App2 starts at Presentation Time of 25 time units (which is 0 time units for App2), then at Presentation Time of 35 time units, Appl's Application Time is 15 time units and App2's Application Time is 10 time units. For applications that are logically subdivided into pages, the Page Time is the time elapsed since a page of an application has been loaded.
-
FIG. 4 is a block diagram of a secondillustrative media player 405 including anICP 435,VCP 410, andmixer 439.Interactive media player 405 is similar in form and function to theinteractive media player 305 shown inFIG. 3 . Notably, however,VCP 435 includes media processors, 1, 2 . . . N (as indicated byelements FIG. 4 ) that are arranged to provideseparate feeds mixer 439. Such arrangement may be desirable in some settings where manipulation of the individual media streams is performed prior to mixing. For example, image processing/selection techniques such panning and zooming of video in a media stream may be independently implemented on one or more of the N separate feeds represented byreference numerals FIG. 4 . - The audio/video feeds 425 and 427, along with the synchronous graphics stream from
ICP 435 are mixed inmixer 439 and output online 441 to adisplay device 455. The other elements inFIG. 4 including ICP 435 (comprisingplaylist manager 437 and task manager 430),media clock 412 inVCP 410 andpresentation clock 460 are configured and function in a similar manner as their counterparts shown inFIG. 3 and described in the accompanying text. - Turning now to a more detailed description of the logical model created to manage application lifetime,
FIG. 5 shows a set of five elements used in first illustrative example of application state management employing Boolean flags. As shown, the set comprises the elements: Valid, Selected, Ready, Loaded and Active. In this illustrative example, an application is in a “Valid” state when the Title Time is within a predetermined timespan specified for the application in the playlist 290 (FIG. 2 ). Note that an application may therefore become Valid as a result of trick play. For example, another form of trick play (in addition to fast forward, rewind or slow motion) is “jumping” to a point in title by using a chapter index in a DVD. Jumping to a particular chapter in the title could make the current title time to be within a valid range for a particular application as defined in theplaylist 290. - An application is in a “Selected” state when the static attributes of the application match the current dynamics attributes of
interactive media player 305. Static attributes are those attributes that do not change over time. For example, an author may construct the playlist 290 (FIG. 2 ) to define an application to be keyed to a specific language. The interactive media player 305 (FIG. 3 ) may be set at application runtime to operate using a language chosen by a user. Thus, the player's current language is a dynamic attribute since it is not determined in advance. Continuing with this example then, if the author designed an application to implement a menu system in French, then should the user sets language of theplayer 305 to be French, the French menu application enters the Selected state. Conversely, it is possible that applications may always be Selected. For example, if the application author specifies no language (and thus the application matches any language selected for the player 305), then the application is Selected as its static attribute, language, matches a current dynamic attribute of theplayer 305. - Group identification (Group ID) is another example of a static attribute that may be used to match a dynamic attribute on the
interactive media player 305 to thereby have an application become Selected. In this case, a group of applications may be accessed at some point during an interactive media session, for example when a game is launched. And in a similar way as with the example above, an application may always be Selected if it has no Group ID and thus not dependent on the currently selected group. - Applications that implement autorun are in the “Ready” state once the application becomes Valid (i.e., the Valid Boolean flag is “true”). For example an application may use autorun to generate a “pop up” (i.e, a small text balloon with factoids describing the underlying video) that always begins at a given point in a video program.
- A second mechanism to set an application into the Ready state is to access an API to set the Ready flag. Here, another application must set the application's ready flag to true through the API if the application's autorun attribute is set to false.
- An application that is set to Valid, Selected and Ready (i.e., the Valid, Selected and Ready Boolean flags are true) will begin loading resources. When loading is complete, the application will be set to “Loaded.”
- An application is set to the “Active” state when it is Valid, Selected, Ready and Loaded (i.e., the Valid, Selected, Ready and Loaded Boolean flags are true). When an application is Active it is enabled to run script, handle events, access resources and the markup is processed and rendered onto the display as described above. When an application is Active its Active Boolean flag is set to true. The use of the Active Boolean flag avoids any ambiguity at application shutdown when releasing memory and the Valid, Selected and Ready flags possibly become set again.
-
FIG. 6 shows an extended set of eight elements used in a second illustrative example of application state management employing Boolean flags. As with the illustrative example shown inFIG. 5 and described in the accompanying text, the extended set of elements includes the elements Valid, Selected, Ready, Loaded and Active. The extended set further includes Shutdown in Progress, Loading and Error. - As shown in
FIG. 7 and described in the accompanying text, an application is in the “Loading” state while activating and stays there only long enough to load before continuing to the Active state. The “Shutdown in Progress” state is entered when an application is engaged in the method shown below inFIG. 8 and described in the accompanying text. - An application is set to the “Error” state in the event of a fatal error (i.e., an error that causes the application to crash or freeze—usually abruptly—for which there is no ability for the application to recover by itself). The use of the Error state enables the application to be driven back to idle when a fatal error occurs.
-
FIGS. 5 and 6 show two sets of elements that are usable to implement application state management using Boolean flags. However, it is emphasized that these sets of elements are used to illustrate a valid logical model for managing application lifetime in an interactive media environment. Accordingly, the number and choice of elements used in specific circumstances may vary depending on the particular requirements at hand. -
FIG. 7 is a diagram of astate machine 700 which illustrates transient and persistent states of an application. As shown, 23 different application states are included in the diagram. Within each box, the states (and corresponding Boolean flags) Valid, Selected, Ready and Loaded have been abbreviated to “V,” “S,” “R” and “L,” respectively. Thus, for example, when a title starts, as shown at the top of the diagram, an application atbox 710 can enter either the Selected or Valid states as indicated byboxes 717 and 715, respectively. Accordingly, Boolean flags are true as indicated by S=1 and V=1 in the diagram shown inFIG. 7 . - If the application is in the Valid state (and thus the Boolean flag V=1) in
box 715, then the application can move to the Ready state inbox 726 with R=1. As noted above, the application may become Ready by invoking an API call Active ( ) or if the application is set for AutoRun (where AutoRun=1). As indicated in the figure, to be Ready an application must be Valid. - At
box 715, if an application is selected and the Boolean flag S=1, then the application becomes Loaded with L=1 since it is already Valid. As indicated by the dashed line aroundbox 730, the “Loading” state is transient because the application moves through this state between persistent states (persistent states inFIG. 7 are indicated by solid lines). When an application is activating (i.e., enters the Active state) is goes through the Loading state long enough to actually functionally load into the player (i.e., have its markup parsed, script interpreted and required resources identified and cached) and then continues to the Active state as indicated bybox 739 inFIG. 7 . -
FIG. 8 is a flow chart showing an illustrative method for shutting down an interactive media application. It is recognized that applications may need to perform some final processing as a part of shutting down. For example, an interactive game that is synchronized to a chapter in a movie video may need to save the user's score when the title concludes. Such needs can give rise to a variety of complicated issues. If the application leaves its valid time (i.e., is not in the Valid state) then it would need to execute program code and make multiple callbacks to script to perform the save (which implies asynchronous input/output) while not being valid. And, in order to execute script, the application would be holding onto resources while not being valid. Such a result would run counter to the notion of the playlist 290 (FIG. 2 ) having single responsibility for resource management. - Accordingly, applications must ordinarily reserve enough time to finish shutdown processing while still Valid. However, applications may not reserve sufficient time and a particular process for shutting down the application is followed in such instances. For example, when a trick play or jump out of an application's valid time occurs, the application must complete shutting down before the video and other applications may be started.
- The process starts at
block 810. At decision block 815 a determination is made as to whether the application has registered a listener for an “OnShutdown” event. If it has not, then the application is allowed to shut down normally while Valid, as shown inblock 819. The process then ends atblock 821. - If the application has registered an OnShutdown event listener, then the process continues at
block 825 where the current title is paused. By pausing the title, Title Time is frozen which results in an application remaining Valid while it runs scripts. And, no resource conflicts can arise because no new additional applications can become Valid if the Title time is not advancing. The presentation clock (360 and 460 inFIGS. 3 and 4 , respectively) continues to run which drives the application's Application Time and Page Time even though Media Time has been paused to allow the application to continue its shutdown processing. - At
block 828, an OnShutdown event is sent to a handler in the application (i.e., an event listener) repeatedly until the handler returns a value of true, as shown atdecision block 833. In cases where the application does not need to use an event listener, then it may be assumed that the application does not need to run script at application shutdown and the opportunity to negatively impact the video stream are minimized. Therefore, the process indicated atblocks 825 and 845 (pause and resume) may be optimized away. - Once the OnShutdown event has been handled by the application, the current title is resumed as indicated in
block 845. The script host and markup are deleted from the application atblock 848. Optionally, the order of these last two steps may be reversed so that the script host and markup deletion occurs prior to the resumption of the current title. The process ends atblock 855. - In the particular case of applications which enable interactive games where scores need to be saved at shutdown, authors may readily handle the typical shutdown case that occurs when a movie video “normally” progresses from chapter to chapter (i.e. without the use of trick play). In this case, the application author may be expected to extend the applications time in the Valid state in the playlist 290 (
FIG. 2 ) to allow sufficient valid time in the following movie video chapter to execute the typical shutdown process. - Optionally, the author may set up a timer to invoke a callback process executed at the end of the movie video chapter and use the callback to handle the save operation. In this case (normal progression but not trick play progression), the application may remove its event listener for the onShutdown event to thereby implement the optimizations described above.
- It is noted that for the sake of clarity and ease of illustration in the description above that data, programs, and other executable program components such as operating systems are shown is discrete blocks, boxes or other elements although it is recognized and emphasized that such programs and components may reside at various times in different storage, memory or processing components of any hardware host used and are executed by one or more processors in such host hardware.
- Although various illustrative arrangements and methods for managing application states in an interactive media environment have been shown and described, it should be understood that the scope of the claims appended hereto shall not necessarily be limited to the specific features, arrangements or methods described. Instead, the specific features, arrangements or methods are disclosed as illustrative forms of implementing managed applications states in an interactive media environment as more particularly claimed below.
Claims (20)
Priority Applications (6)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/352,662 US20070006238A1 (en) | 2005-07-01 | 2006-02-13 | Managing application states in an interactive media environment |
KR1020077030958A KR20080021084A (en) | 2005-07-01 | 2006-06-20 | Methods for managing applications in an interactive media environment, interactive media players, and computer readable media |
PCT/US2006/023906 WO2007005269A1 (en) | 2005-07-01 | 2006-06-20 | Managing application states in an interactive media environment |
JP2008519380A JP5242387B2 (en) | 2005-07-01 | 2006-06-20 | Application state management in an interactive media environment |
EP06773586A EP1899834A4 (en) | 2005-07-01 | 2006-06-20 | Managing application states in an interactive media environment |
US14/263,508 US20140237332A1 (en) | 2005-07-01 | 2014-04-28 | Managing application states in an interactive media environment |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US69594405P | 2005-07-01 | 2005-07-01 | |
US11/352,662 US20070006238A1 (en) | 2005-07-01 | 2006-02-13 | Managing application states in an interactive media environment |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/263,508 Continuation US20140237332A1 (en) | 2005-07-01 | 2014-04-28 | Managing application states in an interactive media environment |
Publications (1)
Publication Number | Publication Date |
---|---|
US20070006238A1 true US20070006238A1 (en) | 2007-01-04 |
Family
ID=37591414
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/352,662 Abandoned US20070006238A1 (en) | 2005-07-01 | 2006-02-13 | Managing application states in an interactive media environment |
US14/263,508 Abandoned US20140237332A1 (en) | 2005-07-01 | 2014-04-28 | Managing application states in an interactive media environment |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/263,508 Abandoned US20140237332A1 (en) | 2005-07-01 | 2014-04-28 | Managing application states in an interactive media environment |
Country Status (5)
Country | Link |
---|---|
US (2) | US20070006238A1 (en) |
EP (1) | EP1899834A4 (en) |
JP (1) | JP5242387B2 (en) |
KR (1) | KR20080021084A (en) |
WO (1) | WO2007005269A1 (en) |
Cited By (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20070006063A1 (en) * | 2005-07-01 | 2007-01-04 | Microsoft Corporation | Synchronization aspects of interactive multimedia presentation management |
US20070005757A1 (en) * | 2005-07-01 | 2007-01-04 | Microsoft Corporation | Distributing input events to multiple applications in an interactive media environment |
US20070005758A1 (en) * | 2005-07-01 | 2007-01-04 | Microsoft Corporation | Application security in an interactive media environment |
US20090092249A1 (en) * | 2007-10-09 | 2009-04-09 | Microsoft Corporation | Media key-transformation obfuscation in advanced access content system |
US7721308B2 (en) | 2005-07-01 | 2010-05-18 | Microsoft Corproation | Synchronization aspects of interactive multimedia presentation management |
US8020084B2 (en) | 2005-07-01 | 2011-09-13 | Microsoft Corporation | Synchronization aspects of interactive multimedia presentation management |
US20120023437A1 (en) * | 2010-07-20 | 2012-01-26 | Kabushiki Kaisha Toshiba | Information processing apparatus and display region arrangement method |
US8305398B2 (en) | 2005-07-01 | 2012-11-06 | Microsoft Corporation | Rendering and compositing multiple applications in an interactive media environment |
US8656268B2 (en) | 2005-07-01 | 2014-02-18 | Microsoft Corporation | Queueing events in an interactive media environment |
US20140164890A1 (en) * | 2012-12-10 | 2014-06-12 | Microsoft Corporation | Insertion and playback of video in documents |
US8922564B2 (en) | 2010-12-01 | 2014-12-30 | Microsoft Corporation | Controlling runtime execution from a host to conserve resources |
WO2015009504A1 (en) * | 2013-07-15 | 2015-01-22 | Microsoft Corporation | Delegation of rendering between a web application and a native application |
US20150242183A1 (en) * | 2012-11-14 | 2015-08-27 | Tencent Technology (Shenzhen) Company Limited | Method and system for controlling the playback of multimedia content |
US10248631B2 (en) * | 2007-12-14 | 2019-04-02 | Amazon Technologies, Inc. | System and method of presenting media data |
US10255060B2 (en) * | 2013-08-06 | 2019-04-09 | Endress + Hauser Process Solutions Ag | Method for extending an embedded software component of a field device |
US10521074B2 (en) * | 2014-07-31 | 2019-12-31 | Dell Products, Lp | System and method for a back stack in a multi-application environment |
US20230360679A1 (en) * | 2009-03-02 | 2023-11-09 | Rovi Technologies Corporation | Application tune manifests and tune state recovery |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20080201332A1 (en) * | 2007-02-20 | 2008-08-21 | Souders Steven K | System and method for preloading content on the basis of user context |
Citations (95)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5394547A (en) * | 1991-12-24 | 1995-02-28 | International Business Machines Corporation | Data processing system and method having selectable scheduler |
US5608859A (en) * | 1993-12-28 | 1997-03-04 | Nec Corporation | Scenario editing apparatus |
US5631694A (en) * | 1996-02-01 | 1997-05-20 | Ibm Corporation | Maximum factor selection policy for batching VOD requests |
US5659539A (en) * | 1995-07-14 | 1997-08-19 | Oracle Corporation | Method and apparatus for frame accurate access of digital audio-visual information |
US5694560A (en) * | 1991-09-13 | 1997-12-02 | Matsushita Electric Industrial Co., Ltd. | Workstation for displaying dynamic image with real-time special effects |
US5717468A (en) * | 1994-12-02 | 1998-02-10 | International Business Machines Corporation | System and method for dynamically recording and displaying comments for a video movie |
US5758008A (en) * | 1995-07-04 | 1998-05-26 | Pioneer Electronic Corporation | Information recording apparatus and information reproducing apparatus |
US5794018A (en) * | 1993-11-24 | 1998-08-11 | Intel Corporation | System and method for synchronizing data streams |
US5809512A (en) * | 1995-07-28 | 1998-09-15 | Matsushita Electric Industrial Co., Ltd. | Information provider apparatus enabling selective playing of multimedia information by interactive input based on displayed hypertext information |
US5877763A (en) * | 1996-11-20 | 1999-03-02 | International Business Machines Corporation | Data processing system and method for viewing objects on a user interface |
US5949410A (en) * | 1996-10-18 | 1999-09-07 | Samsung Electronics Company, Ltd. | Apparatus and method for synchronizing audio and video frames in an MPEG presentation system |
US5995095A (en) * | 1997-12-19 | 1999-11-30 | Sharp Laboratories Of America, Inc. | Method for hierarchical summarization and browsing of digital video |
US6069633A (en) * | 1997-09-18 | 2000-05-30 | Netscape Communications Corporation | Sprite engine |
US6122433A (en) * | 1994-10-20 | 2000-09-19 | Thomson Licensing S.A. | HDTV trick play stream derivation for VCR |
US6212595B1 (en) * | 1998-07-29 | 2001-04-03 | International Business Machines Corporation | Computer program product for fencing a member of a group of processes in a distributed processing environment |
US20010054180A1 (en) * | 2000-01-06 | 2001-12-20 | Atkinson Paul D. | System and method for synchronizing output of media in public spaces |
US20010056580A1 (en) * | 2000-06-24 | 2001-12-27 | Lg Electronics Inc. | Recording medium containing supplementary service information for audio/video contents, and method and apparatus of providing supplementary service information of the recording medium |
US20010056504A1 (en) * | 1999-12-21 | 2001-12-27 | Eugene Kuznetsov | Method and apparatus of data exchange using runtime code generator and translator |
US20020038257A1 (en) * | 1994-04-28 | 2002-03-28 | Kuriacose Joseph | Apparatus for transmitting and receiving executable applications as for a multimedia system |
US6369830B1 (en) * | 1999-05-10 | 2002-04-09 | Apple Computer, Inc. | Rendering translucent layers in a display system |
US6385596B1 (en) * | 1998-02-06 | 2002-05-07 | Liquid Audio, Inc. | Secure online music distribution system |
US6414686B1 (en) * | 1998-12-01 | 2002-07-02 | Eidos Plc | Multimedia editing and composition system having temporal display |
US20020099952A1 (en) * | 2000-07-24 | 2002-07-25 | Lambert John J. | Policies for secure software execution |
US6426778B1 (en) * | 1998-04-03 | 2002-07-30 | Avid Technology, Inc. | System and method for providing interactive components in motion video |
US20020103496A1 (en) * | 2001-01-29 | 2002-08-01 | Harper Richard M. | Ultrasonic surgical instrument with finger actuator |
US6430570B1 (en) * | 1999-03-01 | 2002-08-06 | Hewlett-Packard Company | Java application manager for embedded device |
US20020157103A1 (en) * | 2000-01-07 | 2002-10-24 | Deyang Song | Method for digital media playback in a broadcast network |
US20020170005A1 (en) * | 2001-02-02 | 2002-11-14 | Keith Hayes | Method and apparatus for providing client-based network security |
US6505153B1 (en) * | 2000-05-22 | 2003-01-07 | Compaq Information Technologies Group, L.P. | Efficient method for producing off-line closed captions |
US20030025599A1 (en) * | 2001-05-11 | 2003-02-06 | Monroe David A. | Method and apparatus for collecting, sending, archiving and retrieving motion video and still images and notification of detected events |
US20030078930A1 (en) * | 2001-08-21 | 2003-04-24 | Andre Surcouf | File and content management |
US6564382B2 (en) * | 2000-08-16 | 2003-05-13 | Koninklijke Philips Electronics N.V. | Method for playing multimedia applications |
US20030093792A1 (en) * | 2000-06-30 | 2003-05-15 | Labeeb Ismail K. | Method and apparatus for delivery of television programs and targeted de-coupled advertising |
US6565153B2 (en) * | 2001-07-31 | 2003-05-20 | Johnson Controls Technology Corporation | Upper back support for a seat |
US20030142137A1 (en) * | 2002-01-28 | 2003-07-31 | International Business Machines Corporation | Selectively adjusting the order of windows in response to a scroll wheel rotation |
US20030152904A1 (en) * | 2001-11-30 | 2003-08-14 | Doty Thomas R. | Network based educational system |
US20030174160A1 (en) * | 2002-03-15 | 2003-09-18 | John Deutscher | Interactive presentation viewing system employing multi-media components |
US20030182624A1 (en) * | 2002-03-14 | 2003-09-25 | Openwave Systems Inc. | Method and apparatus for developing web services using standard logical interfaces to support multiple markup languages |
US20030182364A1 (en) * | 2002-03-14 | 2003-09-25 | Openwave Systems Inc. | Method and apparatus for requesting and performing batched operations for web services |
US6629150B1 (en) * | 1999-06-18 | 2003-09-30 | Intel Corporation | Platform and method for creating and using a digital container |
US20030187801A1 (en) * | 2002-03-26 | 2003-10-02 | Microsoft Corporation | Content revocation and license modification in a digital rights management (DRM) system on a computing device |
US20030204613A1 (en) * | 2002-04-26 | 2003-10-30 | Hudson Michael D. | System and methods of streaming media files from a dispersed peer network to maintain quality of service |
US20030210270A1 (en) * | 2002-05-10 | 2003-11-13 | Microsoft Corp. | Method and apparatus for managing input focus and z-order |
US6665835B1 (en) * | 1997-12-23 | 2003-12-16 | Verizon Laboratories, Inc. | Real time media journaler with a timing event coordinator |
US20030231863A1 (en) * | 1998-06-11 | 2003-12-18 | Koninklijke Philips Electronics N.V. | Trick play signal generation for a digital video recorder using retrieved intra-encoded pictures and generated inter-encoded pictures |
US20040001706A1 (en) * | 2002-06-29 | 2004-01-01 | Samsung Electronics Co., Ltd. | Method and apparatus for moving focus for navigation in interactive mode |
US20040034795A1 (en) * | 2001-04-30 | 2004-02-19 | Anderson Mark Stephen | Event handling system |
US20040034622A1 (en) * | 2002-08-13 | 2004-02-19 | Espinoza Danny Javier | Applications software and method for authoring and communicating multimedia content in a multimedia object communication and handling platform |
US20040039834A1 (en) * | 2002-08-20 | 2004-02-26 | Microsoft Corporation | Media streaming of web content data |
US20040039909A1 (en) * | 2002-08-22 | 2004-02-26 | David Cheng | Flexible authentication with multiple levels and factors |
US20040049793A1 (en) * | 1998-12-04 | 2004-03-11 | Chou Philip A. | Multimedia presentation latency minimization |
US6715126B1 (en) * | 1998-09-16 | 2004-03-30 | International Business Machines Corporation | Efficient streaming of synchronized web content from multiple sources |
US20040107401A1 (en) * | 2002-12-02 | 2004-06-03 | Samsung Electronics Co., Ltd | Apparatus and method for authoring multimedia document |
US20040107179A1 (en) * | 2002-08-22 | 2004-06-03 | Mdt, Inc. | Method and system for controlling software execution in an event-driven operating system environment |
US20040123316A1 (en) * | 2002-08-21 | 2004-06-24 | Kendall Scott Allan | Method for adjusting parameters for the presentation of multimedia objects |
US20040133292A1 (en) * | 2002-11-15 | 2004-07-08 | Atsuhiro Sakurai | Generalized envelope matching technique for fast time-scale modification |
US20040143823A1 (en) * | 2003-01-10 | 2004-07-22 | Wei Coach K. | System and method for network-based computing |
US20040148514A1 (en) * | 2000-06-21 | 2004-07-29 | Fee Gregory D | Evidence-based application security |
US20040153648A1 (en) * | 2003-01-31 | 2004-08-05 | Rotholtz Ben Aaron | Method and process for transmitting video content |
US20040156613A1 (en) * | 2001-07-06 | 2004-08-12 | Hempel Andrew Kosamir Henry | Method and system for computer software application execution |
US6785729B1 (en) * | 2000-08-25 | 2004-08-31 | International Business Machines Corporation | System and method for authorizing a network user as entitled to access a computing node wherein authenticated certificate received from the user is mapped into the user identification and the user is presented with the opprtunity to logon to the computing node only after the verification is successful |
US20040205478A1 (en) * | 2001-09-13 | 2004-10-14 | I-Jong Lin | Real-time slide presentation multimedia data object and system and method of recording and browsing a multimedia data object |
US20040205479A1 (en) * | 2001-10-30 | 2004-10-14 | Seaman Mark D. | System and method for creating a multimedia presentation |
US20040210824A1 (en) * | 1996-03-29 | 2004-10-21 | Microsoft Corporation | Interactive entertainment system for presenting supplemental interactive content together with continuous video programs |
US20040221311A1 (en) * | 2003-03-20 | 2004-11-04 | Christopher Dow | System and method for navigation of indexed video content |
US20040223740A1 (en) * | 2003-05-07 | 2004-11-11 | Nec Corporation | Video recording apparatus, recording medium, video recording method, and program |
US20040244003A1 (en) * | 2003-05-30 | 2004-12-02 | Vidiator Enterprises Inc. | Apparatus and method for task scheduling for media processing |
US20040243927A1 (en) * | 2002-03-09 | 2004-12-02 | Samsung Electronics Co. Ltd. | Reproducing method and apparatus for interactive mode using markup documents |
US20040268224A1 (en) * | 2000-03-31 | 2004-12-30 | Balkus Peter A. | Authoring system for combining temporal and nontemporal digital media |
US20040267952A1 (en) * | 2003-06-24 | 2004-12-30 | He Li-Wei | Variable play speed control for media streams |
US20050029842A1 (en) * | 2003-07-09 | 2005-02-10 | Martin Peter Gordon | Cycle saddle assembly |
US20050091574A1 (en) * | 2003-10-27 | 2005-04-28 | Jussi Maaniitty | Multimedia presentation editor for a small-display communication terminal or computing device |
US20050114896A1 (en) * | 2003-11-21 | 2005-05-26 | Hug Joshua D. | Digital rights management for content rendering on playback devices |
US20050122530A1 (en) * | 2000-10-13 | 2005-06-09 | Winfried Denk | System and method for optical scanning |
US6906643B2 (en) * | 2003-04-30 | 2005-06-14 | Hewlett-Packard Development Company, L.P. | Systems and methods of viewing, modifying, and interacting with “path-enhanced” multimedia |
US20050132266A1 (en) * | 2003-11-21 | 2005-06-16 | Ambrosino Timothy J. | Method of authoring, deploying and using interactive, data-driven two or more dimensional content |
US20050140694A1 (en) * | 2003-10-23 | 2005-06-30 | Sriram Subramanian | Media Integration Layer |
US20050149729A1 (en) * | 2003-12-24 | 2005-07-07 | Zimmer Vincent J. | Method to support XML-based security and key management services in a pre-boot execution environment |
US6920613B2 (en) * | 2001-08-27 | 2005-07-19 | Xerox Corporation | Video/text bi-directional linkage for software fault clearance applications |
US6925499B1 (en) * | 2001-12-19 | 2005-08-02 | Info Value Computing, Inc. | Video distribution system using disk load balancing by file copying |
US20050183016A1 (en) * | 2004-01-20 | 2005-08-18 | Pioneer Corporation | Apparatus, method, and computer product for recognizing video contents, and for video recording |
US20050190947A1 (en) * | 2004-03-01 | 2005-09-01 | Dulac Stephen P. | Video on demand in a broadcast network |
US20050244146A1 (en) * | 2004-04-30 | 2005-11-03 | Yasufumi Tsumagari | Meta data for moving picture |
US20050289348A1 (en) * | 2004-06-23 | 2005-12-29 | Microsoft Corporation | System and method for providing security to an application |
US20060020950A1 (en) * | 2004-06-30 | 2006-01-26 | Patrick Ladd | Apparatus and methods for implementation of network software interfaces |
US20060041522A1 (en) * | 2004-08-18 | 2006-02-23 | Xerox Corporation. | Abstract document management systems and methods |
US20060083486A1 (en) * | 2004-10-15 | 2006-04-20 | Takashi Kanemaru | Reproducing apparatus and method |
US20060123451A1 (en) * | 2004-12-07 | 2006-06-08 | Showtime Networks Inc. | Enhanced content in an on-demand environment |
US20060136914A1 (en) * | 2004-11-30 | 2006-06-22 | Metreos Corporation | Application server system and method |
US20060140079A1 (en) * | 2003-11-28 | 2006-06-29 | Toshiya Hamada | Reproduction device, reproduction method, reproduction program, and recording medium |
US7120859B2 (en) * | 2001-09-11 | 2006-10-10 | Sony Corporation | Device for producing multimedia presentation |
US7131143B1 (en) * | 2000-06-21 | 2006-10-31 | Microsoft Corporation | Evaluating initially untrusted evidence in an evidence-based security policy manager |
US20060269221A1 (en) * | 2005-05-18 | 2006-11-30 | Matsushita Electric Industrial Co., Ltd | Content reproduction apparatus |
US20060274612A1 (en) * | 2005-06-02 | 2006-12-07 | Lg Electronics Inc. | Recording medium, apparatus for reproducing data, method thereof, apparatus for storing data and method thereof |
US20070006063A1 (en) * | 2005-07-01 | 2007-01-04 | Microsoft Corporation | Synchronization aspects of interactive multimedia presentation management |
Family Cites Families (33)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7095783B1 (en) * | 1992-06-30 | 2006-08-22 | Discovision Associates | Multistandard video decoder and decompression system for processing encoded bit streams including start codes and methods relating thereto |
US5842033A (en) * | 1992-06-30 | 1998-11-24 | Discovision Associates | Padding apparatus for passing an arbitrary number of bits through a buffer in a pipeline system |
US5544318A (en) * | 1993-04-16 | 1996-08-06 | Accom, Inc., | Asynchronous media server request processing system for servicing reprioritizing request from a client determines whether or not to delay executing said reprioritizing request |
EP1667147B1 (en) * | 1993-12-18 | 2014-03-12 | Sony Corporation | Data reproduction apparatus and data storage |
US6075552A (en) * | 1996-06-12 | 2000-06-13 | Nec Corporation | Monitoring system of multimedia communication terminal |
JPH10289524A (en) * | 1997-04-11 | 1998-10-27 | Sony Corp | Recording medium drive device |
US6340977B1 (en) * | 1999-05-07 | 2002-01-22 | Philip Lui | System and method for dynamic assistance in software applications using behavior and host application models |
US6457122B1 (en) * | 1999-06-18 | 2002-09-24 | Phoenix Technologies Ltd. | Fault tolerant process for the delivery of programs to writeable storage device utilizing pre-operating system software/firmware |
CA2310535A1 (en) * | 1999-06-30 | 2000-12-30 | International Business Machines Corporation | Vault controller context manager and methods of operation for securely maintaining state information between successive browser connections in an electronic business system |
CA2388095A1 (en) * | 1999-10-22 | 2001-05-03 | Activesky, Inc. | An object oriented video system |
WO2001045018A1 (en) * | 1999-12-17 | 2001-06-21 | Dorado Network Systems Corporation | Purpose-based adaptive rendering |
US20040220791A1 (en) * | 2000-01-03 | 2004-11-04 | Interactual Technologies, Inc. A California Corpor | Personalization services for entities from multiple sources |
US20020055928A1 (en) * | 2000-06-21 | 2002-05-09 | Imedium, Inc. | Methods and apparatus employing multi-tier de-coupled architecture for enabling visual interactive display |
US7124424B2 (en) * | 2000-11-27 | 2006-10-17 | Sedna Patent Services, Llc | Method and apparatus for providing interactive program guide (IPG) and video-on-demand (VOD) user interfaces |
JP4691798B2 (en) * | 2001-01-15 | 2011-06-01 | ソニー株式会社 | Recording apparatus and recording medium |
US7917888B2 (en) * | 2001-01-22 | 2011-03-29 | Symbol Technologies, Inc. | System and method for building multi-modal and multi-channel applications |
US6791581B2 (en) * | 2001-01-31 | 2004-09-14 | Microsoft Corporation | Methods and systems for synchronizing skin properties |
US7266816B1 (en) * | 2001-04-30 | 2007-09-04 | Sun Microsystems, Inc. | Method and apparatus for upgrading managed application state for a java based application |
US7778717B2 (en) * | 2002-04-15 | 2010-08-17 | Invensys Systems, Inc. | Component object model communication method for a control system |
US6847393B2 (en) * | 2002-04-19 | 2005-01-25 | Wren Technology Group | Method and system for monitoring point of sale exceptions |
US7231630B2 (en) * | 2002-07-12 | 2007-06-12 | Ensequence Inc. | Method and system automatic control of graphical computer application appearance and execution |
EP1570354A4 (en) * | 2002-11-19 | 2008-07-02 | Nexaweb Technologies Inc | System and method for stateful web-based computing |
CN100474915C (en) * | 2003-01-31 | 2009-04-01 | 松下电器产业株式会社 | Recording medium, reproduction device, recording method, program, and reproduction method |
KR100886528B1 (en) * | 2003-02-28 | 2009-03-02 | 파나소닉 주식회사 | Recording medium, playback device, recording method, computer readable recording medium, playback method for realizing the display of interactive screens with animations |
US7941030B2 (en) * | 2003-04-04 | 2011-05-10 | Victor Company Of Japan, Limited | Audio/video recording apparatus, recording method, playback apparatus, playback method, playback program, and recording program |
US7146563B2 (en) * | 2003-05-29 | 2006-12-05 | International Business Machines Corporation | Maintaining screen and form state in portlets |
US7562254B2 (en) * | 2003-07-01 | 2009-07-14 | International Business Machines Corporation | Checkpointing and restarting long running web services |
CA2541929A1 (en) * | 2003-10-10 | 2005-04-21 | Koninklijke Philips Electronics N.V. | Java lifecycle model for bd-discs |
KR101129121B1 (en) * | 2003-11-12 | 2012-03-27 | 파나소닉 주식회사 | Recording media, reproducing apparatus and method, recording method |
US7761878B2 (en) * | 2003-11-19 | 2010-07-20 | Nexaweb Technologies, Inc | System and method for stateful web-based computing |
JP2005267614A (en) * | 2004-02-16 | 2005-09-29 | Canon Inc | Information processing system, server device, control method of server device, program and storage medium |
US20060080702A1 (en) * | 2004-05-20 | 2006-04-13 | Turner Broadcasting System, Inc. | Systems and methods for delivering content over a network |
US20060005205A1 (en) * | 2004-06-08 | 2006-01-05 | Daniel Illowsky | Device interoperability framework and method for building interoperability applications for interoperable team of devices |
-
2006
- 2006-02-13 US US11/352,662 patent/US20070006238A1/en not_active Abandoned
- 2006-06-20 WO PCT/US2006/023906 patent/WO2007005269A1/en active Application Filing
- 2006-06-20 KR KR1020077030958A patent/KR20080021084A/en not_active Ceased
- 2006-06-20 JP JP2008519380A patent/JP5242387B2/en not_active Expired - Fee Related
- 2006-06-20 EP EP06773586A patent/EP1899834A4/en not_active Ceased
-
2014
- 2014-04-28 US US14/263,508 patent/US20140237332A1/en not_active Abandoned
Patent Citations (99)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5694560A (en) * | 1991-09-13 | 1997-12-02 | Matsushita Electric Industrial Co., Ltd. | Workstation for displaying dynamic image with real-time special effects |
US5394547A (en) * | 1991-12-24 | 1995-02-28 | International Business Machines Corporation | Data processing system and method having selectable scheduler |
US5794018A (en) * | 1993-11-24 | 1998-08-11 | Intel Corporation | System and method for synchronizing data streams |
US5608859A (en) * | 1993-12-28 | 1997-03-04 | Nec Corporation | Scenario editing apparatus |
US20020038257A1 (en) * | 1994-04-28 | 2002-03-28 | Kuriacose Joseph | Apparatus for transmitting and receiving executable applications as for a multimedia system |
US6122433A (en) * | 1994-10-20 | 2000-09-19 | Thomson Licensing S.A. | HDTV trick play stream derivation for VCR |
US5717468A (en) * | 1994-12-02 | 1998-02-10 | International Business Machines Corporation | System and method for dynamically recording and displaying comments for a video movie |
US5758008A (en) * | 1995-07-04 | 1998-05-26 | Pioneer Electronic Corporation | Information recording apparatus and information reproducing apparatus |
US5659539A (en) * | 1995-07-14 | 1997-08-19 | Oracle Corporation | Method and apparatus for frame accurate access of digital audio-visual information |
US5809512A (en) * | 1995-07-28 | 1998-09-15 | Matsushita Electric Industrial Co., Ltd. | Information provider apparatus enabling selective playing of multimedia information by interactive input based on displayed hypertext information |
US5631694A (en) * | 1996-02-01 | 1997-05-20 | Ibm Corporation | Maximum factor selection policy for batching VOD requests |
US20050015815A1 (en) * | 1996-03-29 | 2005-01-20 | Microsoft Corporation | Interactive entertainment system for presenting supplemental interactive content together with continuous video programs |
US20040210824A1 (en) * | 1996-03-29 | 2004-10-21 | Microsoft Corporation | Interactive entertainment system for presenting supplemental interactive content together with continuous video programs |
US5949410A (en) * | 1996-10-18 | 1999-09-07 | Samsung Electronics Company, Ltd. | Apparatus and method for synchronizing audio and video frames in an MPEG presentation system |
US5877763A (en) * | 1996-11-20 | 1999-03-02 | International Business Machines Corporation | Data processing system and method for viewing objects on a user interface |
US6069633A (en) * | 1997-09-18 | 2000-05-30 | Netscape Communications Corporation | Sprite engine |
US5995095A (en) * | 1997-12-19 | 1999-11-30 | Sharp Laboratories Of America, Inc. | Method for hierarchical summarization and browsing of digital video |
US6665835B1 (en) * | 1997-12-23 | 2003-12-16 | Verizon Laboratories, Inc. | Real time media journaler with a timing event coordinator |
US6385596B1 (en) * | 1998-02-06 | 2002-05-07 | Liquid Audio, Inc. | Secure online music distribution system |
US6426778B1 (en) * | 1998-04-03 | 2002-07-30 | Avid Technology, Inc. | System and method for providing interactive components in motion video |
US20030231863A1 (en) * | 1998-06-11 | 2003-12-18 | Koninklijke Philips Electronics N.V. | Trick play signal generation for a digital video recorder using retrieved intra-encoded pictures and generated inter-encoded pictures |
US6212595B1 (en) * | 1998-07-29 | 2001-04-03 | International Business Machines Corporation | Computer program product for fencing a member of a group of processes in a distributed processing environment |
US6715126B1 (en) * | 1998-09-16 | 2004-03-30 | International Business Machines Corporation | Efficient streaming of synchronized web content from multiple sources |
US6414686B1 (en) * | 1998-12-01 | 2002-07-02 | Eidos Plc | Multimedia editing and composition system having temporal display |
US20040049793A1 (en) * | 1998-12-04 | 2004-03-11 | Chou Philip A. | Multimedia presentation latency minimization |
US6430570B1 (en) * | 1999-03-01 | 2002-08-06 | Hewlett-Packard Company | Java application manager for embedded device |
US6369830B1 (en) * | 1999-05-10 | 2002-04-09 | Apple Computer, Inc. | Rendering translucent layers in a display system |
US6629150B1 (en) * | 1999-06-18 | 2003-09-30 | Intel Corporation | Platform and method for creating and using a digital container |
US20010056504A1 (en) * | 1999-12-21 | 2001-12-27 | Eugene Kuznetsov | Method and apparatus of data exchange using runtime code generator and translator |
US20010054180A1 (en) * | 2000-01-06 | 2001-12-20 | Atkinson Paul D. | System and method for synchronizing output of media in public spaces |
US20020157103A1 (en) * | 2000-01-07 | 2002-10-24 | Deyang Song | Method for digital media playback in a broadcast network |
US20040268224A1 (en) * | 2000-03-31 | 2004-12-30 | Balkus Peter A. | Authoring system for combining temporal and nontemporal digital media |
US6505153B1 (en) * | 2000-05-22 | 2003-01-07 | Compaq Information Technologies Group, L.P. | Efficient method for producing off-line closed captions |
US7131143B1 (en) * | 2000-06-21 | 2006-10-31 | Microsoft Corporation | Evaluating initially untrusted evidence in an evidence-based security policy manager |
US20040148514A1 (en) * | 2000-06-21 | 2004-07-29 | Fee Gregory D | Evidence-based application security |
US20010056580A1 (en) * | 2000-06-24 | 2001-12-27 | Lg Electronics Inc. | Recording medium containing supplementary service information for audio/video contents, and method and apparatus of providing supplementary service information of the recording medium |
US20030093792A1 (en) * | 2000-06-30 | 2003-05-15 | Labeeb Ismail K. | Method and apparatus for delivery of television programs and targeted de-coupled advertising |
US20020099952A1 (en) * | 2000-07-24 | 2002-07-25 | Lambert John J. | Policies for secure software execution |
US6564382B2 (en) * | 2000-08-16 | 2003-05-13 | Koninklijke Philips Electronics N.V. | Method for playing multimedia applications |
US6785729B1 (en) * | 2000-08-25 | 2004-08-31 | International Business Machines Corporation | System and method for authorizing a network user as entitled to access a computing node wherein authenticated certificate received from the user is mapped into the user identification and the user is presented with the opprtunity to logon to the computing node only after the verification is successful |
US20050122530A1 (en) * | 2000-10-13 | 2005-06-09 | Winfried Denk | System and method for optical scanning |
US20020103496A1 (en) * | 2001-01-29 | 2002-08-01 | Harper Richard M. | Ultrasonic surgical instrument with finger actuator |
US20020170005A1 (en) * | 2001-02-02 | 2002-11-14 | Keith Hayes | Method and apparatus for providing client-based network security |
US20040034795A1 (en) * | 2001-04-30 | 2004-02-19 | Anderson Mark Stephen | Event handling system |
US20030025599A1 (en) * | 2001-05-11 | 2003-02-06 | Monroe David A. | Method and apparatus for collecting, sending, archiving and retrieving motion video and still images and notification of detected events |
US20040156613A1 (en) * | 2001-07-06 | 2004-08-12 | Hempel Andrew Kosamir Henry | Method and system for computer software application execution |
US6565153B2 (en) * | 2001-07-31 | 2003-05-20 | Johnson Controls Technology Corporation | Upper back support for a seat |
US20030078930A1 (en) * | 2001-08-21 | 2003-04-24 | Andre Surcouf | File and content management |
US6920613B2 (en) * | 2001-08-27 | 2005-07-19 | Xerox Corporation | Video/text bi-directional linkage for software fault clearance applications |
US7120859B2 (en) * | 2001-09-11 | 2006-10-10 | Sony Corporation | Device for producing multimedia presentation |
US20040205478A1 (en) * | 2001-09-13 | 2004-10-14 | I-Jong Lin | Real-time slide presentation multimedia data object and system and method of recording and browsing a multimedia data object |
US20040205479A1 (en) * | 2001-10-30 | 2004-10-14 | Seaman Mark D. | System and method for creating a multimedia presentation |
US20030152904A1 (en) * | 2001-11-30 | 2003-08-14 | Doty Thomas R. | Network based educational system |
US6925499B1 (en) * | 2001-12-19 | 2005-08-02 | Info Value Computing, Inc. | Video distribution system using disk load balancing by file copying |
US20030142137A1 (en) * | 2002-01-28 | 2003-07-31 | International Business Machines Corporation | Selectively adjusting the order of windows in response to a scroll wheel rotation |
US20040243927A1 (en) * | 2002-03-09 | 2004-12-02 | Samsung Electronics Co. Ltd. | Reproducing method and apparatus for interactive mode using markup documents |
US20040247292A1 (en) * | 2002-03-09 | 2004-12-09 | Samsung Electronics Co. Ltd. | Reproducing method and apparatus for interactive mode using markup documents |
US20040250200A1 (en) * | 2002-03-09 | 2004-12-09 | Samsung Electronics Co. Ltd. | Reproducing method and apparatus for interactive mode using markup documents |
US20030182624A1 (en) * | 2002-03-14 | 2003-09-25 | Openwave Systems Inc. | Method and apparatus for developing web services using standard logical interfaces to support multiple markup languages |
US20030182364A1 (en) * | 2002-03-14 | 2003-09-25 | Openwave Systems Inc. | Method and apparatus for requesting and performing batched operations for web services |
US20030174160A1 (en) * | 2002-03-15 | 2003-09-18 | John Deutscher | Interactive presentation viewing system employing multi-media components |
US20030187801A1 (en) * | 2002-03-26 | 2003-10-02 | Microsoft Corporation | Content revocation and license modification in a digital rights management (DRM) system on a computing device |
US20030204613A1 (en) * | 2002-04-26 | 2003-10-30 | Hudson Michael D. | System and methods of streaming media files from a dispersed peer network to maintain quality of service |
US20050125741A1 (en) * | 2002-05-10 | 2005-06-09 | Microsoft Corporation | Method and apparatus for managing input focus and z-order |
US20030210270A1 (en) * | 2002-05-10 | 2003-11-13 | Microsoft Corp. | Method and apparatus for managing input focus and z-order |
US20040001706A1 (en) * | 2002-06-29 | 2004-01-01 | Samsung Electronics Co., Ltd. | Method and apparatus for moving focus for navigation in interactive mode |
US20040034622A1 (en) * | 2002-08-13 | 2004-02-19 | Espinoza Danny Javier | Applications software and method for authoring and communicating multimedia content in a multimedia object communication and handling platform |
US20040039834A1 (en) * | 2002-08-20 | 2004-02-26 | Microsoft Corporation | Media streaming of web content data |
US20040123316A1 (en) * | 2002-08-21 | 2004-06-24 | Kendall Scott Allan | Method for adjusting parameters for the presentation of multimedia objects |
US20040039909A1 (en) * | 2002-08-22 | 2004-02-26 | David Cheng | Flexible authentication with multiple levels and factors |
US20040107179A1 (en) * | 2002-08-22 | 2004-06-03 | Mdt, Inc. | Method and system for controlling software execution in an event-driven operating system environment |
US20040133292A1 (en) * | 2002-11-15 | 2004-07-08 | Atsuhiro Sakurai | Generalized envelope matching technique for fast time-scale modification |
US20040107401A1 (en) * | 2002-12-02 | 2004-06-03 | Samsung Electronics Co., Ltd | Apparatus and method for authoring multimedia document |
US20040143823A1 (en) * | 2003-01-10 | 2004-07-22 | Wei Coach K. | System and method for network-based computing |
US20040153648A1 (en) * | 2003-01-31 | 2004-08-05 | Rotholtz Ben Aaron | Method and process for transmitting video content |
US20040221311A1 (en) * | 2003-03-20 | 2004-11-04 | Christopher Dow | System and method for navigation of indexed video content |
US6906643B2 (en) * | 2003-04-30 | 2005-06-14 | Hewlett-Packard Development Company, L.P. | Systems and methods of viewing, modifying, and interacting with “path-enhanced” multimedia |
US20040223740A1 (en) * | 2003-05-07 | 2004-11-11 | Nec Corporation | Video recording apparatus, recording medium, video recording method, and program |
US20040244003A1 (en) * | 2003-05-30 | 2004-12-02 | Vidiator Enterprises Inc. | Apparatus and method for task scheduling for media processing |
US20040267952A1 (en) * | 2003-06-24 | 2004-12-30 | He Li-Wei | Variable play speed control for media streams |
US20050029842A1 (en) * | 2003-07-09 | 2005-02-10 | Martin Peter Gordon | Cycle saddle assembly |
US20050140694A1 (en) * | 2003-10-23 | 2005-06-30 | Sriram Subramanian | Media Integration Layer |
US20050091574A1 (en) * | 2003-10-27 | 2005-04-28 | Jussi Maaniitty | Multimedia presentation editor for a small-display communication terminal or computing device |
US20050114896A1 (en) * | 2003-11-21 | 2005-05-26 | Hug Joshua D. | Digital rights management for content rendering on playback devices |
US20050132266A1 (en) * | 2003-11-21 | 2005-06-16 | Ambrosino Timothy J. | Method of authoring, deploying and using interactive, data-driven two or more dimensional content |
US20060140079A1 (en) * | 2003-11-28 | 2006-06-29 | Toshiya Hamada | Reproduction device, reproduction method, reproduction program, and recording medium |
US20050149729A1 (en) * | 2003-12-24 | 2005-07-07 | Zimmer Vincent J. | Method to support XML-based security and key management services in a pre-boot execution environment |
US20050183016A1 (en) * | 2004-01-20 | 2005-08-18 | Pioneer Corporation | Apparatus, method, and computer product for recognizing video contents, and for video recording |
US20050190947A1 (en) * | 2004-03-01 | 2005-09-01 | Dulac Stephen P. | Video on demand in a broadcast network |
US20050244146A1 (en) * | 2004-04-30 | 2005-11-03 | Yasufumi Tsumagari | Meta data for moving picture |
US20050289348A1 (en) * | 2004-06-23 | 2005-12-29 | Microsoft Corporation | System and method for providing security to an application |
US20060020950A1 (en) * | 2004-06-30 | 2006-01-26 | Patrick Ladd | Apparatus and methods for implementation of network software interfaces |
US20060041522A1 (en) * | 2004-08-18 | 2006-02-23 | Xerox Corporation. | Abstract document management systems and methods |
US20060083486A1 (en) * | 2004-10-15 | 2006-04-20 | Takashi Kanemaru | Reproducing apparatus and method |
US20060136914A1 (en) * | 2004-11-30 | 2006-06-22 | Metreos Corporation | Application server system and method |
US20060123451A1 (en) * | 2004-12-07 | 2006-06-08 | Showtime Networks Inc. | Enhanced content in an on-demand environment |
US20060269221A1 (en) * | 2005-05-18 | 2006-11-30 | Matsushita Electric Industrial Co., Ltd | Content reproduction apparatus |
US20060274612A1 (en) * | 2005-06-02 | 2006-12-07 | Lg Electronics Inc. | Recording medium, apparatus for reproducing data, method thereof, apparatus for storing data and method thereof |
US20070006063A1 (en) * | 2005-07-01 | 2007-01-04 | Microsoft Corporation | Synchronization aspects of interactive multimedia presentation management |
Cited By (24)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8108787B2 (en) | 2005-07-01 | 2012-01-31 | Microsoft Corporation | Distributing input events to multiple applications in an interactive media environment |
US20070005757A1 (en) * | 2005-07-01 | 2007-01-04 | Microsoft Corporation | Distributing input events to multiple applications in an interactive media environment |
US20070005758A1 (en) * | 2005-07-01 | 2007-01-04 | Microsoft Corporation | Application security in an interactive media environment |
US7721308B2 (en) | 2005-07-01 | 2010-05-18 | Microsoft Corproation | Synchronization aspects of interactive multimedia presentation management |
US7941522B2 (en) | 2005-07-01 | 2011-05-10 | Microsoft Corporation | Application security in an interactive media environment |
US8020084B2 (en) | 2005-07-01 | 2011-09-13 | Microsoft Corporation | Synchronization aspects of interactive multimedia presentation management |
US8799757B2 (en) | 2005-07-01 | 2014-08-05 | Microsoft Corporation | Synchronization aspects of interactive multimedia presentation management |
US8305398B2 (en) | 2005-07-01 | 2012-11-06 | Microsoft Corporation | Rendering and compositing multiple applications in an interactive media environment |
US8656268B2 (en) | 2005-07-01 | 2014-02-18 | Microsoft Corporation | Queueing events in an interactive media environment |
US20070006063A1 (en) * | 2005-07-01 | 2007-01-04 | Microsoft Corporation | Synchronization aspects of interactive multimedia presentation management |
US20090092249A1 (en) * | 2007-10-09 | 2009-04-09 | Microsoft Corporation | Media key-transformation obfuscation in advanced access content system |
US8023653B2 (en) * | 2007-10-09 | 2011-09-20 | Microsoft Corporation | Media key-transformation obfuscation in advanced access content system |
US10248631B2 (en) * | 2007-12-14 | 2019-04-02 | Amazon Technologies, Inc. | System and method of presenting media data |
US20230360679A1 (en) * | 2009-03-02 | 2023-11-09 | Rovi Technologies Corporation | Application tune manifests and tune state recovery |
US20120023437A1 (en) * | 2010-07-20 | 2012-01-26 | Kabushiki Kaisha Toshiba | Information processing apparatus and display region arrangement method |
US8922564B2 (en) | 2010-12-01 | 2014-12-30 | Microsoft Corporation | Controlling runtime execution from a host to conserve resources |
US9639321B2 (en) * | 2012-11-14 | 2017-05-02 | Tencent Technology (Shenzhen) Company Limited | Method and system for controlling the playback of multimedia content |
US20150242183A1 (en) * | 2012-11-14 | 2015-08-27 | Tencent Technology (Shenzhen) Company Limited | Method and system for controlling the playback of multimedia content |
US20140164890A1 (en) * | 2012-12-10 | 2014-06-12 | Microsoft Corporation | Insertion and playback of video in documents |
US9451005B2 (en) | 2013-07-15 | 2016-09-20 | Microsoft Technology Licensing, Llc | Delegation of rendering between a web application and a native application |
WO2015009504A1 (en) * | 2013-07-15 | 2015-01-22 | Microsoft Corporation | Delegation of rendering between a web application and a native application |
US10476931B2 (en) | 2013-07-15 | 2019-11-12 | Microsoft Technology Licensing, Llc | Delegation of rendering between a web application and a native application |
US10255060B2 (en) * | 2013-08-06 | 2019-04-09 | Endress + Hauser Process Solutions Ag | Method for extending an embedded software component of a field device |
US10521074B2 (en) * | 2014-07-31 | 2019-12-31 | Dell Products, Lp | System and method for a back stack in a multi-application environment |
Also Published As
Publication number | Publication date |
---|---|
KR20080021084A (en) | 2008-03-06 |
JP5242387B2 (en) | 2013-07-24 |
JP2009500725A (en) | 2009-01-08 |
WO2007005269A1 (en) | 2007-01-11 |
US20140237332A1 (en) | 2014-08-21 |
EP1899834A1 (en) | 2008-03-19 |
EP1899834A4 (en) | 2009-02-11 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20140237332A1 (en) | Managing application states in an interactive media environment | |
US8108787B2 (en) | Distributing input events to multiple applications in an interactive media environment | |
US8305398B2 (en) | Rendering and compositing multiple applications in an interactive media environment | |
KR101365829B1 (en) | Timing aspects of media content rendering | |
US8656268B2 (en) | Queueing events in an interactive media environment | |
KR101246976B1 (en) | Aspects of media content rendering | |
KR101231323B1 (en) | Declaratively responding to state changes in an interactive multimedia environment | |
US20070006080A1 (en) | Synchronization aspects of interactive multimedia presentation management | |
JP2007513546A (en) | Recording medium on which preload information is recorded, reproducing apparatus and reproducing method thereof | |
KR20050052928A (en) | Display playback device reproducing audio-visual data and interactive contents and display playback method thereof | |
KR20050041854A (en) | Storage medium storing program management information, reproducing apparatus for the storage medium, and method therefor |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: MICROSOFT CORPORATION, WASHINGTON Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:FINGER, JAMES C.;YOVIN, JOHN ANDRE;MAZHAR, KHURSHED;AND OTHERS;REEL/FRAME:017362/0018 Effective date: 20060323 |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |
|
AS | Assignment |
Owner name: MICROSOFT TECHNOLOGY LICENSING, LLC, WASHINGTON Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICROSOFT CORPORATION;REEL/FRAME:034543/0001 Effective date: 20141014 |