重点突破——SVG技术动态随机绘制圆形

Posted 宁静致远

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了重点突破——SVG技术动态随机绘制圆形相关的知识,希望对你有一定的参考价值。

一、引言

在学习Canvas绘图技术时,做的是随机验证码的例子,在学习SVG绘图技术时,同样也有一个随机绘制的例子——动态随机绘制圆形。这个练习,即综合了多种SVG技术的知识点,又很具有艺术感,随机生成的任意一张图片都具有艺术之美。

 

二、要求

在SVG画布上随机的绘制30个实心圆形,大小随机、位置随机、填充颜色随机、透明度随机;点击某个圆形后,它慢慢变大/淡,直至从DOM树上删除。

 

三、实现

 

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style>
        body{
            text-align: center;
        }
        svg{
            background:#ddd;
        }
    </style>
</head>
<body>
   <h1>动态随机绘制SVG圆形</h1>
   <svg id="s9" width="500" height="400"></svg>
   <script>
       for(var i=0;i<30;i++){
          var c = document.createElementNS
          (\'http://www.w3.org/2000/svg\',\'circle\');
           c.setAttribute(\'r\',rn(10, 80));
           c.setAttribute(\'cx\',rn(0, 500));
           c.setAttribute(\'cy\',rn(0, 400));
           c.setAttribute(\'fill\',rc(0, 255));
           c.setAttribute(\'fill-opacity\',Math.random(0, 1));
           //坑:在定时器启动时,所有圆形都已经绘制好,所以此处c会指向最后一个创建好的圆
           c.onclick = function(){
               var that = this;//留存this,解决闭包形成的问题

               //为防止当前圆形再次被点击,应取消其事件监听
               that.onclick = null;

               //启用定时器,让圆形慢慢变大变淡
               var t = setInterval(function(){
                   var r = that.getAttribute(\'r\');
                   r *= 1.05;//注意:*=已经自动把字符串变成浮点数
                   that.setAttribute(\'r\',r);
                   var p = that.getAttribute(\'fill-opacity\');
                   p *= 0.9;
                   that.setAttribute(\'fill-opacity\',p);
                   if(p<0.0001){//当前圆形几乎已经看不见,停掉定时器
                      clearInterval(t);
                      that.parentNode.removeChild(that);
                   }
               },30);
           }
           s9.appendChild(c);

       }

       //random number:返回指定范围内的随机整数
       function rn(min,max){
           var n = Math.floor(Math.random()*(max-min)+min);
           return n;
       }
       //random color:返回指定范围内的随机颜色
       //形如:rgb(x,x,x)
       function rc(min, max){
           var r = rn(min, max);
           var g = rn(min, max);
           var b = rn(min, max);
           return `rgb(${r},${g},${b})`;
       }
   </script>
</body>
</html>

 

效果:


 注:转载请注明出处

以上是关于重点突破——SVG技术动态随机绘制圆形的主要内容,如果未能解决你的问题,请参考以下文章

重点突破——two.js模拟绘制太阳月亮地球转动

D3图表绘制

Python,OpenCV鼠标事件进行矩形圆形的绘制(随机颜色随机半径)

createjs 绘制圆形图片

[javascript svg fill stroke stroke-width circle 属性讲解] svg fill stroke stroke-width circle 属性 绘制圆形及引

如何使用数学随机绘制圆形图?