The present invention relates generally to content that is presented using a description language, such as Rich Media Environment. More particularly, the present invention relates to insertion of advertisements into a scene or multimedia presentation in such content.
This section is intended to provide a background or context to the invention that is recited in the claims. The description herein may include concepts that could be pursued, but are not necessarily ones that have been previously conceived or pursued. Therefore, unless otherwise indicated herein, what is described in this section is not prior art to the description and claims in this application and is not admitted to be prior art by inclusion in this section.
Rapid developments in wireless communications, media broadcasting, and content distribution continue facilitating the delivery of various services and products to mobile devices. One such service, Mobile TV, involves the delivery of various entertainment content and services to mobile users, allowing personalized and interactive viewing of TV content that is specifically adapted for mobile medium. In addition to mobility and enabling the reception of a pure broadcast (i.e., traditional) TV programs, mobile TV may be adapted to deliver a variety of additional services and features such as video-on-demand, personalized content delivery, interactive voting, SMS messaging, live chatting, targeted advertising links, and the like, that represent a merger of wireless communications with the Internet and the traditional TV broadcast services.
The development of the mobile broadcast infrastructure has also spurred the demand for what is called Rich Media Environment, or RME, content. RME is generally referred to content that is graphically rich and contains compound (or multiple) media, including graphics, text, video and audio.
Service and/or content may be formatted as OMA Rich Media Environment (RME)/3GPP Dynamic Interactive Multimedia Scenes (DIMS).
In one aspect, a method includes receiving a content update using presentation description language and inserting complementary information to the content to be presented using the presentation description language based on the content update. The content presented using presentation description language may be, in one embodiment, Rich Media Environment (RME) content, and the complementary information may include one or more advertisements.
These and other advantages and features of various embodiments, together with the organization and manner of operation thereof, will become apparent from the following detailed description when taken in conjunction with the accompanying drawings, wherein like elements have like numerals throughout the several drawings described below.
Different embodiments of the invention are described by referring to the attached drawings, in which:
In the following description, for purposes of explanation and not limitation, details and descriptions are set forth in order to provide a thorough understanding of the present invention. However, it will be apparent to those skilled in the art that the present invention may be practiced in other embodiments that depart from these details and descriptions.
Advertisements can be fixed by the time of broadcast by directly encoding them into the media stream. However, in order to get better revenue out of ads the ads themselves should be audience specific (targeted ads). Furthermore, the exact timing of an advertisement is not always known beforehand. It may be desirable to have the capability of triggering the rendering of the advertisement without further notice. For example, an advertisement may be desired to be placed just after a goal in football match.
In conventional broadcasts, advertisements are inserted into the broadcast stream so that the broadcast content and advertisements alternate. By using RME descriptions for a scene the broadcast or multicast content comprising audio, video, images, textual information using different fonts may be simultaneously rendered in a terminal.
In accordance with embodiments, one or more advertisements or other additional or complementary information and/or content may be inserted into a scene or multimedia presentation that is defined with a scene or presentation description language, such as Rich Media Environment (RME). RME is defined by Open Mobile Alliance (OMA) in the following documents: Rich Media Environment Technical Specification; Draft Version 1.0-12 Nov. 2007; OMA-TS-RME-V1—0-20071112-D; Rich-Media Environment Requirements; Draft Version 1.0-25 Aug. 2005; OMA-RD-RichMediaEnvironment-V1—0—4-20050825-D; and Rich Media Environment Architecture; Draft Version 1.0-15 Jun. 2007; OMA-AD-Rich_Media_Environment-V1—0-20070615-D. Each of these documents is available for downloading at: http://member.openmobilealliance.org/ftp/Public_documents/BT/MAE/Permanent-documents/.
In addition to RME, other scene or presentation description languages are contemplated within the scope of the present invention. Other such languages include Dynamic and Interactive Multimedia Scenes (DIMS), described in document 3GPP TS 26.142 V7.2.0 (2007-12) Technical Specification Dynamic and Interactive Multimedia Scenes; (Release 7), available for downloading at: http://www.3gpp.org/ftp/Specs/archive/26%5Fseries/26.142/.
Additionally, another such language is Synchronized Multimedia Integration Language (SMIL) 1.0 Specification (W3C Recommendation 15 Jun. 1998) available for downloading at: http://www.w3.org/TR/REC-smil/.
In accordance with embodiments, as exemplarily illustrated in
In accordance with embodiments, a scene update may change a part of scene, the layout of the scene, temporal relations between the scene objects and/or interaction with the scene objects. The update commands may allow insertion, deletion, replacement and add operations. In one embodiment, the scene update commands may change the layout so that parts of the layout are overlapping with different opacities. Further, the scene description and/or updates may have scripts embedded or included for modifying the scene or its update and/or modifying any scene objects and their mutual relations. The scripts may be based to ECMAScript Language specification, available for downloading at: http://www.ecma-international.org/publications/standards/Ecma-262.htm, but other scripts may also be used and are contemplated within the scope of the present invention.
In addition to advertisement insertion, the complementary and/or additional information may include the presentation of a selection box or a pull-down menu for selecting an item. Further, the complementary information may include notifications such as changes in program schedules, weather, traffic warnings, or other such notification.
Thus, in accordance with embodiments, the network may issue an RME scene update by which an advertisement may be inserted into an RME descripted scene. The advertisement may be delivered to the user terminal in a variety of manners. In one embodiment, the content of the advertisement is included in the update itself. In another embodiment, the content of the advertisement is pre-provisioned and referenced by the update. The user terminal may then retrieve the pre-provisioned content based on the reference. In yet another embodiment, the content of the advertisement is retrieved by the user terminal interactively upon receipt of the update. In still another embodiment, the content of the advertisement may be received from a broadcast delivery session.
In one embodiment, the RME scene update can be generated indirectly by the terminal itself through the use of, for example, proprietary signaling from the network. This may be useful when the network has a legacy advertisement trigger signaling as the legacy signaling is converted to an RME scene update.
In one embodiment, the content of the advertisement may be either terminal-specific or end-user-specific. In this regard, the advertisement can be targeted for consumption by a particular terminal or end user.
In one embodiment, a single RME stream delivers the same scene updates to all terminals. The scene update handling may be specific to terminal type and/or end user. In another embodiment, different RME streams deliver scene updates to specific terminal types and/or end users. In still another embodiment, a combination of the two above may be used. In this regard, the granularity of specialization may be varied. For example, multiple RME streams may be implemented with each RME stream being specific to a certain group of end users or terminal types.
Referring now to
In another embodiment, terminal or end-user specific RME scene update handling is implemented 220. In this regard, upon receipt of an RME scene update, the terminal processes the update based on the terminal type and/or end user preferences. One way to achieve this is by embedding a script in the scene update where the script can determine the terminal type and/or end user preferences. The specific processing of the scene update may be performed by the script itself, or the script could modify the XML Document Object Model (DOM), resulting indirectly in a terminal type and/or end user specific update. In another embodiment, the script may reside in the root RME document. In another embodiment, the terminal type and end user specific handling can be performed by a terminal type and/or end user specific part of the RME user agent itself.
In another embodiment, terminal or end-user specific content identifier resolution is implemented 230. This may be considered a special case of the RME scene update handling 220 described above. In this regard, the core of the RME scene update is performed independently of the terminal type and end user preferences. Only the content references are resolved in terminal type and/or end user preference specific manner. In another implementation, the core of the RME scene update is performed independently of the terminal type and end user preferences, and only the content references are resolved based on the terminal type and/or end user preferences.
In another embodiment, terminal or end-user specific content is implemented 240. In this regard, up to this point both the RME scene update itself and its handling may have been processed identically or resulting in identical content reference. At this point, even though the content references are identical, the content referenced differs with respect to terminal type and/or end user preferences. The may be realized using terminal type and/or end user preference specific content delivery.
Referring now to
Thus, as exemplarily illustrated in
As described above, various embodiments may deliver content updates in different manners. In one embodiment, as indicated by reference numeral 320 in
The selection of the advertisement from available advertisements that may be preloaded, delivered in file delivery, or requested by a HTTP request may be dependent on the user profile and/or preferences according to a script in the RME stream. The script defines the items from the user profile database that are taken into account when selecting the advertisement to be played. In such case the user profile is not predefined. In addition to the items in the user profile database the script may use also any other data that is accessible in the terminal such as for example time, date, last contacts, last web search keywords, use statistics, detected neighboring devices etc., thus making the user profile dynamic being for example context and/or location dependent. The scripts may be sent in the root RME data or in the RME updates. The RME update may trigger the HTTP request. The request may also be triggered by the predefined instance of time, by a user action or by a detected event. Further the script may instruct to replace an advertisement in the received content stream wherein the replacing advertisement is selected according to criteria defined above.
One class of events is an user interface (UI) event that is analyzed by an event handler creating a request for scene update to a server. These events include in some embodiments operating a pointing device as a cursor, one or more keypresses, joystick operations, ‘mouse over’ etc. Another class of events may include changes in the rendered video and/or audio stream such as program start or end. The video and/or audio content may be analyzed for exceptions such as a goal or pause in a sports program. Such events may trigger the RME scene update either on the server side or on the terminal side, wherein the inserted advertisement or other complementary information may be included in the update, may be downloaded in advance, retrieved interactively or received in the broadcast session.
In this regard, SVG, RME, Flash, MPEG4-LASeR, or similar technologies (jointly called “RME” in the disclosure) provide ways to describe scenes, layouts and manage updates to those.
In one embodiment, RME scenes, event handlers and DOM processing may be used. A script is associated with the element within RME document. An event handler is associated with the said script. When, for example, a “click” event is identified, it is associated with the event handler that in turn uses, for example, Javascript script or Java code to analyze the event. The event details, together with the commands associated with the event, are sent to the server. The server analyzes the request by the terminal and, based on the information, determines a scene update. The scene update is returned to terminal as a part of response to the request. The scene update is applied towards a master RME document at the terminal and, consequently, the uDOM is manipulated, and the effect of the scene update is shown.
The following piece of RME/SVG describes an exemplary implementation:
Referring now to
The following describes the processes at the server end. At step 6, the server receives the HTTP POST and analyzes the request. The server determines from the issued data the scene update to be applied towards client for example, scene update doing advertisement insertion at step 7. At step 8, the scene update is returned as payload of HTTP POST response and identified as scene update content using “Content-Type” header of HTTP. The terminal then receives the response from server.
At step 9, upon response to HTTP POST, the RME engine invokes callback to “urlCallBackObject”. The callback object decapsulates the scene update from the response. Executing Javascript, the RME engine applies scene update and manipulates the DOM, and the effect of the scene update is shown.
In some cases, a sender of an RME stream may want to apply a scene update that places a personalize targeted advertisement. The advertisement can be a simple image or even a complete RME document containing richer functionality. The advertisement placement command, or scene update, may need to refer to some resource, for example image or RME document, etc., to be rendered. The sender may only want to send a single scene update. In accordance with embodiments, SVG, RME, Flash, MPEG4-LASeR, or similar scene/layout descriptions and their updates may refer to resources based on criteria instead of being exactly identified.
In this regard, embodiments may 1) use a URI scheme that is specific for criteria based resource access; 2) extend underlying Document Object Model (DOM); or 3) use a local terminal-bound server at “localhost”.
In one embodiment, a URI scheme that is specific for criteria based resource access is used. One exemplary URI scheme is provided below:
Criteria-URI:==URI-scheme-id “://”*(criterion-key “=” criterion-value “?”)
URI-scheme-id:==“cref”
Criterion-key:==<any char string without white spaces>
Criterion-value:==<any char string without white spaces>
The “cref”-scheme can be used wherever URI is used, typically with “xlink:href” or “href” attribute, but not excluded to those only.
Example URI
cref.//ziplocation=10804?genre=sport
The following example illustrates the use of the URI in RME:
In the above example, the RME engine passes the “cref”-URI to corresponding handler. Thus, to support the new “cref”-scheme the RME engine/terminal should have such handler. The handler resolves the passed “cref”-URI to a reference that can be pointed with “href” and passes it back to RME engine. Resolving key-value criteria pairs is specific to each implementation. One way to do this is to keep a registry of keys with each key having multiple possible values that may be in some embodiments prioritized. Further, each key is linked with local resource, for example file. Upon matching the “cref” criteria, each “cref”-key is looked up from the registry and then the looked up values are matched with the value in the “cref”. Finally, the local resource that this way got most matches is returned.
Considering the above example, these two final interpretations are possible after “cref” processing:
1) Resolved to simple image
2) Resolved more complex way of constructing image
The selection of the appropriate, in some embodiments possibly location and end user specific, advertisement clip can be performed, for example, by the following.
The component resolves the URI designating the file. The URI could point directly to the file (file://foo/eric.mpg) or be formed by encoding the criteria to be matched. The latter could be in the form of key-value pairs found in regular URIs. For example, cref://favouriteColour=red&sex=female&age=25 would resolve to a file that represents advertisement for a twenty-five-year-old girl and whose favorite color is red.
The SVG player may provide a static function for scripts to call. This function is provided as part of the global services of the DOM-tree of the viewed document. The criteria, for example the favorite color, sex and age, are given as arguments or parameters of this function by the calling script. In other words, the script is asking for the “viewed document” to resolve the most appropriate file matching the given criteria.
The designation by the network of the file to be rendered as an advertisement will now be addressed. Giving the plain name is trivial and already supported. Here, one enables conditional selection based on the end user preferences or in some embodiments the current location. The trigger from the network for the terminal to render an advertisement could then contain just the criteria encoded URI (“cref”) or piece of script that calls the resolver function provided by the SVG player. The handler for the criteria-encoded URI (“cref”) may be the file system or that part of the SVG player that requests the file system to open the file upon the document or its update telling the player to do so.
In another embodiment, the underlying Document Object Model (DOM) may be extended. The following example is provided with SVG 1.2 Tiny Micro DOM. The SVG uDOM global is extended as follows, wherein the added part is shown with underlining:
createLocalRefByFilterRules
Creates a IRI reference associated with local resource (such as file on local file system) that matches with ‘filterRule.
in DOMString filterRules
“?”-delimited string or key-value pairs where each key precedes its associated value and key is separated from value by a equal sign. Example: “favoriteContent=sailing?userType=male”. Specifies the list of target filter rules based on which the terminal creates a local IRI reference to best-matching resource.
Return value:
DOMString
String representation of the local IRI reference.
GlobalException
UNDEFINED ERR: Raised if the values for the parameter ‘filterRules’ is not given.
In another embodiment, a local terminal-bound server is used at the “localhost”. This option is similar to first option. The difference is that in this case, no new URI scheme is required, but the http-URI is used to point to ‘localhost’. The URI definition is as follows:
URI-to-be-used:==“http://localhost/cref?”*(criterion-key “=” criterion-value “?”)
Criterion-key:==<any char string without white spaces>
Criterion-value:==<any char string without white spaces>
Thus “cref” in this case is already existing resource directly at ‘localhost’—for example a server script. This script is passed criterion key-value pairs through normal http methods.
As described above, user preferences may be used to provide targeted advertisements. In this regard, various embodiments are provided for the creation of end-user preferences and/or profiles. Such user preferences/profiles may take into account the registered user of the terminal including time used and when used, for example the time of the day and/or the day of the week.
End user preferences or profiles may be characterized in numerous ways. Therefore, predefining a general structure for the profile is impractical, if not impossible. In other words, it is very difficult to come up with a preference or profile structure that can accommodate all use cases. Often, lists of “key”-“value” pairs have been utilized, where the “key” represents the parameter in question and the “value” represents the individual value of the parameter. This in turn means that the one providing content or services has no tools for providing arbitrary characteristics that the receiving device can be expected to match with end user preferences.
In accordance with different embodiments the data structure to represent end user preferences and profile is referred as EndUserPref.
In one embodiment, a user fills in a form on a web page. Answers in the form are given to a script, for example Javascript that constructs the EndUserPref and stores it locally in the terminal.
In another embodiment, upon providing the service or content itself, a similar script is provided with the content or service and executed resulting in the EndUserPref. The resulting EndUserPref can be stored locally in the terminal. Alternatively, the resulting EndUserPref can be stored directly to the XML Document Object Model (DOM) that represents the content or service itself.
In another embodiment, the questionnaire may be an automatic probe or mole that, upon user consent, keeps track of the kind of content the end user prefers, and forms and continuously updates EndUserPref.
In another embodiment, the questionnaire may be an automatic probe or mole that, upon user consent, searches the local files, caches, program settings, bookmarks, etc. and deduces EndUserPref based on this search.
In another embodiment, the questionnaire may be an automatic probe or mole that, upon user consent, searches the Internet resources, for example social networking sites such as Facebook and deduces EndUserPref based on this search.
The local storing of EndUserPref may be achieved by creating dynamically proprietary terminal provisioning management objects (MO) such as for example that are used in OMA Device Management. In this case, there can be any tools or any kind of questionnaire as the MO can, in principle, originate from anywhere.
In one embodiment, the EndUserPref may be applied through a general or standardized format, along with general or standardized characteristics of a particular content/service. The format is known, and, therefore, one can perform comparison between characteristics of the program against the EndUserPref without knowing the semantics of individual parameters or their corresponding values.
In another embodiment, the EndUserPref may be applied through a proprietary format, along with proprietary characteristics of particular content/service. In this regard, content/service specific analysis of the characteristics of particular content/service and the EndUserPref may be required. This embodiment offers the advantage of allowing the most flexible way of characterizing preferences and characteristics.
The EndUserPref may be stored in a variety of locations. In one embodiment, upon launching the consumption of service or content, the EndUserPref can be loaded into the XML DOM object. In another embodiment, upon launching the consumption of service or content, the questionnaire is represented to the end user, and the EndUserPref is constructed specifically for this service or content.
The EndUserPref may be stored in the terminal in a variety of manners. In one embodiment, the EndUserPref may be stored in a proprietary database. In another embodiment, it may be stored in a general or standardized database, such as OMA Device Management. Although stored in a general or standardized database, the EndUserPref may be stored in either a proprietary format or a general or standardized format.
Regardless of the storage method or format of EndUserPref in the storage, the representation of EndUserPref in XML DOM may be either proprietary or standardized.
The various embodiments described herein is described in the general context of method steps or processes, which may be implemented in one embodiment by a computer program product, embodied in a computer-readable medium, including computer-executable instructions, such as program code, executed by computers in networked environments. Generally, program modules may include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. Computer-executable instructions, associated data structures, and program modules represent examples of program code for executing steps of the methods disclosed herein. The particular sequence of such executable instructions or associated data structures represents examples of corresponding acts for implementing the functions described in such steps or processes.
Software and web implementations of various embodiments can be accomplished with standard programming techniques with rule-based logic and other logic to accomplish various database searching steps or processes, correlation steps or processes, comparison steps or processes and decision steps or processes. It should be noted that the words “component” and “module,” as used herein and in the following claims, is intended to encompass implementations using one or more lines of software code, and/or hardware implementations, and/or equipment for receiving manual inputs.
The foregoing description of embodiments have been presented for purposes of illustration and description. The foregoing description is not intended to be exhaustive or to limit embodiments to the precise form disclosed, and modifications and variations are possible in light of the above teachings or may be acquired from practice of various embodiments. The embodiments discussed herein were chosen and described in order to explain the principles and the nature of various embodiments and its practical application to enable one skilled in the art to utilize the present invention in various embodiments and with various modifications as are suited to the particular use contemplated.
This application claims priority to U.S. Application No. 61/030,893 filed Feb. 22, 2008, which is hereby incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
61030893 | Feb 2008 | US |