zoukankan      html  css  js  c++  java
  • 随机色块

    代码描述:

    <!doctype html>
    <html lang="en">
    <head>
    <meta charset="utf-8">
    <title>canvas运动</title>
    <style>

    </style>
    </head>
    <body>
    <canvas width="500" height="300" style="border:1px solid black" id="canvas"></canvas>

    <script>
    var canvas = document.getElementById('canvas');
    var ctx = canvas.getContext("2d");

    var father = {};
    father.children = [];
    /*
    * 增加孩子
    */
    father.add = function (child) {
    father.children.push(child);
    }

    /*
    * 矩形类
    */
    function Rect (x, y, w, h, style) {
    this.x = x;
    this.y = y;
    this.w = w;
    this.h = h;
    this.style = style;
    father.add(this);
    this.render = function () {

    }
    }

    // 生成一个随机位置、随机方向、随机速度、
    // 随机颜色的矩形
    function random () {
    var x = Math.random() * 400;
    var y = Math.random() * 200;
    var w = Math.random() * 40 + 20;
    var h = Math.random() * 40 + 20;
    var colorr = Math.ceil(Math.random() * 256) - 1;//Math.ceil向正取整数
    var colorg = Math.ceil(Math.random() * 256) - 1;
    var colorb = Math.ceil(Math.random() * 256) - 1;
    var color = "rgba("+colorr+","+colorg+","+colorb+",1)";
    var t = new Rect(x,y,w,h,color);
    t.dx = Math.ceil(Math.random()*2) - 1;
    t.dy = Math.ceil(Math.random()*2) - 1;
    t.speed = Math.ceil(Math.random()*3);
    t.render = function () {
    // left
    if (this.dx == 0) {
    this.x -= this.speed ;
    if (this.x < 0) {
    this.dx = 1;
    this.x = 0;
    };

    // right
    }else{
    this.x += this.speed;
    if (this.x > canvas.width - this.w) {
    this.dx = 0;
    this.x = canvas.width - this.w;
    };
    }

    // 上
    if (this.dy == 0) {
    this.y -= this.speed ;
    if (this.y < 0) {
    this.dy = 1;
    this.y = 0;
    };

    // 下
    }else{
    this.y += this.speed;
    if (this.y > canvas.height - this.h) {
    this.dy = 0;
    this.y = canvas.height - this.h;
    };
    }

    ctx.fillStyle = this.style;
    ctx.fillRect(this.x,this.y,this.w,this.h);
    }
    }

    // 生成10个随机矩形
    for (var i = 0; i < 20; i++) {
    random();
    };
    // 主时间轴计时器,控制所有对象的绘制
    setInterval(function () {
    ctx.clearRect(0,0,canvas.width,canvas.height);

    for (var i = 0; i < father.children.length; i++) {

    ctx.save();
    father.children[i].render();
    ctx.restore();
    };
    },10);


    </script>
    </body>
    </html>

  • 相关阅读:
    IOS-UI- UIScrollView 滚动视图(1)
    git实用攻略(二)
    git实用攻略
    一些技术发展和职业规划的建议
    Spring Data JPA 事务
    配置Slf4j依赖,桥接各种多个日志组件(排除commons-logging依赖的影响)
    Apache Shiro去掉URL中的JSESSIONID
    浏览器缓存介绍之sessionStorage、localStorage、Cookie
    【转】大数据批处理框架 Spring Batch全面解析
    ssl和https协议详解
  • 原文地址:https://www.cnblogs.com/patriot/p/5591735.html
Copyright © 2011-2022 走看看