<svg version="1.1" baseProfile="full" 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"> <!--======================================================================--> <!--= SVG 1.1 2nd Edition Test Case =--> <!--======================================================================--> <!--= Copyright 2009 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="SVGWG" author="Dean Jackson" status="accepted" version="$Revision: 1.7 $" testname="$RCSfile: painting-marker-02-f.svg,v $"> <d:testDescription xmlns="http://www.w3.org/1999/xhtml" href="http://www.w3.org/TR/SVG11/painting.html#Markers"> <p> Tests the rendering of markers, specifically property inheritance. For the four tests, there should be two identical paths with markers drawn. </p> <p> The top two tests examine the rendering of markers when the marker and the path referencing it share the same parent and all painting properties are specfied on that parent. The first test show inheritance of the 'fill' property and the second the inheritance of the 'paint' property. In both tests, the marker is painting using the same properties as the referencing object. Because of scaling transformations on the marker, the stroke on the second test is thinner than on the referencing object. </p> <p> The third and fourth tests examine the rendering of markers in a situation where the marker and referencing path do NOT share the same parent and painting properties are specified both on the parent of the marked path and on the contents of the marker itself. In both cases, the marker's parent specifies fill="green" stroke="blue" stroke-width="8". For the third test, the marker contents override with stroke="black". For the fourth test, the marker contents override with fill="black". In neither case should you see fill="orange" or stroke="blue" or "stroke="purple" on the markers as these properties are specified on the ancestor of the referencing object or the referencing object itself and thus shouldn't affect the marker. </p> </d:testDescription> <d:operatorScript xmlns="http://www.w3.org/1999/xhtml"> <p> Run the test. No interaction required. </p> </d:operatorScript> <d:passCriteria xmlns="http://www.w3.org/1999/xhtml"> <p> The path on the left is rendered using the marker elements. The path on the right is rendered using the equivalent SVG, showing what the marked path should look like. These should be identical and match the image to the right. </p> </d:passCriteria> </d:SVGTestCase> <title id="test-title">$RCSfile: painting-marker-02-f.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"> <defs> <clipPath id="overflowHiddenClip1" clipPathUnits="userSpaceOnUse"> <rect x="0" y="0" width="2" height="2"/> </clipPath> <clipPath id="overflowHiddenClip" clipPathUnits="userSpaceOnUse"> <rect x="0" y="0" width="4" height="4"/> </clipPath> </defs> <g fill="green"> <text x="125" y="30" font-size="14" fill="black">Marker Rendering Properties</text> <!-- ===================================================================== --> <!-- Fill property --> <!-- ===================================================================== --> <g fill="black" stroke="none" stroke-width="8"> <marker id="marker1" viewBox="0 0 10 10" markerWidth="2" markerHeight="2" refX="5" refY="5" markerUnits="strokeWidth"> <rect width="10" height="10"/> </marker> <text x="100" y="140" font-size="10" fill="black" stroke="none">Fill Property</text> <path marker-start="url(#marker1)" marker-mid="url(#marker1)" marker-end="url(#marker1)" d="M 30 60 L 80 60 L 80 110 Z"/> <!-- ===================================================================== --> <!-- Generate the equivalent SVG --> <!-- ===================================================================== --> <g transform="translate(120,0)"> <path d="M 30 60 L 80 60 L 80 110 Z"/> <g transform="translate(30,60) scale(8) translate(-1, -1)"> <g clip-path="url(#overflowHiddenClip1)"> <g transform="scale(0.2, 0.2)"> <rect width="10" height="10"/> </g> </g> </g> <g transform="translate(80,60) scale(8) translate(-1, -1)"> <g clip-path="url(#overflowHiddenClip1)"> <g transform="scale(0.2, 0.2)"> <rect width="10" height="10"/> </g> </g> </g> <g transform="translate(80,110) scale(8) translate(-1, -1)"> <g clip-path="url(#overflowHiddenClip1)"> <g transform="scale(0.2, 0.2)"> <rect width="10" height="10"/> </g> </g> </g> </g> </g> <!-- ===================================================================== --> <!-- Stroke property --> <!-- ===================================================================== --> <g fill="none" stroke="black" stroke-width="4"> <marker id="marker2" viewBox="0 0 20 20" markerWidth="4" markerHeight="4" refX="10" refY="10" markerUnits="strokeWidth"> <rect width="20" height="20"/> </marker> <text x="340" y="140" font-size="10" fill="black" stroke="none">Stroke Property</text> <path marker-start="url(#marker2)" marker-mid="url(#marker2)" marker-end="url(#marker2)" d="M 270 60 L 320 60 L 320 110 Z"/> <!-- ===================================================================== --> <!-- Generate the equivalent SVG --> <!-- ===================================================================== --> <g transform="translate(120,0)"> <path d="M 270 60 L 320 60 L 320 110 Z"/> <!-- ===================================================================== --> <!-- Generate the equivalent SVG --> <!-- ===================================================================== --> <g transform="translate(270,60) scale(4) translate(-2, -2)"> <g clip-path="url(#overflowHiddenClip)"> <g transform="scale(0.2, 0.2)"> <rect width="20" height="20"/> </g> </g> </g> <g transform="translate(320,60) scale(4) translate(-2, -2)"> <g clip-path="url(#overflowHiddenClip)"> <g transform="scale(0.2, 0.2)"> <rect width="20" height="20"/> </g> </g> </g> <g transform="translate(320, 110) scale(4) translate(-2, -2)"> <g clip-path="url(#overflowHiddenClip)"> <g transform="scale(0.2, 0.2)"> <rect width="20" height="20"/> </g> </g> </g> </g> </g> <!-- ===================================================================== --> <!-- Define marker element with parents setting painting properties --> <!-- ===================================================================== --> <g fill="green" stroke="blue" stroke-width="8"> <marker id="marker3" viewBox="0 0 20 20" markerWidth="4" markerHeight="4" refX="10" refY="10" markerUnits="strokeWidth"> <rect width="20" height="20" stroke="black"/> </marker> <marker id="marker4" viewBox="0 0 10 10" markerWidth="4" markerHeight="4" refX="5" refY="5" markerUnits="strokeWidth"> <rect width="10" height="10" fill="black" stroke-width="4"/> </marker> </g> <!-- ===================================================================== --> <!-- Parent and specified properties --> <!-- ===================================================================== --> <g fill="orange" stroke="blue"> <text x="90" y="270" font-size="10" fill="black" stroke="none">Mixed Properties</text> <path stroke="purple" stroke-width="4" marker-start="url(#marker3)" marker-mid="url(#marker3)" marker-end="url(#marker3)" d="M 30 190 L 80 190 L 80 240 Z"/> <!-- ===================================================================== --> <!-- Generate the equivalent SVG --> <!-- ===================================================================== --> <g transform="translate(120,0)"> <path stroke="purple" stroke-width="4" d="M 30 190 L 80 190 L 80 240 Z"/> <g fill="green" stroke="black" stroke-width="8"> <g transform="translate(30,190) scale(4) translate(-2, -2)"> <g clip-path="url(#overflowHiddenClip)"> <g transform="scale(.2, .2)"> <rect width="20" height="20"/> </g> </g> </g> <g transform="translate(80,190) scale(4) translate(-2, -2)"> <g clip-path="url(#overflowHiddenClip)"> <g transform="scale(0.2, 0.2)"> <rect width="20" height="20"/> </g> </g> </g> <g transform="translate(80,240) scale(4) translate(-2, -2)"> <g clip-path="url(#overflowHiddenClip)"> <g transform="scale(0.2, 0.2)"> <rect width="20" height="20"/> </g> </g> </g> </g> </g> </g> <g fill="orange" stroke="green"> <text x="340" y="270" font-size="10" fill="black" stroke="none">Mixed Properties</text> <path stroke="purple" stroke-width="4" marker-start="url(#marker4)" marker-mid="url(#marker4)" marker-end="url(#marker4)" d="M 270 190 L 320 190 L 320 240 Z"/> <!-- ===================================================================== --> <!-- Generate the equivalent SVG --> <!-- ===================================================================== --> <g transform="translate(120,0)"> <path stroke="purple" stroke-width="4" d="M 270 190 L 320 190 L 320 240 Z"/> <g fill="black" stroke="blue" stroke-width="4"> <g transform="translate(270,190) scale(4) translate(-2, -2)"> <g clip-path="url(#overflowHiddenClip)"> <g transform="scale(0.4, 0.4)"> <rect width="10" height="10"/> </g> </g> </g> <g transform="translate(320,190) scale(4) translate(-2, -2)"> <g clip-path="url(#overflowHiddenClip)"> <g transform="scale(0.4, 0.4)"> <rect width="10" height="10"/> </g> </g> </g> <g transform="translate(320,240) scale(4) translate(-2, -2)"> <g clip-path="url(#overflowHiddenClip)"> <g transform="scale(0.4, 0.4)"> <rect width="10" height="10"/> </g> </g> </g> </g> </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.7 $</text> </g> <rect id="test-frame" x="1" y="1" width="478" height="358" fill="none" stroke="#000000"/> <!-- 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>