SVG點擊實現動態放大的圓效果

2018-6-1 10:45| 作者: 螞蟻小編| 查看: 5178| 評論: 0|來自: 螞蟻部落

分享一段代碼實例,它利用svg實現了點擊生成動態放大的圓效果。

代碼實例如下:

[HTML] 純文本查看 復制代碼运行代码
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<meta name="author" content="http://www.arpjr.tw/" />
<title>螞蟻部落</title>
</head>
<body>
<svg id="svg" width="500px" height="500px" style="background-color: #f2f2f2"></svg>
<script>
var svg = document.getElementById("svg");
svg.onclick = function(event) {
  var circle = document.createElementNS("http://www.w3.org/2000/svg", "circle");
  circle.setAttribute("cx", event.offsetX);
  circle.setAttribute("cy", event.offsetY);
  circle.setAttribute("r", 10);
  circle.setAttribute("fill", randomColor());
  circle.setAttribute("opacity", 1);
  svg.appendChild(circle);
  var t = setInterval(function() {
    var r = parseInt(circle.getAttribute("r"));
    r++;
    circle.setAttribute("r", r);
    var opacity = parseFloat(circle.getAttribute("opacity"));
    opacity -= 0.005;
    circle.setAttribute("opacity", opacity);
    if (opacity <= 0) {
      circle.parentNode.removeChild(circle);
      clearInterval(t);
    }
  }, 10);
}
function randomColor() {
  var r = Math.floor(Math.random() * 256);
  var g = Math.floor(Math.random() * 256);
  var b = Math.floor(Math.random() * 256);
  return "rgb(" + r + "," + g + "," + b + ")";
}
</script>
</body>
</html>

鮮花

握手

雷人

路過

雞蛋
返回頂部
大圣捕鱼2 3d杀6码走势图 上海快三基本走势 齐鲁风采中奖号码 网球王子沙滩排球 香港王中王论坛资枓香港正 体彩20选5中奖概率 新2彩娱乐平台 三分彩app下线 吉林时时有漏洞么 35选7中奖号码 广西今日快三 中福在线投注卡200规定 足球推荐 安徽快3开奖号码今天 安徽省体彩兑奖中心 特马用什么公式算