--- a/ttml2/spec/ttml2.xml Sun Aug 25 11:03:10 2013 -0600
+++ b/ttml2/spec/ttml2.xml Mon Aug 26 19:04:37 2013 -0600
@@ -120,7 +120,7 @@
for example, providing a standard content format to reference from a <el><track></el>
element in an HTML5 document, or a <el><text></el> or
<el><textstream></el> media element in a <bibref
-ref="smil21"/> document.</p>
+ref="smil3"/> document.</p>
</abstract>
&status;
<langusage><language id='en-us'>English</language></langusage>
@@ -144,7 +144,7 @@
example, a standard content format to reference from a <el><track></el>
element in an HTML5 document, or a <el><text></el> or
<el><textstream></el> media element in a <bibref
-ref="smil21"/> document. Certain properties of TTML support
+ref="smil3"/> document. Certain properties of TTML support
streamability of content, as described in <specref ref="streaming"/>.</p>
<note>
<p>While TTML is not expressly designed for direct (embedded) integration into an
@@ -736,8 +736,8 @@
<gitem>
<label>Synthetic Document Syncbase</label>
<def>
-<p>A document level <xspecref href="http://www.w3.org/TR/2005/REC-SMIL2-20051213/smil-timing.html#Timing-Syncbases">syncbase</xspecref>
-<bibref ref="smil21"/>, § 10.7.1, synthesized or otherwise established by
+<p>A document level <xspecref href="http://www.w3.org/TR/2008/REC-SMIL3-20081201/smil30.html#smil-timing-q158">syncbase</xspecref>
+<bibref ref="smil3"/>, § 5.7.1, synthesized or otherwise established by
the <emph>Document Processing Context</emph> in accordance with the
<emph>Related Media Object</emph> or other processing criteria.</p>
</def>
@@ -1447,6 +1447,8 @@
Animation
</td>
<td>
+<loc href="#animation-vocabulary-animate">animate</loc>,
+<loc href="#animation-vocabulary-animation">animation</loc>,
<loc href="#animation-vocabulary-set">set</loc>
</td>
</tr>
@@ -1545,6 +1547,7 @@
Animation.class
</td>
<td>
+<loc href="#animation-vocabulary-animate">animate</loc> |
<loc href="#animation-vocabulary-set">set</loc>
</td>
</tr>
@@ -2821,7 +2824,7 @@
<note role="explanation">
<p>When the time base is designated as <code>smpte</code>,
every time expression denotes a media marker value akin to that
-defined by <bibref ref="smil21"/>, § 10.4.1, except instead
+defined by <bibref ref="smil3"/>, § 5.4.1, except instead
of using an opaque marker name, a structured <bibref ref="smpte12m"/>
time coordinate serves as the marker name.</p>
</note>
@@ -2938,7 +2941,8 @@
followed by zero or more elements in the
<code>Parameters.class</code> element group,
followed by zero or one <el>styling</el> element,
-followed by zero or one <el>layout</el> element.</p>
+followed by zero or one <el>layout</el> element,
+followed by zero or one <el>animation</el> element.</p>
<p>Any metadata specified by children in the <code>Metadata.class</code>
element group applies semantically to the <emph>Document Instance</emph> as a
whole, and not just the <el>head</el> element.</p>
@@ -2950,6 +2954,9 @@
<loc href="#element-vocab-type-content">Content</loc> elements.</p>
<p>A <el>layout</el> child element is used to specify layout constructs that
are referenced by <loc href="#element-vocab-type-content">Content</loc> elements.</p>
+<p>An <el>animation</el> child element is used to specify animation constructs that
+target animatable <loc href="#element-vocab-type-content">Content</loc>
+or <loc href="#element-vocab-type-layout">Layout</loc> elements.</p>
<table id="elt-syntax-head" role="syntax">
<caption>XML Representation – Element Information Item: head</caption>
<tbody>
@@ -2961,7 +2968,7 @@
<loc href="#content-attribute-lang">xml:lang</loc> = string
<loc href="#content-attribute-space">xml:space</loc> = (<emph>default</emph>|<emph>preserve</emph>)
{<emph>any attribute not in default or any TT namespace</emph>}>
- <emph>Content:</emph> <loc href="#element-vocab-group-table">Metadata.class</loc>*, <loc href="#element-vocab-group-table">Parameters.class</loc>*, <loc href="#styling-vocabulary-styling">styling</loc>?, <loc href="#layout-vocabulary-layout">layout</loc>?
+ <emph>Content:</emph> <loc href="#element-vocab-group-table">Metadata.class</loc>*, <loc href="#element-vocab-group-table">Parameters.class</loc>*, <loc href="#styling-vocabulary-styling">styling</loc>?, <loc href="#layout-vocabulary-layout">layout</loc>?, <loc href="#animation-vocabulary-animation">animation</loc>?
</head>
</eg>
</td>
@@ -3559,6 +3566,7 @@
<p>The <att>style</att> attribute may be specified by an instance of the following
element types:</p>
<ulist>
+<item><p><loc href="#animation-vocabulary-animate"><el>animate</el></loc></p></item>
<item><p><loc href="#document-structure-vocabulary-body"><el>body</el></loc></p></item>
<item><p><loc href="#content-vocabulary-div"><el>div</el></loc></p></item>
<item><p><loc href="#content-vocabulary-p"><el>p</el></loc></p></item>
@@ -5358,8 +5366,8 @@
</table>
<note role="derivation">
<p>The semantics of the style property
-represented by this attribute are based upon that defined by <bibref ref="smil21"/>,
-§ 5.3.3.</p>
+represented by this attribute are based upon that defined by <bibref ref="smil3"/>,
+§ 7.4.2.</p>
</note>
</div3>
<div3 id="style-attribute-textAlign">
@@ -6603,11 +6611,9 @@
<item><p>a <familyName> that takes the form of a <code>quoted-string</code> whose content (unquoted value)
matches (by case sensitive comparison) a <genericFamilyName> must not be interpreted as that <genericFamilyName>, but as
the actual name of a non-generic font family.</p></item>
+<item><p>The syntactic element <emph><code>char</code></emph> is to be interpreted according
+to the <code>Char</code> production defined by <bibref ref="xml10"/> §2.2.</p></item>
</ulist>
-<note role="notation">
-<p>The syntactic element <emph><code>char</code></emph> is to be interpreted according
-to the <code>Char</code> production defined by <bibref ref="xml10"/> §2.2.</p>
-</note>
<note role="elaboration">
<p>The <code>{unicode}</code> escape mechanism defined by <bibref ref="css2"/> §4.1.1
is not supported by this syntax; rather, authors are expected to either (1) directly encode the character
@@ -8078,7 +8084,7 @@
<p>The begin point of a temporal interval is included in the
interval; i.e., the interval is left-wise closed.</p>
<p>The semantics of the <att>begin</att> attribute are those defined
-by <bibref ref="smil21"/>, § 10.4.1,
+by <bibref ref="smil3"/>, § 5.4.1,
while taking into account any overriding semantics defined by this specification.</p>
</div3>
<div3 id="timing-attribute-end">
@@ -8102,7 +8108,7 @@
as [300f,310f).</p>
</note>
<p>The semantics of the <att>end</att> attribute are those defined
-by <bibref ref="smil21"/>, § 10.4.1,
+by <bibref ref="smil3"/>, § 5.4.1,
while taking into account any overriding semantics defined by this specification.</p>
</div3>
<div3 id="timing-attribute-dur">
@@ -8122,10 +8128,10 @@
mode, a (well-formed) <att>dur</att> attribute must not be specified on any
element.</p>
<p>The semantics of the <att>dur</att> attribute are those defined
-by <bibref ref="smil21"/>, § 10.4.1,
+by <bibref ref="smil3"/>, § 5.4.1,
while taking into account any overriding semantics defined by this specification.</p>
<note role="elaboration">
-<p>In the context of the subset of <bibref ref="smil21"/> semantics supported by
+<p>In the context of the subset of <bibref ref="smil3"/> semantics supported by
this specification, the active duration of an element that specifies both
<att>end</att> and <att>dur</att> attributes is equal to the lesser of the value of
the <att>dur</att> attribute and the difference between the value of the
@@ -8147,11 +8153,11 @@
parallel, i.e., simultaneously in time. Furthermore, the specification of
the time interval of each child element is considered to be relative to the temporal
interval of the container element instance. For the purpose of determining the
-<bibref ref="smil21"/> <code>endsync</code> semantics of a <code>par</code>
+<bibref ref="smil3"/> <code>endsync</code> semantics of a <code>par</code>
time container, a default value of <code>all</code> applies.</p>
<note role="elaboration">
<p>The use of a default value of <code>all</code> for the <code>endsync</code>
-behavior is distinct from <bibref ref="smil21"/> which uses a default value
+behavior is distinct from <bibref ref="smil3"/> which uses a default value
of <code>last</code>.</p>
</note>
<p>If the time container semantics of an element instance is <code>seq</code>,
@@ -8174,7 +8180,7 @@
<item><p><loc href="#content-vocabulary-span"><el>span</el></loc></p></item>
</ulist>
<p>The semantics of parallel and sequential time
-containment are those defined by <bibref ref="smil21"/>, § 10.4.2,
+containment are those defined by <bibref ref="smil3"/>, § 5.4.2,
while taking into account any overriding semantics defined by this specification.</p>
</div3>
</div2>
@@ -8273,7 +8279,7 @@
<div2 id="timing-time-intervals">
<head>Time Intervals</head>
<p>The semantics of time containment, durations, and intervals defined by
-<bibref ref="smil21"/> apply to the interpretation of like-named timed elements and timing
+<bibref ref="smil3"/> apply to the interpretation of like-named timed elements and timing
vocabulary defined by this specification, given the following
constraints:</p>
<ulist>
@@ -8281,7 +8287,7 @@
<p>The implicit duration of an anonymous span is defined as follows: if
the anonymous span's parent time container is a parallel time container, then
the implicit duration is equivalent to the <code>indefinite</code>
-duration value as defined by <bibref ref="smil21"/>; if the anonymous span's
+duration value as defined by <bibref ref="smil3"/>; if the anonymous span's
parent time container is a sequential time container, then the implicit duration
is equivalent to zero.</p>
</item>
@@ -8290,30 +8296,30 @@
or <el>span</el> element is determined in accordance to (1) whether
the element is a parallel or sequential time container, (2) the default
<code>endsync</code> semantics defined above by <specref ref="timing-attribute-timeContainer"/>,
-and (3) the semantics of <bibref ref="smil21"/> as applied to these time
+and (3) the semantics of <bibref ref="smil3"/> as applied to these time
containers.</p>
</item>
<item>
<p>The implicit duration of the <el>region</el> element is defined to
be equivalent to the <code>indefinite</code>
-duration value as defined by <bibref ref="smil21"/>.</p>
+duration value as defined by <bibref ref="smil3"/>.</p>
</item>
<item>
<p>If the governing time base is <code>clock</code>, then time
expressions are considered to be equivalent to wall-clock
-based timing in <bibref ref="smil21"/>, where the specific semantics of
+based timing in <bibref ref="smil3"/>, where the specific semantics of
<specref ref="time-expression-semantics-clock"/> apply.</p>
</item>
<item>
<p>If the governing time base is <code>media</code>, then time
expressions are considered to be equivalent to offset based timing
-in <bibref ref="smil21"/>, where the specific semantics of
+in <bibref ref="smil3"/>, where the specific semantics of
<specref ref="time-expression-semantics-media"/> apply.</p>
</item>
<item>
<p>If the governing time base is <code>smpte</code>, then time
expressions are considered to be equivalent to either offset
-based timing or event based timing in <bibref ref="smil21"/>, where the specific semantics of
+based timing or event based timing in <bibref ref="smil3"/>, where the specific semantics of
<specref ref="time-expression-semantics-smpte"/> apply.</p>
</item>
</ulist>
@@ -8331,8 +8337,175 @@
<p>The following elements specify the structure and principal animation aspects of a
<emph>Document Instance</emph>:</p>
<ulist>
+<item><p><specref ref="animation-vocabulary-animation"/></p></item>
+<item><p><specref ref="animation-vocabulary-animate"/></p></item>
<item><p><specref ref="animation-vocabulary-set"/></p></item>
</ulist>
+<div3 id="animation-vocabulary-animation">
+<head>animation</head>
+<p>The <el>animation</el> element is a container element used to group
+animation matter, including metadata that applies to animation matter.</p>
+<p>The <el>animation</el> element accepts as its children zero or more
+elements in the <code>Metadata.class</code> element group, followed by
+zero or more <el>animate</el> elements.</p>
+<table id="elt-syntax-animation" role="syntax">
+<caption>XML Representation – Element Information Item: animation</caption>
+<tbody>
+<tr>
+<td>
+<eg xml:space="preserve">
+<animation
+ <loc href="#content-attribute-id">xml:id</loc> = ID
+ <loc href="#content-attribute-lang">xml:lang</loc> = string
+ <loc href="#content-attribute-space">xml:space</loc> = (<emph>default</emph>|<emph>preserve</emph>)
+ {<emph>any attribute not in default or any TT namespace</emph>}>
+ <emph>Content:</emph> <loc href="#element-vocab-group-table">Metadata.class</loc>*, <loc href="#animation-vocabulary-animate">animate</loc>*
+</animation>
+</eg>
+</td>
+</tr>
+</tbody>
+</table>
+<p>To the extent that time semantics apply to the content of the
+<el>animation</el> element, the implied time interval of this element is
+defined to be coterminous with the <emph>Root Temporal Extent</emph>.</p>
+</div3>
+<div3 id="animation-vocabulary-animate">
+<head>animate</head>
+<p>The <el>animate</el> element expresses a series of changes (animations) to be applied to a targetted attribute
+of a targetted element.</p>
+<p>An <el>animate</el> element may appear as either (1) a child of a
+<loc href="#element-vocab-type-content">Content</loc> or <el>region</el> element or
+(2) a child of an <loc href="#animation-vocabulary-animation">animation</loc> element. In the former
+case, the targetted element of the animation is the parent of the <el>animate</el> element; in the latter
+case, the targetted element is the element referenced by the <att>xlink:href</att> attribute on the
+<el>animate</el> element.</p>
+<p>The targetted attribute (property) is specified by the <att>attributeName</att> attribute.</p>
+<p>The <el>animate</el> element accepts as its children zero or more
+elements in the <code>Metadata.class</code> element group.</p>
+<table id="elt-syntax-animate" role="syntax">
+<caption>XML Representation – Element Information Item: animate</caption>
+<tbody>
+<tr>
+<td>
+<eg xml:space="preserve">
+<animate
+ accumulate = <loc href="#animation-value-accumulate"><accumulate></loc>
+ additive = <loc href="#animation-value-additive"><additive></loc>
+ <phrase role="strong">attributeName</phrase> = <loc href="#animation-value-qualifiedName"><qualifiedName></loc>
+ <loc href="#timing-attribute-begin">begin</loc> = <loc href="#timing-value-timeExpression"><timeExpression></loc>
+ by = <loc href="#animation-value-animationValue"><animationValue></loc>
+ calcMode = <loc href="#animation-value-calcMode"><calcMode></loc>
+ <loc href="#timing-attribute-dur">dur</loc> = <loc href="#timing-value-timeExpression"><timeExpression></loc>
+ <loc href="#timing-attribute-end">end</loc> = <loc href="#timing-value-timeExpression"><timeExpression></loc>
+ fill = <loc href="#animation-value-fill"><fill></loc>
+ from = <loc href="#animation-value-animationValue"><animationValue></loc>
+ keySplines = <loc href="#animation-value-keySplines"><keySplines></loc>
+ keyTimes = <loc href="#animation-value-keyTimes"><keyTimes></loc>
+ repeatCount = <loc href="#animation-value-repeatCount"><repeatCount></loc>
+ repeatDur = <loc href="#animation-value-repeatDur"><repeatDur></loc>
+ <loc href="#style-attribute-style">style</loc> = IDREFS
+ to = <loc href="#animation-value-animationValue"><animationValue></loc>
+ values = <loc href="#animation-value-animationValueList"><animationValueList></loc>
+ <loc href="#content-attribute-id">xlink:href</loc> = <loc href="#animation-value-fragmentIdentifier"><fragmentIdentifier></loc>
+ <loc href="#content-attribute-id">xml:id</loc> = ID
+ <loc href="#content-attribute-lang">xml:lang</loc> = string
+ <loc href="#content-attribute-space">xml:space</loc> = (<emph>default</emph>|<emph>preserve</emph>)
+ {<emph>any attribute not in default or any TT namespace</emph>}>
+ <emph>Content:</emph> <loc href="#element-vocab-group-table">Metadata.class</loc>*
+</animate>
+</eg>
+</td>
+</tr>
+</tbody>
+</table>
+<p/>
+<p>Except for the constraints or variations enumerated below, the semantics of the <el>animate</el> element and its attributes
+enumerated above are defined to be those specified by <bibref ref="svg11"/>, §19.2.12:</p>
+<olist>
+<item><p>For the purpose of interpreting an <att>attributeName</att> attribute, an <att>attributeType</att>
+with a value of <code>XML</code> applies, about which see <bibref ref="svg11"/>, §19.2.5.</p></item>
+<item><p>If no <att>accumulate</att> attribute is specified, then an <emph>accumlate</emph> value of <code>none</code> applies.</p></item>
+<item><p>If no <att>additive</att> attribute is specified, then an <emph>additive</emph> value of <code>replace</code> applies.</p></item>
+<item><p>If no <att>calcMode</att> attribute is specified, then a <emph>calcMode</emph> value of <code>linear</code> applies.</p></item>
+<item><p>If no <att>fill</att> attribute is specified, then a <emph>fill</emph> value of <code>remove</code> applies.</p></item>
+<item><p>If an <att>xlink:href</att> attribute is specified, then the <el>animate</el> element must be a child of an
+<loc href="#animation-vocabulary-animation">animation</loc> element; conversely, if an <el>animate</el> element is a child of
+an <loc href="#animation-vocabulary-animation">animation</loc> element, then it must specify an <att>xlink:href</att> attribute.</p></item>
+</olist>
+<p>An example of using the <el>animate</el> element to animate content
+styling is illustrated below:</p>
+<table id="animation-vocabulary-animate-example-1" role="example">
+<caption>Example Fragment – Content Style Animation</caption>
+<tbody>
+<tr>
+<td>
+<eg xml:space="preserve">
+...
+<p dur="5s" tts:color="yellow">
+<phrase role="strong"><animate attributeName="tts:color" values="yellow,red,green,blue,yellow"/></phrase>
+Text with Continuously Varying Colors!
+</p>
+...
+</eg>
+</td>
+</tr>
+</tbody>
+</table>
+<note role="explanation">
+<p>In the above example, the foreground color of the content "Text
+with Continuously Varying Colors!" is continuously animated from yellow, to red, to green, to
+red, then back to yellow over a 5 second period.</p>
+</note>
+
+<p>An example of using the <el>animate</el> element to animate region
+styling is illustrated below:</p>
+<table id="animation-vocabulary-animate-example-2" role="example">
+<caption>Example Fragment – Region Style Animation</caption>
+<tbody>
+<tr>
+<td>
+<eg xml:space="preserve">
+<tt xml:lang="" xmlns="http://www.w3.org/ns/ttml"
+ xmlns:ttp="http://www.w3.org/ns/ttml#parameter"
+ xmlns:tts="http://www.w3.org/ns/ttml#styling"
+ ttp:extent="640px 480px">
+ <head>
+ <layout>
+ <region xml:id="r1" timeContainer="seq" tts:opacity="0">
+ <phrase role="strong"><animate dur="1s" attributeName="tts:opacity" to="1"/></phrase>
+ <set dur="5s" tts:opacity="1"/>
+ <phrase role="strong"><animate dur="1s" attributeName="tts:opacity" to="0"/></phrase>
+ <style tts:extent="480px 60px"/>
+ <style tts:origin="80px 400px"/>
+ </region>
+ </layout>
+ </head>
+ <body region="r1">...</body>
+</tt>
+</eg>
+</td>
+</tr>
+</tbody>
+</table>
+<note role="explanation">
+<p>In the above example, a region, <code>r1</code>, is initially set to 0% opacity,
+fully transparent, then is faded in to 100% opacity, fully opaque, over a one second
+interval. Opacity remains at 100% for five more seconds, and then is faded out to 0%
+over a one second interval, where it remains.</p>
+</note>
+<p></p>
+<ednote>
+<name>Animate Example Images</name>
+<date>2013-08-25</date>
+<edtext>Insert animated SVG images of animate examples.</edtext>
+</ednote>
+<note role="derivation">
+<p>The semantics of the <el>animate</el> element
+are based upon that defined by <bibref ref="svg11"/>,
+§ 6.2.12, which, in turn, is based upon <bibref ref="smil3"/>, §12.</p>
+</note>
+</div3>
<div3 id="animation-vocabulary-set">
<head>set</head>
<p>The <el>set</el> element is used as a child element of a
@@ -8399,7 +8572,7 @@
</table>
<note role="explanation">
<p>In the above example, the foreground color of the content "Text
-with Flashing Colors" is animated from yellow, to red, to green, to
+with Flashing Colors!" is animated from yellow, to red, to green, to
red, then back to yellow over a 5 second period.</p>
</note>
@@ -8442,10 +8615,16 @@
create an effect of moving the region, which may be desirable so as
to avoid obscuring characters in an underlying video with captions.</p>
</note>
+<p></p>
+<ednote>
+<name>Set Example Images</name>
+<date>2013-08-25</date>
+<edtext>Insert animated SVG images of set examples.</edtext>
+</ednote>
<note role="derivation">
<p>The semantics of the <el>set</el> element
-are based upon that defined by <bibref ref="smil21"/>,
-§ 3.6.2.</p>
+are based upon that defined by <bibref ref="svg11"/>,
+§ 6.2.13, which, in turn, is based upon <bibref ref="smil3"/>, §12.</p>
</note>
</div3>
</div2>
@@ -8454,6 +8633,346 @@
<p>No animation related attribute vocabulary is defined for use in the
core vocabulary catalog.</p>
</div2>
+<div2 id="animation-value-expressions">
+<head>Animation Value Expressions</head>
+<p>Animation attribute values include the use of the following expressions:</p>
+<ulist>
+<item><p><specref ref="animation-value-accumulate"/></p></item>
+<item><p><specref ref="animation-value-additive"/></p></item>
+<item><p><specref ref="animation-value-animationValue"/></p></item>
+<item><p><specref ref="animation-value-animationValueList"/></p></item>
+<item><p><specref ref="animation-value-calcMode"/></p></item>
+<item><p><specref ref="animation-value-fill"/></p></item>
+<item><p><specref ref="animation-value-fragmentIdentifier"/></p></item>
+<item><p><specref ref="animation-value-keySplines"/></p></item>
+<item><p><specref ref="animation-value-keyTimes"/></p></item>
+<item><p><specref ref="animation-value-qualifiedName"/></p></item>
+<item><p><specref ref="animation-value-repeatCount"/></p></item>
+<item><p><specref ref="animation-value-repeatDur"/></p></item>
+</ulist>
+<div3 id="animation-value-accumulate">
+<head><accumulate></head>
+<p>An <accumulate> expression is used to control whether animation is cumulative or not.</p>
+<table id="accumulate-syntax" role="syntax">
+<caption>Syntax Representation – <accumulate></caption>
+<tbody>
+<tr>
+<td>
+<eg xml:space="preserve">
+<accumulate>
+ : "none"
+ | "sum"
+</eg>
+</td>
+</tr>
+</tbody>
+</table>
+<p>The semantics of an <accumulate> expression are those defined by
+<bibref ref="svg11"/>, §19.2.10.</p>
+</div3>
+<div3 id="animation-value-additive">
+<head><additive></head>
+<p>An <additive> expression is used to control whether animation is additive.</p>
+<table id="additive-syntax" role="syntax">
+<caption>Syntax Representation – <additive></caption>
+<tbody>
+<tr>
+<td>
+<eg xml:space="preserve">
+<additive>
+ : "replace"
+ | "sum"
+</eg>
+</td>
+</tr>
+</tbody>
+</table>
+<p>The semantics of an <additive> expression are those defined by
+<bibref ref="svg11"/>, §19.2.10.</p>
+</div3>
+<div3 id="animation-value-animationValue">
+<head><animationValue></head>
+<p>An <animationValue> expression is used to specify the starting (initial), intermediate,
+or ending (final) of the attribute targetted by the animation.</p>
+<table id="animationValue-syntax" role="syntax">
+<caption>Syntax Representation – <animationValue></caption>
+<tbody>
+<tr>
+<td>
+<eg xml:space="preserve">
+<animationValue>
+ : string
+</eg>
+</td>
+</tr>
+</tbody>
+</table>
+<p>The syntax of an <animationValue> expression must satisfy all syntax
+requirements that apply to the attribute targetted by the animation.</p>
+<p>The semantics of an <animationValue> expression are those defined by
+<bibref ref="svg11"/>, §19.2.9.</p>
+</div3>
+<div3 id="animation-value-animationValueList">
+<head><animationValueList></head>
+<p>An <animationValueList> expression is used to specify a list of animation values that sequentially
+apply to the attribute targetted by the animation, wherein each pair of values is separated by a SEMICOLON (U+003B) character
+optionally surrounded by linear white-space (LWSP) characters.</p>
+<table id="animationValueList-syntax" role="syntax">
+<caption>Syntax Representation – <animationValueList></caption>
+<tbody>
+<tr>
+<td>
+<eg xml:space="preserve">
+<animationValueList>
+ : <loc href="#animation-value-animationValue"><animationValue></loc> [ ";" <loc href="#animation-value-animationValue"><animationValue></loc> ]*
+</eg>
+</td>
+</tr>
+</tbody>
+</table>
+<p>The syntax of an <animationValue> in an <animationValueList> expression must satisfy all syntax
+requirements that apply to the attribute targetted by the animation.</p>
+<p>The semantics of an <animationValueList> expression are those defined by
+<bibref ref="svg11"/>, §19.2.9.</p>
+</div3>
+<div3 id="animation-value-calcMode">
+<head><calcMode></head>
+<p>A <calcMode> expression is used to control the interpolation mode of the animation.</p>
+<table id="calcMode-syntax" role="syntax">
+<caption>Syntax Representation – <calcMode></caption>
+<tbody>
+<tr>
+<td>
+<eg xml:space="preserve">
+<calcMode>
+ : "discrete"
+ | "linear"
+ | "displaced"
+ | "spline"
+</eg>
+</td>
+</tr>
+</tbody>
+</table>
+<p>The semantics of a <calcMode> expression are those defined by
+<bibref ref="svg11"/>, §19.2.9.</p>
+</div3>
+<div3 id="animation-value-fill">
+<head><fill></head>
+<p>A <fill> expression is used to determine effect of the animation after the active end of the animation.</p>
+<table id="fill-syntax" role="syntax">
+<caption>Syntax Representation – <fill></caption>
+<tbody>
+<tr>
+<td>
+<eg xml:space="preserve">
+<fill>
+ : "freeze"
+ | "remove"
+</eg>
+</td>
+</tr>
+</tbody>
+</table>
+<p>The semantics of a <fill> expression are those defined by
+<bibref ref="svg11"/>, §19.2.8.</p>
+</div3>
+<div3 id="animation-value-fragmentIdentifier">
+<head><fragmentIdentifier></head>
+<p>A <fragmentIdentifier> expression is used to target (refer to) an animation to a specific element in the same <emph>Document Instance</emph>.</p>
+<table id="fragmentIdentifier-syntax" role="syntax">
+<caption>Syntax Representation – <fragmentIdentifier></caption>
+<tbody>
+<tr>
+<td>
+<eg xml:space="preserve">
+<fragmentIdentifier>
+ : "#" fragment
+
+fragment
+ : uric+
+
+uric
+ : reserved
+ | unreserved
+ | escaped
+
+reserved
+ : [;/?:@&=+$,]
+
+unreserved
+ : [a-zA-Z]
+ | [0-9]
+ | [-_.!~*'()]
+
+escaped
+ : "%" hex hex
+
+hex
+ : [0-9a-fA-F]
+</eg>
+</td>
+</tr>
+</tbody>
+</table>
+<p>Except for the constraints on syntax and semantics that follow below, the semantics of a <fragmentIdentifier>
+expression are those defined to apply to an "<iri>" expression in <bibref ref="svg11"/>, §19.2.4.</p>
+<p>A <fragmentIdentifer> must adhere
+to the <code>xsd:anyURI</code> data type defined by <bibref ref="xsd-2"/>. Furthermore, it
+must adhere to the fragment identifer syntax defined by <bibref ref="uri"/>,
+Section 4.1, and is a strict subset thereof, since at least one character must appear in
+the fragment component.</p>
+<p>No linear white-space (LWSP) is permitted to appear within a fragment identifier.</p>
+<p>A <fragmentIdentifer> expression must refer to an element in the same <emph>Document Instance</emph>,
+i.e., the fragment component must be a valid IDREF.</p>
+</div3>
+<div3 id="animation-value-keySplines">
+<head><keySplines></head>
+<p>An <keySplines> expression is used to specify a list of Bezier control points that control the pacing of an
+animation, wherein each pair of values is separated by a SEMICOLON (U+003B) character
+optionally surrounded by linear white-space (LWSP) characters.</p>
+<table id="keySplines-syntax" role="syntax">
+<caption>Syntax Representation – <keySplines></caption>
+<tbody>
+<tr>
+<td>
+<eg xml:space="preserve">
+<keySplines>
+ : control [ lwsp? ";" lwsp? control ]*
+
+control
+ : x1 comma? y1 comma? x2 comma? y2
+
+x1, x2, y1, y2
+ : coordinate
+
+coordinate // 0 ≥ <emph>value</emph> ≥ 1
+ : whole
+ | whole "." fraction
+ | "." fraction
+
+whole, fraction
+ : <loc href="#style-value-digit"><digit></loc>+
+
+comma
+ : ","
+
+lwsp
+ : ( ' ' | '\t' | '\n' | '\r' )+
+</eg>
+</td>
+</tr>
+</tbody>
+</table>
+<p>The semantics of a <keySplines> expression are those defined by
+<bibref ref="svg11"/>, §19.2.9, as apply to the <att>keySplines</att> attribute.</p>
+</div3>
+<div3 id="animation-value-keyTimes">
+<head><keyTimes></head>
+<p>An <keyTimes> expression is used to specify a list of relative time values that control the pacing of an
+animation, wherein each pair of values is separated by a SEMICOLON (U+003B) character
+optionally surrounded by linear white-space (LWSP) characters.</p>
+<table id="keyTimes-syntax" role="syntax">
+<caption>Syntax Representation – <keyTimes></caption>
+<tbody>
+<tr>
+<td>
+<eg xml:space="preserve">
+<keyTimes>
+ : time [ lwsp? ";" lwsp? time ]*
+
+time // 0 ≥ <emph>value</emph> ≥ 1
+ : whole
+ | whole "." fraction
+ | "." fraction
+
+whole, fraction
+ : <loc href="#style-value-digit"><digit></loc>+
+
+lwsp
+ : ( ' ' | '\t' | '\n' | '\r' )+
+</eg>
+</td>
+</tr>
+</tbody>
+</table>
+<p>The semantics of a <keyTimes> expression are those defined by
+<bibref ref="svg11"/>, §19.2.9, as apply to the <att>keyTimes</att> attribute.</p>
+</div3>
+<div3 id="animation-value-qualifiedName">
+<head><qualifiedName></head>
+<p>A <qualifiedName> expression is used to specify the attribute targetted by the animation.</p>
+<table id="qualifiedName-syntax" role="syntax">
+<caption>Syntax Representation – <qualifiedName></caption>
+<tbody>
+<tr>
+<td>
+<eg xml:space="preserve">
+<qualifiedName>
+ : prefix ":" local
+ | local
+
+prefix
+ : <emph>nmchar</emph>+
+
+local
+ : <emph>nmchar</emph>+
+</eg>
+</td>
+</tr>
+</tbody>
+</table>
+<p>The syntactic element <emph><code>nmchar</code></emph> is to be interpreted according
+to the <code>NameChar</code> production defined by <bibref ref="xml10"/> §2.3,
+except that the COLON (U+003A) character is excluded.</p>
+<p>The semantics of a <qualifiedName> expression are those defined by
+<bibref ref="svg11"/>, §19.2.5, as applying to an <code>attributeName</code> attribute
+according to an implied <code>attributeType</code> of <code>XML</code>.</p>
+</div3>
+<div3 id="animation-value-repeatCount">
+<head><repeatCount></head>
+<p>A <repeatCount> expression is used to determine the number of iterations of a repeated animation.</p>
+<table id="repeatCount-syntax" role="syntax">
+<caption>Syntax Representation – <repeatCount></caption>
+<tbody>
+<tr>
+<td>
+<eg xml:space="preserve">
+<repeatCount>
+ : count
+ | "indefinite"
+
+count:
+ : <loc href="#style-value-digit"><digit></loc>+ // <emph>value</emph> > 0
+</eg>
+</td>
+</tr>
+</tbody>
+</table>
+<p>The semantics of a <repeatCount> expression are those defined by
+<bibref ref="svg11"/>, §19.2.8.</p>
+</div3>
+<div3 id="animation-value-repeatDur">
+<head><repeatDur></head>
+<p>A <repeatDur> expression is used to control the total duration for a repeated animation.</p>
+<table id="repeatDur-syntax" role="syntax">
+<caption>Syntax Representation – <repeatDur></caption>
+<tbody>
+<tr>
+<td>
+<eg xml:space="preserve">
+<repeatDur>
+ : <loc href="#timing-value-timeExpression"><timeExpression></loc>
+ | "indefinite"
+</eg>
+</td>
+</tr>
+</tbody>
+</table>
+<p>The semantics of a <repeatDur> expression are those defined by
+<bibref ref="svg11"/>, §19.2.8.</p>
+</div3>
+</div2>
</div1>
<div1 id="metadata">
<head>Metadata</head>
@@ -9085,17 +9604,9 @@
as relative URIs (fragment identifiers) with respect to the
TT Feature Namespace base URI.</p>
<ednote>
-<name>#animation-referential</name>
-<date>2013-07-10</date>
-<edtext>Consider adding <code>#animation-referential</code> to designate use of <code>style</code> attribute
-on <el>set</el> element.</edtext>
-</ednote>
-<p/>
-<ednote>
-<name>#animation-targeted</name>
-<date>2013-07-10</date>
-<edtext>Consider adding <code>#animation-targeted</code> to designate use of <code>xml:href</code> or
-<code>targetElement</code> attribute on <el>set</el> element (if added).</edtext>
+<name>#animation subset features</name>
+<date>2013-08-26</date>
+<edtext>Add fine grained subset features of #animation.</edtext>
</ednote>
<div3 id="feature-animation">
<head>#animation</head>
@@ -9103,6 +9614,8 @@
feature if it recognizes and is capable of transforming the following
vocabulary defined by <specref ref="animation"/>:</p>
<ulist>
+<item><p><loc href="#animation-vocabulary-animation"><el>animation</el></loc></p></item>
+<item><p><loc href="#animation-vocabulary-animate"><el>animate</el></loc></p></item>
<item><p><loc href="#animation-vocabulary-set"><el>set</el></loc></p></item>
</ulist>
<p>A TTML presentation processor supports the <code>#animation</code>
@@ -11650,11 +12163,11 @@
Schema Definition Language (DSDL) – Part 2: Regular-grammar-based validation – RELAX NG</titleref>,
International Organization for Standardization (ISO).
</bibl>
-<bibl id="smil21" key="SMIL 2.1">Dick Bultermann, et al.,
-<titleref href="http://www.w3.org/TR/2005/REC-SMIL2-20051213/">Synchronized
-Multimedia Integration Language (SMIL 2.1)</titleref>,
-W3C Recommendation, 13 December 2005. (See
-<xspecref href="http://www.w3.org/TR/2005/REC-SMIL2-20051213/">http://www.w3.org/TR/2005/REC-SMIL2-20051213/</xspecref>.)
+<bibl id="smil3" key="SMIL 3.0">Dick Bultermann, et al.,
+<titleref href="http://www.w3.org/TR/2008/REC-SMIL3-20081201/">Synchronized
+Multimedia Integration Language (SMIL 3.0)</titleref>,
+W3C Recommendation, 1 December 2008. (See
+<xspecref href="http://www.w3.org/TR/2008/REC-SMIL3-20081201/">http://www.w3.org/TR/2008/REC-SMIL3-20081201/</xspecref>.)
</bibl>
<bibl id="smpte12m" key="SMPTE 12M">ANSI/SMPTE 12M,
<titleref href="https://www.smpte.org/">Television, Audio and Film –
@@ -11668,6 +12181,13 @@
– sRGB</titleref>, International Electrotechnical
Commission (IEC).
</bibl>
+<bibl id="svg11" key="SVG 1.1">Erik Dahlström et al., Eds.,
+<titleref
+href="http://www.w3.org/TR/2011/REC-SVG11-20110816/">Scalable
+Vector Graphics (SVG) 1.1 Second Edition</titleref>, W3C Recommendation, 16
+August 2011. (See
+<xspecref href="http://www.w3.org/TR/2011/REC-SVG11-20110816/">http://www.w3.org/TR/2011/REC-SVG11-20110816/</xspecref>.)
+</bibl>
<bibl id="uaag" key="UAAG">Ian Jacobs, Jon Gunderson, and Eric Hansen, Eds.,
<titleref href="http://www.w3.org/TR/2002/REC-UAAG10-20021217/">User
Agent Accessibility Guidelines 1.0</titleref>, W3C Recommendation, 17
@@ -11680,6 +12200,12 @@
<xspecref
href="http://www.unicode.org/reports/tr14/tr14-17.html">http://www.unicode.org/reports/tr14/tr14-17.html</xspecref>.)
</bibl>
+<bibl id="uri" key="URI">T. Berner-Lee, R. Fielding, and L. Masinter,
+<titleref
+href="http://www.rfc-editor.org/rfc/rfc2396.txt">Uniform Resource Identifiers (URI): Generic Syntax</titleref>,
+RFC 2396, August 1998, IETF.(See
+<xspecref href="http://www.rfc-editor.org/rfc/rfc2396.txt">http://www.rfc-editor.org/rfc/rfc2396.txt</xspecref>.)
+</bibl>
<bibl id="utc" key="UTC">
Recommendation TF.460,
<titleref
@@ -11805,13 +12331,6 @@
href="http://www.smpte.org/">Conversion from CEA-708 Caption Data to SMPTE-TT</titleref>,
SMPTE Recommended Practice.
</bibl>
-<bibl id="svg11" key="SVG 1.1">Jon Ferraiolo, Jun Fujisawa, Dean Jackson, Eds.,
-<titleref
-href="http://www.w3.org/TR/2003/REC-SVG11-20030114/">Scalable
-Vector Graphics (SVG) 1.1 Specification</titleref>, W3C Recommendation, 14
-January 2003. (See
-<xspecref href="http://www.w3.org/TR/2003/REC-SVG11-20030114/">http://www.w3.org/TR/2003/REC-SVG11-20030114/</xspecref>.)
-</bibl>
<bibl id="ttaf1-req" key="TTAF1-REQ">Glenn Adams, Ed.,
<titleref href="http://www.w3.org/TR/2006/NOTE-ttaf1-req-20060427/">Timed Text (TT) Authoring Format 1.0 Use
Cases and Requirements</titleref>,
@@ -11819,6 +12338,11 @@
<xspecref
href="http://www.w3.org/TR/2006/NOTE-ttaf1-req-20060427/">http://www.w3.org/TR/2006/NOTE-ttaf1-req-20060427/</xspecref>.)
</bibl>
+<bibl id="ttml1" key="TTML1">Glenn Adams, Ed.,
+<titleref href="https://dvcs.w3.org/hg/ttml/raw-file/default/ttml1/spec/ttml1.html">Timed Text Markup Language 1 (TTML1) (Second Edition)</titleref>,
+W3C Editor's Draft. (See
+<xspecref href="https://dvcs.w3.org/hg/ttml/raw-file/default/ttml1/spec/ttml1.html">https://dvcs.w3.org/hg/ttml/raw-file/default/ttml1/spec/ttml1.html</xspecref>.)
+</bibl>
<bibl id="xhtml10" key="XHTML 1.0">Steven Pemberton, et al.,
<titleref
href="http://www.w3.org/TR/2002/REC-xhtml1-20020801/">XHTML™ 1.0,
@@ -12306,6 +12830,20 @@
<td><phrase role="strong">Notes</phrase></td>
</tr>
<tr>
+<td><loc href="#animation-vocabulary-animate"><code>tt:animate</code></loc></td>
+<td><code>svg:animate</code></td>
+<td><bibref ref="svg11"/></td>
+<td>-@* except begin, dur, end; +@tts:*, +@xml:lang, +@xml:space</td>
+<td>3,6</td>
+</tr>
+<tr>
+<td><loc href="#animation-vocabulary-animation"><code>tt:animation</code></loc></td>
+<td><code>tt:layout</code></td>
+<td><bibref ref="ttml1"/></td>
+<td>conceptual derivation</td>
+<td>12</td>
+</tr>
+<tr>
<td><loc href="#document-structure-vocabulary-body"><code>tt:body</code></loc></td>
<td><code>xhtml:body</code></td>
<td><bibref ref="xhtml10"/></td>
@@ -12550,6 +13088,11 @@
<p>Derived from the use of <code>@baseProfile</code>
and <code>@version</code> on the <code>svg:svg</code> element.</p>
</item>
+<item>
+<p>Conceptually derived from existing <el>tt:layout</el> element,
+which is a generic container for layout specifications, but for use
+in defining animation specifications that apply to targetted elements.</p>
+</item>
</olist>
</note>
</div2>
@@ -12598,21 +13141,21 @@
<tr>
<td><loc href="#timing-attribute-begin"><code>begin</code></loc></td>
<td><code>begin</code></td>
-<td><bibref ref="smil21"/></td>
+<td><bibref ref="smil3"/></td>
<td>see notes</td>
<td>2,3,4</td>
</tr>
<tr>
<td><loc href="#timing-attribute-dur"><code>dur</code></loc></td>
<td><code>dur</code></td>
-<td><bibref ref="smil21"/></td>
+<td><bibref ref="smil3"/></td>
<td>see notes</td>
<td>2,3,4</td>
</tr>
<tr>
<td><loc href="#timing-attribute-end"><code>end</code></loc></td>
<td><code>end</code></td>
-<td><bibref ref="smil21"/></td>
+<td><bibref ref="smil3"/></td>
<td>see notes</td>
<td>2,3,4</td>
</tr>
@@ -12633,7 +13176,7 @@
<tr>
<td><loc href="#timing-attribute-timeContainer"><code>timeContainer</code></loc></td>
<td><code>timeContainer</code></td>
-<td><bibref ref="smil21"/></td>
+<td><bibref ref="smil3"/></td>
<td>
-<code>excl</code>,
-<code>none</code>;
@@ -12847,7 +13390,7 @@
<tr>
<td><loc href="#style-attribute-showBackground"><code>tts:showBackground</code></loc></td>
<td><code>showBackground</code></td>
-<td><bibref ref="smil21"/></td>
+<td><bibref ref="smil3"/></td>
<td>-<code>inherit</code></td>
<td></td>
</tr>
@@ -12971,7 +13514,7 @@
</item>
<item>
<p>Syntactically subsets and supersets the <bibref
-ref="smil21"/> <code>Clock-value</code> syntax as follows:
+ref="smil3"/> <code>Clock-value</code> syntax as follows:
(1) requires non-negative <code>Full-clock-value</code> or
<code>Timecount-value</code>;
(2) if <code>Full-clock-value</code>