mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
cc8b720bee
--HG-- rename : content/smil/SMILBoolType.cpp => dom/smil/SMILBoolType.cpp rename : content/smil/SMILBoolType.h => dom/smil/SMILBoolType.h rename : content/smil/SMILEnumType.cpp => dom/smil/SMILEnumType.cpp rename : content/smil/SMILEnumType.h => dom/smil/SMILEnumType.h rename : content/smil/SMILIntegerType.cpp => dom/smil/SMILIntegerType.cpp rename : content/smil/SMILIntegerType.h => dom/smil/SMILIntegerType.h rename : content/smil/SMILStringType.cpp => dom/smil/SMILStringType.cpp rename : content/smil/SMILStringType.h => dom/smil/SMILStringType.h rename : content/smil/crashtests/483584-1.svg => dom/smil/crashtests/483584-1.svg rename : content/smil/crashtests/483584-2.svg => dom/smil/crashtests/483584-2.svg rename : content/smil/crashtests/523188-1.svg => dom/smil/crashtests/523188-1.svg rename : content/smil/crashtests/525099-1.svg => dom/smil/crashtests/525099-1.svg rename : content/smil/crashtests/526536-1.svg => dom/smil/crashtests/526536-1.svg rename : content/smil/crashtests/526875-1.svg => dom/smil/crashtests/526875-1.svg rename : content/smil/crashtests/526875-2.svg => dom/smil/crashtests/526875-2.svg rename : content/smil/crashtests/529387-1-helper.svg => dom/smil/crashtests/529387-1-helper.svg rename : content/smil/crashtests/529387-1.xhtml => dom/smil/crashtests/529387-1.xhtml rename : content/smil/crashtests/531550-1.svg => dom/smil/crashtests/531550-1.svg rename : content/smil/crashtests/537157-1.svg => dom/smil/crashtests/537157-1.svg rename : content/smil/crashtests/541297-1.svg => dom/smil/crashtests/541297-1.svg rename : content/smil/crashtests/547333-1.svg => dom/smil/crashtests/547333-1.svg rename : content/smil/crashtests/548899-1.svg => dom/smil/crashtests/548899-1.svg rename : content/smil/crashtests/551620-1.svg => dom/smil/crashtests/551620-1.svg rename : content/smil/crashtests/554141-1.svg => dom/smil/crashtests/554141-1.svg rename : content/smil/crashtests/554202-1.svg => dom/smil/crashtests/554202-1.svg rename : content/smil/crashtests/554202-2.svg => dom/smil/crashtests/554202-2.svg rename : content/smil/crashtests/555026-1.svg => dom/smil/crashtests/555026-1.svg rename : content/smil/crashtests/556841-1.svg => dom/smil/crashtests/556841-1.svg rename : content/smil/crashtests/572938-1.svg => dom/smil/crashtests/572938-1.svg rename : content/smil/crashtests/572938-2.svg => dom/smil/crashtests/572938-2.svg rename : content/smil/crashtests/572938-3.svg => dom/smil/crashtests/572938-3.svg rename : content/smil/crashtests/572938-4.svg => dom/smil/crashtests/572938-4.svg rename : content/smil/crashtests/588287-1.svg => dom/smil/crashtests/588287-1.svg rename : content/smil/crashtests/588287-2.svg => dom/smil/crashtests/588287-2.svg rename : content/smil/crashtests/590425-1.html => dom/smil/crashtests/590425-1.html rename : content/smil/crashtests/592477-1.xhtml => dom/smil/crashtests/592477-1.xhtml rename : content/smil/crashtests/594653-1.svg => dom/smil/crashtests/594653-1.svg rename : content/smil/crashtests/596796-1.svg => dom/smil/crashtests/596796-1.svg rename : content/smil/crashtests/605345-1.svg => dom/smil/crashtests/605345-1.svg rename : content/smil/crashtests/606101-1.svg => dom/smil/crashtests/606101-1.svg rename : content/smil/crashtests/608295-1.html => dom/smil/crashtests/608295-1.html rename : content/smil/crashtests/608549-1.svg => dom/smil/crashtests/608549-1.svg rename : content/smil/crashtests/611927-1.svg => dom/smil/crashtests/611927-1.svg rename : content/smil/crashtests/615002-1.svg => dom/smil/crashtests/615002-1.svg rename : content/smil/crashtests/615872-1.svg => dom/smil/crashtests/615872-1.svg rename : content/smil/crashtests/641388-1.html => dom/smil/crashtests/641388-1.html rename : content/smil/crashtests/641388-2.html => dom/smil/crashtests/641388-2.html rename : content/smil/crashtests/650732-1.svg => dom/smil/crashtests/650732-1.svg rename : content/smil/crashtests/665334-1.svg => dom/smil/crashtests/665334-1.svg rename : content/smil/crashtests/669225-1.svg => dom/smil/crashtests/669225-1.svg rename : content/smil/crashtests/669225-2.svg => dom/smil/crashtests/669225-2.svg rename : content/smil/crashtests/670313-1.svg => dom/smil/crashtests/670313-1.svg rename : content/smil/crashtests/678822-1.svg => dom/smil/crashtests/678822-1.svg rename : content/smil/crashtests/678847-1.svg => dom/smil/crashtests/678847-1.svg rename : content/smil/crashtests/678938-1.svg => dom/smil/crashtests/678938-1.svg rename : content/smil/crashtests/690994-1.svg => dom/smil/crashtests/690994-1.svg rename : content/smil/crashtests/691337-1.svg => dom/smil/crashtests/691337-1.svg rename : content/smil/crashtests/691337-2.svg => dom/smil/crashtests/691337-2.svg rename : content/smil/crashtests/697640-1.svg => dom/smil/crashtests/697640-1.svg rename : content/smil/crashtests/699325-1.svg => dom/smil/crashtests/699325-1.svg rename : content/smil/crashtests/709907-1.svg => dom/smil/crashtests/709907-1.svg rename : content/smil/crashtests/720103-1.svg => dom/smil/crashtests/720103-1.svg rename : content/smil/crashtests/crashtests.list => dom/smil/crashtests/crashtests.list rename : content/smil/moz.build => dom/smil/moz.build rename : content/smil/nsDOMTimeEvent.cpp => dom/smil/nsDOMTimeEvent.cpp rename : content/smil/nsDOMTimeEvent.h => dom/smil/nsDOMTimeEvent.h rename : content/smil/nsISMILAttr.h => dom/smil/nsISMILAttr.h rename : content/smil/nsISMILType.h => dom/smil/nsISMILType.h rename : content/smil/nsSMILAnimationController.cpp => dom/smil/nsSMILAnimationController.cpp rename : content/smil/nsSMILAnimationController.h => dom/smil/nsSMILAnimationController.h rename : content/smil/nsSMILAnimationFunction.cpp => dom/smil/nsSMILAnimationFunction.cpp rename : content/smil/nsSMILAnimationFunction.h => dom/smil/nsSMILAnimationFunction.h rename : content/smil/nsSMILCSSProperty.cpp => dom/smil/nsSMILCSSProperty.cpp rename : content/smil/nsSMILCSSProperty.h => dom/smil/nsSMILCSSProperty.h rename : content/smil/nsSMILCSSValueType.cpp => dom/smil/nsSMILCSSValueType.cpp rename : content/smil/nsSMILCSSValueType.h => dom/smil/nsSMILCSSValueType.h rename : content/smil/nsSMILCompositor.cpp => dom/smil/nsSMILCompositor.cpp rename : content/smil/nsSMILCompositor.h => dom/smil/nsSMILCompositor.h rename : content/smil/nsSMILCompositorTable.h => dom/smil/nsSMILCompositorTable.h rename : content/smil/nsSMILFloatType.cpp => dom/smil/nsSMILFloatType.cpp rename : content/smil/nsSMILFloatType.h => dom/smil/nsSMILFloatType.h rename : content/smil/nsSMILInstanceTime.cpp => dom/smil/nsSMILInstanceTime.cpp rename : content/smil/nsSMILInstanceTime.h => dom/smil/nsSMILInstanceTime.h rename : content/smil/nsSMILInterval.cpp => dom/smil/nsSMILInterval.cpp rename : content/smil/nsSMILInterval.h => dom/smil/nsSMILInterval.h rename : content/smil/nsSMILKeySpline.cpp => dom/smil/nsSMILKeySpline.cpp rename : content/smil/nsSMILKeySpline.h => dom/smil/nsSMILKeySpline.h rename : content/smil/nsSMILMappedAttribute.cpp => dom/smil/nsSMILMappedAttribute.cpp rename : content/smil/nsSMILMappedAttribute.h => dom/smil/nsSMILMappedAttribute.h rename : content/smil/nsSMILMilestone.h => dom/smil/nsSMILMilestone.h rename : content/smil/nsSMILNullType.cpp => dom/smil/nsSMILNullType.cpp rename : content/smil/nsSMILNullType.h => dom/smil/nsSMILNullType.h rename : content/smil/nsSMILParserUtils.cpp => dom/smil/nsSMILParserUtils.cpp rename : content/smil/nsSMILParserUtils.h => dom/smil/nsSMILParserUtils.h rename : content/smil/nsSMILRepeatCount.cpp => dom/smil/nsSMILRepeatCount.cpp rename : content/smil/nsSMILRepeatCount.h => dom/smil/nsSMILRepeatCount.h rename : content/smil/nsSMILSetAnimationFunction.cpp => dom/smil/nsSMILSetAnimationFunction.cpp rename : content/smil/nsSMILSetAnimationFunction.h => dom/smil/nsSMILSetAnimationFunction.h rename : content/smil/nsSMILTargetIdentifier.h => dom/smil/nsSMILTargetIdentifier.h rename : content/smil/nsSMILTimeContainer.cpp => dom/smil/nsSMILTimeContainer.cpp rename : content/smil/nsSMILTimeContainer.h => dom/smil/nsSMILTimeContainer.h rename : content/smil/nsSMILTimeValue.cpp => dom/smil/nsSMILTimeValue.cpp rename : content/smil/nsSMILTimeValue.h => dom/smil/nsSMILTimeValue.h rename : content/smil/nsSMILTimeValueSpec.cpp => dom/smil/nsSMILTimeValueSpec.cpp rename : content/smil/nsSMILTimeValueSpec.h => dom/smil/nsSMILTimeValueSpec.h rename : content/smil/nsSMILTimeValueSpecParams.h => dom/smil/nsSMILTimeValueSpecParams.h rename : content/smil/nsSMILTimedElement.cpp => dom/smil/nsSMILTimedElement.cpp rename : content/smil/nsSMILTimedElement.h => dom/smil/nsSMILTimedElement.h rename : content/smil/nsSMILTypes.h => dom/smil/nsSMILTypes.h rename : content/smil/nsSMILValue.cpp => dom/smil/nsSMILValue.cpp rename : content/smil/nsSMILValue.h => dom/smil/nsSMILValue.h rename : content/smil/test/db_smilAnimateMotion.js => dom/smil/test/db_smilAnimateMotion.js rename : content/smil/test/db_smilCSSFromBy.js => dom/smil/test/db_smilCSSFromBy.js rename : content/smil/test/db_smilCSSFromTo.js => dom/smil/test/db_smilCSSFromTo.js rename : content/smil/test/db_smilCSSPaced.js => dom/smil/test/db_smilCSSPaced.js rename : content/smil/test/db_smilCSSPropertyList.js => dom/smil/test/db_smilCSSPropertyList.js rename : content/smil/test/db_smilMappedAttrList.js => dom/smil/test/db_smilMappedAttrList.js rename : content/smil/test/mochitest.ini => dom/smil/test/mochitest.ini rename : content/smil/test/moz.build => dom/smil/test/moz.build rename : content/smil/test/smilAnimateMotionValueLists.js => dom/smil/test/smilAnimateMotionValueLists.js rename : content/smil/test/smilExtDoc_helper.svg => dom/smil/test/smilExtDoc_helper.svg rename : content/smil/test/smilTestUtils.js => dom/smil/test/smilTestUtils.js rename : content/smil/test/smilXHR_helper.svg => dom/smil/test/smilXHR_helper.svg rename : content/smil/test/test_smilAccessKey.xhtml => dom/smil/test/test_smilAccessKey.xhtml rename : content/smil/test/test_smilAnimateMotion.xhtml => dom/smil/test/test_smilAnimateMotion.xhtml rename : content/smil/test/test_smilAnimateMotionInvalidValues.xhtml => dom/smil/test/test_smilAnimateMotionInvalidValues.xhtml rename : content/smil/test/test_smilAnimateMotionOverrideRules.xhtml => dom/smil/test/test_smilAnimateMotionOverrideRules.xhtml rename : content/smil/test/test_smilBackwardsSeeking.xhtml => dom/smil/test/test_smilBackwardsSeeking.xhtml rename : content/smil/test/test_smilCSSFontStretchRelative.xhtml => dom/smil/test/test_smilCSSFontStretchRelative.xhtml rename : content/smil/test/test_smilCSSFromBy.xhtml => dom/smil/test/test_smilCSSFromBy.xhtml rename : content/smil/test/test_smilCSSFromTo.xhtml => dom/smil/test/test_smilCSSFromTo.xhtml rename : content/smil/test/test_smilCSSInherit.xhtml => dom/smil/test/test_smilCSSInherit.xhtml rename : content/smil/test/test_smilCSSInvalidValues.xhtml => dom/smil/test/test_smilCSSInvalidValues.xhtml rename : content/smil/test/test_smilCSSPaced.xhtml => dom/smil/test/test_smilCSSPaced.xhtml rename : content/smil/test/test_smilChangeAfterFrozen.xhtml => dom/smil/test/test_smilChangeAfterFrozen.xhtml rename : content/smil/test/test_smilContainerBinding.xhtml => dom/smil/test/test_smilContainerBinding.xhtml rename : content/smil/test/test_smilCrossContainer.xhtml => dom/smil/test/test_smilCrossContainer.xhtml rename : content/smil/test/test_smilDynamicDelayedBeginElement.xhtml => dom/smil/test/test_smilDynamicDelayedBeginElement.xhtml rename : content/smil/test/test_smilExtDoc.xhtml => dom/smil/test/test_smilExtDoc.xhtml rename : content/smil/test/test_smilFillMode.xhtml => dom/smil/test/test_smilFillMode.xhtml rename : content/smil/test/test_smilGetSimpleDuration.xhtml => dom/smil/test/test_smilGetSimpleDuration.xhtml rename : content/smil/test/test_smilGetStartTime.xhtml => dom/smil/test/test_smilGetStartTime.xhtml rename : content/smil/test/test_smilHyperlinking.xhtml => dom/smil/test/test_smilHyperlinking.xhtml rename : content/smil/test/test_smilInvalidValues.html => dom/smil/test/test_smilInvalidValues.html rename : content/smil/test/test_smilKeySplines.xhtml => dom/smil/test/test_smilKeySplines.xhtml rename : content/smil/test/test_smilKeyTimes.xhtml => dom/smil/test/test_smilKeyTimes.xhtml rename : content/smil/test/test_smilKeyTimesPacedMode.xhtml => dom/smil/test/test_smilKeyTimesPacedMode.xhtml rename : content/smil/test/test_smilMappedAttrFromBy.xhtml => dom/smil/test/test_smilMappedAttrFromBy.xhtml rename : content/smil/test/test_smilMappedAttrFromTo.xhtml => dom/smil/test/test_smilMappedAttrFromTo.xhtml rename : content/smil/test/test_smilMappedAttrPaced.xhtml => dom/smil/test/test_smilMappedAttrPaced.xhtml rename : content/smil/test/test_smilMinTiming.html => dom/smil/test/test_smilMinTiming.html rename : content/smil/test/test_smilRepeatDuration.html => dom/smil/test/test_smilRepeatDuration.html rename : content/smil/test/test_smilRepeatTiming.xhtml => dom/smil/test/test_smilRepeatTiming.xhtml rename : content/smil/test/test_smilReset.xhtml => dom/smil/test/test_smilReset.xhtml rename : content/smil/test/test_smilRestart.xhtml => dom/smil/test/test_smilRestart.xhtml rename : content/smil/test/test_smilSetCurrentTime.xhtml => dom/smil/test/test_smilSetCurrentTime.xhtml rename : content/smil/test/test_smilSync.xhtml => dom/smil/test/test_smilSync.xhtml rename : content/smil/test/test_smilSyncTransform.xhtml => dom/smil/test/test_smilSyncTransform.xhtml rename : content/smil/test/test_smilSyncbaseTarget.xhtml => dom/smil/test/test_smilSyncbaseTarget.xhtml rename : content/smil/test/test_smilTextZoom.xhtml => dom/smil/test/test_smilTextZoom.xhtml rename : content/smil/test/test_smilTimeEvents.xhtml => dom/smil/test/test_smilTimeEvents.xhtml rename : content/smil/test/test_smilTiming.xhtml => dom/smil/test/test_smilTiming.xhtml rename : content/smil/test/test_smilTimingZeroIntervals.xhtml => dom/smil/test/test_smilTimingZeroIntervals.xhtml rename : content/smil/test/test_smilUpdatedInterval.xhtml => dom/smil/test/test_smilUpdatedInterval.xhtml rename : content/smil/test/test_smilValues.xhtml => dom/smil/test/test_smilValues.xhtml rename : content/smil/test/test_smilXHR.xhtml => dom/smil/test/test_smilXHR.xhtml extra : rebase_source : 4038f574b020b79d3725efd91eeef457d9d6a0b0
392 lines
11 KiB
HTML
392 lines
11 KiB
HTML
<html xmlns="http://www.w3.org/1999/xhtml">
|
|
<head>
|
|
<title>Test for SMIL keyTimes</title>
|
|
<script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
|
|
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
|
|
</head>
|
|
<body>
|
|
<a target="_blank"
|
|
href="https://bugzilla.mozilla.org/show_bug.cgi?id=557885">Mozilla Bug
|
|
557885</a>
|
|
<p id="display"></p>
|
|
<div id="content" style="display: none">
|
|
<svg id="svg" xmlns="http://www.w3.org/2000/svg" width="120px" height="120px">
|
|
<circle cx="-100" cy="20" r="15" fill="blue" id="circle"/>
|
|
</svg>
|
|
</div>
|
|
<pre id="test">
|
|
<script class="testbody" type="text/javascript">
|
|
<![CDATA[
|
|
/** Test for SMIL keyTimes **/
|
|
|
|
var gSvg = document.getElementById("svg");
|
|
SimpleTest.waitForExplicitFinish();
|
|
|
|
function main()
|
|
{
|
|
gSvg.pauseAnimations();
|
|
|
|
var testCases = Array();
|
|
|
|
// Simple case
|
|
testCases.push({
|
|
'attr' : { 'values': '0; 50; 100',
|
|
'keyTimes': '0; .8; 1' },
|
|
'times': [ [ 4, 25 ],
|
|
[ 8, 50 ],
|
|
[ 9, 75 ],
|
|
[ 10, 100 ] ]
|
|
});
|
|
|
|
// Parsing tests
|
|
testCases.push(parseOk(' 0 ; .8;1 ')); // extra whitespace
|
|
testCases.push(parseNotOk(';0; .8; 1')); // leading semi-colon
|
|
testCases.push(parseNotOk('; .8; 1')); // leading semi-colon
|
|
testCases.push(parseOk('0; .8; 1;')); // trailing semi-colon
|
|
testCases.push(parseNotOk('')); // empty string
|
|
testCases.push(parseNotOk(' ')); // empty string
|
|
testCases.push(parseNotOk('0; .8')); // too few values
|
|
testCases.push(parseNotOk('0; .8; .9; 1')); // too many values
|
|
testCases.push(parseNotOk('0; 1; .8')); // non-increasing
|
|
testCases.push(parseNotOk('0; .8; .9')); // final value non-1 with
|
|
// calcMode=linear
|
|
testCases.push(parseOk('0; .8; .9', { 'calcMode': 'discrete' }));
|
|
testCases.push(parseNotOk('0.01; .8; 1')); // first value not 0
|
|
testCases.push(parseNotOk('0.01; .8; 1', { 'calcMode': 'discrete' }));
|
|
// first value not 0
|
|
testCases.push(parseNotOk('0; .8; 1.1')); // out of range
|
|
testCases.push(parseNotOk('-0.1; .8; 1')); // out of range
|
|
|
|
|
|
// 2 values
|
|
testCases.push({
|
|
'attr' : { 'values': '0; 50',
|
|
'keyTimes': '0; 1' },
|
|
'times': [ [ 6, 30 ] ]
|
|
});
|
|
|
|
// 1 value
|
|
testCases.push({
|
|
'attr' : { 'values': '50',
|
|
'keyTimes': ' 0' },
|
|
'times': [ [ 7, 50 ] ]
|
|
});
|
|
|
|
// 1 bad value
|
|
testCases.push({
|
|
'attr' : { 'values': '50',
|
|
'keyTimes': '0.1' },
|
|
'times': [ [ 0, -100 ] ]
|
|
});
|
|
|
|
// 1 value, calcMode=discrete
|
|
testCases.push({
|
|
'attr' : { 'values': '50',
|
|
'calcMode': 'discrete',
|
|
'keyTimes': ' 0' },
|
|
'times': [ [ 7, 50 ] ]
|
|
});
|
|
|
|
// 1 bad value, calcMode=discrete
|
|
testCases.push({
|
|
'attr' : { 'values': '50',
|
|
'calcMode': 'discrete',
|
|
'keyTimes': '0.1' },
|
|
'times': [ [ 0, -100 ] ]
|
|
});
|
|
|
|
// from-to
|
|
testCases.push({
|
|
'attr' : { 'from': '10',
|
|
'to': '20',
|
|
'keyTimes': '0.0; 1.0' },
|
|
'times': [ [ 3.5, 13.5 ] ]
|
|
});
|
|
|
|
// from-to calcMode=discrete
|
|
testCases.push({
|
|
'attr' : { 'from': '10',
|
|
'to': '20',
|
|
'calcMode': 'discrete',
|
|
'keyTimes': '0.0; 0.7' },
|
|
'times': [ [ 0, 10 ],
|
|
[ 6.9, 10 ],
|
|
[ 7.0, 20 ],
|
|
[ 10.0, 20 ],
|
|
[ 11.0, 20 ] ]
|
|
});
|
|
|
|
// from-to calcMode=discrete one keyTime only
|
|
testCases.push({
|
|
'attr' : { 'values': '20',
|
|
'calcMode': 'discrete',
|
|
'keyTimes': '0' },
|
|
'times': [ [ 0, 20 ],
|
|
[ 6.9, 20 ],
|
|
[ 7.0, 20 ],
|
|
[ 10.0, 20 ],
|
|
[ 11.0, 20 ] ]
|
|
});
|
|
|
|
// from-to calcMode=discrete one keyTime, mismatches no. values
|
|
testCases.push({
|
|
'attr' : { 'values': '10; 20',
|
|
'calcMode': 'discrete',
|
|
'keyTimes': '0' },
|
|
'times': [ [ 0, -100 ] ]
|
|
});
|
|
|
|
// to
|
|
testCases.push({
|
|
'attr' : { 'to': '100',
|
|
'keyTimes': '0.0; 1.0' },
|
|
'times': [ [ 0, -100 ],
|
|
[ 7, 40 ] ]
|
|
});
|
|
|
|
// to -- bad number of keyTimes (too many)
|
|
testCases.push({
|
|
'attr' : { 'to': '100',
|
|
'keyTimes': '0.0; 0.5; 1.0' },
|
|
'times': [ [ 2, -100 ] ]
|
|
});
|
|
|
|
// unfrozen to calcMode=discrete two keyTimes
|
|
testCases.push({
|
|
'attr' : { 'to': '100',
|
|
'calcMode': 'discrete',
|
|
'keyTimes': '0.0; 1.0',
|
|
'fill': 'remove' },
|
|
'times': [ [ 0, -100 ],
|
|
[ 7, -100 ],
|
|
[ 10, -100 ],
|
|
[ 12, -100 ]]
|
|
});
|
|
|
|
// frozen to calcMode=discrete two keyTimes
|
|
testCases.push({
|
|
'attr' : { 'to': '100',
|
|
'calcMode': 'discrete',
|
|
'keyTimes': '0.0; 1.0' },
|
|
'times': [ [ 0, -100 ],
|
|
[ 7, -100 ],
|
|
[ 10, 100 ],
|
|
[ 12, 100 ] ]
|
|
});
|
|
|
|
// to calcMode=discrete -- bad number of keyTimes (one, expecting two)
|
|
testCases.push({
|
|
'attr' : { 'to': '100',
|
|
'calcMode': 'discrete',
|
|
'keyTimes': '0' },
|
|
'times': [ [ 0, -100 ],
|
|
[ 7, -100 ] ]
|
|
});
|
|
|
|
// values calcMode=discrete
|
|
testCases.push({
|
|
'attr' : { 'values': '0; 10; 20; 30',
|
|
'calcMode': 'discrete',
|
|
'keyTimes': '0;.2;.4;.6' },
|
|
'times': [ [ 0, 0 ],
|
|
[ 1.9, 0 ],
|
|
[ 2, 10 ],
|
|
[ 3.9, 10 ],
|
|
[ 4.0, 20 ],
|
|
[ 5.9, 20 ],
|
|
[ 6.0, 30 ],
|
|
[ 9.9, 30 ],
|
|
[ 10.0, 30 ] ]
|
|
});
|
|
|
|
// The following two accumulate tests are from SMIL 3.0
|
|
// (Note that this behaviour differs from that defined for SVG Tiny 1.2 which
|
|
// specifically excludes the last value: "Note that in the case of discrete
|
|
// animation, the frozen value that is used is the value of the animation just
|
|
// before the end of the active duration.")
|
|
// accumulate=none
|
|
testCases.push({
|
|
'attr' : { 'values': '0; 10; 20',
|
|
'calcMode': 'discrete',
|
|
'keyTimes': '0;.5;1',
|
|
'fill': 'freeze',
|
|
'repeatCount': '2',
|
|
'accumulate': 'none' },
|
|
'times': [ [ 0, 0 ],
|
|
[ 5, 10 ],
|
|
[ 10, 0 ],
|
|
[ 15, 10 ],
|
|
[ 20, 20 ],
|
|
[ 25, 20 ] ]
|
|
});
|
|
|
|
// accumulate=sum
|
|
testCases.push({
|
|
'attr' : { 'values': '0; 10; 20',
|
|
'calcMode': 'discrete',
|
|
'keyTimes': '0;.5;1',
|
|
'fill': 'freeze',
|
|
'repeatCount': '2',
|
|
'accumulate': 'sum' },
|
|
'times': [ [ 0, 0 ],
|
|
[ 5, 10 ],
|
|
[ 10, 20 ],
|
|
[ 15, 30 ],
|
|
[ 20, 40 ],
|
|
[ 25, 40 ] ]
|
|
});
|
|
|
|
// If the interpolation mode is paced, the keyTimes attribute is ignored.
|
|
testCases.push({
|
|
'attr' : { 'values': '0; 10; 20',
|
|
'calcMode': 'paced',
|
|
'keyTimes': '0;.2;1' },
|
|
'times': [ [ 0, 0 ],
|
|
[ 2, 4 ],
|
|
[ 5, 10 ] ]
|
|
});
|
|
|
|
// SMIL 3 has:
|
|
// If the simple duration is indefinite and the interpolation mode is
|
|
// linear or spline, any keyTimes specification will be ignored.
|
|
// However, since keyTimes represent "a proportional offset into the simple
|
|
// duration of the animation element" surely discrete animation too cannot use
|
|
// keyTimes when the simple duration is indefinite. Hence SVGT 1.2 is surely
|
|
// more correct when it has:
|
|
// If the simple duration is indefinite, any 'keyTimes' specification will
|
|
// be ignored.
|
|
// (linear)
|
|
testCases.push({
|
|
'attr' : { 'values': '0; 10; 20',
|
|
'dur': 'indefinite',
|
|
'keyTimes': '0;.2;1' },
|
|
'times': [ [ 0, 0 ],
|
|
[ 5, 0 ] ]
|
|
});
|
|
// (spline)
|
|
testCases.push({
|
|
'attr' : { 'values': '0; 10; 20',
|
|
'dur': 'indefinite',
|
|
'calcMode': 'spline',
|
|
'keyTimes': '0;.2;1',
|
|
'keySplines': '0 0 1 1; 0 0 1 1' },
|
|
'times': [ [ 0, 0 ],
|
|
[ 5, 0 ] ]
|
|
});
|
|
// (discrete)
|
|
testCases.push({
|
|
'attr' : { 'values': '0; 10; 20',
|
|
'dur': 'indefinite',
|
|
'calcMode': 'discrete',
|
|
'keyTimes': '0;.2;1' },
|
|
'times': [ [ 0, 0 ],
|
|
[ 5, 0 ] ]
|
|
});
|
|
|
|
for (var i = 0; i < testCases.length; i++) {
|
|
gSvg.setCurrentTime(0);
|
|
var test = testCases[i];
|
|
|
|
// Create animation elements
|
|
var anim = createAnim(test.attr);
|
|
|
|
// Run samples
|
|
for (var j = 0; j < test.times.length; j++) {
|
|
var times = test.times[j];
|
|
gSvg.setCurrentTime(times[0]);
|
|
checkSample(anim, times[1], times[0], i);
|
|
}
|
|
|
|
anim.parentNode.removeChild(anim);
|
|
}
|
|
|
|
// fallback to discrete for non-additive animation
|
|
var attr = { 'values': 'butt; round; square',
|
|
'attributeName': 'stroke-linecap',
|
|
'calcMode': 'linear',
|
|
'keyTimes': '0;.2;1',
|
|
'fill': 'remove' };
|
|
var anim = createAnim(attr);
|
|
var samples = [ [ 0, 'butt' ],
|
|
[ 1.9, 'butt' ],
|
|
[ 2.0, 'round' ],
|
|
[ 9.9, 'round' ],
|
|
[ 10, 'butt' ] // fill=remove so we'll never set it to square
|
|
];
|
|
for (var i = 0; i < samples.length; i++) {
|
|
var sample = samples[i];
|
|
gSvg.setCurrentTime(sample[0]);
|
|
checkLineCapSample(anim, sample[1], sample[0],
|
|
"[non-interpolatable fallback]");
|
|
}
|
|
anim.parentNode.removeChild(anim);
|
|
|
|
SimpleTest.finish();
|
|
}
|
|
|
|
function parseOk(str, extra)
|
|
{
|
|
var attr = { 'values': '0; 50; 100',
|
|
'keyTimes': str };
|
|
if (typeof(extra) == "object") {
|
|
for (name in extra) {
|
|
attr[name] = extra[name];
|
|
}
|
|
}
|
|
return {
|
|
'attr' : attr,
|
|
'times': [ [ 0, 0 ] ]
|
|
};
|
|
}
|
|
|
|
function parseNotOk(str, extra)
|
|
{
|
|
var result = parseOk(str, extra);
|
|
result.times = [ [ 0, -100 ] ];
|
|
return result;
|
|
}
|
|
|
|
function createAnim(attr)
|
|
{
|
|
const svgns = "http://www.w3.org/2000/svg";
|
|
var anim = document.createElementNS(svgns, 'animate');
|
|
anim.setAttribute('attributeName','cx');
|
|
anim.setAttribute('dur','10s');
|
|
anim.setAttribute('begin','0s');
|
|
anim.setAttribute('fill','freeze');
|
|
for (name in attr) {
|
|
anim.setAttribute(name, attr[name]);
|
|
}
|
|
return document.getElementById('circle').appendChild(anim);
|
|
}
|
|
|
|
function checkSample(anim, expectedValue, sampleTime, caseNum)
|
|
{
|
|
var msg = "Test case " + caseNum +
|
|
" (keyTimes: '" + anim.getAttribute('keyTimes') + "'" +
|
|
" calcMode: " + anim.getAttribute('calcMode') + "), " +
|
|
"t=" + sampleTime +
|
|
": Unexpected sample value:";
|
|
is(anim.targetElement.cx.animVal.value, expectedValue, msg);
|
|
}
|
|
|
|
function checkLineCapSample(anim, expectedValue, sampleTime, caseDescr)
|
|
{
|
|
var msg = "Test case " + caseDescr +
|
|
" (keyTimes: '" + anim.getAttribute('keyTimes') + "'" +
|
|
" calcMode: " + anim.getAttribute('calcMode') + "), " +
|
|
"t=" + sampleTime +
|
|
": Unexpected sample value:";
|
|
var actualValue =
|
|
window.getComputedStyle(anim.targetElement, null).
|
|
getPropertyValue('stroke-linecap');
|
|
is(actualValue, expectedValue, msg);
|
|
}
|
|
|
|
window.addEventListener("load", main, false);
|
|
]]>
|
|
</script>
|
|
</pre>
|
|
</body>
|
|
</html>
|