blob: c0a45e813f989072f4504c491438a164d21bc44c [file] [log] [blame]
<svg id="svg-root" width="100%" height="100%"
viewBox="0 0 480 360" xmlns="http://www.w3.org/2000/svg"
xmlns:xlink="http://www.w3.org/1999/xlink">
<!--======================================================================-->
<!--= Copyright 2008 World Wide Web Consortium, (Massachusetts =-->
<!--= Institute of Technology, European Research Consortium for =-->
<!--= Informatics and Mathematics (ERCIM), Keio University). =-->
<!--= All Rights Reserved. =-->
<!--= See http://www.w3.org/Consortium/Legal/. =-->
<!--======================================================================-->
<d:SVGTestCase xmlns:d="http://www.w3.org/2000/02/svg/testsuite/description/"
template-version="1.4" reviewer="DOH" author="AE" status="accepted"
version="$Revision: 1.2 $" testname="$RCSfile: animate-interact-pevents-04-t.svg,v $">
<d:testDescription xmlns="http://www.w3.org/1999/xhtml" href="http://www.w3.org/TR/SVG11/interact.html#PointerEventsProperty">
<p>Tests the pointer-events attribute with different painting values</p>
<p>
The 2nd and 3rd columns represent respectively rects with no fill/stroke and transparent fill/stroke.
The 4th column has visibility set to hidden.
</p>
<p>
The first row tests pointer-events="painted", i.e. event on fill and stroke that are set.
The second row tests pointer-events="fill", i.e. event on a fill that is set.
The third row tests pointer-events="stroke", i.e. even on a stroke that is et.
The fourth row tests pointer-events="all", i.e. event on fill and stroke that are set.
The fifth row tests pointer-events="none", i.e. no event.
</p>
</d:testDescription>
<d:operatorScript xmlns="http://www.w3.org/1999/xhtml">
<p>
Slowly move the mouse over the rectangles in each row while checking the pass criteria.
</p>
</d:operatorScript>
<d:passCriteria xmlns="http://www.w3.org/1999/xhtml">
<p>
The test is passed if the following conditions are met:
</p>
<ul>
<li>In the first row of squares, the fill and stroke of squares 1, 3 and 4 only must trigger a pale red rectangle to appear
over the squares on mouseover.</li>
<li>In the second row of squares, the fill only of all squares must trigger a pale red rectangle to appear
over the squares on mouseover.</li>
<li>In the third row of squares, the stroke only of all must trigger a pale red rectangle to appear
over the squares on mouseover.</li>
<li>In the fourth row of squares, the fill and stroke of all squares must trigger a pale red rectangle to appear
over the squares on mouseover.</li>
<li>In the fifth row of squares, nothing is to trigger on mouseover.</li>
</ul>
</d:passCriteria>
</d:SVGTestCase>
<title id="test-title">$RCSfile: animate-interact-pevents-04-t.svg,v $</title>
<defs>
<font-face
font-family="SVGFreeSansASCII"
unicode-range="U+0-7F">
<font-face-src>
<font-face-uri xlink:href="../resources/SVGFreeSans.svg#ascii"/>
</font-face-src>
</font-face>
</defs>
<g id="test-body-content" font-family="SVGFreeSansASCII,sans-serif" font-size="18">
<g text-anchor="middle">
<text id="display-title" x="240" y="25" fill="#555" font-size="12">
<tspan fill="black" font-size="10">Testing pointer-events</tspan> - pale RED rect should appear on mouseover.
</text>
<text id="comment-1" x="240" y="37" fill="#555" font-size="10">
2nd and 3rd columns represent respectively rects with no fill/stroke and transparent fill/stroke
</text>
</g>
<g transform="translate(0, 5)">
<g transform="translate(25, 50)">
<rect x="-10" y="-10" width="200" height="50" fill="red" fill-opacity="0">
<set attributeName="fill-opacity" to="0.4" begin="r60.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r60.mouseout"/>
<set attributeName="fill-opacity" to="0.4" begin="r61.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r61.mouseout"/>
<set attributeName="fill-opacity" to="0.4" begin="r62.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r62.mouseout"/>
<set attributeName="fill-opacity" to="0.4" begin="r63.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r63.mouseout"/>
</rect>
<rect id="r60" width="30" height="30" fill="blue" stroke-width="10" stroke="blue" fill-opacity=".3" stroke-opacity=".3" pointer-events="painted"/>
<rect x="50" width="30" height="30" fill="black" fill-opacity="0.1" stroke-width="10" stroke="black" stroke-opacity="0.1"/>
<rect id="r61" x="50" width="30" height="30" fill="none" stroke-width="10" stroke="none" fill-opacity=".3" stroke-opacity=".3" pointer-events="painted"/>
<rect x="100" width="30" height="30" fill="blue" fill-opacity="0.1" stroke-width="10" stroke="blue" stroke-opacity="0.1"/>
<rect id="r62" x="100" width="30" height="30" fill="blue" stroke-width="10" stroke="blue" fill-opacity="0" stroke-opacity="0" pointer-events="painted"/>
<rect x="145" y="-5" width="40" height="40" fill="none" stroke-width="1" stroke="blue" stroke-dasharray="3,3" stroke-opacity=".5"/>
<rect x="150" width="30" height="30" fill="none" stroke-width="1" stroke="blue" stroke-dasharray="1,1"/>
<rect x="155" y="5" width="20" height="20" fill="none" stroke-width="1" stroke="blue" stroke-dasharray="3,3" stroke-opacity=".5"/>
<rect id="r63" x="150" width="30" height="30" fill="blue" stroke-width="10" stroke="blue" visibility="hidden" pointer-events="painted"/>
<g font-size="12">
<text x="200" y="15">painted : </text>
<text x="200" y="30" fill="#777">fill and stroke of rects 1, 3 and 4 must trigger</text>
</g>
</g>
<g transform="translate(25, 100)">
<rect x="-10" y="-10" width="200" height="50" fill="red" fill-opacity="0">
<set attributeName="fill-opacity" to="0.4" begin="r70.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r70.mouseout"/>
<set attributeName="fill-opacity" to="0.4" begin="r71.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r71.mouseout"/>
<set attributeName="fill-opacity" to="0.4" begin="r72.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r72.mouseout"/>
<set attributeName="fill-opacity" to="0.4" begin="r73.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r73.mouseout"/>
</rect>
<rect id="r70" width="30" height="30" fill="blue" stroke-width="10" stroke="black" fill-opacity=".3" stroke-opacity=".3" pointer-events="fill"/>
<rect x="50" width="30" height="30" fill="blue" fill-opacity="0.1" stroke-width="10" stroke="black" stroke-opacity="0.1"/>
<rect id="r71" x="50" width="30" height="30" fill="none" stroke-width="10" stroke="none" fill-opacity=".3" stroke-opacity=".3" pointer-events="fill"/>
<rect x="100" width="30" height="30" fill="blue" fill-opacity="0.1" stroke-width="10" stroke="black" stroke-opacity="0.1"/>
<rect id="r72" x="100" width="30" height="30" fill="blue" stroke-width="10" stroke="black" fill-opacity="0" stroke-opacity="0" pointer-events="fill"/>
<rect x="145" y="-5" width="40" height="40" fill="none" stroke-width="1" stroke="black" stroke-dasharray="3,3" stroke-opacity=".5"/>
<rect x="150" width="30" height="30" fill="none" stroke-width="1" stroke="black" stroke-dasharray="1,1"/>
<rect x="155" y="5" width="20" height="20" fill="none" stroke-width="1" stroke="black" stroke-dasharray="3,3" stroke-opacity=".5"/>
<rect id="r73" x="150" width="30" height="30" fill="blue" stroke-width="10" stroke="black" visibility="hidden" pointer-events="fill"/>
<g font-size="12">
<text x="200" y="15">fill : </text>
<text x="200" y="30" fill="#777">fill of rects 1 to 4 must trigger</text>
</g>
</g>
<g transform="translate(25, 150)">
<rect x="-10" y="-10" width="200" height="50" fill="red" fill-opacity="0">
<set attributeName="fill-opacity" to="0.4" begin="r80.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r80.mouseout"/>
<set attributeName="fill-opacity" to="0.4" begin="r81.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r81.mouseout"/>
<set attributeName="fill-opacity" to="0.4" begin="r82.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r82.mouseout"/>
<set attributeName="fill-opacity" to="0.4" begin="r83.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r83.mouseout"/>
</rect>
<rect id="r80" width="30" height="30" fill="black" stroke-width="10" stroke="blue" fill-opacity=".3" stroke-opacity=".3" pointer-events="stroke"/>
<rect x="50" width="30" height="30" fill="black" fill-opacity="0.1" stroke-width="10" stroke="blue" stroke-opacity="0.1"/>
<rect id="r81" x="50" width="30" height="30" fill="none" stroke-width="10" stroke="none" fill-opacity=".3" stroke-opacity=".3" pointer-events="stroke"/>
<rect x="100" width="30" height="30" fill="black" fill-opacity="0.1" stroke-width="10" stroke="blue" stroke-opacity="0.1"/>
<rect id="r82" x="100" width="30" height="30" fill="black" stroke-width="10" stroke="blue" fill-opacity="0" stroke-opacity="0" pointer-events="stroke"/>
<rect x="145" y="-5" width="40" height="40" fill="none" stroke-width="1" stroke="blue" stroke-dasharray="3,3" stroke-opacity=".5"/>
<rect x="150" width="30" height="30" fill="none" stroke-width="1" stroke="blue" stroke-dasharray="1,1"/>
<rect x="155" y="5" width="20" height="20" fill="none" stroke-width="1" stroke="blue" stroke-dasharray="3,3" stroke-opacity=".5"/>
<rect id="r83" x="150" width="30" height="30" fill="black" stroke-width="10" stroke="blue" visibility="hidden" pointer-events="stroke"/>
<g font-size="12">
<text x="200" y="15">stroke : </text>
<text x="200" y="30" fill="#777">stroke of rects 1 to 4 must trigger</text>
</g>
</g>
<g transform="translate(25, 200)">
<rect x="-10" y="-10" width="200" height="50" fill="red" fill-opacity="0">
<set attributeName="fill-opacity" to="0.4" begin="r90.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r90.mouseout"/>
<set attributeName="fill-opacity" to="0.4" begin="r91.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r91.mouseout"/>
<set attributeName="fill-opacity" to="0.4" begin="r92.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r92.mouseout"/>
<set attributeName="fill-opacity" to="0.4" begin="r93.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r93.mouseout"/>
</rect>
<rect id="r90" width="30" height="30" fill="blue" stroke-width="10" stroke="blue" fill-opacity=".3" stroke-opacity=".3" pointer-events="all"/>
<rect x="50" width="30" height="30" fill="blue" fill-opacity="0.1" stroke-width="10" stroke="blue" stroke-opacity="0.1"/>
<rect id="r91" x="50" width="30" height="30" fill="none" stroke-width="10" stroke="none" fill-opacity=".3" stroke-opacity=".3" pointer-events="all"/>
<rect x="100" width="30" height="30" fill="blue" fill-opacity="0.1" stroke-width="10" stroke="blue" stroke-opacity="0.1"/>
<rect id="r92" x="100" width="30" height="30" fill="blue" stroke-width="10" stroke="blue" fill-opacity="0" stroke-opacity="0" pointer-events="all"/>
<rect x="145" y="-5" width="40" height="40" fill="none" stroke-width="1" stroke="blue" stroke-dasharray="3,3" stroke-opacity=".5"/>
<rect x="150" width="30" height="30" fill="none" stroke-width="1" stroke="blue" stroke-dasharray="1,1"/>
<rect x="155" y="5" width="20" height="20" fill="none" stroke-width="1" stroke="blue" stroke-dasharray="3,3" stroke-opacity=".5"/>
<rect id="r93" x="150" width="30" height="30" fill="blue" stroke-width="10" stroke="blue" visibility="hidden" pointer-events="all"/>
<g font-size="12">
<text x="200" y="15">all : </text>
<text x="200" y="30" fill="#777">stroke and fill of rects 1 to 4 must trigger</text>
</g>
</g>
<g transform="translate(25, 250)">
<rect x="-10" y="-10" width="200" height="50" fill="red" fill-opacity="0">
<set attributeName="fill-opacity" to="0.4" begin="r00.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r00.mouseout"/>
<set attributeName="fill-opacity" to="0.4" begin="r01.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r01.mouseout"/>
<set attributeName="fill-opacity" to="0.4" begin="r02.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r02.mouseout"/>
<set attributeName="fill-opacity" to="0.4" begin="r03.mouseover"/>
<set attributeName="fill-opacity" to="0" begin="r03.mouseout"/>
</rect>
<rect id="r00" width="30" height="30" fill="black" stroke-width="10" stroke="black" fill-opacity=".3" stroke-opacity=".3" pointer-events="none"/>
<rect x="50" width="30" height="30" fill="black" fill-opacity="0.1" stroke-width="10" stroke="black" stroke-opacity="0.1"/>
<rect id="r01" x="50" width="30" height="30" fill="none" stroke-width="10" stroke="none" fill-opacity=".3" stroke-opacity=".3" pointer-events="none"/>
<rect x="100" width="30" height="30" fill="black" fill-opacity="0.1" stroke-width="10" stroke="black" stroke-opacity="0.1"/>
<rect id="r02" x="100" width="30" height="30" fill="black" stroke-width="10" stroke="black" fill-opacity="0" stroke-opacity="0" pointer-events="none"/>
<rect x="145" y="-5" width="40" height="40" fill="none" stroke-width="1" stroke="black" stroke-dasharray="3,3" stroke-opacity=".5"/>
<rect x="150" width="30" height="30" fill="none" stroke-width="1" stroke="black" stroke-dasharray="1,1"/>
<rect x="155" y="5" width="20" height="20" fill="none" stroke-width="1" stroke="black" stroke-dasharray="3,3" stroke-opacity=".5"/>
<rect id="r03" x="150" width="30" height="30" fill="black" stroke-width="10" stroke="black" visibility="hidden" pointer-events="none"/>
<g font-size="12">
<text x="200" y="15">none : </text>
<text x="200" y="30" fill="#777">nothing is to trigger</text>
</g>
</g>
</g>
</g>
<g font-family="SVGFreeSansASCII,sans-serif" font-size="32">
<text id="revision" x="10" y="340" stroke="none"
fill="black">$Revision: 1.2 $</text>
</g>
<rect id="test-frame" x="1" y="1" width="478" height="358" fill="none" stroke="#000"/>
<!-- comment out this watermark once the test is approved
<g id="draft-watermark">
<rect x="1" y="1" width="478" height="20" fill="red" stroke="black" stroke-width="1"/>
<text font-family="SVGFreeSansASCII,sans-serif" font-weight="bold" font-size="20" x="240"
text-anchor="middle" y="18" stroke-width="0.5" stroke="black" fill="white">DRAFT</text>
</g> -->
</svg>