js通过canvas实现动画效果

博客探讨了在JavaScript中利用Canvas实现动画效果时的重要注意事项。提到Canvas的width和height属性直接影响坐标系尺寸,而CSS设置的宽高仅改变显示比例,不会影响坐标值,可能导致图像拉伸。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

有个要注意的点,就是canvas标签本身自带width与height属性,设置此属性可以直接更改canvas坐标系的宽与高,而在css里设置宽高,只是把canvas坐标系拉伸了,坐标值不变,显示出来的图像也都被拉伸了。

<html>
<body>
<canvas id = "canvas" width = "800px" height="600px"></canvas>
<script type="text/javascript">
var canvas = document.getElementById("canvas");
var parti = [];
function loop()
{
    CreateParticles();
    UpdateParticles();
    KillParticles();
    DrawParticles();
}

function CreateParticles()
{
    var partis = {x:Math.random()*canvas.clientWidth, y:0 , color:"white", radius:2 + Math.random()* 5 ,speed:2+Math.random()*5};
    if(parti.length < 80)
    {
        parti.push(partis);
    }
}

function UpdateParticles()
{
    for(var i in parti)
    {
        parti[i].y += parti[i].speed;
    }
}

function KillParticles()
{
    for(var i in parti)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值