简单的canvas动画原理

Posted 面条请不要欺负汉堡

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了简单的canvas动画原理相关的知识,希望对你有一定的参考价值。

简单的canvas动画原理一般就是如下步骤:

setInterval(
   function()
       draw(ctx);
       update(canvas.width,canvas.height);
   ,
   50
);  

深入了解setInterval

一. draw(ctx);
1.清空 canvas
除非接下来要画的内容会完全充满 canvas (例如背景图),否则你需要清空所有。最简单的做法就是用 clearRect 方法。
2.保存 canvas 状态
如果你要改变一些会改变 canvas 状态的设置(样式,变形之类的),又要在每画一帧之时都是原始状态的话,你需要先保存一下。ctx.save();
3.绘制被动画的图形
绘制要被动画的图形
4.恢复 canvas 状态
如果已经保存了 canvas 的状态,可以先恢复它(ctx.restore();),然后重绘下一帧。

.update(canvas.width,canvas.height)

      改变动画的原理是:位置的改变(运用物理学原理,初始化加速度vx(x轴的加速度)vyy轴的加速度))加速度可以是随机vx:Math.random()*5+10,vy:Math.random()*5+10

1.首先令图形的位置等于加速度

x +=vx;y+=vy;

2.根据你的需求进行判断

 2.1图形在运动时不能超出canvas画布的宽

if(x-图形的半径<=0)

  vx=-vx;

 x=半径;

if(x+图形的半径<=canvas.width)

  vx=-vx;

x= canvas.width-半径;


以上是关于简单的canvas动画原理的主要内容,如果未能解决你的问题,请参考以下文章

Canvas 动画原理与 fabric 实现

HTML5 Canvas动画效果实现原理

怎么设置canvas动画为背景

画布,使用正弦波沿方形路径为形状设置动画

canvas 动画循环

canvas动画——粒子系统