chromium/third_party/blink/web_tests/svg/as-background-image/resources/mouse-repel.svg

<?xml version="1.0" encoding="utf-8" standalone="no"?>
<svg onload="init(evt)" width="500" height="500" zoomAndPan="disable"
     xmlns="http://www.w3.org/2000/svg"
     xmlns:xlink="http://www.w3.org/1999/xlink">
    <script type="text/ecmascript"><![CDATA[
        var svgns = "http://www.w3.org/2000/svg";

        var width   = 6;
        var height  = 6;
        var r       = 15;
        var offset  = 30;
        var spacing = 20;
        var elems   = [];
        var midX    = (500 - ((width-1)  * spacing)) / 2;
        var midY    = (470 - ((height-1) * spacing)) / 2;
        var world;
        
        function init(e) {
            if ( window.svgDocument == null )
                svgDocument = e.target.ownerDocument;
            
            world = svgDocument.getElementById("world");
            world.setAttributeNS(
                null,
                "transform",
                "translate(" + midX + "," + midY + ")"
            );

            createElements();
        }

        function createElements() {
            for ( var y = 0; y < height; y++ ) {
                for ( var x = 0; x < width; x++ ) {
                    createElement(x, y);
                }
            }
        }

        function createElement(x, y) {
            var elem = svgDocument.createElementNS(svgns, "circle");
            var cx = x * spacing;
            var cy = y * spacing;
            var translate = "translate(" + cx + "," + cy + ")";
            
            elem.setAttributeNS(null, "cx", -offset);
            elem.setAttributeNS(null, "r", r);
            elem.setAttributeNS(null, "transform", translate);

            // store shape for later manipulation
            elems.push([elem, cx, cy]);

            // add shape to world
            world.appendChild(elem);
        }

        function update(e) {
            var length = elems.length;
            
            for ( var i = 0; i < length; i++ ) {
                var elem = elems[i];
                var dx = (e.clientX - elem[1]) - midX;
                var dy = (e.clientY - elem[2]) - midY;
                var angle = 180 * Math.atan2(dy, dx) / Math.PI;
                var rotate = "rotate(" + angle + ")";
                var translate = "translate(" + elem[1] + "," + elem[2] + ")";

                elem[0].setAttributeNS(
                    null,
                    "transform",
                    translate + " " + rotate
                );
            }
        }

        function changeColor(e) {
            var color = e.target.getAttributeNS(null, "stroke");

            world.setAttributeNS(null, "stroke", color);
            world.setAttributeNS(null, "fill", color);
        }
    ]]></script>
    <rect x="-16384" y="-16384" width="32767" height="32767"
          fill="none" pointer-events="fill" onmousemove="update(evt)"/>
    <rect x="10" y="10" width="478" height="478" rx="5" ry="5"
          fill="none" stroke="grey" stroke-width="2"/>
    <g id="world" pointer-events="none"
       stroke="rgb(192,124,158)" fill="rgb(192,124,158)" fill-opacity="0.5"/>

    <rect x="10" y="460" width="478" height="29" rx="5" ry="5"
          stroke="grey" stroke-width="2" fill="rgb(230,230,230)"/>
    <g fill-opacity="0.5" onclick="changeColor(evt)">
        <circle cx="25"  cy="475" r="10" stroke="rgb(192,124,158)" fill="rgb(192,124,158)"/>
        <circle cx="50"  cy="475" r="10" stroke="rgb(100,149,5)"   fill="rgb(100,149,5)"/>
        <circle cx="75"  cy="475" r="10" stroke="rgb(8,168,128)"   fill="rgb(8,168,128)"/>
        <circle cx="100" cy="475" r="10" stroke="rgb(240,96,18)"   fill="rgb(240,96,18)"/>
        <circle cx="125" cy="475" r="10" stroke="rgb(73,122,247)"  fill="rgb(73,122,247)"/>
        <circle cx="150" cy="475" r="10" stroke="rgb(240,203,0)"   fill="rgb(240,203,0)"/>
        <circle cx="175" cy="475" r="10" stroke="rgb(170,78,247)"  fill="rgb(170,78,247)"/>
    </g>

    <text x="485" y="485" font-size="10px" font-rendering="optimizeLegibility" fill="grey" text-anchor="end" pointer-events="none">Copyright 2004, Kevin Lindsey</text>
</svg>