canvas学习笔记【2021.10.29】

今天跟着B站up主老板汽水加糖,学习了用canvas线性小球。

split()方法 按值分割字符串为数组的方法,如果有多个值,可以把它看成数组中的逗号。

例子:

let textArry = 'javaScript HTML PHP Canvas CSS ES6 vue React NodeJs'.split(' ');

console.log(textArry);

结果如下:

Array(9) [ "javaScript", "HTML", "PHP", "Canvas", "CSS", "ES6", "vue", "React", "NodeJs" ]

fillStyle继承问题 当你前面设置了fillStyle的时候,使用closepath()是不会清除fillStyle的,就像用画笔粘了颜色,你清除画布是没用的,因为没有改变画笔粘的颜色。利用这个继承机制,我们可以让小球的颜色和线的颜色一致。

连线问题 这个就是有x个小球,想让每一个小球都连接在一起,那么需要从第一个小球从0开始依次递增。比如5个球,第一个连接0个,第二个连接1个。。。第五个连接4个。

完整代码如下:

!
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        body{
            width: 98vw;
            height: 98vh;
        }
    </style>
</head>

<body>
    <canvas id="canvas">
        您的浏览器不支持canvas,请升级。
    </canvas>
</body>
<script>
    /** @type {HTMLCanvasElement} */
    var canvas = document.querySelector("#canvas");
    var ctx = canvas.getContext('2d');

    let w = document.documentElement.clientWidth-6;
    let h = document.documentElement.clientHeight-6;
    canvas.width=w;
    canvas.height=h;

    //第一步封装三个函数
    //画线
    function drawLine(x1, y1, x2, y2, color) {
        ctx.beginPath();
        ctx.moveTo(x1, y1);
        ctx.lineTo(x2, y2);
        ctx.strokeStyle = color || '#000';
        ctx.stroke();
        ctx.closePath();
    }
    //画字
    function drawText(text, x, y) {
        ctx.font = "28px 楷体";
        //fillStyle不会因为关闭路径而消失
        ctx.textAlign = "start";
        ctx.textBaseline = "middle";
        ctx.fillText(text, x, y);
    }
    //画球
    function drawBall(x, y, r, color) {
        ctx.beginPath();
        ctx.arc(x, y, r, 0, Math.PI * 2);
        ctx.fillStyle = color || '#000';
        ctx.fill();
        ctx.closePath();
    }
    //创建小球类
    function random(num) {
        return parseInt(Math.random() * num);//随机整数
    }
    function ball(text) {
        //随机生成的属性
        this.x = random(1096)+52;
        this.y = random(696)+52;
        this.r = random(40) + 50;
        this.color = "#" + parseInt(Math.random() * 0xffffff).toString(16);
        this.xSpeed = random(8 - 3) + 3;
        this.ySpeed = random(7 - 2) + 2;
        //外部传入的参数
        this.text=text;
    }
    //显示小球
    ball.prototype.show = function(){
        this.run();
        drawBall(this.x, this.y, this.r, this.color);
        drawText(this.text,this.x+this.r+5,this.y);//字的颜色和球颜色一样,是因为canvas保存了上一个的fillstyle
        
    }
    //碰撞检测
    ball.prototype.run = function(){
        if(this.x-this.r<=0||this.x+this.r>=w){
            this.xSpeed=-this.xSpeed;//this少不了
        }
        this.x=this.x + this.xSpeed;
        if(this.y-this.r<=0||this.y+this.r>=h){
            this.ySpeed=-this.ySpeed;
        }
        this.y=this.y+this.ySpeed;
    }
    //建立放文字的数组
    let textArry = 'javaScript HTML PHP Canvas CSS ES6 vue React NodeJs'.split(' ');
    console.log(textArry);
    //建立小球数组
    let ballArry =[];
    //创建5个小球并放在数组中
     for(var i =0;i<5;i++){
        var Ball = new  ball(textArry[i]);//记得用new创建新对象;传入text;数组还得放前面
        ballArry.push(Ball);
        Ball.show();
     }
     //更新坐标,让小球动起来
     let ballTimer = setInterval(function(){
       ctx.clearRect(0,0,w,h);
      for(var i =0;i<5;i++){
          ballArry[i].show();
      //两次for循环实现小球连线
        //原理:小球连接的个数为自身顺序-1,这可通过j来确定连接的个数
        for(var j =0;j<i;j++){
            //取出ballArry[i]前面的小球
            var frontBall = ballArry[j];
            drawLine(ballArry[i].x,ballArry[i].y,frontBall.x,frontBall.y,ballArry[i].color);
        }
    }
     },20)

    
</script>

</html>

上一篇:邀你看一场浪漫的烟火 -- canvas放烟花


下一篇:画点:canvas画折线图的小js