Drawing an SVG image into a <canvas> that is not in the DOM draws the wrong region
[WebKit-https.git] / LayoutTests / svg / as-image / img-with-svg-resource-not-in-dom-no-size-and-drawImage.html
1 <body>
2 <p>This test shows a <code>&lt;canvas></code> element in which we draw the SVG image with the source rectangle set to fit the green rectangle from the SVG image and the destination rectangle as the bounds of the canvas element. In this example, the source <code>&lt;img></code> is not in the DOM and is not explicitly sized.</p>
3 <script type="text/javascript">
4
5 if (window.testRunner)
6     testRunner.waitUntilDone();
7
8 var width = 200;
9 var height = 200;
10 var svgData = 'data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 200 200"><rect width="200" height="200" fill="red" /><rect x="20" y="20" width="40" height="40" fill="green" /></svg>';
11
12 var canvas = document.body.appendChild(document.createElement("canvas"));
13 canvas.width = width;
14 canvas.height = height;
15
16 var image = new Image();
17 image.src = svgData;
18
19 if (image.complete)
20     draw();
21 else
22     image.addEventListener("load", draw);
23
24 function draw() {
25     canvas.getContext("2d").drawImage(image, 20, 20, 40, 40, 0, 0, width, height);
26     if (window.testRunner)
27         testRunner.notifyDone();
28 }
29
30 </script>
31 </body>