canvas绘制弹跳小球

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>canvas多弹跳小球</title>
</head>

<body>
<input type="button" id="clbtn" value="清除画布" style="border:1px solid #444;display:block;margin: 10px auto;" />
<canvas id="canvas" style="border:1px solid #444;display:block;margin: 10px auto;"></canvas>
</body>
<script>
window.onload=function(){
    var clbtn=document.getElementById("clbtn");
    var canvas=document.getElementById("canvas");
    var cxt=canvas.getContext("2d");
    canvas.width=1000;
    canvas.height=500;
    function ball(x,y,vx,colorindex){
        this.x=x;
        this.y=y;
        this.r=20;
        this.g=2;
        this.vx=vx;
        this.vy=-20;
        this.colorindex=colorindex;
        this.color=[‘red‘,‘blue‘,‘green‘,‘orange‘,‘yellow‘,‘pink‘];
    };
    var balls=[];

//    context.arc(centerx,centery,radius,startingAngle,endingAngle,anticlockwise=flase)
//                  圆心坐标    ,半径值   ,开始角度    ,结束角度,    顺逆时针(默认flase顺时针)
    canvas.onmousedown=function(){
        canvas.onmousemove=function(e){
            var e= event || ev;
            var x = e.clientX-canvas.offsetLeft;
            var y = e.clientY-canvas.offsetTop+document.body.scrollTop;

            balls.push(new ball(x,y,Math.floor(Math.random()*50-5),Math.floor(Math.random()*6+1)));

            }
        };
    canvas.onmouseup=function(){
        canvas.onmousemove=null;
        };

    setInterval(function(){
        cxt.clearRect(0,0,cxt.canvas.width,cxt.canvas.height);//清除画布20帧
        for(var i = 0 ;i<balls.length;i++)
        {
            balls[i].x += balls[i].vx;
            balls[i].y += balls[i].vy;
            balls[i].vy += balls[i].g;
            cxt.beginPath();
            cxt.arc(balls[i].x,balls[i].y,balls[i].r,0,2*Math.PI);
            cxt.closePath();
            cxt.fillStyle=balls[i].color[balls[i].colorindex];
            cxt.fill();
            cxt.strokeStyle=‘white‘;
            cxt.stroke();
            document.title = balls.length;

            if(  balls[i].y>=500 -  balls[i].r)
            {
                 balls[i].y = 500 -  balls[i].r;
                 balls[i].vy = - balls[i].vy*0.7;
            }
            if(  balls[i].x>=1000 -  balls[i].r || balls[i].x<=0-  balls[i].r)
            {
                
                 balls[i].vx = - balls[i].vx*0.7;
            }
        };

        },50);

clbtn.onclick=function(){
        cxt.clearRect(0,0,cxt.canvas.width,cxt.canvas.height);
        balls.splice(0,balls.length);//清空数组
        };
}

</script>
</html>

canvas绘制弹跳小球。

时间: 2024-10-27 11:44:05

canvas绘制弹跳小球的相关文章

用canvas绘制折线图

1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>用canvas绘制折线图</title> 6 </head> 7 <body> 8 <canvas id="cv"></canvas> 9 </body> 1

封装 用canvas绘制直线的函数--面向对象

1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>用面向对象的思想 封装 在canvas绘制直线的函数</title> 6 </head> 7 <body> 8 <canvas id="cv"></canvas> 9 &

canvas绘制时钟

<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>canvas绘制钟表</title> <style type="text/css"> #canvas{ /*border: 2px solid red;*/ display: block; margin: 0 auto; } </style> </

html5 Canvas绘制图形入门详解

html5,这个应该就不需要多作介绍了,只要是开发人员应该都不会陌生.html5是「新兴」的网页技术标准,目前,除IE8及其以下版本的IE浏览器之外,几乎所有主流浏览器(FireFox.Chrome.Opera.Safari.IE9+)都已经开始支持html5了.除此之外,在移动浏览器市场上,众多的移动浏览器也纷纷展开关于「html5的支持能力以及性能表现」的军备竞赛.html作为革命性的网页技术标准,再加上众多浏览器厂商或组织的鼎力支持,可以想见,html5将会成为未来网页技术的领头羊. ht

用h5中的canvas 绘制八卦图

1 <!doctype html> 2 <html> 3 <head> 4 <meta charset="UTF-8"> 5 <title>canvas绘制八卦图</title> 6 </head> 7 8 <body> 9 <canvas id="canvas" width="600" height="500"><

使用Canvas绘制图形的基本教程

原文地址:http://www.cnblogs.com/picaso/archive/2012/11/26/2789077.html HTML5火的正热,最近有个想法也是要用到HTML的相关功能,所以也要好好学习一把. 好好看了一下Canvas的功能,感觉HTML5在客户端交互的功能性越来越强了,今天看了一下Canvas绘图,下边是几个实例,记下以备后用. 1.使用Canvas绘制直线: <!doctype html> <html> <head> <meta ch

Canvas绘制线条模糊的解决方案

前段时间,做一个跨平台app项目,需要绘制分时图和K线图.找了很多开源的js的图表库,包括echarts.highcharts等等,都不是很满意,原因有2: 1.太臃肿,我实际上只要一个分时和一个K线图表,最多搭配几个线形图 2.不满足需求.主要就是分时图,国内玩的js图表库,几乎都没有分时图.都是用1分钟线的收盘价线来做的,和中国股民的使用习惯完全不搭界. 多年前有人开源了一个js绘制股票图形的库,叫做html54stock,图像表现上很符合中国人的使用习惯,但是也有问题: 1.封装不好,很多

用canvas绘制的饼状图,6等分,颜色随机

都说程序员懒,生活还是不能懒的,比如洗头.洗脸,当然也包括是分享咯.下面分享一下我用H5的新标签canvas绘制的饼状图,颜色是随机生成的,动态生成6等分,我还做了随机生成数据的, 配上文字,每份所占的比例就显而意见.,这点用在分析数据还是挺好的.图片如下; canvas 是 HTML5 提供的一个用于展示绘图效果的标签. canvas 原意画布, 帆布. 在 HTML 页面中用于展示绘图效果. 最早 canvas 是苹果提出的一个方案, 今天已经在大多数浏览器中实现.. 基本使用语法: 使用

canvas绘制清晰的方法

很早就开始使用canvas,包括自己绘制各种图形,以及作为画布提供给诸如echarts,当canvas绘制细线条,特别是关于文字绘制会出现很模糊或者锯齿的感觉. 1 <canvas ref="canvas" width="200" height="200"/> 正常情况下一般都是这么写的,但是实际上对于canvas来说,这个canvas.width canvas.height 与canvas.style.width canvas.st