zoukankan      html  css  js  c++  java
  • 【重点突破】——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>

    效果:


     注:转载请注明出处

  • 相关阅读:
    Docker为PHP安装gd扩展
    git修改远端仓库地址
    Oracle11g R2学习系列 之四Maven+Struts+Spring实验
    Oracle11g R2学习系列 之三教程选择
    Oracle11g R2学习系列 之二基本概念和环境介绍
    西雅图之行
    Oracle11g R2学习系列 之一安装篇
    Startcom SSL证书申请 IIS设置 配置 攻略
    StartCom 申请 SSL 证书及 Nginx HTTPS 支持配置全攻略
    没有了SA密码,无法Windows集成身份登录,DBA怎么办?
  • 原文地址:https://www.cnblogs.com/ljq66/p/7623809.html
Copyright © 2011-2022 走看看