summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/conformance-checkers/html-svg/masking-path-07-b-isvalid.html
blob: 0412497f072b1f691d5a78173862e66c65e985fe (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
<!DOCTYPE html>
<html lang='en'>
<head>
 <title>masking-path-07-b-manual.svg</title>
 <meta charset='utf-8'>
</head>
<body>
 <h1>Source SVG: masking-path-07-b-manual.svg</h1>
<svg version="1.1" baseProfile="basic" 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/.                          =-->
  <!--======================================================================-->
  
  <title id="test-title">$RCSfile: masking-path-07-b.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="clipCircle1">
        <circle id="c1" cx="100" cy="100" r="50"/>
      </clipPath>

      <clipPath id="clipCircle2">
        <circle id="c2" cx="150" cy="150" r="50"/>
      </clipPath>

      <clipPath id="clipPath1">
        <path id="p1" d="M10 10l100 0 0 100 -100 0ZM50 50l40 0 0 40 -40 0Z" clip-rule="evenodd"/>
      </clipPath>

      <!-- "If a valid 'clip-path' reference is placed on one of the children of a 'clipPath' element, 
		      then the given child element is clipped by the referenced clipping path before OR'ing the 
			  silhouette of the child element with the silhouettes of the other child elements." -->
      <clipPath id="clipRects1">
        <rect x="50" y="30" width="25" height="100"/>
        <rect x="25" y="50" width="10" height="10" clip-path="url(#clipTwoCircles)"/>
      </clipPath>

      <!-- Test use in a clipPath -->
      <clipPath id="clipTwoCircles">
        <use xlink:href="#c1"/>
        <use xlink:href="#c2"/>
      </clipPath>

      <clipPath id="clipInClip1">
        <use xlink:href="#c2" clip-path="url(#clipCircle1)"/>
        <use xlink:href="#p1"/>
      </clipPath>

      <clipPath id="clipOnClip1" clip-path="url(#clipCircle1)">
        <use xlink:href="#c2"/>
        <use xlink:href="#p1"/>
      </clipPath>

      <pattern patternUnits="userSpaceOnUse" id="pattern" x="0" y="0" width="20" height="20">
        <rect x="0" y="0" width="10" height="10" fill="gray"/>
        <rect x="10" y="10" width="10" height="10" fill="gray"/>
      </pattern>
    </defs>

    <rect x="20" y="70" width="210" height="210" fill="url(#pattern)" stroke="black" stroke-width="4"/>
		<rect x="250" y="70" width="210" height="210" fill="url(#pattern)" stroke="black" stroke-width="4"/>

    <text x="240" y="2em" text-anchor="middle">Test clip unions and intersections</text>

    <g transform="translate(20, 70)">
      <g id="subtest1">
        <use xlink:href="#p1" fill="red" fill-rule="evenodd"/>
        <use xlink:href="#c2" fill="red" clip-path="url(#clipCircle1)"/>
        <use xlink:href="#c1" fill="red" clip-path="url(#clipCircle2)"/>

        <rect width="200" height="200" fill="blue" clip-path="url(#clipInClip1)"/>

        <use xlink:href="#c2" fill="none" clip-path="url(#clipCircle1)" stroke="black"/>
        <use xlink:href="#c1" fill="none" clip-path="url(#clipCircle2)" stroke="black"/>
        <use xlink:href="#p1" fill="none" stroke="black"/>
      </g>

      <g id="subtest2" transform="translate(230,0)">
        <g clip-path="url(#clipCircle1)">
          <use xlink:href="#c2" fill="red"/>
          <use xlink:href="#p1" fill="red" fill-rule="evenodd"/>
        </g>

        <rect width="300" height="300" fill="blue" clip-path="url(#clipOnClip1)"/>

        <use xlink:href="#c1" fill="none" stroke="black"/>
      </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.11 $</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>
</body>
</html>