Movatterモバイル変換


[0]ホーム

URL:


previous  next  contents  

4.The SMIL 2.1 Content Control Modules

Editor for SMIL 2.1
Thierry Michel, W3C.
Editors for SMIL 2.0
Dick Bulterman, Oratrix
Jeffrey Ayars, RealNetworks.

Table of contents

4.1 Summary of Changes for SMIL 2.1

This section is informative.

The SMIL 2.1 specification leaves the SMIL 2.0 Content Control Modules[SMIL20-content-control] unchanged.

4.2Introduction

This section is informative.

This section defines the SMIL 2.1 content control modules. These modulescontain elements and attributes which provide for runtime content choices andoptimized content delivery. SMIL content control functionality is partitionedacross four modules:

Since all of the content control elements and attributes are defined inmodules, designers of other markup languages can reuse this functionality ona module by module basis when they need to include media content control intheir language.

The functionality in the CustomTestAttributes module builds on thefunctionality of the BasicContentControl module; profiles implementing theCustomTestAttributes module must also implement the BasicContentControlmodule. The PrefetchControl and SkipContentControl modules have noprerequisites.

In some of the module descriptions for content control, the concept of"user preference" may be present. User preferences are usually set by theplayback engine using a preferences dialog box, but this specification doesnot place any restrictions on how such preferences are communicated from theuser to the SMIL player.

It is implementation dependent when content control attributes areevaluated. Attributes may be evaluated multiple times. Dynamic reevaluationis allowed but not required.

4.3The SMIL 2.1BasicContentControl Module

4.3.1SMIL 2.1BasicContentControl Module Overview

SMIL 1.0 provides a "test-attribute" mechanism to process an element onlywhen certain conditions are true, for example when the language preferencespecified by the user matches that of a media object. One or more testattributes may appear on media object references or timing structureelements; if the attribute evaluates totrue, thecontaining element is played, and if the attribute evaluates tofalse the containing element is ignored. SMIL 1.0 alsoprovides theswitch element forexpressing that a set of document parts are alternatives, and that the firstone fulfilling certain conditions should be chosen. This is useful to expressthat different language versions of an audio file are available, and that theclient may select one of them.

The SMIL 2.1 BasicContent module includes the test attribute functionalityfrom SMIL 1.0 and extends it by supporting new system test attributes. Thissection will describe the use of the predefined system test attributes, theswitch element and test attributein-line placement. A mechanism for extending test attributes is presented intheCustomTestAttributesmodule.

PredefinedSystem Test Attributes

This specification defines a list of test attributes that can be added tolanguage elements, as allowed by the language designer. In SMIL 1.0, theseelements are synchronization and media elements. Conceptually, theseattributes represent Boolean tests. When any of the test attributes specifiedfor an element evaluates tofalse, the elementcarrying this attribute is ignored.

SMIL 2.1 supports the full set of SMIL 1.0 system attributes. The SMIL 1.0compatible system test attributes are:

Note that, with the exception ofsystem-overdub-or-caption,the names of these attributes have been changed to reflect SMIL 2.1'scamelCase conventions. The SMIL 1.0 hyphenated names are deprecated inthis release.

New to SMIL 2.1 are system test attributes that define additionalcharacteristics of the system environment. These are:

The complete definition of each attribute is given in theattributes definitionsection.

Theswitch element

Theswitch element allows anauthor to specify a set of alternative elements from which only the firstacceptable element is chosen.

An example of the use of theswitch is:

  ...  <par>    <video src="anchor.mpg" ... />    <switch>      <audio src="dutchHQ.aiff" systemBitrate="56000" ... />      <audio src="dutchMQ.aiff" systemBitrate="28800" ... />      <audio src="dutchLQ.aiff" ... />    </switch>  </par>   ...

In this example, one audio object is selected to accompany the videoobject. If the system bitrate is 56000 or higher, the objectdutchHQ.aiff is selected. If the system bitrate is at least 28800 butless than 56000, the objectdutchMQ.aiff is selected. If no otherobjects are selected, the alternativedutchLQ.aiff is selected, sinceit has no test attribute (thus is always acceptable) and no other testattributes evaluated totrue.

Authors should order the alternatives from the most desirable to the leastdesirable. Furthermore, authors may wish to place a relatively fail-safealternative as the last item in theswitch so that at least one item within theswitch is chosen (unless this isexplicitly not desired).

Note that some network protocols, e.g. HTTP and RTSP, supportcontent-negotiation, which may be an alternative to using theswitch element in some cases.

It is the responsibility of the SMIL 2.1 player to determine the settingfor system test attribute values. Such settings may be determined staticallybased on configuration settings, or they may be determined (and re-evaluated)dynamically, depending on the player implementation. Players may not selectmembers of aswitch at random.

System Test AttributeIn-Line Use

To allow more flexibility in element selection, test attributes may alsobe used outside of theswitchelement.

In the following example of in-line test attribute use, captions are shownonly if the user wants captionson.

 ... <par>    <audio src="audio.rm"/>    <video src="video.rm"/>    <textstream src="stockticker.rt"/>    <textstream src="closed-caps.rt" systemCaptions="on"/> </par> ...

The alternatives indicated by the in-line construct could be representedas a set ofswitch statements,although the resultingswitch couldbecome explosive in size. Use of an in-line test mechanism significantlysimplifies the specification of adaptive content, especially in those caseswhere many independent alternatives exist. Note, however, that there is nofail-safe alternative mechanism (such as defining an element without a testattribute inside of aswitch) whenusing test attributes in-line.

Examples of Switch and Test Attribute Use

  1. Choosing between content with different total bitrates

    In a common scenario, implementations may wish to allow for selection via asystemBitrate attribute on elements. The SMIL 2.1 player evaluates each of the elements within theswitch one at a time, looking for an acceptable bitrate value.

     ... <par>    <text .../>    <switch>       <par systemBitrate="40000">       ...       </par>       <par systemBitrate="24000">       ...       </par>        <par systemBitrate="10000">       ...        </par>     </switch>  </par>  ...

    In this example, if the system bitrate has been determined to be less than 10000 (in mobile telephone cases, for example), then none of thepar constructs would be included.

  2. Choosing between audio resources with different bitrates

    The elements within theswitch may be any combination of elements. For instance, one could specify an alternate audio track:

     ... <switch>    <audio src="joe-audio-better-quality" systemBitrate="16000" />     <audio src="joe-audio" /> </switch> ...

    If the system bitrate was less than 16000, the standard-quality audio would be presented by default.

  3. Choosing between audio resources in different languages

    In the following example, an audio resource is available both in Dutch and in English. Based on the user's preferred language, the player can choose one of these audio resources.

     ... <switch>    <audio src="joe-audio-nederlands" systemLanguage="nl"/>    <audio src="joe-audio-english" systemLanguage="en"/> </switch> ...

    In this example, if the system language setting was anything other than Dutch or English, no audio would be presented. To make a choice the default, it should appear as the last item in the list and not contain a test attribute. In the following fragment, English is used as the default:

     ... <switch>    <audio src="joe-audio-nederlands" systemLanguage="nl"/>    <audio src="joe-audio-english" /> </switch> ...
  4. Choosing between content written for different screens

    In the following example, the presentation contains alternative parts designed for screens with different resolutions and bit-depths. Depending on the particular characteristics of the screen, the player must use the first alternative in which all of the test attributes evaluate totrue.

     ... <par>    <text .../>    <switch>       <par systemScreenSize="1024X1280" systemScreenDepth="16">       ...       </par>       <par systemScreenSize="480X640" systemScreenDepth="32">       ...       </par>        <par systemScreenSize="480X640" systemScreenDepth="16">        ...        </par>     </switch>  </par>  ...
  5. Supporting multiple options via in-line use

    This example shows a video that is accompanied by zero or more media objects. If the system language has been set to either Dutch or English, then the appropriate audio object will play. In addition, if the system language has been set to either Dutch or English andsystemCaptions has also been set toon, the appropriate text files will also be displayed.

      ...  <par>    <video src="anchor.mpg" ... />    <audio src="dutch.aiff"   systemLanguage="nl"  ... />    <audio src="english.aiff" systemLanguage="en" ... />    <text  src="dutch.html"   systemLanguage="nl" systemCaption="on"... />    <text  src="english.html" systemLanguage="en" systemCaption="on"... />  </par>   ...

    If system language is set to something other than Dutch or English, no objects will be rendered (except the video). Note that there is no catch-all default mechanism when using test attributes for in-line evaluation.

  6. Choosing the language of overdub and subtitle tracks

    In the following example, a French-language movie is available with English, German, and Dutch overdub and subtitle tracks. The following SMIL segment expresses this, and switches on the alternatives that the user prefers.

     ... <par>    <switch>       <audio src="movie-aud-en.rm" systemLanguage="en"             systemOverdubOrSubtitle="overdub"/>       <audio src="movie-aud-de.rm" systemLanguage="de"             systemOverdubOrSubtitle="overdub"/>       <audio src="movie-aud-nl.rm" systemLanguage="nl"             systemOverdubOrSubtitle="overdub"/>       <!-- French for everyone else -->        <audio src="movie-aud-fr.rm"/>    </switch>     <video src="movie-vid.rm"/>    <switch>        <textstream src="movie-sub-en.rt" systemLanguage="en"              systemOverdubOrSubtitle="subtitle"/>       <textstream src="movie-sub-de.rt" systemLanguage="de"             systemOverdubOrSubtitle="subtitle"/>        <textstream src="movie-sub-nl.rt" systemLanguage="nl"             systemOverdubOrSubtitle="subtitle"/>        <!-- French captions for those that really want them -->        <textstream src="movie-caps-fr.rt" systemCaptions="on"/>    </switch>  </par>  ...

4.3.2Elements andAttributes

SMIL 2.1 BasicContentControl defines theswitch element and a set of predefinedsystem test attributes.

Theswitchelement

Theswitch element allows anauthor to specify a set of alternative elements. An element is selected asfollows: the player evaluates the elements in the order in which they occurin theswitch element. The firstacceptable element is selected at the exclusion of all other elements withintheswitch. Implementations must NOTarbitrarily pick an object within aswitch when test attributes for all childelements fail.

Element attributes

This element does not have attributes beyond those required of allelements in the profile.

Element content

The content of the element is language implementation dependent.

In the SMIL 2.1 language profile, if theswitch is used as a direct or indirectchild of abody element, it may containany media object or timing structure container, or it may contain nestedswitch elements. All of theseelements may appear multiple times inside theswitch. If theswitch is used as a direct or indirectchild of ahead element, it may containone or morelayout elements.

Predefined TestAttributes

SMIL 2.1 defines the following system test attributes. When any of thetest attributes specified for an element evaluates tofalse, the element carrying this attribute is ignored.Note that most hyphenated test attribute names from SMIL 1.0 have beendeprecated in favor of names using the current SMILcamelCaseconvention. For these, the deprecated SMIL 1.0 name is shown in parenthesesafter the preferred name.

systemAudioDesc
values:on | off
This test attribute specifies whether or not closed audio descriptions should be rendered. This is intended to provide authors with the ability to support audio descriptions in the same way thatsystemCaptions provides text captions. The value ofsystemAudioDesc is used to control object rendering in conjunction with the user's preference for receiving audio descriptions of a media object if and when these are available. A value ofon indicates a preference to have such descriptions rendered when available. A value ofoff indicates a preference not to render such descriptions.
Authors should placesystemAudioDesc =on only on elements that they wish to render when the user has indicated they want audio descriptions. Authors should placesystemAudioDesc =off only on elements that they wish to render when the user has indicated they DON'T want audio descriptions.
Evaluates totrue if the user preference matches this attribute value. Evaluates tofalse if they do not match.
systemBitrate (system-bitrate)
value:the approximate bandwidth, in bits-per-second, available to the system.
The measurement of bandwidth is application specific, meaning that applications may use sophisticated measurement of end-to-end connectivity, or a simple static setting controlled by the user. In the latter case, this could for instance be used to make a choice based on the user's connection to the network. Typical values for modem users would be 14400, 28800, 56000 bit/s etc. Evaluates totrue if the available system bitrate is equal to or greater than the given value. Evaluates tofalse if the available system bitrate is less than the given value.
The attribute can assume any integer value greater than 0. If the value exceeds an implementation-defined maximum bandwidth value, the attribute always evaluates tofalse.
systemCaptions (system-captions)
values:on | off
This attribute allows authors to specify a redundant text equivalent of the audio portion of the presentation. Examples of intended use are: audiences with hearing disabilities, those learning to read, or anyone who wants or needs this information.
Evaluates totrue if the user preference matches this attribute value. Evaluates tofalse if they do not match.
systemComponent
value:an XML CDATA string containing one or more white-space separatedURI's.
Each URI identifies a component of the playback system, e.g. user agent component/feature, number of audio channels, codec, HW MPEG decoder, etc. The URI is implementation dependent. Each implementation is encouraged to publish a list of component URIs which can be used to identify and resolve the presence of implementation-dependent components.
Evaluates totrue if all URI's match one of the URI's that the user agent recognizes. Evaluates tofalse otherwise.
systemCPU
value:an XML NMTOKEN ([[XML11]).
This test attribute specifies the CPU on which a user agent may be running. An implementation must allow the user the ability to set the system value tounknown for privacy.
The following list contains the suggested values for this test attribute (additional names may be supported by an implementation):alpha, arm, arm32, hppa1.1, m68k, mips, ppc, rs6000, vax, x86, unknown.

These values come from the _PR_SI_ARCHITECTURE constants defined by themozilla project.

Evaluates totrue if the user preference matches this attribute value. Evaluates tofalse if they do not match. The value is case-sensitive.
systemLanguage (system-language)
values:a comma-separated list of language names as defined in [RFC1766], or an empty/null string
This attribute evaluates totrue (1) if one of the languages indicated by user preferences exactly equals one of the languages given in the value of this parameter, or (2) if one of the languages indicated by user preferences exactly matches a prefix of one of the languages given in the value of this parameter such that the first tag character following the prefix is "-". Evaluates tofalse otherwise. For example, if generic English is specified in the user preferences, it will match both "en" by case (1) and "en-gb" (British English) by case (2), but if British English is specified in the user preferences, it will match only "en-gb" by case (1).
If a null or empty string is specified, the test attribute evaluates tofalse.

The syntax of thesystemLanguage and the deprecatedsystem-language attributes are defined using EBNF notation (as defined in[XML11]) as list of XML namespace prefixes[XML-NS], separated by the ',' character:

systemLanguageArgumentValue ::= (languageTag (S? ',' S? languageTag)*)?

Where allowed white space is indicated as "S", defined as follows (taken from the[XML11] definition for 'S'):

S ::= (#x20 | #x9 | #xD | #xA)+

Implementation: When making the choice of linguistic preference available to the user, implementers should take into account the fact that most users are not familiar with the details of language matching as described above, and should provide appropriate guidance. As an example, users may mistakenly assume that on selecting "en-gb", they will be served any kind of English document if British English is not available. The user interface for setting user preferences should guide the user to add "en" to get the best matching behavior.

systemOperatingSystem
value:an XML NMTOKEN ([XML11])
This test attribute specifies the operating system on which a user agent may be running. An implementation must allow the user the ability to set the user preference tounknown for privacy.
The following list contains the suggested values for this test attribute (additional names may be supported by an implementation): aix, beos, bsdi, dgux, freebsd, hpux, irix, linux, macos, ncr, nec, netbsd, nextstep, nto, openbsd, openvms, os2, osf, palmos, qnx, sinix, rhapsody, sco, solaris, sonly, sunos, unixware, win16, win32, win9x, winnt, wince, unknown.

These values come from the _PR_SI_SYSNAME constants defined by themozilla project.

Evaluates totrue if the user preference matches this attribute value. Evaluates tofalse if they do not match. The value is case-sensitive.
systemOverdubOrSubtitle
values:overdub | subtitle
This attribute specifies whether subtitles or overdub is rendered.overdub selects for substitution of one voice track for another, andsubtitle means that the user prefers the display of text in a language other than that which is being used in the audio track.
Evaluates totrue if the user preference matches this attribute value. Evaluates tofalse if they do not match.
system-overdub-or-caption
values:caption | overdub
This test attribute has been deprecated in favor of usingsystemOverdubOrSubtitle andsystemCaptions.
This attribute is a setting which determines if users prefer overdubbing or captioning when the option is available.
Evaluates totrue if the user preference matches this attribute value. Evaluates tofalse if they do not match.
systemRequired(system-required)
value:list of namespace prefix language extensions
This attributes provides an extension mechanism for new elements or attributes. Evaluates totrue if all of the extensions in the list are supported by the implementation, otherwise, this evaluates tofalse. The syntax of thesystemRequired and the deprecatedsystem-required attributes are defined using EBNF notation (as defined in[XML11]) as list of XML namespace prefixes[XML-NS], separated by the '+' character:
systemRequiredArgumentValue := NMTOKEN (S? '+' S? NMTOKEN)*

Where allowed white space is indicated as "S", defined as follows (taken from the[XML11] definition for 'S'):

S ::= (#x20 | #x9 | #xD | #xA)+
systemScreenDepth (system-screen-depth)
values:a number greater than 0
This attribute specifies the depth of the screen color palette in bits required for displaying the element. Typical values are1 | 4 | 8 | 24 | 32.
Evaluates totrue if the playback engine is capable of displaying images or video with the given color depth. Evaluates tofalse if the playback engine is only capable of displaying images or video with a smaller color depth.
systemScreenSize (system-screen-size)
value:a screen size
Attribute values have the following syntax:
screen size ::= screen-height"X"screen-width
Each of these is a pixel value, and must be an integer value greater than 0.
Evaluates totrue if the playback engine is capable of displaying a presentation of the given size. Evaluates tofalse if the playback engine is only capable of displaying smaller presentations.

It is the responsibility of the SMIL 2.1 Player to determine the settingsfor each predefined test variable. These values may be determined by staticconfiguration settings, or they may be evaluated dynamically during runtime.Such setting and (re)evaluation behavior is implementation dependent.

For this version of SMIL elements with specified test attributes thatevaluate to false, or elements within a switch that are not selected, areconsidered to be ignored and will behave as though they were not specified inthe document. Any references to these elements will be as if the elementswere not in the document. In particular, any ID references to the elementwill act as if there was no element with that ID. Languages that integratethis module must specify any additional behavior related to these ignoredelements. In the SMIL 2.1 Language profile, timing attributes that referenceinvalid IDs are treated as being indefinite.

Authors should be aware that this model for handling ignoredelements may be revised in a future version of SMIL, and the relatedsemantics may well change. These changes should not affect implementationsthat only support parse-time (or equivalent) evaluation of test attributesand/or the switch element. However, the semantics ofdynamicre-evaluation (i.e. re-evaluation during document presentation) of testattributes and/or switch elements are not defined in this version of SMIL;this will be addressed in a future version.

Authors should realize that if several alternative elementsare enclosed in aswitch, and none ofthem evaluate to true, this may lead to situations such as a media objectbeing shown without one or more companion objects. It is thus recommended toinclude a "catch-all" choice at the end of aswitch which is acceptable in all cases.

4.3.3 Integration Requirements for the BasicContentControl Module

The functionality in this module does not build on functionality definedin other SMIL 2.1 modules.

4.3.4 Document Type Definition (DTD) for the BasicContentControl Module

See the fullDTD for theSMIL Content Control modules.

4.4The SMIL 2.1CustomTestAttributes Module

4.4.1SMIL 2.1CustomTestAttributes Module Overview

The use of predefined system test attributes in the SMILBasicContentControl module provides a selection mechanism based on attributesthat are fixed within the module's definition. The CustomTestAttribute moduleextends this facility with the definition of author-defined custom testattributes. Custom test attributes allow presentation authors to define theirown test attributes for use in a specific document. Custom test attributesmay be shared among application documents using theuid attribute.

As with system test attributes, custom test attributes can be used withintiming structure and media object elements; if they evaluate totrue, the containing element is activated and if theyevaluate tofalse, the containing element isignored. In this version of SMIL, an ignored element will be treated as if itwere not part of the source document. As a result, any element referencingthe ID of the ignored node will, in effect, reference an invalid ID.Languages that integrate this module must specify any additional behaviorrelated to these ignored elements.

Since custom test attributes are application/document specific, they needa mechanism to allow attribute definition and attribute setting. Attributedefinition is done via thecustomAttributes andcustomTest elements. The initial stateof any custom test attribute can be set at author-time with thedefaultState attribute, which takes avalue of eithertrue orfalse. This module provides anoverride attribute with a valuehidden that gives an author the ability to discourageruntime resetting of any attributes using these mechanisms.

The state of the attribute can be changed in one of three ways:

  1. by modifying the value of the default state attribute in the document source before delivery to the player;
  2. by using the unique identifier given in the uid attribute to dereference a runtime value for the customTest; or
  3. by an interface presented to the user (or the user agent) through the document player at runtime.

The exact rules for setting and modifying the values associated withcustom test attributes are givenbelow.

An implementation may support either, both, or none of methods 2 and 3. Ifmethod 2 is supported, the URI value inuid is simply a unique identifier and does notimply that the runtime value must be fetched over the Web. The value may bestored and retrieved locally, and simply identified by the uid. The precisemanner in which this is done is implementation dependent. If method 3 issupported, the custom test attribute facility does not require any specificUI support for direct user manipulation of the custom test attributes.

Example Use

The following example shows one way in which custom test attributes can beapplied within a SMIL 2.1 Language profile document:

<smil>  <head>    <layout>       <!-- define projection regions -->    </layout>    <customAttributes>      <customTest title="West Coast Edition"         defaultState="false" override="visible"          uid="http://defs.example.org/user-settings/west-coast" />      <customTest title="East Coast Edition"         defaultState="false" override="visible"         uid="http://defs.example.org/user-settings/east-coast" />      <customTest  title="Northern Edition"        defaultState="false" override="visible"        uid="http://defs.example.org/user-settings/far-north" />      <customTest   title="National Edition"        defaultState="true"  override="hidden" />    </customAttributes>  </head>  <body>    ...    <par>      <img src="background.png" region="a"/>      <video src="story_1v.rm" region="b" />      <switch>        <audio src="story_1w.rm" region="c" customTest="west-coast"/>        <audio src="story_1e.rm" region="c" customTest="east-coast"/>        <audio src="story_1n.rm" region="c" customTest="far-north"/>        <audio src="story_1r.rm" region="c" customTest="the-rest"/>      </switch>    </par>    ...  </body></smil>

ThecustomAttributeselement in the header contains the definition of the available custom testattributes. Each custom test attribute, defined by thecustomTest element, contains anidentifier and a title (which can be used by a user agent, if available, tolabel the attribute), as well as an (optional) initial state definition, aUID that contains a unique identifier for the value setting for thisattribute and an override flag.

The custom test variables named "west-coast", "east-coast" and "far-north"are defined with a default rendering state offalse. They each contain a reference to a URI which isused to define local settings for the respective variables.

The custom test variable "the-rest" is defined with a default renderingsetting oftrue.

Inside thebody, a SMILswitch construct is used to select mediaobjects for inclusion in a presentation depending on the values of thevarious custom test attributes. The first object that contains a value oftrue will be rendered, and since in this examplethe last option will always resolvetrue, it willbe rendered if no other objects resolve totrue.

While this example showsswitch-based use of custom test attributes,the facility could also be applied as test attributes in in-line use.

Rules for SettingValues

The setting of the value associated with a custom test attribute proceedsas follows:

  1. The initial setting is taken from the value of thedefaultState attribute, if present. If no default state is explicitly defined, a value offalse is used.
  2. Next, if a URI mechanism is supported by the implementation, the URI defined by theuid attribute is checked to see if a persistent value has been defined for the custom test attribute with the associated id. If such a value is present, it is used instead of the default state defined in the document (if any). Otherwise, the existing initial state is maintained.
  3. Next, if a UI-based mechanism (either via the SMIL DOM, a player GUI or some other means) is available and a value has been set by the user, the value associated with the custom test attribute is set to the user-specified value. If no user preference has been defined, either the UID-based value or the default value from the document text (in that order) is used.

Note that a user setting of the custom test attribute will take precedenceover a URI setting. If the user has not specified a value for the attributethen the URI setting takes precedence. As with predefined system testattributes, this evaluation will occur in an implementation-defined manner.The value may be (re)evaluated dynamically, but this is not required. Notealso that not all implementations need supportuid or UI setting of attributes.

4.4.2Elements andAttributes

This section defines the elements and attributes that make up thefunctionality in the SMIL CustomTestAttributes module. ThecustomAttributes andcustomTest elements are used to definecustom test attribute variables and thecustomTest attribute is used in-line onmedia object and timing structure references to control evaluation of thecontaining elements.

ThecustomAttributes element

ThecustomAttributeselement contains definitions of each of the custom test attributes. Thecontained elements define a collection of author-specified test attributesthat can be used inswitch statementsor as in-line test attributes in the document.

Element attributes

This element does not have attributes beyond those required of allelements in the profile.

Element content

ThecustomAttributeselement may contain one or morecustomTest elements.

ThecustomTestelement

ThecustomTest element definesan author-specified name that will be used as the test argument in theswitch element or in-line on media objectand timing structure elements. ThecustomTest elements are defined withinthe section delineated by thecustomAttributes elements thatmake up part of the document header.

Element attributes
defaultState
values:true | false
The initial state for the named custom test variable is given in the value of this attribute. If unspecified, it defaults tofalse.
The run-time state for the named custom test variable may be set according to the rules foruid and/oroverride attribute processing, if present. The values are not case-sensitive.
override
values:visible | hidden
This attribute allows the author to choose whether the ability to override the initial state of a custom test variable should be presented to the typical user, or whether that choice should be reserved for users that specifically express a preference for this access. If the value of theoverride attribute isvisible, then the user agent should make available to the user a means to set the custom test variable value in its default configuration either directly, via the SMIL DOM, or by some other mechanism. If the value of theoverride attribute ishidden, then the user agent should not present to the user a means to set the custom attribute value unless the user has expressed a preference for this access. The values are not case-sensitive. The default value ishidden.
uid
values: AURI
The URI identifies the associated custom test for persistent use. The user agent should use this as the key to store and retrieve values associated with the custom test attribute, and take care that privacy and security issues are regarded. If the permitted by theoverride attribute, a resolved reference to a setting via theuid attribute defines the initial setting of the custom test value; this value may be overridden by the user/user-agent if permitted by theoverride attribute. It is up to the runtime environment to enforce this attribute.

The actual evaluation mechanism associated with the URI is implementation dependent. It can vary from a simple lookup in a local file or registry, to a secure reference via a capabilities database, and may be influenced by other configuration settings provided by the implementation.

Element content

None.

ThecustomTest attribute

In addition to thecustomAttributes andcustomTest elements, this moduleprovides acustomTest attributethat can be applied by language designers to media objects and timingstructure elements requiring selection. In all operational aspects, thecustom test attribute is similar to the predefined system test attributefacility of the Basic Content Control module.

customTest
value:a list of XML identifiers
The identifiers, defined in thecustomTest elements, define variables that are evaluated as test attributes. If the variables all evaluate totrue, the associated element is evaluated, otherwise it and its content are skipped.customTest attributes whose values don't match the identifier of acustomTest element evaluate tofalse

The syntax of thecustomTest is defined using EBNF notation (as defined in[XML11]) as list of customTest element identifier references, separated by the '+' character:

CustomTestArgumentValue := IDREF (S? '+' S? IDREF)*

Where allowed white space is indicated as "S", defined as follows (taken from the[XML11] definition for 'S'):

S ::= (#x20 | #x9 | #xD | #xA)+

4.4.3 Integration Requirements for the CustomTestAttribute Module

The functionality in this module builds on functionality defined in theBasicContentControl module, which is a required prerequisite for inclusion ofthe CustomTestAttribute module.

The profile implementing the custom test elements and attributes mustprovide a means of associating a unique XML identifier with a customTestelement, so that it can be used by the customTest attribute. And the profileshould provide a means of associating descriptive text with a customTestelement, which may be used in a GUI or other selection mechanism that may bepresented to the user. For the SMIL 2.1 Language Profile, the element's idand title attributes serve this purpose.

4.4.4 Document Type Definition (DTD) for the CustomTestAttribute Module

See the fullDTD for theSMIL Content Control modules.

4.5The SMIL 2.1PrefetchControl Module

4.5.1SMIL 2.1PrefetchControl Module Overview

This module defines an element and attributes that can be used to controlthe fetching of content from a server in a manner that will improve therendering performance of the document.

This element will give a suggestion or hint to a user agent that a mediaresource will be used in the future and the author would like part or all ofthe resource fetched ahead of time to make the document playback smoother.User-agents can ignoreprefetchelements, though doing so may cause an interruption in the document playbackwhen the resource is needed. It gives authoring tools or savvy authors theability to schedule retrieval of resources when they think that there isavailable bandwidth or time to do it. Aprefetch element is contained within thebody of an XML document, and its scheduling is based on its lexical orderunless explicit timing is present.

Prefetching data from a URL that changes the contentdynamically is potentially dangerous: if the entire resource isn'tprefetched, a subsequent request for the remaining data may yield data from anewer resource. A user agent should respect any appropriate cachingdirectives applied to the content, e.g. no-cache 822 headers in HTTP. Morespecifically, content marked as non-cacheable would have to be refetched eachtime it was played, where content that is cacheable could be prefetched once,with the results of the prefetch cached for future use.

Examples

  1. Prefetch an image so it can be displayed immediately after a video ends:
     <smil xmlns="http://www.w3.org/2005/SMIL21/Language">    <body>      <seq>       <par>         <prefetch            src="http://www.example.org/logo.gif"/>         <text            src="http://www.example.org/pleasewait.html" fill="freeze"/>       </par>       <video src="rtsp://www.example.org/video.mpg"/>        <img src="http://www.example.org/logo.gif" dur="5s"/>      </seq>    </body>  </smil>

    The example starts with a prefetch in parallel with the rendering of a text object. The text is discrete media so it ends immediately, the prefetch is defaulted to prefetch the entire image at full available bandwidth and the prefetch element ends when the image is downloaded. That ends the<par> and the video begins playing. When the video ends the image is shown.

  2. Prefetch the images for a button so that rollover occurs quickly for the end user:
     <html> <body>     <prefetch src="http://www.example.org/up.gif"/>     <prefetch src="http://www.example.org/down.gif"/>     ....     <!-- script will change the graphic on rollover -->     <img src="http://www.example.org/up.gif"/>   </body> </html>

4.5.2Elements andAttributes

Theprefetchelement

Theprefetch gives authors amechanism to influence the scheduling of media object transfers from a serverto the player.

Documents must still playback even when theprefetch elements are ignored, althoughrebuffering or pauses in presentation of the document may occur. If theprefetch for aprefetch element isignored, any timing on the element is still respected, e.g. if aprefetch element has adur="5s", elements that depend on theprefetch element's timing behave as ifthe prefetch took 5 seconds.

The intrinsic duration of aprefetch element is either the durationof the media fetch, if the prefetch operation is supported by theimplementation, or zero if prefetch is not supported.

If aprefetch element isrepeated, due to restart or repeat on a parent element the prefetch operationshould occur again. This insures appropriately "fresh" data is displayed if,for example, the prefetch is for a banner ad to a URL whose content changeswith each request.

Element attributes

Theprefetch element supportsthe following attributes:

mediaSize
values:bytes-value | percent-value
Defines how much of the resource to fetch as a function of the file size of the resource. To fetch the entire resource without knowing its size, specify 100%. The default is 100%.
mediaTime
values:clock-value | percent-value
Defines how much of the resource to fetch as a function of the duration of the resource. To fetch the entire resource without knowing its duration, specify 100%. The default is 100%.
For discrete media (non-time based media like text/html or image/png) using this attribute causes the entire resource to be fetched.
bandwidth
values:bitrate-value | percent-value
Defines how much network bandwidth the user agent should use when doing the prefetch. To use all that is available, specify 100%. The default is 100%.

Any attribute with a value of "0%" is ignored and treated as if theattribute wasn't specified.

If bothmediaSize andmediaTime are specified,mediaSize is used andmediaTime is ignored.

If theclipBegin orclipEnd in the media object are differentfrom the prefetch, an implementation can use any data that was fetched butthe result may not be optimal.

Attribute value syntax
bytes-value
The bytes-value value has the following syntax:

bytes-value ::= Digit+; any positive number

percent-value
The percent-val value has the following syntax:

percent-value ::= Digit+ "%"; any positive number in the range 0 to 100

clock-value
The clock-value value has the following syntax:
Clock-val         ::= ( Hms-val | Smpte-val )Smpte-val         ::= ( Smpte-type )? Hours ":" Minutes ":" Seconds                      ( ":" Frames ( "." Subframes )? )?Smpte-type        ::= "smpte" | "smpte-30-drop" | "smpte-25"Hms-val           ::= ( "npt=" )? (Full-clock-val | Partial-clock-val                      | Timecount-val)Full-clock-val    ::= Hours ":" Minutes ":" Seconds ("." Fraction)?Partial-clock-val ::= Minutes ":" Seconds ("." Fraction)?Timecount-val     ::= Timecount ("." Fraction)? (Metric)?Metric            ::= "h" | "min" | "s" | "ms"Hours             ::= DIGIT+; any positive numberMinutes           ::= 2DIGIT; range from 00 to 59Seconds           ::= 2DIGIT; range from 00 to 59Frames            ::= 2DIGIT; smpte range = 00-29, smpte-30-drop range = 00-29, smpte-25 range = 00-24Subframes         ::= 2DIGIT; smpte range = 00-01, smpte-30-drop range = 00-01, smpte-25 range = 00-01Fraction          ::= DIGIT+Timecount         ::= DIGIT+2DIGIT            ::= DIGIT DIGITDIGIT             ::= [0-9]

For Timecount values, the default metric suffix is "s" (for seconds).

bitrate-value
The bitrate-value value specifies a number of bits per second. It has the following syntax:

bitrate-value ::= Digit+; any positive number

4.5.3 Integration Requirements for the PrefetchControl Module

A profile integrating the PrefetchControl module must add the attributesnecessary to specify the media to be fetched. In general, these will be thesame resource specifying attributes as those on the media elementsthemselves. In addition, the profile must add any necessary attributes tocontrol the timing of theprefetchelement.

4.5.4 Document Type Definition (DTD) for the PrefetchControl Module

See the fullDTD for theSMIL Content Control modules.

4.6The SMIL 2.1SkipContentControl Module

4.6.1SMIL 2.1SkipContentControl Module Overview

This module contains one attribute,skip-content attribute, that can beused to selectively control the evaluation of the element on which thisattribute appears. This attribute is introduced for future extensibility ofSMIL. The functionality is unchanged from SMIL 1.0.

4.6.2Elements andAttributes

Element definition

The SkipContentControl module does not contain any element definitions.

Theskip-content attribute

skip-content
value:true | false
This attribute controls whether the content of an element is evaluated or should be skipped.
  • If a new element is introduced in a future version of language allowing markup from a previous version of the language as element content, theskip-content attribute controls whether this content is processed by the user agent.
  • If an empty element in a version of a language becomes non-empty in a future SMIL version, theskip-content attribute controls whether this content is ignored by a user agent, or results in a syntax error.
If the value of theskip-content attribute istrue, and one of the cases above apply, the content of the element is ignored. If the value isfalse, the content of the element is processed.
The default value forskip-content istrue.

4.6.3 Integration Requirements for the SkipContentControl Module

It is the responsibility of the language profile to specify which elementshaveskip-content attributes toenable this expansion mechanism.


previous  next  contents  

[8]ページ先頭

©2009-2025 Movatter.jp